/* ==========================================================
   Rete di Boyle — rete.css  v2
   ========================================================== */
*, *::before, *::after { box-sizing: border-box; margin: 0; }
html { scroll-behavior: smooth; }

:root {
  --r-bg:     #020c1a;
  --r-text:   #edf7ff;
  --r-muted:  rgba(237,247,255,.72);
  --r-soft:   rgba(237,247,255,.46);
  --r-cyan:   #7be4ff;
  --r-cyan2:  #a8eeff;
  --r-border: rgba(120,210,255,.18);
  --r-glass:  rgba(5,18,46,.64);
  --r-shadow: 0 22px 56px rgba(0,0,0,.44);
  --r-glow:   0 0 34px rgba(100,200,255,.14);
  --r-r:      24px;
}

body {
  margin: 0; color: var(--r-text);
  font-family: 'DM Sans', system-ui, -apple-system, sans-serif;
  background: transparent; overflow-x: hidden; line-height: 1.6;
}
/* Sfondo oceano identico all'home */
body::before {
  content: ""; position: fixed; inset: 0; z-index: -3;
  background: url("assets/ocean-desktop.jpg") center top / cover no-repeat;
}
/* body::after rimosso */
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.skip { position: absolute; left: 12px; top: -60px; background: #fff; color: #00131e; padding: 10px 14px; border-radius: 10px; z-index: 200; }
.skip:focus { top: 12px; }
.container { width: min(1400px,100%); padding: 0 28px; margin: 0 auto; }

/* ── HEADER ── */
.header {
  position: sticky; top: 0; z-index: 200; width: 100%;
  background: rgba(4, 20, 52, 0.94);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  border-bottom: 1px solid rgba(80,170,255,.18);
  box-shadow: 0 1px 0 rgba(40,130,255,.10), 0 4px 28px rgba(0,0,0,.22);
  transition: background .3s;
}
.header.scrolled { background: rgba(3, 14, 38, 0.98); }
.header__inner { display: flex; align-items: center; justify-content: space-between; min-height: 72px; gap: 16px; position: relative; }
.brand { display: flex; align-items: center; gap: 13px; }
.brand img { width: 50px; height: 50px; flex-shrink: 0; border-radius: 50%; filter: drop-shadow(0 0 10px rgba(123,228,255,.3)); }
.brand__text { display: grid; gap: 2px; min-width: 0; }
.brand__text strong { font-size: .94rem; font-weight: 700; white-space: nowrap; }
.brand__text em { font-style: normal; font-size: .63rem; color: var(--r-soft); white-space: normal; overflow: hidden; display: block; line-height: 1.3; }
.nav--desktop { display: flex; align-items: center; gap: 4px; font-size: .88rem; }
.nav--desktop a { color: var(--r-muted); padding: 6px 11px; border-radius: 9px; transition: color .2s, background .2s; }
.nav--desktop a:hover { color: var(--r-text); background: rgba(123,228,255,.08); }
.nav-active { color: var(--r-text) !important; background: rgba(123,228,255,.1) !important; }
.nav-cta { background: linear-gradient(135deg, rgba(125,232,255,.98), rgba(82,158,255,.92)); color: #021830 !important; font-weight: 700; padding: 7px 16px !important; border-radius: 999px !important; }
.nav-mobile-btn { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 42px; height: 42px; background: rgba(6,20,44,.7); border: 1px solid rgba(123,228,255,.2); border-radius: 11px; padding: 0 11px; cursor: pointer; }
.nav-mobile-btn span { display: block; height: 2px; background: var(--r-text); border-radius: 2px; transition: transform .22s, opacity .22s; }
.nav-mobile-btn.is-open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-mobile-btn.is-open span:nth-child(2) { opacity: 0; }
.nav-mobile-btn.is-open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.nav-mobile-panel { display: none; position: absolute; top: calc(100% + 10px); right: 8px; width: calc(100vw - 32px); z-index: 9000; background: rgba(3,14,32,.97); border: 1px solid rgba(123,228,255,.2); border-radius: 18px; padding: 10px; box-shadow: 0 24px 60px rgba(0,0,0,.55); backdrop-filter: blur(22px); z-index: 200; }
.nav-mobile-panel[aria-hidden="false"] { display: grid; gap: 2px; }
.nav-mobile-panel a { display: block; padding: 11px 16px; border-radius: 12px; font-size: .98rem; font-weight: 600; transition: background .15s; text-align: center; }
.nav-mobile-panel .lang-toggle--mobile { display: flex; }
.lang-toggle--mobile {
  margin-top: 6px; width: 100%; padding: 10px 16px;
  display: none; align-items: center; justify-content: center; gap: 4px;
  border-radius: 10px; background: rgba(123,228,255,.08);
  border: 1px solid rgba(123,228,255,.22); color: #a8eeff;
  font-size: .82rem; font-weight: 700; letter-spacing: .08em; cursor: pointer;
  transition: background .18s;
}
.lang-toggle--mobile:hover { background: rgba(123,228,255,.16); }
.lang-toggle--mobile .lang-sep { opacity: .4; font-weight: 400; }
.nav-mobile-panel a:hover { background: rgba(123,228,255,.09); color: var(--r-cyan2); }

/* ── HERO ── */
.hero {
  position: relative; min-height: auto; padding: 36px 40px 8px;
  margin: 0;
  border-bottom: none;
}
.hero::before { display: none; }
.hero__connectome { position: absolute; inset: 0; z-index: 1; pointer-events: none; opacity: .44; transition: opacity .3s; }
.hero:hover .hero__connectome { opacity: .54; }
.connectome-svg { width: 100%; height: 100%; display: block; }
.connectome-links path { fill: none; stroke: rgba(170,241,255,.17); stroke-width: 1.6; stroke-linecap: round; }
.connectome-links path.link-soft  { stroke: rgba(170,241,255,.1);  stroke-width: 1.1; }
.connectome-links path.link-faint { stroke: rgba(170,241,255,.07); stroke-width: .9; }
.connectome-nodes .node { fill: url(#nodeGrad); opacity: .22; animation: nodePulse 6.5s ease-in-out infinite; transform-origin: center; }
.connectome-nodes .node-2{ animation-delay:-1.2s; } .connectome-nodes .node-3{ animation-delay:-3.1s; }
.connectome-nodes .node-4{ animation-delay:-2.4s; } .connectome-nodes .node-5{ animation-delay:-4.2s; }
.connectome-nodes .node-6{ animation-delay:-1.8s; } .connectome-nodes .node-7{ animation-delay:-5.1s; }
.connectome-nodes .node-8{ animation-delay:-2.9s; } .connectome-nodes .node-9{ animation-delay:-3.8s; }
.connectome-nodes .node-10{ animation-delay:-1.5s; } .connectome-nodes .node-11{ animation-delay:-4.9s; }
.connectome-nodes .node-12{ animation-delay:-2.2s; } .connectome-nodes .node-13{ animation-delay:-5.8s; }
.connectome-nodes .node-14{ animation-delay:-3.2s; } .connectome-nodes .node-15{ animation-delay:-1.1s; }
.connectome-nodes .node-16{ animation-delay:-4.4s; }
.traveler { fill: #fff; opacity: .82; filter: drop-shadow(0 0 5px rgba(255,255,255,.9)) drop-shadow(0 0 16px rgba(124,243,255,.95)); animation: travelerFlicker 2.6s steps(2,end) infinite; }
.traveler-b{ animation-delay:-1.1s; } .traveler-c{ animation-delay:-.3s; }
.traveler-d{ animation-delay:-1.8s; } .traveler-e{ animation-delay:-2.2s; }
.traveler-f{ animation-delay:-.7s; }
@keyframes nodePulse { 0%,100%{opacity:.16;transform:scale(.86);} 28%{opacity:.56;transform:scale(1.14);} 70%{opacity:.18;transform:scale(.9);} }
@keyframes travelerFlicker { 0%,100%{opacity:.14;} 15%{opacity:.92;} 58%{opacity:.85;} 66%{opacity:.2;} }

.hero__content {
  position: relative; z-index: 10; max-width: 720px; padding-top: 8px;
}
.hero__content::before { display: none; }
.hero__eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 5px 16px; border-radius: 999px; font-size: .68rem;
  letter-spacing: .22em; text-transform: uppercase; font-weight: 600;
  color: var(--r-cyan2); background: rgba(123,228,255,.08);
  border: 1px solid rgba(123,228,255,.18); margin-bottom: 20px;
}
.hero__title { font-size: clamp(2.8rem, 6vw, 5.2rem); font-weight: 800; letter-spacing: -.05em; line-height: .9; margin-bottom: 18px; }
.hero__glow { color: var(--r-cyan2); text-shadow: 0 0 40px rgba(123,228,255,.4); }
.hero__subtitle { font-size: 1.06rem; color: var(--r-muted); max-width: 58ch; line-height: 1.68; margin-bottom: 28px; }
.hero__cta { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-bottom: 16px; }
.hero__stats { display: flex; gap: 0; background: rgba(5,18,46,.48); border: 1px solid rgba(123,228,255,.14); border-radius: 14px; overflow: visible; backdrop-filter: blur(14px); max-width: 100%; width: 100%; }
.hero__stat { flex: 1; padding: 14px 16px; text-align: center; border-right: 1px solid rgba(123,228,255,.1); }
.hero__stat:last-child { border-right: 0; }
.hero__stat-n { display: block; font-size: 1.5rem; font-weight: 700; color: var(--r-cyan2); letter-spacing: -.04em; line-height: 1; margin-bottom: 3px; }
.hero__stat-l { font-size: .68rem; color: var(--r-soft); letter-spacing: .04em; }

/* ── BUTTONS ── */
.btn-electric {
  position: relative; overflow: hidden; display: inline-flex; align-items: center;
  min-height: 50px; padding: 0 24px; border-radius: 999px;
  border: 1px solid rgba(124,243,255,.34);
  background: linear-gradient(135deg, rgba(8,78,176,.96), rgba(10,142,231,.92));
  color: #fff; font-weight: 700; cursor: pointer;
  box-shadow: 0 14px 34px rgba(0,75,170,.28), inset 0 1px 0 rgba(255,255,255,.14);
  transition: transform .18s, filter .18s, box-shadow .18s;
}
.btn-electric:hover { transform: translateY(-2px); filter: brightness(1.06); box-shadow: 0 18px 40px rgba(0,75,170,.36); }
.btn-electric::before {
  content: ""; position: absolute; inset: -30% auto -30% -18%; width: 28%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.88), transparent);
  transform: skewX(-22deg); filter: blur(4px); opacity: .95;
  animation: electricSweep 2.6s linear infinite;
}
@keyframes electricSweep { 0%{left:-24%;} 100%{left:118%;} }
.btn-electric__inner { position: relative; z-index: 1; display: flex; align-items: center; gap: 8px; }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  min-height: 50px; padding: 0 22px; border-radius: 999px;
  background: rgba(5,18,46,.6); border: 1px solid rgba(123,228,255,.24);
  color: var(--r-muted); font-weight: 600; backdrop-filter: blur(10px);
  transition: border-color .2s, background .2s, transform .2s;
}
.btn-ghost:hover { border-color: rgba(123,228,255,.44); background: rgba(8,26,60,.75); transform: translateY(-2px); }

/* ── MEMBERS SECTION ── */
.members-section { padding: 0 0 80px; position: relative; }
.members-header { padding-top: 8px; }
.members-header { margin-bottom: 32px; }
.members-title { font-size: clamp(1.8rem,3.5vw,2.8rem); font-weight: 700; letter-spacing: -.04em; margin-bottom: 8px; }
.members-sub { color: var(--r-muted); font-size: .96rem; }

/* Canvas sinaptico */
#synapseCanvas {
  position: fixed; inset: 0; pointer-events: none;
  width: 100vw; height: 100vh; z-index: 1; opacity: .62;
}

/* Grid carte */
.members-grid {
  position: relative; z-index: 1;
  display: grid; grid-template-columns: repeat(5, minmax(0,1fr));
  gap: 20px;
}

/* ── MEMBER CARD ── */
.member-card {
  position: relative; overflow: visible;
  min-height: 380px; border-radius: var(--r-r);
  border: 1px solid rgba(150,228,255,.22);
  background: linear-gradient(180deg, rgba(14,58,110,.12), rgba(4,16,34,.26)), rgba(4,14,28,.2);
  box-shadow: 0 0 0 1px rgba(124,243,255,.03) inset, 0 0 22px rgba(124,243,255,.05), var(--r-shadow);
  backdrop-filter: blur(12px);
  padding: 22px 18px 18px;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  /* Animazione entrata */
  will-change: transform, opacity;
  opacity: 0; transform: translateY(28px);
  transition: opacity .65s ease, transform .65s cubic-bezier(.22,.68,0,1.2),
              border-color .25s, box-shadow .25s;
}
.member-card.is-visible { opacity: 1; transform: none; }

/* ── Profilo completo: bordo verde + linea luminosa in cima ── */
.member-card--complete {
  border-color: rgba(0,210,130,.45) !important;
  box-shadow:
    0 0 0 1px rgba(0,210,130,.12) inset,
    0 0 28px rgba(0,210,130,.10),
    var(--r-shadow);
}
.member-card--complete::before {
  background:
    radial-gradient(circle at top, rgba(0,210,130,.18), transparent 38%),
    linear-gradient(180deg, rgba(0,210,130,.08), transparent 28%) !important;
}
/* Linea luminosa verde in cima */
.member-card--complete::after {
  box-shadow:
    inset 0 2px 0 rgba(0,210,130,.70),
    inset 0 1px 0 rgba(255,255,255,.10),
    inset 0 -1px 0 rgba(0,0,0,.18),
    inset 1px 0 0 rgba(255,255,255,.04) !important;
}
/* Profilo parziale: bordo arancione sottile */
.member-card--partial {
  border-color: rgba(220,120,30,.32) !important;
  box-shadow:
    0 0 0 1px rgba(220,120,30,.08) inset,
    0 0 20px rgba(220,120,30,.07),
    var(--r-shadow);
}
.member-card--partial::after {
  box-shadow:
    inset 0 2px 0 rgba(220,120,30,.45),
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(0,0,0,.18),
    inset 1px 0 0 rgba(255,255,255,.04) !important;
}
/* Stagger */
.member-card:nth-child(1){transition-delay:.00s} .member-card:nth-child(2){transition-delay:.07s}
.member-card:nth-child(3){transition-delay:.14s} .member-card:nth-child(4){transition-delay:.21s}
.member-card:nth-child(5){transition-delay:.28s} .member-card:nth-child(6){transition-delay:.35s}
.member-card:nth-child(7){transition-delay:.42s} .member-card:nth-child(8){transition-delay:.49s}
.member-card:nth-child(9){transition-delay:.56s} .member-card:nth-child(10){transition-delay:.63s}
.member-card:nth-child(11){transition-delay:.00s} .member-card:nth-child(12){transition-delay:.07s}
.member-card:nth-child(13){transition-delay:.14s} .member-card:nth-child(14){transition-delay:.21s}

/* Vetro 3D: riflesso */
.member-card::before {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  background:
    radial-gradient(circle at top, rgba(124,243,255,.12), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.05), transparent 32%);
  opacity: .8;
}
/* Bordo vetro spesso */
.member-card::after {
  content: ""; position: absolute; inset: 0; border-radius: inherit; pointer-events: none;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.16),
    inset 0 -1px 0 rgba(0,0,0,.18),
    inset 1px 0 0 rgba(255,255,255,.06);
}
/* Linea luminosa cyan in basso */
.member-card .member-location {
  position: absolute; bottom: 62px; left: 0; right: 0;
  display: flex; align-items: center; gap: 0; padding: 0 18px;
  z-index: 2;
}
.member-location__line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(124,243,255,.55), transparent);
  box-shadow: 0 0 8px rgba(124,243,255,.22);
}
.member-location__city {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .66rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--r-cyan2); padding: 0 10px; white-space: nowrap; flex-shrink: 0;
}

/* Hover: sollevamento + glow */
.member-card:hover {
  transform: translateY(-7px) !important;
  border-color: rgba(124,243,255,.4);
  box-shadow: 0 0 0 1px rgba(124,243,255,.1) inset, 0 0 36px rgba(124,243,255,.14), var(--r-shadow);
}
.member-card > * { position: relative; z-index: 1; }

/* Foto */
.member-photo-wrap {
  width: 148px; height: 148px; margin: 0 auto 16px;
  border-radius: 999px; padding: 5px;
  background: radial-gradient(circle, rgba(124,243,255,.18), rgba(124,243,255,.02) 62%, transparent 72%);
  box-shadow: 0 0 0 2px rgba(124,243,255,.26), 0 0 24px rgba(124,243,255,.32), 0 0 60px rgba(124,243,255,.1);
  flex: 0 0 auto; transition: box-shadow .25s;
}
.member-card:hover .member-photo-wrap { box-shadow: 0 0 0 2px rgba(124,243,255,.38), 0 0 34px rgba(124,243,255,.48), 0 0 80px rgba(124,243,255,.18); }

