:root {
  --bg:#0e0e0e;
  --ink:#f5f5f5;
  --ink-dim:#c2c2c2;
  --accent:#ff005c;
  --accent-neon:#16ffd9;
  --accent-alt:#7f00ff;
  --panel:#161616;
  --panel-soft:#1f1f1f;
  --radius:20px;
  --grad:linear-gradient(135deg,#ff005c 0%,#7f00ff 50%,#16ffd9 100%);
  --font-1:'Urbanist',sans-serif;
  --font-2:'Montserrat',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body {
  background: var(--bg) url("data:image/svg+xml,%3Csvg width='140' height='140' viewBox='0 0 140 140' xmlns='http://www.w3.org/2000/svg'%3E%3Crect fill='%23101010' width='140' height='140'/%3E%3Cpath d='M0 140L140 0ZM70 140L140 70ZM0 70L70 0Z' stroke='%231a1a1a' stroke-width='1' stroke-opacity='.4'/%3E%3C/svg%3E") fixed;
  font-family: var(--font-2);
  color: var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  padding-top: 70px;
}
img{max-width:100%;display:block}

.hero {
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:100px 20px 60px;
  overflow:hidden;
  background: radial-gradient(circle at 30% 40%,#222 0%,#0d0d0d 70%);
}
.overlay-texture{
  position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg,rgba(255,255,255,0.03)0 4px,transparent 4px 8px),
    radial-gradient(circle at 70% 30%,rgba(255,0,120,.15),transparent 70%);
  mix-blend-mode:overlay;
  pointer-events:none;
  opacity:.6;
}
.hero-inner {max-width:880px;z-index:2;}
.logo {
  font-family:var(--font-1);
  font-size:clamp(2.8rem,6vw,4.8rem);
  letter-spacing:-2px;
  font-weight:900;
  background:var(--grad);
  -webkit-background-clip:text;
  color:transparent;
  position:relative;
  text-shadow:0 0 18px rgba(255,255,255,0.15);
}
.logo span {
  display:block;
  font-size:.38em;
  letter-spacing:4px;
  margin-top:-10px;
  font-weight:700;
  text-shadow:none;
}
.tagline {
  font-size:1.2rem;
  margin:25px auto 40px;
  max-width:640px;
  color:var(--ink-dim);
  font-weight:400;
}
.cta-group {display:flex;gap:20px;justify-content:center;flex-wrap:wrap;}
.btn {
  --btn-bg:var(--panel-soft);
  padding:16px 34px;
  border-radius:40px;
  font-weight:600;
  font-size:.95rem;
  letter-spacing:.5px;
  text-decoration:none;
  color:var(--ink);
  background:var(--btn-bg);
  position:relative;
  overflow:hidden;
  border:1px solid #2c2c2c;
  transition:.35s;
  box-shadow:0 4px 14px -6px rgba(0,0,0,.6);
}
.btn.primary {
  background:var(--grad);
  color:#fff;
  border:none;
  box-shadow:0 0 0 0 rgba(255,0,92,.6),0 12px 30px -10px rgba(0,0,0,.7);
}
.btn.primary:hover {transform:translateY(-3px);box-shadow:0 0 18px -2px rgba(255,0,140,.5),0 16px 40px -12px rgba(0,0,0,.9);}
.btn.ghost {background:#151515;border:1px solid #292929;}
.btn.ghost:hover {border-color:var(--accent-neon);color:var(--accent-neon);}
.btn.pulse {animation:pulseGlow 3s infinite;}
@keyframes pulseGlow {
  0%,100% {box-shadow:0 0 0 0 rgba(22,255,217,.4);}
  40% {box-shadow:0 0 25px -5px rgba(22,255,217,.7);}
}

.floating-badge {
  position:absolute;
  top:35px;right:30px;
  background:rgba(0,0,0,.55);
  backdrop-filter:blur(6px);
  padding:10px 18px;
  font-size:.7rem;
  letter-spacing:2px;
  border:1px solid #333;
  border-radius:30px;
  text-transform:uppercase;
  font-weight:600;
  color:var(--accent-neon);
  box-shadow:0 0 12px -4px var(--accent-neon);
}

.scroll-down {
  position:absolute;
  bottom:28px;
  left:50%;
  transform:translateX(-50%);
  width:30px;height:50px;
  border:2px solid #333;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  opacity:.6;
  transition:.3s;
}
.scroll-down:hover {opacity:1;border-color:var(--accent-neon);}
.scroll-down span {
  display:block;
  width:6px;height:6px;
  background:var(--accent-neon);
  border-radius:50%;
  animation:scrollDot 1.6s infinite;
  box-shadow:0 0 8px var(--accent-neon);
}
@keyframes scrollDot {
  0% {transform:translateY(-10px);opacity:.2;}
  50% {transform:translateY(6px);opacity:1;}
  100% {transform:translateY(-10px);opacity:.2;}
}

/* Sections */
.section {padding:90px 26px;position:relative;}
.section h2 {
  font-family:var(--font-1);
  font-size:clamp(1.9rem,4vw,3rem);
  letter-spacing:-1px;
  margin-bottom:25px;
  background:linear-gradient(90deg,#fff,#999);
  -webkit-background-clip:text;
  color:transparent;
}
.section-intro {max-width:640px;margin:0 auto 40px;text-align:center;color:var(--ink-dim);}

.wrap {max-width:1200px;margin:0 auto;}
.wrap.split {display:grid;gap:70px;align-items:center;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));}
.wrap.narrow {max-width:780px;text-align:center;}

.highlight {
  background:radial-gradient(circle at 80% 10%,#1d1d1d, #101010);
  border-top:1px solid #1c1c1c;
  border-bottom:1px solid #1c1c1c;
}

.features {list-style:none;margin:25px 0 28px;padding:0;}
.features li {margin:4px 0;color:var(--accent-neon);font-weight:500;font-size:.9rem;letter-spacing:.5px;}

.neo-card {
  background:linear-gradient(140deg,#171717 0%,#121212 70%);
  border:1px solid #272727;
  border-radius:var(--radius);
  padding:30px 32px;
  position:relative;
  overflow:hidden;
  box-shadow:0 0 0 1px #1a1a1a,0 16px 40px -22px rgba(0,0,0,.8);
}
.neo-card:before, .neo-card:after {
  content:"";
  position:absolute;
  width:240px;height:240px;
  background:radial-gradient(circle,var(--accent-neon),transparent 70%);
  top:-120px;right:-90px;
  opacity:.07;
  mix-blend-mode:screen;
}
.neo-card h3 {margin:0 0 18px;font-family:var(--font-1);letter-spacing:1px;}

.steps {display:grid;gap:12px;font-size:.85rem;margin-bottom:25px;}
.step {
  background:#191919;
  border:1px solid #242424;
  padding:10px 14px;
  border-radius:14px;
  display:flex;
  align-items:center;
  gap:10px;
  letter-spacing:.5px;
}
.step span {
  width:28px;height:28px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:var(--grad);
  font-size:.75rem;font-weight:700;
}

.status-bar {
  position:relative;
  background:#1d1d1d;
  height:10px;
  border-radius:8px;
  margin-bottom:16px;
  overflow:hidden;
  border:1px solid #242424;
}
.status-bar .bar {
  position:absolute;
  inset:0;
  width:35%;
  background:var(--grad);
  animation:progress 4s linear infinite;
  filter:drop-shadow(0 0 6px rgba(255,0,120,.5));
}
@keyframes progress {
  0% {transform:translateX(-100%);}
  100% {transform:translateX(200%);}
}
.hint {font-size:.75rem;color:var(--ink-dim);letter-spacing:1px;text-transform:uppercase;margin:0;}
.small {font-size:.7rem;letter-spacing:1px;margin-top:18px;}
.muted {color:#666;}

/* Stores */
.stores {background:#0c0c0c;}
.store-grid {
  display:grid;
  gap:36px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  margin-top:40px;
}
.store-card {
  background:#141414;
  border:1px solid #272727;
  border-radius:26px;
  overflow:hidden;
  position:relative;
  display:flex;
  flex-direction:column;
  min-height:300px;
  box-shadow:0 10px 26px -18px rgba(0,0,0,.9);
  transition:.35s;
}
.store-card:hover {transform:translateY(-6px);border-color:#444;}
.store-card.full {grid-column:1/-1;display:block;background:#181818;}
.store-img {
  height:160px;
  background-size:cover;
  background-position:center;
  filter:grayscale(.4) contrast(1.1);
  position:relative;
}
.store-img:after {
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(to top,#111 0%,transparent 100%);
  opacity:.8;
}
.store-img.img1 {background-image:linear-gradient(120deg,#111,#111),url('assets/img/loja1.jpg');}
.store-img.img2 {background-image:linear-gradient(120deg,#111,#111),url('assets/img/loja2.jpg');}

.store-body {padding:20px 22px 28px;display:flex;flex-direction:column;gap:8px;}
.store-body.wide {padding:36px 32px;}
.store-body h3 {margin:0;font-family:var(--font-1);font-size:1.4rem;}
.addr {line-height:1.3;font-size:.85rem;color:var(--ink-dim);}
.tag {
  font-size:.6rem;
  letter-spacing:1px;
  text-transform:uppercase;
  background:var(--grad);
  -webkit-background-clip:text;
  color:transparent;
  font-weight:700;
}
.tag.alt {background:linear-gradient(90deg,#16ffd9,#7f00ff);-webkit-background-clip:text;}
.mini-btn {
  margin-top:auto;
  align-self:flex-start;
  font-size:.65rem;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:10px 16px;
  border-radius:40px;
  text-decoration:none;
  background:#1e1e1e;
  border:1px solid #2b2b2b;
  color:var(--ink-dim);
  transition:.3s;
}
.mini-btn:hover {color:var(--accent-neon);border-color:var(--accent-neon);}

.hours {
  list-style:none;
  margin:12px 0 18px;
  padding:0;
  font-size:.9rem;
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}
.obs {font-size:.7rem;color:#777;letter-spacing:.5px;}

/* About / Contact */
.about {background:radial-gradient(circle at 40% 20%,#181818,#0b0b0b);}
.contact {background:#101010;}
.contact a.link-bold {color:var(--accent-neon);font-weight:600;text-decoration:none;}
.contact a.link-bold:hover {text-decoration:underline;}
.social {display:flex;gap:14px;margin-top:18px;}
.soc {
  width:44px;height:44px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:#171717;
  color:#888;
  font-weight:600;
  text-decoration:none;
  font-size:.8rem;
  border:1px solid #242424;
  transition:.3s;
}
.soc:hover {color:var(--accent-neon);border-color:var(--accent-neon);}

/* Footer */
.footer {
  padding:60px 20px 40px;
  text-align:center;
  background:#050505;
  border-top:1px solid #191919;
  font-size:.8rem;
  color:#666;
}
.footer p {margin:6px 0;}
.tiny {font-size:.6rem;letter-spacing:1px;text-transform:uppercase;}

/* Back to top */
.back-top {
  position:fixed;
  right:20px;bottom:22px;
  width:46px;height:46px;
  background:#141414;
  border:1px solid #2a2a2a;
  backdrop-filter:blur(4px);
  color:#777;
  text-decoration:none;
  display:flex;align-items:center;justify-content:center;
  font-weight:600;
  border-radius:14px;
  font-size:1.1rem;
  transition:.3s;
  opacity:.8;
}
.back-top:hover {color:var(--accent-neon);border-color:var(--accent-neon);opacity:1;}

/* Minigame */
.game-section { background:#0c0c0c; border-top:1px solid #1b1b1b; border-bottom:1px solid #1b1b1b; }
.game-hud {
  display:flex; gap:18px; align-items:center; justify-content:space-between;
  background:#121212; border:1px solid #232323; border-radius:14px; padding:12px 16px; margin:10px 0 12px;
}
.game-actions { display:flex; gap:10px; }
.game-area {
  position:relative; height:420px; border:1px solid #232323; border-radius:16px;
  background: radial-gradient(circle at 70% 30%, #171717, #0e0e0e);
  overflow:hidden; box-shadow:0 10px 30px -22px rgba(0,0,0,.7);
}
.leaf {
  position:absolute; cursor:pointer; user-select:none;
  filter: drop-shadow(0 0 6px rgba(22,255,217,.4));
  animation: floatUp 1.6s ease-out forwards;
}
.leaf:active { transform: scale(0.9); }
.game-result { margin-top:10px; color:#16ffd9; font-weight:600; }
@keyframes floatUp {
  0% { transform: translateY(20px) scale(0.9); opacity:.0; }
  30% { opacity:1; }
  100% { transform: translateY(-40px) scale(1); opacity:.0; }
}

@media (max-width:640px){
  .game-hud { flex-direction:column; align-items:flex-start; gap:8px; }
  .game-area { height:360px; }
}
  background:linear-gradient(90deg,#fff,#bbb);
  -webkit-background-clip:text;
  color:transparent;
}
.store-info {
  display:flex;
  flex-direction:column;
  gap:6px;
  font-size:.75rem;
  line-height:1.3;
  margin-bottom:10px;
  color:var(--ink-dim);
}
.store-info .icon {
  font-size:1rem;
  vertical-align:middle;
  margin-right:4px;
  color:var(--accent-neon);
}
.store-hours {
  display:flex;
  flex-direction:column;
  gap:4px;
  margin:6px 0 10px;
  font-size:.65rem;
  letter-spacing:.5px;
  text-transform:uppercase;
}
.store-hours .day {
  display:flex;
  justify-content:space-between;
  background:#181818;
  border:1px solid #242424;
  padding:6px 10px;
  border-radius:8px;
}
.store-hours .day.closed {
  opacity:.45;
  background:#141414;
  border-style:dashed;
}
.store-actions .btn {
  font-size:.65rem;
  padding:10px 18px;
  letter-spacing:1px;
}

/* Avaliações */
.reviews {
  background:#101010;
  border-top:1px solid #1c1c1c;
  border-bottom:1px solid #1c1c1c;
}
.reviews h2 {margin-top:0;}
.reviews .dashboard-review {
  transition:.3s;
}
.reviews .dashboard-review:hover {
  transform:translateY(-4px);
  box-shadow:0 0 18px -6px #000;
}

/* Galeria ajuste de figura */
.gallery-grid figure {position:relative;}
.gallery-grid figure img {display:block;}

/* Ajuste badge fechada */
.floating-badge {transition:.35s;}
.floating-badge.offline {
  background:rgba(120,0,0,.55)!important;
  color:#ffb3b3!important;
  box-shadow:0 0 12px -4px #ff6262;
}

/* Responsividade adicional */
@media (max-width:680px){
  .store-hours .day {font-size:.6rem;padding:5px 8px;}
  .store-actions {flex-direction:column;}
  .store-actions .btn {width:100%;text-align:center;}
  #avaliacoes .btn {width:100%;}
}

/* Ícones Material fallback */
.icon.material-icons {
  font-family:'Material Icons';
  font-weight:normal;
  font-style:normal;
  line-height:1;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-transform:none;
  letter-spacing:normal;
  -webkit-font-smoothing:antialiased;
}

/* Correção scroll anchor offset suave (opcional) */
html {
  scroll-behavior:smooth;
}
