/*
Theme Name:  W12 TV
Theme URI:   https://ericbuhler.fr
Author:      Eric Buhler
Author URI:  https://ericbuhler.fr
Description: Thème vitrine premium pour chaîne de télévision généraliste W12. Style lumineux C8/TPMP. Propulsé par Buhler Studio.
Version:     1.0.0
License:     GNU General Public License v2 or later
Text Domain: w12
Tags:        television, media, entertainment, one-page, custom-colors, custom-logo, full-width-template, translation-ready
*/

/* ============================================================
   CSS VARIABLES — PALETTE LUMINEUSE C8/TPMP
============================================================ */
:root {
  --c-bg:           #f0f4ff;
  --c-bg-alt:       #ffffff;
  --c-surface:      #ffffff;
  --c-surface2:     #eef2ff;

  --c-primary:      #0057ff;
  --c-primary-light:#dce8ff;
  --c-cyan:         #00c8e8;
  --c-cyan-light:   #d0f5fb;
  --c-yellow:       #ffe600;
  --c-pink:         #ff3399;
  --c-orange:       #ff6b00;

  --c-text:         #0a0a1a;
  --c-text-muted:   #5a5a7a;
  --c-border:       #dde4ff;
  --c-white:        #ffffff;

  /* Header / Footer overrides (depuis Customizer) */
  --c-header-bg:    rgba(255,255,255,0.88);
  --c-header-text:  #0a0a1a;
  --c-footer-bg:    #0a0a1a;
  --c-footer-text:  rgba(255,255,255,0.5);

  --font-display: 'Bebas Neue', sans-serif;
  --font-body:    'Outfit', sans-serif;

  --r-sm:   10px;
  --r-md:   18px;
  --r-lg:   28px;
  --r-xl:   48px;
  --r-pill: 100px;

  --t-fast: 0.18s cubic-bezier(.4,0,.2,1);
  --t-med:  0.35s cubic-bezier(.4,0,.2,1);
  --t-slow: 0.6s  cubic-bezier(.4,0,.2,1);

  --shadow-blue:  0 8px 40px rgba(0,87,255,0.18);
  --shadow-cyan:  0 8px 40px rgba(0,200,232,0.18);
  --shadow-card:  0 4px 24px rgba(0,20,80,0.08);
  --shadow-lg:    0 16px 60px rgba(0,20,80,0.12);

  --logo-size:    48px;
  --demo-h:       28px;
}

/* ============================================================
   BANDEAU DÉMO — OBLIGATOIRE — body::before — EN HAUT
============================================================ */
body::before {
  content: "⚠️ DÉMONSTRATION — Ce site est une proposition commerciale non publiée — Tous droits réservés © ericbuhler.fr";
  position: fixed;
  top: 0; left: 0;
  width: 100%;
  height: var(--demo-h);
  background: #0a0a1a;
  color: #fff;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.03em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 9999;
  pointer-events: none;
  border-bottom: 2px solid var(--c-primary);
}

/* ============================================================
   RESET & BASE
============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  background: var(--c-bg);
  color: var(--c-text);
  padding-top: var(--demo-h);
  overflow-x: hidden;
  line-height: 1.6;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--c-bg); }
::-webkit-scrollbar-thumb { background: var(--c-primary); border-radius: 3px; }

/* ============================================================
   FOND — FORMES ANIMÉES
============================================================ */
.bg-shapes { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.bg-shape  { position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.22; animation: shapeFloat 18s ease-in-out infinite; }
.bs1 { width:600px;height:600px; background:var(--c-cyan);    top:-200px;  right:-100px; animation-delay:0s;   }
.bs2 { width:400px;height:400px; background:var(--c-primary); bottom:10%;  left:-100px;  animation-delay:-9s;  }
.bs3 { width:300px;height:300px; background:var(--c-yellow);  top:40%;     right:5%;     animation-delay:-5s; opacity:.12; }
.bs4 { width:200px;height:200px; background:var(--c-pink);    bottom:30%;  right:20%;    animation-delay:-12s; opacity:.10; }
@keyframes shapeFloat { 0%,100%{transform:translate(0,0) scale(1)} 33%{transform:translate(30px,-40px) scale(1.06)} 66%{transform:translate(-20px,30px) scale(0.94)} }

/* ============================================================
   HEADER
============================================================ */
.site-header {
  position: fixed;
  top: var(--demo-h); left: 0; right: 0;
  z-index: 100;
  padding: 0 5%;
  height: 72px;
  display: flex; align-items: center; justify-content: space-between;
  background: var(--c-header-bg);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 2px solid var(--c-border);
  box-shadow: 0 2px 20px rgba(0,87,255,0.07);
  transition: box-shadow var(--t-med);
}
.site-header.scrolled { box-shadow: 0 4px 30px rgba(0,87,255,0.12); }

/* Logo */
.site-logo { display:flex; align-items:center; gap:12px; }
.site-logo img { height: var(--logo-size); width: auto; }
.logo-text {
  display: flex; align-items: center; gap: 4px;
  font-family: var(--font-display);
  font-size: 2.4rem;
  letter-spacing: 0.02em; line-height: 1;
  color: var(--c-header-text);
}
.logo-text .w12 { color: var(--c-primary); }
.logo-badge {
  background: var(--c-cyan); color: #fff;
  font-family: var(--font-body); font-size: 0.58rem; font-weight: 800;
  letter-spacing: 0.1em; padding: 2px 7px; border-radius: 4px;
  margin-left: 6px; align-self: flex-end; margin-bottom: 6px;
  text-transform: uppercase;
  animation: badgePop 2s ease-in-out infinite;
}
@keyframes badgePop { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }

/* Nav */
.nav-main { display: flex; align-items: center; gap: 32px; }
.nav-main a {
  font-size: 0.85rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--c-text-muted);
  transition: color var(--t-fast); position: relative;
}
.nav-main a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:3px; background:var(--c-primary); border-radius:2px;
  transition: width var(--t-med);
}
.nav-main a:hover, .nav-main a:focus { color: var(--c-primary); }
.nav-main a:hover::after { width: 100%; }

