/* assets/css/style.css */

/* =========================
   VARIABLES + BASE
========================= */
:root{
  --teal:#008081;
  --teal-dark:#3d9b94;
  --yellow:#fed601;
  --cream:#fce9da;
  --text:#0f2a2a;
  --muted:#3e5a5a;
  --radius:16px;
  --shadow:0 12px 40px rgba(0,0,0,.08);
}

*{ box-sizing:border-box; }
html,body{ height:100%; max-width:100%; overflow-x:hidden; }

body{
  margin:0;
  font-family:'Manrope',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--cream);
  line-height:1.6;
}

main{ display:block; width:100%; }

img,iframe{ max-width:100%; display:block; }
a{ color:var(--teal); text-decoration:none; }
a:hover{ color:var(--teal-dark); }

/* Focus style (keyboard friendly) */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline:2px solid var(--teal);
  outline-offset:3px;
}

/* =========================
   HEADER / NAV
========================= */
.topbar{
  position:sticky;
  top:0;
  z-index:20000; /* header stays above page content */
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:12px 24px;
  background:rgba(252,233,218,.90);
  backdrop-filter:blur(6px);
  border-bottom:1px solid rgba(0,0,0,.05);
}

.logo-area{ display:flex; align-items:center; gap:12px; }

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  color:var(--text);
  min-width:0;
}

/* ✅ LOGO: keep white square SAME size, make image inside BIGGER */
.logo{
  width:56px;               /* square stays same */
  height:56px;
  border-radius:12px;
  background:#fff;
  box-shadow:var(--shadow);

  display:flex;
  align-items:center;
  justify-content:center;

  padding:3px;              /* smaller padding -> logo appears bigger */
  overflow:hidden;          /* hides zoomed edges cleanly */
  flex-shrink:0;
}

/* If your HTML is: <div class="logo"><img ...></div> */
.logo img{
  width:100%;
  height:100%;
  object-fit:contain;

  transform:scale(6);    /* ✅ zoom logo inside square */
  transform-origin:center;
}

/* If your HTML is: <img class="logo" src="..."> (rare, but safe) */
img.logo{
  width:56px;
  height:56px;
  border-radius:12px;
  background:#fff;
  box-shadow:var(--shadow);
  padding:3px;
  object-fit:contain;

  transform:scale(1.18);
  transform-origin:center;
}

.brand-name{ font-weight:800; display:block; }

.main-nav{
  display:flex;
  align-items:center;
  gap:18px;
}

.main-nav a{
  font-weight:700;
  color:var(--text);
  padding:8px 10px;
  border-radius:12px;
}

/* Active menu */
.main-nav a[aria-current="page"]{
  background:rgba(0,128,128,.10);
  color:var(--text);
}

.btn{
  background:var(--teal);
  color:#fff;
  padding:10px 18px;
  border-radius:999px;
  border:2px solid transparent;
  transition:transform .15s ease, background .2s ease, color .2s ease, border-color .2s ease;
  box-shadow:var(--shadow);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}
.btn:hover{
  background:var(--yellow);
  color:var(--text);
  border-color:var(--teal);
  transform:translateY(-1px);
}

.nav-toggle{
  display:none;
  background:none;
  border:none;
  font-size:24px;
  cursor:pointer;
  color:var(--text);
}

/* Overlay exists in header.php */
.nav-overlay{ display:none; }

/* =========================
   LAYOUT BLOCKS
========================= */
.section{
  padding:60px 24px;
  max-width:1180px;
  margin:0 auto;
}

.section h2{ margin:0 0 12px; font-size:2rem; }
.section p.lead{ color:var(--muted); max-width:720px; }

.grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(240px, 1fr));
  gap:20px;
}

.card{
  background:#fff;
  padding:18px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  transition:transform .2s ease, box-shadow .2s ease;
}
.card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px rgba(0,0,0,.10);
}

/* =========================
   HERO
========================= */
.hero{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:32px;
  padding:80px 24px 60px;
  align-items:center;
  max-width:1180px;
  margin:0 auto;
}

.hero h1{ font-size:2.4rem; margin:0 0 12px; }
.hero p{ font-size:1.1rem; color:var(--muted); }

.breadcrumb{ display:flex; gap:8px; font-size:.95rem; margin-bottom:12px; }
.breadcrumb a{ color:var(--muted); }

.hero .cta-group{
  display:flex;
  gap:12px;
  margin-top:16px;
  flex-wrap:wrap;
}

.stat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:16px;
  margin:32px 0;
}

.stat{
  background:#fff;
  padding:18px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  text-align:center;
}

/* Programs list */
.program{ list-style:none; padding:0; margin:0; }
.program li{
  padding:8px 12px;
  background:rgba(0,0,0,.04);
  border-radius:10px;
  margin-bottom:8px;
}

/* =========================
   ABOUT (no absolute)
========================= */
#about{
  display:grid;
  grid-template-columns:1fr 320px;
  align-items:center;
  gap:48px;
}

.about-text{ min-width:0; }

.about-paragraph{
  margin:0 0 18px;
  line-height:1.8;
  color:var(--muted);
  max-width:70ch;
}

