/* ============================================================
   NOÈ PONTI — "Velocity in Water"
   Webbro.ch — concept rebuild
   Deep-pool aquatic theme · royal blue + cyan (brand logo)
   ============================================================ */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button,input,textarea{font:inherit;color:inherit}

/* ---------- Tokens ---------- */
:root{
  --abyss:#03081c;
  --deep:#07153c;
  --deep-2:#0a1f55;
  --royal:#1c34a8;        /* NP monogram blue */
  --royal-lt:#2f50d6;
  --cyan:#16d2ff;         /* logo wave cyan */
  --cyan-soft:#7fe8ff;
  --foam:#e9f6ff;
  --gold:#ffc23c;         /* medals */
  --white:#ffffff;
  --ink:#06122e;
  --muted:#9fb4d8;
  --line:rgba(127,232,255,.16);
  --glass:rgba(7,21,60,.55);

  --ff-display:'Anton',Impact,sans-serif;
  --ff-body:'Manrope',system-ui,sans-serif;

  --wrap:1200px;
  --r:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 24px 60px -24px rgba(2,8,28,.85);
  --glow:0 0 0 1px rgba(22,210,255,.25),0 10px 40px -10px rgba(22,210,255,.45);
}

/* ---------- Base ---------- */
body{
  font-family:var(--ff-body);
  color:var(--foam);
  background:var(--abyss);
  line-height:1.65;
  overflow-x:hidden;
  position:relative;
}
/* layered deep-water atmosphere */
body::before{
  content:"";position:fixed;inset:0;z-index:-2;
  background:
    radial-gradient(1200px 800px at 80% -10%,rgba(28,52,168,.55),transparent 60%),
    radial-gradient(900px 700px at 0% 100%,rgba(22,210,255,.18),transparent 55%),
    linear-gradient(180deg,var(--deep) 0%,var(--abyss) 55%,#02050f 100%);
}
/* caustic light shimmer */
body::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background-image:
    radial-gradient(2px 2px at 20% 30%,rgba(255,255,255,.10),transparent),
    radial-gradient(2px 2px at 70% 60%,rgba(255,255,255,.08),transparent),
    radial-gradient(1px 1px at 40% 80%,rgba(255,255,255,.07),transparent);
  background-size:280px 280px,360px 360px,220px 220px;
  animation:drift 26s linear infinite;
}
@keyframes drift{to{background-position:280px 280px,-360px 360px,220px -220px}}

.wrap{width:min(var(--wrap),92vw);margin-inline:auto}
.eyebrow{
  font-family:var(--ff-body);font-weight:800;letter-spacing:.32em;
  text-transform:uppercase;font-size:.72rem;color:var(--cyan);
  display:inline-flex;align-items:center;gap:.6rem;margin-bottom:1rem;
}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--cyan);display:inline-block}

h1,h2,h3{font-family:var(--ff-display);font-weight:400;line-height:.98;letter-spacing:.01em;text-transform:uppercase}
.h-xl{font-size:clamp(2.8rem,9vw,7rem)}
.h-lg{font-size:clamp(2.2rem,6vw,4.4rem)}
.h-md{font-size:clamp(1.6rem,3.4vw,2.6rem)}
.lead{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--foam);max-width:62ch}
.muted{color:var(--muted)}
.accent{color:var(--cyan)}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--cyan);
  display:inline-flex;align-items:center;gap:.6rem;
  font-weight:800;letter-spacing:.04em;text-transform:uppercase;font-size:.84rem;
  padding:.95rem 1.6rem;border-radius:999px;cursor:pointer;border:0;
  background:var(--bg);color:#04122e;position:relative;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
  box-shadow:0 10px 30px -10px rgba(22,210,255,.6);
}
.btn:hover{transform:translateY(-3px);box-shadow:0 18px 44px -12px rgba(22,210,255,.85)}
.btn svg{transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(4px)}
.btn--ghost{background:transparent;color:var(--foam);box-shadow:inset 0 0 0 1.5px var(--line)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--cyan);color:var(--cyan)}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s var(--ease),padding .4s var(--ease),box-shadow .4s var(--ease);
  padding:1.1rem 0;
}
.site-header.scrolled{
  background:var(--glass);backdrop-filter:blur(16px) saturate(1.3);
  padding:.55rem 0;box-shadow:0 1px 0 var(--line),0 18px 40px -28px #000;
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:800}
.brand img{height:42px;width:auto;filter:drop-shadow(0 4px 14px rgba(22,210,255,.4))}
.nav-links{display:flex;align-items:center;gap:.3rem}
.nav-links a{
  position:relative;font-weight:700;font-size:.82rem;letter-spacing:.02em;
  text-transform:uppercase;padding:.6rem .85rem;border-radius:10px;color:var(--foam);
  transition:color .3s var(--ease),background .3s var(--ease);white-space:nowrap;
}
.nav-links a::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.42rem;height:2px;
  background:var(--cyan);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);border-radius:2px;
}
.nav-links a:hover{color:var(--cyan)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--white)}

