@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Cormorant+Garamond:wght@300;400;500;600&family=Source+Sans+3:wght@300;400;600&display=swap');

*{margin:0;padding:0;box-sizing:border-box}
:root{
  --oro:#B8965A;--oro-light:#D4B07A;--oro-pale:rgba(184,150,90,0.12);
  --verde:#157d8a;--verde-dark:#0f5f6b;--verde-light:#1a9aaa;--verde-pale:rgba(21,125,138,0.12);
  --nero:#0A0907;--nero-mid:#141210;--nero-card:#1C1916;
  --avorio:#F7F3EC;
  --testo:rgba(247,243,236,0.92);--testo-mid:rgba(247,243,236,0.65);--testo-dim:rgba(247,243,236,0.38);
  --linea:rgba(184,150,90,0.18);--linea-v:rgba(21,125,138,0.22);
}
html{scroll-behavior:smooth}
body{background:var(--nero);color:var(--testo);font-family:'Source Sans 3',sans-serif;overflow-x:hidden}

/* ANIMAZIONI */
.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}.reveal-delay-2{transition-delay:0.2s}.reveal-delay-3{transition-delay:0.3s}

/* NAV */
nav{position:sticky;top:0;z-index:100;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:1.5rem;padding:0 3rem;height:64px;background:rgba(10,9,7,0.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--linea)}
nav.scrolled{box-shadow:0 4px 40px rgba(0,0,0,0.5)}
.nav-logo{display:flex;align-items:center;gap:0.75rem;text-decoration:none}
.nav-logo img{height:36px;width:auto}
.nav-logo-fb{font-family:'Playfair Display',serif;font-size:0.82rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--oro);line-height:1.2;display:none}
.nav-links{display:flex;justify-content:center;gap:1.4rem;list-style:none}
.nav-links a{font-size:0.7rem;letter-spacing:0.11em;text-transform:uppercase;color:var(--testo-dim);text-decoration:none;transition:color 0.25s;position:relative}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--verde);transition:width 0.25s}
.nav-links a:hover{color:var(--testo)}.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--avorio)}
.nav-cta{font-size:0.7rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.4rem 1.1rem;background:var(--verde);color:#fff;text-decoration:none;transition:background 0.25s,transform 0.2s;white-space:nowrap}
.nav-cta:hover{background:var(--verde-dark);transform:translateY(-1px)}

/* NAV TOP ROW (mobile only, definito nel media query) */
.nav-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.2rem;
  height: 52px;
  width: 100%;
  flex-shrink: 0;
}

.nav-logo {
  flex-shrink: 0;  /* ← aggiunge questo */
}
/* PAGE HERO */
.page-hero{padding:5rem 4rem 3.5rem;border-bottom:1px solid var(--linea);position:relative;overflow:hidden;background:var(--nero-mid)}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0.08}
.page-hero-content{position:relative;z-index:1}
.page-breadcrumb{font-family:'Cormorant Garamond',serif;font-size:0.72rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--testo-dim);margin-bottom:1rem}
.page-breadcrumb a{color:var(--verde-light);text-decoration:none}
.page-breadcrumb a:hover{color:var(--oro)}
.page-breadcrumb span{margin:0 0.5rem;opacity:0.4}
.page-title{font-family:'Playfair Display',serif;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:700;line-height:1.0;color:var(--avorio)}
.page-title em{font-style:italic;color:var(--oro)}
.page-subtitle{font-size:1rem;color:var(--testo-mid);margin-top:0.75rem;line-height:1.7}

/* SEZIONI */
section{padding:4.5rem 4rem}
.s-eye{font-family:'Cormorant Garamond',serif;font-size:0.72rem;letter-spacing:0.38em;text-transform:uppercase;color:var(--verde-light);margin-bottom:0.6rem;display:flex;align-items:center;gap:0.75rem}
.s-eye::before{content:'';display:block;width:1.5rem;height:1px;background:var(--verde)}
.s-title{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,3vw,2.2rem);font-weight:700;line-height:1.1;color:var(--avorio);margin-bottom:1.8rem}

