/* ===========================================================
   LES RETRAITÉS DE LA VIMEUSE
   École : rétro-vintage convivial — bulletin de club, affiche d'antan
   =========================================================== */
:root{
  --bordeaux:#7A2E2E;
  --bordeaux-d:#5f2222;
  --moutarde:#D9A441;
  --moutarde-d:#b9852a;
  --bouteille:#2F5D50;
  --bouteille-d:#234539;
  --cream:#F4EAD2;
  --cream-2:#FBF4E2;
  --paper:#FCF8EC;
  --ink:#33271a;
  --muted:#7c6c52;
  --line:#d8c49a;
  --maxw:1120px;
  --disp:"Yeseva One",Georgia,serif;
  --script:"Sacramento",cursive;
  --body:"Libre Franklin",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);background:var(--cream);color:var(--ink);line-height:1.75;font-size:17px;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--disp);font-weight:400;line-height:1.12;color:var(--bordeaux)}
h1{font-size:clamp(2.5rem,6vw,4.6rem)}
h2{font-size:clamp(1.9rem,3.8vw,2.9rem)}
h3{font-size:1.4rem}
p{margin-bottom:1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 26px}
.lead{font-size:1.2rem}
.muted{color:var(--muted)}
.script{font-family:var(--script);color:var(--moutarde-d);font-size:2.2rem;line-height:1}
section{padding:80px 0}
.center{text-align:center}
.orn{color:var(--moutarde);letter-spacing:.4em}
.flourish{display:flex;align-items:center;justify-content:center;gap:16px;color:var(--moutarde);margin:10px 0}
.flourish::before,.flourish::after{content:"";height:1px;width:60px;background:var(--moutarde)}

.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:700;font-size:.92rem;text-transform:uppercase;letter-spacing:.08em;padding:14px 28px;border:2px solid var(--bordeaux);background:var(--bordeaux);color:var(--cream);cursor:pointer;transition:.16s}
.btn:hover{background:var(--bordeaux-d)}
.btn-mout{background:var(--moutarde);border-color:var(--moutarde);color:var(--bordeaux-d)}.btn-mout:hover{background:var(--moutarde-d);border-color:var(--moutarde-d)}
.btn-bout{background:var(--bouteille);border-color:var(--bouteille);color:var(--cream)}.btn-bout:hover{background:var(--bouteille-d);border-color:var(--bouteille-d)}
.btn-out{background:transparent;color:var(--bordeaux)}.btn-out:hover{background:var(--bordeaux);color:var(--cream)}

/* badge label */
.badge{display:inline-block;font-family:var(--body);font-weight:700;text-transform:uppercase;letter-spacing:.16em;font-size:.74rem;color:var(--cream);background:var(--bouteille);padding:6px 16px;border-radius:999px}