.btn-nav {
  background: var(--c-primary) !important; color: #fff !important;
  padding: 10px 22px; border-radius: var(--r-pill) !important;
  font-weight: 700; font-size: 0.82rem; letter-spacing: 0.06em;
  transition: all var(--t-fast) !important; box-shadow: var(--shadow-blue);
}
.btn-nav:hover { background: #0044d4 !important; transform: translateY(-2px) !important; }
.btn-nav::after { display:none !important; }
.btn-nav:hover { color:#fff !important; }

/* Hamburger */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; }
.hamburger span { display:block; width:24px; height:2.5px; background:var(--c-text); border-radius:2px; transition:all var(--t-fast); }

/* Nav mobile */
.nav-mobile {
  display: none; position:fixed;
  top: calc(var(--demo-h) + 72px); left:0; right:0;
  background: #fff; padding:24px 5%; z-index:99;
  border-bottom: 2px solid var(--c-border); flex-direction:column; gap:0;
  box-shadow: var(--shadow-lg);
}
.nav-mobile.open { display:flex; }
.nav-mobile a { font-size:1rem; font-weight:600; color:var(--c-text-muted); padding:14px 0; border-bottom:1px solid var(--c-border); transition:color var(--t-fast); }
.nav-mobile a:hover { color:var(--c-primary); }

/* ============================================================
   HERO
============================================================ */
#hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  overflow:hidden;
  background: linear-gradient(135deg, #e8f0ff 0%, #f0faff 50%, #fff8e0 100%);
  padding-top: calc(72px + var(--demo-h));
}
.hero-grid-bg {
  position:absolute; inset:0;
  background-image: linear-gradient(rgba(0,87,255,0.06) 1px,transparent 1px), linear-gradient(90deg,rgba(0,87,255,0.06) 1px,transparent 1px);
  background-size: 48px 48px; pointer-events:none;
}
.hero-accent-left { position:absolute; left:0; top:0; bottom:0; width:8px; background:linear-gradient(180deg,var(--c-primary) 0%,var(--c-cyan) 50%,var(--c-yellow) 100%); }

.hero-inner {
  position:relative; z-index:2; width:100%; max-width:1240px;
  margin:0 auto; padding:60px 5% 60px 7%;
  display:grid; grid-template-columns:1fr 1fr; align-items:center; gap:60px;
}

.hero-live {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--c-primary); color:#fff;
  font-size:0.72rem; font-weight:800; letter-spacing:0.14em; text-transform:uppercase;
  padding:6px 14px 6px 10px; border-radius:var(--r-pill); margin-bottom:28px;
}
.live-dot { width:8px;height:8px; background:#fff; border-radius:50%; animation:livePulse 1.2s ease-in-out infinite; }
@keyframes livePulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:0.4;transform:scale(0.7)} }

h1.hero-title {
  font-family:var(--font-display); font-size:clamp(3.8rem,9vw,8rem);
  line-height:0.88; letter-spacing:0.01em; margin-bottom:24px; color:var(--c-text);
}
.hero-title .w12   { color:var(--c-primary); display:block; }
.hero-title .tagline { color:var(--c-text); font-size:0.42em; display:block; letter-spacing:0.04em; margin-top:4px; }

.hero-desc { font-size:1.05rem; color:var(--c-text-muted); line-height:1.8; max-width:440px; margin-bottom:40px; }

