/* katalima.css — Programme Katalima (clean) */

.programme-page{
  max-width:var(--maxw);
  margin:0 auto;
  padding:44px 16px 70px;
}

/* ===== HERO ===== */
.prog-hero{ text-align:center; padding:8px 0 26px; }

.prog-title{
  margin:0 0 10px;
  font-family:var(--ff-serif);
  font-weight:900;
  font-size:2.6rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--violet);
}

.prog-subtitle{
  margin:0 auto;
  max-width:820px;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-size:1.25rem;
  line-height:1.6;
  color:var(--ink);
}

/* ===== MEDIA ===== */
.prog-media{ padding:8px 0 18px; }

.media-grid{ display:grid; grid-template-columns:1fr 1fr; gap:28px; }

.media-card{
  position:relative;
  min-height:300px;
  border-radius:26px;
  background:radial-gradient(160% 200% at 50% 40%, var(--g1) 0%, var(--g2) 38%, var(--g3) 68%, var(--g4) 100%);
  box-shadow:0 0 0 1px rgba(230,231,255,.36), 0 14px 30px rgba(198,201,255,.55), 0 4px 10px rgba(0,0,0,.12);
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}

.media-card img{ width:100%; height:100%; object-fit:cover; display:block; }

.media-card--placeholder{
  color:#111;
  font-family:var(--ff-accent);
  font-weight:900;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.9rem;
  opacity:.9;
}

/* ===== AXIOM ===== */
.prog-axiom{ padding:6px 0 18px; text-align:center; }

.prog-axiom-text{
  margin:0 auto;
  max-width:980px;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-size:1.2rem;
  line-height:1.7;
  letter-spacing:.08em;
  color:#111;
}

/* ===== TEXTE + LISTES ===== */
.prog-points{ padding:8px 0 30px; }

.checklist{
  list-style:none;
  margin:0 auto;
  padding:0;
  max-width:900px;
  display:grid;
  gap:12px;
  color:var(--ink);
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-size:1.15rem;
  line-height:1.7;
}

.checklist > li{ position:relative; padding-left:26px; }

.checklist > li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:var(--violet);
  font-weight:900;
}

.subchecklist{
  margin:8px 0 0;
  padding-left:22px;
  list-style:disc;
  font-family:inherit;
  font-size:1.05rem;
  line-height:1.6;
}

/* ===== PROJETS OIKOS ===== */
.oikos{ padding:32px 0 40px; }

.oikos-title{
  margin:0 0 10px;
  text-align:center;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-weight:900;
  font-size:2.3rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--violet);
}

.oikos-intro{
  margin:0 auto 24px;
  max-width:820px;
  text-align:center;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-size:1.15rem;
  line-height:1.7;
  color:var(--ink);
}

.oikos-project{ margin-top:30px; }

.oikos-project-title{
  margin:0 0 10px;
  text-align:center;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-weight:900;
  font-size:1.55rem;          /* même taille que Paidion */
  letter-spacing:.20em;       /* même vibe */
  text-transform:uppercase;
  color:var(--violet);
}

.oikos-subtitle{
  margin:0 auto 14px;
  max-width:920px;
  text-align:center;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-size:1.15rem;
  line-height:1.6;
  color:var(--ink);
}

.oikos-panels{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:18px 32px;
}

/* EXACT style violet tres clair (ta photo) */
.oikos-panel{
  border-radius:18px;
  padding:22px 20px 20px;
  background:
    radial-gradient(160% 200% at 50% 40%,
      rgba(255,255,255,.9) 0%,
      rgba(203,207,252,.96) 45%,
      rgba(157,163,234,.96) 100%);
  box-shadow:
    0 0 0 1px rgba(230,231,255,.9),
    0 10px 20px rgba(158,168,255,.5);
  color:#111;
}

/* demandé : label centré mais contenu (puces) à gauche */
.oikos-label{
  margin:0 0 8px;
  font-family:Impact,system-ui,sans-serif;
  font-weight:700;
  font-size:1.2rem;
  text-transform:uppercase;
  letter-spacing:.10em;
  color:var(--violet);
  text-align:center;
}

.oikos-list{
  margin:0;
  padding-left:22px;
  list-style:disc;
  font-family:"Big Caslon","Bodoni Moda",var(--ff-serif),Georgia,serif;
  font-size:1.05rem;
  line-height:1.6;
  color:var(--ink);
  text-align:left;
}

.oikos-list li{ margin:0 0 6px; }

/* ===== RESPONSIVE ===== */
@media (max-width:900px){
  .media-grid{ grid-template-columns:1fr; }
  .oikos-panels{ grid-template-columns:1fr; gap:18px; }
}

@media (max-width:640px){
  .prog-title{ font-size:2.1rem; letter-spacing:.18em; }
  .prog-axiom-text{ font-size:1.05rem; letter-spacing:.06em; }
}