.burger{display:none;width:46px;height:46px;border-radius:12px;border:1px solid var(--line);
  background:var(--glass);cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center}
.burger span{width:20px;height:2px;background:var(--foam);transition:.3s var(--ease)}
.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)}

@media(max-width:920px){
  .burger{display:flex}
  .nav-links{
    position:fixed;inset:0 0 0 auto;width:min(320px,82vw);flex-direction:column;
    align-items:flex-start;gap:.4rem;padding:6rem 1.6rem 2rem;
    background:linear-gradient(180deg,var(--deep),var(--abyss));
    backdrop-filter:blur(20px);box-shadow:-20px 0 60px -20px #000;
    transform:translateX(105%);transition:transform .45s var(--ease);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{font-size:1rem;width:100%;padding:.85rem .6rem}
  .nav-links a::after{display:none}
}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding:8rem 0 5rem;overflow:hidden}
.hero__bg{position:absolute;inset:0;z-index:-1}
.hero__bg img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;
  filter:saturate(1.1) contrast(1.05);transform-origin:center;transform:scale(1.12);
  animation:slowzoom 18s var(--ease) forwards;will-change:transform}
@keyframes slowzoom{to{transform:scale(1.1)}}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(3,8,28,.55) 0%,rgba(3,8,28,.35) 40%,rgba(3,8,28,.92) 100%),
  linear-gradient(90deg,rgba(3,8,28,.7),transparent 60%)}

/* swimming lane lines overlay */
.lanes{position:absolute;inset:0;z-index:-1;opacity:.5;mix-blend-mode:screen;pointer-events:none}
.lanes span{position:absolute;top:0;bottom:0;width:2px;
  background:linear-gradient(180deg,transparent,rgba(22,210,255,.5),transparent);
  animation:lane 7s linear infinite}
.lanes span:nth-child(1){left:12%;animation-delay:0s}
.lanes span:nth-child(2){left:32%;animation-delay:1.2s}
.lanes span:nth-child(3){left:52%;animation-delay:.5s}
.lanes span:nth-child(4){left:72%;animation-delay:1.8s}
.lanes span:nth-child(5){left:88%;animation-delay:.9s}
@keyframes lane{0%{opacity:0;transform:translateY(-12%)}50%{opacity:.8}100%{opacity:0;transform:translateY(12%)}}

.hero__inner{position:relative}
.hero__kicker{display:inline-flex;gap:.7rem;align-items:center;
  font-weight:800;letter-spacing:.3em;text-transform:uppercase;font-size:.74rem;color:var(--cyan)}
.hero__kicker{margin-bottom:.5rem}
.hero h1{margin:1.2rem 0 1rem;text-shadow:0 20px 60px rgba(0,0,0,.5)}
.hero h1 .stroke{color:transparent;-webkit-text-stroke:2px var(--cyan-soft)}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.4rem 2.4rem;align-items:center;margin-top:1.6rem}
.hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.scrollcue{position:absolute;bottom:1.4rem;left:50%;transform:translateX(-50%);
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);
  display:flex;flex-direction:column;align-items:center;gap:.5rem}