.hero-ctas { display:flex; gap:14px; flex-wrap:wrap; }

.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--c-primary); color:#fff;
  padding:16px 32px; border-radius:var(--r-pill);
  font-weight:700; font-size:0.92rem; letter-spacing:0.05em;
  transition:all var(--t-fast); box-shadow:var(--shadow-blue);
  position:relative; overflow:hidden; cursor:pointer; border:none;
  font-family: var(--font-body);
}
.btn-primary::before { content:''; position:absolute; inset:0; background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.2) 50%,transparent 70%); transform:translateX(-100%); transition:transform 0.5s; }
.btn-primary:hover::before { transform:translateX(100%); }
.btn-primary:hover { background:#0044d4; transform:translateY(-2px); box-shadow:0 12px 40px rgba(0,87,255,0.3); color:#fff; }

.btn-cyan {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--c-cyan); color:#fff;
  padding:16px 32px; border-radius:var(--r-pill);
  font-weight:700; font-size:0.92rem; letter-spacing:0.05em;
  transition:all var(--t-fast); box-shadow:var(--shadow-cyan);
}
.btn-cyan:hover { background:#00afd0; transform:translateY(-2px); }

/* TV Screen */
.hero-right { position:relative; }
.tv-screen {
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  box-shadow:var(--shadow-lg), 0 0 60px rgba(0,87,255,0.15);
  border:3px solid var(--c-primary); background:#000; aspect-ratio:16/10;
}
.tv-screen img { width:100%; height:100%; object-fit:cover; opacity:.92; }
.tv-screen::after { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,0.08) 0%,transparent 50%); pointer-events:none; }
.tv-bar { position:absolute; bottom:0;left:0;right:0; background:linear-gradient(90deg,var(--c-primary),var(--c-cyan)); padding:12px 20px; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.tv-bar-title { font-weight:800; font-size:0.88rem; color:#fff; letter-spacing:0.04em; }
.tv-bar-time { font-weight:600; font-size:0.78rem; color:rgba(255,255,255,0.85); white-space:nowrap; }
.tv-channel { position:absolute; top:16px;right:16px; background:var(--c-primary); color:#fff; font-family:var(--font-display); font-size:1.8rem; letter-spacing:0.02em; padding:6px 14px; border-radius:var(--r-sm); line-height:1; box-shadow:0 4px 16px rgba(0,87,255,0.4); }

/* Floating cards */
.hero-float { position:absolute; background:#fff; border-radius:var(--r-md); padding:14px 18px; box-shadow:var(--shadow-lg); border:1.5px solid var(--c-border); display:flex; align-items:center; gap:12px; animation:floatCard 5s ease-in-out infinite; }
.hero-float.f1 { bottom:-20px; left:-30px; animation-delay:0s; }
.hero-float.f2 { top:-16px;   right:-20px; animation-delay:-2.5s; }
@keyframes floatCard { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }
.float-icon { width:38px;height:38px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; }
.float-icon.blue { background:var(--c-primary-light); color:var(--c-primary); }
.float-icon.cyan { background:var(--c-cyan-light);    color:var(--c-cyan); }
.float-num { font-family:var(--font-display); font-size:1.4rem; color:var(--c-text); line-height:1; }
.float-lbl { font-size:0.68rem; color:var(--c-text-muted); font-weight:500; }

/* ============================================================
   STATS
============================================================ */
#stats { background:var(--c-primary); position:relative; z-index:1; }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); max-width:1240px; margin:0 auto; }
.stat-item { padding:40px 5%; text-align:center; border-right:1px solid rgba(255,255,255,0.15); transition:background var(--t-fast); }
.stat-item:last-child { border-right:none; }
.stat-item:hover { background:rgba(255,255,255,0.08); }
.stat-number { font-family:var(--font-display); font-size:clamp(2.2rem,4vw,3.5rem); color:#fff; line-height:1; margin-bottom:8px; }
.stat-number span { color:var(--c-yellow); }
.stat-label { font-size:0.78rem; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.7); }

/* ============================================================
   SECTIONS COMMUNES
============================================================ */
section { position:relative; z-index:1; }
.section-inner { max-width:1240px; margin:0 auto; padding:100px 5%; }

.section-tag { display:inline-flex; align-items:center; gap:8px; font-size:0.72rem; font-weight:800; letter-spacing:0.15em; text-transform:uppercase; color:var(--c-primary); margin-bottom:14px; }
.section-tag .tag-line { display:block; width:24px; height:3px; background:var(--c-primary); border-radius:2px; }
.section-tag.cyan { color:var(--c-cyan); }
.section-tag.cyan .tag-line { background:var(--c-cyan); }

h2.section-title { font-family:var(--font-display); font-size:clamp(2.4rem,5vw,4.5rem); line-height:0.92; letter-spacing:0.02em; color:var(--c-text); margin-bottom:16px; }
.section-desc { font-size:1rem; color:var(--c-text-muted); max-width:520px; line-height:1.8; }

/* ============================================================
   PROGRAMMES
============================================================ */
#programmes { background:var(--c-bg-alt); }
.programmes-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:52px; flex-wrap:wrap; gap:24px; }
.programmes-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }

.prog-card { border-radius:var(--r-md); overflow:hidden; background:#fff; border:2px solid var(--c-border); cursor:pointer; transition:all var(--t-med); position:relative; }
.prog-card:hover { border-color:var(--c-primary); transform:translateY(-6px); box-shadow:var(--shadow-lg), 0 0 30px rgba(0,87,255,0.12); }
.prog-card.featured { grid-column:span 2; }

.prog-img-wrap { position:relative; aspect-ratio:16/9; overflow:hidden; }
.prog-card.featured .prog-img-wrap { aspect-ratio:16/7; }
.prog-img { width:100%;height:100%; object-fit:cover; transition:transform var(--t-slow); }
.prog-card:hover .prog-img { transform:scale(1.05); }
.prog-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.7) 0%,transparent 60%); }
.prog-play { position:absolute; top:50%;left:50%; transform:translate(-50%,-50%) scale(0.8); opacity:0; transition:all var(--t-med); width:56px;height:56px; background:var(--c-primary); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 0 30px rgba(0,87,255,0.5); }
.prog-card:hover .prog-play { opacity:1; transform:translate(-50%,-50%) scale(1); }