/* header — masthead vintage */
.topband{background:var(--bordeaux);color:var(--moutarde);text-align:center;font-family:var(--body);font-weight:600;text-transform:uppercase;letter-spacing:.24em;font-size:.7rem;padding:7px}
.hdr{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:3px double var(--bordeaux)}
.nav{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{width:52px;height:52px}
.brand b{font-family:var(--disp);font-size:1.2rem;color:var(--bordeaux);line-height:1}
.brand small{display:block;font-family:var(--script);font-size:1.25rem;color:var(--moutarde-d);line-height:1}
.nav-links{display:flex;gap:2px;list-style:none;align-items:center}
.nav-links a{padding:9px 13px;font-family:var(--body);font-weight:600;font-size:.9rem;color:var(--ink)}
.nav-links a:hover,.nav-links a.active{color:var(--bordeaux)}
.nav-links .cta{background:var(--moutarde);color:var(--bordeaux-d);font-weight:700}
.burger{display:none;width:46px;height:42px;border:2px solid var(--bordeaux);background:transparent;cursor:pointer}
.burger span{display:block;width:20px;height:2px;background:var(--bordeaux);margin:4px auto}

/* HERO — affiche encadrée */
.hero{padding:60px 0}
.hero .frame{border:3px double var(--bordeaux);background:var(--paper);padding:54px 40px;text-align:center;position:relative;box-shadow:8px 8px 0 var(--moutarde)}
.hero .corner{position:absolute;width:18px;height:18px;border:3px solid var(--moutarde)}
.hero .c1{top:8px;left:8px;border-right:0;border-bottom:0}
.hero .c2{top:8px;right:8px;border-left:0;border-bottom:0}
.hero .c3{bottom:8px;left:8px;border-right:0;border-top:0}
.hero .c4{bottom:8px;right:8px;border-left:0;border-top:0}
.hero img.medal{width:88px;height:88px;margin:0 auto 8px}
.hero .script{font-size:2.6rem;margin-bottom:-6px}
.hero h1{margin:6px 0}
.hero p{max-width:46ch;margin:10px auto 0;font-size:1.18rem}
.hero .acts{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:26px}

/* ruban citations défilant -> static ribbon */
.ribbon{background:var(--bouteille);color:var(--cream);text-align:center;padding:16px;font-family:var(--disp);font-size:1.3rem;border-top:3px solid var(--moutarde);border-bottom:3px solid var(--moutarde)}
.ribbon .orn{color:var(--moutarde);margin:0 14px}

/* presentation */
.split{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.split.rev .m{order:2}
.split .m{border:3px solid var(--bordeaux);padding:8px;background:var(--paper);box-shadow:7px 7px 0 var(--bouteille)}
.split .m img{width:100%;height:100%;object-fit:cover;min-height:300px}

/* activities vignettes (framed) */
.vignettes{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.vignette{background:var(--paper);border:2px solid var(--bordeaux);padding:0;box-shadow:6px 6px 0 var(--moutarde);transition:.18s}
.vignette:hover{transform:translate(-3px,-3px);box-shadow:9px 9px 0 var(--moutarde)}
.vignette .top{background:var(--bordeaux);color:var(--cream);text-align:center;padding:10px;font-family:var(--disp);font-size:1.15rem;letter-spacing:.02em}
.vignette .bd{padding:22px 22px 26px;text-align:center}
.vignette .ic{font-size:2rem;color:var(--bouteille);margin-bottom:10px}
.vignette p{margin:0;color:var(--muted);font-size:.96rem}

/* calendrier / bill */
.calendar{border:3px double var(--bordeaux);background:var(--paper)}
.calendar .it{display:grid;grid-template-columns:auto 1fr;gap:22px;padding:18px 26px;border-bottom:1px dashed var(--line);align-items:center}
.calendar .it:last-child{border-bottom:0}
.calendar .dot{width:54px;height:54px;border-radius:50%;background:var(--moutarde);color:var(--bordeaux-d);display:grid;place-items:center;font-family:var(--disp);font-size:1rem;text-align:center;line-height:1.05;flex:0 0 auto}
.calendar h3{margin:0 0 2px;font-size:1.25rem}
.calendar p{margin:0;color:var(--muted)}

/* stats / club en chiffres */
.figs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:3px double var(--bordeaux);background:var(--paper)}
.figs .f{padding:30px 22px;text-align:center;border-right:1px dashed var(--line)}
.figs .f:last-child{border-right:0}
.figs .n{font-family:var(--disp);font-size:2.6rem;color:var(--bordeaux)}
.figs .l{color:var(--muted);font-size:.92rem;margin-top:4px}

/* gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gal figure{border:2px solid var(--bordeaux);padding:6px;background:var(--paper);box-shadow:4px 4px 0 var(--bouteille)}
.gal img{width:100%;height:200px;object-fit:cover}

/* ticket / adhésion */
.ticket{border:3px dashed var(--bordeaux);background:var(--paper);padding:36px;display:grid;grid-template-columns:1.3fr 1fr;gap:30px;align-items:center;position:relative}
.ticket .punch{position:absolute;top:50%;width:26px;height:26px;border-radius:50%;background:var(--cream);border:3px dashed var(--bordeaux);transform:translateY(-50%)}
.ticket .pl{left:-15px;border-right:0}.ticket .pr{right:-15px;border-left:0}

/* testimonial */
.testi{background:var(--bordeaux);color:var(--cream);text-align:center}
.testi blockquote{font-family:var(--disp);font-size:clamp(1.5rem,3vw,2.2rem);line-height:1.3;max-width:24ch;margin:0 auto 14px;color:var(--cream)}
.testi .who{font-family:var(--script);font-size:1.8rem;color:var(--moutarde)}

/* cta */
.cta{background:var(--moutarde);text-align:center}
.cta h2{color:var(--bordeaux-d)}.cta p{max-width:46ch;margin:12px auto 24px;color:var(--bordeaux-d);font-weight:600}

/* page hero */
.page-hero{background:var(--bordeaux);color:var(--cream);text-align:center;padding:60px 0;border-bottom:4px solid var(--moutarde)}
.page-hero .script{color:var(--moutarde);font-size:2.4rem}
.page-hero h1{color:var(--cream);margin-top:-4px}
.page-hero p{max-width:56ch;margin:10px auto 0;color:#f1e4c8}

/* prose */
.prose{max-width:720px;margin:0 auto}
.prose h2{margin:28px 0 10px;font-size:1.7rem}
.prose p,.prose li{color:#473826}
.prose ul{padding-left:20px;margin:8px 0;display:grid;gap:7px}

/* contact / legal */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.info{background:var(--paper);border:2px solid var(--bordeaux);padding:20px 22px;margin-bottom:16px;box-shadow:5px 5px 0 var(--moutarde)}
.info h3{margin-bottom:4px;font-size:1.15rem}.info p,.info a{margin:0;color:var(--muted)}.info a{color:var(--bordeaux);font-weight:700}
.legal{background:var(--bouteille);color:var(--cream);padding:24px 26px;box-shadow:5px 5px 0 var(--bordeaux)}
.legal h3{color:var(--moutarde);margin-bottom:10px;font-size:1.2rem}
.legal .row{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px dashed rgba(255,255,255,.3);font-size:.92rem}
.legal .row:last-child{border:0}.legal .row span:first-child{color:#d8e4dd}.legal .row span:last-child{font-weight:700}
.form-card{background:var(--paper);border:3px double var(--bordeaux);padding:30px}
.field{margin-bottom:15px}.field label{display:block;font-family:var(--body);font-weight:700;font-size:.85rem;margin-bottom:6px;color:var(--bordeaux)}
.field input,.field textarea,.field select{width:100%;padding:13px 15px;border:2px solid var(--line);background:#fff;font:inherit}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--moutarde)}
.field textarea{min-height:130px;resize:vertical}
.consent{display:flex;gap:9px;font-size:.84rem;color:var(--muted)}.consent input{width:auto;margin-top:4px}
.map{border:2px solid var(--bordeaux);width:100%;height:280px;margin-top:16px}

/* footer */
.ftr{background:var(--bordeaux-d);color:#e9d6b6;padding:56px 0 24px;border-top:4px solid var(--moutarde)}
.ftr-grid{display:grid;grid-template-columns:1.8fr 1fr 1.3fr;gap:32px}
.ftr .brand b{color:var(--cream)}.ftr .brand small{color:var(--moutarde)}
.ftr h4{font-family:var(--disp);color:var(--moutarde);font-size:1.05rem;margin-bottom:12px}
.ftr ul{list-style:none;display:grid;gap:8px}.ftr a,.ftr li{color:#e9d6b6;font-size:.92rem}.ftr a:hover{color:var(--moutarde)}
.ftr-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;margin-top:38px;padding-top:16px;border-top:1px dashed rgba(217,164,65,.4);font-size:.83rem;color:#c2a578}
.ftr-bottom a{color:#e9d6b6}

.reveal{opacity:0;transform:translateY(18px);transition:.55s}.reveal.in{opacity:1;transform:none}

@media(max-width:900px){
  .split,.contact-grid,.ticket{grid-template-columns:1fr}
  .split.rev .m{order:0}
  .vignettes,.figs,.gal{grid-template-columns:1fr 1fr}
  .figs .f:nth-child(2){border-right:0}
  .ftr-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  .nav-links{position:fixed;inset:80px 0 auto 0;background:var(--paper);flex-direction:column;align-items:stretch;padding:12px;gap:2px;border-bottom:3px double var(--bordeaux);transform:translateY(-150%);transition:.3s}
  .nav-links.open{transform:none}.burger{display:block}
  .vignettes,.figs,.gal{grid-template-columns:1fr}.figs .f{border-right:0}
  .calendar .it{grid-template-columns:1fr;text-align:center;gap:10px}.calendar .dot{margin:0 auto}
  section{padding:56px 0}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important}.reveal{opacity:1;transform:none}}