.scrollcue i{width:1px;height:36px;background:linear-gradient(var(--cyan),transparent);animation:cue 2s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- Wave divider ---------- */
.wave{display:block;width:100%;height:auto;line-height:0;color:var(--deep)}
.wave--flip{transform:rotate(180deg)}

/* ---------- Sections ---------- */
section{position:relative}
.band{padding:clamp(4rem,8vw,7rem) 0}
.band--deep{background:linear-gradient(180deg,var(--deep),#040d27)}
.sec-head{max-width:60ch;margin-bottom:3rem}
.sec-head.center{margin-inline:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem}
.stat{
  padding:1.8rem 1.4rem;border-radius:var(--r);text-align:center;position:relative;overflow:hidden;
  background:linear-gradient(160deg,rgba(28,52,168,.4),rgba(7,21,60,.6));
  border:1px solid var(--line);transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.stat:hover{transform:translateY(-6px);box-shadow:var(--glow)}
.stat b{font-family:var(--ff-display);font-size:clamp(3.4rem,7vw,5.4rem);
  color:#eafaff;display:block;line-height:.92;letter-spacing:-.01em;white-space:nowrap;
  text-shadow:0 0 28px rgba(22,210,255,.55),0 2px 10px rgba(0,0,0,.4)}
.stat>span{display:block;margin-top:.7rem;font-size:.82rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--foam);font-weight:700;opacity:.92}

/* ---------- Cards grid ---------- */
.grid{display:grid;gap:1.6rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}

.card{
  background:linear-gradient(165deg,rgba(10,31,85,.7),rgba(4,11,32,.85));
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease);
  display:flex;flex-direction:column;height:100%;
}
.card:hover{transform:translateY(-8px);border-color:rgba(22,210,255,.5);box-shadow:var(--shadow)}
.card__media{aspect-ratio:16/10;overflow:hidden;position:relative}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.card:hover .card__media img{transform:scale(1.07)}
.card__body{padding:1.5rem;display:flex;flex-direction:column;gap:.7rem;flex:1}
.card__date{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);font-weight:800}
.card__title{font-family:var(--ff-body);font-weight:800;font-size:1.18rem;color:var(--white);line-height:1.25}
.card p{color:var(--muted);font-size:.95rem}
.card__more{margin-top:auto;font-weight:800;font-size:.8rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--cyan);display:inline-flex;gap:.4rem;align-items:center}
.card__more::after{content:"→";transition:transform .3s var(--ease)}
.card:hover .card__more::after{transform:translateX(5px)}

/* News (text-only) */
.news{display:grid;gap:1.1rem}
.news-item{
  display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start;
  padding:1.5rem;border-radius:var(--r);border:1px solid var(--line);
  background:linear-gradient(120deg,rgba(10,31,85,.55),rgba(4,11,32,.6));
  transition:transform .4s var(--ease),border-color .4s var(--ease),background .4s var(--ease);
}
.news-item:hover{transform:translateX(6px);border-color:rgba(22,210,255,.45);background:linear-gradient(120deg,rgba(15,40,110,.7),rgba(4,11,32,.7))}
.news-date{font-family:var(--ff-display);font-size:1.05rem;color:var(--cyan);
  writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:.05em;
  border-left:2px solid var(--cyan);padding-left:.6rem}
.news-body h3{font-family:var(--ff-body);font-weight:800;font-size:1.2rem;color:var(--white);margin-bottom:.4rem;text-transform:none}
.news-body p{color:var(--muted);font-size:.97rem}