/* PULSANTI */
.btn-oro{font-family:'Source Sans 3',sans-serif;font-size:0.8rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.8rem 1.8rem;background:var(--oro);color:var(--nero);text-decoration:none;font-weight:700;display:inline-block;transition:background 0.25s,transform 0.2s}
.btn-oro:hover{background:var(--oro-light);transform:translateY(-2px)}
.btn-verde{font-family:'Source Sans 3',sans-serif;font-size:0.8rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.8rem 1.8rem;background:var(--verde);color:#fff;text-decoration:none;font-weight:600;display:inline-block;transition:background 0.25s,transform 0.2s;text-align:center}
.btn-verde:hover{background:var(--verde-dark);transform:translateY(-2px)}
.btn-outline{font-family:'Source Sans 3',sans-serif;font-size:0.78rem;letter-spacing:0.1em;text-transform:uppercase;padding:0.7rem 1.4rem;border:1px solid var(--linea);color:var(--testo-mid);text-decoration:none;display:inline-block;transition:all 0.25s}
.btn-outline:hover{border-color:var(--oro);color:var(--oro)}
.btn-paypal{font-family:'Source Sans 3',sans-serif;font-size:0.82rem;letter-spacing:0.06em;text-transform:uppercase;padding:0.9rem 1.5rem;background:#FFC439;color:#003087;text-decoration:none;font-weight:700;text-align:center;display:flex;align-items:center;justify-content:center;gap:0.5rem;transition:filter 0.2s,transform 0.2s}
.btn-paypal:hover{filter:brightness(1.07);transform:translateY(-1px)}

/* TABELLE */
.table-wrap{overflow-x:auto;margin-bottom:2rem}
table{width:100%;border-collapse:collapse;font-size:0.88rem}
thead tr{border-bottom:1px solid var(--oro);color:var(--oro)}
thead th{font-family:'Cormorant Garamond',serif;font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;padding:0.6rem 1rem;text-align:left;font-weight:500}
tbody tr{border-bottom:1px solid var(--linea);transition:background 0.2s}
tbody tr:hover{background:var(--oro-pale)}
tbody td{padding:0.75rem 1rem;color:var(--testo-mid);line-height:1.5}
tbody td:first-child{color:var(--avorio);font-weight:600}
.premio-badge{display:inline-block;font-size:0.7rem;letter-spacing:0.1em;padding:0.15rem 0.5rem;border:1px solid rgba(184,150,90,0.3);color:var(--oro);margin-left:0.5rem;vertical-align:middle}

/* CARD PERSONA */
.person-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.5rem}
.person-card{background:var(--nero-card);border:1px solid var(--linea);padding:1.8rem 1.5rem;text-align:center;transition:border-color 0.3s,transform 0.3s}
.person-card:hover{border-color:var(--oro);transform:translateY(-4px)}
.person-card.presidente{border-color:rgba(184,150,90,0.4);background:var(--oro-pale)}
.person-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;object-position:top;margin:0 auto 1rem;display:block;border:2px solid var(--linea);background:var(--nero)}
.person-photo.oro-border{border-color:rgba(184,150,90,0.5)}
.person-photo-ph{width:100px;height:100px;border-radius:50%;background:var(--oro-pale);border:2px solid var(--linea);margin:0 auto 1rem;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--oro)}
.person-role{font-family:'Cormorant Garamond',serif;font-size:0.68rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--verde-light);margin-bottom:0.4rem}
.person-role.oro{color:var(--oro)}
.person-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--avorio);line-height:1.2;margin-bottom:0.3rem}
.person-detail{font-size:0.78rem;color:var(--testo-dim);line-height:1.5}
.person-links{display:flex;justify-content:center;gap:0.5rem;margin-top:0.8rem;flex-wrap:wrap}
.person-link{font-size:0.65rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--verde-light);text-decoration:none;border-bottom:1px solid rgba(21,125,138,0.3);padding-bottom:0.1rem;transition:color 0.2s}
.person-link:hover{color:var(--oro)}

