/* ===========================================================================
   ATARASHI GOES TO SICILY — v2
   Design system condiviso. Token estratti 1:1 dal sito attuale.
   =========================================================================== */

/* ---- Font self-hosted (Space Grotesk / Space Mono). Monument Extended:
        caricato via cdnfonts nel <head> di ogni pagina. ---- */
@font-face{font-family:"Space Grotesk";font-weight:300;font-display:swap;src:url(../fonts/space-grotesk-v22-latin-300.woff2) format("woff2")}
@font-face{font-family:"Space Grotesk";font-weight:400;font-display:swap;src:url(../fonts/space-grotesk-v22-latin-regular.woff2) format("woff2")}
@font-face{font-family:"Space Grotesk";font-weight:500;font-display:swap;src:url(../fonts/space-grotesk-v22-latin-500.woff2) format("woff2")}
@font-face{font-family:"Space Grotesk";font-weight:600;font-display:swap;src:url(../fonts/space-grotesk-v22-latin-600.woff2) format("woff2")}
@font-face{font-family:"Space Grotesk";font-weight:700;font-display:swap;src:url(../fonts/space-grotesk-v22-latin-700.woff2) format("woff2")}
@font-face{font-family:"Space Mono";font-weight:400;font-display:swap;src:url(../fonts/space-mono-v17-latin-regular.woff2) format("woff2")}
@font-face{font-family:"Space Mono";font-weight:700;font-display:swap;src:url(../fonts/space-mono-v17-latin-700.woff2) format("woff2")}

:root{
  --bg:#0a0a0a;
  --bg-card:#121212;
  --bg-card-2:#171717;
  --line:rgba(241,238,233,.10);
  --line-strong:rgba(241,238,233,.18);
  --text:#f1eee9;
  --muted:#988f81;
  --orange:#f47825;
  --orange-ink:#0a0a0a;
  --green:#3ddc84;
  --font-display:"Monument Extended","Space Grotesk",sans-serif;
  --font-body:"Space Grotesk",sans-serif;
  --font-mono:"Space Mono",monospace;
  --maxw:1180px;
  --radius:14px;
  --header-h:68px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:var(--font-body);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* texture noise globale (identica all'attuale) */
body::before{
  content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.03;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px}

/* ---- Tipografia ---- */
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.02;letter-spacing:-.01em;margin:0;text-transform:uppercase}
h1{font-size:clamp(2.6rem,8vw,6rem)}
h2{font-size:clamp(2rem,5.2vw,3.6rem)}
h3{font-size:clamp(1.3rem,2.6vw,1.9rem)}
p{margin:0 0 1rem}
.label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--orange)}
.label.muted{color:var(--muted)}
.lead{font-size:clamp(1rem,1.6vw,1.18rem);color:var(--text)}
.muted{color:var(--muted)}
.center{text-align:center}

/* ---- Layout ---- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px);position:relative;z-index:2}
section{position:relative;z-index:2}
.section{padding:clamp(64px,10vw,120px) 0}
.section-head{max-width:760px;margin:0 auto clamp(34px,5vw,56px);text-align:center}
.section-head .label{display:inline-block;margin-bottom:14px}
.section-head h2{margin-bottom:14px}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* ---- Bottoni ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-family:var(--font-mono);font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  padding:.85em 1.5em;border-radius:999px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s ease,background .2s ease,color .2s ease,border-color .2s ease;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--orange);color:var(--orange-ink);border-color:var(--orange)}
.btn-primary:hover{background:#ff8a3d}
.btn-outline{background:transparent;color:var(--orange);border-color:var(--orange)}
.btn-outline:hover{background:rgba(244,120,37,.12)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line-strong)}
.btn-ghost:hover{border-color:var(--text)}
.btn-green{background:var(--green);color:var(--orange-ink);border-color:var(--green)}
.btn-sm{padding:.55em 1.05em;font-size:.72rem}

/* ---- Header sticky ---- */
.site-header{position:fixed;top:0;left:0;right:0;height:var(--header-h);z-index:50;
  display:flex;align-items:center;
  background:rgba(10,10,10,.72);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.site-header .container{display:flex;align-items:center;gap:18px;width:100%}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand img{height:30px;width:auto}
.brand .when{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;line-height:1.2}
.nav{display:flex;align-items:center;gap:18px;margin-left:auto}
.nav a{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text);opacity:.82;white-space:nowrap;transition:opacity .2s,color .2s}
.nav a:hover,.nav a.active{opacity:1;color:var(--orange)}
.header-tools{display:flex;align-items:center;gap:12px}
/* toggle lingua */
.lang-toggle{display:inline-flex;border:1px solid var(--line-strong);border-radius:999px;overflow:hidden;font-family:var(--font-mono)}
.lang-toggle button{background:transparent;color:var(--muted);border:0;cursor:pointer;
  font-size:.68rem;font-weight:700;letter-spacing:.08em;padding:.42em .7em;transition:background .2s,color .2s}