/* Events */
.events{display:grid;gap:1rem}
.event{
  display:grid;grid-template-columns:140px 1fr auto;gap:1.4rem;align-items:center;
  padding:1.4rem 1.6rem;border-radius:var(--r);border:1px solid var(--line);
  background:linear-gradient(120deg,rgba(10,31,85,.5),rgba(4,11,32,.55));
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s;
}
.event:hover{transform:translateY(-4px);border-color:rgba(22,210,255,.5);box-shadow:var(--glow)}
.event__date{font-family:var(--ff-display);color:var(--cyan);font-size:1.1rem;line-height:1.1}
.event__date small{display:block;font-family:var(--ff-body);color:var(--muted);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;margin-top:.2rem}
.event__title{font-weight:800;color:var(--white);font-size:1.15rem}
.event__desc{color:var(--muted);font-size:.92rem;margin-top:.2rem}
.event__tag{font-size:.7rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;
  padding:.4rem .8rem;border-radius:999px;color:#04122e;background:var(--cyan-soft);white-space:nowrap}

/* Foto del mese */
.photo-feature{display:grid;grid-template-columns:1.3fr 1fr;gap:2.5rem;align-items:center}
.photo-feature figure{position:relative;border-radius:calc(var(--r) + 6px);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow)}
.photo-feature figure::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 120px rgba(3,8,28,.6)}
.photo-feature img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.photo-feature figure:hover img{transform:scale(1.05)}
.photo-tag{position:absolute;top:1rem;left:1rem;z-index:2;background:var(--glass);
  backdrop-filter:blur(8px);padding:.5rem .9rem;border-radius:999px;border:1px solid var(--line);
  font-size:.72rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan)}