/* SPONSOR CARD */
.sponsor-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem}
.sponsor-card{background:var(--nero-card);border:1px solid var(--linea);padding:2rem;transition:border-color 0.3s,transform 0.3s}
.sponsor-card:hover{border-color:var(--oro);transform:translateY(-3px)}
.sponsor-logo{width:120px;height:60px;object-fit:contain;margin-bottom:1.2rem;filter:brightness(0.9) grayscale(20%);transition:filter 0.3s}
.sponsor-card:hover .sponsor-logo{filter:brightness(1) grayscale(0%)}
.sponsor-name{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--avorio);margin-bottom:0.5rem}
.sponsor-desc{font-size:0.82rem;line-height:1.7;color:var(--testo-dim);margin-bottom:1rem}
.sponsor-link{font-size:0.72rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--verde-light);text-decoration:none;border-bottom:1px solid rgba(21,125,138,0.3);padding-bottom:0.1rem}
.sponsor-link:hover{color:var(--oro)}

/* MEMBERSHIP CARD */
.membership-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.5rem}
.membership-card{background:var(--nero-card);border:1px solid var(--linea);padding:2rem;position:relative;overflow:hidden}
.membership-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px}
.membership-card.green::before{background:var(--verde)}
.membership-card.blue::before{background:#1a6aaa}
.membership-card.orange::before{background:#c07030}
.membership-card.bronze::before{background:#a07040}
.membership-card.silver::before{background:#909090}
.membership-card.gold::before{background:var(--oro)}
.membership-type{font-family:'Cormorant Garamond',serif;font-size:0.7rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--testo-dim);margin-bottom:0.4rem}
.membership-name{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--avorio);margin-bottom:0.3rem}
.membership-price{font-size:1rem;color:var(--oro);font-weight:600;margin-bottom:1.2rem}
.membership-features{list-style:none;margin-bottom:1.5rem}
.membership-features li{font-size:0.8rem;color:var(--testo-dim);padding:0.25rem 0;border-bottom:1px solid rgba(184,150,90,0.08);display:flex;gap:0.5rem;align-items:baseline}
.membership-features li::before{content:'·';color:var(--oro);flex-shrink:0}

/* STORIA TESTO */
.story-layout{display:grid;grid-template-columns:1fr 340px;gap:5rem;align-items:start}
.story-text p{font-size:1rem;line-height:1.95;color:var(--testo-mid);margin-bottom:1.4rem}
.story-text p strong{color:var(--avorio)}
.story-photo{position:sticky;top:5rem}
.story-photo img{width:100%;display:block;border:1px solid var(--linea)}
.story-photo-cap{font-family:'Cormorant Garamond',serif;font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--testo-dim);text-align:center;margin-top:0.6rem}
.story-author{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--linea);font-family:'Cormorant Garamond',serif;font-size:0.82rem;letter-spacing:0.12em;color:var(--oro);font-style:italic}

/* FOOTER */
.site-footer{padding:2rem 4rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--linea)}
.foot-copy{font-size:0.72rem;color:var(--testo-dim)}
.foot-links{display:flex;gap:1.2rem}
.foot-links a{font-size:0.7rem;letter-spacing:0.08em;text-transform:uppercase;color:var(--testo-dim);text-decoration:none;transition:color 0.2s}
.foot-links a:hover{color:var(--oro)}
.foot-logo img{height:28px;opacity:0.4;transition:opacity 0.3s}.foot-logo img:hover{opacity:0.7}

