/* Polices auto-hébergées (chemins relatifs à ce fichier : assets/css/ -> assets/fonts/) */
@font-face{font-family:'Montserrat';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/montserrat-700.woff2') format('woff2')}
@font-face{font-family:'Montserrat';font-style:normal;font-weight:800;font-display:swap;src:url('../fonts/montserrat-800.woff2') format('woff2')}
@font-face{font-family:'Roboto';font-style:normal;font-weight:300;font-display:swap;src:url('../fonts/roboto-300.woff2') format('woff2')}
@font-face{font-family:'Roboto';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/roboto-400.woff2') format('woff2')}
@font-face{font-family:'Roboto';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/roboto-500.woff2') format('woff2')}
@font-face{font-family:'Roboto';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/roboto-700.woff2') format('woff2')}
:root{
  --blue:#3C83F6; --gold:#F6AF3C; --gray:#6B7280; --dark:#1A1A2E;
  --bg:#ffffff; --text:#0c0c14; --text-soft:#33333b;
  --surface:#ffffff; --surface-2:#f6f8fc; --light:#EBF2FF; --border:#E5E7EB;
  --header-bg:rgba(255,255,255,.95); --hero-top:#EBF2FF; --hero-bot:#ffffff;
  --hero-overlay:linear-gradient(90deg,#ffffff 0%,#ffffff 32%,rgba(255,255,255,.74) 56%,rgba(235,242,255,.30) 100%);
  --hero-overlay-mobile:linear-gradient(180deg,rgba(255,255,255,.80),rgba(255,255,255,.93));
  --maxw:1120px;
}
[data-theme="dark"]{
  --bg:#0f0f17; --text:#ececf3; --text-soft:#b9b9c8;
  --surface:#181824; --surface-2:#14141f; --light:#1d1d2c; --border:#2c2c44;
  --header-bg:rgba(15,15,23,.92); --hero-top:#161622; --hero-bot:#0f0f17;
  --hero-overlay:linear-gradient(90deg,#0f0f17 0%,#0f0f17 32%,rgba(15,15,23,.80) 56%,rgba(15,15,23,.42) 100%);
  --hero-overlay-mobile:linear-gradient(180deg,rgba(15,15,23,.84),rgba(15,15,23,.93));
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:"Roboto",Arial,sans-serif;color:var(--text);line-height:1.6;font-size:17px;background:var(--bg);transition:background .25s,color .25s}
h1,h2,h3{font-family:"Montserrat",Arial,sans-serif;line-height:1.15;color:var(--text)}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.btn{display:inline-block;font-family:"Montserrat";font-weight:700;font-size:15px;padding:14px 26px;border-radius:8px;transition:.18s;cursor:pointer;border:2px solid transparent}
.btn-primary{background:var(--blue);color:#fff}
.btn-primary:hover{background:#2f6fd8}
.btn-ghost{background:transparent;color:var(--blue);border-color:var(--blue)}
.btn-ghost:hover{background:var(--light)}
.eyebrow{font-family:"Montserrat";font-weight:700;letter-spacing:.08em;text-transform:uppercase;font-size:13px;color:var(--blue)}

/* Header */
header{position:sticky;top:0;z-index:50;background:var(--header-bg);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav img.logo{height:30px;width:auto}
.nav .logo-dark{display:none}
[data-theme="dark"] .nav .logo-light{display:none}
[data-theme="dark"] .nav .logo-dark{display:inline-block}
.nav ul{display:flex;gap:28px;list-style:none;align-items:center}
.nav nav a{font-size:15px;font-weight:400;color:var(--text)}
.nav nav a:hover{color:var(--blue)}
.nav-right{display:flex;align-items:center;gap:16px}
.lang{font-size:13px;color:var(--gray);font-weight:700}
.lang a.active{color:var(--text)}
.theme-toggle{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);background:var(--surface);display:grid;place-items:center;cursor:pointer;color:var(--text);transition:.2s;flex:0 0 auto}
.theme-toggle:hover{border-color:var(--blue);color:var(--blue);transform:rotate(12deg)}
.theme-toggle svg{width:19px;height:19px}
.theme-toggle .i-sun{display:none}
[data-theme="dark"] .theme-toggle .i-moon{display:none}
[data-theme="dark"] .theme-toggle .i-sun{display:block}
.burger{display:none;background:none;border:0;font-size:26px;cursor:pointer;color:var(--text)}

/* Hero */
.hero{position:relative;overflow:hidden;background:var(--hero-bot);padding:88px 0 72px}
.hero::before{content:"";position:absolute;inset:0;background:url("../img/hero-atelier.jpg") center right / cover no-repeat;z-index:0}
.hero::after{content:"";position:absolute;inset:0;background:var(--hero-overlay);z-index:1}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-size:46px;font-weight:800;max-width:14ch}
.hero p.sub{font-size:23px;line-height:1.5;color:var(--text-soft);margin:24px 0 34px;max-width:60ch}
.hero .cta-row{display:flex;gap:16px;flex-wrap:wrap}

/* Inner page hero */
.page-hero{background:linear-gradient(180deg,var(--hero-top) 0%,var(--hero-bot) 100%);padding:64px 0 44px}
.page-hero h1{font-size:40px;font-weight:800;max-width:22ch}
.page-hero p{font-size:19px;color:var(--text-soft);margin-top:14px;max-width:66ch}
.page-hero.with-photo{position:relative;overflow:hidden;padding:80px 0 60px}
.page-hero.with-photo::before{content:"";position:absolute;inset:0;background:url("../img/recrut-hero.jpg") center right / cover no-repeat;z-index:0}
.page-hero.with-photo::after{content:"";position:absolute;inset:0;background:var(--hero-overlay);z-index:1}
.page-hero.with-photo .wrap{position:relative;z-index:2}

/* Galerie photos */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.gallery figure{position:relative;margin:0;border-radius:14px;overflow:hidden}
.gallery img{width:100%;height:300px;object-fit:cover;display:block;transition:transform .45s ease}
.gallery figure:hover img{transform:scale(1.05)}
.gallery figcaption{position:absolute;left:0;right:0;bottom:0;padding:16px;color:#fff;font-family:"Montserrat";font-weight:700;font-size:15px;background:linear-gradient(0deg,rgba(0,0,0,.7) 0%,rgba(0,0,0,0) 100%)}

/* Logos */
.proof{padding:40px 0 8px;text-align:center}
.proof p{color:var(--gray);font-size:15px;margin-bottom:26px}
.logos{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 48px}
.logos img{height:38px;width:auto;filter:grayscale(1);opacity:.55;transition:.2s}
.logos img.tall{height:64px}
[data-theme="dark"] .logos img{filter:grayscale(1) invert(1);opacity:.72}
.logos img:hover{filter:grayscale(0);opacity:1}
.logos .logo-break{flex-basis:100%;height:0}

/* Sections */
section{padding:64px 0}
.section-tight{padding:48px 0}
h2.title{font-size:32px;font-weight:800;margin-bottom:14px}
.lead{font-size:19px;color:var(--text-soft);max-width:70ch}
.checklist{list-style:none;margin-top:26px;display:grid;gap:14px;max-width:760px}
.checklist li{display:flex;gap:14px;font-size:17px;line-height:1.6}
.checklist li::before{content:"";flex:0 0 auto;width:16px;height:16px;border-radius:4px;background:var(--blue);margin-top:.35em}

.alt{background:var(--dark);color:#e9e9f0}
[data-theme="dark"] .alt{background:#15151f}
.alt h2,.alt h3{color:#fff}
.alt .lead{color:#c4c4d2}

/* 3 cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:36px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:28px;transition:.2s}
.card:hover{border-color:var(--blue);box-shadow:0 8px 28px rgba(60,131,246,.12);transform:translateY(-2px)}
.card .eyebrow{font-size:12px}
.card h3{font-size:20px;margin:10px 0 10px}
.card p{color:var(--text-soft);font-size:16px}
.card:focus-visible{outline:2px solid var(--blue);outline-offset:2px}
.card-detail{max-height:0;opacity:0;overflow:hidden;margin:0;color:var(--text-soft);font-size:14px;line-height:1.5;transition:max-height .28s ease,opacity .2s ease,margin .28s ease}
.card:hover .card-detail,.card:focus-within .card-detail{max-height:220px;opacity:1;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* Cas concrets */
.cases{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px 32px;margin-top:36px}
.case{border-left:3px solid var(--blue);padding:6px 0 6px 22px}
.case h3{font-size:18px;margin-bottom:8px}
.case p{font-size:15px;color:var(--text-soft)}
.case .res{margin-top:10px;font-weight:700;color:var(--text)}

/* Ce que vous obtenez */
.obtain{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:36px}
.obtain article{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px 24px;position:relative;overflow:hidden;transition:.22s}
.obtain article::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--blue),#79a8ff)}
.obtain article:hover{transform:translateY(-5px);box-shadow:0 14px 34px rgba(60,131,246,.16);border-color:var(--blue)}
.obtain .oicon{display:grid;place-items:center;width:46px;height:46px;border-radius:12px;background:var(--light);color:var(--blue);margin-bottom:16px}
.obtain .oicon svg{width:24px;height:24px}
.obtain h3{font-size:17px;font-weight:700;color:var(--text);line-height:1.35}

/* positioning */
.pos{text-align:center;max-width:820px;margin:0 auto}
.pos h2{font-size:30px;font-weight:800}
.pos .punch{font-family:"Montserrat";font-weight:700;font-size:22px;color:var(--blue);margin:18px 0}

/* newsletter */
.news{background:var(--light);border-radius:16px;padding:44px;display:flex;gap:40px;align-items:center;flex-wrap:wrap}
.news .txt{flex:1;min-width:280px}
.news h2{font-size:26px;font-weight:800;margin-bottom:10px}
.news p{color:var(--text-soft)}
.news-embed{flex:0 0 auto;width:480px;max-width:100%}
.news-embed iframe{width:100%;height:320px;border:1px solid var(--border);border-radius:10px;background:#fff;display:block}
.news-embed .fallback{display:block;margin-top:10px;font-size:13px;color:var(--gray)}
.news-embed .fallback a{color:var(--blue);font-weight:700}

/* FAQ accordion */
.faq{max-width:820px;margin:0 auto;display:grid;gap:14px}
.faq details{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:0 22px;transition:.2s}
.faq details[open]{border-color:var(--blue);box-shadow:0 6px 22px rgba(60,131,246,.08)}
.faq summary{list-style:none;cursor:pointer;font-family:"Montserrat";font-weight:700;font-size:18px;color:var(--text);padding:20px 0;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:26px;line-height:1;color:var(--blue);flex:0 0 auto;transition:.2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .answer{padding:0 0 22px;color:var(--text-soft);font-size:16px}
.faq .answer ul{margin:10px 0 0 20px;display:grid;gap:6px}

/* Recrutement */
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:30px;max-width:920px}
.values div{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:22px}
.values h3{font-size:17px;margin-bottom:6px}
.values p{color:var(--text-soft);font-size:15px}
.jobs{max-width:820px;margin:30px auto 0;display:grid;gap:16px}
.job{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px}
.job h3{font-size:19px;margin-bottom:6px}
.job p{color:var(--text-soft);font-size:16px}

/* Prose (pages légales) */
.prose{max-width:780px;margin:0 auto}
.prose h2{font-size:23px;font-weight:800;margin:34px 0 12px}
.prose h3{font-size:18px;margin:22px 0 8px;color:var(--text)}
.prose p,.prose li{color:var(--text-soft);font-size:16px;margin-bottom:8px}
.prose ul{margin:8px 0 14px 22px;display:grid;gap:6px}
.prose .todo{background:var(--light);border-left:3px solid var(--gold);padding:1px 8px;border-radius:4px;color:var(--text);font-weight:700;font-size:14px}

/* Dernier article (compact, dans le bloc newsletter, sans lien) */
.latest-mini{margin-top:18px;padding-top:16px;border-top:1px solid var(--border)}
.latest-mini-label{font-family:"Montserrat";font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:11px;color:var(--blue)}
.latest-mini-title{font-family:"Montserrat";font-weight:700;font-size:15px;color:var(--text);margin:4px 0}
.latest-mini-sum{color:var(--text-soft);font-size:13px;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* final cta */
.final{background:var(--blue);color:#fff;text-align:center}
.final h2{color:#fff;font-size:34px;font-weight:800;max-width:20ch;margin:0 auto 14px}
.final p{font-size:19px;color:#eaf1ff;margin-bottom:28px}
.final .btn-primary{background:#fff;color:var(--blue)}
.final .btn-primary:hover{background:#eaf1ff}

/* footer */
footer{background:#12121c;color:#b9b9c8;padding:54px 0 30px;font-size:15px}
footer .cols{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;margin-bottom:30px}
footer img{height:28px;opacity:.95}
footer a{color:#b9b9c8}
footer a:hover{color:#fff}
footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
footer .legal{border-top:1px solid #2c2c44;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:#7c7c92}

@media(max-width:860px){
  .nav nav,.nav .lang{display:none}
  .nav.open nav{display:flex;position:absolute;top:72px;left:0;right:0;background:var(--surface);flex-direction:column;padding:20px 24px;border-bottom:1px solid var(--border)}
  .nav.open nav ul{flex-direction:column;align-items:flex-start;gap:18px}
  .burger{display:block}
  .hero::after,.page-hero.with-photo::after{background:var(--hero-overlay-mobile)}
  .hero::before,.page-hero.with-photo::before{background-position:center}
  .gallery{grid-template-columns:1fr}
  .hero h1{font-size:34px}
  .hero p.sub{font-size:19px}
  .page-hero h1{font-size:30px}
  .cards,.cases,.obtain,.values{grid-template-columns:1fr}
  .card-detail{max-height:none;opacity:1;margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
  h2.title,.pos h2,.final h2{font-size:26px}
}
