/* ═══════════════════════════════════════════════
   BABY-FOOT EPENDES — 10ème Édition Anniversaire
   Thème : festif & chaleureux sur fond clair
   ═══════════════════════════════════════════════ */

:root {
    /* Palette anniversaire sobre */
    --cream:      #FDF8F0;
    --cream2:     #F5EDD8;
    --cream3:     #EDE0C4;
    --dark:       #1E1810;
    --dark-text:  #2E2518;
    --muted:      #7A6A50;

    /* Couleurs festives (utilisées avec retenue) */
    --gold:       #C9940A;
    --gold-l:     #E8B020;
    --gold-pale:  #FDF0C0;
    --red:        #C0392B;
    --red-l:      #E04535;
    --teal:       #1A7A6E;
    --teal-l:     #22A090;
    --purple:     #5B3A8E;
    --purple-l:   #7B56B8;
    --blue:       #1A5FA0;
    --blue-l:     #2E7DC8;

    --border:     rgba(180,140,60,0.25);
    --card-bg:    #fff;
    --section-alt: #F0E8D8;
}

/* ─── RESET ─── */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
    font-family:'Nunito',sans-serif;
    background:var(--cream);
    color:var(--dark-text);
    overflow-x:hidden;
}
h1,h2,h3{font-family:'Playfair Display',serif;}

/* ─── HEADER ─── */
header{
    position:sticky;top:0;z-index:100;
    background:rgba(253,248,240,0.97);
    backdrop-filter:blur(8px);
    border-bottom:2px solid var(--gold);
    box-shadow:0 2px 16px rgba(180,120,10,.10);
}
.hdr{
    max-width:1200px;margin:0 auto;
    padding:0 1.5rem;
    display:flex;align-items:center;justify-content:space-between;
    height:72px;
}
.logo{text-decoration:none;}
.logo-m{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--dark-text);font-weight:700;}
.logo-s{font-size:.65rem;font-weight:800;color:var(--gold);letter-spacing:.18em;text-transform:uppercase;}
.hdr-r{display:flex;align-items:center;gap:1.4rem;}
.hdr-date{text-align:center;display:none;}
@media(min-width:560px){.hdr-date{display:block;}}
.hdr-date .d{font-family:'Playfair Display',serif;font-size:1.25rem;color:var(--gold);font-weight:700;}
.hdr-date .s{font-size:.67rem;color:var(--muted);font-weight:700;}
.btn-hdr{
    background:var(--red);color:#fff;
    font-weight:800;font-size:.85rem;
    padding:.55rem 1.25rem;border-radius:20px;
    text-decoration:none;letter-spacing:.04em;
    box-shadow:0 3px 10px rgba(192,57,43,.3);
    transition:background .2s,transform .15s,box-shadow .2s;
}
.btn-hdr:hover{background:var(--red-l);transform:scale(1.05);box-shadow:0 5px 16px rgba(192,57,43,.4);}

nav{
    max-width:1200px;margin:0 auto;
    padding:0 1.5rem .55rem;
    display:none;gap:1.8rem;justify-content:center;
}
@media(min-width:1024px){nav{display:flex;}}
nav a{
    font-size:.72rem;font-weight:800;letter-spacing:.1em;
    text-transform:uppercase;color:var(--muted);
    text-decoration:none;transition:color .2s;
}
nav a:hover{color:var(--gold);}

/* ─── HERO ─── */
.hero{
    position:relative;
    min-height:90vh;
    display:flex;align-items:center;justify-content:center;
    text-align:center;overflow:hidden;
    padding:5rem 1.5rem;
    background:var(--cream);
}

/* Fond décoratif : dégradé radial festif centré */
.hero::before{
    content:'';
    position:absolute;inset:0;
    background:
        radial-gradient(ellipse 70% 60% at 50% 45%, rgba(253,240,192,.9) 0%, transparent 70%),
        radial-gradient(ellipse 100% 80% at 50% 50%, var(--cream) 0%, var(--cream2) 100%);
    z-index:0;
}

/* Image de fond atténuée */
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-bg img{
    width:100%;height:100%;object-fit:cover;
    opacity:.07;mix-blend-mode:multiply;
}

