
:root{
  --white:#ffffff;
  --muted:#6b7280;
  --brand:#0b8b3e; /* Senegal green */
  --accent:#e6b800; /* Senegal yellow */
  --highlight:#c62828; /* Senegal red */
  --paper:#fffdf8;
  --card:#ffffff;
  --shadow:0 10px 25px rgba(0,0,0,.08);
  --radius:16px;
  --inner: min(1100px, 92vw);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Manrope, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Helvetica, Arial, sans-serif;color:#111;background:var(--paper);}

a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}

.brand-logo{width:44px;height:44px;border-radius:50%;object-fit:cover;border:2px solid #eee;box-shadow:var(--shadow)}
.footer-logo{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid #eee;margin-right:.6rem}

.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:1000}
.skip-link:focus{left:1rem;top:1rem;width:auto;height:auto;background:#000;color:#fff;padding:.5rem .75rem;border-radius:8px}

.inner{width:var(--inner);margin-inline:auto;padding:clamp(1rem,3vw,1.5rem)}
.section{padding-block:clamp(2.5rem,4vw,4rem)}
.section.alt{background:#fafafa}

.header-grid{display:grid;grid-template-columns:1fr auto;align-items:center;gap:1rem}
.brand{display:flex;gap:.9rem;align-items:center}
.site-title{margin:0;font-weight:800;letter-spacing:.4px}
.site-tagline{margin:.15rem 0 0;color:var(--muted);font-size:.95rem}
.nav a{margin:0 .6rem;font-weight:600}
.nav .btn{margin-left:.5rem}

.hero{position:relative;display:grid;min-height:64vh;place-items:center;background:linear-gradient(135deg, rgba(11,139,62,.07), rgba(230,184,0,.07)), #fff}
.hero-media{position:absolute;inset:0;overflow:hidden}
.hero-media img{width:100%;height:100%;object-fit:cover;filter:saturate(.95) contrast(1.05) brightness(.98)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,0,0,0.45), rgba(0,0,0,0.15), rgba(255,255,255,0));mix-blend:multiply}
.hero-content{position:relative;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.hero h2{font-size:clamp(2rem,5vw,3rem);margin:0 0 .6rem}
.hero p{max-width:60ch;font-size:clamp(1rem,2vw,1.15rem);margin:0 0 1.1rem}
.hero-ctas{display:flex;gap:.75rem;flex-wrap:wrap}
.hero-pattern{position:absolute;bottom:0;left:0;width:100%;height:20px;fill:var(--accent);opacity:.9}

.grid-2{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(1rem,3vw,2rem);align-items:center}
@media (max-width: 860px){.grid-2{grid-template-columns:1fr}}

.big-list{line-height:1.65}
.big-list li{margin:.35rem 0}

.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-top:1rem}
@media (max-width: 920px){.cards{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 560px){.cards{grid-template-columns:1fr}}

.card{background:var(--card);border-radius:var(--radius);padding:1.1rem;box-shadow:var(--shadow);border:1px solid #eee}
.frame{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);border:1px solid #eee;background:#fff}

.dates{list-style:none;padding-left:0;margin:.5rem 0 1rem}
.dates li{display:flex;justify-content:space-between;align-items:center;padding:.8rem 1rem;border:1px solid #eee;border-radius:12px;margin:.5rem 0;background:#fff;box-shadow:var(--shadow)}

.callout{background:linear-gradient(135deg, rgba(198,40,40,.06), rgba(11,139,62,.06));border:1px solid #eee;border-radius:var(--radius);padding:1rem}

.form{display:grid;gap:.8rem;margin-top:.5rem}
.form label{display:grid;gap:.35rem;font-weight:600}
input, textarea{font:inherit;padding:.8rem 1rem;border-radius:12px;border:1px solid #ddd;background:#fff}
input:focus, textarea:focus{outline:3px solid rgba(11,139,62,.2);border-color:#0b8b3e}

.btn{display:inline-block;padding:.8rem 1.05rem;border-radius:14px;border:2px solid transparent;font-weight:800;letter-spacing:.2px}
.btn.primary{background:linear-gradient(135deg, #0b8b3e, #e6b800);color:#fff}
.btn.outline{border-color:#fff;color:#fff;background:transparent}
.btn.ghost{border-color:#ddd;color:#111;background:#fff}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 20px rgba(0,0,0,.08)}

.site-footer{border-top:1px solid #eee;padding-block:1.5rem;background:#fff}
.footer-grid{display:grid;grid-template-columns:auto 1fr 1fr;gap:1rem;align-items:center}
.footer-left{display:flex;align-items:center;gap:.6rem}
@media (max-width: 720px){.footer-grid{grid-template-columns:1fr;gap:.3rem;text-align:center;justify-items:center}}

.muted{color:var(--muted)}
.small{font-size:.9rem;color:var(--muted)}