/* ── Circonferenza foto: colore profilo ── */
.member-photo-wrap--complete {
  box-shadow:
    0 0 0 2.5px rgba(0,210,130,.75),
    0 0 18px rgba(0,210,130,.35),
    0 0 50px rgba(0,210,130,.12) !important;
  background: radial-gradient(circle, rgba(0,210,130,.20), rgba(0,210,130,.04) 62%, transparent 72%) !important;
}
.member-photo-wrap--partial {
  box-shadow:
    0 0 0 2px rgba(220,140,30,.60),
    0 0 14px rgba(220,140,30,.22),
    0 0 36px rgba(220,140,30,.08) !important;
  background: radial-gradient(circle, rgba(220,140,30,.14), rgba(220,140,30,.02) 62%, transparent 72%) !important;
}
.member-card:hover .member-photo-wrap--complete {
  box-shadow:
    0 0 0 3px rgba(0,210,130,.90),
    0 0 28px rgba(0,210,130,.50),
    0 0 70px rgba(0,210,130,.20) !important;
}
.member-card:hover .member-photo-wrap--partial {
  box-shadow:
    0 0 0 2.5px rgba(220,140,30,.80),
    0 0 22px rgba(220,140,30,.35),
    0 0 50px rgba(220,140,30,.14) !important;
}
.member-photo { width: 100%; height: 100%; object-fit: cover; border-radius: 999px; border: 2px solid rgba(255,255,255,.28); background: rgba(5,18,46,.8); }
.member-name { margin: 0 0 8px; font-size: clamp(1rem,1.1vw,1.25rem); font-weight: 800; letter-spacing: -.03em; line-height: 1.1; }
.member-role { margin: 0 0 auto; color: var(--r-muted); font-size: .82rem; line-height: 1.5; max-width: 28ch; padding-bottom: 110px; }
.member-links {
  position: absolute; bottom: 14px; left: 0; right: 0;
  display: flex; gap: 8px; align-items: center;
  justify-content: center; padding: 0 16px;
  overflow: visible; z-index: 20;
}
.icon-btn {
  width: 40px; height: 40px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid rgba(124,243,255,.22); background: rgba(255,255,255,.04);
  transition: transform .18s, background .18s, border-color .18s;
}
.icon-btn { position: relative; }
.icon-btn:not(.icon-btn--locked):hover { transform: translateY(-2px) scale(1.06); background: rgba(124,243,255,.14); border-color: rgba(124,243,255,.44); }
.icon { width: 18px; height: 18px; fill: currentColor; display: block; }

/* ── CTA SECTION ── */
.cta-section { padding: 32px 0 72px; }
.cta-box {
  position: relative; overflow: hidden;
  padding: 44px 32px; border-radius: var(--r-r);
  border: 1px solid rgba(124,243,255,.18);
  background: linear-gradient(135deg, rgba(8,32,68,.22), rgba(4,14,32,.28));
  backdrop-filter: blur(12px); box-shadow: var(--r-shadow);
  text-align: center;
}
.cta-box__bg {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(circle at top, rgba(124,243,255,.1), transparent 35%);
  opacity: .85;
}
.cta-box__content { position: relative; z-index: 1; }
.cta-box__title { font-size: clamp(1.4rem,2.8vw,2.2rem); font-weight: 700; letter-spacing: -.04em; margin-bottom: 12px; }
.cta-box__text { color: var(--r-muted); max-width: 72ch; margin: 0 auto 24px; line-height: 1.68; }

/* ── MODAL ── */
.modal { position: fixed; inset: 0; display: none; align-items: center; justify-content: center; padding: 24px; background: rgba(1,6,16,.74); backdrop-filter: blur(8px); z-index: 9000; }
.modal.is-open { display: flex; }
.modal__dialog { width: min(860px,100%); max-height: 90vh; overflow-y: auto; border-radius: 28px; border: 1px solid rgba(124,243,255,.18); background: linear-gradient(160deg, rgba(4,16,38,.98), rgba(2,10,28,.99)); box-shadow: 0 34px 90px rgba(0,0,0,.52); position: relative; padding: 28px 28px 24px; }
.modal__close { position: absolute; top: 14px; right: 14px; width: 42px; height: 42px; border-radius: 999px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.04); color: #fff; cursor: pointer; font-size: 1.1rem; transition: transform .18s, background .18s; display: flex; align-items: center; justify-content: center; }
.modal__close:hover { transform: scale(1.05); background: rgba(255,255,255,.1); }
.modal__head { margin-bottom: 22px; padding-bottom: 18px; border-bottom: 1px solid rgba(123,228,255,.1); }
.modal__kicker { font-size: .66rem; letter-spacing: .2em; text-transform: uppercase; color: var(--r-cyan2); font-weight: 600; display: block; margin-bottom: 8px; }
.modal__title { font-size: clamp(1.5rem,2.6vw,2.1rem); letter-spacing: -.04em; font-weight: 700; margin-bottom: 8px; }
.modal__desc { color: var(--r-muted); font-size: .9rem; line-height: 1.65; }
.network-form { display: grid; gap: 14px; margin-top: 16px; }
.form-grid { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
.field { display: grid; gap: 6px; }
.field--full { grid-column: 1/-1; }
.field label { font-weight: 700; color: var(--r-cyan2); font-size: .76rem; letter-spacing: .12em; }
.field input, .field textarea { width: 100%; padding: 12px 14px; border-radius: 14px; border: 1px solid rgba(123,228,255,.2); background: rgba(5,18,52,.8); color: #fff; outline: none; font: inherit; transition: border-color .18s, box-shadow .18s, background .18s; }
.field input::placeholder, .field textarea::placeholder { color: rgba(237,247,255,.3); }
.field input:focus, .field textarea:focus { border-color: rgba(123,228,255,.42); box-shadow: 0 0 0 4px rgba(123,228,255,.1); background: rgba(8,26,60,.88); }
.field textarea { min-height: 110px; resize: vertical; }
.modal__actions { margin-top: 8px; }
.form-status { margin-top: 14px; padding: 12px 16px; border-radius: 12px; font-size: .9rem; font-weight: 600; }
.form-status:empty { display: none; }
.form-status.is-success { color: #4dffd6; background: rgba(0,220,180,.1); border: 1px solid rgba(0,220,180,.24); }
.form-status.is-error   { color: #ff8fa3; background: rgba(255,80,100,.08); border: 1px solid rgba(255,80,100,.2); }

/* ── FOOTER ── */
.footer { padding: 26px 0 40px; border-top: 1px solid rgba(120,210,255,.1); background: rgba(1,7,17,.8); backdrop-filter: blur(12px); }
.footer__inner { display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.footer__brand { display: flex; align-items: center; gap: 10px; color: rgba(237,247,255,.5); font-size: .86rem; }
.footer__brand img { border-radius: 8px; opacity: .7; }
.footer__links { display: flex; gap: 18px; flex-wrap: wrap; }
.footer__links a { color: rgba(237,247,255,.55); font-size: .84rem; transition: color .2s; }
.footer__links a:hover { color: var(--r-cyan2); }

/* ── REVEAL ── */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s cubic-bezier(.22,.68,0,1.1); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  .traveler, .connectome-nodes .node, .btn-electric::before, .btn-amici::before { animation: none !important; }
}

/* ── RESPONSIVE ── */
@media (max-width: 1280px) { .members-grid { grid-template-columns: repeat(4,minmax(0,1fr)); } }
@media (max-width: 1024px) { .members-grid { grid-template-columns: repeat(3,minmax(0,1fr)); } .hero { min-height: 460px; } }
@media (max-width: 900px) {
  body::before { background: url("assets/ocean-mobile.jpg") center top / cover no-repeat; }
  .brand__text em { display: block; font-size: .58rem; white-space: normal; line-height: 1.3; }
  .nav--desktop { display: none; }
  .nav-mobile-btn { display: flex; }
  .header { position: sticky; top: 0; z-index: 200; }
  .hero { min-height: 420px; padding: 26px 18px 24px; }
  .hero__title { font-size: 2.6rem; }
  .hero__subtitle { font-size: .96rem; max-width: 100%; }
  .hero__connectome { opacity: .3; }
  .members-grid { grid-template-columns: repeat(2,minmax(0,1fr)); gap: 14px; }
  .member-card { min-height: 320px; padding: 16px 14px 14px; }
  .member-photo-wrap { width: 120px; height: 120px; }
  .member-name { font-size: .96rem; }
  .member-role { font-size: .76rem; padding-bottom: 46px; }
  .cta-section { padding: 20px 0 52px; }
  .cta-box { padding: 32px 22px; }
  .form-grid { grid-template-columns: 1fr; }
  .modal { padding: 14px; }
  .modal__dialog { padding: 20px 16px; }
  .footer__inner { flex-direction: column; text-align: center; gap: 10px; }
  #synapseCanvas { display: none; }
}
@media (max-width: 520px) {
  .members-grid { grid-template-columns: 1fr; }
  .member-card { min-height: auto; }
  .hero__cta { flex-direction: column; align-items: stretch; }
  .btn-electric, .btn-ghost { width: 100%; justify-content: center; }
}


/* ==========================================================
   RETE v2.1 — card più trasparenti + canvas full-page
   ========================================================== */

/* Canvas fisso su tutta la pagina */
#synapseCanvas {
  position: fixed !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .72 !important;
}

/* Header/hero/sezioni sopra il canvas */
/* header z-index handled above */


/* Card: molto più trasparente, effetto vetro profondo */
.member-card {
  background:
    linear-gradient(135deg,
      rgba(255,255,255,.06) 0%,
      rgba(255,255,255,.02) 20%,
      rgba(4,18,46,.28) 60%,
      rgba(2,10,28,.32) 100%) !important;
  border: 1px solid rgba(160,230,255,.22) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.18),
    inset 0 -1px 0 rgba(0,0,0,.15),
    0 16px 48px rgba(0,0,0,.38),
    0 0 0 1px rgba(124,243,255,.04) !important;
  /* backdrop-filter consolidato — vedi definizione finale */
  -webkit-backdrop-filter: blur(22px) saturate(1.3) !important;
}

/* Riflesso interno: più vistoso per effetto vetro realistico */
.member-card::before {
  background:
    linear-gradient(135deg,
      rgba(255,255,255,.18) 0%,
      rgba(255,255,255,.08) 18%,
      rgba(200,240,255,.04) 35%,
      transparent 55%,
      rgba(123,228,255,.04) 85%,
      rgba(123,228,255,.1) 100%) !important;
  mix-blend-mode: screen !important;
  opacity: 1 !important;
  transition: opacity .35s !important;
}
.member-card:hover::before { opacity: 1 !important; }

/* Bordo vetro spesso, più luminoso */
.member-card::after {
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(0,0,0,.22),
    inset 1.5px 0 0 rgba(255,255,255,.1),
    inset -1px 0 0 rgba(0,0,0,.12) !important;
  border: 1px solid rgba(200,240,255,.12) !important;
}

/* Hover: alzarsi di più, glow sinergico con il canvas */
.member-card:hover {
  transform: translateY(-10px) !important;
  border-color: rgba(124,243,255,.5) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -1px 0 rgba(0,0,0,.15),
    0 28px 70px rgba(0,0,0,.5),
    0 0 60px rgba(80,200,255,.16) !important;
}

/* Riga città: più luminosa e visibile */
.member-location__line {
  background: linear-gradient(90deg, transparent, rgba(124,243,255,.7), transparent) !important;
  box-shadow: 0 0 12px rgba(124,243,255,.35) !important;
}

/* Rimuovi canvas dalla members-section (ora è fixed) */
.members-section #synapseCanvas { display: none !important; }


/* ==========================================================
   RETE WOW v2 — 3D tilt, glow individuale, pulse, cinematic
   ========================================================== */

/* ── 1. CARD 3D TILT: prospettiva sul grid ── */
.members-grid {
  perspective: 1400px;
  perspective-origin: 50% 40%;
}

/* La card riceve il tilt via JS (--rx, --ry custom props) */
.member-card {
  transform-style: preserve-3d;
  transform:
    perspective(1000px)
    rotateX(var(--rx, 0deg))
    rotateY(var(--ry, 0deg))
    translateY(0);
  transition:
    transform .18s cubic-bezier(.22,.68,0,1.2),
    box-shadow .18s,
    border-color .18s !important;
  will-change: transform;
}
/* Al hover il tilt viene applicato da JS, non serve translateY qui */
.member-card:hover {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.22),
    0 28px 70px rgba(0,0,0,.5),
    0 0 60px rgba(80,200,255,.18) !important;
  border-color: rgba(124,243,255,.55) !important;
}

/* ── 2. FOTO: glow individuale colorato al hover ── */
.member-photo-wrap {
  transition: box-shadow .3s ease !important;
}
/* Ogni quinta card: colore diverso per varietà */
.member-card:nth-child(5n+1):hover .member-photo-wrap {
  box-shadow: 0 0 0 2px rgba(123,228,255,.5), 0 0 40px rgba(123,228,255,.5), 0 0 80px rgba(0,160,255,.2) !important;
}
.member-card:nth-child(5n+2):hover .member-photo-wrap {
  box-shadow: 0 0 0 2px rgba(77,255,214,.5), 0 0 40px rgba(77,255,214,.45), 0 0 80px rgba(0,200,160,.2) !important;
}
.member-card:nth-child(5n+3):hover .member-photo-wrap {
  box-shadow: 0 0 0 2px rgba(196,176,255,.5), 0 0 40px rgba(196,176,255,.45), 0 0 80px rgba(120,80,255,.2) !important;
}
.member-card:nth-child(5n+4):hover .member-photo-wrap {
  box-shadow: 0 0 0 2px rgba(255,180,100,.45), 0 0 40px rgba(255,160,80,.4), 0 0 80px rgba(200,100,0,.18) !important;
}
.member-card:nth-child(5n+5):hover .member-photo-wrap {
  box-shadow: 0 0 0 2px rgba(100,220,255,.5), 0 0 40px rgba(80,200,255,.45), 0 0 80px rgba(0,120,255,.2) !important;
}

/* ── 3. FOTO: scala al hover ── */
.member-photo {
  transition: transform .35s cubic-bezier(.22,.68,0,1.3), filter .3s !important;
}
.member-card:hover .member-photo {
  transform: scale(1.07) !important;
  filter: brightness(1.08) saturate(1.12) !important;
}

/* ── 4. NOME: glow al hover ── */
.member-name {
  transition: text-shadow .3s !important;
}
.member-card:hover .member-name {
  text-shadow: 0 0 20px rgba(123,228,255,.5) !important;
}

/* ── 5. CONTATORE EROI: numeri animati ── */
.hero__stat-n {
  display: block;
  transition: color .3s;
}

/* ── 6. RIGA CITTÀ: animazione pulse continua ── */
@keyframes cityLinePulse {
  0%,100% { opacity: .6; }
  50%      { opacity: 1; box-shadow: 0 0 18px rgba(124,243,255,.5); }
}
.member-location__line {
  animation: cityLinePulse 3s ease-in-out infinite !important;
}
.member-card:hover .member-location__line {
  animation: none !important;
  background: linear-gradient(90deg, transparent, rgba(124,243,255,.95), transparent) !important;
  box-shadow: 0 0 20px rgba(124,243,255,.6) !important;
}

/* ── 7. REVEAL CINEMATICO: entrata a cascata con rotazione ── */
/* ── REVEAL DESKTOP: entrata pulita senza perspective ── */
.member-card {
  opacity: 0;
  transform: translateY(28px) scale(.97);
}
.member-card.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  transition:
    opacity .65s cubic-bezier(.25,.46,.45,.94),
    transform .65s cubic-bezier(.22,.68,0,1.15);
}

/* ── 8. CTA BOX: bordo luminoso animato ── */
@keyframes ctaBorderFlow {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}
.cta-box {
  position: relative;
}
.cta-box::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: calc(var(--r-r) + 1px);
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(124,243,255,.5) 25%,
    rgba(80,160,255,.4) 50%,
    rgba(196,176,255,.5) 75%,
    transparent 100%);
  background-size: 200% 100%;
  animation: ctaBorderFlow 4s linear infinite;
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: 1px;
  pointer-events: none;
  z-index: 0;
}

/* ── 9. HERO: particella flare sull'occhio ── */
@keyframes heroFlare {
  0%   { opacity: 0; transform: scale(.5) rotate(0deg); }
  50%  { opacity: .8; transform: scale(1.1) rotate(180deg); }
  100% { opacity: 0; transform: scale(.5) rotate(360deg); }
}
.hero::after {
  content: "";
  position: absolute;
  width: 300px; height: 300px;
  left: 8%; top: 10%;
  background: radial-gradient(circle, rgba(124,243,255,.12) 0%, transparent 60%);
  border-radius: 50%;
  pointer-events: none;
  animation: heroFlare 8s ease-in-out infinite;
  z-index: 0;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  .member-card { transform: none !important; transition: box-shadow .3s !important; }
  .member-card.is-visible { transform: none !important; opacity: 1 !important; }
  .member-location__line { animation: none !important; }
  .cta-box::after { animation: none !important; }
  .hero::after { animation: none !important; }
}


/* ==========================================================
   RETE WOW v3 — canvas immersivo, card lingotto, icone
   ========================================================== */

/* ── CANVAS: visibile ovunque, opacità aumentata ── */
#synapseCanvas {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .72 !important;  /* più visibile */
  display: block !important; /* annulla display:none dei blocchi precedenti */
}
/* Annulla tutte le regole display:none precedenti */
.members-section #synapseCanvas { display: block !important; }

/* Header e sezioni sopra il canvas */
/* header z-index handled above */

/* ── TRASPARENTE ── */
/* Effetto: vetro spesso, bordo frastagliato luminoso,
   riflesso angolare come cristallo, profondità 3D */
