:root{
  --ink:#24211c;
  --muted:#6b6255;
  --paper:#fbf3df;
  --paper-2:#fffaf0;
  --line:#d8c7a7;
  --red:#9a2f2f;
  --green:#426b4f;
  --blue:#2f4f68;
  --gold:#c99b4a;
  --shadow:0 18px 45px rgba(44,34,20,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--ink);
  font-family: Georgia, 'Times New Roman', serif;
  line-height:1.72;
  background:
    radial-gradient(circle at 15% 15%, rgba(201,155,74,.12), transparent 28rem),
    radial-gradient(circle at 90% 5%, rgba(66,107,79,.11), transparent 24rem),
    linear-gradient(90deg, rgba(154,47,47,.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(154,47,47,.025) 1px, transparent 1px),
    var(--paper);
  background-size:auto, auto, 42px 42px, 42px 42px, auto;
}
a{color:inherit}
img{max-width:100%;display:block}
.skip{position:absolute;left:-999px;top:auto}.skip:focus{left:1rem;top:1rem;background:white;padding:.7rem 1rem;z-index:20}
.wrap{width:min(1160px, calc(100% - 40px)); margin:auto}
.top-strip{
  background:#2d2419;color:#fff2dc;font-size:.87rem;letter-spacing:.03em;
  padding:.42rem 0;border-bottom:4px double rgba(255,242,220,.35)
}
.top-strip .wrap{display:flex;gap:1rem;justify-content:space-between;align-items:center;flex-wrap:wrap}
.header{
  background:rgba(251,243,223,.93);backdrop-filter: blur(8px);position:sticky;top:0;z-index:10;
  border-bottom:1px solid var(--line);
}
.navbar{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1rem 0}
.brand{display:flex;align-items:center;gap:.8rem;text-decoration:none}
.brand-mark{
  width:58px;height:58px;border:2px solid var(--ink);border-radius:50%;display:grid;place-items:center;
  background:var(--paper-2);box-shadow:inset 0 0 0 5px #ead9b9;font-weight:800;color:var(--red)
}
.brand-title{font-size:1.45rem;font-weight:800;line-height:1;text-transform:uppercase;letter-spacing:.06em}
.brand-title span{display:block;font-size:.74rem;font-weight:500;letter-spacing:.18em;margin-top:.35rem;color:var(--muted)}
nav ul{display:flex;align-items:center;gap:.35rem;list-style:none;margin:0;padding:0;flex-wrap:wrap;justify-content:flex-end}
nav a{display:block;text-decoration:none;padding:.58rem .75rem;border:1px solid transparent;border-radius:999px;font-size:.92rem;font-weight:700}
nav a:hover,nav a.active{border-color:var(--line);background:#fff7e6;color:var(--red)}
.menu-toggle{display:none;background:var(--ink);color:#fff;border:0;border-radius:8px;padding:.6rem .85rem;font-weight:700}
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line)}
.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(36,33,28,.83), rgba(36,33,28,.48), rgba(36,33,28,.2)),url('../img/sport-collectif.webp') center/cover;filter:saturate(.84);}
.hero .wrap{position:relative;min-height:580px;display:grid;grid-template-columns:1fr .72fr;align-items:center;gap:2rem;padding:4rem 0}
.badge{display:inline-flex;align-items:center;gap:.5rem;background:rgba(251,243,223,.92);border:1px solid rgba(216,199,167,.8);padding:.45rem .75rem;border-radius:0;color:var(--red);font-weight:800;letter-spacing:.1em;text-transform:uppercase;font-size:.76rem;box-shadow:5px 5px 0 rgba(0,0,0,.16)}
h1{font-size:clamp(2.55rem,7vw,5.9rem);line-height:.92;margin:.75rem 0;color:#fff4df;text-transform:uppercase;letter-spacing:.015em;text-shadow:0 4px 18px rgba(0,0,0,.35)}
.hero-lead{font-size:clamp(1.08rem,2vw,1.4rem);max-width:660px;color:#fff7e8;margin:0 0 1.5rem}
.hero-actions{display:flex;gap:.85rem;flex-wrap:wrap;margin-top:1.8rem}
.btn{display:inline-block;text-decoration:none;border:2px solid var(--ink);padding:.78rem 1.05rem;font-weight:800;background:var(--gold);box-shadow:5px 5px 0 rgba(0,0,0,.22);transition:.2s transform,.2s box-shadow}
.btn:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 rgba(0,0,0,.22)}
.btn.alt{background:var(--paper-2)}
.notice-board{background:rgba(255,250,240,.93);padding:1.1rem;border:2px solid #382b1e;box-shadow:14px 14px 0 rgba(0,0,0,.22);transform:rotate(1deg)}
.notice-board h2{font-size:1.15rem;margin:.2rem 0 .65rem;color:var(--red);text-transform:uppercase;letter-spacing:.08em}
.notice-board ul{padding-left:1.2rem;margin:.6rem 0}.notice-board li{margin:.35rem 0}.stamp{display:inline-block;border:2px solid var(--red);color:var(--red);padding:.1rem .45rem;text-transform:uppercase;letter-spacing:.12em;font-size:.73rem;transform:rotate(-3deg);font-weight:900}
.section{padding:4.6rem 0}.section.tight{padding:2.8rem 0}.section-title{margin-bottom:2rem;display:grid;gap:.55rem}
.eyebrow{font-family:Arial, sans-serif;color:var(--red);font-size:.78rem;font-weight:900;text-transform:uppercase;letter-spacing:.2em}
h2{font-size:clamp(2rem,4vw,3.5rem);line-height:1.02;margin:0;color:var(--ink)}
h3{font-size:1.45rem;line-height:1.2;margin:.15rem 0 .75rem}.lead{font-size:1.18rem;color:#443a2e;max-width:820px}.grid{display:grid;gap:1.4rem}.two{grid-template-columns:1fr 1fr}.three{grid-template-columns:repeat(3,1fr)}.four{grid-template-columns:repeat(4,1fr)}
.card{background:rgba(255,250,240,.9);border:1px solid var(--line);box-shadow:var(--shadow);padding:1.35rem}.card.ruled{background:linear-gradient(#fffaf0 31px, #ead9b9 32px);background-size:100% 32px}.card.red{border-top:7px solid var(--red)}.card.green{border-top:7px solid var(--green)}.card.blue{border-top:7px solid var(--blue)}
.kicker{font-family:Arial,sans-serif;font-size:.74rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.big-number{font-size:3rem;line-height:1;color:var(--red);font-weight:900}.mini{font-size:.92rem;color:var(--muted)}
.photo-card{position:relative;overflow:hidden;min-height:260px;border:10px solid #fffaf0;box-shadow:var(--shadow);background:#eee}.photo-card img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}.photo-card figcaption{position:absolute;left:0;right:0;bottom:0;background:rgba(36,33,28,.78);color:#fff3dd;padding:.75rem 1rem;font-weight:800}
.timeline{border-left:3px solid var(--red);padding-left:1.1rem;display:grid;gap:1rem}.timeline article{position:relative;background:#fffaf0;border:1px solid var(--line);padding:1rem}.timeline article:before{content:"";position:absolute;left:-1.58rem;top:1.15rem;width:.85rem;height:.85rem;background:var(--red);border:3px solid var(--paper);border-radius:50%}
.callout{background:#2d2419;color:#fff0d6;padding:2rem;border:8px double rgba(255,240,214,.32);box-shadow:var(--shadow)}.callout h2,.callout h3{color:#fff6e6}.callout a{color:#fff6e6}.callout .btn{color:var(--ink)}
.identity{display:grid;gap:.65rem}.identity div{display:grid;grid-template-columns:150px 1fr;gap:1rem;border-bottom:1px dashed var(--line);padding-bottom:.55rem}.identity strong{color:var(--red)}
.gallery{display:grid;grid-template-columns:1.3fr .7fr 1fr;grid-auto-rows:220px;gap:1rem}.gallery figure{margin:0}.gallery .tall{grid-row:span 2}.gallery .wide{grid-column:span 2}.gallery img{height:100%;width:100%;object-fit:cover;border:8px solid #fffaf0;box-shadow:var(--shadow)}
.page-hero{background:#2d2419;color:#fff2dc;padding:4rem 0 2.8rem;border-bottom:8px double rgba(255,242,220,.28)}.page-hero h1{font-size:clamp(2.3rem,5vw,4.4rem);margin:0;color:#fff2dc}.page-hero p{max-width:760px;font-size:1.15rem;color:#ead9b9}
.contact-box{display:grid;grid-template-columns:1fr .8fr;gap:1.5rem}.map-placeholder{min-height:320px;background:repeating-linear-gradient(45deg,#ead9b9 0 12px,#fffaf0 12px 24px);border:2px solid var(--ink);display:grid;place-items:center;text-align:center;padding:2rem}
footer{background:#1f1b16;color:#ead9b9;padding:3rem 0 1.5rem;border-top:8px double rgba(234,217,185,.28)}footer .footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:2rem}footer a{color:#fff4df}.footer-bottom{border-top:1px solid rgba(234,217,185,.18);margin-top:2rem;padding-top:1rem;font-size:.86rem;color:#cdbb9a}
@media(max-width:900px){.hero .wrap,.two,.three,.four,.contact-box,footer .footer-grid{grid-template-columns:1fr}.notice-board{transform:none}.gallery{grid-template-columns:1fr;grid-auto-rows:240px}.gallery .wide{grid-column:auto}.gallery .tall{grid-row:auto}.menu-toggle{display:block}nav{display:none;width:100%}nav.open{display:block}nav ul{justify-content:flex-start;display:grid;gap:.25rem}.navbar{flex-wrap:wrap}.hero .wrap{min-height:auto;padding:3.5rem 0}.identity div{grid-template-columns:1fr}}
