/* ============================================================
   Tennis Club de Bouliac — styles partagés
   Palette issue du logo : orange #F09000 / teal #183030
   ============================================================ */
:root{
  --orange:#F09000;
  --orange-soft:#FFB23E;
  --teal:#183030;
  --teal-700:#23433F;
  --cream:#FBF8F3;
  --cream-2:#F3EDE3;
  --ink:#1B2624;
  --muted:#6C7A77;
  --line:rgba(24,48,48,.10);
  --r:18px;
  --shadow:0 24px 60px -28px rgba(24,48,48,.35);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Instrument Sans',sans-serif;background:var(--cream);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,.display{font-family:'Bricolage Grotesque',sans-serif;line-height:1.02;letter-spacing:-.02em}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.eyebrow{font-size:.78rem;text-transform:uppercase;letter-spacing:.18em;font-weight:600;color:var(--orange)}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .35s ease}
.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
header.scrolled{background:rgba(251,248,243,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
header.scrolled .nav{padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;font-family:'Bricolage Grotesque';font-weight:800;font-size:1.05rem;color:var(--teal)}
.brand img{width:40px;height:40px}
.brand .lg-dark{display:none}
header.on-dark:not(.scrolled) .brand .lg-color{display:none}
header.on-dark:not(.scrolled) .brand .lg-dark{display:inline-block}
.navlinks{display:flex;gap:22px;align-items:center}
.navlinks a{font-size:.93rem;font-weight:500;color:var(--teal);opacity:.8;transition:opacity .2s}
.navlinks a:hover,.navlinks a.active{opacity:1;color:var(--orange)}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--orange);color:#fff;font-weight:600;padding:11px 22px;border-radius:100px;font-size:.92rem;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 8px 20px -8px rgba(240,144,0,.7);border:none;cursor:pointer}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.55);box-shadow:none}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.infos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.info{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px}
.info h3{color:var(--teal);font-size:1.15rem;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.info h3 .ic{width:34px;height:34px;border-radius:10px;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem}
.info p,.info a{color:var(--muted);font-size:.95rem;line-height:1.9}
.info a:hover{color:var(--orange)}
@media(max-width:900px){.infos-grid{grid-template-columns:1fr}}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 26px -8px rgba(240,144,0,.8)}
.btn.ghost{background:transparent;color:var(--teal);border:1.5px solid var(--line);box-shadow:none}
.btn.ghost:hover{border-color:var(--teal);transform:translateY(-2px)}
.btn.lg{padding:15px 30px;font-size:1rem}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer}
.burger span{width:24px;height:2px;background:var(--teal);border-radius:2px;transition:background .3s}
/* En-tête au-dessus d'un bandeau sombre : texte clair tant qu'on n'a pas scrollé */
header.on-dark .navlinks a,header.on-dark .brand{color:#fff}
header.on-dark .burger span{background:#fff}
header.on-dark.scrolled .navlinks a,header.on-dark.scrolled .brand{color:var(--teal)}
header.on-dark.scrolled .burger span{background:var(--teal)}
header.on-dark .navlinks a.active{color:var(--orange-soft)}
header.on-dark.scrolled .navlinks a.active{color:var(--orange)}

/* reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* PAGE BANNER (sous-pages) */
.banner{padding:150px 0 60px;background:var(--teal);color:#fff;position:relative;overflow:hidden}
.banner:before{content:"";position:absolute;width:440px;height:440px;border-radius:50%;background:radial-gradient(circle,rgba(240,144,0,.22),transparent 70%);top:-160px;right:-120px}
.banner h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:800;position:relative}
.banner p{opacity:.85;margin-top:14px;max-width:54ch;position:relative}
.crumb{font-size:.85rem;opacity:.7;margin-bottom:16px;position:relative}
.crumb a:hover{color:var(--orange-soft)}

/* SECTION */
section.block{padding:90px 0}
.head{max-width:640px;margin-bottom:48px}
.head h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--teal);margin:14px 0}
.head p{color:var(--muted);font-size:1.05rem}

/* STATS */
.stats{background:var(--teal);color:#fff;border-radius:28px;margin:0 28px}
.stats-inner{max-width:1140px;margin:0 auto;padding:46px 28px;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat b{font-family:'Bricolage Grotesque';font-size:2.6rem;color:var(--orange-soft);display:block;line-height:1}
.stat span{font-size:.9rem;opacity:.8;display:block;margin-top:6px}

/* MÉTÉO */
.weather-card{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;background:linear-gradient(120deg,#fff,var(--cream-2));border:1px solid var(--line);border-radius:var(--r);padding:20px 26px;margin-bottom:28px}
.weather-card .w-main{display:flex;align-items:center;gap:18px}
.weather-card .w-ico{font-size:2.6rem;line-height:1}
.weather-card .w-temp{font-family:'Bricolage Grotesque';font-weight:800;font-size:2rem;color:var(--teal);line-height:1}
.weather-card .w-temp .w-loc{font-family:'Instrument Sans';font-weight:500;font-size:.9rem;color:var(--muted);margin-left:8px}
.weather-card .w-desc{color:var(--muted);font-size:.92rem;margin-top:3px}
.weather-card .w-meta{display:flex;align-items:center;gap:22px;font-size:.9rem;color:var(--teal)}
.weather-card .w-play{font-weight:600;padding:7px 14px;border-radius:100px;font-size:.82rem}
.weather-card .w-play.ok{background:#E8F5EF;color:#0c6b4d}
.weather-card .w-play.no{background:#FBE9E7;color:#b3401f}
@media(max-width:600px){.weather-card .w-meta{width:100%;justify-content:space-between;gap:12px}}

/* CARDS génériques */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:34px;transition:transform .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}

/* ÉQUIPE */
.team-group h3.gtitle{font-size:1.4rem;color:var(--teal);margin:46px 0 22px;display:flex;align-items:center;gap:12px}
.team-group h3.gtitle:before{content:"";width:30px;height:3px;background:var(--orange);border-radius:3px}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.member{text-align:center}
.member .ph{width:120px;height:120px;border-radius:50%;object-fit:cover;margin:0 auto 14px;border:3px solid #fff;box-shadow:var(--shadow);background:var(--cream-2)}
.member .ph.noimg{display:flex;align-items:center;justify-content:center;font-family:'Bricolage Grotesque';font-weight:800;font-size:2rem;color:#fff;background:linear-gradient(135deg,var(--orange-soft),var(--orange))}
.member b{display:block;color:var(--teal);font-size:1.02rem;font-family:'Bricolage Grotesque'}
.member span{font-size:.85rem;color:var(--muted)}
.member.coach .ph{border-color:var(--orange)}

/* INSTALLATIONS */
.inst-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.inst{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:16/10;box-shadow:var(--shadow)}
.inst img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.inst:hover img{transform:scale(1.05)}
.inst .cap{position:absolute;left:0;right:0;bottom:0;padding:22px;background:linear-gradient(transparent,rgba(24,48,48,.85));color:#fff}
.inst .cap b{font-family:'Bricolage Grotesque';font-size:1.2rem;display:block}
.inst .cap span{font-size:.86rem;opacity:.85}

/* ÉCOLE */
.school-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.sc{background:var(--cream-2);border-radius:var(--r);padding:30px;position:relative;overflow:hidden}
.sc .age{position:absolute;top:18px;right:20px;font-family:'Bricolage Grotesque';font-weight:800;font-size:2.6rem;color:rgba(24,48,48,.07)}
.sc h3{color:var(--teal);font-size:1.3rem;margin-bottom:8px}
.sc p{color:var(--muted);font-size:.93rem}
.sc .dot{width:38px;height:38px;border-radius:12px;background:var(--orange);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:#fff;font-weight:700}

/* TARIFS */
.tarif-tabs{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:34px}
.tarif-tabs button{background:#fff;border:1.5px solid var(--line);color:var(--teal);padding:10px 20px;border-radius:100px;font-weight:600;cursor:pointer;font-size:.92rem;font-family:inherit;transition:all .2s ease}
.tarif-tabs button.active{background:var(--teal);color:#fff;border-color:var(--teal)}
.tarif-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tarif{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:30px;display:flex;flex-direction:column;transition:transform .25s ease,box-shadow .25s ease,border-color .25s}
.tarif:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--orange)}
.tarif.feature{background:var(--teal);color:#fff;border-color:var(--teal)}
.tarif .name{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.3rem;color:var(--teal)}
.tarif.feature .name{color:#fff}
.tarif .who{font-size:.85rem;color:var(--muted);margin-bottom:18px}
.tarif.feature .who{color:rgba(255,255,255,.7)}
.tarif .price{font-family:'Bricolage Grotesque';font-weight:800;font-size:2.4rem;color:var(--orange);line-height:1}
.tarif.feature .price{color:var(--orange-soft)}
.tarif .price small{font-size:.9rem;color:var(--muted);font-weight:400;font-family:'Instrument Sans'}
.tarif.feature .price small{color:rgba(255,255,255,.7)}
.tarif .desc{font-size:.9rem;color:var(--muted);margin:14px 0 22px;flex:1}
.tarif.feature .desc{color:rgba(255,255,255,.8)}
.tarif .pick{margin-top:auto;text-align:center;padding:11px;border-radius:100px;border:1.5px solid var(--line);font-weight:600;font-size:.9rem;transition:all .2s ease;cursor:pointer;color:var(--teal)}
.tarif:hover .pick{background:var(--orange);color:#fff;border-color:var(--orange)}
.tarif.feature .pick{background:var(--orange);color:#fff;border-color:var(--orange)}
.badge{align-self:flex-start;background:var(--orange);color:#fff;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;padding:4px 11px;border-radius:100px;margin-bottom:12px}

/* FORMULAIRE */
.form-wrap{max-width:760px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:24px;padding:44px;box-shadow:var(--shadow)}
.form-step-head{display:flex;gap:8px;margin-bottom:30px}
.form-step-head .s{flex:1;height:5px;border-radius:5px;background:var(--cream-2)}
.form-step-head .s.on{background:var(--orange)}
.fieldset h3{color:var(--teal);font-size:1.4rem;margin-bottom:6px}
.fieldset p.sub{color:var(--muted);font-size:.92rem;margin-bottom:24px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{margin-bottom:18px}
.field label{display:block;font-size:.85rem;font-weight:600;color:var(--teal);margin-bottom:7px}
.field input,.field select,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;color:var(--ink);background:var(--cream);transition:border-color .2s ease}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--orange);background:#fff}
.field .hint{font-size:.78rem;color:var(--muted);margin-top:5px}
.field.err input,.field.err select{border-color:#d4453a}
.field .errmsg{color:#d4453a;font-size:.78rem;margin-top:5px;display:none}
.field.err .errmsg{display:block}
.form-nav{display:flex;justify-content:space-between;margin-top:30px;gap:12px}
.checkrow{display:flex;gap:11px;align-items:flex-start;font-size:.9rem;color:var(--muted);margin-top:8px}
.checkrow input{width:auto;margin-top:4px}
.recap{background:var(--cream);border-radius:14px;padding:20px;margin-bottom:20px}
.recap .line{display:flex;justify-content:space-between;padding:7px 0;font-size:.92rem;border-bottom:1px dashed var(--line)}
.recap .line:last-child{border:0}
.recap .line b{color:var(--teal)}
.success{text-align:center;padding:20px}
.success .ico{width:74px;height:74px;border-radius:50%;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.4rem;margin:0 auto 20px}
.success h3{color:var(--teal);font-size:1.6rem;margin-bottom:10px}
.success p{color:var(--muted)}
.note{background:#FFF6E8;border:1px solid #F4D9A8;border-radius:12px;padding:14px 16px;font-size:.86rem;color:#8a6406;margin-bottom:24px}

/* COMPÉTITION banner */
.compet{background:linear-gradient(120deg,var(--teal),var(--teal-700));border-radius:28px;color:#fff;padding:60px;position:relative;overflow:hidden;display:grid;grid-template-columns:1.3fr .7fr;gap:40px;align-items:center}
.compet:before{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(240,144,0,.3),transparent 70%);top:-80px;right:-40px}
.compet h2{font-size:clamp(1.8rem,3.5vw,2.6rem);color:#fff;position:relative}
.compet p{opacity:.85;margin:16px 0 26px;max-width:46ch;position:relative}
.phone-mock{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:22px;backdrop-filter:blur(6px);position:relative}
.compet-visual{position:relative}
.compet-visual img{width:100%;max-width:360px;display:block;margin:0 auto;border-radius:24px;box-shadow:0 20px 50px rgba(0,0,0,.35)}
.cordage-card{background:linear-gradient(120deg,var(--teal),var(--teal-700));border-radius:28px;color:#fff;padding:56px;position:relative;overflow:hidden;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center}
.cordage-card:before{content:"";position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(240,144,0,.28),transparent 70%);bottom:-90px;left:-50px}
.cordage-card h2{font-size:clamp(1.8rem,3.5vw,2.6rem);color:#fff;position:relative;margin:6px 0 0}
.cordage-card p{opacity:.85;margin:16px 0 26px;max-width:44ch;position:relative}
.cordage-prices{display:grid;gap:13px;position:relative}
.cordage-price{display:flex;justify-content:space-between;align-items:center;gap:14px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:16px 22px}
.cordage-price .cp-label{font-weight:500;opacity:.92;font-size:.98rem}
.cordage-price .cp-val{font-family:'Bricolage Grotesque';font-weight:800;font-size:1.5rem;line-height:1;white-space:nowrap;color:var(--orange-soft)}
.cordage-price.feat{background:var(--orange);border-color:transparent;box-shadow:0 12px 28px -10px rgba(240,144,0,.7)}
.cordage-price.feat .cp-label{opacity:1}
.cordage-price.feat .cp-val{color:#fff}
@media(max-width:780px){.cordage-card{grid-template-columns:1fr;padding:38px 28px;gap:30px}}
.cordage-banner{display:block;max-width:760px;margin:0 auto;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);transition:transform .25s ease}
.cordage-banner:hover{transform:translateY(-4px)}
.cordage-banner img{width:100%;display:block}
.phone-mock .row{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.86rem}
.phone-mock .row:last-child{border:0}
.phone-mock .pill{background:var(--orange);color:#fff;border-radius:8px;padding:3px 9px;font-size:.72rem;font-weight:600}

/* SOCIAL */
.social-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:24px}
.yt-frame{position:relative;border-radius:var(--r);overflow:hidden;aspect-ratio:16/9;box-shadow:var(--shadow);background:var(--teal)}
.yt-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.social-cards{display:flex;flex-direction:column;gap:14px;justify-content:space-between}
.soc{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;flex:1;transition:transform .22s ease,box-shadow .22s ease,border-color .22s ease}
.soc:hover{transform:translateX(4px);box-shadow:var(--shadow)}
.soc svg{flex:none}
.soc div{flex:1;line-height:1.3}
.soc b{display:block;color:var(--teal);font-family:'Bricolage Grotesque';font-size:1.05rem}
.soc span{font-size:.85rem;color:var(--muted)}
.soc .arr{color:var(--orange);font-size:1.2rem;transition:transform .22s ease}
.soc:hover .arr{transform:translateX(4px)}
.soc.ig{color:#E1306C}.soc.fb{color:#1877F2}.soc.yt2{color:#FF0000}
.soc.ig:hover{border-color:#E1306C}.soc.fb:hover{border-color:#1877F2}.soc.yt2:hover{border-color:#FF0000}

/* FOOTER */
.foot-social{display:flex;gap:12px;margin-top:18px}
.foot-social a{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);color:#fff;opacity:.85;transition:all .22s ease}
.foot-social a:hover{background:var(--orange);opacity:1;transform:translateY(-3px)}
footer{background:var(--teal);color:#fff;padding:70px 0 32px;margin-top:30px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px}
.foot-brand{display:flex;align-items:center;gap:12px;font-family:'Bricolage Grotesque';font-weight:800;font-size:1.2rem;margin-bottom:18px}
.foot-brand img{width:42px;height:42px}
footer p,footer a{opacity:.78;font-size:.92rem;line-height:1.9}
footer a:hover{opacity:1;color:var(--orange-soft)}
.foot-col h4{font-family:'Bricolage Grotesque';font-size:1rem;margin-bottom:14px;opacity:1}
.foot-col a{display:block}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:46px;padding-top:22px;display:flex;justify-content:space-between;font-size:.82rem;opacity:.6;flex-wrap:wrap;gap:10px}
.foot-version{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;letter-spacing:.03em;opacity:.85}
.foot-bottom a{color:inherit;text-decoration:underline;text-underline-offset:2px}
.foot-bottom a:hover{color:var(--orange-soft)}

/* PAGES LÉGALES */
.legal{max-width:760px;margin:0 auto}
.legal h3{color:var(--teal);font-size:1.2rem;margin:28px 0 8px}
.legal p,.legal li{color:var(--muted);line-height:1.75}
.legal ul{margin:8px 0 8px 20px}
.legal a{color:var(--orange);font-weight:600}
.legal .upd{font-size:.85rem;color:var(--muted);margin-top:34px;font-style:italic}

/* PRÉSENTATION */
.intro-prose{max-width:760px;margin:30px auto 0;text-align:center}
.intro-prose p{color:var(--muted);font-size:1.08rem;line-height:1.85;margin-bottom:18px}
.intro-prose p:first-of-type{color:var(--ink);font-size:1.18rem}

/* ZONE DE DÉPÔT (upload admin) */
.dropzone{border:2px dashed var(--line);border-radius:14px;padding:20px;text-align:center;cursor:pointer;background:var(--cream-2);color:var(--muted);font-size:.9rem;transition:.18s ease}
.dropzone:hover,.dropzone.drag{border-color:var(--orange);background:#FFF6E8;color:var(--ink)}
.dropzone .dz-link{color:var(--orange);font-weight:600;text-decoration:underline}
.dz-preview{margin-top:10px;display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.dz-preview img{max-height:80px;border-radius:8px;border:1px solid var(--line);background:#fff;padding:4px}
.dz-preview .dz-file{font-size:.88rem;color:var(--teal)}
.dz-clear{background:none;border:0;color:#b3261e;font-size:.82rem;cursor:pointer;text-decoration:underline}
.dz-url{margin-top:8px}

/* CHAMP MOT DE PASSE (œil) */
.pw-wrap{position:relative}
.pw-wrap input{width:100%;padding-right:46px;box-sizing:border-box}
.pw-eye{position:absolute;top:50%;right:6px;transform:translateY(-50%);background:none;border:0;cursor:pointer;font-size:1.05rem;line-height:1;opacity:.55;padding:6px}
.pw-eye:hover,.pw-eye.on{opacity:1}

/* LISTE ADMIN : vignette + édition en place */
.row-thumb{width:42px;height:42px;border-radius:8px;object-fit:contain;background:#fff;border:1px solid var(--line);padding:3px;flex:0 0 auto}
.row-thumb.empty{background:var(--cream-2)}
.inline-edit{background:var(--cream-2);border:1px solid var(--orange-soft);border-radius:14px;padding:18px 18px 6px;margin-bottom:12px}

/* ZENNIZ — court connecté */
.zenniz{background:linear-gradient(120deg,var(--teal),var(--teal-700));border-radius:28px;color:#fff;padding:54px;position:relative;overflow:hidden}
.zenniz:before{content:"";position:absolute;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(240,144,0,.28),transparent 70%);top:-90px;right:-60px}
.zen-head{position:relative;max-width:700px}
.zen-head h2{color:#fff;font-size:clamp(1.7rem,3.4vw,2.5rem);margin:6px 0 14px}
.zen-head p{opacity:.9;font-size:1.05rem;line-height:1.75}
.zen-grid{position:relative;display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin:34px 0 28px}
.zen-card{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:22px;backdrop-filter:blur(6px)}
.zen-card .zi{font-size:1.6rem;display:block;margin-bottom:8px}
.zen-card h3{color:#fff;font-size:1.12rem;margin-bottom:6px}
.zen-card p{opacity:.85;font-size:.92rem;line-height:1.6}
.zen-cta{position:relative;display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.zen-link{color:#fff;opacity:.85;font-size:.92rem;font-weight:600}
.zen-link:hover{opacity:1;color:var(--orange-soft)}
.zen-note{position:relative;opacity:.8;font-size:.88rem;margin-top:18px}
.btn.light{background:transparent;border:1.5px solid rgba(255,255,255,.55);color:#fff}
.btn.light:hover{background:rgba(255,255,255,.12)}
@media(max-width:760px){.zenniz{padding:34px 26px}.zen-grid{grid-template-columns:1fr}}

/* PARTENAIRES */
.partner-tier{margin-bottom:44px}
.partner-tier .gtitle{font-size:1.4rem;color:var(--teal);margin-bottom:22px;display:flex;align-items:center;gap:12px}
.partner-tier .gtitle:before{content:"";width:30px;height:3px;background:var(--orange);border-radius:3px}
.partner-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.partner{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;text-align:center;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;display:block}
.partner:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--orange)}
.partner .logo{height:84px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.partner .logo img{max-height:84px;max-width:100%;object-fit:contain}
.partner b{color:var(--teal);display:block;font-family:'Bricolage Grotesque';font-size:1.02rem}
.partner p{font-size:.83rem;color:var(--muted);margin-top:6px;line-height:1.5}
.partner-strip{display:flex;flex-wrap:wrap;gap:34px;align-items:center;justify-content:center}
.partner-strip img{height:42px;max-width:120px;object-fit:contain;filter:grayscale(1);opacity:.65;transition:.25s ease}
.partner-strip img:hover{filter:none;opacity:1}

/* TOURNOIS */
.tourn-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.tourn{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:28px;transition:transform .25s ease,box-shadow .25s ease}
.tourn:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.tourn-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:12px;border:1px solid var(--line);margin-bottom:16px;cursor:zoom-in;display:block}
.tourn .top{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:6px}
.tourn .cat{font-size:.78rem;color:var(--orange);font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.tourn h3{color:var(--teal);font-size:1.3rem;margin:2px 0}
.tourn .dates{font-size:.88rem;color:var(--muted);margin-bottom:12px}
.tourn p{color:var(--muted);font-size:.92rem;margin-bottom:16px}
.stat-pill{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:4px 11px;border-radius:100px;white-space:nowrap}
.stat-pill.encours{background:#E8F5EF;color:#0c6b4d}
.stat-pill.avenir{background:#FFF6E8;color:#8a6406}
.stat-pill.termine{background:#ececec;color:#777}

/* ACTU / NEWSLETTER */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.news{background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;transition:transform .25s ease,box-shadow .25s ease}
.news:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.news .ph{height:200px;background:linear-gradient(135deg,var(--orange-soft),var(--orange))}
.news .ph.img{background:#fff;background-size:contain;background-repeat:no-repeat;background-position:center;cursor:zoom-in}
.lightbox{position:fixed;inset:0;z-index:9999;background:rgba(10,24,24,.9);display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lightbox[hidden]{display:none}
.lightbox img{max-width:92vw;max-height:90vh;border-radius:10px;box-shadow:0 24px 70px rgba(0,0,0,.55)}
.lightbox .lb-close{position:absolute;top:18px;right:24px;color:#fff;font-size:34px;line-height:1;background:none;border:none;cursor:pointer;opacity:.85}
.news .ph.alt{background:linear-gradient(135deg,var(--teal-700),var(--teal))}
.news .ph.alt2{background:linear-gradient(135deg,#E9DCC6,#cdb48a)}
.news .body{padding:22px}
.news .date{font-size:.78rem;color:var(--orange);font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.news h3{color:var(--teal);font-size:1.18rem;margin:8px 0}
.news p{color:var(--muted);font-size:.9rem}
.actu-list{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.nl-list{display:flex;flex-direction:column;gap:12px}
.nl-item{display:flex;justify-content:space-between;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px 22px;transition:border-color .2s ease}
.nl-item:hover{border-color:var(--orange)}
.nl-item b{color:var(--teal);font-family:'Bricolage Grotesque'}
.nl-item span{font-size:.84rem;color:var(--muted)}

/* RESPONSIVE */
@media(max-width:900px){
  .navlinks{display:none}
  .burger{display:flex}
  header.menu-open .navlinks{display:flex;flex-direction:column;align-items:flex-start;position:absolute;top:100%;left:0;right:0;background:var(--cream);border-bottom:1px solid var(--line);padding:20px 28px;gap:18px;box-shadow:var(--shadow)}
  header.menu-open .navlinks a{color:var(--teal);opacity:1}
  header.menu-open.on-dark .navlinks a{color:var(--teal)}
  .stats-inner{grid-template-columns:1fr 1fr;gap:34px}
  .school-grid,.tarif-grid,.inst-grid,.social-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .partner-grid{grid-template-columns:1fr 1fr}
  .tourn-grid,.actu-list,.news-grid{grid-template-columns:1fr}
  .nl-item{flex-direction:column;align-items:flex-start;gap:6px}
  .compet{grid-template-columns:1fr;padding:40px 30px}
  .foot-grid{grid-template-columns:1fr 1fr}
  .grid2{grid-template-columns:1fr}
  .form-wrap{padding:28px}
}