.member-card {
  background:
    /* strato riflesso angolare superiore */
    linear-gradient(135deg,
      rgba(255,255,255,.14) 0%,
      rgba(255,255,255,.04) 15%,
      transparent 30%,
      transparent 70%,
      rgba(255,255,255,.02) 85%,
      rgba(255,255,255,.06) 100%),
    /* vetro tintato */
    rgba(8,24,58,.18) !important;

  border: 1px solid rgba(180,240,255,.28) !important;

  box-shadow:
    /* bordo superiore luminoso (spigolo del lingotto) */
    inset 0 2px 0 rgba(255,255,255,.28),
    /* bordo laterale sx */
    inset 2px 0 0 rgba(255,255,255,.1),
    /* bordo inferiore scuro (profondità) */
    inset 0 -2px 0 rgba(0,0,0,.3),
    /* bordo laterale dx scuro */
    inset -1px 0 0 rgba(0,0,0,.15),
    /* ombra esterna profonda */
    0 20px 60px rgba(0,0,0,.55),
    /* alone cyan esterno */
    0 0 0 1px rgba(124,243,255,.06) !important;

  /* backdrop-filter consolidato — vedi definizione finale */
  -webkit-backdrop-filter: blur(24px) saturate(1.6) brightness(1.08) !important;
  overflow: visible !important; /* permette al glow di uscire */
}

/* Riflesso interno come vetro molato */
.member-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  pointer-events: none !important;
  z-index: 0 !important;
  background:
    /* diagonale brillante principale */
    linear-gradient(145deg,
      rgba(255,255,255,.18) 0%,
      rgba(255,255,255,.06) 12%,
      transparent 28%,
      transparent 72%,
      rgba(200,240,255,.04) 88%,
      rgba(200,240,255,.1) 100%) !important;
  mix-blend-mode: screen !important;
  transition: opacity .3s !important;
  opacity: .9 !important;
}

/* Bordo vetro multi-strato */
.member-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  pointer-events: none !important;
  z-index: 3 !important;
  background: none !important;
  /* Simula spessore del vetro con bordi multipli */
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -1px 0 rgba(0,0,0,.35),
    inset 1px 0 0 rgba(255,255,255,.18),
    inset -1px 0 0 rgba(0,0,0,.2),
    inset 0 2px 6px rgba(255,255,255,.08),
    inset 0 -2px 6px rgba(0,0,0,.15) !important;
}

/* Hover del lingotto: si solleva e splende */
.member-card:hover {
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.38),
    inset 2px 0 0 rgba(255,255,255,.18),
    inset 0 -2px 0 rgba(0,0,0,.28),
    inset -1px 0 0 rgba(0,0,0,.12),
    0 36px 80px rgba(0,0,0,.65),
    0 0 60px rgba(100,220,255,.22),
    0 0 120px rgba(60,160,255,.1) !important;
  border-color: rgba(160,240,255,.6) !important;
}

/* ── ICONE LINKEDIN/EMAIL: più in basso ── */
.member-links {
  margin-top: 18px !important;  /* era ~10px */
  padding-top: 12px !important;
}

/* ── EXTRA WOW: shimmer sulla card al hover ── */
@keyframes cardShimmer {
  0%   { transform: translateX(-100%) skewX(-12deg); }
  100% { transform: translateX(220%)  skewX(-12deg); }
}
.member-card:hover .member-photo-wrap::before {
  content: "";
  position: absolute;
  inset: -30% auto -30% -20%;
  width: 35%;
  background: linear-gradient(90deg,
    transparent,
    rgba(255,255,255,.18),
    transparent);
  animation: cardShimmer .55s ease forwards;
  pointer-events: none;
  z-index: 10;
}
.member-photo-wrap { position: relative; overflow: hidden; }

/* ── EXTRA WOW: numero membri nel hero con glow ── */
.hero__stat-n {
  font-size: 1.8rem !important;
  font-weight: 800 !important;
  letter-spacing: -.05em !important;
  transition: text-shadow .4s, color .4s !important;
}
.hero__stat:hover .hero__stat-n {
  color: #fff !important;
  text-shadow: 0 0 24px var(--r-cyan2), 0 0 48px rgba(123,228,255,.4) !important;
}

/* Mobile: disabilita 3D tilt, riduci opacità canvas */
@media (max-width: 768px) {
  #synapseCanvas { opacity: .72 !important; }
  .member-card {
    /* transform: none rimosso — gestito dal sistema animazioni */
    overflow: hidden !important;
  }
  .member-card:hover {
    transform: translateY(-4px) !important;
  }
  .member-links {
    margin-top: 14px !important;
    padding-top: 10px !important;
  }
}


/* ── Z-INDEX FIX DEFINITIVO ── */
/* Canvas: sotto tutto */
#synapseCanvas { z-index: 0 !important; }
/* Contenuto: sopra il canvas */
/* header z-index handled above */

/* ──: sopra tutto, NON sovrascrivere position:fixed */
.modal { z-index: 9000 !important; position: fixed !important; }


/* ==========================================================
   RETE v9 — tag aree, benefici, email wall, crescita
   ========================================================== */

