
*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:'Poppins',sans-serif;
}

html{
scroll-behavior:smooth;
}

body{
scroll-snap-type:none;
overflow-y:scroll;
overflow-x:hidden;
background:#0f172a;
color:white;
position:relative;
}

body.preloader-active{
overflow:hidden;
}

.page-preloader{
position:fixed;
inset:0;
z-index:5000;
pointer-events:auto;
opacity:1;
visibility:visible;
transition:opacity 0.35s ease, visibility 0.35s ease;
background:
radial-gradient(120% 100% at 50% -10%, rgb(35 106 68 / 22%) 0%, rgb(11 29 44 / 0%) 55%),
linear-gradient(180deg, rgb(7 18 28 / 98%) 0%, rgb(8 24 36 / 96%) 100%);
overflow:hidden;
}

.page-preloader.is-hidden{
opacity:0;
visibility:hidden;
pointer-events:none;
}

.page-preloader-leaves{
position:absolute;
inset:0;
}

.page-preloader-leaf{
position:absolute;
left:var(--x);
top:-90px;
width:var(--size);
height:auto;
opacity:0.95;
filter:drop-shadow(0 5px 8px rgb(0 0 0 / 45%));
animation:preloader-leaf-fall var(--dur) linear infinite;
animation-delay:var(--delay);
will-change:transform, top, opacity;
}

@keyframes preloader-leaf-fall{
0%{
transform:translate3d(0,-12vh,0) rotate(0deg);
opacity:0;
}
12%{
opacity:1;
}
86%{
opacity:1;
}
100%{
transform:translate3d(var(--drift),108vh,0) rotate(540deg);
opacity:0;
}
}

/* HEADER */

header{position:fixed;top:0;width:100%;height:70px;background: rgb(0 0 0 / 0%);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:space-between;padding: 10px 40px;z-index:1000;}

.logo{
font-weight:700;
font-size:20px;
color:#4ade80;
width:0;
overflow:hidden;
margin-right:0;
transition:width 0.25s ease, margin-right 0.25s ease;
flex-shrink:0;
}

body.show-small-logo .logo{
width:74px;
margin-right:6px;
}

.header-left{
display:flex;
align-items:center;
gap:14px;
}

.online-status{
display:inline-flex;
align-items:center;
gap:10px;
color:#fcebc5;
font-family:'Press Start 2P',cursive;
text-shadow:0 1px 2px rgb(0 0 0 / 45%);
white-space:nowrap;
}

.online-status-icon{
width:28px;
height:28px;
object-fit:contain;
animation:status-blink 1.4s ease-in-out infinite;
}

.online-status-text{
display:flex;
flex-direction:column;
gap:4px;
line-height:1;
}

.online-status-count{
font-size:14px;
}

.online-status-host{
font-size:10px;
opacity:0.9;
letter-spacing:0.2px;
}

@keyframes status-blink{
0%,100%{opacity:1;filter:drop-shadow(0 0 0 rgb(170 255 190 / 0));}
50%{opacity:0.75;filter:drop-shadow(0 0 8px rgb(170 255 190 / 70%));}
}