/* Bande colorée top */
.hero-ribbon{
    position:absolute;top:0;left:0;right:0;
    height:5px;
    background:linear-gradient(90deg,
        var(--red) 0%, var(--red) 12.5%,
        var(--gold-l) 12.5%, var(--gold-l) 25%,
        var(--teal) 25%, var(--teal) 37.5%,
        var(--purple) 37.5%, var(--purple) 50%,
        var(--blue) 50%, var(--blue) 62.5%,
        var(--red-l) 62.5%, var(--red-l) 75%,
        var(--gold) 75%, var(--gold) 87.5%,
        var(--teal-l) 87.5%, var(--teal-l) 100%
    );
    z-index:2;
}

/* Décorations SVG latérales */
.hero-deco{
    position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden;
}

.hero-c{position:relative;z-index:10;max-width:780px;}

.badge{
    display:inline-block;
    background:var(--gold-pale);
    border:2px solid var(--gold);
    color:var(--gold);
    font-size:.72rem;font-weight:900;
    letter-spacing:.2em;text-transform:uppercase;
    padding:.35rem 1.2rem;border-radius:100px;
    margin-bottom:1.4rem;
}

.hero h1{font-size:clamp(3rem,9vw,7rem);line-height:.95;color:var(--dark-text);}
.hero h1 .sm{font-size:.46em;color:var(--muted);display:block;margin-bottom:.1em;font-weight:700;}
.hero h1 .g{
    color:var(--gold);display:block;
    text-shadow:0 2px 0 rgba(180,120,10,.15);
}

/* Banderole / streamers CSS */
.streamers{
    display:flex;align-items:center;gap:.6rem;
    justify-content:center;margin:1.2rem 0;
}
.streamer{
    width:3px;border-radius:2px;
    animation:wave 1.8s ease-in-out infinite alternate;
}
.streamer:nth-child(1){height:22px;background:var(--red);animation-delay:0s;}
.streamer:nth-child(2){height:30px;background:var(--gold-l);animation-delay:.15s;}
.streamer:nth-child(3){height:18px;background:var(--teal);animation-delay:.3s;}
.streamer:nth-child(4){height:28px;background:var(--purple);animation-delay:.1s;}
.streamer:nth-child(5){height:24px;background:var(--blue);animation-delay:.25s;}
.streamer:nth-child(6){height:32px;background:var(--red-l);animation-delay:.05s;}
.streamer:nth-child(7){height:20px;background:var(--gold);animation-delay:.2s;}
.streamer:nth-child(8){height:26px;background:var(--teal-l);animation-delay:.35s;}
.streamer:nth-child(9){height:18px;background:var(--purple-l);animation-delay:.12s;}

@keyframes wave{
    from{transform:scaleY(1) rotate(-3deg);}
    to{transform:scaleY(.6) rotate(3deg);}
}

.hero-sub{
    font-size:1rem;color:var(--muted);
    max-width:520px;margin:0 auto 2rem;line-height:1.7;
}
.btn-hero{
    display:inline-block;
    background:var(--gold);color:#fff;
    font-weight:900;font-size:.92rem;
    letter-spacing:.1em;text-transform:uppercase;
    padding:.9rem 2.6rem;border-radius:100px;
    text-decoration:none;
    box-shadow:0 4px 20px rgba(201,148,10,.35);
    transition:background .2s,transform .18s,box-shadow .2s;
}
.btn-hero:hover{
    background:var(--gold-l);
    transform:scale(1.05) translateY(-2px);
    box-shadow:0 8px 28px rgba(201,148,10,.45);
}

.hero-mob{margin-top:2rem;display:block;}
.hero-mob .d{font-family:'Playfair Display',serif;font-size:1.7rem;color:var(--gold);}
.hero-mob .s{color:var(--muted);font-size:.8rem;}
@media(min-width:560px){.hero-mob{display:none;}}

/* ─── SHARED ─── */
section{position:relative;z-index:1;}
.ctr{max-width:1200px;margin:0 auto;padding:0 1.5rem;}
.sh{text-align:center;margin-bottom:2.8rem;}
.sh h2{font-size:clamp(1.8rem,4vw,2.8rem);color:var(--dark-text);}
.sh p{color:var(--muted);margin-top:.35rem;font-size:.9rem;}
.divider{
    width:60px;height:3px;margin:.85rem auto 0;border-radius:2px;
    background:linear-gradient(90deg,var(--red),var(--gold-l),var(--teal));
}