.prog-genre-badge { position:absolute; top:14px;left:14px; font-size:0.65rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:4px 12px; border-radius:var(--r-pill); color:#fff; }
.badge-film   { background:var(--c-primary); }
.badge-serie  { background:var(--c-cyan); }
.badge-divert { background:var(--c-pink); }
.badge-prime  { background:var(--c-yellow); color:#0a0a1a; }

.prog-body { padding:20px 20px 22px; }
.prog-card h3 { font-family:var(--font-display); font-size:1.4rem; letter-spacing:0.02em; color:var(--c-text); margin-bottom:8px; line-height:1.1; }
.prog-time { display:flex; align-items:center; gap:6px; font-size:0.78rem; font-weight:600; color:var(--c-primary); }

/* ============================================================
   À PROPOS
============================================================ */
#about { background:linear-gradient(135deg,#e8f0ff 0%,#f0faff 100%); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-visual { position:relative; }
.about-screen { border-radius:var(--r-lg); overflow:hidden; border:3px solid var(--c-primary); box-shadow:var(--shadow-lg), var(--shadow-blue); position:relative; }
.about-screen img { width:100%; aspect-ratio:4/3; object-fit:cover; }
.about-screen::after { content:''; position:absolute; bottom:0;left:0;right:0; height:6px; background:linear-gradient(90deg,var(--c-primary),var(--c-cyan),var(--c-yellow),var(--c-pink)); }

.about-float { position:absolute; background:#fff; border-radius:var(--r-md); padding:16px 20px; box-shadow:var(--shadow-lg); border:2px solid var(--c-border); }
.about-float.tr { top:-20px; right:-24px; }
.about-float.bl { bottom:-20px; left:-24px; }
.float-big-num { font-family:var(--font-display); font-size:2rem; color:var(--c-primary); line-height:1; }
.float-big-lbl { font-size:0.72rem; color:var(--c-text-muted); margin-top:2px; }

.about-kpis { display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px; }
.kpi { background:#fff; border:2px solid var(--c-border); border-radius:var(--r-sm); padding:18px; text-align:center; transition:border-color var(--t-fast), transform var(--t-fast); }
.kpi:hover { border-color:var(--c-primary); transform:translateY(-3px); }
.kpi-num { font-family:var(--font-display); font-size:2rem; color:var(--c-primary); line-height:1; }
.kpi-lbl { font-size:0.72rem; color:var(--c-text-muted); margin-top:4px; font-weight:500; }

/* ============================================================
   VIDÉO
============================================================ */
#video-section { background:var(--c-bg); }
.video-wrapper { position:relative; border-radius:var(--r-lg); overflow:hidden; border:3px solid var(--c-primary); box-shadow:var(--shadow-blue), var(--shadow-lg); margin-top:48px; }
.video-wrapper::before { content:''; position:absolute; top:0;left:0;right:0; height:6px; background:linear-gradient(90deg,var(--c-primary),var(--c-cyan),var(--c-yellow),var(--c-pink)); z-index:2; }
.video-wrapper iframe { width:100%; aspect-ratio:16/9; border:none; display:block; }

/* ============================================================
   GRILLE TV
============================================================ */
#grille { background:var(--c-bg-alt); }
.grille-tabs { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:32px; }
.grille-tab { padding:10px 22px; border-radius:var(--r-pill); font-size:0.82rem; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; cursor:pointer; transition:all var(--t-fast); color:var(--c-text-muted); border:2px solid var(--c-border); background:#fff; font-family:var(--font-body); }
.grille-tab.active { background:var(--c-primary); border-color:var(--c-primary); color:#fff; box-shadow:var(--shadow-blue); }
.grille-tab:hover:not(.active) { border-color:var(--c-primary); color:var(--c-primary); }

.grille-table { width:100%; border-collapse:collapse; background:#fff; border-radius:var(--r-md); overflow:hidden; border:2px solid var(--c-border); box-shadow:var(--shadow-card); }
.grille-table th { padding:16px 20px; text-align:left; font-size:0.72rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:var(--c-text-muted); border-bottom:2px solid var(--c-border); background:var(--c-surface2); }
.grille-table td { padding:15px 20px; border-bottom:1px solid var(--c-border); font-size:0.9rem; }
.grille-table tr:last-child td { border-bottom:none; }
.grille-table tbody tr:hover td { background:var(--c-primary-light); }
.grille-time { font-family:var(--font-display); font-size:1.15rem; color:var(--c-primary); letter-spacing:0.05em; white-space:nowrap; }
.grille-title { font-weight:600; }
.grille-type { display:inline-block; padding:3px 12px; border-radius:var(--r-pill); font-size:0.68rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; }
.type-film   { background:var(--c-primary-light); color:var(--c-primary); }
.type-serie  { background:var(--c-cyan-light);    color:#007a8c; }
.type-divert { background:#fff0f6;                color:var(--c-pink); }
.type-info   { background:#fff8e0;                color:#9a6800; }
.grille-prime { color:var(--c-orange); font-weight:700; font-size:0.78rem; }

/* ============================================================
   GALERIE
============================================================ */
#galerie { background:var(--c-bg); }
.galerie-stripe { height:6px; background:linear-gradient(90deg,var(--c-primary) 25%,var(--c-cyan) 25% 50%,var(--c-yellow) 50% 75%,var(--c-pink) 75%); margin-bottom:48px; border-radius:var(--r-pill); }
.galerie-grid { display:grid; grid-template-columns:repeat(3,1fr); grid-template-rows:260px 200px; gap:12px; }
.gal-item { border-radius:var(--r-sm); overflow:hidden; cursor:pointer; position:relative; border:2px solid transparent; transition:border-color var(--t-fast), transform var(--t-fast); }
.gal-item:first-child { grid-column:span 2; grid-row:span 2; }
.gal-item:hover { border-color:var(--c-primary); transform:scale(0.99); }
.gal-item img { width:100%;height:100%; object-fit:cover; transition:all var(--t-slow); }
.gal-overlay { position:absolute; inset:0; background:rgba(0,87,255,0.5); opacity:0; transition:opacity var(--t-med); display:flex; align-items:flex-end; padding:16px; }
.gal-item:hover .gal-overlay { opacity:1; }
.gal-caption { font-size:0.85rem; font-weight:700; color:#fff; }

/* ============================================================
   TÉMOIGNAGES
============================================================ */
#temoignages { background:linear-gradient(135deg,var(--c-primary) 0%,#003dbc 100%); }
#temoignages .section-title { color:#fff; }
#temoignages .section-tag { color:rgba(255,255,255,0.7); }
#temoignages .section-tag .tag-line { background:rgba(255,255,255,0.5); }
.temoignages-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:48px; }
.temo-card { background:rgba(255,255,255,0.1); border:1.5px solid rgba(255,255,255,0.2); backdrop-filter:blur(12px); border-radius:var(--r-md); padding:32px; transition:all var(--t-med); position:relative; }
.temo-card:hover { background:rgba(255,255,255,0.18); transform:translateY(-4px); }
.temo-card::before { content:'"'; position:absolute; top:20px;right:24px; font-family:var(--font-display); font-size:5rem; color:rgba(255,255,255,0.1); line-height:1; pointer-events:none; }
.temo-stars { display:flex; gap:4px; margin-bottom:16px; }
.star { color:var(--c-yellow); font-size:1rem; }
.temo-text { font-size:0.95rem; color:rgba(255,255,255,0.85); line-height:1.8; margin-bottom:24px; font-style:italic; }
.temo-author { display:flex; align-items:center; gap:12px; }
.author-avatar { width:44px;height:44px; border-radius:50%; background:rgba(255,255,255,0.2); display:flex; align-items:center; justify-content:center; font-family:var(--font-display); font-size:1.2rem; color:#fff; border:2px solid rgba(255,255,255,0.4); flex-shrink:0; }
.author-name { font-weight:700; color:#fff; font-size:0.9rem; }
.author-city { font-size:0.74rem; color:rgba(255,255,255,0.6); }

/* ============================================================
   FAQ
============================================================ */
#faq { background:var(--c-bg-alt); }
.faq-list { max-width:800px; margin:48px auto 0; display:flex; flex-direction:column; gap:12px; }
.faq-item { background:#fff; border:2px solid var(--c-border); border-radius:var(--r-sm); overflow:hidden; transition:border-color var(--t-fast), box-shadow var(--t-fast); }
.faq-item.open, .faq-item:hover { border-color:var(--c-primary); box-shadow:var(--shadow-blue); }
.faq-question { width:100%; display:flex; align-items:center; justify-content:space-between; padding:22px 24px; cursor:pointer; background:none; border:none; color:var(--c-text); font-family:var(--font-body); font-size:0.97rem; font-weight:700; text-align:left; gap:16px; }
.faq-icon { flex-shrink:0; width:28px;height:28px; background:var(--c-primary-light); border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all var(--t-fast); color:var(--c-primary); }
.faq-item.open .faq-icon { background:var(--c-primary); color:#fff; transform:rotate(180deg); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.4s cubic-bezier(.4,0,.2,1); }
.faq-item.open .faq-answer { max-height:200px; }
.faq-answer p { padding:0 24px 22px; font-size:0.9rem; color:var(--c-text-muted); line-height:1.8; }

/* ============================================================
   CONTACT
============================================================ */
#contact { background:var(--c-bg); }
.contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:60px; align-items:start; }
.contact-info-item { display:flex; align-items:flex-start; gap:16px; margin-bottom:28px; }
.contact-icon { width:48px;height:48px; background:var(--c-primary-light); border:2px solid var(--c-border); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; color:var(--c-primary); flex-shrink:0; }
.contact-info-label { font-size:0.7rem; font-weight:800; letter-spacing:0.12em; text-transform:uppercase; color:var(--c-text-muted); margin-bottom:4px; }
.contact-info-val { font-weight:600; color:var(--c-text); }
.contact-socials { display:flex; gap:10px; margin-top:36px; }
.social-btn { width:44px;height:44px; background:#fff; border:2px solid var(--c-border); border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; transition:all var(--t-fast); color:var(--c-text-muted); }
.social-btn:hover { background:var(--c-primary-light); border-color:var(--c-primary); color:var(--c-primary); transform:translateY(-2px); }

/* Form */
.contact-form { background:#fff; border:2px solid var(--c-border); border-radius:var(--r-lg); padding:36px; box-shadow:var(--shadow-card); display:flex; flex-direction:column; gap:16px; }
.form-group { display:flex; flex-direction:column; gap:8px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
label { font-size:0.78rem; font-weight:800; letter-spacing:0.08em; text-transform:uppercase; color:var(--c-text); }
input[type="text"], input[type="email"], input[type="tel"], textarea, select {
  background:var(--c-bg); border:2px solid var(--c-border); border-radius:var(--r-sm);
  padding:13px 16px; color:var(--c-text); font-family:var(--font-body); font-size:0.92rem;
  width:100%; transition:all var(--t-fast); outline:none;
}
input:focus, textarea:focus, select:focus { border-color:var(--c-primary); background:var(--c-primary-light); box-shadow:0 0 0 3px rgba(0,87,255,0.1); }
textarea { min-height:110px; resize:vertical; }
.form-notice { font-size:0.73rem; color:var(--c-text-muted); }
.wpcf7-response-output { margin-top:8px; font-size:0.85rem; }

/* ============================================================
   BLOG — INDEX
============================================================ */
#blog-hero { background:linear-gradient(135deg,var(--c-primary) 0%,#003dbc 100%); padding:160px 5% 80px; text-align:center; }
#blog-hero h1 { font-family:var(--font-display); font-size:clamp(3rem,8vw,6rem); color:#fff; letter-spacing:0.02em; }
#blog-hero p { color:rgba(255,255,255,0.7); margin-top:12px; font-size:1rem; }

.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:28px; max-width:1240px; margin:0 auto; padding:80px 5%; }
.blog-card { background:#fff; border:2px solid var(--c-border); border-radius:var(--r-md); overflow:hidden; transition:all var(--t-med); }
.blog-card:hover { border-color:var(--c-primary); transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.blog-card.featured { grid-column:span 3; display:grid; grid-template-columns:1fr 1fr; }
.blog-card.featured .blog-card-img { aspect-ratio:auto; min-height:360px; }
.blog-card-img { position:relative; aspect-ratio:16/9; overflow:hidden; }
.blog-card-img img { width:100%;height:100%; object-fit:cover; transition:transform var(--t-slow); }
.blog-card:hover .blog-card-img img { transform:scale(1.04); }
.blog-cat { position:absolute; top:14px;left:14px; background:var(--c-primary); color:#fff; font-size:0.65rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:4px 12px; border-radius:var(--r-pill); }
.blog-card-body { padding:24px; display:flex; flex-direction:column; gap:10px; }
.blog-meta { font-size:0.75rem; color:var(--c-text-muted); display:flex; gap:12px; align-items:center; }
.blog-card h2, .blog-card h3 { font-family:var(--font-display); font-size:1.5rem; letter-spacing:0.02em; color:var(--c-text); line-height:1.1; }
.blog-card.featured h2 { font-size:2.2rem; }
.blog-excerpt { font-size:0.88rem; color:var(--c-text-muted); line-height:1.7; }
.blog-read-more { display:inline-flex; align-items:center; gap:6px; font-size:0.82rem; font-weight:700; color:var(--c-primary); margin-top:8px; }
.blog-read-more:hover { text-decoration:underline; }

/* Breadcrumb */
.breadcrumb { font-size:0.78rem; color:var(--c-text-muted); padding:16px 5%; max-width:1240px; margin:0 auto; display:flex; gap:8px; align-items:center; flex-wrap:wrap; }
.breadcrumb a { color:var(--c-primary); }
.breadcrumb span { color:var(--c-text-muted); }

/* ============================================================
   ARTICLE SINGLE
============================================================ */
.single-hero { position:relative; min-height:480px; display:flex; align-items:flex-end; overflow:hidden; }
.single-hero-bg { position:absolute; inset:0; background-size:cover; background-position:center; filter:brightness(.4) saturate(.7); }
.single-hero-content { position:relative; z-index:2; padding:60px 5% 48px; max-width:900px; }
.single-cat { display:inline-block; background:var(--c-primary); color:#fff; font-size:0.68rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; padding:4px 14px; border-radius:var(--r-pill); margin-bottom:14px; }
.single-hero-content h1 { font-family:var(--font-display); font-size:clamp(2.2rem,5vw,4rem); color:#fff; line-height:0.95; letter-spacing:0.02em; }
.single-meta { margin-top:16px; font-size:0.78rem; color:rgba(255,255,255,0.65); display:flex; gap:16px; flex-wrap:wrap; }

article.single-content { max-width:760px; margin:48px auto; padding:0 5%; }
article.single-content p { font-size:1.05rem; line-height:1.9; color:var(--c-text); margin-bottom:20px; }
article.single-content h2 { font-family:var(--font-display); font-size:2rem; color:var(--c-text); margin:36px 0 14px; }
article.single-content h3 { font-size:1.2rem; font-weight:700; color:var(--c-text); margin:28px 0 12px; }
article.single-content blockquote { border-left:4px solid var(--c-primary); padding:14px 20px; background:var(--c-primary-light); border-radius:0 var(--r-sm) var(--r-sm) 0; margin:24px 0; font-style:italic; }
article.single-content figure { margin:28px 0; }
article.single-content figcaption { font-size:0.78rem; color:var(--c-text-muted); margin-top:8px; text-align:center; }
article.single-content img { border-radius:var(--r-sm); width:100%; }

/* Nav prev/next */
.post-nav { display:grid; grid-template-columns:1fr 1fr; gap:16px; max-width:760px; margin:48px auto; padding:0 5%; }
.post-nav-item { background:#fff; border:2px solid var(--c-border); border-radius:var(--r-sm); padding:20px; transition:all var(--t-fast); }
.post-nav-item:hover { border-color:var(--c-primary); }
.post-nav-label { font-size:0.7rem; font-weight:800; letter-spacing:0.1em; text-transform:uppercase; color:var(--c-text-muted); margin-bottom:8px; }
.post-nav-title { font-family:var(--font-display); font-size:1.15rem; color:var(--c-text); }

/* ============================================================
   404
============================================================ */
.page-404 { min-height:80vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; padding:80px 5%; }
.page-404 .err-num { font-family:var(--font-display); font-size:clamp(8rem,20vw,16rem); color:var(--c-primary); line-height:.85; opacity:.15; }
.page-404 h1 { font-family:var(--font-display); font-size:clamp(2rem,5vw,3.5rem); margin-top:-60px; position:relative; z-index:1; }
.page-404 p { color:var(--c-text-muted); margin:16px 0 32px; }

/* ============================================================
   FOOTER
============================================================ */
.footer-rainbow { height:5px; background:linear-gradient(90deg,var(--c-primary) 25%,var(--c-cyan) 25% 50%,var(--c-yellow) 50% 75%,var(--c-pink) 75%); }
.site-footer { background:var(--c-footer-bg); padding:64px 5% 0; }
.footer-grid { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:48px; max-width:1240px; margin:0 auto 48px; }
.footer-logo .logo-text .w12 { color:var(--c-cyan); }
.footer-desc { font-size:0.85rem; color:var(--c-footer-text); line-height:1.8; margin-bottom:24px; }
.footer-col-title { font-size:0.7rem; font-weight:800; letter-spacing:0.14em; text-transform:uppercase; color:#fff; margin-bottom:20px; }
.footer-links { display:flex; flex-direction:column; gap:10px; }
.footer-links a { font-size:0.85rem; color:rgba(255,255,255,0.4); transition:color var(--t-fast); }
.footer-links a:hover { color:var(--c-cyan); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.08); padding:24px 0; max-width:1240px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.footer-copy { font-size:0.78rem; color:rgba(255,255,255,0.3); }
.footer-copy a { color:var(--c-cyan); }
.footer-copy a:hover { text-decoration:underline; }

/* ============================================================
   WHATSAPP
============================================================ */
.whatsapp-float { position:fixed; bottom:28px;right:28px; z-index:200; width:58px;height:58px; background:#25d366; border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(37,211,102,.45); transition:all var(--t-fast); animation:waPop .5s 2s backwards cubic-bezier(.34,1.56,.64,1); }
@keyframes waPop { from{transform:scale(0);opacity:0} to{transform:scale(1);opacity:1} }
.whatsapp-float:hover { transform:scale(1.12); box-shadow:0 8px 30px rgba(37,211,102,.6); }

/* ============================================================
   RGPD
============================================================ */
.rgpd-banner { position:fixed; bottom:0;left:0;right:0; z-index:300; background:#fff; border-top:3px solid var(--c-primary); padding:20px 5%; display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap; box-shadow:0 -8px 40px rgba(0,20,80,.1); }
.rgpd-banner.hidden { display:none; }
.rgpd-text { font-size:0.83rem; color:var(--c-text-muted); max-width:600px; line-height:1.7; }
.rgpd-text a { color:var(--c-primary); font-weight:600; }
.rgpd-btns { display:flex; gap:10px; flex-shrink:0; }
.rgpd-accept { padding:10px 24px; background:var(--c-primary); color:#fff; border:none; border-radius:var(--r-pill); font-family:var(--font-body); font-size:0.82rem; font-weight:700; cursor:pointer; transition:all var(--t-fast); }
.rgpd-accept:hover { background:#0044d4; }
.rgpd-refuse { padding:10px 24px; background:transparent; color:var(--c-text-muted); border:2px solid var(--c-border); border-radius:var(--r-pill); font-family:var(--font-body); font-size:0.82rem; font-weight:600; cursor:pointer; transition:all var(--t-fast); }
.rgpd-refuse:hover { border-color:var(--c-text-muted); }

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width:1024px) {
  .hero-inner        { grid-template-columns:1fr; gap:48px; padding:60px 5%; }
  .hero-right        { max-width:560px; margin:0 auto; }
  .about-grid        { grid-template-columns:1fr; gap:48px; }
  .programmes-grid   { grid-template-columns:1fr 1fr; }
  .prog-card.featured{ grid-column:span 2; }
  .temoignages-grid  { grid-template-columns:1fr 1fr; }
  .footer-grid       { grid-template-columns:1fr 1fr; }
  .stats-grid        { grid-template-columns:repeat(2,1fr); }
  .stat-item:nth-child(2) { border-right:none; }
  .contact-grid      { grid-template-columns:1fr; }
  .blog-card.featured{ grid-column:span 3; }
}
@media (max-width:768px) {
  .nav-main  { display:none; }
  .hamburger { display:flex; }
  .programmes-grid { grid-template-columns:1fr; }
  .prog-card.featured { grid-column:span 1; }
  .galerie-grid { grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .gal-item:first-child { grid-column:span 2; grid-row:span 1; }
  .temoignages-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .about-float, .hero-float { display:none; }
  .blog-grid { grid-template-columns:1fr 1fr; }
  .blog-card.featured { grid-column:span 2; grid-template-columns:1fr; }
  .post-nav { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .hero-ctas { flex-direction:column; }
  .btn-primary, .btn-cyan { width:100%; justify-content:center; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .galerie-grid { grid-template-columns:1fr; }
  .gal-item:first-child { grid-column:span 1; }
  .form-row { grid-template-columns:1fr; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .stat-item { border-right:none; border-bottom:1px solid rgba(255,255,255,0.15); }
  .blog-grid { grid-template-columns:1fr; }
  .blog-card.featured { grid-column:span 1; }
}