nav a{display:inline-flex;align-items:center;justify-content:center;min-width:130px;height:44px;padding:0 18px;text-decoration:none;color:#fcebc5;font-family:'Press Start 2P',cursive;font-size: 13px;line-height:1;letter-spacing:0.4px;text-transform:uppercase;transition:0.3s;background-image:url('../img/menu-item-buttons.png');background-repeat:no-repeat;background-size:100% 100%;background-position:center;text-shadow:0 1px 2px rgb(0 0 0 / 40%);}

.home-link{
min-width:46px;
width:46px;
height:46px;
padding:0;
background-image:url('../img/homebutton.png');
background-repeat:no-repeat;
background-size:contain;
background-position:center;
}

.play-link{
background-image:url('../img/menu-item-play-button.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
min-width:140px;
}

nav a:not(.home-link):hover{
color:#fcebc5;
transform:translateY(-2px) scale(1.04);
filter:brightness(1.08);
}

nav a:not(.home-link):not(.play-link):hover,
nav a:not(.home-link):not(.play-link):focus-visible{
background-image:url('../img/menu-item-buttons-selected.png');
}

.desktop-nav a:not(.home-link):not(.play-link)[aria-current="page"],
.mobile-nav-links a:not(.home-link):not(.play-link)[aria-current="page"]{
background-image:url('../img/menu-item-buttons-selected.png') !important;
}

nav a.home-link:hover{
transform:translateY(-2px) scale(1.04);
filter:brightness(1.08);
}

nav{
display:flex;
align-items:center;
gap:14px;
}

.nav-online-status{
display:inline-flex;
align-items:center;
justify-content:center;
min-width:160px;
height:44px;
padding:0 14px;
font-family:'Press Start 2P',cursive;
font-size:11px;
line-height:1;
letter-spacing:0.2px;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 40%);
background:rgb(8 24 36 / 82%);
border:1px solid rgb(252 235 197 / 34%);
border-radius:10px;
}

.mobile-nav-online-status{
min-width:100%;
height:42px;
margin:2px 0;
}

.mobile-nav-toggle{
display:none;
width:84px;
height:84px;
border:none;
border-radius:0;
background:transparent;
align-items:center;
justify-content:center;
cursor:pointer;
padding:0;
}

.mobile-nav-toggle-icon{
width:48px;
height:48px;
object-fit:contain;
}

.mobile-nav{
display:none;
}

.vote-fixed-btn{
position:fixed;
right:18px;
bottom:18px;
width:188px;
height:66px;
display:inline-flex;
align-items:center;
justify-content:center;
text-decoration:none;
font-family:'Press Start 2P',cursive;
font-size:14px;
line-height:1;
letter-spacing:0.3px;
text-transform:uppercase;
color:#fff7dd;
text-shadow:0 2px 4px rgb(0 0 0 / 55%);
background-image:url('../img/vote-button.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
z-index:1800;
transition:transform 0.2s ease, filter 0.2s ease;
animation:vote-shake 9s ease-in-out infinite;
}

.vote-fixed-btn:hover{
transform:translateY(-2px) scale(1.03);
filter:brightness(1.08);
}

@keyframes vote-shake{
0%, 72%, 100%{transform:translateX(0) rotate(0deg);}
74%{transform:translateX(-2px) rotate(-1.2deg);}
76%{transform:translateX(3px) rotate(1.1deg);}
78%{transform:translateX(-3px) rotate(-1deg);}
80%{transform:translateX(2px) rotate(0.8deg);}
82%{transform:translateX(0) rotate(0deg);}
}

/* SECTIONS */

.section{
/*height:100vh;*/
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
text-align:center;
padding:80px 20px;
}

.section-divider{
width:100%;
aspect-ratio:1958 / 176;
background-image:url('../img/divider-home.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
position:relative;
z-index:5;
pointer-events:none;
margin-top:clamp(-96px,-5.5vw,-52px);
margin-bottom:clamp(-18px,-1.2vw,-8px);
}

.floating-elements{
position:absolute;
inset:0;
pointer-events:none;
z-index:900;
}

.floating-el{
position:absolute;
width:clamp(168px,21vw,330px);
height:auto;
opacity:0.9;
filter:drop-shadow(0 8px 14px rgb(0 0 0 / 26%));
animation:float-drift 6.5s ease-in-out infinite;
will-change:transform;
}

.floating-el-1{top:120vh;left:1%;animation-delay:-1.2s;}
.floating-el-2{top:266vh;right:1%;animation-delay:-2.8s;}
.floating-el-3{top:380vh;left:2%;animation-delay:-0.4s;}
.floating-el-4{top:484vh;right:2%;animation-delay:-3.4s;}
.floating-el-5{top:530vh;left:1%;animation-delay:-1.9s;}

@keyframes float-drift{
0%,100%{margin-top:0;filter:drop-shadow(0 8px 14px rgb(0 0 0 / 26%));}
50%{margin-top:-10px;filter:drop-shadow(0 12px 18px rgb(0 0 0 / 30%));}
}

.section h1{
font-size:60px;
margin-bottom:20px;
font-family:'Press Start 2P',cursive;
line-height:1.2;
letter-spacing:0.3px;
text-shadow:0 2px 5px rgb(0 0 0 / 65%);
}

.section p{
max-width:600px;
opacity:0.8;
}

.section-subtext{
max-width:860px;
margin:-6px auto 36px;
color:#eaf3ff;
font-size:clamp(15px,1.2vw,20px);
font-weight:400;
line-height:1.45;
text-shadow:0 1px 3px rgb(0 0 0 / 55%);
opacity:0.95;
}
.maplewood-logo-header{
width:550px;
animation:logo-float 4.5s ease-in-out infinite;
filter:drop-shadow(0 8px 22px rgb(0 0 0 / 30%));
}
.maplewood-logo-small{
  width: 74px;
  top: 4px;
  position: relative;
  opacity:0;
  visibility:hidden;
  transform:translateY(-8px);
  transition:opacity 0.25s ease, transform 0.25s ease, visibility 0.25s ease;
}

body.show-small-logo .maplewood-logo-small{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

/* HERO */

.hero{
background:linear-gradient(120deg,#22c55e,#4ade80);
color:#022c22;
background-image: url('../img/background-image-maplewood.png');
background-repeat:no-repeat;
background-size:cover;
background-position:center top;
min-height:100vh;
min-height:100svh;
position:relative;
overflow:hidden;
}

.hero > *{
position:relative;
z-index:2;
}

.hero-particles{
position:absolute;
inset:0;
z-index:1;
pointer-events:none;
}

.hero-particles span{
position:absolute;
left:var(--x);
bottom:-30px;
width:var(--size);
height:var(--size);
border-radius:50%;
background:rgb(255 255 255 / 55%);
box-shadow:0 0 12px rgb(255 255 255 / 45%);
animation:particle-rise var(--dur) linear infinite;
animation-delay:var(--delay);
}

.hero-banner-text{
width:min(92vw,980px);
margin-top:10px;
margin-bottom:16px;
padding:10px 18px;
display:flex;
align-items:center;
justify-content:center;
}

.hero-banner-text p{
max-width:860px;
margin:0;
color:#fff8e8;
opacity:1;
font-family:'Poppins',sans-serif;
font-size:clamp(17px,1.35vw,22px);
font-weight:600;
line-height:1.5;
letter-spacing:0.1px;
text-shadow:0 2px 4px rgb(0 0 0 / 75%);
text-wrap:balance;
}

@keyframes logo-float{
0%,100%{transform:translateY(0);}
50%{transform:translateY(-10px);}
}

@keyframes particle-rise{
0%{
transform:translate3d(0,0,0) scale(0.8);
opacity:0;
}
15%{
opacity:0.9;
}
85%{
opacity:0.6;
}
100%{
transform:translate3d(0,-110vh,0) scale(1.15);
opacity:0;
}
}

.join-btn{
margin-top:30px;
padding:15px 35px;
border:none;
border-radius:30px;
background:#022c22;
color:white;
font-size:18px;
cursor:pointer;
transition:0.3s;
}

.join-btn:hover{
transform:scale(1.1);
background:#065f46;
}

.hero-action-buttons{
margin-top:30px;
display:flex;
gap:18px;
align-items:center;
justify-content:center;
flex-wrap:wrap;
}

.hero-action-btn{
display:inline-flex;
align-items:center;
justify-content:center;
flex-direction:column;
min-width:280px;
height:88px;
padding:0 20px;
text-decoration:none;
color:#fcebc5;
font-family:'Press Start 2P',cursive;
font-size:17px;
font-weight:700;
letter-spacing:0.4px;
text-transform:uppercase;
text-shadow:0 1px 2px rgb(0 0 0 / 45%);
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
transition:transform 0.2s ease, filter 0.2s ease;
}

.hero-action-btn span{
display:block;
font-family:'Press Start 2P',cursive;
font-size:1em;
line-height:1.15;
}

.hero-action-btn small{
display:block;
margin-top:2px;
font-family:'Poppins',sans-serif;
font-size:11px;
font-weight:600;
line-height:1.1;
letter-spacing:0.2px;
text-transform:none;
opacity:0.95;
}

.hero-action-btn-server{
background-image:url('../img/join-server-button.png');
}

.hero-action-btn-community{
background-image:url('../img/join-community-button.png');
}

.hero-action-btn:hover{
transform:translateY(-2px) scale(1.03);
filter:brightness(1.08);
}

/* FEATURES */

.features{
position:relative;
overflow:hidden;
background:
radial-gradient(circle at 12% 18%, rgb(252 235 197 / 16%), transparent 34%),
radial-gradient(circle at 85% 75%, rgb(86 193 255 / 14%), transparent 38%),
linear-gradient(165deg, #12293a 0%, #0a1c2c 52%, #071523 100%);
}

.features::before{
content:"";
position:absolute;
inset:0;
background:linear-gradient(0deg, rgb(3 10 16 / 38%), rgb(3 10 16 / 18%));
pointer-events:none;
z-index:0;
}

.features > *{
position:relative;
z-index:1;
}

.features-layout{
width:min(94vw,1300px);
display:flex;
flex-direction:column;
gap:30px;
}

.features-title{
text-align:center;
margin-bottom:6px;
}

.feature-rows{
width:100%;
display:flex;
flex-direction:column;
gap:48px;
}

.feature-row{
display:grid;
grid-template-columns:minmax(0,1fr) minmax(0,1fr);
gap:22px;
align-items:stretch;
}

.feature-row-survival-banner{
grid-template-columns:1fr;
}

.feature-row-grief-banner{
grid-template-columns:1fr;
}

.feature-row-worldgen-banner{
grid-template-columns:1fr;
}

.feature-survival-banner{
--guide-banner-image:url('../img/survival.png');
--guide-banner-height:320px;
margin:0;
border-radius:16px;
border:1px solid rgb(252 235 197 / 20%);
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
}

.feature-survival-banner::before{
background-position:center 38%;
}

.feature-survival-banner::after{
background:
linear-gradient(102deg, rgb(6 16 26 / 90%) 0%, rgb(9 25 40 / 84%) 36%, rgb(12 34 52 / 48%) 62%, rgb(12 34 52 / 0%) 84%),
linear-gradient(180deg, rgb(6 16 26 / 18%) 0%, rgb(6 16 26 / 66%) 100%);
}

.feature-survival-banner .guide-page-banner-content{
max-width:none;
}

.feature-grief-banner{
--guide-banner-image:url('../img/griefprevention.png');
--guide-banner-height:305px;
margin:0;
border-radius:16px;
border:1px solid rgb(252 235 197 / 20%);
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
}

.feature-grief-banner::before{
background-position:center 34%;
}

.feature-grief-banner::after{
background:
linear-gradient(102deg, rgb(5 14 24 / 94%) 0%, rgb(8 22 34 / 88%) 38%, rgb(11 31 47 / 58%) 64%, rgb(11 31 47 / 6%) 86%),
linear-gradient(180deg, rgb(6 16 26 / 26%) 0%, rgb(6 16 26 / 74%) 100%);
}

.feature-grief-banner .guide-page-banner-content{
max-width:none;
}

.feature-worldgen-banner{
--guide-banner-image:url('../img/wordgenerator.png');
--guide-banner-height:335px;
margin:0;
border-radius:16px;
border:1px solid rgb(252 235 197 / 20%);
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
}

.feature-worldgen-banner::before{
background-position:center 42%;
}

.feature-worldgen-banner::after{
background:
linear-gradient(102deg, rgb(6 16 26 / 88%) 0%, rgb(9 25 40 / 80%) 34%, rgb(12 34 52 / 42%) 62%, rgb(12 34 52 / 0%) 86%),
linear-gradient(180deg, rgb(6 16 26 / 16%) 0%, rgb(6 16 26 / 60%) 100%);
}

.feature-worldgen-banner .guide-page-banner-content{
max-width:none;
}

.feature-banner-with-character .guide-page-banner-content{
max-width:none;
padding-right:min(28vw,280px);
}

.feature-banner-character{
position:absolute;
right:0;
bottom:0;
width:clamp(120px,19vw,240px);
height:auto;
z-index:3;
pointer-events:none;
}

@media (max-width:700px){
.feature-banner-with-character .guide-page-banner-content{
padding-right:132px;
}

.feature-banner-character{
width:104px;
}
}

.feature-row.is-reverse .feature-text{
order:2;
}

.feature-row.is-reverse .feature-media{
order:1;
}

.feature-text{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
box-shadow:0 8px 18px rgb(0 0 0 / 30%), inset 0 0 0 1px rgb(255 255 255 / 6%);
border-radius:16px;
padding:24px;
text-align:left;
display:flex;
flex-direction:column;
justify-content:center;
}

.feature-text h3{
margin:0 0 10px;
font-family:'Press Start 2P',cursive;
font-size:18px;
line-height:1.25;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.feature-text p{
margin:0;
max-width:none;
color:#e9f3ff;
opacity:0.95;
font-size:16px;
line-height:1.5;
}

.feature-text.has-extra-image{
justify-content:flex-start;
position:relative;
padding-bottom:96px;
}

.feature-text-extra-image{
width:44%;
max-width:210px;
display:block;
margin-top:0;
border-radius:0;
position:absolute;
right:12px;
bottom:10px;
pointer-events:none;
}

.feature-media{
min-height:240px;
border-radius:16px;
background:
linear-gradient(135deg,rgb(252 235 197 / 10%),rgb(86 193 255 / 10%)),
rgb(9 24 36 / 36%);
overflow:hidden;
}

.feature-media img{
width:100%;
height:100%;
display:block;
object-fit:cover;
}

.guide-section{
height:auto;
min-height:62vh;
padding:110px 20px;
background:transparent;
}

.features,
.gallery,
.guide-section{
padding:110px 20px;
margin:0;
}

.guide-section h1{
margin-bottom:20px;
}

.guide-links{
display:grid;
grid-template-columns:repeat(4,minmax(0,1fr));
gap:12px;
width:min(92vw,1200px);
margin-top:10px;
}

.guide-links a{
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
gap:12px;
text-decoration:none;
color:#f1f6ff;
font-weight:600;
padding:16px 12px;
min-height:128px;
border:1px solid rgb(252 235 197 / 14%);
border-radius:12px;
background:rgb(11 29 42 / 72%);
transition:transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.guide-links a:hover{
transform:translateY(-2px);
border-color:rgb(252 235 197 / 34%);
background:rgb(14 36 52 / 78%);
}

.guide-item-icon{
width:76px;
height:76px;
display:block;
object-fit:contain;
flex-shrink:0;
}

.guide-item-name{
display:block;
text-align:center;
font-size:14px;
line-height:1.25;
}

.cards{
display:flex;
gap:26px;
margin-top:40px;
flex-wrap:wrap;
justify-content:center;
}

.card{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 22%);
box-shadow:0 8px 18px rgb(0 0 0 / 30%), inset 0 0 0 1px rgb(255 255 255 / 6%);
backdrop-filter:blur(2px);
-webkit-backdrop-filter:blur(2px);
padding:28px 24px;
border-radius:16px;
width:270px;
transition:transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.card:hover{
transform:translateY(-8px) scale(1.02);
border-color:rgb(252 235 197 / 48%);
box-shadow:0 16px 30px rgb(0 0 0 / 38%), 0 0 16px rgb(252 235 197 / 18%);
}

.card h3{
margin-bottom:12px;
font-family:'Press Start 2P',cursive;
font-size:14px;
line-height:1.25;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.card p{
margin:0;
color:#e9f3ff;
opacity:0.95;
font-size:16px;
line-height:1.45;
}

/* GALLERY */

.gallery{
background:#0f172a;
}

.news-grid{
display:grid;
grid-template-columns:repeat(3,minmax(0,1fr));
gap:30px;
width:min(92vw,1200px);
margin-top:36px;
}

.news-card{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:16px;
padding:24px;
text-align:left;
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
transition:transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.news-card:hover{
transform:translateY(-6px);
border-color:rgb(252 235 197 / 42%);
box-shadow:0 16px 28px rgb(0 0 0 / 34%);
}

.news-thumb{
width:100%;
aspect-ratio:16 / 9;
display:block;
object-fit:cover;
border-radius:10px;
margin-bottom:14px;
background:
linear-gradient(135deg,rgb(252 235 197 / 20%),rgb(86 193 255 / 18%)),
linear-gradient(180deg,rgb(9 20 30 / 90%),rgb(6 15 24 / 92%));
border:1px solid rgb(252 235 197 / 24%);
}

.news-card h3{
margin:0 0 12px;
font-family:'Press Start 2P',cursive;
font-size:14px;
line-height:1.3;
color:#fcebc5;
}

.news-card p{
margin:0 0 16px;
color:#e9f3ff;
opacity:0.95;
font-size:15px;
line-height:1.5;
}

.news-card a{
display:inline-block;
text-decoration:none;
font-weight:700;
color:#fcebc5;
border-bottom:1px solid rgb(252 235 197 / 35%);
padding-bottom:2px;
}

.news-card a:hover{
filter:brightness(1.1);
}

.news-actions{
width:min(92vw,1200px);
margin-top:14px;
display:flex;
justify-content:flex-end;
}

.news-all-btn{
display:inline-flex;
align-items:center;
justify-content:center;
min-width:172px;
height:46px;
padding:0 14px;
text-decoration:none;
font-family:'Press Start 2P',cursive;
font-size:11px;
text-transform:uppercase;
color:#fcebc5;
background-image:url('../img/menu-item-buttons.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
text-shadow:0 1px 2px rgb(0 0 0 / 50%);
transition:transform 0.2s ease, filter 0.2s ease;
}

.news-all-btn:hover{
transform:translateY(-2px) scale(1.03);
filter:brightness(1.08);
}

/* STORE */

.store{
background:#102233;
padding:140px 20px;
}

.store-grid{
display:grid;
grid-template-columns:1fr;
gap:24px;
width:min(92vw,760px);
margin-top:34px;
}

section.section + section.section{/* margin-top:30px; */}

.store-card{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:14px;
padding:24px 22px;
text-align:left;
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
transition:transform 0.22s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}

.store-card:hover{
transform:translateY(-3px);
border-color:rgb(252 235 197 / 42%);
box-shadow:0 16px 28px rgb(0 0 0 / 34%);
}

.store-item-head{
display:flex;
align-items:flex-start;
gap:10px;
}

.store-item-content{
display:flex;
flex-direction:column;
gap:4px;
}

.store-item-icon{
width:92px;
height:92px;
flex-shrink:0;
object-fit:contain;
}

.store-card h3{
margin:0;
font-family:'Press Start 2P',cursive;
font-size:16px;
line-height:1.3;
color:#fcebc5;
}

.store-card p{
margin:0;
color:#e9f3ff;
opacity:0.95;
font-size:14px;
line-height:1.4;
}

.store-actions{
width:min(92vw,1100px);
margin-top:18px;
display:flex;
justify-content:center;
}

.store-visit-btn{
min-width:250px;
height:82px;
}

/* JOIN */

.join{
background:#0b1d2c;
position:relative;
z-index:12;
}

.join h1{
font-family:'Press Start 2P',cursive;
font-size:clamp(30px,3.2vw,52px);
line-height:1.2;
max-width:920px;
margin-bottom:16px;
color:#fcebc5;
text-shadow:0 3px 7px rgb(0 0 0 / 70%);
letter-spacing:0.3px;
}

.join-intro{
max-width:760px;
margin-top:4px;
font-size:clamp(18px,1.45vw,24px);
font-weight:600;
line-height:1.5;
color:#fff8e6;
text-shadow:0 2px 6px rgb(0 0 0 / 68%);
}

.join-ip{
margin-top:14px;
font-family:'Press Start 2P',cursive;
font-size:clamp(12px,1vw,16px);
letter-spacing:0.2px;
color:#fcebc5;
text-shadow:0 2px 4px rgb(0 0 0 / 75%);
}

.join-arrow-link{
margin-top:12px;
display:inline-flex;
align-items:center;
justify-content:center;
position:relative;
z-index:13;
}

.join-arrow{
width:54px;
height:auto;
animation:arrow-bounce 1.15s ease-in-out infinite;
filter:drop-shadow(0 4px 8px rgb(0 0 0 / 55%));
}

@keyframes arrow-bounce{
0%,100%{transform:translateY(0);}
50%{transform:translateY(14px);}
}

.play-modal{
position:fixed;
inset:0;
display:flex;
align-items:center;
justify-content:center;
padding:24px;
background:rgb(6 12 18 / 62%);
backdrop-filter:blur(7px);
-webkit-backdrop-filter:blur(7px);
opacity:0;
visibility:hidden;
pointer-events:none;
transition:opacity 0.22s ease,visibility 0.22s ease;
z-index:2500;
}

.play-modal.is-open{
opacity:1;
visibility:visible;
pointer-events:auto;
}

.play-modal-panel{
position:relative;
width:min(62vw,780px);
aspect-ratio:1390 / 1111;
background-image:url('../img/modalblock-play.png');
background-repeat:no-repeat;
background-size:contain;
background-position:center;
margin:0 auto;
display:flex;
align-items:center;
justify-content:center;
}

.play-modal-content{
width:68%;
text-align:left;
color:#fcebc5;
text-shadow:0 1px 3px rgb(0 0 0 / 60%);
transform:translateY(26px);
max-height:min(70vh,560px);
overflow-y:auto;
padding-right:4px;
}

.play-modal-vote-grid{
margin-top:150px;
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:12px;
text-align:left;
}

.play-modal-vote-link{
display:flex;
align-items:center;
justify-content:space-between;
gap:10px;
min-height:56px;
padding:0 18px;
text-decoration:none;
font-family:'Press Start 2P',cursive;
font-size:9px;
letter-spacing:0.2px;
text-transform:uppercase;
color:#141414;
line-height:1.2;
background:linear-gradient(180deg,rgb(252 241 214 / 98%),rgb(243 226 188 / 99%));
border:1px solid rgb(36 28 16 / 42%);
border-radius:10px;
box-shadow:0 8px 16px rgb(0 0 0 / 28%), inset 0 0 0 1px rgb(255 255 255 / 34%);
text-shadow:none;
transition:transform 0.2s ease,filter 0.2s ease,border-color 0.2s ease,box-shadow 0.2s ease,background 0.2s ease;
}

.play-modal-vote-link:hover,
.play-modal-vote-link:focus-visible{
background:linear-gradient(180deg,rgb(255 247 226 / 99%),rgb(250 236 202 / 99%));
border-color:rgb(20 20 20 / 72%);
box-shadow:0 10px 20px rgb(0 0 0 / 34%);
transform:translateY(-2px);
filter:none;
}

.play-modal-vote-icon{
display:inline-flex;
align-items:center;
justify-content:center;
width:28px;
height:28px;
border-radius:8px;
border:1px solid rgb(20 20 20 / 52%);
background:rgb(255 245 220 / 95%);
color:#111;
font-size:13px;
line-height:1;
opacity:0.9;
flex-shrink:0;
}

.play-modal-close{
position:absolute;
top:4%;
right:4%;
width:38px;
height:38px;
border:none;
background:transparent;
color:#fcebc5;
font-family:'Press Start 2P',cursive;
font-size:18px;
line-height:1;
cursor:pointer;
text-shadow:0 1px 3px rgb(0 0 0 / 55%);
}

.play-modal-close:hover{
filter:brightness(1.2);
}

/* FOOTER */

footer{
width:100%;
min-height:0;
background:#0b1d2c;
display:flex;
align-items:center;
justify-content:flex-end;
flex-direction:column;
padding:136px 20px 22px;
position:relative;
overflow:hidden;
margin-top:clamp(-150px,-12vw,-72px);
z-index:8;
}

.home-page #site-footer{
margin-top:0 !important;
position:relative;
z-index:20;
}

footer::before{
content:"";
position:absolute;
left:0;
right:0;
bottom:0;
aspect-ratio:1536 / 946;
background-image:url('../img/footer-website.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:bottom center;
opacity:0.72;
pointer-events:none;
z-index:0;
}

footer.small-footer{
background:transparent;
}

footer.small-footer::before{
display:block;
inset:0;
top:0;
right:0;
bottom:0;
left:0;
aspect-ratio:auto;
background-image:url('../img/footer-website-small.png');
background-position:center;
}

.footer-particles{
position:absolute;
inset:0;
z-index:1;
pointer-events:none;
}

.footer-particles span{
position:absolute;
left:var(--x);
bottom:-24px;
width:var(--size);
height:var(--size);
border-radius:50%;
background:rgb(255 255 255 / 50%);
box-shadow:0 0 10px rgb(255 255 255 / 40%);
animation:particle-rise var(--dur) linear infinite;
animation-delay:var(--delay);
}

.footer-intro{margin-top:8px;margin-bottom: 100px;max-width:min(92vw,980px);text-align:center;padding: 0 164px;color:#fcebc5;text-shadow:0 2px 6px rgb(0 0 0 / 72%);}

.footer-intro h2{
margin:0;
font-family:'Press Start 2P',cursive;
font-size:clamp(20px,3.1vw,44px);
line-height:1.25;
color:#fcebc5;
}

.footer-intro p{
margin:12px 0 14px;
font-size:clamp(15px,1.25vw,22px);
line-height:1.5;
font-weight:600;
color:#fff8e6;
}

footer > *{
position:relative;
z-index:2;
}

.footer-people{
width:clamp(460px,42vw,1100px);
height:auto;
margin:14px auto 0;
filter:drop-shadow(0 6px 12px rgb(0 0 0 / 35%));
display:block;
}

.footer-cta{
display:flex;
justify-content:center;
width:100%;
margin-top:12px;
}

.footer-join-btn{
min-width:560px;
height:170px;
font-size:32px;
position:relative;
isolation:isolate;
animation:footer-join-pulse 1.8s ease-in-out infinite;
}

.footer-join-btn small{
font-size:17px;
margin-top:6px;
letter-spacing:0.2px;
}

@keyframes footer-join-pulse{
0%,100%{
filter:brightness(1);
}
50%{
filter:brightness(1.08);
}
}

.footer-join-btn::after{
content:"";
position:absolute;
left:50%;
top:50%;
width:70%;
height:70%;
transform:translate(-50%, -50%) scale(0.85);
border-radius:999px;
background:radial-gradient(circle, rgb(91 255 144 / 42%) 0%, rgb(91 255 144 / 22%) 45%, rgb(91 255 144 / 0%) 72%);
filter:blur(8px);
z-index:-1;
pointer-events:none;
animation:footer-join-center-glow 1.8s ease-in-out infinite;
}

@keyframes footer-join-center-glow{
0%,100%{
opacity:0.28;
transform:translate(-50%, -50%) scale(0.82);
}
50%{
opacity:0.78;
transform:translate(-50%, -50%) scale(1.15);
}
}

.footer-online{
margin-top:10px;
display:flex;
flex-direction:column;
align-items:center;
text-align:center;
color:#fcebc5;
text-shadow:0 2px 6px rgb(0 0 0 / 72%);
}

.footer-online-number{
font-family:'Press Start 2P',cursive;
font-size:clamp(42px,5.5vw,92px);
line-height:1;
}

.footer-online-label{
margin-top:6px;
font-family:'Press Start 2P',cursive;
font-size:clamp(11px,1.2vw,18px);
letter-spacing:0.3px;
text-transform:uppercase;
}

.footer-links{margin-top: 26px;display:flex;align-items:center;justify-content:center;gap:26px;flex-wrap:wrap;}

.footer-links a{
text-decoration:none;
color:#f7e8c5;
font-size:14px;
font-weight:600;
text-shadow:0 1px 2px rgb(0 0 0 / 55%);
border-bottom:1px solid rgb(247 232 197 / 35%);
padding-bottom:2px;
}

.footer-links a:hover{
color:#fff5da;
border-bottom-color:rgb(255 245 218 / 75%);
}

.footer-legal{
margin-top:14px;
max-width:920px;
text-align:center;
padding:10px 14px;
background:rgb(4 12 18 / 40%);
border:1px solid rgb(252 235 197 / 20%);
border-radius:10px;
}

.footer-legal p{
margin:0;
color:#fff7e6;
opacity:0.9;
font-size:13px;
line-height:1.4;
}

.footer-legal p + p{
margin-top:6px;
opacity:0.82;
}

/* COOKIE CONSENT */

.cookie-consent{
position:fixed;
left:16px;
bottom:16px;
width:min(520px, calc(100vw - 28px));
padding:22px 20px 18px;
background:
radial-gradient(120% 120% at 16% 10%, rgb(252 235 197 / 16%) 0%, rgb(252 235 197 / 0%) 52%),
linear-gradient(180deg, rgb(10 30 43 / 94%) 0%, rgb(6 20 31 / 96%) 100%);
border:1px solid rgb(252 235 197 / 30%);
border-radius:14px;
backdrop-filter:blur(2px);
-webkit-backdrop-filter:blur(2px);
box-shadow:
0 12px 26px rgb(0 0 0 / 45%),
inset 0 0 0 1px rgb(255 255 255 / 6%),
0 0 18px rgb(252 235 197 / 12%);
z-index:2200;
color:#fff6dc;
}

.cookie-consent.is-hidden{
display:none;
}

.cookie-consent p{
margin:0;
font-size:13px;
line-height:1.4;
text-shadow:0 1px 2px rgb(0 0 0 / 55%);
max-width:460px;
}

.cookie-consent-actions{
margin-top:14px;
display:flex;
align-items:center;
gap:8px;
flex-wrap:wrap;
}

.cookie-consent-btn,
.cookie-consent-link{
display:inline-flex;
align-items:center;
justify-content:center;
height:32px;
padding:0 12px;
text-decoration:none;
border-radius:8px;
border:1px solid rgb(252 235 197 / 45%);
font-family:'Press Start 2P',cursive;
font-size:8px;
text-transform:uppercase;
letter-spacing:0.2px;
cursor:pointer;
transition:transform 0.15s ease, filter 0.15s ease, border-color 0.15s ease;
}

.cookie-consent-btn:hover,
.cookie-consent-link:hover{
transform:translateY(-1px);
filter:brightness(1.06);
}

.cookie-consent-btn.is-accept{
background:rgb(74 222 128 / 88%);
color:#072113;
border-color:rgb(153 255 192 / 85%);
}

.cookie-consent-btn.is-decline{
background:rgb(14 36 52 / 88%);
color:#fcebc5;
}

.cookie-consent-link{
background:rgb(252 235 197 / 92%);
color:#1a1610;
}

/* TABLET & SMALL LAPTOP */
@media (max-width:1200px){
.floating-elements{
display:none;
}

header{
padding:10px 22px;
}

nav{
gap:10px;
}

nav a{
min-width:112px;
font-size:11px;
}

.play-link{
min-width:124px;
}

.section{
padding:92px 20px 72px;
}

.section h1{
font-size:clamp(34px,5vw,50px);
}

.hero-action-btn{
min-width:240px;
height:78px;
font-size:15px;
}

.features-layout{
gap:18px;
}

.feature-row{
grid-template-columns:1fr;
}

.feature-row.is-reverse .feature-text,
.feature-row.is-reverse .feature-media{
order:initial;
}

.feature-media{
min-height:220px;
}

.guide-links{
grid-template-columns:repeat(3,minmax(0,1fr));
}

.news-grid{
grid-template-columns:repeat(2,minmax(0,1fr));
gap:22px;
}

.store{
padding:110px 20px;
}

footer{
padding:86px 20px 20px;
}
}

/* LARGE DESKTOP / HIGH RES */
@media (min-width:1800px){
header{
height:82px;
padding:12px 56px;
}

nav a{
min-width:150px;
height:52px;
font-size:15px;
}

.home-link{
width:56px;
height:56px;
min-width:56px;
}

.play-link{
min-width:164px;
}

.section{
padding:120px 24px 90px;
}

.section h1{
font-size:72px;
}

.hero-banner-text{
width:min(88vw,1200px);
}

.hero-action-btn{
min-width:330px;
height:102px;
font-size:20px;
}

.features-layout,
.news-grid,
.guide-links{
width:min(88vw,1500px);
}

.guide-links{
grid-template-columns:repeat(4,minmax(0,1fr));
gap:16px;
}

.guide-links a{
min-height:136px;
}

.news-grid{
grid-template-columns:repeat(3,minmax(0,1fr));
}

.store-grid{
width:min(80vw,980px);
}

.footer-online-number{
font-size:106px;
}

.footer-join-btn{
min-width:700px;
height:200px;
font-size:38px;
}
}

@media(max-width:700px){

header{
padding:10px 14px;
height:auto;
min-height:70px;
}

.floating-elements{
display:none;
}

.desktop-nav{
display:none;
}

.mobile-nav-toggle{
display:inline-flex;
}

.mobile-nav{
display:flex;
position:fixed;
inset:0;
width:100vw;
height:100vh;
padding:18px 16px 26px;
border:none;
background:rgb(5 16 24 / 96%);
backdrop-filter:blur(10px);
-webkit-backdrop-filter:blur(10px);
flex-direction:column;
gap:18px;
opacity:0;
transform:translateY(-16px);
pointer-events:none;
transition:opacity 0.2s ease, transform 0.2s ease;
z-index:2000;
}

.mobile-nav.is-open{
opacity:1;
transform:translateY(0);
pointer-events:auto;
}

.mobile-nav-header{
display:flex;
align-items:center;
justify-content:center;
}

.mobile-nav-logo{
width:min(72vw,320px);
height:auto;
}

.mobile-nav-close{
position:absolute;
top:14px;
right:14px;
width:46px;
height:46px;
border:1px solid rgb(252 235 197 / 24%);
border-radius:10px;
background:rgb(10 30 43 / 78%);
color:#fcebc5;
font-size:28px;
line-height:1;
cursor:pointer;
}

.mobile-nav-links{
flex:1;
display:flex;
flex-direction:column;
align-items:center;
justify-content:center;
gap:12px;
}

.mobile-nav-links a{
display:flex;
align-items:center;
justify-content:center;
min-width:min(84vw,340px);
height:52px;
padding:0 14px;
text-decoration:none;
color:#fcebc5;
font-family:'Press Start 2P',cursive;
font-size:12px;
letter-spacing:0.3px;
text-transform:uppercase;
background-image:url('../img/menu-item-buttons.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
text-shadow:0 1px 2px rgb(0 0 0 / 45%);
}

.mobile-nav-links .home-link{
min-width:56px;
width:56px;
height:56px;
padding:0;
background-image:url('../img/homebutton.png');
background-size:contain;
}

.mobile-nav-links .play-link{
background-image:url('../img/menu-item-play-button.png');
min-width:min(84vw,340px);
}

.mobile-nav-links a:hover{
filter:brightness(1.08);
}

.mobile-nav-links a:not(.home-link):not(.play-link):hover,
.mobile-nav-links a:not(.home-link):not(.play-link):focus-visible{
background-image:url('../img/menu-item-buttons-selected.png');
}

nav a:not(.home-link):not(.play-link)[aria-current="page"],
.mobile-nav-links a:not(.home-link):not(.play-link)[aria-current="page"]{
background-image:url('../img/menu-item-buttons-selected.png');
}

nav a.selected,
.mobile-nav-links a.selected{
background-image:url('../img/menu-item-buttons-selected.png') !important;
}

.home-link{
min-width:38px;
width:38px;
height:38px;
}

.play-link{
min-width:108px;
}

.online-status{
gap:6px;
}

.online-status-icon{
width:20px;
height:20px;
}

.online-status-text{
gap:2px;
}

.online-status-count{
font-size:10px;
}

.online-status-host{
font-size:7px;
}

.play-modal-panel{
width:min(88vw,520px);
}

.play-modal-content{
width:74%;
}

.play-modal-vote-grid{
grid-template-columns:1fr;
gap:8px;
}

.play-modal-vote-link{
font-size:13px;
min-height:46px;
padding:0 12px;
}

.maplewood-logo-header{
width:86vw;
max-width:460px;
}

.section h1{
font-size:40px;
}

.section{
padding:96px 16px 64px;
}

.cards{
flex-direction:column;
align-items:center;
}

.hero-action-buttons{
gap:12px;
}

.hero-action-btn{
min-width:220px;
height:70px;
font-size:14px;
}

.hero-action-btn small{
font-size:9px;
margin-top:1px;
}

.hero-banner-text{
padding:8px 12px;
}

.hero-banner-text p{
font-size:15px;
line-height:1.45;
text-shadow:0 2px 3px rgb(0 0 0 / 80%);
}

.vote-fixed-btn{
right:12px;
bottom:12px;
width:156px;
height:56px;
font-size:12px;
}

.join-intro{
font-size:16px;
line-height:1.4;
}

.join h1{
font-size:clamp(22px,5vw,34px);
line-height:1.25;
margin-bottom:12px;
}

.join-ip{
font-size:10px;
}

.join-arrow{
width:42px;
}

.floating-el{
width:clamp(126px,24vw,186px);
}

.floating-el-2,
.floating-el-4{
display:none;
}

footer{
padding:22px 14px;
margin-top:clamp(-86px,-10vw,-36px);
}

.home-page #site-footer{
margin-top:0 !important;
position:relative;
z-index:20;
}

.footer-intro{
margin-top:10px;
margin-bottom:50px;
padding:0;
}

.footer-intro h2{
font-size:clamp(18px,6.8vw,24px);
}

.footer-intro p{
margin:10px 0 12px;
font-size:14px;
line-height:1.42;
}

.footer-join-btn{min-width:320px;height:120px;font-size: 22px;}

.footer-people{
width:min(420px,88vw);
margin-top:10px;
}

.footer-people{
display:none;
}

.footer-join-btn small{
font-size:13px;
margin-top:2px;
}

.footer-links{
gap:14px;
margin-top:34px;
}

.footer-links a{
font-size:12px;
}

.footer-online-number{
font-size:42px;
}

.footer-online-label{
font-size:11px;
}

.footer-legal{
padding:8px 10px;
}

.footer-legal p{
font-size:11px;
line-height:1.35;
}

.cookie-consent{
left:10px;
right:10px;
bottom:10px;
width:min(460px, calc(100vw - 20px));
right:auto;
padding:18px 16px 14px;
}

.cookie-consent p{
font-size:12px;
}

.cookie-consent-actions{
gap:6px;
}

.cookie-consent-btn,
.cookie-consent-link{
height:32px;
font-size:8px;
padding:0 10px;
}

.store{
padding:100px 20px;
}

.features-layout{
grid-template-columns:1fr;
gap:20px;
}

.features-title{
text-align:center;
}

.features .cards{
justify-content:center;
}

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

.feature-media{
min-height:180px;
}

.features .feature-rows{
gap:20px;
}

.features .guide-page-banner{
height:auto;
max-height:none;
min-height:260px;
padding:84px 14px 18px;
margin-bottom:0;
}

.features .guide-page-banner h1{
font-size:clamp(22px,7vw,30px);
line-height:1.24;
margin-bottom:8px;
}

.features .guide-page-banner-text{
font-size:13px;
line-height:1.45;
max-width:none;
}

.features .feature-banner-with-character .guide-page-banner-content{
padding-right:0;
}

.features .feature-banner-character{
display:none;
}

.guide-section{
min-height:auto;
padding:84px 16px;
}

.features,
.gallery,
.guide-section{
padding:84px 16px;
margin:0;
}

.guide-links{
grid-template-columns:repeat(2,minmax(0,1fr));
}

.guide-links a{
min-height:120px;
padding:14px 10px;
}

.guide-item-icon{
width:64px;
height:64px;
}

.guide-item-name{
font-size:13px;
}

.feature-text.has-extra-image{
padding-bottom:80px;
}

.feature-text-extra-image{
width:46%;
max-width:170px;
right:10px;
bottom:8px;
}

.news-grid{
grid-template-columns:1fr;
gap:20px;
}

.store-visit-btn{
min-width:220px;
height:70px;
}

section.section + section.section{
margin-top:20px;
}

body.show-small-logo .logo{
width:58px;
margin-right:4px;
}

}

/* GUIDE PAGE */

body.guide-page{
scroll-snap-type:none;
background:
radial-gradient(circle at 15% 12%, rgb(252 235 197 / 12%), transparent 34%),
radial-gradient(circle at 82% 78%, rgb(86 193 255 / 12%), transparent 36%),
#0f172a;
}

.guide-page .maplewood-logo-small{
opacity:1;
visibility:visible;
transform:translateY(0);
}

.guide-page .logo{
width:74px;
margin-right:6px;
}

.guide-page-main{
min-height:100vh;
padding:0 0 70px;
position:relative;
z-index:6;
}

.guide-page-banner{
--guide-banner-height:280px;
position:relative;
width:100%;
height:var(--guide-banner-height);
max-height:var(--guide-banner-height);
margin:0 0 28px;
padding:92px 20px 24px;
display:flex;
flex-direction:column;
justify-content:flex-end;
overflow:hidden;
text-align:left;
}

body.guide-page .guide-page-banner{
--guide-banner-image:url('../img/guide.png');
}

.guide-page-banner::before{
content:"";
position:absolute;
inset:0;
background-image:var(--guide-banner-image);
background-repeat:no-repeat;
background-size:cover;
background-position:center;
z-index:0;
}

.guide-page-banner::after{
content:"";
position:absolute;
inset:0;
background:
linear-gradient(100deg, rgb(6 16 26 / 92%) 0%, rgb(9 25 40 / 86%) 35%, rgb(12 34 52 / 55%) 58%, rgb(12 34 52 / 0%) 82%),
linear-gradient(180deg, rgb(6 16 26 / 14%) 0%, rgb(6 16 26 / 70%) 100%);
z-index:1;
}

.guide-page-banner-content{
position:relative;
z-index:2;
width:100%;
max-width:1280px;
margin-left:auto;
margin-right:auto;
}

.guide-page-kicker{
margin:0 0 10px;
font-family:'Press Start 2P',cursive;
font-size:12px;
text-transform:uppercase;
letter-spacing:0.3px;
color:#fcebc5;
opacity:0.9;
text-shadow:0 2px 6px rgb(0 0 0 / 80%);
}

.guide-page-banner h1{
margin:0 0 12px;
font-family:'Press Start 2P',cursive;
font-size:clamp(30px,4vw,52px);
line-height:1.2;
color:#fcebc5;
text-shadow:0 2px 8px rgb(0 0 0 / 85%);
}

.guide-page-banner-text{
margin:0;
max-width:760px;
color:#e9f3ff;
opacity:0.95;
font-size:17px;
line-height:1.5;
text-shadow:0 2px 8px rgb(0 0 0 / 82%);
}

.guide-page-shell{
width:min(calc(100% - 40px), 1280px);
margin:0 auto;
display:grid;
grid-template-columns:300px minmax(0,1fr);
gap:26px;
align-items:start;
text-align:left;
}

.guide-menu{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:16px;
padding:22px 18px;
position:sticky;
top:90px;
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
}

.guide-menu h1{
margin:0 0 12px;
font-family:'Press Start 2P',cursive;
font-size:24px;
line-height:1.25;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.guide-page-intro{
margin:0 0 18px;
max-width:none;
color:#e9f3ff;
opacity:0.95;
font-size:14px;
line-height:1.45;
}

.guide-menu-item{
width:100%;
display:flex;
align-items:center;
gap:10px;
text-align:left;
margin:0 0 9px;
padding:12px 12px;
border:1px solid rgb(252 235 197 / 18%);
border-radius:10px;
background:rgb(11 29 42 / 70%);
color:#f1f6ff;
font-family:'Poppins',sans-serif;
font-size:14px;
font-weight:600;
cursor:pointer;
transition:transform 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.guide-menu-item:last-child{
margin-bottom:0;
}

.guide-menu-item:hover{
transform:translateX(4px);
border-color:rgb(252 235 197 / 40%);
background:rgb(16 40 58 / 82%);
}

.guide-menu-item.is-active{
border-color:rgb(252 235 197 / 62%);
background:rgb(26 56 76 / 90%);
color:#fff5dc;
}

.guide-menu-item-icon{
width:30px;
height:30px;
display:block;
object-fit:contain;
flex-shrink:0;
}

.guide-content{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:16px;
padding:30px;
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
min-height:620px;
}

.guide-content-item{
display:none;
}

.guide-content-item.is-active{
display:block;
animation:guide-fade 0.2s ease;
}

@keyframes guide-fade{
from{opacity:0;transform:translateY(4px);}
to{opacity:1;transform:translateY(0);}
}

.guide-content-item h2{
margin:0 0 12px;
font-family:'Press Start 2P',cursive;
font-size:26px;
line-height:1.25;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.guide-content-item p{
margin:0 0 16px;
max-width:100%;
color:#e9f3ff;
opacity:0.95;
font-size:16px;
line-height:1.55;
}

.guide-content-item img{
max-width:100%;
height:auto;
border-radius:10px;
border:1px solid rgb(252 235 197 / 24%);
margin:8px 0 14px;
}

.guide-content-item table{
width:100%;
border-collapse:collapse;
margin:10px 0 16px;
background:rgb(11 29 42 / 58%);
}

.guide-content-item th,
.guide-content-item td{
border:1px solid rgb(252 235 197 / 28%);
padding:8px 10px;
color:#f1f6ff;
font-size:14px;
}

.guide-content-item ul{
margin:0;
padding-left:22px;
color:#f1f6ff;
}

.guide-content-item li{
margin:0 0 10px;
line-height:1.5;
}

.guide-content-item li:last-child{
margin-bottom:0;
}

.guide-page footer{
margin-top:0;
aspect-ratio:auto;
min-height:360px;
padding:48px 20px 18px;
justify-content:flex-end;
}

.guide-page .footer-cta{
margin-top:0;
}

.guide-page .footer-join-btn{
min-width:440px;
height:132px;
font-size:26px;
animation:none;
}

.guide-page .footer-join-btn small{
font-size:14px;
}

.guide-page .footer-links{
margin-top:16px;
}

.guide-page .footer-legal{
margin-top:10px;
}

@media (max-width:1200px){
.guide-page-banner{
--guide-banner-height:240px;
padding:96px 20px 20px;
}

.guide-page-kicker{
font-size:11px;
}

.guide-page-shell{
grid-template-columns:260px minmax(0,1fr);
gap:18px;
}

.guide-menu h1{
font-size:20px;
}

.guide-content{
min-height:560px;
padding:24px;
}

.guide-content-item h2{
font-size:22px;
}
}

@media(max-width:700px){
.guide-page-main{
padding:0 0 52px;
}

.guide-page-banner{--guide-banner-height: 270px;padding: 101px 14px 14px;margin-bottom: 14px;}

.guide-page-banner > *{
width:100%;
}

.guide-page-kicker{
font-size:10px;
margin-bottom:8px;
}

.guide-page-banner h1{
font-size:32px;
margin-bottom:10px;
}

.guide-page-banner-text{
font-size:14px;
line-height:1.45;
}

.guide-page-shell{
width:min(calc(100% - 28px), 1280px);
grid-template-columns:1fr;
gap:14px;
}

.guide-menu{
position:relative;
top:auto;
padding:12px 14px !important;
display:flex;
align-items:stretch;
gap:10px;
overflow-x:auto;
overflow-y:hidden;
scroll-snap-type:x mandatory;
-webkit-overflow-scrolling:touch;
scrollbar-width:thin;
}

.guide-menu::before{
content:"";
flex:0 0 42px;
}

.guide-menu::after{
content:"Swipe";
position:sticky;
right:2px;
align-self:center;
display:inline-flex;
align-items:center;
justify-content:center;
height:22px;
padding:0 8px;
font-family:'Press Start 2P',cursive;
font-size:8px;
letter-spacing:0.2px;
color:#fcebc5;
background:rgb(6 18 28 / 84%);
border:1px solid rgb(252 235 197 / 26%);
border-radius:999px;
opacity:0.86;
pointer-events:none;
transition:opacity 0.2s ease;
}

.guide-menu.is-hinting::after{
opacity:1;
}

.guide-menu h1{
font-size:18px;
}

.guide-menu-item{
flex:0 0 auto;
min-width:170px;
max-width:210px;
margin:0;
padding:10px 10px;
font-size:12px;
border-radius:12px;
scroll-snap-align:start;
}

.guide-menu-item:first-child{
margin-left:0 !important;
}

.guide-menu > .guide-menu-item:first-of-type{
margin-left:18px !important;
}

.guide-menu-item:last-child{
margin-right:0 !important;
}

.guide-menu-item:hover{
transform:none;
}

.guide-menu-item-icon{
width:26px;
height:26px;
}

.guide-content{
padding:18px 14px;
min-height:420px;
}

.guide-content-item h2{
font-size:19px;
}

.guide-content-item p,
.guide-content-item li{
font-size:14px;
}

.guide-page footer{
min-height:290px;
padding:30px 14px 14px;
}

.guide-page .footer-join-btn{
min-width:290px;
height:96px;
font-size:20px;
}

.guide-page .footer-join-btn small{
font-size:11px;
}
}

/* NEWS PAGE */

.news-page .guide-page-shell{
grid-template-columns:1fr;
}

.news-page .guide-page-banner{
--guide-banner-image:url('../img/news.png')!important;
}

.news-page .guide-content{
min-height:auto;
padding:0;
border:none;
box-shadow:none;
background:transparent;
}

.news-page .news-feed{
border:none;
box-shadow:none;
background:transparent;
}

/* LEGAL PAGES */

.legal-page .guide-page-shell{
grid-template-columns:1fr;
}

.legal-page .guide-content.news-feed{
padding:0;
border:none;
box-shadow:none;
background:transparent;
}

.legal-page .guide-content-item{
display:block;
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:16px;
padding:26px 24px;
box-shadow:0 10px 24px rgb(0 0 0 / 28%);
}

.legal-page .guide-content-item h2{
margin:22px 0 10px;
font-family:'Press Start 2P',cursive;
font-size:16px;
line-height:1.35;
color:#fcebc5;
}

.legal-page .guide-content-item h3{
margin:14px 0 6px;
font-size:13px;
line-height:1.35;
text-transform:uppercase;
letter-spacing:0.3px;
color:#f7e8c5;
opacity:0.95;
}

.legal-page .guide-content-item p{
margin:0 0 12px;
font-size:15px;
line-height:1.62;
color:#eaf3ff;
opacity:0.96;
}

.legal-page .legal-subtext{
margin:0 0 16px;
font-size:14px;
opacity:0.92;
}

.legal-page .legal-callout{
margin:0 0 18px;
padding:12px 14px;
border-radius:12px;
border:1px solid rgb(252 235 197 / 30%);
background:rgb(9 29 43 / 72%);
color:#fff4d6;
font-size:14px;
line-height:1.5;
}

.legal-page .legal-list{
margin:0 0 14px;
padding-left:22px;
}

.legal-page .legal-list li{
margin:0 0 8px;
font-size:15px;
line-height:1.55;
color:#eaf3ff;
}

/* VOTE NOW PAGE */

.vote-now-page .guide-page-shell{
grid-template-columns:1fr;
}

.vote-now-banner{
--guide-banner-image:url('../img/background-image-maplewood5.png')!important;
}

.vote-now-content{
min-height:auto;
padding:28px;
}

.vote-now-grid{
display:grid;
grid-template-columns:repeat(2,minmax(0,1fr));
gap:12px;
}

.vote-now-grid .play-modal-vote-link{
min-height:58px;
font-size:11px;
}

.vote-now-page .vote-fixed-btn{
display:none;
}

@media (max-width:700px){
.vote-now-content{
padding:18px 14px;
}

.vote-now-grid{
grid-template-columns:1fr;
}

.vote-now-grid .play-modal-vote-link{
font-size:10px;
min-height:54px;
}

.legal-page .guide-content-item{
padding:16px 14px;
}

.legal-page .guide-content-item h2{
font-size:13px;
margin:16px 0 8px;
}

.legal-page .guide-content-item h3{
font-size:11px;
}

.legal-page .guide-content-item p,
.legal-page .legal-list li{
font-size:14px;
line-height:1.55;
}
}

.news-feed{
display:flex;
flex-direction:column;
gap:20px;
}

.news-feed-item{
display:grid;
grid-template-columns:320px minmax(0,1fr);
gap:20px;
align-items:stretch;
background:rgb(11 29 42 / 70%);
border:1px solid rgb(252 235 197 / 20%);
border-radius:14px;
padding:16px;
}

.news-feed-image{
width:100%;
height:100%;
min-height:180px;
max-height:230px;
object-fit:cover;
border-radius:10px;
border:1px solid rgb(252 235 197 / 24%);
}

.news-feed-body{
display:flex;
flex-direction:column;
justify-content:center;
align-items:flex-start;
}

.news-feed-body h2{
margin:0 0 10px;
font-family:'Press Start 2P',cursive;
font-size:18px;
line-height:1.35;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.news-feed-meta{
display:flex;
align-items:center;
gap:10px;
flex-wrap:wrap;
margin:0 0 10px;
color:#f7e8c6;
font-size:12px;
font-weight:600;
line-height:1.35;
}

.news-feed-meta span{
display:inline-flex;
align-items:center;
gap:6px;
padding:4px 8px;
border-radius:999px;
border:1px solid rgb(252 235 197 / 24%);
background:rgb(6 19 30 / 55%);
}

.news-feed-body p{
margin:0 0 16px;
max-width:100%;
color:#e9f3ff;
opacity:0.95;
font-size:15px;
line-height:1.55;
}

.news-feed-keywords{
display:flex;
align-items:center;
gap:8px;
flex-wrap:wrap;
margin:0 0 14px;
}

.news-feed-keywords span{
display:inline-flex;
align-items:center;
padding:5px 10px;
border-radius:999px;
border:1px solid rgb(129 224 255 / 34%);
background:rgb(13 42 56 / 68%);
color:#dff7ff;
font-size:11px;
font-weight:600;
line-height:1.2;
}

.news-feed-btn{
display:inline-flex;
align-items:center;
justify-content:center;
min-width:190px;
height:44px;
padding:0 16px;
text-decoration:none;
font-family:'Press Start 2P',cursive;
font-size:10px;
text-transform:uppercase;
color:#fcebc5;
background-image:url('../img/menu-item-buttons.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
text-shadow:0 1px 2px rgb(0 0 0 / 50%);
transition:transform 0.2s ease, filter 0.2s ease;
}

.news-feed-btn:hover{
transform:translateY(-2px) scale(1.03);
filter:brightness(1.08);
}

.news-pagination{
display:flex;
align-items:center;
justify-content:center;
gap:10px;
margin-top:20px;
}

.news-page-link{
display:inline-flex;
align-items:center;
justify-content:center;
min-width:38px;
height:38px;
padding:0 10px;
border-radius:10px;
border:1px solid rgb(252 235 197 / 24%);
background:rgb(11 29 42 / 70%);
color:#fcebc5;
text-decoration:none;
font-family:'Press Start 2P',cursive;
font-size:10px;
transition:transform 0.2s ease, filter 0.2s ease, border-color 0.2s ease;
}

.news-page-link:hover{
transform:translateY(-2px);
border-color:rgb(252 235 197 / 46%);
filter:brightness(1.08);
}

.news-page-link.is-active{
background:rgb(26 56 76 / 90%);
border-color:rgb(252 235 197 / 62%);
color:#fff5dc;
}

.news-page-dots{
color:#f1f6ff;
font-weight:700;
letter-spacing:2px;
}

@media (max-width:900px){
.news-feed-item{
grid-template-columns:250px minmax(0,1fr);
gap:14px;
}

.news-feed-image{
min-height:160px;
max-height:190px;
}

.news-feed-body h2{
font-size:15px;
}

.news-feed-meta{
font-size:11px;
}
}

@media (max-width:700px){
.news-page .guide-content{
padding:0;
}

.news-feed-item{
grid-template-columns:1fr;
padding:12px;
}

.news-feed-image{
min-height:170px;
max-height:210px;
}

.news-feed-body h2{
font-size:14px;
}

.news-feed-meta{
font-size:10px;
gap:6px;
}

.news-feed-meta span{
padding:4px 7px;
}

.news-feed-body p{
font-size:14px;
}

.news-feed-keywords{
gap:6px;
margin-bottom:12px;
}

.news-feed-keywords span{
font-size:10px;
padding:4px 8px;
}

.news-feed-btn{
min-width:172px;
height:40px;
font-size:9px;
}

.news-pagination{
gap:8px;
margin-top:14px;
}

.news-page-link{
min-width:34px;
height:34px;
font-size:9px;
}
}

/* NEWS DETAIL PAGE */

.news-detail-page .guide-page-shell{
grid-template-columns:1fr;
}

.news-detail-article{
width:min(100%, 980px);
margin:0 auto;
min-height:auto;
padding:26px;
}

.news-detail-meta{
display:flex;
flex-wrap:wrap;
gap:10px;
margin:0 0 16px;
}

.news-detail-meta span{
display:inline-flex;
align-items:center;
height:34px;
padding:0 12px;
border-radius:999px;
background:rgb(16 40 58 / 82%);
border:1px solid rgb(252 235 197 / 22%);
font-size:12px;
font-weight:600;
color:#f1f6ff;
}

.news-detail-keywords{
display:flex;
align-items:center;
gap:8px;
flex-wrap:wrap;
margin:0 0 14px;
}

.news-detail-keywords span{
display:inline-flex;
align-items:center;
padding:5px 10px;
border-radius:999px;
border:1px solid rgb(129 224 255 / 34%);
background:rgb(13 42 56 / 68%);
color:#dff7ff;
font-size:11px;
font-weight:600;
line-height:1.2;
}

.news-detail-cover{
width:100%;
display:block;
aspect-ratio:16 / 7;
object-fit:cover;
border-radius:14px;
border:1px solid rgb(252 235 197 / 24%);
margin:0 0 22px;
}

.news-detail-article h2{
margin:22px 0 10px;
font-family:'Press Start 2P',cursive;
font-size:18px;
line-height:1.35;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.news-detail-article p{
margin:0 0 14px;
max-width:100%;
color:#e9f3ff;
opacity:0.95;
font-size:16px;
line-height:1.7;
}

.news-detail-actions{
margin-top:24px;
}

@media (max-width:700px){
.news-detail-article{
padding:16px 14px;
}

.news-detail-meta span{
height:30px;
padding:0 10px;
font-size:11px;
}

.news-detail-keywords{
gap:6px;
margin-bottom:12px;
}

.news-detail-keywords span{
font-size:10px;
padding:4px 8px;
}

.news-detail-cover{
aspect-ratio:16 / 10;
margin-bottom:16px;
}

.news-detail-article h2{
font-size:14px;
margin-top:18px;
}

.news-detail-article p{
font-size:14px;
line-height:1.6;
}
}

/* STORE PAGE */

.store-page .guide-page-shell{
grid-template-columns:1fr;
}

.store-page .news-feed-btn:not(.store-buy-btn),
.section.store .store-visit-btn{
background-image:none !important;
background-color:transparent !important;
border:1px solid rgb(252 235 197 / 46%);
box-shadow:none;
filter:none;
}

.store-page .news-feed-btn:not(.store-buy-btn):hover,
.section.store .store-visit-btn:hover{
background-color:rgb(252 235 197 / 10%) !important;
border-color:rgb(252 235 197 / 72%);
filter:none;
}

.store-page-banner{
--guide-banner-image:url('../img/background-image-maplewood4.png')!important;
}

.store-floating-cart{
position:fixed;
right:18px;
bottom:98px;
width:74px;
height:74px;
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
text-decoration:none;
background:linear-gradient(145deg, rgb(16 43 63 / 96%), rgb(8 24 36 / 98%));
border:2px solid rgb(252 235 197 / 44%);
box-shadow:0 14px 28px rgb(0 0 0 / 38%);
z-index:1900;
transition:transform 0.2s ease, filter 0.2s ease;
}

.store-floating-cart:hover{
transform:translateY(-2px) scale(1.03);
filter:brightness(1.08);
}

.store-floating-cart-icon svg{
width:32px;
height:32px;
stroke:#fcebc5;
stroke-width:1.8;
fill:none;
stroke-linecap:round;
stroke-linejoin:round;
}

.store-floating-cart-count{
position:absolute;
top:-6px;
right:-3px;
min-width:28px;
height:28px;
padding:0 7px;
display:inline-flex;
align-items:center;
justify-content:center;
border-radius:999px;
background:rgb(200 39 39 / 96%);
color:#fff;
font-family:'Press Start 2P',cursive;
font-size:10px;
line-height:1;
border:2px solid rgb(255 255 255 / 26%);
}

.store-floating-cart-preview{
position:absolute;
right:86px;
bottom:0;
width:300px;
padding:12px;
border-radius:12px;
background:rgb(6 20 33 / 97%);
border:1px solid rgb(252 235 197 / 28%);
box-shadow:0 12px 28px rgb(0 0 0 / 42%);
display:none;
color:#f1f6ff;
pointer-events:none;
}

.store-floating-cart:hover .store-floating-cart-preview{
display:flex;
flex-direction:column;
gap:8px;
}

.store-floating-cart-preview strong{
font-family:'Press Start 2P',cursive;
font-size:11px;
color:#fcebc5;
}

.store-floating-cart-item{
display:flex;
align-items:center;
justify-content:space-between;
gap:10px;
font-size:12px;
line-height:1.3;
}

.store-floating-cart-item-main{
display:flex;
flex-direction:column;
gap:2px;
min-width:0;
}

.store-floating-cart-item-name{
max-width:220px;
white-space:nowrap;
overflow:hidden;
text-overflow:ellipsis;
}

.store-floating-cart-item-meta{
font-size:11px;
opacity:0.82;
}

.store-floating-cart-item-qty{
font-weight:700;
color:#fcebc5;
white-space:nowrap;
}

.store-floating-cart-empty,
.store-floating-cart-more{
font-size:12px;
opacity:0.9;
}

.store-floating-cart-total{
margin-top:4px;
padding-top:8px;
border-top:1px solid rgb(252 235 197 / 24%);
display:flex;
align-items:center;
justify-content:space-between;
font-size:12px;
font-weight:700;
color:#fcebc5;
}

.store-feed{
display:flex;
flex-direction:column;
gap:20px;
}

.store-catalog-layout{
display:grid;
grid-template-columns:minmax(230px, 280px) minmax(0, 1fr);
gap:18px;
align-items:start;
}

.store-category-sidebar{
background:linear-gradient(180deg,rgb(8 24 36 / 88%),rgb(5 17 28 / 90%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:14px;
padding:14px;
position:sticky;
top:92px;
}

.store-category-sidebar h3{
margin:0 0 10px;
font-family:'Press Start 2P',cursive;
font-size:13px;
line-height:1.3;
color:#fcebc5;
}

.store-category-list{
display:flex;
flex-direction:column;
gap:8px;
}

.store-category-btn{
display:flex;
align-items:center;
justify-content:space-between;
gap:10px;
border:1px solid rgb(252 235 197 / 20%);
border-radius:10px;
background:rgb(7 22 35 / 70%);
color:#e9f3ff;
padding:10px 12px;
font-size:12px;
font-weight:600;
cursor:pointer;
transition:transform 0.2s ease, border-color 0.2s ease, filter 0.2s ease;
}

.store-category-btn:hover{
transform:translateY(-1px);
border-color:rgb(252 235 197 / 42%);
filter:brightness(1.06);
}

.store-category-btn.is-active{
background:rgb(18 45 65 / 88%);
border-color:rgb(252 235 197 / 54%);
color:#fff5dc;
}

.store-category-count{
display:inline-flex;
align-items:center;
justify-content:center;
min-width:30px;
height:24px;
padding:0 8px;
border-radius:999px;
background:rgb(5 17 28 / 80%);
border:1px solid rgb(252 235 197 / 20%);
font-size:11px;
}

.store-catalog-main{
display:flex;
flex-direction:column;
gap:12px;
position:relative;
}

.store-category-heading{
display:flex;
align-items:flex-end;
justify-content:space-between;
gap:10px;
}

.store-category-heading h3{
margin:0;
font-family:'Press Start 2P',cursive;
font-size:15px;
line-height:1.3;
color:#fcebc5;
}

.store-category-heading p{
margin:0;
font-size:12px;
opacity:0.9;
}

.store-feed-header{
display:flex;
align-items:center;
justify-content:space-between;
gap:12px;
flex-wrap:wrap;
}

.store-initial-loading{
margin-top:-4px;
margin-bottom:4px;
}

.store-load-track{
width:100%;
height:8px;
border-radius:999px;
overflow:hidden;
background:rgb(8 24 36 / 70%);
border:1px solid rgb(252 235 197 / 20%);
}

.store-load-bar{
display:block;
width:35%;
height:100%;
border-radius:999px;
background:linear-gradient(90deg, rgb(252 235 197 / 38%), rgb(252 235 197 / 95%), rgb(252 235 197 / 38%));
animation:store-load-progress 1.15s ease-in-out infinite;
}

.store-initial-loading p{
margin:8px 0 0 !important;
font-size:12px !important;
opacity:0.9 !important;
}

@keyframes store-load-progress{
0%{transform:translateX(-120%);}
100%{transform:translateX(320%);}
}

.store-feed-title{
margin:0;
font-family:'Press Start 2P',cursive;
font-size:20px;
line-height:1.35;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.store-grid-page{
width:100%;
max-width:none;
margin-top:0;
display:grid;
grid-template-columns:repeat(3, minmax(0, 1fr));
gap:18px;
align-items:stretch;
position:relative;
}

.store-grid-page.is-loading{
opacity:0.55;
pointer-events:none;
}

.store-grid-loader{
position:absolute;
left:0;
right:0;
top:52px;
height:78px;
display:none;
align-items:center;
justify-content:center;
gap:10px;
border-radius:12px;
background:rgb(6 20 33 / 86%);
border:1px solid rgb(252 235 197 / 24%);
z-index:3;
color:#fcebc5;
font-size:13px;
font-weight:700;
}

.store-grid-loader.is-visible{
display:flex;
}

.store-grid-loader-spinner{
width:22px;
height:22px;
border:3px solid rgb(252 235 197 / 28%);
border-top-color:#fcebc5;
border-radius:50%;
animation:store-grid-spin 0.8s linear infinite;
}

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

.store-card-message{
width:100%;
}

.store-price{
font-size:14px;
font-weight:700;
color:#fcebc5 !important;
opacity:1 !important;
}

.store-buy-btn{
margin-top:10px;
}

.store-alert{
border:1px solid rgb(252 235 197 / 26%);
border-radius:12px;
padding:12px 14px;
font-size:14px;
line-height:1.45;
}

.store-alert-success{
background:rgb(18 69 36 / 62%);
}

.store-alert-error{
background:rgb(119 28 28 / 62%);
}

.store-alert-info{
background:rgb(17 48 74 / 62%);
}

.store-product-category{
font-size:11px !important;
text-transform:uppercase;
letter-spacing:0.6px;
opacity:0.88 !important;
}

.store-card-actions{
display:flex;
gap:10px;
flex-wrap:wrap;
margin-top:10px;
}

.store-grid-page .store-card{
padding:0;
overflow:hidden;
display:flex;
flex-direction:column;
min-height:100%;
background:linear-gradient(180deg, rgb(8 24 36 / 96%), rgb(5 17 28 / 96%));
border:1px solid rgb(252 235 197 / 24%);
border-radius:18px;
box-shadow:inset 0 0 0 1px rgb(252 235 197 / 10%);
}

.store-grid-page .store-item-content{
padding:10px 22px 24px;
height:100%;
display:flex;
flex-direction:column;
align-items:center;
text-align:center;
gap:8px;
}

.store-grid-page .store-item-content h3{
font-family:'Poppins',sans-serif;
font-weight:800;
letter-spacing:0.2px;
font-size:19px;
line-height:1.15;
min-height:0;
margin:6px 0 0;
color:#fff5dc;
}

.store-grid-page .store-item-content p{
font-size:13px;
line-height:1.45;
}

.store-grid-page .store-card-actions{
margin-top:auto;
padding-top:10px;
width:100%;
display:flex;
justify-content:center;
}

.store-product-image{
display:block;
width:148px;
height:148px;
object-fit:contain;
background:transparent;
border:none;
}

.store-image-link{
display:flex;
justify-content:center;
align-items:center;
line-height:0;
border:none;
padding:0;
background:transparent;
cursor:pointer;
width:100%;
text-align:left;
padding-top:24px;
}

.store-product-image-placeholder{
display:flex;
align-items:center;
justify-content:center;
height:172px;
background:transparent;
border:none;
}

.store-grid-page .store-product-category{
display:none;
}

.store-name-link{
background:none;
border:none;
padding:0;
margin:0;
cursor:pointer;
}

.store-name-link h3{
font-size:19px !important;
}

.store-grid-page .store-price{
font-family:'Poppins',sans-serif;
font-size:16px;
font-weight:700;
letter-spacing:0.2px;
color:rgb(200 191 183 / 88%) !important;
margin:4px 0 2px;
}

.store-grid-page .store-inline-form{
width:100%;
display:flex;
justify-content:center;
}

.store-grid-page .store-buy-btn{
margin-top:0;
width:min(320px, 100%);
padding:12px 16px;
border-radius:10px;
border:1px solid rgb(176 255 214 / 70%);
background:rgb(35 167 113 / 96%);
color:#f4fff9 !important;
font-family:'Press Start 2P',cursive !important;
font-size:14px;
font-weight:400;
line-height:1.2;
letter-spacing:0.2px;
text-transform:uppercase;
display:flex;
align-items:center;
justify-content:center;
gap:12px;
transition:border-color .2s ease, filter .2s ease, background .2s ease;
}

.store-grid-page .store-buy-btn span{
font-family:'Press Start 2P',cursive !important;
font-weight:400;
}

.store-grid-page .store-buy-btn:hover{
border-color:rgb(203 255 230 / 86%);
background:rgb(47 186 128 / 98%);
}

.store-grid-page .store-buy-btn.is-remove{
border-color:rgb(255 184 184 / 72%);
background:rgb(177 63 63 / 96%);
color:#fff5f5 !important;
}

.store-grid-page .store-buy-btn.is-remove:hover{
border-color:rgb(255 212 212 / 88%);
background:rgb(196 74 74 / 98%);
}

.store-grid-page .store-buy-btn:focus-visible{
outline:2px solid rgb(255 224 170 / 92%);
outline-offset:2px;
}

.store-buy-btn-icon{
display:inline-flex;
width:22px;
height:22px;
border-radius:50%;
background:rgb(255 248 236 / 22%);
border:1px solid rgb(255 236 198 / 54%);
color:#fff8ef;
align-items:center;
justify-content:center;
font-size:16px;
font-weight:800;
line-height:1;
}

.store-username-modal .store-buy-btn{
min-width:0;
width:100%;
height:44px;
padding:0 14px;
border-radius:10px;
border:1px solid rgb(252 235 197 / 46%);
background-image:none !important;
background-color:rgb(10 38 56 / 95%) !important;
box-shadow:none;
font-family:'Press Start 2P',cursive;
font-size:10px;
font-weight:400;
letter-spacing:0.2px;
text-transform:uppercase;
color:#fcebc5 !important;
}

.store-username-modal .store-buy-btn:hover{
background-color:rgb(13 47 70 / 95%) !important;
border-color:rgb(252 235 197 / 70%);
filter:none;
transform:none;
}

.store-product-image-detail{
border-radius:12px;
border:1px solid rgb(252 235 197 / 20%);
margin:0 0 12px;
}

.store-product-detail{
padding:18px;
}

.store-product-detail .store-item-content h3{
font-size:20px;
}

.store-product-detail .store-item-content p{
font-size:15px;
}

.store-inline-form{
display:inline-flex;
}

button.news-feed-btn{
border:none;
cursor:pointer;
}

.store-cart-form{
display:flex;
gap:10px;
align-items:flex-end;
flex-wrap:wrap;
margin-top:10px;
}

.store-qty-label{
display:flex;
flex-direction:column;
gap:6px;
font-size:12px;
font-weight:600;
color:#fcebc5;
}

.store-qty-label input,
.store-inline-form input[type="number"]{
height:40px;
width:90px;
border-radius:10px;
border:1px solid rgb(252 235 197 / 30%);
background:rgb(7 22 35 / 88%);
color:#fcebc5;
padding:0 10px;
font-weight:600;
}

.store-cart-card{
margin-top:4px;
}

.store-cart-items{
display:flex;
flex-direction:column;
gap:12px;
}

.store-cart-item{
display:flex;
justify-content:space-between;
gap:12px;
padding:12px;
border:1px solid rgb(252 235 197 / 20%);
border-radius:12px;
background:rgb(7 22 35 / 55%);
align-items:center;
flex-wrap:wrap;
}

.store-cart-item strong{
display:block;
margin-bottom:4px;
}

.store-cart-item > div:first-child{
display:grid;
grid-template-columns:auto 1fr;
gap:10px;
align-items:center;
}

.store-cart-thumb{
width:56px;
height:56px;
border-radius:10px;
object-fit:cover;
border:1px solid rgb(252 235 197 / 20%);
background:rgb(6 20 33 / 96%);
}

.store-cart-item p{
margin:0 !important;
font-size:13px !important;
opacity:0.9 !important;
}

.store-cart-actions{
display:flex;
gap:8px;
flex-wrap:wrap;
}

.store-cart-footer{
display:flex;
justify-content:space-between;
gap:10px;
margin-top:14px;
flex-wrap:wrap;
}

.store-remove-btn{
filter:saturate(0.72) hue-rotate(300deg);
}

.cart-page-shell .guide-content{
min-height:auto;
}

.cart-page-grid{
display:grid;
grid-template-columns:minmax(0,1.8fr) minmax(290px,1fr);
gap:18px;
align-items:start;
}

.cart-page-items .store-item-content h3,
.cart-page-summary .store-item-content h3{
margin-bottom:10px;
}

.cart-line-total{
font-size:12px !important;
opacity:0.86 !important;
}

.cart-summary-row{
display:flex;
align-items:center;
justify-content:space-between;
gap:10px;
padding:10px 0;
border-bottom:1px solid rgb(252 235 197 / 18%);
font-size:14px;
}

.cart-summary-row:last-of-type{
margin-bottom:8px;
}

.cart-summary-note{
font-size:12px !important;
opacity:0.88 !important;
margin-top:10px !important;
}

.store-username-chip{margin-top:20px;display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;border:1px solid rgb(252 235 197 / 28%);background: rgb(14 72 38 / 53%);color:#fcebc5;font-weight:700;font-size:13px;cursor:pointer;}

.store-username-avatar{
width:22px;
height:22px;
border-radius:50%;
flex-shrink:0;
object-fit:cover;
border:1px solid rgb(252 235 197 / 35%);
background:rgb(8 24 36 / 95%);
}

.store-username-chip strong{
color:#fff5dc;
}

.store-category-sidebar .store-username-chip{
width:100%;
justify-content:space-between;
margin:0 0 12px;
border-radius:12px;
}

.store-top-customer{
margin:0 0 12px;
padding:10px 12px;
border-radius:12px;
border:1px solid rgb(252 235 197 / 22%);
background:rgb(8 24 36 / 62%);
}

.store-top-customer-label{
margin:0 0 4px !important;
font-size:11px !important;
letter-spacing:.06em;
text-transform:uppercase;
opacity:.8 !important;
}

.store-top-customer-name{
display:block;
margin:0;
font-size:14px;
line-height:1.35;
color:#fff5dc;
}

.store-top-customer-total{
margin:4px 0 0 !important;
font-size:12px !important;
opacity:.88 !important;
}

.cart-page .store-cart-footer{
justify-content:flex-start;
}

.cart-page .store-cart-footer .store-inline-form{
width:100%;
}

.cart-page .store-cart-footer .news-feed-btn{
width:100%;
}

.cart-page .store-cart-footer .store-buy-btn{
background-image:none !important;
background-color:rgb(35 167 113 / 96%) !important;
border:1px solid rgb(176 255 214 / 70%);
box-shadow:none;
color:#f4fff9 !important;
}

.cart-page .store-cart-footer .store-buy-btn:hover{
background-color:rgb(47 186 128 / 98%) !important;
border-color:rgb(203 255 230 / 86%);
filter:none;
transform:none;
}

.cart-page .news-feed-btn[disabled]{
opacity:0.45;
pointer-events:none;
}

.store-product-modal{
position:fixed;
inset:0;
background:rgb(3 11 20 / 78%);
display:none;
align-items:center;
justify-content:center;
padding:20px;
z-index:2300;
}

.store-product-modal.is-open{
display:flex;
}

.store-product-modal-dialog{
width:min(980px, 96vw);
height:min(90vh, 900px);
max-height:min(90vh, 900px);
overflow:hidden;
background:
radial-gradient(140% 120% at 6% 0%, rgb(36 110 74 / 16%) 0%, rgb(36 110 74 / 0%) 52%),
linear-gradient(180deg, rgb(10 27 41 / 98%), rgb(6 18 30 / 98%));
border:1px solid rgb(252 235 197 / 20%);
border-radius:20px;
padding:22px;
display:grid;
grid-template-columns:minmax(280px, 1fr) minmax(0, 1.2fr);
gap:18px;
position:relative;
box-shadow:0 24px 50px rgb(0 0 0 / 55%);
}

.store-product-modal-close{
position:absolute;
top:14px;
right:14px;
width:44px;
height:44px;
border-radius:50%;
border:1px solid rgb(252 235 197 / 24%);
background:rgb(8 24 36 / 92%);
color:#fcebc5;
font-size:30px;
line-height:1;
cursor:pointer;
transition:background .2s ease, border-color .2s ease;
}

.store-product-modal-close:hover{
background:rgb(14 37 55 / 96%);
border-color:rgb(252 235 197 / 48%);
}

.store-product-modal-side{
display:flex;
flex-direction:column;
gap:12px;
padding:18px;
border-radius:16px;
border:1px solid rgb(252 235 197 / 18%);
background:linear-gradient(180deg, rgb(9 27 41 / 90%), rgb(7 20 33 / 92%));
box-shadow:inset 0 0 0 1px rgb(252 235 197 / 8%);
overflow:hidden;
}

.store-product-modal-media-wrap{
border-radius:12px;
overflow:hidden;
border:1px solid rgb(252 235 197 / 16%);
background:linear-gradient(145deg, rgb(14 36 53 / 92%), rgb(7 22 36 / 96%));
min-height:250px;
display:flex;
align-items:center;
justify-content:center;
padding:12px;
}

.store-product-modal-media{
display:block;
width:min(210px, 100%);
height:auto;
max-height:240px;
object-fit:contain;
}

.store-product-modal-side .store-product-category{
margin:2px 0 0;
font-size:10px !important;
letter-spacing:0.8px;
opacity:.8 !important;
}

.store-product-modal-side h3{
margin:0;
font-family:'Poppins',sans-serif;
font-size:38px;
font-weight:800;
line-height:1.1;
color:#fff5dc;
}

.store-product-modal-side .store-price{
margin:2px 0 0;
font-size:24px;
font-weight:700;
letter-spacing:0.2px;
color:rgb(230 220 208 / 90%) !important;
}

.store-product-modal-side .store-cart-form{
margin-top:8px;
display:flex;
flex-direction:column;
align-items:stretch;
gap:10px;
}

.store-product-modal-side .store-qty-label{
font-size:11px;
letter-spacing:0.2px;
text-transform:uppercase;
}

.store-product-modal-side .store-qty-label input{
width:100%;
height:42px;
border-radius:10px;
}

.store-product-modal-side .store-buy-btn{
margin-top:2px;
width:100%;
height:46px;
padding:0 14px;
border-radius:10px;
border:1px solid rgb(176 255 214 / 70%);
background:rgb(35 167 113 / 96%);
background-image:none !important;
color:#f4fff9 !important;
font-family:'Press Start 2P',cursive !important;
font-size:11px;
font-weight:400;
line-height:1.2;
letter-spacing:0.2px;
text-transform:uppercase;
box-shadow:none;
}

.store-product-modal-side .store-buy-btn:hover{
background:rgb(47 186 128 / 98%);
border-color:rgb(203 255 230 / 86%);
filter:none;
transform:none;
}

.store-product-modal-side .store-buy-btn.is-remove{
border-color:rgb(255 184 184 / 72%);
background:rgb(177 63 63 / 96%);
color:#fff5f5 !important;
}

.store-product-modal-side .store-buy-btn.is-remove:hover{
border-color:rgb(255 212 212 / 88%);
background:rgb(196 74 74 / 98%);
}

.store-product-modal-content{
display:flex;
flex-direction:column;
gap:12px;
padding:20px;
border-radius:16px;
border:1px solid rgb(252 235 197 / 14%);
background:rgb(6 19 32 / 82%);
min-height:100%;
overflow:hidden;
}

.store-product-modal-content h4{
margin:0;
font-family:'Poppins',sans-serif;
font-size:28px;
font-weight:800;
line-height:1.15;
color:#fcebc5;
padding-bottom:10px;
border-bottom:1px solid rgb(252 235 197 / 18%);
}

#store-product-modal-description{
white-space:normal;
font-size:16px;
line-height:1.6;
color:rgb(226 239 251 / 94%);
padding-right:10px;
overflow-wrap:anywhere;
overflow:auto;
flex:1;
min-height:0;
}

#store-product-modal-description strong{
color:#fff5dc;
font-weight:700;
}

#store-product-modal-description ul,
#store-product-modal-description ol{
padding-left:22px;
margin:10px 0;
}

#store-product-modal-description p{
margin:0 0 12px;
}

#store-product-modal-description li{
margin:0 0 8px;
}

.store-username-modal{
position:fixed;
inset:0;
background:rgb(4 14 24 / 72%);
display:none;
align-items:center;
justify-content:center;
padding:16px;
z-index:2400;
}

.store-username-modal.is-open{
display:flex;
}

.store-username-modal-dialog{
width:min(520px, 95vw);
background:linear-gradient(180deg,rgb(8 24 36 / 96%),rgb(5 17 28 / 96%));
border:1px solid rgb(252 235 197 / 24%);
border-radius:16px;
padding:22px 18px 18px;
position:relative;
box-shadow:0 18px 38px rgb(0 0 0 / 48%);
display:flex;
flex-direction:column;
gap:12px;
}

.store-username-modal-dialog h3{
margin:0;
font-family:'Press Start 2P',cursive;
font-size:16px;
line-height:1.45;
color:#fcebc5;
}

.store-username-modal-dialog p{
margin:0;
font-size:14px;
line-height:1.55;
color:#e9f3ff;
}

.store-username-form{
display:flex;
flex-direction:column;
gap:10px;
}

.store-username-form label{
font-size:13px;
font-weight:700;
color:#fcebc5;
}

.store-username-form input{
border-radius:10px;
border:1px solid rgb(252 235 197 / 30%);
background:rgb(8 24 36 / 85%);
color:#fff5dc;
padding:11px 12px;
font-size:14px;
}

.store-username-feedback{
min-height:20px;
font-size:13px !important;
}

.store-username-feedback.is-error{
color:#ffb6b6 !important;
}

.store-username-feedback.is-success{
color:#b8ffc2 !important;
}

.cart-username-form{
margin-top:12px;
display:flex;
gap:8px;
align-items:center;
}

.cart-username-form input[type="text"]{
flex:1;
min-width:0;
border-radius:10px;
border:1px solid rgb(252 235 197 / 30%);
background:rgb(8 24 36 / 85%);
color:#fff5dc;
padding:10px 12px;
font-size:14px;
}

@media (max-width:1050px){
.store-grid-page{
grid-template-columns:repeat(2, minmax(0, 1fr));
}

.cart-page-grid{
grid-template-columns:1fr;
}

.store-catalog-layout{
grid-template-columns:1fr;
}

.store-category-sidebar{
position:static;
}

.store-category-list{
flex-direction:row;
flex-wrap:wrap;
}

.store-category-btn{
min-width:180px;
}

.store-product-modal-dialog{
grid-template-columns:1fr;
padding:16px;
gap:14px;
height:min(90vh, 900px);
}

.store-product-modal-side{
padding:14px;
}

.store-product-modal-side h3{
font-size:30px;
}

.store-product-modal-side .store-price{
font-size:22px;
}

.store-product-modal-content{
padding:16px;
}

.store-product-modal-content h4{
font-size:24px;
}

#store-product-modal-description{
font-size:15px;
line-height:1.55;
}
}

@media (max-width:700px){
.store-floating-cart{
right:14px;
bottom:88px;
width:62px;
height:62px;
}

.store-floating-cart-icon svg{
width:27px;
height:27px;
}

.store-floating-cart-count{
min-width:24px;
height:24px;
font-size:9px;
}

.store-floating-cart-preview{
display:none !important;
}

.store-feed-title{
font-size:16px;
}

.store-grid-page{
grid-template-columns:1fr;
gap:14px;
}

.store-name-link h3{
font-size:18px !important;
}

.store-grid-page .store-price{
font-size:15px;
}

.store-grid-page .store-buy-btn{
font-size:13px;
}

.store-card-actions{
flex-direction:column;
}

.store-inline-form{
width:100%;
}

.store-inline-form .news-feed-btn,
.store-card-actions .news-feed-btn{
width:100%;
}

.cart-username-form{
flex-direction:column;
}

.cart-username-form .news-feed-btn{
width:100%;
}

.store-cart-actions{
width:100%;
}

.store-cart-actions .store-inline-form{
width:100%;
}

.store-product-modal-dialog{
grid-template-columns:1fr;
padding:14px;
height:min(94vh, 900px);
}

.store-product-modal-media-wrap{
min-height:190px;
padding:10px;
}

.store-product-modal-media{
width:min(170px, 100%);
max-height:190px;
}

.store-product-modal-side{
padding:12px;
}

.store-product-modal-side h3{
font-size:24px;
}

.store-product-modal-side .store-price{
font-size:18px;
}

.store-product-modal-side .store-buy-btn{
height:42px;
font-size:9px;
}

.store-product-modal-content{
padding:14px;
}

.store-product-modal-content h4{
font-size:20px;
}

#store-product-modal-description{
font-size:14px;
line-height:1.5;
max-height:44vh;
}
}

/* MAP PAGE */

.map-page .guide-page-shell{
grid-template-columns:1fr;
}

.map-page .guide-page-banner{
--guide-banner-image:url('../img/background-image-maplewood5.png')!important;
}

.map-page-shell .guide-content{
min-height:auto;
padding:24px;
}

.map-embed-card h2{
margin:0;
font-family:'Press Start 2P',cursive;
font-size:20px;
line-height:1.35;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 60%);
}

.map-embed-header{
display:flex;
align-items:center;
justify-content:space-between;
gap:14px;
margin-bottom:16px;
flex-wrap:wrap;
}

.map-modal-trigger{
border:none;
cursor:pointer;
background-color:transparent;
appearance:none;
-webkit-appearance:none;
}

.map-embed-wrap{
position:relative;
width:100%;
aspect-ratio:16 / 9;
border-radius:14px;
overflow:hidden;
border:1px solid rgb(252 235 197 / 24%);
background:rgb(8 24 36 / 88%);
}

.map-embed-wrap iframe{
position:absolute;
inset:0;
width:100%;
height:100%;
border:none;
}

.map-page .map-embed-wrap iframe{
transform:scale(1.3);
transform-origin:center center;
}

.map-embed-help{
margin:14px 0 0;
max-width:100%;
color:#e9f3ff;
opacity:0.95;
font-size:14px;
line-height:1.55;
}

.map-embed-help code{
font-family:monospace;
background:rgb(15 23 42 / 70%);
padding:2px 6px;
border-radius:6px;
border:1px solid rgb(252 235 197 / 22%);
}

.map-full-modal{
position:fixed;
inset:0;
display:flex;
align-items:center;
justify-content:center;
padding:16px;
background:rgb(6 12 18 / 78%);
backdrop-filter:blur(6px);
-webkit-backdrop-filter:blur(6px);
opacity:0;
visibility:hidden;
pointer-events:none;
transition:opacity 0.22s ease, visibility 0.22s ease;
z-index:3200;
}

.map-full-modal.is-open{
opacity:1;
visibility:visible;
pointer-events:auto;
}

.map-full-modal-panel{
position:relative;
width:min(96vw,1800px);
height:min(92vh,1020px);
border-radius:16px;
overflow:hidden;
border:1px solid rgb(252 235 197 / 28%);
box-shadow:0 18px 48px rgb(0 0 0 / 52%);
background:rgb(8 24 36 / 95%);
}

.map-full-modal-panel iframe{
width:100%;
height:100%;
border:none;
display:block;
}

.map-modal-slot{
width:100%;
height:100%;
}

.map-full-modal-panel .map-embed-wrap{
width:100%;
height:100%;
max-width:none;
aspect-ratio:auto;
border:none;
border-radius:0;
}

.map-embed-wrap.is-expanded{
position:relative;
inset:auto;
z-index:auto;
width:100%;
height:100%;
max-width:none;
aspect-ratio:auto;
border-radius:0;
box-shadow:none;
}

.map-embed-wrap.is-expanded iframe{
height:100%;
max-height:none;
}

.map-full-modal-close{
position:fixed;
top:18px;
right:18px;
z-index:2702;
pointer-events:auto;
}

.map-full-modal.is-open .map-full-modal-close{
position:fixed;
top:14px;
right:14px;
z-index:3200;
width:40px;
height:40px;
border:none;
border-radius:10px;
background:rgb(8 24 36 / 84%);
border:1px solid rgb(252 235 197 / 30%);
color:#fcebc5;
font-family:'Press Start 2P',cursive;
font-size:14px;
line-height:1;
cursor:pointer;
text-shadow:0 1px 2px rgb(0 0 0 / 55%);
}

.map-full-modal-close:hover{
filter:brightness(1.1);
}

@media (max-width:700px){
.map-page-shell .guide-content{
padding:14px;
}

.map-embed-card h2{
font-size:16px;
}

.map-embed-wrap{
aspect-ratio:auto;
height:calc(100vh - 70px);
height:calc(100dvh - 70px);
}

.map-embed-wrap iframe{
height:100%;
}

.map-embed-help{
font-size:13px;
}

.map-full-modal{
padding:10px;
}

.map-full-modal-panel{
width:100%;
height:88vh;
border-radius:12px;
}

.map-full-modal-close{
top:10px;
right:10px;
width:36px;
height:36px;
font-size:12px;
}
}

/* ERROR PAGE */

body.error-page{
background:
radial-gradient(circle at 14% 16%, rgb(252 235 197 / 20%), transparent 32%),
radial-gradient(circle at 84% 74%, rgb(86 193 255 / 22%), transparent 34%),
linear-gradient(180deg, rgb(3 9 15 / 30%) 0%, rgb(3 9 15 / 0%) 45%),
#0f172a;
}

.error-page-main{
min-height:100vh;
padding:122px 20px 72px;
display:flex;
align-items:center;
justify-content:center;
}

.error-shell{
width:min(100%, 920px);
background:
radial-gradient(circle at 50% -15%, rgb(252 235 197 / 14%), transparent 52%),
linear-gradient(180deg,rgb(10 30 45 / 96%),rgb(6 18 29 / 96%));
border:1px solid rgb(252 235 197 / 30%);
border-radius:20px;
padding:42px 34px;
text-align:center;
box-shadow:
0 22px 48px rgb(0 0 0 / 44%),
0 0 0 1px rgb(255 255 255 / 3%) inset;
position:relative;
overflow:hidden;
}

.error-shell::before{
content:"";
position:absolute;
left:50%;
top:-120px;
width:520px;
height:240px;
transform:translateX(-50%);
background:radial-gradient(ellipse at center, rgb(252 235 197 / 20%) 0%, rgb(252 235 197 / 0%) 70%);
pointer-events:none;
}

.error-kicker{
margin:0 0 14px;
display:inline-flex;
align-items:center;
justify-content:center;
height:28px;
padding:0 12px;
font-family:'Press Start 2P',cursive;
font-size:10px;
letter-spacing:0.2px;
color:#fff6dc;
background:rgb(8 24 36 / 80%);
border:1px solid rgb(252 235 197 / 36%);
border-radius:999px;
text-shadow:0 1px 2px rgb(0 0 0 / 50%);
position:relative;
z-index:1;
}

.error-code{
margin:0 0 16px;
font-family:'Press Start 2P',cursive;
font-size:clamp(44px, 8.2vw, 112px);
line-height:1.1;
color:#fcebc5;
text-shadow:
0 4px 16px rgb(0 0 0 / 70%),
0 0 18px rgb(252 235 197 / 26%);
position:relative;
z-index:1;
}

.error-shell h1{
margin:0 0 14px;
font-family:'Press Start 2P',cursive;
font-size:clamp(20px, 2.3vw, 34px);
line-height:1.25;
color:#fcebc5;
position:relative;
z-index:1;
}

.error-subtitle{
margin:0 auto;
max-width:700px;
color:#e9f3ff;
opacity:0.95;
font-size:17px;
line-height:1.6;
position:relative;
z-index:1;
}

.error-actions{
margin-top:30px;
display:flex;
gap:12px;
justify-content:center;
flex-wrap:wrap;
position:relative;
z-index:1;
}

.error-btn{
text-decoration:none;
display:inline-flex;
align-items:center;
justify-content:center;
min-width:210px;
height:46px;
padding:0 16px;
font-family:'Press Start 2P',cursive;
font-size:11px;
line-height:1;
letter-spacing:0.3px;
color:#fcebc5;
text-shadow:0 1px 2px rgb(0 0 0 / 50%);
background-image:url('../img/menu-item-buttons-selected.png');
background-repeat:no-repeat;
background-size:100% 100%;
background-position:center;
transition:transform 0.2s ease, filter 0.2s ease;
}

.error-btn:hover,
.error-btn:focus-visible{
transform:translateY(-2px) scale(1.02);
filter:brightness(1.08);
}

.error-btn-alt{
background-image:url('../img/menu-item-buttons.png');
}

@media (max-width:700px){
.error-shell{
padding:30px 18px;
border-radius:14px;
}

.error-kicker{
height:24px;
font-size:9px;
padding:0 10px;
}

.error-subtitle{
font-size:15px;
}

.error-btn{
min-width:100%;
height:44px;
font-size:10px;
}
}
.margin-top-20{
margin-top:20px!important;
}