/* ── TAG AREA ── */
.member-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  justify-content: center;
  margin: 6px 0 8px;
  position: relative; z-index: 2;
}
.member-tag {
  display: inline-flex; align-items: center;
  padding: 3px 10px; border-radius: 999px;
  font-size: .62rem; font-weight: 700; letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--tag-color, #7be4ff);
  background: color-mix(in srgb, var(--tag-color, #7be4ff) 12%, transparent);
  border: 1px solid color-mix(in srgb, var(--tag-color, #7be4ff) 30%, transparent);
  transition: background .2s, box-shadow .2s;
}
/* Fallback per browser senza color-mix */
@supports not (color: color-mix(in srgb, red 50%, blue)) {
  .member-tag { background: rgba(123,228,255,.1); border: 1px solid rgba(123,228,255,.24); }
}
.member-card:hover .member-tag {
  box-shadow: 0 0 10px color-mix(in srgb, var(--tag-color, #7be4ff) 35%, transparent);
}

/* ── HERO STAT "In crescita" ── */
.hero__stat--growing .hero__stat-n {
  color: #4dffd6 !important;
}

/* ── EMAIL LOCK BUTTON ── */
.member-email-btn {
  cursor: pointer;
  opacity: .55;
  transition: opacity .2s, transform .2s;
}
.member-email-btn:hover {
  opacity: 1;
  transform: translateY(-2px) scale(1.06);
  color: var(--r-cyan2);
}
.member-email-btn .icon { stroke: currentColor; fill: none; }

/* ── EMAIL WALL MODAL ── */
.email-wall {
  position: fixed; inset: 0; z-index: 9500;
  display: none; align-items: center; justify-content: center;
  padding: 24px;
  background: rgba(1,6,16,.8); backdrop-filter: blur(10px);
}
.email-wall.is-open { display: flex; }
.email-wall__dialog {
  position: relative;
  width: min(480px, 100%);
  background: linear-gradient(160deg, rgba(4,16,38,.98), rgba(2,10,28,.99));
  border: 1px solid rgba(123,228,255,.2); border-radius: 28px;
  padding: 36px 32px 28px;
  box-shadow: 0 32px 80px rgba(0,0,0,.55);
  text-align: center;
}
.email-wall__close {
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.12);
  color: #fff; cursor: pointer; font-size: 1rem;
  display: flex; align-items: center; justify-content: center;
  transition: background .2s;
}
.email-wall__close:hover { background: rgba(255,255,255,.14); }
.email-wall__icon {
  width: 64px; height: 64px; margin: 0 auto 18px;
  border-radius: 18px; display: flex; align-items: center; justify-content: center;
  background: rgba(123,228,255,.08); border: 1px solid rgba(123,228,255,.2);
  color: var(--r-cyan2);
}
.email-wall__title { font-size: 1.3rem; font-weight: 700; letter-spacing: -.03em; margin-bottom: 12px; }
.email-wall__text { color: var(--r-muted); font-size: .92rem; line-height: 1.65; margin-bottom: 22px; }
.email-wall__actions { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.email-wall__note { font-size: .78rem; color: var(--r-soft); }
.email-wall__note a { color: var(--r-cyan2); }

/* ── BENEFITS SECTION ── */
.benefits-section { padding: 80px 0 56px; }
.benefits-header { max-width: 680px; margin: 0 auto 44px; text-align: center; }
.benefits-eyebrow {
  display: inline-block; margin-bottom: 12px;
  font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--r-cyan2); font-weight: 600;
}
.benefits-title { font-size: clamp(1.7rem,3.2vw,2.6rem); font-weight: 700; letter-spacing: -.04em; margin-bottom: 12px; }
.benefits-sub { color: var(--r-muted); font-size: .96rem; line-height: 1.65; }

.benefits-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 18px;
}
.benefit-card {
  padding: 28px 24px;
  border-radius: 20px;
  border: 1px solid rgba(120,210,255,.14);
  background: rgba(5,18,46,.5);
  backdrop-filter: blur(16px);
  transition: transform .3s cubic-bezier(.22,.68,0,1.3), border-color .25s, box-shadow .25s;
}
.benefit-card:hover {
  transform: translateY(-5px);
  border-color: rgba(120,210,255,.3);
  box-shadow: 0 16px 44px rgba(0,0,0,.35), 0 0 30px rgba(80,180,255,.08);
}
.benefit-icon {
  width: 52px; height: 52px; border-radius: 16px; margin-bottom: 18px;
  display: flex; align-items: center; justify-content: center;
  transition: transform .3s cubic-bezier(.22,.68,0,1.3);
}
.benefit-card:hover .benefit-icon { transform: scale(1.1) translateY(-2px); }
.benefit-icon--cyan   { background: rgba(123,228,255,.1); border: 1px solid rgba(123,228,255,.22); color: #a8eeff; }
.benefit-icon--green  { background: rgba(77,255,214,.1);  border: 1px solid rgba(77,255,214,.22);  color: #4dffd6; }
.benefit-icon--purple { background: rgba(196,176,255,.1); border: 1px solid rgba(196,176,255,.22); color: #c4b0ff; }
.benefit-icon--orange { background: rgba(255,179,71,.1);  border: 1px solid rgba(255,179,71,.22);  color: #ffb347; }
.benefit-card h3 { font-size: 1rem; font-weight: 700; margin-bottom: 10px; letter-spacing: -.02em; }
.benefit-card p  { font-size: .85rem; color: var(--r-muted); line-height: 1.6; margin: 0; }

/* ── TOP ACCENT LINE per ogni benefit ── */
.benefit-card:nth-child(1) { border-top: 2px solid rgba(123,228,255,.4); }
.benefit-card:nth-child(2) { border-top: 2px solid rgba(77,255,214,.4); }
.benefit-card:nth-child(3) { border-top: 2px solid rgba(196,176,255,.4); }
.benefit-card:nth-child(4) { border-top: 2px solid rgba(255,179,71,.4); }
.benefit-card:nth-child(5) { border-top: 2px solid rgba(77,255,214,.4); }
.benefit-card:nth-child(6) { border-top: 2px solid rgba(123,228,255,.4); }

/* Responsive benefits */
@media (max-width: 1024px) { .benefits-grid { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px)  { .benefits-grid { grid-template-columns: 1fr; } }

/* Mobile */
@media (max-width: 768px) {
  .benefits-section { padding: 56px 0 36px; }
  .benefit-card { padding: 22px 18px; }
  .email-wall__dialog { padding: 28px 22px 24px; }
  .member-tags { gap: 5px; }
  .member-tag { font-size: .58rem; padding: 3px 8px; }
}


/* ════════════════════════════════════════════════════════
   RETE FINALE — lingotti, animazioni, hero pulito
   ════════════════════════════════════════════════════════ */

/* Nessun riquadro sull'hero */
.hero__content::before { display: none !important; }
.hero::before { display: none !important; }

/* Card lingotto: visibile, definito, oceano trasparisce */
.member-card {
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.15) 0%,
      rgba(255,255,255,.04) 14%,
      transparent 28%,
      rgba(4,18,52,.30) 68%,
      rgba(4,18,52,.42) 100%) !important;
  border: 1px solid rgba(185,238,255,.42) !important;
  box-shadow:
    inset 0 2.5px 0 rgba(255,255,255,.34),
    inset 2px 0 0 rgba(255,255,255,.14),
    inset 0 -2.5px 0 rgba(0,0,0,.36),
    inset -1.5px 0 0 rgba(0,0,0,.18),
    0 18px 55px rgba(0,0,0,.48),
    0 0 40px rgba(100,200,255,.07) !important;
  backdrop-filter: blur(8px) saturate(1.35) !important;
  -webkit-backdrop-filter: blur(8px) saturate(1.35) !important;
}

/* Riflesso vetro molato */
.member-card::before {
  background:
    linear-gradient(145deg,
      rgba(255,255,255,.18) 0%,
      rgba(255,255,255,.06) 12%,
      transparent 26%,
      transparent 74%,
      rgba(200,240,255,.04) 88%,
      rgba(200,240,255,.08) 100%) !important;
}

/* Spigoli vetro */
.member-card::after {
  box-shadow:
    inset 0 2px 0 rgba(255,255,255,.28),
    inset 0 -2px 0 rgba(0,0,0,.32),
    inset 2px 0 0 rgba(255,255,255,.12),
    inset -2px 0 0 rgba(0,0,0,.18) !important;
}

/* ── Animazione lingotto: collisione laterale ── */
@keyframes cardEnterLeft {
  0%   { opacity:0; transform:perspective(900px) rotateY(-28deg) translateX(-65px) translateY(32px) scale(.88); filter:blur(3px); }
  55%  { opacity:1; transform:perspective(900px) rotateY(7deg) translateX(10px) translateY(-5px) scale(1.03); filter:blur(0); }
  78%  { transform:perspective(900px) rotateY(-3deg) translateX(-4px) translateY(2px) scale(.99); }
  100% { transform:perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0) scale(1); }
}
@keyframes cardEnterRight {
  0%   { opacity:0; transform:perspective(900px) rotateY(28deg) translateX(65px) translateY(32px) scale(.88); filter:blur(3px); }
  55%  { opacity:1; transform:perspective(900px) rotateY(-7deg) translateX(-10px) translateY(-5px) scale(1.03); filter:blur(0); }
  78%  { transform:perspective(900px) rotateY(3deg) translateX(4px) translateY(2px) scale(.99); }
  100% { transform:perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0) scale(1); }
}
@keyframes cardEnterUp {
  0%   { opacity:0; transform:perspective(900px) rotateX(22deg) translateY(62px) scale(.88); filter:blur(3px); }
  60%  { opacity:1; transform:perspective(900px) rotateX(-5deg) translateY(-7px) scale(1.03); filter:blur(0); }
  82%  { transform:perspective(900px) rotateX(2deg) translateY(3px) scale(.99); }
  100% { transform:perspective(1000px) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(0) scale(1); }
}

/* Collisione: sinistra/centro/destra alternati */
.member-card:nth-child(3n+1).is-visible { animation: cardEnterLeft  .92s cubic-bezier(.22,.68,0,1.08) both; }
.member-card:nth-child(3n+2).is-visible { animation: cardEnterUp    .92s cubic-bezier(.22,.68,0,1.08) both; }
.member-card:nth-child(3n+3).is-visible { animation: cardEnterRight .92s cubic-bezier(.22,.68,0,1.08) both; }

/* Stagger progressivo */
.member-card:nth-child(1){animation-delay:.00s} .member-card:nth-child(2){animation-delay:.10s}
.member-card:nth-child(3){animation-delay:.20s} .member-card:nth-child(4){animation-delay:.07s}
.member-card:nth-child(5){animation-delay:.17s} .member-card:nth-child(6){animation-delay:.27s}
.member-card:nth-child(7){animation-delay:.04s} .member-card:nth-child(8){animation-delay:.14s}
.member-card:nth-child(9){animation-delay:.24s} .member-card:nth-child(10){animation-delay:.02s}
.member-card:nth-child(11){animation-delay:.12s} .member-card:nth-child(12){animation-delay:.22s}
.member-card:nth-child(13){animation-delay:.05s} .member-card:nth-child(14){animation-delay:.15s}
.member-card:nth-child(15){animation-delay:.25s}

/* brand-copy */



.brand-sub{font-size:.63rem!important}
@media(max-width:768px){.brand-sub{display:none!important}}

/* access modal */
.access-modal{position:fixed;inset:0;z-index:9600;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(1,6,16,.88);backdrop-filter:blur(12px)}
.access-modal.is-open{display:flex}
.access-modal__dialog{position:relative;width:min(440px,100%);background:linear-gradient(160deg,rgba(4,18,44,.99),rgba(2,10,28,.99));border:1px solid rgba(123,228,255,.22);border-radius:24px;padding:36px 28px 28px;text-align:center;box-shadow:0 32px 80px rgba(0,0,0,.6)}
.access-modal__close{position:absolute;top:12px;right:12px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:#fff;cursor:pointer;font-size:.95rem;display:flex;align-items:center;justify-content:center;transition:background .2s}
.access-modal__close:hover{background:rgba(255,255,255,.14)}
.access-modal__icon{width:60px;height:60px;margin:0 auto 16px;border-radius:18px;display:flex;align-items:center;justify-content:center;background:rgba(123,228,255,.1);border:1px solid rgba(123,228,255,.22);color:var(--r-cyan2,#a8eeff)}
.access-modal__title{font-size:1.25rem;font-weight:700;letter-spacing:-.03em;margin-bottom:10px}
.access-modal__desc{color:var(--r-muted,rgba(237,247,255,.72));font-size:.88rem;line-height:1.6;margin-bottom:20px}
.access-modal__form{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}
.access-modal__input{width:100%;padding:13px 16px;border-radius:12px;border:1px solid rgba(123,228,255,.24);background:rgba(5,18,52,.9);color:#fff;font:inherit;font-size:.96rem;text-align:center;letter-spacing:.08em;text-transform:uppercase;outline:none;transition:border-color .2s,box-shadow .2s}
.access-modal__input:focus{border-color:rgba(123,228,255,.5);box-shadow:0 0 0 4px rgba(123,228,255,.12)}
.access-modal__input.shake{animation:inputShake .4s cubic-bezier(.36,.07,.19,.97)}
@keyframes inputShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-5px)}80%{transform:translateX(5px)}}
.access-modal__status{font-size:.88rem;font-weight:600;min-height:22px;margin-bottom:10px}
.access-modal__status.success{color:#4dffd6}
.access-modal__status.error{color:#ff8fa3}
.access-modal__note{font-size:.78rem;color:var(--r-soft,rgba(237,247,255,.46))}
.access-modal__link{background:none;border:none;color:var(--r-cyan2,#a8eeff);cursor:pointer;font:inherit;font-size:.78rem;text-decoration:underline;padding:0}


/* ════════════════════════════════════════════════════════
   PERCHÉ ENTRARE — evento SX + benefit cards DX
   ════════════════════════════════════════════════════════ */

.rete-why-section { padding: 80px 0 72px; }
.rete-why-grid {
  display: block;
}


.rete-why-header {
  text-align: center;
  max-width: 620px;
  margin: 0 auto 52px;
}
.rete-why-header h2 {
  font-size: clamp(1.7rem, 3vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -.04em;
  margin-bottom: 12px;
}
.rete-why-header .section-subheading {
  color: var(--r-muted);
  font-size: .96rem;
  line-height: 1.7;
}

/* Grid: poster verticale SX + benefits 2col DX */

/* ── Colonna SX: evento ── */
.rete-event-col {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rete-event-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--r-cyan2);
}
.rete-event-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--r-cyan2);
  box-shadow: 0 0 8px rgba(123,228,255,.8);
  flex-shrink: 0;
}

  50%    { opacity:.35; transform:scale(1.6); }


/* Card poster verticale */
.rete-event-poster-card {
  padding: 0 0 16px !important;
  overflow: hidden;
}
.rete-event-poster-card > img {
  width: 100%;
  aspect-ratio: .72;
  object-fit: cover;
  border-radius: 16px 16px 0 0;
  display: block;
}
.rete-event-info {
  padding: 14px 16px 0;
}

/* Bottone pubblica evento — stile tratteggiato sobrio */
.rete-event-publish-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  width: 100%;
  padding: 11px 16px;
  border-radius: 12px;
  border: 1px dashed rgba(123,228,255,.25);
  background: rgba(123,228,255,.03);
  color: var(--r-soft);
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .03em;
  cursor: pointer;
  transition: border-color .2s, color .2s, background .2s;
}
.rete-event-publish-btn:hover {
  border-color: rgba(123,228,255,.45);
  color: var(--r-cyan2);
  background: rgba(123,228,255,.06);
}

/* ── Colonna DX: benefit cards ── */
.rete-benefits-col {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
  align-content: start;
}

/* Benefit card: riga icona + testo */
.rete-benefits-col .benefit-card {
  display: flex;
  flex-direction: row;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 14px;
}
.rete-benefits-col .benefit-icon {
  flex-shrink: 0;
  width: 34px; height: 34px;
  border-radius: 9px;
}
.rete-benefits-col .benefit-card h3 {
  font-size: .88rem;
  font-weight: 700;
  margin: 0 0 4px;
  letter-spacing: -.02em;
}
.rete-benefits-col .benefit-card p {
  font-size: .79rem;
  line-height: 1.55;
  color: var(--r-muted);
  margin: 0;
}

/* ── Tasto IT/EN — identico alla home ── */
.lang-toggle {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 5px 12px;
  border-radius: 999px;
  background: rgba(123,228,255,.07);
  border: 1px solid rgba(123,228,255,.22);
  color: rgba(237,247,255,.65);
  font-size: .74rem;
  font-weight: 700;
  letter-spacing: .10em;
  cursor: pointer;
  transition: background .2s, border-color .2s, color .2s;
  white-space: nowrap;
  line-height: 1;
  position: relative;
  z-index: 9999;
  pointer-events: auto !important;
}
.lang-toggle:hover {
  background: rgba(123,228,255,.15);
  border-color: rgba(123,228,255,.42);
  color: #a8eeff;
}
#langCurrent { color: var(--r-cyan2, #a8eeff); font-weight: 800; }
.lang-sep { opacity: .28; }
#langOther { opacity: .52; }

/* ── Responsive ── */
@media (max-width: 900px) {

}

@media (max-width: 768px) {
  .lang-toggle { display: none; }
  .btn-eventi::before, .btn-amici::before { animation: none !important; }
}



/* ════════════════════════════════════════════════════════
   STACKING ORDER — definitivo
   -3: ocean image (body::before)
   -2: rimosso (body::after eliminato)
    0: body background transparent
    1: canvas sinapsi (position:fixed)
    2: hero connectome SVG
   10: contenuto hero (titolo, bottoni, stats)
  200: header sticky
 9000: modali
   ════════════════════════════════════════════════════════ */

/* Canvas: sempre sopra l'oceano, sotto il contenuto */
#synapseCanvas {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  z-index: 1 !important;
  pointer-events: none !important;
  opacity: .62 !important;
}

/* Hero: NO isolation, NO z-index sul container (romperebbe il canvas fixed) */
.hero {
  position: relative !important;
  isolation: auto !important;
  z-index: auto !important;
  overflow: visible !important;
}

/* Connectome SVG: sopra il canvas */
.hero__connectome {
  z-index: 2 !important;
}

/* Contenuto hero: sopra tutto */
.hero__content {
  position: relative !important;
  z-index: 10 !important;
}
.hero__cta    { position: relative; z-index: 10; }
.hero__stats  { position: relative; z-index: 10; }
.hero__eyebrow{ position: relative; z-index: 10; }

/* Header: sopra canvas e contenuto */
.header { position: sticky !important; top: 0 !important; z-index: 200 !important; }

/* Sezioni sotto hero: sopra canvas */
.members-section,
.rete-why-section,
.cta-section,
.footer { position: relative; z-index: 10; }


/* ── SHAKE ── */
@keyframes shake { 0%,100%{transform:translateX(0)} 20%,60%{transform:translateX(-6px)} 40%,80%{transform:translateX(6px)} }
.shake { animation: shake .4s ease; }

/* ── ICON STATES ── */
.icon-btn--locked { opacity:.32; cursor:not-allowed; filter:grayscale(.4); }
.icon-btn--locked:hover { opacity:.4; transform:none !important; background:transparent !important; }
.icon-btn--pencil { color:#c4b0ff; border-color:rgba(196,176,255,.22); }
.icon-btn--pencil:hover:not(.icon-btn--locked) { background:rgba(196,176,255,.14); border-color:rgba(196,176,255,.44); }

/* ── TOOLTIP SOTTO le icone ── */
.icon-btn[data-tip] { position: relative; }
.icon-btn[data-tip]::after {
  content: attr(data-tip);
  position: absolute;
  top: calc(100% + 6px);
  left: 50%; transform: translateX(-50%);
  background: rgba(0,20,50,.96);
  color: #a8eeff;
  border: 1px solid rgba(123,228,255,.3);
  font-size: .7rem; font-weight: 600;
  white-space: nowrap;
  padding: 5px 10px; border-radius: 8px;
  pointer-events: none; opacity: 0;
  transition: opacity .18s; z-index: 9999;
}
.icon-btn[data-tip]:hover::after { opacity: 1; }

/* ── BARRA ACCESSO INLINE HERO ── */
.hero-access-bar {
  display: inline-flex; align-items: center; gap: 8px;
  flex-shrink: 1;
}
.hero-access-input {
  flex: 1; min-width: 140px; max-width: 200px;
  background: rgba(123,228,255,.08);
  border: 1px solid rgba(123,228,255,.28);
  border-radius: 999px; padding: 10px 18px;
  color: #edf7ff; font-size: .82rem; font-family: monospace;
  letter-spacing: .06em; outline: none; transition: border-color .2s;
}
.hero-access-input:focus { border-color: rgba(123,228,255,.6); }
.hero-access-input::placeholder { color: rgba(168,238,255,.35); }
.hero-access-input:disabled { opacity: .5; }
.hero-access-btn {
  background: rgba(123,228,255,.14);
  border: 1px solid rgba(123,228,255,.3);
  border-radius: 999px; padding: 10px 20px;
  color: #a8eeff; font-size: .78rem; font-weight: 700;
  cursor: pointer; transition: background .2s;
}
.hero-access-btn:hover { background: rgba(123,228,255,.26); }
.hero-access-btn:disabled { opacity: .4; cursor: default; }
.hero-access-status { font-size: .76rem; }
.hero-access-status.ok  { color: #4dffd6; }
.hero-access-status.err { color: #ff7070; }

/* ── MODAL PROFILO ── */
.profile-modal {
  position:fixed; inset:0; z-index:9800; display:none;
  align-items:center; justify-content:center; padding:20px;
  background:rgba(1,14,32,.78);
  backdrop-filter:blur(18px) saturate(1.4);
}
.profile-modal.is-open { display:flex; }

.profile-modal__dialog {
  width:min(540px,100%); max-height:88vh; overflow-y:auto;
  border-radius:24px;
  background: linear-gradient(160deg, rgba(4,42,84,.97) 0%, rgba(3,28,62,.97) 55%, rgba(2,18,44,.98) 100%);
  border:1px solid rgba(100,210,255,.28);
  box-shadow: 0 0 0 1px rgba(100,210,255,.08), 0 34px 90px rgba(0,0,0,.55), inset 0 1px 0 rgba(124,243,255,.12);
  padding:32px;
  position:relative;
}
.profile-modal__dialog::before {
  content:''; position:absolute; top:-60px; left:50%; transform:translateX(-50%);
  width:320px; height:160px;
  background:radial-gradient(ellipse, rgba(80,180,255,.15) 0%, transparent 70%);
  pointer-events:none; z-index:0;
}
.profile-modal__close {
  position:absolute; top:14px; right:14px;
  width:38px; height:38px; border-radius:10px;
  background:rgba(100,200,255,.1); border:1px solid rgba(100,210,255,.2);
  color:#a8eeff; font-size:1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .18s; z-index:1;
}
.profile-modal__close:hover { background:rgba(100,200,255,.2); }

.profile-modal__name {
  font-size:1.25rem; font-weight:800; color:#e8f7ff;
  margin:0 0 4px; position:relative; z-index:1;
}
.profile-modal__role {
  font-size:.82rem; color:rgba(124,220,255,.65);
  margin:0 0 16px; position:relative; z-index:1;
}
.profile-modal__bio {
  font-size:.88rem; line-height:1.75; color:rgba(220,245,255,.82);
  margin:0 0 20px; padding-bottom:16px;
  border-bottom:1px solid rgba(100,210,255,.15);
  position:relative; z-index:1;
}
.profile-modal__bio.empty { color:rgba(140,200,255,.35); font-style:italic; }
.profile-modal__links { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:16px; position:relative; z-index:1; }
.profile-link { display:inline-flex; align-items:center; padding:5px 12px; border-radius:8px; font-size:.76rem; background:rgba(123,228,255,.08); border:1px solid rgba(123,228,255,.18); color:#a8eeff; text-decoration:none; transition:background .18s; }
.profile-link:hover { background:rgba(123,228,255,.16); }
.profile-modal__avail { display:flex; gap:10px; flex-wrap:wrap; }
.avail-tag { padding:4px 10px; border-radius:6px; font-size:.76rem; font-weight:600; background:rgba(77,255,214,.08); border:1px solid rgba(77,255,214,.2); color:#4dffd6; }

/* ── MODAL MATITA ── */
.edit-modal {
  position:fixed; inset:0; z-index:9900; display:none;
  align-items:center; justify-content:center; padding:20px;
  background:rgba(1,14,32,.78);
  backdrop-filter:blur(18px) saturate(1.4);
}
.edit-modal.is-open { display:flex; }

.edit-modal__dialog {
  width:min(580px,100%); max-height:90vh; overflow-y:auto;
  border-radius:24px;
  background: linear-gradient(160deg, rgba(4,42,84,.97) 0%, rgba(3,28,62,.97) 55%, rgba(2,18,44,.98) 100%);
  border:1px solid rgba(100,210,255,.28);
  box-shadow: 0 0 0 1px rgba(100,210,255,.08), 0 34px 90px rgba(0,0,0,.55), inset 0 1px 0 rgba(124,243,255,.12);
  padding:32px;
  position:relative;
}
.edit-modal__dialog::before {
  content:''; position:absolute; top:-60px; left:50%; transform:translateX(-50%);
  width:340px; height:180px;
  background:radial-gradient(ellipse, rgba(80,180,255,.13) 0%, transparent 70%);
  pointer-events:none; z-index:0;
}
.edit-modal__close {
  position:absolute; top:14px; right:14px;
  width:38px; height:38px; border-radius:10px;
  background:rgba(100,200,255,.1); border:1px solid rgba(100,210,255,.2);
  color:#a8eeff; font-size:1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .18s; z-index:1;
}
.edit-modal__close:hover { background:rgba(100,200,255,.2); }
.edit-modal__title { font-size:1.15rem; font-weight:800; color:#e8f7ff; margin:0 0 4px; position:relative; z-index:1; }
.edit-modal__sub { font-size:.78rem; color:rgba(124,220,255,.6); margin:0 0 24px; position:relative; z-index:1; }
.edit-section-label {
  font-size:.62rem; font-weight:800; letter-spacing:.14em; text-transform:uppercase;
  color:#7dd3fc; margin:22px 0 10px; padding-bottom:6px;
  border-bottom:1px solid rgba(100,210,255,.18); position:relative; z-index:1;
}
.edit-field { margin-bottom:12px; position:relative; z-index:1; }
.edit-field label { display:block; font-size:.72rem; font-weight:600; color:rgba(160,230,255,.75); margin-bottom:5px; }
.edit-field input, .edit-field textarea {
  width:100%; padding:10px 14px; border-radius:10px;
  background:rgba(6,38,78,.6); border:1px solid rgba(100,200,255,.22);
  color:#ddf4ff; font-size:.83rem; outline:none;
  transition:border-color .2s, background .2s, box-shadow .2s;
  box-sizing:border-box; font-family:inherit;
}
.edit-field textarea { resize:vertical; min-height:90px; line-height:1.65; }
.edit-field input:focus, .edit-field textarea:focus {
  border-color:rgba(100,220,255,.55); background:rgba(6,42,88,.75);
  box-shadow:0 0 0 3px rgba(100,210,255,.08);
}
.edit-field input::placeholder, .edit-field textarea::placeholder { color:rgba(140,210,255,.3); }
.edit-checkboxes { display:flex; flex-direction:column; gap:10px; margin-bottom:20px; position:relative; z-index:1; }
.edit-checkbox {
  display:flex; align-items:center; gap:12px; font-size:.83rem;
  color:rgba(220,245,255,.85); cursor:pointer; padding:10px 14px;
  border-radius:10px; background:rgba(6,38,78,.4); border:1px solid rgba(100,200,255,.14);
  transition:background .18s, border-color .18s;
}
.edit-checkbox:hover { background:rgba(6,50,100,.5); border-color:rgba(100,210,255,.28); }
.edit-checkbox input[type=checkbox] { accent-color:#4dd9f5; width:17px; height:17px; flex-shrink:0; }
.edit-submit {
  width:100%; padding:13px; border-radius:12px;
  background:linear-gradient(135deg, rgba(0,160,220,.75) 0%, rgba(0,120,200,.8) 50%, rgba(0,90,180,.75) 100%);
  border:1px solid rgba(100,220,255,.4); color:#e8f8ff;
  font-size:.9rem; font-weight:700; cursor:pointer;
  transition:filter .2s, transform .15s, box-shadow .2s;
  margin-top:10px; position:relative; z-index:1;
  box-shadow:0 6px 24px rgba(0,120,220,.3);
}
.edit-submit:hover { filter:brightness(1.12); transform:translateY(-1px); box-shadow:0 10px 32px rgba(0,140,255,.4); }
.edit-submit:active { transform:translateY(0); }
.edit-status { text-align:center; font-size:.8rem; margin-top:10px; min-height:20px; position:relative; z-index:1; }
.edit-status.ok  { color:#4dffd6; }
.edit-status.err { color:#ff8080; }

/* Profile modal improved */
.pm-header { margin-bottom:16px; }
.avail-badge { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:999px; font-size:.72rem; font-weight:700; letter-spacing:.04em; margin:0 6px 8px 0; }
.avail-badge--speaker { background:rgba(123,228,255,.12); border:1px solid rgba(123,228,255,.3); color:#7ce8ff; }
.avail-badge--podcast { background:rgba(196,176,255,.12); border:1px solid rgba(196,176,255,.3); color:#c4b0ff; }
.avail-badge--research { background:rgba(77,255,214,.12); border:1px solid rgba(77,255,214,.3); color:#4dffd6; }
.pm-tags { display:flex; flex-wrap:wrap; gap:6px; margin:12px 0 16px; }
.pm-tag { display:inline-flex; align-items:center; padding:3px 10px; border-radius:999px; font-size:.62rem; font-weight:700; letter-spacing:.08em; background:rgba(123,228,255,.08); border:1px solid rgba(123,228,255,.18); color:rgba(168,238,255,.7); text-transform:uppercase; }
.profile-link { display:inline-flex; align-items:center; padding:6px 14px; border-radius:999px; font-size:.75rem; font-weight:600; background:rgba(123,228,255,.08); border:1px solid rgba(123,228,255,.18); color:#7ce8ff; text-decoration:none; transition:background .18s; margin:0 6px 6px 0; }
.profile-link:hover { background:rgba(123,228,255,.16); border-color:rgba(123,228,255,.4); }

/* ── MOBILE FIXES ── */
@media (max-width: 768px) {
  .member-card { min-height: 400px; }
  .member-links { bottom: 10px; gap: 5px; }
  .member-location { bottom: 56px; }
  .icon-btn { width: 30px; height: 30px; border-radius: 8px; }
  .hero-access-bar { max-width: 100%; }
  .hero-access-input { min-width: 0; font-size:.75rem; padding:8px 14px; }
}

/* ── Profile btn: colore caldo, illuminazione ── */
.member-profile-btn {
  color: #ffd166;
  border-color: rgba(255,209,102,.25);
}
.member-profile-btn:not(.icon-btn--locked):hover {
  transform: translateY(-2px) scale(1.06);
  background: rgba(255,209,102,.14);
  border-color: rgba(255,209,102,.5);
  color: #ffd166;
}

/* ── Matita: colore e hover ── */
.member-edit-btn {
  color: #c4b0ff;
  border-color: rgba(196,176,255,.22);
}
.member-edit-btn:hover {
  background: rgba(196,176,255,.14) !important;
  border-color: rgba(196,176,255,.44) !important;
  transform: translateY(-2px) scale(1.06) !important;
}

@media (max-width: 480px) {
  .member-role { font-size: .78rem; padding-bottom: 110px; }
  .member-card { min-height: 380px; }
}


/* ════════════════════════════════════════════════════════
   JOIN GRID — Rete di Boyle + Amici di Boyle
   ════════════════════════════════════════════════════════ */

.join-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin: 0 auto;
  max-width: 960px;
}

.join-card {
  border-radius: 24px;
  padding: 32px 28px 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
  overflow: hidden;
}

/* Rete — bordo ciano */
.join-card--rete {
  background: linear-gradient(140deg, rgba(8,28,68,.72), rgba(4,14,34,.85));
  border: 1px solid rgba(123,228,255,.28);
  box-shadow: 0 0 60px rgba(123,228,255,.06);
}
.join-card--rete::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(123,228,255,.08), transparent);
  pointer-events: none;
}

/* Amici — bordo verde */
.join-card--amici {
  background: linear-gradient(140deg, rgba(4,40,28,.72), rgba(2,20,14,.85));
  border: 1px solid rgba(77,255,180,.28);
  box-shadow: 0 0 60px rgba(77,255,180,.06);
}
.join-card--amici::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 80% 50% at 50% -20%, rgba(77,255,180,.08), transparent);
  pointer-events: none;
}

/* Badge */
.join-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  background: rgba(123,228,255,.12);
  border: 1px solid rgba(123,228,255,.25);
  color: #a8eeff;
  width: fit-content;
}
.join-card__badge--amici {
  background: rgba(77,255,180,.12);
  border-color: rgba(77,255,180,.25);
  color: #4dffd6;
}

/* Title */
.join-card__title {
  font-size: clamp(1.1rem, 1.6vw, 1.4rem);
  font-weight: 800;
  color: #edf7ff;
  line-height: 1.25;
  letter-spacing: -.03em;
  margin: 0;
}

/* Text */
.join-card__text {
  font-size: .88rem;
  line-height: 1.7;
  color: rgba(237,247,255,.65);
  margin: 0;
}

/* Benefits */
.join-card__benefits {
  display: flex;
  flex-direction: column;
  gap: 7px;
  flex: 1;
}
.join-card__benefits span {
  font-size: .8rem;
  color: rgba(237,247,255,.72);
  display: flex;
  align-items: center;
  gap: 6px;
}
.join-card--rete .join-card__benefits span::before { content: ''; }

/* CTA button Amici — verde */
.btn-amici {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 28px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(77,255,180,.22), rgba(0,200,140,.18));
  border: 1px solid rgba(77,255,180,.4);
  color: #4dffd6;
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  position: relative; overflow: hidden;
  transition: background .22s, border-color .22s, transform .18s;
  white-space: nowrap;
}

.btn-amici::before {
  content: "";
  position: absolute; inset: -30% auto -30% -18%; width: 26%;
  background: linear-gradient(90deg, transparent, rgba(77,255,180,.7), transparent);
  transform: skewX(-22deg); filter: blur(4px); opacity: .9;
  animation: amiciSweep 2.6s linear infinite;
}
@keyframes amiciSweep { 0%{left:-28%;} 100%{left:120%;} }
.btn-amici__inner { position: relative; z-index: 1; display: flex; align-items: center; gap: 8px; }
.btn-amici:hover {
  background: linear-gradient(135deg, rgba(77,255,180,.32), rgba(0,200,140,.28));
  border-color: rgba(77,255,180,.65);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,200,140,.2);
}

/* ════════════════════════════════════════════════════════
   MODAL AMICI DI BOYLE
   ════════════════════════════════════════════════════════ */

.modal__dialog--amici {
  border-color: rgba(77,255,180,.22) !important;
}
.modal__kicker--amici {
  color: #4dffd6 !important;
  border-color: rgba(77,255,180,.2) !important;
  background: rgba(77,255,180,.08) !important;
}

/* Vantaggi inline nel modal */
.amici-benefits-inline {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 16px;
  background: rgba(77,255,180,.04);
  border: 1px solid rgba(77,255,180,.12);
  border-radius: 14px;
  margin-bottom: 20px;
}
.amici-benefit-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: .78rem;
  color: rgba(237,247,255,.75);
  line-height: 1.4;
}
.amici-benefit-item svg {
  color: #4dffd6;
  flex-shrink: 0;
  margin-top: 1px;
}
.amici-benefit-item--note {
  grid-column: 1 / -1;
  color: rgba(77,255,180,.7);
  font-style: italic;
  font-size: .74rem;
}
.amici-benefit-item--note svg { color: rgba(77,255,180,.7); }

/* Select nel form */
.network-form select {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(123,228,255,.2);
  background: rgba(255,255,255,.04);
  color: var(--r-text, #edf7ff);
  font-size: .9rem;
  outline: none;
  appearance: none;
  cursor: pointer;
  transition: border-color .2s;
}
.network-form select:focus { border-color: rgba(77,255,180,.45); }
.modal__dialog--amici .network-form select:focus { border-color: rgba(77,255,180,.45); }

/* Submit button Amici */
.btn-amici-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(77,255,180,.2), rgba(0,200,140,.16));
  border: 1px solid rgba(77,255,180,.4);
  color: #4dffd6;
  font-size: .9rem;
  font-weight: 700;
  cursor: pointer;
  transition: background .22s, border-color .22s;
  width: 100%;
}
.btn-amici-submit:hover {
  background: linear-gradient(135deg, rgba(77,255,180,.3), rgba(0,200,140,.26));
  border-color: rgba(77,255,180,.65);
}
.btn-amici-submit:disabled { opacity: .5; cursor: default; }

/* Responsive */
@media (max-width: 768px) {
  .join-grid { grid-template-columns: 1fr; }
  .amici-benefits-inline { grid-template-columns: 1fr; }
}




/* ════════════════════════════════════════════════════════
   SEZIONE PROSSIMO EVENTO
   ════════════════════════════════════════════════════════ */

.next-event-section {
  padding: 60px 0 80px;
  border-top: 1px solid rgba(123,228,255,.08);
}

/* Locandina + info fianco a fianco */
.next-event-grid {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 40px;
  align-items: start;
  max-width: 820px;
  margin: 0 auto 48px;
}
.next-event-poster {
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid rgba(123,228,255,.15);
}
.next-event-poster img {
  width: 100%;
  display: block;
  border-radius: 16px;
}
.next-event-info-col {
  display: flex;
  flex-direction: column;
  padding-top: 4px;
}
.next-event-title {
  font-size: clamp(1.3rem, 2vw, 1.8rem);
  font-weight: 800;
  color: #edf7ff;
  letter-spacing: -.03em;
  margin: 0 0 12px;
}
.next-event-desc {
  font-size: .88rem;
  line-height: 1.7;
  color: rgba(237,247,255,.65);
  margin: 0 0 16px;
}

/* Box proponi evento */
.next-event-propose {
  max-width: 820px;
  margin: 0 auto;
}
.next-event-propose__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }
.next-event-propose__text {
  flex: 1;
}
.next-event-propose__title {
  font-size: 1rem;
  font-weight: 800;
  color: #edf7ff;
  margin: 0 0 6px;
}
.next-event-propose__desc {
  font-size: .82rem;
  line-height: 1.6;
  color: rgba(237,247,255,.55);
  margin: 0;
}
.next-event-publish-btn {
  flex-shrink: 0;
  white-space: nowrap;
  width: auto !important;
  min-width: 180px;
}



/* ── Modal mobile ── */
@media (max-width: 768px) {
  .profile-modal__dialog,
  .edit-modal__dialog {
    padding: 20px 16px;
    border-radius: 16px;
  }
  .amici-benefits-inline { grid-template-columns: 1fr; }
  .network-form select { font-size: .85rem; }
}

/* ── Tooltip mobile sopra le icone ── */
@media (max-width: 768px) {
  .icon-btn[data-tip]::after {
    top: auto;
    bottom: calc(100% + 6px);
    font-size: .65rem;
    padding: 3px 7px;
  }
}

/* btn-electric mantiene electricSweep su mobile */

@media (max-width: 768px) {
  .hero__stats { 
    max-width: 100% !important; 
    width: 100% !important;
    flex-wrap: nowrap !important;
  }
  .hero__stat {
    padding: 10px 8px !important;
  }
  .hero__stat-n { font-size: 1.2rem !important; }
  .hero__stat-l { font-size: .6rem !important; }
}

/* ══ KILL ANIMAZIONI MOBILE ══ */
@media (max-width: 768px) {
  .hero::after        { animation: none !important; opacity: 0 !important; }
  .hero::before       { animation: none !important; }
  .connectome-nodes .node { animation: none !important; }
  .traveler           { animation: none !important; }
  .city-line          { animation: none !important; }
  .rete-event-dot     { animation: none !important; }
  /* btn-electric::before e btn-amici::before MANTENGONO l'elettricità */
  .hero-access-bar::before { animation: none !important; }
}

/* ══ BENEFIT CARDS: UNA PER RIGA SU MOBILE — DEFINITIVO ══ */
@media (max-width: 768px) {
  .rete-benefits-col {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: unset !important;
    gap: 12px !important;
  }
  .rete-benefits-col .benefit-card {
    width: 100% !important;
    max-width: 100% !important;
  }
}

/* ══ MOBILE: event grid e layout ══ */
@media (max-width: 768px) {
  .next-event-grid {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  .next-event-poster {
    max-width: 280px;
    margin: 0 auto;
  }
  .container {
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
    box-sizing: border-box !important;
  }
  .hero {
    overflow-x: hidden !important;
  }
}

/* ══ HERO RETE: centrata su desktop ══ */
@media (min-width: 769px) {
  .hero .container {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .hero__content {
    text-align: center !important;
    max-width: 780px !important;
    margin: 0 auto !important;
  }
  .hero__eyebrow {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .hero__subtitle {
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .hero__cta {
    justify-content: center !important;
  }
  .hero__stats {
    max-width: 560px !important;
    margin: 0 auto !important;
  }
  /* Barra accesso: centrata */
  .hero-access-bar {
    max-width: 480px !important;
    margin: 0 auto !important;
  }
}

/* ── Bottone viola EVENTI ── */
.btn-eventi {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 26px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(196,176,255,.18), rgba(150,120,255,.14));
  border: 1px solid rgba(196,176,255,.38);
  color: #c4b0ff;
  font-size: .88rem;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  position: relative; overflow: hidden;
  transition: background .22s, border-color .22s, transform .18s;
}
.btn-eventi::before {
  content: "";
  position: absolute; inset: -30% auto -30% -18%; width: 26%;
  background: linear-gradient(90deg, transparent, rgba(196,176,255,.6), transparent);
  transform: skewX(-22deg); filter: blur(4px); opacity: .9;
  animation: eventiSweep 2.8s linear infinite;
}
@keyframes eventiSweep { 0%{left:-28%;} 100%{left:120%;} }
.btn-eventi:hover {
  background: linear-gradient(135deg, rgba(196,176,255,.28), rgba(150,120,255,.22));
  border-color: rgba(196,176,255,.6);
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(150,120,255,.2);
}
@media (max-width: 768px) {
  .btn-eventi::before { animation: none !important; }
}

/* ════════════════════════════════════════════════════════
   EDIT MODAL — REDESIGN OCEAN PREMIUM
   ════════════════════════════════════════════════════════ */

.edit-modal {
  position: fixed; inset: 0; z-index: 9500;
  display: none; align-items: center; justify-content: center;
  padding: 20px;
  background: rgba(1, 6, 20, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.edit-modal.is-open { display: flex; }

.edit-modal__dialog {
  background: linear-gradient(160deg, rgba(4,22,56,0.97) 0%, rgba(2,14,38,0.99) 100%);
  border: 1px solid rgba(100,200,255,0.18);
  border-radius: 20px;
  box-shadow: 0 24px 80px rgba(0,0,0,0.6), 0 0 0 1px rgba(100,200,255,0.08), inset 0 1px 0 rgba(100,200,255,0.12);
  width: 100%; max-width: 580px;
  max-height: 88vh; overflow-y: auto;
  padding: 0;
  position: relative;
}
.edit-modal__dialog::-webkit-scrollbar { width: 4px; }
.edit-modal__dialog::-webkit-scrollbar-track { background: transparent; }
.edit-modal__dialog::-webkit-scrollbar-thumb { background: rgba(100,200,255,0.2); border-radius: 2px; }

/* Header identità */
.edit-modal__header {
  display: flex; align-items: center; gap: 16px;
  padding: 24px 28px 20px;
  border-bottom: 1px solid rgba(100,200,255,0.1);
  position: relative;
}

.edit-modal__avatar {
  width: 52px; height: 52px; border-radius: 50%;
  background: linear-gradient(135deg, rgba(0,150,255,0.3), rgba(0,220,180,0.2));
  border: 1px solid rgba(100,200,255,0.3);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; font-weight: 800; color: #7dd3fc;
  letter-spacing: .05em; flex-shrink: 0;
  box-shadow: 0 0 20px rgba(0,150,255,0.2);
}

.edit-modal__identity { flex: 1; min-width: 0; }
.edit-modal__name {
  font-size: 1.05rem; font-weight: 800; color: #e8f4ff;
  margin: 0 0 3px; letter-spacing: -.01em;
}
.edit-modal__role-label {
  font-size: .72rem; color: rgba(150,200,240,0.55);
  margin: 0 0 6px; line-height: 1.4;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.edit-modal__status {
  display: inline-block;
  font-size: .68rem; font-weight: 700; letter-spacing: .08em;
  padding: 2px 10px; border-radius: 999px;
  background: rgba(100,200,255,0.06);
  border: 1px solid rgba(100,200,255,0.15);
  color: rgba(150,200,240,0.5);
}
.edit-modal__status--active {
  background: rgba(0,255,180,0.08);
  border-color: rgba(0,255,180,0.25);
  color: #4dffd6;
  box-shadow: 0 0 12px rgba(0,255,180,0.1);
}

.edit-modal__close {
  position: absolute; top: 20px; right: 20px;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(100,200,255,0.06);
  border: 1px solid rgba(100,200,255,0.15);
  color: rgba(180,210,240,0.6); font-size: .9rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.edit-modal__close:hover { background: rgba(255,80,80,0.15); color: #ff8080; }

/* Blocchi sezione */
.edit-section-block {
  padding: 20px 28px;
  border-bottom: 1px solid rgba(100,200,255,0.07);
}
.edit-section-block:last-of-type { border-bottom: none; }

.edit-section-label {
  font-size: .7rem; font-weight: 800; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(125,211,252,0.6);
  margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.edit-section-icon { font-size: .8rem; opacity: .7; }

/* Campi input */
.edit-field { margin-bottom: 12px; }
.edit-field label {
  display: block; font-size: .72rem; font-weight: 600;
  color: rgba(180,210,240,0.65); margin-bottom: 5px;
  letter-spacing: .04em;
}
.edit-field__hint { font-weight: 400; opacity: .6; margin-left: 4px; }

.edit-field textarea,
.edit-field input[type="url"] {
  width: 100%; padding: 10px 14px;
  background: rgba(4,18,48,0.7);
  border: 1px solid rgba(100,200,255,0.16);
  border-radius: 10px; color: #d0e8ff;
  font-size: .83rem; font-family: inherit;
  transition: border-color .2s, box-shadow .2s;
  outline: none;
}
.edit-field textarea { resize: vertical; min-height: 80px; }
.edit-field textarea:focus,
.edit-field input[type="url"]:focus {
  border-color: rgba(100,200,255,0.4);
  box-shadow: 0 0 0 3px rgba(100,200,255,0.08);
}

.edit-field__input-wrap {
  display: flex; align-items: center;
  background: rgba(4,18,48,0.7);
  border: 1px solid rgba(100,200,255,0.16);
  border-radius: 10px; overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.edit-field__input-wrap:focus-within {
  border-color: rgba(100,200,255,0.4);
  box-shadow: 0 0 0 3px rgba(100,200,255,0.08);
}
.edit-field__prefix {
  padding: 10px 12px;
  font-size: .7rem; font-weight: 800; letter-spacing: .06em;
  color: rgba(125,211,252,0.5); border-right: 1px solid rgba(100,200,255,0.1);
  flex-shrink: 0; min-width: 34px; text-align: center;
}
.edit-field__input-wrap input {
  border: none; background: transparent;
  padding: 10px 12px; width: 100%;
  color: #d0e8ff; font-size: .83rem; font-family: inherit;
  outline: none;
}

.edit-char-count {
  display: block; text-align: right; font-size: .68rem;
  color: rgba(130,180,220,0.4); margin-top: 4px;
}

/* Grid 2 colonne per link */
.edit-fields-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
@media (max-width: 520px) { .edit-fields-grid { grid-template-columns: 1fr; } }

/* Checkbox disponibilità */
.edit-checkboxes { display: flex; flex-direction: column; gap: 10px; }
.edit-checkbox {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: rgba(4,18,48,0.5);
  border: 1px solid rgba(100,200,255,0.1);
  border-radius: 10px; cursor: pointer;
  transition: border-color .2s, background .2s;
}
.edit-checkbox:hover {
  background: rgba(100,200,255,0.06);
  border-color: rgba(100,200,255,0.2);
}
.edit-checkbox input[type="checkbox"] {
  width: 16px; height: 16px; accent-color: #4dffd6;
  flex-shrink: 0; cursor: pointer;
}
.edit-checkbox span { font-size: .82rem; color: rgba(180,210,240,0.8); }

/* Footer modal */
.edit-modal__footer {
  padding: 20px 28px;
  border-top: 1px solid rgba(100,200,255,0.1);
}
.edit-submit {
  width: 100%; padding: 13px;
  background: linear-gradient(135deg, rgba(0,140,255,0.25), rgba(0,200,180,0.2));
  border: 1px solid rgba(0,180,255,0.35);
  border-radius: 12px; color: #7dd3fc;
  font-size: .88rem; font-weight: 800; letter-spacing: .06em;
  cursor: pointer; transition: background .22s, box-shadow .22s, transform .15s;
  position: relative; overflow: hidden;
}
.edit-submit:hover {
  background: linear-gradient(135deg, rgba(0,140,255,0.38), rgba(0,200,180,0.3));
  box-shadow: 0 8px 28px rgba(0,150,255,0.2);
  transform: translateY(-1px);
}
.edit-status {
  text-align: center; font-size: .78rem; margin-top: 10px;
  color: #4dffd6; min-height: 20px;
}

/* Rimuovi vecchi stili edit-modal che possono conflittare */
.edit-modal__title { display: none; }

/* ════════════════════════════════════════════════════════
   BADGE PROFILO ATTIVO + FILTRO
   ════════════════════════════════════════════════════════ */

.profile-active-badge {
  display: inline-block;
  font-size: .63rem; font-weight: 700; letter-spacing: .1em;
  padding: 3px 10px; border-radius: 999px;
  background: rgba(0,255,180,0.08);
  border: 1px solid rgba(0,255,180,0.22);
  color: #4dffd6;
  margin-bottom: 6px;
  animation: profileGlow 3s ease-in-out infinite;
}
@keyframes profileGlow {
  0%, 100% { box-shadow: 0 0 6px rgba(0,255,180,0.15); }
  50%       { box-shadow: 0 0 14px rgba(0,255,180,0.35); }
}
@media (max-width: 768px) {
  .profile-active-badge { animation: none; }
}

/* Filtro membri */
.members-filter { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 20px; }
.filter-btn {
  padding: 7px 18px; border-radius: 999px;
  font-size: .78rem; font-weight: 700; letter-spacing: .06em;
  cursor: pointer; transition: all .2s;
  background: rgba(100,200,255,0.06);
  border: 1px solid rgba(100,200,255,0.18);
  color: rgba(180,210,240,0.6);
}
.filter-btn:hover { background: rgba(100,200,255,0.12); color: rgba(180,210,240,0.9); }
.filter-btn--active {
  background: rgba(0,200,255,0.15);
  border-color: rgba(0,200,255,0.4);
  color: #7dd3fc;
  box-shadow: 0 0 12px rgba(0,200,255,0.1);
}

/* ════════════════════════════════════════════════════════
   PAGINA PERSONALE — REDESIGN
   ════════════════════════════════════════════════════════ */

/* Override sfondo nero con oceano profondo */
.member-profile-page {
  background: linear-gradient(160deg, #020e28 0%, #030d22 60%, #04152e 100%) !important;
  min-height: 100vh;
}

/* Hero profilo compatta */
.profile-hero {
  padding: 48px 32px 32px;
  border-bottom: 1px solid rgba(100,200,255,0.1);
  display: flex; gap: 24px; align-items: flex-start;
  max-width: 760px; margin: 0 auto;
}
.profile-hero__photo {
  width: 88px; height: 88px; border-radius: 50%; flex-shrink: 0;
  object-fit: cover;
  border: 2px solid rgba(100,200,255,0.25);
  box-shadow: 0 0 30px rgba(0,150,255,0.2);
  background: rgba(4,18,48,0.8);
}
.profile-hero__info { flex: 1; }
.profile-hero__kicker {
  font-size: .65rem; font-weight: 800; letter-spacing: .22em;
  text-transform: uppercase; color: rgba(125,211,252,0.55);
  margin-bottom: 6px;
}
.profile-hero__name {
  font-size: 1.7rem; font-weight: 800; color: #e8f4ff;
  letter-spacing: -.02em; margin-bottom: 6px; line-height: 1.1;
}
.profile-hero__role {
  font-size: .82rem; color: rgba(160,200,240,0.65);
  line-height: 1.5; margin-bottom: 10px;
}
.profile-hero__location {
  font-size: .72rem; color: rgba(130,180,220,0.45);
  display: flex; align-items: center; gap: 5px;
}

/* Contenuto profilo */
.profile-body {
  max-width: 760px; margin: 0 auto; padding: 32px;
}

/* Box bio */
.profile-bio-box {
  background: rgba(4,18,48,0.6);
  border: 1px solid rgba(100,200,255,0.12);
  border-radius: 14px; padding: 20px 24px;
  margin-bottom: 24px;
  border-left: 3px solid rgba(100,200,255,0.3);
}
.profile-bio-box p {
  font-size: .88rem; line-height: 1.8;
  color: rgba(200,225,245,0.8); margin: 0;
}

/* Link professionali pill */
.profile-links {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px;
}
.profile-link-pill {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px; border-radius: 999px;
  background: rgba(4,18,48,0.7);
  border: 1px solid rgba(100,200,255,0.18);
  color: rgba(180,215,245,0.75);
  font-size: .76rem; font-weight: 600; text-decoration: none;
  transition: border-color .2s, color .2s, box-shadow .2s;
}
.profile-link-pill:hover {
  border-color: rgba(100,200,255,0.4);
  color: #7dd3fc;
  box-shadow: 0 4px 16px rgba(0,150,255,0.12);
}
.profile-link-pill__icon {
  font-size: .7rem; opacity: .6;
}

/* Disponibilità chips */
.profile-availability {
  display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 24px;
}
.avail-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 999px;
  font-size: .73rem; font-weight: 700; letter-spacing: .05em;
  background: rgba(0,200,140,0.08);
  border: 1px solid rgba(0,200,140,0.22);
  color: #4dffd6;
}
.avail-chip::before { content: "✓"; font-size: .65rem; }

/* Tags area */
.profile-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.profile-tag {
  padding: 4px 12px; border-radius: 999px;
  font-size: .68rem; font-weight: 700; letter-spacing: .08em;
  background: rgba(100,180,255,0.08);
  border: 1px solid rgba(100,180,255,0.18);
  color: rgba(150,200,240,0.65);
}

/* Sezione label profilo */
.profile-section-label {
  font-size: .65rem; font-weight: 800; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(125,211,252,0.45);
  margin-bottom: 12px; margin-top: 24px;
}

/* Back link */
.profile-back {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 16px; border-radius: 999px;
  background: rgba(4,18,48,0.7);
  border: 1px solid rgba(100,200,255,0.15);
  color: rgba(150,200,240,0.6); font-size: .75rem; font-weight: 600;
  text-decoration: none; margin-bottom: 32px;
  transition: border-color .2s, color .2s;
}
.profile-back:hover { border-color: rgba(100,200,255,0.35); color: #7dd3fc; }

@media (max-width: 600px) {
  .profile-hero { flex-direction: column; padding: 32px 20px 24px; }
  .profile-body { padding: 24px 20px; }
}

/* ════════════════════════════════════════════════════════
   PROFILE MODAL — REDESIGN
   ════════════════════════════════════════════════════════ */

.profile-modal {
  position: fixed; inset: 0; z-index: 9400;
  display: none; align-items: center; justify-content: center;
  padding: 20px;
  background: rgba(1, 6, 20, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.profile-modal.is-open { display: flex; }

.profile-modal__dialog {
  background: linear-gradient(160deg, rgba(3,16,44,0.98) 0%, rgba(2,11,30,0.99) 100%);
  border: 1px solid rgba(100,200,255,0.15);
  border-radius: 20px;
  box-shadow: 0 28px 80px rgba(0,0,0,0.65), inset 0 1px 0 rgba(100,200,255,0.1);
  width: 100%; max-width: 600px;
  max-height: 90vh; overflow-y: auto;
  position: relative;
}
.profile-modal__dialog::-webkit-scrollbar { width: 4px; }
.profile-modal__dialog::-webkit-scrollbar-thumb { background: rgba(100,200,255,0.15); border-radius: 2px; }

.profile-modal__close {
  position: absolute; top: 20px; right: 20px; z-index: 2;
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(100,200,255,0.06);
  border: 1px solid rgba(100,200,255,0.15);
  color: rgba(180,210,240,0.6); font-size: .9rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background .2s, color .2s;
}
.profile-modal__close:hover { background: rgba(255,80,80,0.15); color: #ff8080; }

/* Nascondi wrapper vuoti */
#pm-avail-wrap:empty, #pm-links-wrap { }

/* Badge profilo parziale */
.profile-active-badge--partial {
  background: rgba(255,200,0,0.07);
  border-color: rgba(255,200,0,0.2);
  color: rgba(255,220,80,0.75);
  animation: none;
}
.profile-active-badge--full {
  background: rgba(0,255,180,0.08);
  border-color: rgba(0,255,180,0.22);
  color: #4dffd6;
}

/* ════════════════════════════════════════════════════════
   MODAL MATITA — REDESIGN WOW
   ════════════════════════════════════════════════════════ */

.edit-modal {
  position: fixed; inset: 0; z-index: 9500;
  display: none; align-items: center; justify-content: center;
  padding: 16px;
  background: rgba(0, 4, 16, 0.88);
  backdrop-filter: blur(14px);
}
.edit-modal.is-open { display: flex; }

.edit-modal__dialog {
  background: linear-gradient(160deg, #040f28 0%, #020a1c 100%);
  border: 1px solid rgba(80,180,255,.2);
  border-top: 1px solid rgba(120,220,255,.35);
  border-radius: 22px;
  box-shadow:
    0 0 0 1px rgba(80,180,255,.08),
    0 32px 80px rgba(0,0,0,.7),
    0 0 60px rgba(0,120,255,.08),
    inset 0 1px 0 rgba(120,220,255,.15);
  width: 100%; max-width: 560px;
  max-height: 88vh; overflow-y: auto;
  position: relative;
}
.edit-modal__dialog::-webkit-scrollbar { width: 3px; }
.edit-modal__dialog::-webkit-scrollbar-thumb { background: rgba(80,180,255,.2); border-radius: 2px; }

/* Header */
.edit-modal__header {
  display: flex; align-items: center; gap: 14px;
  padding: 22px 24px 18px;
  border-bottom: 1px solid rgba(80,180,255,.1);
  background: linear-gradient(180deg, rgba(0,80,180,.12) 0%, transparent 100%);
}
.edit-modal__avatar {
  width: 48px; height: 48px; border-radius: 50%; flex-shrink: 0;
  background: linear-gradient(135deg, rgba(0,120,255,.4), rgba(0,200,180,.25));
  border: 1px solid rgba(80,200,255,.35);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; font-weight: 800; color: #7dd3fc;
  box-shadow: 0 0 20px rgba(0,120,255,.25), inset 0 1px 0 rgba(255,255,255,.08);
}
.edit-modal__identity { flex: 1; min-width: 0; }
.edit-modal__name {
  font-size: 1rem; font-weight: 800; color: #e8f4ff;
  margin: 0 0 2px; letter-spacing: -.01em;
}
.edit-modal__role-label {
  font-size: .7rem; color: rgba(140,190,230,.5); margin: 0 0 6px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.edit-modal__status {
  display: inline-block; font-size: .65rem; font-weight: 700;
  padding: 2px 8px; border-radius: 999px;
  background: rgba(80,180,255,.06); border: 1px solid rgba(80,180,255,.15);
  color: rgba(140,190,230,.5);
}
.edit-modal__status--active {
  background: rgba(0,210,140,.08); border-color: rgba(0,210,140,.25); color: #4dffd6;
}
.edit-modal__close {
  position: absolute; top: 18px; right: 18px;
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(80,180,255,.06); border: 1px solid rgba(80,180,255,.15);
  color: rgba(160,200,240,.6); font-size: .85rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.edit-modal__close:hover { background: rgba(255,60,60,.15); color: #ff9090; border-color: rgba(255,60,60,.2); }

/* Sezioni */
.edit-section-block {
  padding: 16px 24px;
  border-bottom: 1px solid rgba(80,180,255,.07);
}
.edit-section-label {
  font-size: .65rem; font-weight: 800; letter-spacing: .18em;
  text-transform: uppercase; color: rgba(100,180,255,.5);
  margin-bottom: 12px; display: flex; align-items: center; gap: 7px;
}
.edit-section-icon { opacity: .6; }

/* Campi */
.edit-field { margin-bottom: 10px; }
.edit-field label {
  display: block; font-size: .68rem; font-weight: 700;
  color: rgba(160,200,240,.55); margin-bottom: 4px; letter-spacing: .04em;
}
.edit-field__hint { font-weight: 400; opacity: .55; margin-left: 3px; }
.edit-field__input-wrap {
  display: flex; align-items: stretch;
  background: rgba(2,10,30,.7);
  border: 1px solid rgba(80,180,255,.14);
  border-radius: 10px; overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.edit-field__input-wrap:focus-within {
  border-color: rgba(80,180,255,.38);
  box-shadow: 0 0 0 3px rgba(80,180,255,.07), 0 0 16px rgba(0,100,255,.06);
}
.edit-field__prefix {
  padding: 9px 10px; font-size: .66rem; font-weight: 800;
  color: rgba(100,180,255,.4); border-right: 1px solid rgba(80,180,255,.1);
  min-width: 30px; text-align: center; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.edit-field__input-wrap input {
  border: none; background: transparent; padding: 9px 11px;
  width: 100%; color: #c8e0ff; font-size: .8rem; font-family: inherit; outline: none;
}
.edit-field__input-wrap input::placeholder { color: rgba(80,140,200,.3); }
.edit-field textarea {
  width: 100%; padding: 10px 13px;
  background: rgba(2,10,30,.7); border: 1px solid rgba(80,180,255,.14);
  border-radius: 10px; color: #c8e0ff; font-size: .8rem;
  font-family: inherit; resize: vertical; min-height: 75px; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.edit-field textarea:focus {
  border-color: rgba(80,180,255,.38);
  box-shadow: 0 0 0 3px rgba(80,180,255,.07);
}
.edit-field textarea::placeholder { color: rgba(80,140,200,.3); }
.edit-char-count {
  text-align: right; font-size: .64rem; color: rgba(100,160,220,.35); margin-top: 3px; display: block;
}
.edit-fields-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
@media (max-width: 480px) { .edit-fields-grid { grid-template-columns: 1fr; } }

/* Checkbox */
.edit-checkboxes { display: flex; flex-direction: column; gap: 8px; }
.edit-checkbox {
  display: flex; align-items: center; gap: 11px;
  padding: 10px 14px;
  background: rgba(2,10,30,.5);
  border: 1px solid rgba(80,180,255,.09);
  border-radius: 10px; cursor: pointer;
  transition: border-color .2s, background .2s;
}
.edit-checkbox:hover { background: rgba(80,180,255,.05); border-color: rgba(80,180,255,.18); }
.edit-checkbox input[type="checkbox"] { width: 14px; height: 14px; accent-color: #4dffd6; cursor: pointer; flex-shrink: 0; }
.edit-checkbox span { font-size: .78rem; color: rgba(160,200,240,.75); }

/* Footer */
.edit-modal__footer { padding: 16px 24px; border-top: 1px solid rgba(80,180,255,.09); }
.edit-submit {
  width: 100%; padding: 12px;
  background: linear-gradient(135deg, rgba(0,100,255,.22), rgba(0,180,160,.16));
  border: 1px solid rgba(0,150,255,.3);
  border-radius: 12px; color: #7dd3fc;
  font-size: .84rem; font-weight: 800; letter-spacing: .06em;
  cursor: pointer; transition: all .22s; position: relative; overflow: hidden;
}
.edit-submit::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(90deg, transparent, rgba(100,200,255,.08), transparent);
  transform: translateX(-100%); transition: transform .5s;
}
.edit-submit:hover::before { transform: translateX(100%); }
.edit-submit:hover {
  background: linear-gradient(135deg, rgba(0,100,255,.32), rgba(0,180,160,.26));
  box-shadow: 0 8px 24px rgba(0,100,255,.18);
  transform: translateY(-1px);
}
.edit-status {
  text-align: center; font-size: .75rem; margin-top: 8px; color: #4dffd6; min-height: 18px;
}

/* ════ PAGINA PERSONALE — sfondo oceano ════ */
.profile-modal {
  position: fixed; inset: 0; z-index: 9400;
  display: none; align-items: center; justify-content: center;
  padding: 16px;
  background: rgba(0, 4, 16, 0.85);
  backdrop-filter: blur(14px);
}
.profile-modal.is-open { display: flex; }

.profile-modal__dialog {
  background: linear-gradient(160deg, #030e26 0%, #020918 60%, #03101e 100%);
  border: 1px solid rgba(80,180,255,.15);
  border-top: 1px solid rgba(100,200,255,.28);
  border-radius: 22px;
  box-shadow:
    0 32px 80px rgba(0,0,0,.7),
    0 0 60px rgba(0,100,200,.06),
    inset 0 1px 0 rgba(100,200,255,.1);
  width: 100%; max-width: 580px;
  max-height: 90vh; overflow-y: auto;
  position: relative;
}
.profile-modal__dialog::-webkit-scrollbar { width: 3px; }
.profile-modal__dialog::-webkit-scrollbar-thumb { background: rgba(80,180,255,.18); border-radius: 2px; }

.profile-modal__close {
  position: absolute; top: 18px; right: 18px; z-index: 2;
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(80,180,255,.06); border: 1px solid rgba(80,180,255,.15);
  color: rgba(160,200,240,.6); font-size: .85rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.profile-modal__close:hover { background: rgba(255,60,60,.15); color: #ff9090; }

/* Hero profilo */
.profile-hero {
  padding: 32px 28px 24px; display: flex; gap: 20px; align-items: flex-start;
  border-bottom: 1px solid rgba(80,180,255,.1);
  background: linear-gradient(180deg, rgba(0,60,160,.1) 0%, transparent 100%);
}
.profile-hero__photo {
  width: 80px; height: 80px; border-radius: 50%; flex-shrink: 0;
  object-fit: cover;
  border: 2px solid rgba(80,180,255,.3);
  box-shadow: 0 0 24px rgba(0,100,255,.2);
  background: rgba(4,18,48,.8);
}
.profile-hero__kicker {
  font-size: .62rem; font-weight: 800; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(100,180,255,.45); margin-bottom: 5px;
}
.profile-hero__name {
  font-size: 1.5rem; font-weight: 800; color: #e8f4ff;
  letter-spacing: -.02em; margin-bottom: 5px; line-height: 1.1;
}
.profile-hero__role {
  font-size: .76rem; color: rgba(140,190,230,.6); line-height: 1.5; margin-bottom: 8px;
}
.profile-hero__location {
  font-size: .68rem; color: rgba(100,160,210,.4);
  display: flex; align-items: center; gap: 4px;
}

/* Body */
.profile-body { padding: 24px 28px; }
.profile-section-label {
  font-size: .62rem; font-weight: 800; letter-spacing: .18em;
  text-transform: uppercase; color: rgba(80,160,255,.4);
  margin-bottom: 10px; margin-top: 20px;
}
.profile-section-label:first-child { margin-top: 0; }

/* Bio box */
.profile-bio-box {
  background: rgba(0,20,60,.4);
  border: 1px solid rgba(80,180,255,.1);
  border-left: 3px solid rgba(80,180,255,.3);
  border-radius: 12px; padding: 16px 18px; margin-bottom: 16px;
}
.profile-bio-box p { font-size: .84rem; line-height: 1.8; color: rgba(190,220,245,.75); margin: 0; }

/* Link pill */
.profile-links { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 16px; }
.profile-link-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 7px 14px; border-radius: 999px;
  background: rgba(2,14,40,.7);
  border: 1px solid rgba(80,180,255,.16);
  color: rgba(160,210,245,.7);
  font-size: .72rem; font-weight: 600; text-decoration: none;
  transition: border-color .2s, color .2s, box-shadow .2s;
}
.profile-link-pill:hover {
  border-color: rgba(80,180,255,.38); color: #7dd3fc;
  box-shadow: 0 4px 14px rgba(0,120,255,.1);
}
.profile-link-pill__icon { font-size: .65rem; opacity: .55; }

/* Disponibilità */
.profile-availability { display: flex; flex-wrap: wrap; gap: 7px; }
.avail-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 6px 12px; border-radius: 999px;
  font-size: .68rem; font-weight: 700;
  background: rgba(0,180,120,.07); border: 1px solid rgba(0,180,120,.2); color: #4dffd6;
}
.avail-chip::before { content: "✓"; font-size: .6rem; }

/* ════ LEGENDA ════ */
.profile-legend {
  display: flex; flex-wrap: wrap; gap: 14px;
  margin-top: 10px; padding: 7px 14px;
  background: rgba(4,18,48,.35);
  border: 1px solid rgba(80,180,255,.08);
  border-radius: 10px; width: fit-content;
}
.pleg { display: inline-flex; align-items: center; gap: 5px; font-size: .67rem; font-weight: 600; }
.pleg--base     { color: rgba(220,180,60,.7); }
.pleg--partial  { color: rgba(220,110,30,.9); }
.pleg--complete { color: rgba(0,210,140,.95); }

/* ════ ICONE PROFILO STATI ════ */
.profile-icon-partial {
  color: rgba(220,110,30,.9) !important;
  border-color: rgba(220,110,30,.3) !important;
}
.profile-icon-complete {
  color: rgba(0,210,140,.95) !important;
  border-color: rgba(0,210,140,.3) !important;
  box-shadow: 0 0 12px rgba(0,210,140,.2) !important;
}

/* ════ LEGENDA PROFILI ════ */
.profile-legend { display:flex;flex-wrap:wrap;gap:14px;margin-top:10px;padding:7px 14px;background:rgba(4,18,48,.35);border:1px solid rgba(80,180,255,.08);border-radius:10px;width:fit-content; }
.pleg { display:inline-flex;align-items:center;gap:5px;font-size:.67rem;font-weight:600; }
.pleg--base    { color:rgba(220,180,60,.7); }
.pleg--partial { color:rgba(220,110,30,.9); }
.pleg--complete{ color:rgba(0,210,140,.95); }

/* ════ ICONE PROFILO STATI ════ */
.profile-icon-partial  { color:rgba(220,110,30,.9)!important;border-color:rgba(220,110,30,.3)!important; }
.profile-icon-complete { color:rgba(0,210,140,.95)!important;border-color:rgba(0,210,140,.3)!important;box-shadow:0 0 12px rgba(0,210,140,.2)!important; }

/* ════════════════════════════════════════════════════════
   FILTRO SKILL
   ════════════════════════════════════════════════════════ */
.skill-filter-wrap { margin: 20px 0 28px; }

.skill-filter-toggle {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 10px 22px; border-radius: 999px; cursor: pointer;
  background: linear-gradient(135deg, rgba(0,90,220,.22), rgba(0,160,255,.14));
  border: 1px solid rgba(80,180,255,.35);
  color: rgba(170,225,255,.9);
  font-size: .8rem; font-weight: 700; letter-spacing: .07em;
  transition: all .2s;
  box-shadow: 0 0 20px rgba(0,100,255,.06), inset 0 1px 0 rgba(120,200,255,.1);
}
.skill-filter-toggle:hover {
  background: linear-gradient(135deg, rgba(0,90,220,.34), rgba(0,160,255,.26));
  border-color: rgba(80,180,255,.6); color: #b8e8ff;
  box-shadow: 0 6px 22px rgba(0,100,255,.18), inset 0 1px 0 rgba(120,200,255,.15);
  transform: translateY(-1px);
}
#skillFilterArrow { font-size:.62rem; opacity:.55; transition: transform .2s; }

/* Pannello */
.skill-filter-panel {
  overflow: hidden; max-height: 0; opacity: 0; margin-top: 0;
  transition: max-height .38s cubic-bezier(.4,0,.2,1), opacity .28s, margin .28s;
}
.skill-filter-panel--open { max-height: 700px; opacity: 1; margin-top: 14px; }

.skill-filter-inner {
  display: flex; flex-wrap: wrap; gap: 9px;
  padding: 18px 20px;
  background: linear-gradient(135deg, rgba(2,14,42,.88), rgba(3,18,50,.92));
  border: 1px solid rgba(80,180,255,.16);
  border-radius: 18px;
  box-shadow: 0 12px 40px rgba(0,0,0,.4), inset 0 1px 0 rgba(80,180,255,.1);
}

.skill-tag-btn {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 7px 15px; border-radius: 999px; cursor: pointer;
  font-size: .73rem; font-weight: 700; letter-spacing: .04em; white-space: nowrap;
  background: rgba(4,20,55,.7); border: 1px solid rgba(80,180,255,.18);
  color: rgba(160,210,245,.7); transition: all .17s;
}
.skill-tag-btn:hover { transform: translateY(-2px); box-shadow: 0 4px 14px rgba(0,80,200,.15); }
.skill-tag-btn:not(.skill-tag-btn--all) {
  border-color: color-mix(in srgb, var(--tc,#7be4ff) 32%, transparent);
  color: color-mix(in srgb, var(--tc,#7be4ff) 72%, rgba(200,230,255,.7));
}
.skill-tag-btn:not(.skill-tag-btn--all):hover {
  background: color-mix(in srgb, var(--tc,#7be4ff) 14%, rgba(4,18,48,.8));
  border-color: color-mix(in srgb, var(--tc,#7be4ff) 60%, transparent);
  color: var(--tc,#7be4ff);
  box-shadow: 0 4px 16px color-mix(in srgb, var(--tc,#7be4ff) 20%, transparent);
}
.skill-tag-btn--all.skill-tag-btn--active {
  background: rgba(0,110,255,.22); border-color: rgba(80,180,255,.55);
  color: #7dd3fc; box-shadow: 0 0 16px rgba(0,100,255,.14);
}
.skill-tag-btn--active:not(.skill-tag-btn--all) {
  background: color-mix(in srgb, var(--tc,#7be4ff) 18%, rgba(4,18,48,.85));
  border-color: color-mix(in srgb, var(--tc,#7be4ff) 68%, transparent);
  color: var(--tc,#7be4ff);
  box-shadow: 0 0 18px color-mix(in srgb, var(--tc,#7be4ff) 22%, transparent);
}
@media(max-width:768px){
  .skill-filter-inner { gap:7px; padding:14px 15px; }
  .skill-tag-btn { font-size:.69rem; padding:6px 12px; }
}

/* ════════════════════════════════════════════════════════
   MODAL MATITA + PAGINA PERSONALE — VIVACI
   ════════════════════════════════════════════════════════ */

/* Dialogo base */
.profile-modal__dialog,
.edit-modal__dialog {
  background: linear-gradient(150deg,
    rgba(6,24,68,.97) 0%,
    rgba(4,16,50,.98) 50%,
    rgba(5,20,60,.97) 100%) !important;
  border: 1px solid rgba(80,180,255,.25) !important;
  border-top: 2px solid rgba(100,210,255,.45) !important;
  box-shadow:
    0 0 0 1px rgba(80,180,255,.06),
    0 28px 70px rgba(0,0,0,.6),
    0 0 100px rgba(0,80,255,.07),
    inset 0 1px 0 rgba(120,220,255,.2) !important;
}

/* Hero pagina personale */
.profile-hero {
  background: linear-gradient(135deg,
    rgba(0,80,200,.2) 0%, rgba(0,50,150,.1) 100%) !important;
  border-bottom: 1px solid rgba(80,180,255,.16) !important;
}
.profile-hero__kicker { color: rgba(100,200,255,.65) !important; letter-spacing:.2em; }
.profile-hero__name   { color: #eef8ff !important; text-shadow: 0 0 40px rgba(80,180,255,.2); }
.profile-hero__role   { color: rgba(175,215,250,.8) !important; }
.profile-hero__location { color: rgba(100,165,220,.5) !important; }

/* Bio */
.profile-bio-box {
  background: rgba(0,40,110,.3) !important;
  border: 1px solid rgba(80,180,255,.18) !important;
  border-left: 3px solid rgba(80,180,255,.5) !important;
  border-radius: 12px !important;
}
.profile-bio-box p { color: rgba(210,235,255,.88) !important; line-height: 1.8; }
.profile-section-label { color: rgba(100,190,255,.55) !important; }

/* Link pill */
.profile-link-pill {
  background: rgba(0,50,130,.38) !important;
  border: 1px solid rgba(80,180,255,.24) !important;
  color: rgba(175,220,255,.82) !important;
}
.profile-link-pill:hover {
  background: rgba(0,80,190,.48) !important;
  border-color: rgba(80,180,255,.5) !important;
  color: #a8dfff !important;
  box-shadow: 0 4px 16px rgba(0,100,255,.14) !important;
}

/* Header matita */
.edit-modal__header {
  background: linear-gradient(180deg, rgba(0,60,180,.18) 0%, transparent 100%) !important;
  border-bottom: 1px solid rgba(80,180,255,.14) !important;
  padding: 22px 26px 18px !important;
}
.edit-modal__name { color: #eef8ff !important; font-size: 1.05rem !important; }
.edit-modal__role-label { color: rgba(150,200,240,.55) !important; }
.edit-modal__status {
  background: rgba(0,80,180,.1) !important;
  border-color: rgba(80,180,255,.2) !important;
  color: rgba(140,195,240,.55) !important;
}
.edit-modal__status--active {
  background: rgba(0,200,130,.1) !important;
  border-color: rgba(0,200,130,.28) !important;
  color: #4dffd6 !important;
}

/* Campi input */
.edit-field__input-wrap {
  background: rgba(0,28,78,.6) !important;
  border: 1px solid rgba(80,180,255,.2) !important;
  border-radius: 10px !important;
}
.edit-field__input-wrap:focus-within {
  border-color: rgba(80,180,255,.5) !important;
  box-shadow: 0 0 0 3px rgba(0,100,255,.09), 0 0 20px rgba(0,80,255,.07) !important;
}
.edit-field__input-wrap input {
  background: transparent !important;
  color: #cce4ff !important;
}
.edit-field__input-wrap input::placeholder { color: rgba(80,150,215,.35) !important; }
.edit-field__prefix {
  color: rgba(100,180,255,.5) !important;
  border-right-color: rgba(80,180,255,.12) !important;
}
.edit-field textarea {
  background: rgba(0,28,78,.6) !important;
  border: 1px solid rgba(80,180,255,.2) !important;
  color: #cce4ff !important;
}
.edit-field textarea:focus {
  border-color: rgba(80,180,255,.5) !important;
  box-shadow: 0 0 0 3px rgba(0,100,255,.09) !important;
}
.edit-field textarea::placeholder { color: rgba(80,150,215,.35) !important; }
.edit-field label { color: rgba(155,205,245,.62) !important; font-size: .69rem !important; }

/* Checkbox */
.edit-checkbox {
  background: rgba(0,28,78,.5) !important;
  border: 1px solid rgba(80,180,255,.14) !important;
  border-radius: 10px !important;
}
.edit-checkbox:hover {
  background: rgba(0,60,160,.28) !important;
  border-color: rgba(80,180,255,.28) !important;
}
.edit-checkbox span { color: rgba(170,215,248,.82) !important; }

/* Submit */
.edit-submit {
  background: linear-gradient(135deg, rgba(0,100,255,.28), rgba(0,180,160,.2)) !important;
  border: 1px solid rgba(0,160,255,.38) !important;
  color: #7dd3fc !important;
  font-size: .86rem !important; font-weight: 800 !important;
}
.edit-submit:hover {
  background: linear-gradient(135deg, rgba(0,100,255,.4), rgba(0,180,160,.3)) !important;
  box-shadow: 0 8px 28px rgba(0,100,255,.22) !important;
  transform: translateY(-1px) !important;
}
.edit-status { color: #4dffd6 !important; font-size: .76rem !important; }

/* ════ HERO CTA — etichette + layout + popover ════ */

.hero__cta { display: flex; flex-wrap: wrap; gap: 12px; align-items: flex-end; }

.hero-cta-group { display: flex; flex-direction: column; gap: 5px; }

.hero-cta-label {
  font-size: .7rem; font-weight: 700; letter-spacing: .09em;
  text-transform: uppercase; color: rgba(160,220,255,.6);
  padding-left: 4px; align-self: flex-start; white-space: nowrap;
  min-height: 1.6em; display: flex; align-items: flex-end;
}

.hero-cta-row { display: flex; align-items: center; gap: 8px; position: relative; }

/* Bottone ⓘ */
.hero-info-wrap { position: relative; flex-shrink: 0; }
.hero-info-btn {
  width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0;
  background: rgba(80,180,255,.1); border: 1px solid rgba(80,180,255,.28);
  color: rgba(120,200,255,.75); font-size: .82rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .18s, color .18s;
}
.hero-info-btn:hover { background: rgba(80,180,255,.22); color: #a8dfff; }

/* Popover */
.hero-popover {
  display: none;
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  left: auto;
  width: 270px;
  background: rgba(3,14,40,.98);
  border: 1px solid rgba(80,180,255,.28);
  border-top: 2px solid rgba(100,200,255,.55);
  border-radius: 14px;
  padding: 15px 17px;
  box-shadow: 0 20px 50px rgba(0,0,0,.6), 0 0 0 1px rgba(80,180,255,.06);
  z-index: 9999;
}
.hero-popover--open { display: block; animation: popIn .18s ease; }
@keyframes popIn {
  from { opacity:0; transform:translateY(8px); }
  to   { opacity:1; transform:translateY(0); }
}
.hero-popover__title {
  font-size: .72rem; font-weight: 800; letter-spacing: .13em;
  text-transform: uppercase; color: #7dd3fc; margin-bottom: 6px;
}
.hero-popover__desc {
  font-size: .73rem; color: rgba(175,215,248,.6);
  line-height: 1.55; margin-bottom: 9px;
}
.hero-popover__list { list-style: none; display: flex; flex-direction: column; gap: 4px; }
.hero-popover__list li { font-size: .71rem; color: rgba(155,210,245,.78); line-height: 1.4; }

/* Mobile: bottoni full-width, popover centrato */
@media (max-width: 640px) {
  .hero__cta { flex-direction: column; gap: 10px; width: 100%; }
  .hero-cta-group { width: 100%; }
  .hero-cta-row { width: 100%; }
  .btn-electric { width: 100% !important; min-height: 50px !important; }
  .btn-amici    { width: 100% !important; min-height: 50px !important; padding: 0 20px !important; }
  .hero-popover {
    position: fixed;
    bottom: auto;
    top: 50%;
    left: 50%;
    right: auto;
    transform: translate(-50%, -50%);
    width: calc(100vw - 32px);
    max-width: 340px;
  }
  .hero-popover--open {
    animation: popInCenter .2s ease;
  }
  @keyframes popInCenter {
    from { opacity:0; transform:translate(-50%,-50%) scale(.95); }
    to   { opacity:1; transform:translate(-50%,-50%) scale(1); }
  }
}

/* ════ FIX MOBILE CTA — etichette e bottoni ════ */
@media (max-width: 640px) {

  /* Contenitore: colonna, larghezza piena */
  .hero__cta {
    flex-direction: column !important;
    align-items: stretch !important;
    width: 100% !important;
    gap: 14px !important;
  }

  /* Ogni gruppo occupa tutta la larghezza */
  .hero-cta-group {
    width: 100% !important;
  }

  /* Etichetta: va a capo, non straborda */
  .hero-cta-label {
    white-space: normal !important;
    font-size: .75rem !important;
    line-height: 1.3 !important;
    margin-bottom: 2px !important;
  }

  /* Riga bottone + ⓘ: bottone prende tutto lo spazio */
  .hero-cta-row {
    width: 100% !important;
  }

  /* Bottone blu: larghezza piena */
  .btn-electric {
    width: 100% !important;
    flex: 1 !important;
    min-height: 50px !important;
    box-sizing: border-box !important;
  }

  /* Bottone verde: larghezza piena, testo va a capo */
  .btn-amici {
    flex: 1 !important;
    width: 100% !important;
    min-height: 50px !important;
    white-space: normal !important;
    text-align: center !important;
    padding: 12px 16px !important;
    box-sizing: border-box !important;
  }

  /* Popover: centrato a schermo, non fuori viewport */
  .hero-popover {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    right: auto !important;
    bottom: auto !important;
    transform: translate(-50%, -50%) !important;
    width: calc(100vw - 32px) !important;
    max-width: 340px !important;
    z-index: 9999 !important;
  }
  .hero-popover--open {
    display: block !important;
    animation: popCenter .2s ease !important;
  }
  @keyframes popCenter {
    from { opacity:0; transform:translate(-50%,-50%) scale(.95); }
    to   { opacity:1; transform:translate(-50%,-50%) scale(1); }
  }
}


/* ════════════════════════════════════════════════════════
   PATCH 2026-03-30 — micro-bio, CTA mobile, popover desktop
   ════════════════════════════════════════════════════════ */

.member-role {
  padding-bottom: 156px;
}

.member-bio-snippet {
  position: absolute;
  left: 20px;
  right: 20px;
  bottom: 96px;
  margin: 0;
  font-size: .76rem;
  font-style: italic;
  line-height: 1.45;
  color: rgba(210,235,255,.78);
  text-align: center;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: calc(.76rem * 1.45 * 2);
}

.member-card .member-location {
  bottom: 58px;
}

.member-links {
  bottom: 14px;
}

@media (max-width: 768px) {
  .member-role {
    padding-bottom: 170px;
  }

  .member-bio-snippet {
    left: 14px;
    right: 14px;
    bottom: 94px;
    font-size: .73rem;
    line-height: 1.42;
    color: rgba(210,235,255,.82);
  }

  .member-card .member-location {
    bottom: 58px;
    padding: 0 14px;
  }
}

@media (min-width: 641px) {
  .hero-popover__list,
  .hero-popover__list li {
    text-align: left !important;
    align-items: flex-start;
    justify-content: flex-start;
  }
}

@media (max-width: 640px) {
  .btn-electric,
  .btn-amici {
    width: calc(100% - 36px) !important;
  }

  .btn-eventi {
    width: calc(100% - 36px) !important;
    min-height: 50px !important;
    padding: 12px 16px !important;
    box-sizing: border-box !important;
    align-self: flex-start !important;
    margin-right: auto !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .btn-amici::before {
    animation: amiciSweep 2.6s linear infinite !important;
    opacity: .9 !important;
  }

  .btn-eventi::before {
    animation: eventiSweep 2.8s linear infinite !important;
    opacity: .9 !important;
  }
}

/* ════════════════════════════════════════════════════════
   MOBILE ANIMATIONS — effetto entrata wow
   ════════════════════════════════════════════════════════ */

@keyframes cardEnterMobile {
  0%   { opacity: 0; transform: translateY(44px) scale(.93); filter: blur(5px); }
  55%  { opacity: 1; transform: translateY(-5px) scale(1.02); filter: blur(0); }
  100% { opacity: 1; transform: translateY(0)    scale(1);    filter: blur(0); }
}

@keyframes cardGlowPulse {
  0%, 100% { box-shadow: 0 0 0 1px rgba(124,243,255,.04) inset, 0 0 22px rgba(124,243,255,.07), var(--r-shadow); }
  50%       { box-shadow: 0 0 0 1px rgba(124,243,255,.16) inset, 0 0 42px rgba(124,243,255,.22), var(--r-shadow); }
}

@media (max-width: 768px) {
  /* Stato iniziale card mobile */
  .member-card {
    opacity: 0;
    transform: translateY(36px) scale(.95);
    filter: blur(3px);
    transition:
      opacity  .55s ease,
      transform .55s cubic-bezier(.22,.68,0,1.22),
      filter   .4s  ease;
  }
  .member-card.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
    filter: blur(0);
    animation: cardGlowPulse 3s ease-in-out 0.6s 2;
  }
  /* Stagger: coppie per griglia 2 col */
  .member-card:nth-child(odd)  { transition-delay: .00s; }
  .member-card:nth-child(even) { transition-delay: .10s; }
}

@media (prefers-reduced-motion: reduce) {
  .member-card, .member-card.is-visible {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    transition: none !important;
  }
}

/* ── Toggle lingua mobile (hamburger menu) ── */
.lang-toggle--mobile {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  margin-top: 10px;
  width: 100%;
  padding: 9px 16px;
  border-radius: 8px;
  background: rgba(123,228,255,.08);
  border: 1px solid rgba(123,228,255,.22);
  color: #a8eeff;
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  cursor: pointer;
  transition: background .18s, border-color .18s;
}
.lang-toggle--mobile:hover {
  background: rgba(123,228,255,.15);
  border-color: rgba(123,228,255,.40);
}
.lang-toggle--mobile .lang-sep {
  opacity: .45;
  font-weight: 400;
}

/* Nascondi toggle lingua mobile su desktop */
@media (min-width: 769px) {
  .lang-toggle--mobile { display: none !important; }
}


/* ── Hamburger mobile: dropdown compatto proporzionato ── */
@media (max-width: 768px) {
  .nav-mobile-panel {
    width: 220px !important;
    min-width: 0 !important;
    right: 0 !important;
    left: auto !important;
    padding: 8px !important;
    border-radius: 16px !important;
  }
  .nav-mobile-panel a {
    padding: 10px 16px !important;
    font-size: .95rem !important;
    text-align: left !important;
    border-radius: 10px !important;
  }
  /* Contatti: nel pannello mobile stesso stile degli altri link */
  .nav-mobile-panel a.nav-cta {
    background: transparent !important;
    color: var(--text, rgba(237,247,255,.85)) !important;
    border-radius: 10px !important;
    padding: 10px 16px !important;
    font-weight: 600 !important;
  }
  .nav-mobile-panel a.nav-cta:hover {
    background: rgba(123,228,255,.09) !important;
    color: #7dd3fc !important;
  }
  /* Bottone lingua: compatto */
  .nav-mobile-panel .lang-toggle--mobile {
    display: flex !important;
    margin-top: 4px !important;
    padding: 8px 16px !important;
    font-size: .8rem !important;
  }
}

/* ── Cookie banner ── */
#cookie-banner {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999;
  background: rgba(4,16,38,.92); backdrop-filter: blur(18px);
  border-top: 1px solid rgba(120,210,255,.14);
  padding: 14px 24px;
  display: flex; align-items: center; justify-content: center;
  gap: 16px; flex-wrap: wrap;
  transform: translateY(100%);
  transition: transform .4s cubic-bezier(.22,.68,0,1.2);
}
#cookie-banner.visible { transform: translateY(0); }
#cookie-banner p { font-size: .8rem; color: rgba(237,247,255,.72); margin: 0; flex: 1; min-width: 200px; }
#cookie-banner a { color: #a8eeff; text-decoration: none; }
#cookie-accept {
  padding: 7px 20px; border-radius: 999px;
  background: rgba(123,228,255,.12); border: 1px solid rgba(123,228,255,.28);
  color: #a8eeff; font-size: .8rem; font-weight: 600; cursor: pointer;
  transition: background .2s;
}
#cookie-accept:hover { background: rgba(123,228,255,.22); }



/* ══════════════════════════════════════════
   TAB NEWSLETTER — attaccato ai contatori
══════════════════════════════════════════ */

/* Il blocco stats deve permettere overflow */
.hero__stats {
  overflow: visible !important;
  position: relative;
}

/* Container tab — si posiziona subito dopo "In crescita" */

/* ── LINGUETTA ── */

/* ── PANNELLO — si apre verso il basso ── */
/* Bordo dorato in cima */

/* Stato aperto */


/* ══════════════════════════════════════════
   NEWSLETTER — TAB DESKTOP + PULSANTE MOBILE
══════════════════════════════════════════ */

/* ── TAB DESKTOP (linguetta verticale) ── */
.nl-tab {
  position: relative;
  flex-shrink: 0;
  display: flex;
  align-items: stretch;
  border-left: 1px solid rgba(255,215,0,.18);
}
.nl-tab__trigger {
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  background: rgba(255,210,20,.11);
  border: none;
  padding: 14px 10px;
  cursor: pointer;
  color: rgba(255,220,55,.85);
  font-family: inherit;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  white-space: nowrap;
  border-radius: 0 8px 8px 0;
  transition: background .2s, color .2s;
}
.nl-tab__trigger:hover,
.nl-tab--open .nl-tab__trigger {
  background: rgba(255,210,20,.22);
  color: rgba(255,230,70,1);
}
.nl-tab__panel {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  width: 210px;
  background: rgba(8,22,52,.92);
  border: 1px solid rgba(255,215,0,.28);
  border-radius: 12px 0 12px 12px;
  backdrop-filter: blur(18px);
  padding: 14px 16px 14px;
  z-index: 50;
  box-shadow: 0 8px 28px rgba(0,0,0,.45);
}
.nl-tab--open .nl-tab__panel {
  display: block;
  animation: nlPanelIn .22s ease;
}
@keyframes nlPanelIn {
  from { opacity:0; transform:translateY(-4px); }
  to   { opacity:1; transform:translateY(0); }
}
.nl-tab__kicker {
  font-size: .58rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,215,0,.55); margin-bottom: 7px;
}
.nl-tab__body {
  font-size: .72rem; color: rgba(237,247,255,.72);
  line-height: 1.5; margin-bottom: 10px;
}
.nl-tab__link {
  display: block; font-size: .63rem; font-weight: 700;
  color: rgba(255,215,0,.88); text-decoration: none;
  border-top: 1px solid rgba(255,215,0,.15);
  padding-top: 8px; white-space: nowrap;
}
.nl-tab__link:hover { color: #ffe84d; text-decoration: underline; }

/* ── PULSANTE MOBILE — nascosto su desktop ── */
.nl-mob, .nl-mob__panel { display: none; }

@media (max-width: 700px) {

  /* Nascondi tab desktop */
  .nl-tab { display: none !important; }

  /* Contatori su mobile: wrap + full width */
  .hero__stats {
    flex-wrap: wrap !important;
    overflow: visible !important;
  }
  .hero__stat {
    flex: 1 1 18% !important;
    min-width: 50px !important;
  }

  /* Pulsante newsletter mobile */
  .nl-mob {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    margin-top: 10px;
    padding: 12px 16px;
    background: rgba(255,210,20,.07);
    border: 1px solid rgba(255,215,0,.26);
    border-radius: 12px;
    cursor: pointer;
    font-family: inherit;
    text-align: left;
    transition: background .2s;
    backdrop-filter: blur(10px);
  }
  .nl-mob:hover,
  .nl-mob--open {
    background: rgba(255,210,20,.14);
    border-color: rgba(255,215,0,.42);
  }
  .nl-mob--open {
    border-radius: 12px 12px 0 0;
    border-bottom-color: transparent;
  }
  .nl-mob__left {
    display: flex; align-items: center; gap: 11px;
  }
  .nl-mob__icon {
    font-size: 1.2rem; flex-shrink: 0;
  }
  .nl-mob__title {
    display: block; font-size: .82rem; font-weight: 700;
    color: rgba(255,222,50,.95);
  }
  .nl-mob__sub {
    display: block; font-size: .57rem; font-weight: 700;
    letter-spacing: .08em; text-transform: uppercase;
    color: rgba(255,215,0,.45); margin-top: 1px;
  }
  .nl-mob__arr {
    font-size: 1.1rem; color: rgba(255,215,0,.5);
    transition: transform .25s cubic-bezier(.22,1,.36,1);
    flex-shrink: 0;
  }
  .nl-mob--open .nl-mob__arr { transform: rotate(90deg); }

  /* Pannello mobile */
  .nl-mob__panel {
    display: block;
    max-height: 0; overflow: hidden;
    opacity: 0; padding: 0 16px;
    background: rgba(6,18,46,.78);
    border: 1px solid rgba(255,215,0,.2);
    border-top: none;
    border-radius: 0 0 12px 12px;
    backdrop-filter: blur(14px);
    transition:
      max-height .35s cubic-bezier(.22,1,.36,1),
      opacity .25s ease,
      padding .3s;
  }
  .nl-mob__panel--open {
    max-height: 150px; opacity: 1;
    padding: 13px 16px 15px;
  }
  .nl-mob__body {
    font-size: .73rem; color: rgba(237,247,255,.7);
    line-height: 1.5; margin-bottom: 10px;
  }
  .nl-mob__link {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: .67rem; font-weight: 700;
    color: rgba(255,218,50,.9); text-decoration: none;
    border: 1px solid rgba(255,215,0,.22);
    border-radius: 999px; padding: 5px 13px;
    background: rgba(255,215,0,.05);
    white-space: nowrap;
    transition: background .2s, color .2s;
  }
  .nl-mob__link:hover {
    background: rgba(255,215,0,.13); color: #ffe84d;
  }
}

/* ══ FOOTER UNIFICATO ══ */
.site-footer {
  padding: 26px 0 32px;
  border-top: 1px solid rgba(120,210,255,.1);
  background: rgba(1,7,17,.8);
  backdrop-filter: blur(12px);
}
.footer-grid {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.footer-copy {
  font-size: .75rem;
  color: rgba(237,247,255,.45);
}
.footer-grid nav {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 18px;
  align-items: center;
}
.footer-grid nav a {
  font-size: .75rem;
  color: rgba(237,247,255,.45);
  text-decoration: none;
  transition: color .2s;
}
.footer-grid nav a:hover { color: rgba(168,238,255,.85); }

@media (max-width: 600px) {
  .footer-grid {
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 10px;
  }
  .footer-grid nav {
    justify-content: center;
    gap: 6px 14px;
  }
}