.about-image{
  display:flex;
  justify-content:flex-end;
}

.about-image img{
  width:220px;
  max-width:100%;
  height:auto;
}

/* =========================
   CERTIFICATES
========================= */
.tag{
  display:inline-block;
  padding:6px 10px;
  border-radius:12px;
  background:var(--yellow);
  color:var(--text);
  font-weight:800;
  font-size:.85rem;
}

.cert-logos{
  margin-top:18px;
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  align-items:center;
  justify-content:center;
}

.cert-logos img{
  height:110px;
  width:auto;
  max-width:100%;
  object-fit:contain;
  background:#fff;
  border-radius:16px;
  padding:14px 18px;
  box-shadow:0 12px 32px rgba(0,0,0,.08);
}

@media (max-width:768px){
  .cert-logos img{ height:70px; padding:12px 16px; }
}

/* =========================
   SESSIONS
========================= */
.sessions-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:22px;
  margin-top:18px;
  align-items:stretch;
}

@media (max-width:1100px){
  .sessions-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
}

@media (max-width:650px){
  .sessions-grid{ grid-template-columns:1fr; }
}

.session-card img{
  width:100%;
  border-radius:12px;
  height:160px;
  object-fit:cover;
}

.session-card .session-meta{
  display:flex;
  gap:10px;
  margin-top:12px;
  margin-bottom:14px;
  flex-wrap:wrap;
}

.session-card .pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:7px 12px;
  border-radius:999px;
  font-size:13px;
  font-weight:800;
  line-height:1;
}

.session-card .pill-onsite{
  background:var(--yellow);
  color:#1a1a1a;
}

.session-card .pill-online{
  background:rgba(0,128,128,.12);
  color:#006b6b;
  border:1px solid rgba(0,128,128,.25);
}

.session-card .btn.btn-card{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 18px;
  border-radius:999px;
  font-weight:800;
}

/* =========================
   FAQ (hidden + aria)
========================= */
.faq{ margin-top:18px; }

.faq-item{
  border-bottom:1px solid rgba(0,0,0,.08);
  padding:8px 0;
}

.faq-question{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  background:transparent;
  border:0;
  padding:16px 0;
  text-align:left;
  cursor:pointer;
  font-weight:800;
  font-size:1rem;
  color:var(--text);
}

.faq-icon{
  font-size:22px;
  line-height:1;
  font-weight:900;
}

.faq-answer[hidden]{ display:none !important; }

.faq-answer{
  padding:0 0 16px 0;
  max-width:75ch;
  color:var(--muted);
}