/* ─── ANNIVERSARY ─── */
.anniv{
    padding:4rem 1.5rem;text-align:center;
    background:var(--dark-text);
    color:#fff;
}
.ring{
    display:inline-flex;align-items:center;justify-content:center;
    width:140px;height:140px;border-radius:50%;
    background:linear-gradient(135deg,var(--gold),var(--gold-l));
    box-shadow:0 0 0 8px rgba(232,176,32,.15),0 0 0 16px rgba(232,176,32,.07),0 8px 32px rgba(180,120,10,.35);
    margin-bottom:1.4rem;
}
.ring span{
    font-family:'Playfair Display',serif;
    font-size:4.5rem;font-weight:900;color:#fff;line-height:1;
    text-shadow:0 2px 8px rgba(0,0,0,.25);
}
.anniv h2{font-size:clamp(1.3rem,3vw,2.1rem);color:#fff;}
.anniv p{color:rgba(255,255,255,.65);margin-top:.75rem;max-width:470px;margin-left:auto;margin-right:auto;font-size:.9rem;line-height:1.7;}
.dots{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:2rem;flex-wrap:wrap;}
.dots .yr{font-size:.7rem;font-weight:800;color:rgba(255,255,255,.45);letter-spacing:.07em;}
.dots .yr.hi{color:var(--gold-l);}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.25);}
.dot.on{background:rgba(255,255,255,.6);}
.dot.star{width:14px;height:14px;background:var(--gold-l);box-shadow:0 0 8px var(--gold);}

/* ─── INFOS ─── */
#infos{padding:5rem 0;background:var(--cream);}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(225px,1fr));gap:1.4rem;}
.card{
    background:var(--card-bg);
    border:1px solid var(--cream3);
    border-radius:12px;padding:1.8rem;text-align:center;
    box-shadow:0 2px 12px rgba(0,0,0,.06);
    transition:border-color .2s,transform .2s,box-shadow .2s;
    position:relative;overflow:hidden;
}
/* Top accent bar per card */
.card::before{
    content:'';position:absolute;top:0;left:0;right:0;height:4px;border-radius:12px 12px 0 0;
}
.card:nth-child(1)::before{background:var(--teal);}
.card:nth-child(2)::before{background:var(--gold);}
.card:nth-child(3)::before{background:var(--purple);}
.card:nth-child(4)::before{background:var(--red);}
.card:hover{border-color:var(--cream3);transform:translateY(-4px);box-shadow:0 8px 28px rgba(0,0,0,.10);}
.ci{font-size:2rem;margin-bottom:.7rem;display:block;}
.card h3{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--dark-text);margin-bottom:.5rem;}
.card .big{font-family:'Playfair Display',serif;font-size:2.8rem;color:var(--gold);line-height:1;font-weight:900;}
.card .lbl{color:var(--muted);font-size:.8rem;margin-top:.2rem;}
.card .note{
    margin-top:.9rem;font-size:.78rem;color:var(--muted);
    background:var(--cream);border:1px solid var(--cream3);
    border-radius:6px;padding:.55rem .75rem;line-height:1.5;
}
.al{list-style:none;display:flex;flex-direction:column;gap:.45rem;}
.al li{font-weight:700;color:var(--dark-text);}

/* ─── PALMARES ─── */
#palmares{padding:5rem 0;background:var(--section-alt);}
.palm-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.4rem;}
.ec{
    background:var(--card-bg);
    border:1px solid var(--cream3);
    border-radius:10px;overflow:hidden;
    box-shadow:0 2px 10px rgba(0,0,0,.05);
    transition:transform .2s,box-shadow .2s;
}
.ec:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.10);}
.ec-hdr{
    padding:.8rem 1.2rem;
    display:flex;align-items:baseline;justify-content:space-between;
    border-bottom:1px solid var(--cream3);
}
/* Each year header gets a unique accent */
.ec-hdr{background:linear-gradient(135deg,var(--cream2),var(--cream));}
.ec-yr{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--gold);font-weight:700;}
.ec-n{font-size:.65rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);}
.ec-body{padding:.65rem 1.2rem .9rem;}
.pr{display:flex;align-items:baseline;gap:.65rem;padding:.38rem 0;border-bottom:1px solid rgba(0,0,0,.04);}
.pr:last-child{border-bottom:none;}
.pi{font-size:.95rem;min-width:26px;}
.pt{font-weight:700;font-size:.84rem;color:var(--dark-text);flex:1;}
.cl{
    font-size:.62rem;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
    color:var(--muted);margin:.7rem 0 .3rem;
    padding-top:.45rem;border-top:2px dashed var(--cream3);
}
.ec-hi{border:2px solid var(--gold);grid-column:1/-1;}
.ec-hi .ec-hdr{background:linear-gradient(135deg,var(--gold-pale),var(--cream));}
.ec-hi-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:0 2rem;}

