:root{
  /* Palette ispirata allo screen del gioco */
  --bg0:#070A10;
  --bg1:#0A0F1E;
  --navy:#0F1B33;
  --navy2:#1A2A4A;
  --amber0:#3A1F0C;
  --amber1:#6A3A12;
  --amber2:#9A5A18;
  --gold0:#F7E7B4;
  --gold1:#F0CF7A;
  --gold2:#D6A74E;
  --gold3:#B8822A;
  --ice:#2CD3FF;
  --muted:rgba(255,255,255,.72);
  --muted2:rgba(255,255,255,.55);
  --line:rgba(255,255,255,.10);
  --shadow: 0 18px 60px rgba(0,0,0,.55);
  --radius: 22px;
  --radius2: 28px;
  --max: 1120px;
  --btnH: 56px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:#fff;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(1200px 700px at 20% -10%, rgba(214,167,78,.18), transparent 60%),
    radial-gradient(900px 600px at 85% 10%, rgba(44,211,255,.12), transparent 55%),
    radial-gradient(900px 700px at 40% 120%, rgba(154,90,24,.20), transparent 60%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x:hidden;
}

/* “Luce” che si muove (effetto casino discreto) */
.spotlight{
  pointer-events:none;
  position:fixed; inset:-40vh -30vw;
  background:
    radial-gradient(closest-side at 35% 20%, rgba(240,207,122,.15), transparent 65%),
    radial-gradient(closest-side at 70% 35%, rgba(44,211,255,.10), transparent 60%),
    radial-gradient(closest-side at 50% 80%, rgba(184,130,42,.12), transparent 65%);
  filter: blur(10px);
  animation: drift 14s ease-in-out infinite alternate;
  opacity:.9;
  z-index:0;
}
@keyframes drift{
  0%{ transform: translate3d(-2%, -1%, 0) scale(1); }
  100%{ transform: translate3d(2%, 1%, 0) scale(1.03); }
}

a{color:inherit; text-decoration:none}
.wrap{position:relative; z-index:1}

.topbar{
  position:sticky; top:0; z-index:10;
  backdrop-filter: blur(10px);
  background: linear-gradient(180deg, rgba(10,15,30,.82), rgba(10,15,30,.55));
  border-bottom:1px solid var(--line);
}
.topbar-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:14px 18px;
  display:flex; align-items:center; justify-content:space-between;
  gap:12px;
}
.brand{
  display:flex; align-items:center; gap:12px;
  min-width: 220px;
}
.brand img{
  width:42px; height:42px; border-radius:12px;
  border:1px solid rgba(255,255,255,.16);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  object-fit:cover;
}
.brand .name{line-height:1.1}
.brand .name strong{
  font-family:Cinzel, serif;
  letter-spacing:.04em;
  font-size:16px;
}
.brand .name span{
  display:block;
  color:var(--muted2);
  font-size:12px;
  margin-top:3px;
}
.nav{
  display:flex; gap:12px; flex-wrap:wrap; justify-content:flex-end;
}
.nav a{
  font-size:13px;
  color:var(--muted);
  padding:8px 10px;
  border-radius:999px;
  border:1px solid transparent;
  transition: all .18s ease;
}
.nav a:hover{
  color:#fff;
  border-color: rgba(240,207,122,.22);
  background: rgba(240,207,122,.06);
}
.nav a[aria-current="page"]{
  color:#fff;
  border-color: rgba(240,207,122,.32);
  background: rgba(240,207,122,.08);
}

/* Hero */
.hero{
  max-width:var(--max);
  margin: 0 auto;
  padding: 34px 18px 22px;
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: 22px;
  align-items:stretch;
}
@media (max-width: 980px){
  .hero{grid-template-columns:1fr; padding-top:22px}
  .brand{min-width:auto}
}

.card{
  border-radius:var(--radius2);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}
.card::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(800px 220px at 20% 0%, rgba(240,207,122,.15), transparent 60%),
    radial-gradient(600px 260px at 85% 0%, rgba(44,211,255,.10), transparent 60%);
  opacity:.85;
  pointer-events:none;
}
.card-inner{ position:relative; padding: 28px 26px; }