/* ---------- Team / people ---------- */
.people{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem}
.person{position:relative;border-radius:var(--r);overflow:hidden;border:1px solid var(--line);
  background:#050f2b;aspect-ratio:3/4;transition:transform .45s var(--ease),box-shadow .45s var(--ease)}
.person:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.person img{width:100%;height:100%;object-fit:cover;object-position:50% 30%;
  filter:grayscale(.25) contrast(1.02);transition:transform .7s var(--ease),filter .5s}
.person:hover img{transform:scale(1.06);filter:grayscale(0)}
.person__info{position:absolute;inset:auto 0 0 0;padding:1.4rem 1.3rem 1.3rem;
  background:linear-gradient(180deg,transparent,rgba(3,8,28,.92) 55%)}
.person__info h3{font-family:var(--ff-body);font-weight:800;text-transform:none;font-size:1.2rem;color:#fff}
.person__info span{font-size:.84rem;color:var(--cyan-soft);font-weight:600}
.role-tag{position:absolute;top:1rem;left:1rem;font-size:.66rem;font-weight:800;
  letter-spacing:.12em;text-transform:uppercase;padding:.35rem .75rem;border-radius:999px;
  background:var(--glass);backdrop-filter:blur(6px);border:1px solid var(--line);color:var(--cyan)}

/* ---------- Sponsors ---------- */
.sponsor-group{margin-bottom:3rem}
.sponsor-group h3{font-family:var(--ff-body);font-weight:800;text-transform:uppercase;
  letter-spacing:.16em;font-size:.82rem;color:var(--cyan);margin-bottom:1.4rem;
  display:flex;align-items:center;gap:1rem}
.sponsor-group h3::after{content:"";flex:1;height:1px;background:var(--line)}
.logos{display:grid;gap:1.2rem}
.logos--main{grid-template-columns:1fr;max-width:420px}
.logos--4{grid-template-columns:repeat(4,1fr)}
.logos--6{grid-template-columns:repeat(6,1fr)}
.logo-tile{
  display:flex;align-items:center;justify-content:center;padding:1.6rem;
  background:var(--white);border-radius:14px;aspect-ratio:3/2;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);position:relative;overflow:hidden;
}
.logo-tile.is-main{aspect-ratio:5/2;padding:2.2rem}
.logo-tile img{max-height:100%;max-width:100%;width:auto;object-fit:contain;
  filter:saturate(1);transition:transform .4s var(--ease)}
.logo-tile:hover{transform:translateY(-5px);box-shadow:var(--glow)}
.logo-tile:hover img{transform:scale(1.06)}

/* marquee */
.marquee{overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee__track{display:flex;gap:2.5rem;width:max-content;animation:scroll 32s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee img{height:42px;width:auto;object-fit:contain;background:#fff;border-radius:10px;padding:.6rem .9rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- Split / prose ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.split__media{border-radius:calc(var(--r) + 8px);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);position:relative}
.split__media img{width:100%;height:100%;object-fit:cover}
.prose p{margin-bottom:1.1rem;color:var(--foam)}
.prose p .accent{font-weight:700}

/* fact list */
.facts{display:grid;grid-template-columns:repeat(2,1fr);gap:.8rem;margin-top:1.5rem}
.fact{padding:1rem 1.2rem;border-radius:14px;border:1px solid var(--line);
  background:rgba(7,21,60,.5)}
.fact dt{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700}
.fact dd{font-family:var(--ff-display);font-size:1.4rem;color:#fff;margin-top:.2rem}

/* timeline */
.timeline{position:relative;padding-left:2rem;margin-top:1rem}
.timeline::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;
  background:linear-gradient(var(--cyan),transparent)}
.tl{position:relative;padding:0 0 2rem 1.5rem}
.tl::before{content:"";position:absolute;left:-1.55rem;top:.35rem;width:14px;height:14px;
  border-radius:50%;background:var(--cyan);box-shadow:0 0 0 5px rgba(22,210,255,.18)}
.tl b{font-family:var(--ff-display);color:var(--cyan);font-size:1.2rem;letter-spacing:.03em}
.tl h4{font-weight:800;color:#fff;margin:.2rem 0 .3rem;font-size:1.05rem}
.tl p{color:var(--muted);font-size:.94rem}

/* records */
.records{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
.record{padding:2rem;border-radius:var(--r);border:1px solid var(--line);position:relative;overflow:hidden;
  background:linear-gradient(160deg,rgba(28,52,168,.45),rgba(4,11,32,.8))}
.record::before{content:"";position:absolute;right:-30px;top:-30px;width:140px;height:140px;
  background:radial-gradient(circle,rgba(22,210,255,.35),transparent 70%)}
.record small{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:800}
.record .time{font-family:var(--ff-display);font-size:clamp(3rem,7vw,4.6rem);color:#fff;line-height:.9;margin:.5rem 0}
.record p{color:var(--muted)}

/* palmares medals */
.medals{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:1rem}
.medal{padding:1.6rem;border-radius:var(--r);border:1px solid var(--line);text-align:center;
  background:rgba(7,21,60,.5);transition:transform .4s var(--ease),box-shadow .4s}
.medal:hover{transform:translateY(-5px);box-shadow:var(--glow)}
.medal .ic{font-size:2rem}
.medal b{display:block;font-family:var(--ff-display);font-size:1.8rem;color:#fff;margin:.3rem 0}
.medal span{font-size:.82rem;color:var(--muted)}

/* ---------- Contact ---------- */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem}
.field{margin-bottom:1.1rem}
.field label{display:block;font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--muted);font-weight:700;margin-bottom:.45rem}
.field input,.field textarea{width:100%;padding:.9rem 1.1rem;border-radius:12px;
  background:rgba(3,8,28,.6);border:1px solid var(--line);color:#fff;
  transition:border-color .3s,box-shadow .3s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(22,210,255,.15)}
.field textarea{min-height:140px;resize:vertical}
.req{color:var(--cyan)}
.info-card{padding:1.6rem 1.8rem;border-radius:var(--r);border:1px solid var(--line);
  background:linear-gradient(160deg,rgba(10,31,85,.6),rgba(4,11,32,.7));margin-bottom:1.2rem}
.info-card h4{font-family:var(--ff-body);font-weight:800;color:#fff;margin-bottom:.3rem}
.info-card a{color:var(--cyan)}
.info-card .row{display:flex;gap:.6rem;align-items:center;color:var(--muted);margin-top:.4rem;font-size:.95rem}
.info-card .row .ui-ic{width:1.15rem;height:1.15rem;color:var(--cyan);flex:none}

/* ---------- Footer ---------- */
.site-footer{position:relative;padding:4rem 0 2rem;margin-top:2rem;
  background:linear-gradient(180deg,#040d27,#02050f);border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2.5rem;margin-bottom:2.5rem}
.foot-brand img{height:54px;margin-bottom:1rem}
.foot-brand p{color:var(--muted);max-width:38ch}
.foot-col h5{font-family:var(--ff-body);font-weight:800;text-transform:uppercase;letter-spacing:.14em;
  font-size:.78rem;color:var(--cyan);margin-bottom:1rem}
.foot-col a{display:block;color:var(--muted);padding:.3rem 0;transition:color .3s,transform .3s}
.foot-col a:hover{color:var(--cyan);transform:translateX(4px)}
.socials{display:flex;gap:.7rem;margin-top:1.2rem}
.socials a{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;
  border:1px solid var(--line);background:rgba(7,21,60,.5);transition:.35s var(--ease)}
.socials a:hover{background:var(--cyan);color:#04122e;transform:translateY(-4px)}
.socials svg{width:18px;height:18px}
.foot-bottom{display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center;
  padding-top:1.6rem;border-top:1px solid var(--line);color:var(--muted);font-size:.85rem}
.foot-bottom a{color:var(--cyan);font-weight:700}

/* ---------- Reveal anim ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}

/* bubbles */
.bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.bubbles i{position:absolute;bottom:-40px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.6),rgba(22,210,255,.15));
  animation:rise linear infinite;opacity:.5}
@keyframes rise{to{transform:translateY(-110vh) translateX(20px);opacity:0}}

/* page hero (interior) */
.page-hero{position:relative;padding:9rem 0 4rem;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(800px 400px at 20% 0%,rgba(28,52,168,.5),transparent 60%)}
.page-hero .crumb{color:var(--muted);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700}
.page-hero .crumb a:hover{color:var(--cyan)}

/* ---------- Responsive ---------- */
@media(max-width:1000px){
  .grid-3,.logos--6{grid-template-columns:repeat(3,1fr)}
  .people{grid-template-columns:repeat(2,1fr)}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .scrollcue{display:none}
  .split,.photo-feature,.contact{grid-template-columns:1fr}
  .grid-2,.grid-3,.records,.logos--4{grid-template-columns:1fr 1fr}
  .logos--6{grid-template-columns:repeat(3,1fr)}
  .medals{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr;gap:2rem}
  .event{grid-template-columns:1fr;gap:.5rem}
  .event__tag{justify-self:start}
  .facts{grid-template-columns:1fr 1fr}
  .news-date{writing-mode:horizontal-tb;border-left:0;border-top:2px solid var(--cyan);padding:.4rem 0 0;border-radius:0}
  .news-item{grid-template-columns:1fr}
}
@media(max-width:480px){
  .logos--4,.logos--6,.grid-2,.grid-3,.records,.people,.stats{grid-template-columns:1fr}
  .facts{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .reveal{opacity:1;transform:none}
}

/* ============================================================
   CMS additions — lang switch, tabs, news filters, results
   ============================================================ */

/* Language switcher (desktop) */
.nav-lang{display:flex;align-items:center;gap:.35rem;margin-left:.5rem;
  padding-left:.9rem;border-left:1px solid var(--line)}
.nav-lang a{font-weight:800;font-size:.8rem;letter-spacing:.05em;color:var(--muted);
  padding:.35rem .5rem;border-radius:8px;transition:color .3s,background .3s}
.nav-lang a.on{color:#04122e;background:var(--cyan)}
.nav-lang a:not(.on):hover{color:var(--cyan)}
.nav-lang span{color:var(--muted);opacity:.5}

/* Tabs (Agenda & Risultati, News categories) */
.tabs{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.5rem}
.tab-btn{font-family:var(--ff-body);font-weight:800;letter-spacing:.04em;text-transform:uppercase;
  font-size:.82rem;padding:.7rem 1.3rem;border-radius:999px;cursor:pointer;
  border:1px solid var(--line);background:rgba(7,21,60,.5);color:var(--muted);
  transition:.35s var(--ease)}
.tab-btn:hover{color:var(--cyan);border-color:rgba(22,210,255,.4)}
.tab-btn.active{background:var(--cyan);color:#04122e;border-color:var(--cyan);
  box-shadow:0 8px 24px -10px rgba(22,210,255,.7)}
.tab-panel{display:none;animation:fadeUp .5s var(--ease)}
.tab-panel.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* Results table */
.result-list{display:grid;gap:.8rem}
.result-row{display:grid;grid-template-columns:120px 1fr auto;gap:1.2rem;align-items:center;
  padding:1.2rem 1.5rem;border-radius:var(--r);border:1px solid var(--line);
  background:linear-gradient(120deg,rgba(10,31,85,.5),rgba(4,11,32,.55));
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.result-row:hover{transform:translateX(6px);border-color:rgba(22,210,255,.45);box-shadow:var(--glow)}
.result-row .r-date{font-family:var(--ff-display);color:var(--cyan);font-size:1rem;letter-spacing:.03em}
.result-row .r-event{font-weight:800;color:#fff}
.result-row .r-disc{color:var(--muted);font-size:.9rem;margin-top:.15rem}
.result-row .r-right{text-align:right;display:flex;align-items:center;gap:.9rem;justify-content:flex-end}
.result-row .r-time{font-family:var(--ff-display);font-size:1.5rem;color:#fff;line-height:1}
.result-row .r-medal{display:inline-flex;align-items:center;gap:.15rem}

/* Icone medaglie / record / trofeo (SVG, niente emoji) */
.medal-ic,.star-ic,.trophy-ic{width:1.5rem;height:1.5rem;vertical-align:middle}
.r-medal .medal-ic{width:1.7rem;height:1.7rem}
.record__star{display:inline-flex;vertical-align:middle;margin-right:.4rem}
.record__star .star-ic{width:1.1rem;height:1.1rem}
.medal .ic{display:flex;justify-content:center;align-items:center;min-height:2.4rem}
.medal .ic .medal-ic,.medal .ic .trophy-ic{width:2.4rem;height:2.4rem}
.medal .ic .trophy-ic{color:var(--cyan-soft)}
.result-row .r-result{font-size:.78rem;color:var(--cyan-soft);font-weight:700;display:block;margin-top:.2rem}

/* News meta */
.news-cat{display:inline-block;font-size:.66rem;font-weight:800;letter-spacing:.12em;
  text-transform:uppercase;padding:.3rem .7rem;border-radius:999px;
  background:rgba(22,210,255,.14);color:var(--cyan);border:1px solid var(--line);margin-bottom:.2rem;align-self:flex-start}
.card__media--placeholder{display:grid;place-items:center;
  background:linear-gradient(160deg,var(--royal),var(--deep))}
.card__media--placeholder svg{width:64px;height:64px;opacity:.5;color:var(--cyan-soft)}

/* card as link */
a.card{color:inherit}
a.card:focus-visible{outline:2px solid var(--cyan);outline-offset:3px}

/* News article (detail) */
.article{max-width:820px;margin:0 auto}
.article__back{display:inline-flex;align-items:center;gap:.5rem;color:var(--cyan);
  font-weight:800;font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:1.6rem}
.article__back::before{content:"←";transition:transform .3s var(--ease)}
.article__back:hover::before{transform:translateX(-4px)}
.article__meta{display:flex;align-items:center;gap:.8rem;flex-wrap:wrap;margin:1rem 0 1.4rem}
.article__media{border-radius:calc(var(--r) + 6px);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);margin:1.8rem 0}
.article__media img{width:100%;display:block}
.article__lead{font-size:clamp(1.1rem,1.7vw,1.3rem);color:var(--foam);font-weight:600;
  border-left:3px solid var(--cyan);padding-left:1.1rem;margin:1.4rem 0}
.article__body{font-size:1.06rem;color:var(--foam)}
.article__body p{margin-bottom:1.1rem}
.article__body p:empty{display:none}

/* Palmarès teaser (home) */
.pal-teaser{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
@media(max-width:760px){.pal-teaser{grid-template-columns:1fr}}

/* responsive CMS */
@media(max-width:680px){
  .result-row{grid-template-columns:1fr;gap:.5rem}
  .result-row .r-right{justify-content:flex-start;text-align:left}
}
@media(max-width:920px){
  .nav-lang{margin:1rem 0 0;padding:1rem 0 0;border-left:0;border-top:1px solid var(--line);width:100%;justify-content:flex-start}
  .nav-links .nav-lang a{width:auto;padding:.4rem .8rem}
}