/* ─── CLASSEMENT ─── */
#classement{padding:5rem 0;background:var(--cream);}
.rbox{
    max-width:680px;margin:0 auto;
    background:var(--card-bg);
    border:1px solid var(--cream3);
    border-radius:10px;padding:2.2rem;
    box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.rbox h3{font-family:'Playfair Display',serif;font-size:1.45rem;color:var(--dark-text);margin-bottom:1.1rem;}
.rr{
    display:flex;align-items:center;justify-content:space-between;
    background:var(--cream);border:1px solid var(--cream3);
    border-radius:6px;padding:.62rem 1rem;margin-bottom:.35rem;
    transition:border-color .15s,background .15s;
}
.rr:hover{border-color:var(--gold);background:var(--gold-pale);}
.rp{font-family:'Playfair Display',serif;font-size:1rem;min-width:65px;}
.rn{font-weight:700;font-size:.86rem;color:var(--dark-text);}
.rp.g{color:var(--gold);}.rp.s{color:#888;}.rp.b{color:#A05020;}.rp.f{color:#907050;}.rp.n{color:var(--muted);}
.rnote{font-size:.76rem;color:var(--muted);text-align:center;margin-top:.9rem;line-height:1.5;}

/* ─── DOWNLOADS ─── */
#telechargements{padding:5rem 0;background:var(--section-alt);}
.dl-g{display:grid;grid-template-columns:repeat(auto-fit,minmax(195px,1fr));gap:1.2rem;max-width:760px;margin:0 auto;}
.dlc{
    background:var(--card-bg);border:1px solid var(--cream3);
    border-radius:10px;padding:1.7rem;text-align:center;
    text-decoration:none;color:var(--dark-text);
    box-shadow:0 2px 10px rgba(0,0,0,.05);
    transition:border-color .2s,transform .2s,box-shadow .2s;
}
.dlc:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 8px 22px rgba(0,0,0,.10);}
.dlc h3{font-size:.9rem;font-weight:800;color:var(--dark-text);}
.dlc p{font-size:.76rem;color:var(--gold);margin-top:.3rem;font-weight:700;}

/* ─── CONTACT ─── */
#contact{padding:5rem 0;text-align:center;background:var(--dark-text);}
#contact h2{font-size:clamp(1.8rem,4vw,2.8rem);color:#fff;}
#contact .sh p{color:rgba(255,255,255,.55);}
#contact .divider{background:linear-gradient(90deg,var(--red),var(--gold-l),var(--teal));}
.cstk{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem;}
.btn-reg{
    display:inline-block;background:var(--gold);color:#fff;
    font-weight:900;font-size:1.05rem;letter-spacing:.08em;
    padding:1rem 3rem;border-radius:100px;text-decoration:none;
    box-shadow:0 4px 22px rgba(201,148,10,.4);
    transition:background .2s,transform .15s,box-shadow .2s;
}
.btn-reg:hover{background:var(--gold-l);transform:scale(1.05);box-shadow:0 8px 30px rgba(201,148,10,.5);}
.btn-mail{
    display:inline-block;background:transparent;
    border:1px solid rgba(255,255,255,.25);
    color:rgba(255,255,255,.8);
    font-weight:700;font-size:.85rem;
    padding:.7rem 1.8rem;border-radius:100px;
    text-decoration:none;
    transition:border-color .2s,background .2s,color .2s;
}
.btn-mail:hover{border-color:var(--gold);color:var(--gold-l);background:rgba(255,255,255,.05);}

/* ─── FOOTER ─── */
footer{
    background:#141008;
    padding:2rem 1.5rem;text-align:center;
    color:rgba(255,255,255,.4);font-size:.8rem;
    border-top:3px solid var(--gold);
}
footer .g{color:var(--gold-l);}

/* ─── SCROLL TOP ─── */
#sTop{
    position:fixed;bottom:1.8rem;right:1.8rem;
    width:40px;height:40px;
    background:var(--gold);border:none;
    color:#fff;border-radius:50%;
    font-size:1.1rem;cursor:pointer;
    display:none;align-items:center;justify-content:center;
    z-index:99;
    box-shadow:0 4px 14px rgba(201,148,10,.4);
    transition:background .2s,transform .15s;
}
#sTop:hover{background:var(--gold-l);transform:scale(1.1);}
#sTop.sh{display:flex;}