.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(240,207,122,.24);
  background: rgba(240,207,122,.08);
  color: rgba(255,255,255,.88);
  letter-spacing:.02em;
}
.dot{
  width:7px; height:7px; border-radius:50%;
  background: radial-gradient(circle at 30% 30%, var(--gold0), var(--gold2));
  box-shadow: 0 0 18px rgba(240,207,122,.55);
}

h1{
  margin: 16px 0 10px;
  font-family:Cinzel, serif;
  font-size: 44px;
  line-height: 1.05;
  letter-spacing:.02em;
  background: linear-gradient(180deg, var(--gold0), var(--gold1) 55%, var(--gold2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  text-shadow: 0 10px 28px rgba(0,0,0,.35);
}
@media (max-width: 520px){
  h1{font-size: 36px}
}

.sub{
  color: var(--muted);
  font-size: 16px;
  line-height: 1.55;
  max-width: 56ch;
  margin: 0 0 18px;
}

.badges{
  display:flex; gap:10px; flex-wrap:wrap;
  margin: 18px 0 12px;
}
.pill{
  display:inline-flex; align-items:center; gap:9px;
  padding:10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.82);
  font-size: 13px;
}
.pill b{color:#fff; font-weight:700}
.pill .mini{
  width:22px; height:22px; border-radius:8px;
  display:grid; place-items:center;
  background: linear-gradient(180deg, rgba(240,207,122,.25), rgba(214,167,78,.06));
  border:1px solid rgba(240,207,122,.25);
  box-shadow: 0 10px 25px rgba(0,0,0,.25);
}

.cta-row{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top: 18px;
  align-items:center;
}
.btn{
  height: var(--btnH);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 0 18px;
  border-radius: 16px;
  border: 1px solid rgba(240,207,122,.26);
  background: linear-gradient(180deg, rgba(154,90,24,.42), rgba(58,31,12,.35));
  color:#fff;
  font-weight:700;
  letter-spacing:.02em;
  position:relative;
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  transition: transform .16s ease, filter .16s ease, border-color .16s ease;
  user-select:none;
  white-space:nowrap;
}
.btn:hover{
  transform: translateY(-1px);
  filter: brightness(1.06);
  border-color: rgba(240,207,122,.42);
}
.btn:active{ transform: translateY(0px) scale(.99); }
.btn .ic{
  width:26px; height:26px;
  border-radius:10px;
  display:grid; place-items:center;
  background: linear-gradient(180deg, rgba(240,207,122,.26), rgba(214,167,78,.06));
  border:1px solid rgba(240,207,122,.25);
}

/* Shimmer sul CTA principale */
.btn.primary::after{
  content:"";
  position:absolute;
  top:-40%;
  left:-40%;
  width: 65%;
  height: 180%;
  background: linear-gradient(90deg, transparent, rgba(247,231,180,.28), transparent);
  transform: rotate(18deg);
  animation: shimmer 3.6s ease-in-out infinite;
  opacity:.9;
}
@keyframes shimmer{
  0%{ transform: translateX(-140%) rotate(18deg); }
  50%{ transform: translateX(240%) rotate(18deg); }
  100%{ transform: translateX(240%) rotate(18deg); }
}

.btn.secondary{
  border: 1px solid rgba(255,255,255,.14);
  background: linear-gradient(180deg, rgba(15,27,51,.65), rgba(15,27,51,.35));
  color: rgba(255,255,255,.90);
}

.store-note{
  color: var(--muted2);
  font-size: 12px;
  margin-top: 10px;
  line-height:1.45;
}

/* Preview “phone” */
.preview{
  display:grid;
  place-items:center;
  padding: 18px;
}
.phone{
  width: min(360px, 100%);
  aspect-ratio: 9/19.5;
  border-radius: 34px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02));
  box-shadow: 0 28px 70px rgba(0,0,0,.65);
  overflow:hidden;
  position:relative;
}
.phone::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(180px 120px at 25% 20%, rgba(240,207,122,.18), transparent 70%),
    radial-gradient(220px 160px at 75% 25%, rgba(44,211,255,.10), transparent 70%);
  pointer-events:none;
  mix-blend-mode: screen;
  opacity:.9;
}
.phone img{
  width:100%; height:100%;
  object-fit:cover;
  filter: saturate(1.05) contrast(1.04);
  transform: scale(1.02);
}
.glass{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(255,255,255,.12), transparent 30%, rgba(0,0,0,.08));
  pointer-events:none;
}

