:root{
  --bg1:#0a0a0a; --bg2:#2b2b2b;
  --ink:#e7fefe; --muted:#9ccccc;
  --teal:#00d9d9; --teal-soft:#7ef9f9;
  --line:rgba(255,255,255,.06);
  --smokeX: 50%; --smokeY: 50%;
}
*{box-sizing:border-box}
html,body{height:100%} html{scroll-behavior:smooth}
body{
  margin:0; color:var(--ink);
  font-family:'Poppins',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  overflow-x:hidden;
  background:
    radial-gradient(1000px 600px at 10% 10%, #0f1a1a 0%, transparent 35%) fixed,
    radial-gradient(900px 500px at 90% 90%, #0e1a1a 0%, transparent 40%) fixed,
    linear-gradient(180deg, var(--bg1), var(--bg2));
  cursor: none; /* nasconde il cursore di sistema per immersione */
}
/* FUMO REATTIVO MOLTO EVIDENTE (globale) */
body::before{
  content:''; position:fixed; inset:0; z-index:-1;
  background:
    radial-gradient(800px 420px at var(--smokeX) var(--smokeY), rgba(0,217,217,.45), transparent 60%),
    radial-gradient(1200px 640px at calc(var(--smokeX) + 12%) calc(var(--smokeY) + 10%), rgba(126,249,249,.30), transparent 65%),
    radial-gradient(900px 540px at calc(var(--smokeX) - 14%) calc(var(--smokeY) - 12%), rgba(108,163,163,.28), transparent 70%),
    url('../img/smoke-bg.png') center/cover no-repeat;
  opacity:.5; /* molto evidente */
  filter: blur(8px) saturate(120%) contrast(112%);
  animation:smokeDrift 60s linear infinite;
}
@keyframes smokeDrift{
  0%{background-position: center, center, center, center}
  50%{background-position: calc(var(--smokeX) + 2%) calc(var(--smokeY) + 2%), calc(var(--smokeX) - 2%) calc(var(--smokeY) - 2%), center, center}
  100%{background-position: center, center, center, center}
}

/* NAVBAR */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:10px 18px;
  background:rgba(0,0,0,.45); backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)
}
.nav .brand{display:flex; align-items:center; gap:10px; color:#fff; text-decoration:none}
.nav .brand img{height:28px; filter:drop-shadow(0 0 6px rgba(0,217,217,.6))}
.nav .brand span{font:700 18px/1 'Bebas Neue',sans-serif; letter-spacing:2px}
.nav-links{display:flex; gap:16px; list-style:none; margin:0; padding:0}
.nav-links a{color:var(--muted); text-decoration:none; padding:6px 10px; border-radius:10px; transition:.25s}
.nav-links a.active,.nav-links a:hover{color:#fff; background:rgba(0,217,217,.08); text-shadow:0 0 8px rgba(0,217,217,.6); box-shadow:inset 0 -2px 0 var(--teal)}

/* PANELS */
.panel{position:relative; min-height:100svh; display:flex; align-items:center; justify-content:center; padding:108px 20px 86px}
.panel-content .container,.panel-media .container{width:min(1100px,92vw); margin-inline:auto}
.section-title{font:700 42px/1 'Bebas Neue',sans-serif; letter-spacing:3px; color:var(--teal); text-transform:uppercase; margin:0 0 10px}
.lead{color:#cfeeee; max-width:900px}

/* HERO */
.panel-hero{text-align:center}
.spray-wrap{position:relative; display:inline-block}
.logo-hero{width:min(360px,62vw); filter:drop-shadow(0 0 22px rgba(0,217,217,.7)); opacity:0; transform:translateY(10px) scale(.98); animation:logoIn .8s ease .2s forwards, glowPulse 3s ease-in-out .8s infinite}
@keyframes logoIn{to{opacity:1; transform:translateY(0) scale(1)}}
@keyframes glowPulse{0%,100%{filter:drop-shadow(0 0 20px rgba(0,217,217,.7))}50%{filter:drop-shadow(0 0 38px rgba(0,217,217,1))}}
.spray-drip{position:absolute; top:85%; width:6px; height:0; background:linear-gradient(var(--teal), transparent); border-radius:3px; filter:blur(.3px); opacity:.9; animation:drip 3s ease-out forwards}
.spray-drip.d1{left:18%} .spray-drip.d2{left:52%; animation-delay:.2s} .spray-drip.d3{left:78%; animation-delay:.35s}
@keyframes drip{0%{height:0; opacity:0} 10%{opacity:1} 80%{height:52px} 100%{height:64px; opacity:.3}}

.title{margin:12px 0 6px; font:700 clamp(42px,8vw,96px)/.9 'Bebas Neue',sans-serif; letter-spacing:4px; position:relative}
.motto{color:var(--teal-soft); opacity:.98}
.glow{text-shadow:0 0 26px rgba(0,242,242,.6)}
.cta{margin-top:20px; display:flex; gap:12px; justify-content:center; flex-wrap:wrap}
.btn{cursor:pointer; border:none; text-decoration:none; padding:12px 20px; border-radius:999px; transition:.25s; font-weight:700}
.btn.neon{background:var(--teal); color:#001717; box-shadow:0 0 0 rgba(0,217,217,0)}
.btn.neon:hover{box-shadow:0 0 28px rgba(0,217,217,.9)}
.btn.outline{background:transparent; color:var(--teal); border:1px solid rgba(0,217,217,.6)}
.btn.outline:hover{background:rgba(0,217,217,.18)}

.scroll-indicator{position:absolute; bottom:18px; left:50%; transform:translateX(-50%); color:var(--muted); font-size:12px; letter-spacing:2px; text-transform:uppercase; animation:float 2.4s ease-in-out infinite}
@keyframes float{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,-8px)}}

/* GRAIN */
.grain{position:absolute; inset:0; pointer-events:none; background-image:url('../img/noise.png'); opacity:.06; mix-blend-mode:screen; animation:grain 10s steps(10) infinite}
@keyframes grain{0%{transform:translate(0,0)}25%{transform:translate(-10px,5px)}50%{transform:translate(5px,-10px)}75%{transform:translate(10px,5px)}100%{transform:translate(0,0)}}

/* CARDS */
.cards{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; margin-top:22px}
.card{background:linear-gradient(180deg,#0b0b0b,#0f0f0f); border:1px solid var(--line); border-radius:18px; padding:18px; transition:transform .25s, box-shadow .25s, border-color .25s; text-decoration:none; color:#fff}
.card:hover{transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.35), 0 0 22px rgba(0,217,217,.3); border-color:rgba(0,217,217,.35)}
.card h3{margin:0 0 8px; color:var(--teal)}
.edge{position:relative}
.edge::before{content:''; position:absolute; inset:0; border-radius:inherit; padding:1px; background:linear-gradient(120deg, rgba(0,217,217,.0), rgba(0,217,217,.7), rgba(0,217,217,.0)); -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; animation:edgeFlow 3.2s linear infinite}
@keyframes edgeFlow{0%{background-position:-200% 0} 100%{background-position:200% 0}}

/* TIMELINE */
.timeline{border-left:2px dashed rgba(255,255,255,.25); margin:16px 0 0 10px; padding-left:16px}
.t-item{position:relative; margin:18px 0; padding-left:8px}
.t-dot{position:absolute; left:-27px; top:6px; width:14px; height:14px; border-radius:50%; background:radial-gradient(circle at 30% 30%, #fff, var(--teal)); box-shadow:0 0 16px rgba(0,217,217,.8)}

/* VALUES */
.values{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; margin-top:10px}
.v-card{background:#0f0f0f; border:1px solid var(--line); border-radius:16px; padding:18px; text-align:center; transition:.25s}
.v-ico{font-size:28px; display:block; margin-bottom:6px}
.v-card:hover{transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,.35), 0 0 26px rgba(0,217,217,.35); border-color:rgba(0,217,217,.35)}

/* GALLERY */
.gallery{display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:12px; margin-top:14px}
.gallery-item{overflow:hidden; border-radius:16px; border:1px solid var(--line); position:relative}
.gallery-item img{width:100%; height:100%; object-fit:cover; display:block; transform:scale(1.04); transition:transform .5s ease, filter .5s ease}
.gallery-item:hover img{transform:scale(1.1); filter:contrast(1.05) brightness(1.05)}
.lightbox{position:fixed; inset:0; background:rgba(0,0,0,.85); display:none; align-items:center; justify-content:center; z-index:60; padding:20px}
.lightbox.open{display:flex}
.lightbox-img{max-width:92vw; max-height:84vh; border-radius:14px; box-shadow:0 0 40px rgba(0,217,217,.3)}
.lightbox-close{position:absolute; top:18px; right:18px; font-size:28px; background:transparent; color:#fff; border:1px solid rgba(255,255,255,.2); border-radius:10px; padding:6px 12px; cursor:pointer}

/* CONTACT */
.contact-actions{display:flex; gap:12px; margin:10px 0 16px; flex-wrap:wrap}
.contact-form{display:flex; flex-direction:column; gap:10px}
.contact-form .row{display:flex; gap:10px; flex-wrap:wrap}
.contact-form input, .contact-form textarea{flex:1; background:#121212; color:#e8ffff; border:1px solid var(--line); border-radius:12px; padding:12px 14px; outline:none; transition:border-color .25s, box-shadow .25s}
.contact-form textarea{min-height:140px; resize:vertical}
.contact-form input:focus, .contact-form textarea:focus{border-color:rgba(0,217,217,.6); box-shadow:0 0 0 3px rgba(0,217,217,.18)}
.form-note{color:#8fbcbc; font-size:12px}

/* LISTS & GRIDS */
.famiglia-grid,.streamers-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:20px; margin-top:30px}
.famiglia-card,.streamer-card{background:#111; border:1px solid var(--line); border-radius:18px; padding:16px; text-align:center; transition:transform .3s, box-shadow .3s, border-color .3s}
.famiglia-card:hover,.streamer-card:hover{transform:translateY(-5px); box-shadow:0 8px 30px rgba(0,0,0,.35), 0 0 26px rgba(0,217,217,.4); border-color:rgba(0,217,217,.4)}
.famiglia-card img,.streamer-card img{width:100%; border-radius:12px; margin-bottom:10px; height:220px; object-fit:cover; border:2px solid rgba(0,217,217,.45); box-shadow:0 0 22px rgba(0,217,217,.35); transition:transform .35s ease, box-shadow .35s ease}
.famiglia-card:hover img,.streamer-card:hover img{transform:scale(1.03); box-shadow:0 0 44px rgba(0,217,217,.75)}
.back-space{height:36px} /* extra spazio sopra al bottone per evitare sormonto */

/* FOOTER */
.footer{padding:28px 14px; text-align:center; color:var(--muted); background:linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.6)); border-top:1px solid var(--line)}
.footer .badge{margin:6px 0 0; opacity:.95}

/* BUTTONS & MISC */
.to-top{position:fixed; right:16px; bottom:16px; z-index:55; border:none; padding:10px 12px; border-radius:12px; background:rgba(0,217,217,.22); color:#dff; cursor:pointer; opacity:0; transform:translateY(10px); transition:.25s; backdrop-filter:blur(10px)}
.to-top.show{opacity:1; transform:translateY(0)}
.to-top:hover{background:rgba(0,217,217,.32)}

/* RESPONSIVE */
@media (max-width:800px){
  .section-title{font-size:34px}
  .logo-hero{width:min(260px,70vw)}
}

/* REDUCED MOTION */
@media (prefers-reduced-motion:reduce){
  *{animation:none!important; transition:none!important}
}


@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap');

body {
    font-family: 'Poppins', sans-serif !important;
    background: linear-gradient(135deg, #001f1f, #003333, #001f1f);
    background-size: 400% 400%;
    animation: gradientMove 15s ease infinite;
}
@keyframes gradientMove {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

a:hover, h1:hover, h2:hover, h3:hover, button:hover {
    text-shadow: 0 0 10px #00e6e6, 0 0 20px #00e6e6;
}

.fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 1s ease, transform 1s ease;
}
.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}

.cursor, .cursor-dot, #cursor {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
}


/* Font e animazioni globali */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;600;700&display=swap');
body {
    font-family: 'Poppins', sans-serif !important;
    background: linear-gradient(135deg, #001f1f, #003333, #001f1f);
    background-size: 400% 400%;
    animation: gradientMove 15s ease infinite;
}
@keyframes gradientMove {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}
a:hover, h1:hover, h2:hover, h3:hover, button:hover {
    text-shadow: 0 0 10px #00e6e6, 0 0 20px #00e6e6;
}
.fade-in {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 1s ease, transform 1s ease;
}
.fade-in.visible {
    opacity: 1;
    transform: translateY(0);
}
/* Cursor fix: invisibile solo in navbar */
.navbar .cursor, .navbar .cursor-dot, .navbar #cursor {
    display: none !important;
    opacity: 0 !important;
    visibility: hidden !important;
}