/* ─── FADE IN ─── */
.fi{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease;}
.fi.in{opacity:1;transform:none;}
.d1{transition-delay:.07s;}.d2{transition-delay:.14s;}.d3{transition-delay:.21s;}.d4{transition-delay:.28s;}

/* ─── NAV ACTIVE ─── */
nav a.nav-active{color:var(--gold);}

/* ─── PAGE HERO (sous-pages palmarès / résultats) ─── */
.page-hero{
    position:relative;
    padding:5rem 1.5rem 3.5rem;
    text-align:center;
    background:var(--dark-text);
    overflow:hidden;
}
.page-hero::before{
    content:'';
    position:absolute;inset:0;
    background:radial-gradient(ellipse 90% 70% at 50% 50%,rgba(201,148,10,.09) 0%,transparent 70%);
    z-index:0;
}
.page-hero-ribbon{
    position:absolute;top:0;left:0;right:0;height:5px;
    background:linear-gradient(90deg,
        var(--red) 0%,var(--red) 12.5%,
        var(--gold-l) 12.5%,var(--gold-l) 25%,
        var(--teal) 25%,var(--teal) 37.5%,
        var(--purple) 37.5%,var(--purple) 50%,
        var(--blue) 50%,var(--blue) 62.5%,
        var(--red-l) 62.5%,var(--red-l) 75%,
        var(--gold) 75%,var(--gold) 87.5%,
        var(--teal-l) 87.5%,var(--teal-l) 100%
    );
    z-index:2;
}
.page-hero-c{
    position:relative;z-index:1;
    max-width:780px;margin:0 auto;
}
.page-hero h1{
    font-family:'Playfair Display',serif;
    font-size:clamp(2.2rem,6vw,4rem);
    color:#fff;line-height:1.05;
    margin-bottom:.5rem;
}
.ph-sm{
    font-size:.42em;color:var(--gold-l);
    display:block;margin-bottom:.25em;
    font-weight:700;letter-spacing:.08em;
    text-transform:uppercase;
}
.page-hero-sub{
    color:rgba(255,255,255,.6);
    font-size:.95rem;
    max-width:540px;margin:0 auto 2rem;
    line-height:1.7;
}
.page-breadcrumb{
    font-size:.72rem;
    color:rgba(255,255,255,.35);
    margin-bottom:1.5rem;
    letter-spacing:.04em;
}
.page-breadcrumb a{
    color:var(--gold-l);text-decoration:none;font-weight:700;
}
.page-breadcrumb a:hover{text-decoration:underline;}
.page-breadcrumb span{margin:0 .4rem;opacity:.5;}

/* ─── ANNIVERSARY BUTTONS ─── */
.btn-anniv{
    display:inline-block;
    background:rgba(255,255,255,.12);
    border:1px solid rgba(255,255,255,.25);
    color:#fff;
    font-weight:800;font-size:.82rem;
    letter-spacing:.07em;
    padding:.65rem 1.6rem;border-radius:100px;
    text-decoration:none;
    transition:background .2s,border-color .2s,transform .15s;
}
.btn-anniv:hover{background:rgba(255,255,255,.2);border-color:var(--gold-l);transform:scale(1.04);}
.btn-anniv-s{color:var(--gold-l);border-color:var(--gold);}
.btn-anniv-s:hover{background:rgba(232,176,32,.15);}

/* ─── CROSS-LINKS (liens internes entre pages) ─── */
.xlinks{padding:4rem 0;background:var(--cream2);}
.xlinks-g{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
    gap:1.2rem;max-width:700px;margin:0 auto;
}
.xlc{
    background:var(--card-bg);
    border:2px solid var(--cream3);
    border-radius:14px;padding:2rem 1.6rem;
    text-align:center;text-decoration:none;
    color:var(--dark-text);
    box-shadow:0 2px 12px rgba(0,0,0,.05);
    transition:border-color .2s,transform .2s,box-shadow .2s;
    display:block;
}
.xlc:hover{
    border-color:var(--gold);
    transform:translateY(-5px);
    box-shadow:0 10px 28px rgba(0,0,0,.11);
}
.xl-icon{font-size:2.2rem;display:block;margin-bottom:.7rem;}
.xlc h3{
    font-family:'Playfair Display',serif;
    font-size:1.15rem;color:var(--dark-text);margin-bottom:.35rem;
}
.xlc p{font-size:.78rem;color:var(--gold);font-weight:800;letter-spacing:.02em;}