.lang-toggle button.active{background:var(--orange);color:var(--orange-ink)}
/* hamburger */
.burger{display:none;background:transparent;border:0;cursor:pointer;padding:6px;flex-direction:column;gap:5px}
.burger span{width:24px;height:2px;background:var(--text);transition:transform .25s,opacity .2s}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* mobile nav overlay */
.mobile-nav{position:fixed;inset:var(--header-h) 0 0;z-index:49;background:rgba(8,8,8,.98);
  display:none;flex-direction:column;justify-content:center;gap:6px;padding:30px clamp(18px,6vw,40px)}
.mobile-nav.open{display:flex}
.mobile-nav a{font-family:var(--font-display);text-transform:uppercase;font-size:1.7rem;padding:.35em 0;border-bottom:1px solid var(--line)}
.mobile-nav .btn{margin-top:20px;align-self:flex-start}

@media(max-width:1140px){
  .nav{display:none}
  .burger{display:flex}
  .brand .when{display:none}
}

/* ---- HERO ---- */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;padding-top:var(--header-h)}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.hero-overlay{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(10,10,10,1) 2%,rgba(10,10,10,.45) 45%,rgba(10,10,10,.15) 100%)}
.hero-inner{position:relative;z-index:2;padding:40px clamp(18px,4vw,40px) 70px;max-width:1000px}
.hero .eyebrow{display:flex;gap:14px;align-items:center;justify-content:center;margin-bottom:18px;flex-wrap:wrap}
.hero h1{margin:0 0 6px}
.hero .sub{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text);font-size:clamp(.8rem,1.4vw,1rem)}

/* countdown */
.countdown{display:flex;gap:clamp(10px,3vw,30px);justify-content:center;margin:34px 0 30px}
.countdown .unit{min-width:62px}
.countdown .num{font-family:var(--font-display);font-size:clamp(1.8rem,5vw,3rem);line-height:1;color:var(--text)}
.countdown .lab{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.2em;color:var(--orange);text-transform:uppercase;margin-top:8px}
.countdown .sep{font-family:var(--font-display);font-size:clamp(1.4rem,4vw,2.4rem);color:var(--muted);align-self:flex-start}
.hero-cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:6px}
.hero-note{margin-top:18px;font-size:.8rem;color:var(--muted)}
.hero-note a{color:var(--muted);text-decoration:underline}

/* fact badges */
.facts{display:flex;gap:clamp(16px,4vw,44px);justify-content:center;flex-wrap:wrap;margin-top:48px}
.facts .fact{display:flex;align-items:center;gap:9px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--text)}
.facts .fact .dot{color:var(--orange)}