/* =========================
   FORMS
========================= */
.form-card{
  background:#fff;
  padding:20px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

form{ display:grid; gap:12px; }
label{ font-weight:700; }

input,textarea,select{
  width:100%;
  padding:12px;
  border-radius:12px;
  border:1px solid rgba(0,0,0,.10);
  font-family:inherit;
  background:#fff;
  color:var(--text);
}

.success{ color:#0f7f3f; font-weight:800; }
.error{ color:#b00020; font-weight:800; }

/* =========================
   MAP
========================= */
.map-embed iframe{
  width:100%;
  border:none;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  min-height:280px;
  background:#fff;
}

/* =========================
   FOOTER (match footer.php)
========================= */
.site-footer{
  background:#0b3f3f;
  color:#e9f3f3;
  padding:40px 24px 16px;
}

.site-footer a{ color:rgba(233,243,243,.92); }
.site-footer a:hover{ color:#fff; text-decoration:underline; }

.footer-inner{
  max-width:1200px;
  margin:0 auto;
}

.footer-top{
  display:grid;
  grid-template-columns:1.2fr 1fr 1fr 1.3fr;
  gap:42px;
  align-items:start;
}

.footer-col h4{
  margin:0 0 14px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(233,243,243,.85);
}

.footer-col p{
  margin:0 0 10px;
  color:rgba(233,243,243,.92);
  line-height:1.65;
}

.footer-col a{
  display:block;
  margin:0 0 10px;
  line-height:1.6;
}

.footer-col--newsletter h4{
  font-size:20px;
  text-transform:none;
  letter-spacing:0;
  color:#e9f3f3;
}

.footer-newsletter{
  margin-top:14px;
  display:grid;
  gap:10px;
  max-width:340px;
}

.footer-newsletter input{
  width:100%;
  border:1px solid rgba(255,255,255,.20);
  background:rgba(255,255,255,.08);
  color:#fff;
  border-radius:10px;
  padding:12px;
  outline:none;
}

.footer-newsletter input::placeholder{ color:rgba(255,255,255,.7); }

.footer-newsletter input:focus{
  border-color:rgba(255,255,255,.45);
  background:rgba(255,255,255,.12);
}

.footer-btn{
  width:fit-content;
  padding:10px 16px;
  border:0;
  border-radius:10px;
  font-weight:800;
  cursor:pointer;
  background:rgba(255,255,255,.90);
  color:#0b3f3f;
  transition:transform .15s ease, background .15s ease;
}

.footer-btn:hover{
  transform:translateY(-1px);
  background:#fff;
}

.footer-divider{
  margin:26px 0 14px;
  height:1px;
  background:rgba(255,255,255,.14);
}

.footer-bottom{
  text-align:center;
  margin-top:0;
  color:rgba(233,243,243,.85);
  font-size:14px;
  padding-bottom:0;
}

/* Social icons (icons only, no circles) */
.footer-social{
  display:flex;
  gap:14px;
  margin-top:14px;
  align-items:center;
  flex-wrap:wrap;
}

.footer-social .social-icon{
  background:none;
  border:none;
  padding:0;
  margin:0;
  color:#fff !important;
  text-decoration:none;
  font-size:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:opacity .2s ease;
}

.footer-social .social-icon:hover{ opacity:.7; }

@media (max-width:1000px){
  .footer-top{ grid-template-columns:1fr 1fr; }
  .footer-col--newsletter{ grid-column:1 / -1; }
}
@media (max-width:600px){
  .site-footer{ padding:34px 16px 14px; }
  .footer-top{ grid-template-columns:1fr; gap:26px; }
  .footer-newsletter{ max-width:100%; }
}

/* =========================
   REVEAL
========================= */
.reveal{
  opacity:1;
  transform:none;
  transition:all .6s ease;
}
body.js-enabled .reveal{
  opacity:0;
  transform:translateY(20px);
}
body.js-enabled .reveal.visible{
  opacity:1;
  transform:translateY(0);
}

/* =====================================================
   RESPONSIVE NAV + LAYOUT (MOBILE)
   ✅ HARD FIX: menu links ALWAYS clickable
===================================================== */
@media (max-width:900px){
  .hero{
    grid-template-columns:1fr;
    padding:60px 16px;
  }

  /* About stacks */
  #about{
    grid-template-columns:1fr;
    text-align:center;
    gap:26px;
  }
  .about-image{ justify-content:center; }
  .about-image img{ width:180px; }

  /* Toggle visible */
  .nav-toggle{
    display:block;
    position:relative;
    z-index:10002;
  }

  /* Overlay MUST be below nav */
  .nav-overlay{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,.35);
    z-index:10000;
    display:none;
    pointer-events:auto;
  }
  body.nav-open .nav-overlay{
    display:block;
  }

  /* Drawer MUST be above overlay */
  .main-nav{
    position:fixed;
    top:0;
    right:0;
    height:100vh;
    width:min(86vw, 360px);
    padding:18px;
    background:rgba(15,42,42,.96);

    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    align-items:flex-start;
    gap:12px;

    transform:translateX(110%);
    transition:transform .25s ease;

    z-index:10001;
    pointer-events:auto;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }

  body.nav-open .main-nav,
  .main-nav.active{
    transform:translateX(0);
  }

  /* Links must accept touch */
  .main-nav a{
    color:#fff;
    font-size:1.1rem;
    width:100%;
    padding:14px 14px;
    border-radius:12px;
    pointer-events:auto;
  }

  .main-nav a[aria-current="page"]{
    background:rgba(255,255,255,.12);
    color:#fff;
  }
}

/* Helpers */
.muted{ color:var(--muted); }
.section.hero-detail{ padding-top:40px; }

/* =========================================
   MODE TOGGLE (INSCRIPTION PAGE)
   Highlight selected format clearly
========================================= */

.mode-toggle{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:18px;
}

.mode-toggle button{
  border:2px solid transparent;
  background:var(--teal);
  color:#fff;
  font-weight:800;
  padding:10px 18px;
  border-radius:999px;
  cursor:pointer;
  transition:.2s;
}

/* ✅ ACTIVE BUTTON = YELLOW */
.mode-toggle button.active{
  background:var(--yellow);
  color:var(--text);
  border-color:var(--teal);
  box-shadow:0 6px 18px rgba(0,0,0,.12);
}

/* Hover */
.mode-toggle button:hover{
  transform:translateY(-2px);
}


/* =========================================
   SESSION SELECT FILTERED LIST
========================================= */

select option.hidden-option{
  display:none;
}


/* =========================================
   ADMIN INSCRIPTIONS CARD DESIGN
========================================= */

.admin-inscriptions{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:18px;
  margin-top:16px;
}

.admin-ins-card{
  background:#fff;
  border-radius:18px;
  padding:16px;
  box-shadow:0 10px 30px rgba(0,0,0,.08);
  transition:.2s;
}

.admin-ins-card:hover{
  transform:translateY(-4px);
}

.admin-ins-card h4{
  margin:0;
  font-size:16px;
  font-weight:900;
}

.admin-ins-meta{
  margin-top:8px;
  font-size:13px;
  color:var(--muted);
  line-height:1.5;
}


/* =========================================
   BADGES (Présentiel / En ligne)
========================================= */

.badge{
  display:inline-flex;
  padding:6px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:900;
}

.badge-presentiel{
  background:var(--yellow);
  color:#000;
}

.badge-online{
  background:rgba(0,128,128,.15);
  color:var(--teal);
  border:1px solid rgba(0,128,128,.25);
}