/* ISCRIZIONE */
.iscrizione-section{background:var(--nero-mid);border-bottom:1px solid var(--linea)}
.iscr-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:start}
.steps{display:flex;flex-direction:column;gap:1rem;margin-top:0.5rem}
.step-row{display:flex;gap:1.2rem;align-items:flex-start;padding:1rem;border:1px solid transparent;transition:border-color 0.3s,background 0.3s}
.step-row:hover{border-color:var(--linea);background:var(--oro-pale)}
.step-n{font-family:'Playfair Display',serif;font-size:1.6rem;font-weight:700;color:rgba(184,150,90,0.3);line-height:1;min-width:1.8rem}
.step-t{font-size:0.92rem;line-height:1.7;color:var(--testo-mid);padding-top:0.2rem}
.step-t strong{color:var(--avorio)}
.iscr-box{background:var(--nero-card);border:1px solid var(--linea);padding:2.2rem}
.iscr-info p{font-size:0.9rem;line-height:1.78;color:var(--testo-mid);margin-bottom:0.9rem}
.iscr-info a{color:var(--verde-light);text-decoration:none;transition:color 0.2s}
.iscr-info a:hover{color:var(--oro)}
.iscr-btns{display:flex;flex-direction:column;gap:0.75rem;margin-top:1.8rem}
.btn-div{font-family:'Cormorant Garamond',serif;font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;text-align:center;color:var(--testo-dim);padding:0.2rem 0;display:flex;align-items:center;gap:0.75rem}
.btn-div::before,.btn-div::after{content:'';flex:1;height:1px;background:var(--linea)}


/* =====================
   RESPONSIVE MOBILE
   ===================== */
@media (max-width: 768px) {

  /* NAV: due righe */
  nav {
    display: flex;
    flex-direction: column;
    height: auto;
    padding: 0;
    gap: 0;
  }
  .nav-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 1.2rem;
    height: 52px;
    width: 100%;
    flex-shrink: 0;
  }
  .nav-links {
    display: flex !important;
    justify-content: flex-start;
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    width: 100%;
    border-top: 1px solid var(--linea);
    padding: 0 0.5rem;
  }
  .nav-links::-webkit-scrollbar { display: none; }
  .nav-links li a {
    display: block;
    padding: 0.65rem 0.85rem;
    white-space: nowrap;
    font-size: 0.66rem;
  }
  .nav-cta {
    display: block !important;
    font-size: 0.66rem;
    padding: 0.32rem 0.85rem;
    flex-shrink: 0;
  }

  /* Hero: logo nel flusso, sopra il testo */
  .hero { padding: 0 1.5rem 4rem; min-height: 100svh; justify-content: flex-end; }
  .hero-logo {
    position: relative;
    top: auto; right: auto;
    transform: none;
    text-align: center;
    margin-bottom: 2rem;
    animation: slideInRightMobile 1s cubic-bezier(0.22,1,0.36,1) 0.4s both;
  }
  @keyframes slideInRightMobile {
    from { opacity: 0; transform: translateX(40px); }
    to   { opacity: 1; transform: translateX(0); }
  }
  .hero-logo img { width: 140px; }
  .hero-content { max-width: 100%; }
  .hero-num { font-size: 50vw; right: -1rem; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-actions a { text-align: center; }

  /* Stats bar */
  .stats-bar { grid-template-columns: repeat(2,1fr); }
  .stat-item { padding: 1.2rem 1rem; }

  /* Sezioni */
  section { padding: 3.5rem 1.5rem; }

  /* Griglie → 1 colonna */
  .premio-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .cat-grid    { grid-template-columns: 1fr; }
  .vgrid       { grid-template-columns: 1fr; gap: 2rem; }
  .iscr-grid   { grid-template-columns: 1fr; gap: 2.5rem; }
  .cg-grid     { grid-template-columns: 1fr; gap: 2rem; }
  .dir-row     { grid-template-columns: 1fr; gap: 1rem; margin-bottom: 2.5rem; }

  /* Albo presidenti */
  .albo-grid { grid-template-columns: repeat(3,1fr); gap: 1rem; }
  .albo-img, .albo-ph { width: 56px; height: 56px; }

  /* Pulsanti */
  .btn-outline { display: block; text-align: center; }

  /* Footer */
  footer { padding: 1.5rem; flex-direction: column; gap: 1rem; text-align: center; }
}

@media (max-width: 480px) {
  .albo-grid { grid-template-columns: repeat(2,1fr); }
  .hero-logo img { width: 110px; }
}