/* ---- LINEUP ---- */
.lineup-head .badge{display:inline-block}
.headliner{background:linear-gradient(180deg,var(--bg-card),#0d0d0d);border:1px solid var(--line-strong);
  border-radius:var(--radius);padding:clamp(28px,5vw,54px) clamp(20px,4vw,40px);text-align:center;margin-bottom:22px;position:relative;overflow:hidden}
.headliner::after{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 0%,rgba(244,120,37,.16),transparent 60%);pointer-events:none}
.headliner .names{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.8rem,6vw,4rem);line-height:1.0;position:relative}
.headliner .b2b{color:var(--orange);font-size:.5em;display:inline-block;margin:0 .25em;vertical-align:middle}
.headliner .when{font-family:var(--font-mono);letter-spacing:.2em;color:var(--muted);text-transform:uppercase;font-size:.78rem;margin-top:16px;position:relative}

.lineup-names{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.12em .55em;margin-top:clamp(20px,4vw,36px)}
.lineup-names span{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.5rem,4.6vw,2.9rem);line-height:1.12;color:var(--text)}
.lineup-names .sep{color:var(--orange);font-size:.62em}

/* lineup a gerarchia (tier 2 / 1 / 2) */
.lineup-tiers{display:flex;flex-direction:column}
.tier{display:grid;gap:18px}
.tier + .tier{margin-top:clamp(28px,4.5vw,44px)}
.tier-1{grid-template-columns:1fr 1fr}
.tier-3{grid-template-columns:1fr 1fr}
.tier-label{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-align:center;margin:clamp(8px,2vw,16px) 0 14px}
.tier-label:first-child{margin-top:0}
.tier-label b{color:var(--orange);font-weight:700}
.tier-1 .artist .photo{aspect-ratio:3/2}
.tier-1 .artist .name{font-size:clamp(1.3rem,2.4vw,1.75rem)}
.tier-1 .artist .body{padding:18px 19px 20px}
.tier-2{grid-template-columns:1fr;justify-items:center}
.tier-2 .artist{max-width:620px;width:100%}
.tier-2 .artist .photo{aspect-ratio:3/2}
.tier-2 .artist .name{font-size:clamp(1.25rem,2.2vw,1.6rem)}
/* tier 3: square crop box so portrait/landscape sources line up side by side */
.tier-3 .artist .photo{aspect-ratio:1/1;position:relative}
.tier-3 .artist .photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
@media(max-width:720px){
  .tier-1,.tier-3{grid-template-columns:1fr}
}
.lineup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}
.artist{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:border-color .2s,transform .2s}
.artist:hover{border-color:var(--orange);transform:translateY(-3px)}
.artist .photo{aspect-ratio:4/3;background:linear-gradient(135deg,#1c1c1c,#101010);display:flex;align-items:center;justify-content:center}
.artist .photo img{width:100%;height:100%;object-fit:cover}
.artist .photo .ph{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;text-align:center;padding:10px}
.artist .body{padding:16px 17px 18px;flex:1;display:flex;flex-direction:column}
.artist .name{font-family:var(--font-display);text-transform:uppercase;font-size:1.15rem;line-height:1.05}
.artist .bio{font-size:.86rem;color:var(--muted);margin:8px 0 12px;flex:1}
.artist .links{display:flex;gap:14px;align-items:center}
.artist .links a{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:var(--orange)}

/* placeholder content marker */
.todo{display:inline-block;font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--orange);background:rgba(244,120,37,.12);border:1px dashed rgba(244,120,37,.5);border-radius:6px;padding:.18em .55em}

/* ---- Spotify block ---- */
.sound{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(22px,4vw,40px);text-align:center}
.spotify-facade{position:relative;max-width:760px;margin:22px auto 0;aspect-ratio:16/7;border-radius:12px;cursor:pointer;
  background:linear-gradient(135deg,#1e1208,#0c0c0c);border:1px solid rgba(244,120,37,.4);
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.spotify-facade .play{width:64px;height:64px;border-radius:50%;background:var(--orange);color:var(--orange-ink);display:flex;align-items:center;justify-content:center;font-size:24px;transition:transform .2s}
.spotify-facade:hover .play{transform:scale(1.08)}
.spotify-facade .hint{position:absolute;bottom:14px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.spotify-live iframe{border-radius:12px;max-width:760px;margin:22px auto 0;display:block;width:100%}

/* ---- Card grid generico (scorciatoie, partner, hospitality, festival info) ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px}
.card{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:24px 22px;display:flex;flex-direction:column;gap:8px;transition:border-color .2s,transform .2s}
.card:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.card .ic{font-size:1.4rem;color:var(--orange)}
.card h3{font-size:1.15rem}
.card p{color:var(--muted);font-size:.92rem;margin:0}
.card .more{margin-top:auto;padding-top:12px;font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--orange)}
.card-link{cursor:pointer}

/* link-card (scorciatoie home) con freccia */
.shortcut{display:flex;align-items:center;justify-content:space-between;gap:14px}
.shortcut .arrow{color:var(--orange);font-size:1.2rem}

/* ---- Partner: intestazione ruolo + logo (senza card) ---- */
.partner-grid{display:flex;flex-wrap:wrap;justify-content:center;
  gap:clamp(30px,4.5vw,48px) clamp(26px,4vw,48px);max-width:760px;margin:0 auto}
.partner-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;width:clamp(220px,42%,320px)}
@media(max-width:560px){.partner-item{width:100%;max-width:330px}}
.partner-role{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.2em;text-transform:uppercase;color:var(--orange)}
.partner-logo{width:100%;aspect-ratio:16/10;border-radius:14px;display:flex;align-items:center;justify-content:center;padding:clamp(20px,3.2vw,30px);
  background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 12px 32px rgba(0,0,0,.38);text-decoration:none;transition:transform .2s ease,box-shadow .2s ease}
a.partner-logo:hover{transform:translateY(-4px);box-shadow:0 20px 46px rgba(0,0,0,.5)}
.partner-logo img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block}
.partner-logo span{font-family:var(--font-display);font-size:clamp(1.1rem,2.4vw,1.4rem);letter-spacing:.01em;color:#111;line-height:1.12}

/* ---- Newsletter / community ---- */
.subscribe{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:30px;align-items:center;
  background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,4vw,44px)}
.form-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.form-row input{flex:1;min-width:160px;background:#0d0d0d;border:1px solid var(--line-strong);border-radius:999px;
  color:var(--text);padding:.8em 1.2em;font-family:var(--font-body);font-size:.95rem}
.form-row input::placeholder{color:var(--muted)}
.consent{font-size:.74rem;color:var(--muted);margin-top:10px}

/* ---- Travel / step / faq (pagine interne) ---- */
.travel-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.travel{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:24px}
.travel h3{font-size:1.1rem;margin-bottom:8px}
.travel ul{margin:0;padding-left:18px;color:var(--muted);font-size:.92rem}
.travel li{margin:6px 0}
.map-embed{margin-top:26px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:16/7;background:#111}
.map-embed iframe{width:100%;height:100%;border:0;display:block}

.steps{counter-reset:s;display:grid;gap:14px;max-width:760px;margin:0 auto}
.step{display:flex;gap:16px;background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px}
.step::before{counter-increment:s;content:counter(s);font-family:var(--font-display);color:var(--orange);font-size:1.5rem;line-height:1;min-width:34px}
.step h3{font-size:1.05rem;margin-bottom:5px}
.step p{color:var(--muted);margin:0;font-size:.92rem}

.faq{max-width:820px;margin:0 auto;display:grid;gap:10px}
.faq details{background:var(--bg-card);border:1px solid var(--line);border-radius:12px;padding:4px 20px}
.faq summary{cursor:pointer;list-style:none;padding:16px 0;font-family:var(--font-display);text-transform:uppercase;font-size:1.02rem;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--orange);font-size:1.4rem}
.faq details[open] summary::after{content:"–"}
.faq details p{color:var(--muted);padding:0 0 18px;margin:0}

/* ---- page hero (pagine interne, senza video) ---- */
.page-hero{padding:calc(var(--header-h) + 60px) 0 30px;text-align:center}
.page-hero .label{display:inline-block;margin-bottom:14px}
.page-hero p{max-width:640px;margin:14px auto 0;color:var(--muted)}
.breadcrumb{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.breadcrumb a:hover{color:var(--orange)}

/* ---- Footer ---- */
.site-footer{border-top:1px solid var(--line);padding:54px 0 40px;text-align:center;position:relative;z-index:2}
.site-footer .logo{height:40px;margin:0 auto 22px;opacity:.85}
.foot-tag{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-size:.72rem;margin-bottom:20px}
.foot-partners{max-width:680px;margin:0 auto 26px;opacity:.7}
.foot-links{display:flex;gap:22px;justify-content:center;flex-wrap:wrap;margin-bottom:18px;font-family:var(--font-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}
.foot-links a{color:var(--muted)}.foot-links a:hover{color:var(--orange)}
.foot-social{display:flex;gap:18px;justify-content:center;margin-bottom:20px}
.foot-social a{color:var(--text);opacity:.8}.foot-social a:hover{color:var(--orange)}
.copyright{font-size:.74rem;color:var(--muted)}

/* ---- Cookie banner ---- */
.cookie{position:fixed;left:18px;right:18px;bottom:18px;z-index:60;max-width:560px;margin:0 auto;
  background:#141414;border:1px solid var(--line-strong);border-radius:14px;padding:20px 22px;
  box-shadow:0 20px 60px rgba(0,0,0,.5);display:none}
.cookie.show{display:block}
.cookie p{font-size:.86rem;color:var(--muted);margin:0 0 14px}
.cookie p a{color:var(--orange);text-decoration:underline}
.cookie .row{display:flex;gap:10px;flex-wrap:wrap}

/* ===========================================================================
   MAPPA INTERATTIVA "Come arrivare" (Leaflet, tema dark + arancio)
   =========================================================================== */
.travelmap-wrap{margin:0 auto;max-width:1100px}
.map-filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:16px}
.map-filters button{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;
  background:var(--bg-card);color:var(--muted);border:1px solid var(--line-strong);border-radius:999px;
  padding:.6em 1.15em;cursor:pointer;transition:all .2s;display:inline-flex;gap:.5em;align-items:center}
.map-filters button:hover{color:var(--text);border-color:var(--text)}
.map-filters button.active{background:var(--orange);color:var(--orange-ink);border-color:var(--orange)}

.map-stage{display:grid;grid-template-columns:1fr 320px;gap:16px}
@media(max-width:820px){.map-stage{grid-template-columns:1fr}}
#travelmap{height:520px;border-radius:var(--radius);border:1px solid var(--line-strong);overflow:hidden;background:#06080c;z-index:2}
@media(max-width:820px){#travelmap{height:420px}}
.leaflet-container{background:#06080c;font-family:var(--font-body)}
.leaflet-control-zoom a{background:#141414 !important;color:var(--text) !important;border-color:var(--line) !important}
.leaflet-control-attribution{background:rgba(10,10,10,.7) !important;color:var(--muted) !important;font-size:10px}
.leaflet-control-attribution a{color:var(--muted) !important}
/* glow sugli archi (pane overlay) */
.leaflet-overlay-pane svg path.ats-arc-glow{filter:drop-shadow(0 0 6px rgba(244,120,37,.65))}

/* pin città */
.ats-pin{display:flex;align-items:center;gap:6px;white-space:nowrap}
.ats-dot{width:11px;height:11px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 3px rgba(244,120,37,.22);flex:0 0 auto}
.ats-lbl{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--text);text-shadow:0 1px 4px #000;text-transform:uppercase}
.ats-pin:hover .ats-dot{background:#ff9550}
/* hub Catania */
.ats-hub .ats-dot{width:9px;height:9px;background:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.18)}
.ats-hub .ats-lbl{color:#d8d2c7}
/* destinazione Messina (pulsante) */
.ats-messina{position:relative;display:flex;align-items:center;gap:8px;white-space:nowrap}
.ats-messina .ats-core{width:15px;height:15px;border-radius:50%;background:var(--orange);box-shadow:0 0 14px 3px rgba(244,120,37,.8);position:relative;z-index:2}
.ats-messina .ats-pulse{position:absolute;left:0;top:50%;width:15px;height:15px;border-radius:50%;background:var(--orange);transform:translateY(-50%);animation:atsPulse 2.4s ease-out infinite;z-index:1}
.ats-messina .ats-lbl{font-family:var(--font-display);font-size:14px;letter-spacing:.02em;color:#fff}
@keyframes atsPulse{0%{transform:translateY(-50%) scale(1);opacity:.7}100%{transform:translateY(-50%) scale(4.2);opacity:0}}
@media(prefers-reduced-motion:reduce){.ats-messina .ats-pulse{animation:none;opacity:0}}

/* popup dark */
.leaflet-popup-content-wrapper{background:#141414;color:var(--text);border:1px solid var(--line-strong);border-radius:12px;box-shadow:0 16px 40px rgba(0,0,0,.5)}
.leaflet-popup-tip{background:#141414;border:1px solid var(--line-strong)}
.leaflet-popup-content{margin:14px 16px;font-size:13px;line-height:1.5}
.leaflet-popup-content b{font-family:var(--font-display);text-transform:uppercase;font-size:14px}

/* pannello rotta (a fianco / sotto) */
.route-panel{background:var(--bg-card);border:1px solid var(--line);border-radius:var(--radius);padding:20px 20px;min-height:200px;display:flex;flex-direction:column}
.route-panel .rp-empty{color:var(--muted);font-size:.9rem;margin:auto;text-align:center;font-family:var(--font-mono);letter-spacing:.04em}
.route-panel .rp-city{font-family:var(--font-display);text-transform:uppercase;font-size:1.4rem;line-height:1}
.route-panel .rp-tag{font-family:var(--font-mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-top:6px}
.route-panel .rp-steps{list-style:none;padding:0;margin:16px 0 0}
.route-panel .rp-steps li{position:relative;padding:0 0 14px 22px;font-size:.88rem;color:var(--text)}
.route-panel .rp-steps li::before{content:"";position:absolute;left:4px;top:5px;width:8px;height:8px;border-radius:50%;background:var(--orange)}
.route-panel .rp-steps li::after{content:"";position:absolute;left:7px;top:13px;bottom:0;width:1px;background:var(--line-strong)}
.route-panel .rp-steps li:last-child::after{display:none}
.route-panel .rp-steps li small{display:block;color:var(--muted);font-size:.78rem;margin-top:2px}
.route-panel .rp-dur{margin-top:auto;padding-top:14px;font-family:var(--font-mono);font-size:.74rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase}
.route-panel .rp-dur b{color:var(--orange)}

/* hint + pin attivo + card opzioni nel pannello */
.map-hint{text-align:center;color:var(--muted);font-size:.84rem;margin:0 0 16px;font-family:var(--font-mono);letter-spacing:.03em}
.ats-pin.active .ats-dot{background:#fff;box-shadow:0 0 0 4px rgba(244,120,37,.55)}
.rp-opts{display:flex;flex-direction:column;gap:10px;margin-top:14px;overflow-y:auto}
.rp-back{align-self:flex-start;background:transparent;border:1px solid var(--line-strong);color:var(--muted);font-family:var(--font-mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;border-radius:999px;padding:.42em .85em;cursor:pointer;margin-bottom:14px;transition:color .2s,border-color .2s}
.rp-back:hover{color:var(--text);border-color:var(--text)}
.rp-opt{background:#0e0e0e;border:1px solid var(--line);border-left:2px solid var(--orange);border-radius:10px;padding:11px 13px;cursor:pointer;transition:border-color .2s,background .2s}
.rp-opt:hover,.rp-opt.on{border-color:var(--orange);background:#16110b}
/* archi: transizione morbida quando si evidenziano */
#travelmap .leaflet-overlay-pane path{transition:opacity .25s ease, stroke-width .2s ease}
/* icona del mezzo sul tracciato */
.ats-mode{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:#0a0a0a;border:1px solid var(--orange);font-size:13px;line-height:1;box-shadow:0 0 10px rgba(244,120,37,.55)}
.rp-opt-h{display:flex;align-items:center;gap:8px;font-family:var(--font-display);text-transform:uppercase;font-size:.92rem;color:var(--text);line-height:1.1}
.rp-ic{font-size:1rem;flex:0 0 auto}
.rp-seas{font-family:var(--font-mono);font-style:normal;font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;color:var(--orange);background:rgba(244,120,37,.14);border-radius:5px;padding:1px 6px}
.rp-opt-l{font-size:.82rem;margin-top:5px;color:var(--text)}
.rp-opt-l.muted{color:var(--muted);font-size:.78rem}

/* nota indicativa + lista statica */
.map-note{text-align:center;color:var(--muted);font-size:.76rem;margin-top:14px;font-family:var(--font-mono);letter-spacing:.04em}
.city-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:8px;margin-top:26px}
.city-list .ci{background:var(--bg-card);border:1px solid var(--line);border-radius:10px;padding:12px 15px;font-size:.86rem}
.city-list .ci b{font-family:var(--font-display);text-transform:uppercase;font-size:.95rem;display:block;margin-bottom:3px}
.city-list .ci span{color:var(--muted)}

/* ===========================================================================
   IL FESTIVAL — fascia CTA + segnaposto foto
   =========================================================================== */
.cta-band{display:flex;flex-direction:column;align-items:center;text-align:center;gap:clamp(16px,2.6vw,24px);
  background:linear-gradient(180deg,#181410,#0e0e0e);border:1px solid var(--line-strong);
  border-radius:16px;padding:clamp(24px,3.6vw,38px) clamp(22px,4vw,40px);max-width:760px;margin:0 auto}
.cta-band .when{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.3rem,3.2vw,2.2rem);line-height:1.04}
.cta-band .sub{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:9px}
.cta-band .btn{flex:0 0 auto}

.photo-ph{position:relative;border:1px dashed var(--line-strong);border-radius:14px;
  background:repeating-linear-gradient(45deg,#101010,#101010 13px,#141414 13px,#141414 26px);
  display:flex;align-items:center;justify-content:center;text-align:center;aspect-ratio:16/9;color:var(--muted);overflow:hidden}
.photo-ph span{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;padding:10px}
.f-media.map{background:#0e0e0e;border:1px solid var(--line);border-radius:16px;padding:16px;display:flex}
.f-media.map img{aspect-ratio:auto;object-fit:contain;border-radius:8px;max-height:360px;width:100%;margin:auto}
.map-thumb{display:inline-block;margin-top:16px;border:1px solid var(--line);border-radius:10px;overflow:hidden;max-width:300px}
.map-thumb img{display:block;width:100%;height:auto}
.map-thumb .cap{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:7px 10px}
.siteplan{background:var(--bg-card);border:1px solid var(--line-strong);border-radius:16px;padding:12px;max-width:640px;margin:0 auto;box-shadow:0 16px 48px rgba(0,0,0,.4)}
.siteplan a{display:block;cursor:zoom-in}
.siteplan img{display:block;width:100%;height:auto;border-radius:8px}

/* ===========================================================================
   VIVI MESSINA — layout editoriale (immagini, ritmo asimmetrico)
   =========================================================================== */
.ed-hero{position:relative;min-height:84svh;display:flex;align-items:flex-end;overflow:hidden}
.ed-hero img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.ed-hero .veil{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(10,10,10,.97) 6%,rgba(10,10,10,.45) 46%,rgba(10,10,10,.28) 100%)}
.ed-hero .inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;width:100%;padding:0 clamp(18px,4vw,40px) clamp(42px,7vw,84px)}
.ed-hero .breadcrumb{margin-bottom:18px}
.ed-hero h1{font-size:clamp(2.7rem,8.4vw,6.6rem);max-width:13ch;line-height:.96}
.ed-hero .lead{max-width:58ch;margin-top:20px;color:#e7e2d8;font-size:clamp(1rem,1.7vw,1.2rem)}

.ed-stats{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(26px,7vw,84px);max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,40px)}
.ed-stat{text-align:center}
.ed-stat .n{font-family:var(--font-display);font-size:clamp(2.3rem,5.5vw,3.8rem);color:var(--orange);line-height:1}
.ed-stat .l{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:11px}

.feature{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(26px,5vw,64px);align-items:center;max-width:var(--maxw);margin:clamp(56px,9vw,112px) auto 0;padding:0 clamp(18px,4vw,40px)}
.feature.reverse .f-media{order:2}
.f-media{position:relative;margin:0}
.f-media img{width:100%;height:100%;object-fit:cover;border-radius:16px;aspect-ratio:5/4;display:block}
.f-media figcaption{position:absolute;left:13px;bottom:12px;font-family:var(--font-mono);font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.82);background:rgba(0,0,0,.42);padding:4px 9px;border-radius:6px;backdrop-filter:blur(4px)}
.f-body .label{display:inline-block;margin-bottom:13px}
.f-body h2{font-size:clamp(1.8rem,4vw,3.05rem);margin-bottom:15px;line-height:1.02}
.f-body p{color:var(--muted);font-size:clamp(.98rem,1.4vw,1.1rem);margin-bottom:.8rem}
.f-body p b{color:var(--text);font-weight:500}
@media(max-width:760px){.feature{grid-template-columns:1fr;gap:20px}.feature.reverse .f-media{order:0}.f-media img{aspect-ratio:16/10}}

.quoteband{position:relative;margin:clamp(56px,9vw,112px) 0 0;padding:clamp(54px,10vw,120px) 0;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.quoteband img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.18;filter:grayscale(.25) sepia(.3) contrast(1.05)}
.quoteband .veil{position:absolute;inset:0;background:radial-gradient(130% 120% at 50% 40%,rgba(10,10,10,.55),rgba(10,10,10,.93))}
.quoteband .inner{position:relative;z-index:2;max-width:920px;margin:0 auto;text-align:center;padding:0 clamp(18px,5vw,40px)}
.pull{font-family:var(--font-display);text-transform:uppercase;font-size:clamp(1.7rem,4.8vw,3.5rem);line-height:1.04;margin:0}
.pull .or{color:var(--orange)}
.quoteband .src{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:20px}
.quoteband p.note{max-width:640px;margin:24px auto 0;color:#cfc9be;font-size:clamp(.95rem,1.4vw,1.06rem)}
.quoteband p.note + p.note{margin-top:14px}

.photo-credits{max-width:var(--maxw);margin:clamp(44px,6vw,72px) auto 0;padding:18px clamp(18px,4vw,40px) 0;border-top:1px solid var(--line);font-family:var(--font-mono);font-size:.64rem;letter-spacing:.03em;color:var(--muted);line-height:1.8}

/* ---- i18n: testo bilingue inline ----
   Ogni testo traducibile ha due elementi gemelli: <x data-lang="en">…</x><x data-lang="it">…</x>.
   Si mostra solo la lingua attiva (impostata su <html lang="…">). Niente JS di lookup, niente
   dizionario centrale: ogni pagina è autosufficiente e si edita in contesto. */
html[lang="en"] [data-lang]:not([data-lang="en"]){display:none}
html[lang="it"] [data-lang]:not([data-lang="it"]){display:none}
/* utilità spazi */
.mt-s{margin-top:14px}.mt-m{margin-top:26px}
.stack-center{display:flex;flex-direction:column;align-items:center}