/* Sections */
section{
  max-width:var(--max);
  margin: 0 auto;
  padding: 18px 18px;
}
.grid-3{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
@media (max-width: 900px){
  .grid-3{grid-template-columns:1fr}
}

.tile{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  overflow:hidden;
  position:relative;
}
.tile::before{
  content:"";
  position:absolute; inset:-1px;
  background:
    radial-gradient(500px 180px at 15% 0%, rgba(240,207,122,.14), transparent 62%),
    radial-gradient(420px 220px at 90% 10%, rgba(44,211,255,.10), transparent 65%);
  opacity:.85;
  pointer-events:none;
}
.tile > div{ position:relative; padding: 18px 18px 16px; }
.tile h3{
  margin: 0 0 8px;
  font-family: Cinzel, serif;
  letter-spacing:.02em;
  font-size: 18px;
  background: linear-gradient(180deg, var(--gold0), var(--gold2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.tile p{
  margin:0;
  color: var(--muted);
  line-height: 1.55;
  font-size: 14px;
}
.tile .tag{
  display:inline-flex;
  margin-top: 12px;
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(240,207,122,.20);
  background: rgba(240,207,122,.07);
  color: rgba(255,255,255,.86);
}

/* Screenshot strip */
.shots{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 10px;
}
@media (max-width: 900px){
  .shots{grid-template-columns:1fr}
}
.shot{
  border-radius: var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  position:relative;
  min-height: 210px;
}
.shot img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.03) contrast(1.03);
  transform: scale(1.01);
  transition: transform .25s ease;
}
.shot:hover img{ transform: scale(1.05); }

/* FAQ */
.faq{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 900px){
  .faq{grid-template-columns:1fr}
}
details{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  padding: 14px 14px;
  box-shadow: 0 18px 55px rgba(0,0,0,.40);
}
summary{
  cursor:pointer;
  list-style:none;
  font-weight: 700;
  color: rgba(255,255,255,.92);
}
summary::-webkit-details-marker{display:none}
details p{
  margin:10px 0 0;
  color: var(--muted);
  line-height:1.6;
  font-size: 14px;
}

/* Footer */
footer{
  padding: 28px 18px 40px;
  border-top:1px solid var(--line);
  background: linear-gradient(180deg, rgba(10,15,30,.25), rgba(0,0,0,.0));
}
.footer-inner{
  max-width:var(--max);
  margin:0 auto;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 14px;
  flex-wrap:wrap;
}
.small{
  color: var(--muted2);
  font-size: 12px;
  line-height: 1.45;
}

/* Reveal animation (JS aggiunge .in) */
.reveal{
  opacity:0;
  transform: translateY(10px);
  transition: opacity .55s ease, transform .55s ease;
}
.reveal.in{
  opacity:1;
  transform: translateY(0);
}

/* Legal pages */
.page{
  max-width: var(--max);
  margin: 0 auto;
  padding: 22px 18px 22px;
}
.prose{
  color: rgba(255,255,255,.88);
  line-height: 1.7;
  font-size: 15px;
}
.prose p{ margin: 0 0 14px; }
.prose a{ color: var(--gold1); text-decoration: underline; text-underline-offset: 2px; }
.prose a:hover{ color: var(--gold0); }
.prose h2{
  margin: 24px 0 10px;
  font-family: Cinzel, serif;
  letter-spacing: .02em;
  font-size: 22px;
  background: linear-gradient(180deg, var(--gold0), var(--gold2));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.prose h3{
  margin: 18px 0 8px;
  font-size: 16px;
  color: rgba(255,255,255,.95);
}
.prose ul{ margin: 0 0 14px 20px; padding:0; color: rgba(255,255,255,.84); }
.prose li{ margin: 6px 0; }
.notice{
  border-radius: var(--radius);
  border:1px solid rgba(240,207,122,.22);
  background: rgba(240,207,122,.08);
  padding: 14px 14px;
  color: rgba(255,255,255,.90);
}
.meta-row{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
  color: var(--muted2);
  font-size: 12px;
}

