/* ═══ ÉVÉNEMENTS DJAM — Design system 100 % kit graphique 2024 ═══
   DJaune #F2B748 · Sombre vinyle #3A3121 · Or #A68A57 · Jaune éclat #F2C743 · Orange crépuscule #F2911B */

@font-face{font-family:'Kallisto';src:url('/static/fonts/kallisto-heavy.woff2') format('woff2');font-weight:900;font-display:swap}
@font-face{font-family:'Kallisto';src:url('/static/fonts/kallisto-bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'Kallisto';src:url('/static/fonts/kallisto-medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Poppins';src:url('/static/fonts/poppins-regular.woff2') format('woff2');font-weight:400;font-display:swap}
@font-face{font-family:'Poppins';src:url('/static/fonts/poppins-bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'ProximaNova';src:url('/static/fonts/proximanova-bold.woff2') format('woff2');font-weight:700;font-display:swap}

:root{
  --djaune:#F2B748; --vinyle:#3A3121; --or:#A68A57; --eclat:#F2C743; --crepuscule:#F2911B;
  --bg:#241E13; --bg2:#2E2718; --bg3:#3A3121; --line:rgba(242,183,72,.16);
  --creme:#FAF4E8; --texte:#EDE4D3; --muted:#BCAE93;
  --grad:linear-gradient(120deg,#F2C743 0%,#F2B748 45%,#F2911B 100%);
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --r:18px; --rs:12px;
  --ff-t:'Kallisto','Poppins',sans-serif; --ff-b:'Poppins',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--ff-b);background:var(--bg);color:var(--texte);line-height:1.7;font-size:16.5px;
  -webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--djaune);text-decoration:none}
a:hover{color:var(--eclat)}
::selection{background:var(--djaune);color:var(--vinyle)}

h1,h2,h3{font-family:var(--ff-t);font-weight:900;line-height:1.15;color:var(--creme);
  text-wrap:balance;letter-spacing:.5px}
h1{font-size:clamp(2.1rem,5.2vw,3.6rem)}
h2{font-size:clamp(1.6rem,3.4vw,2.4rem)}
h3{font-size:1.15rem;letter-spacing:.4px}
p{margin-bottom:1em}
.lead{font-size:1.15rem;color:var(--texte)}
.muted{color:var(--muted)}
.gold{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
section{padding:84px 0}
.kicker{font-family:var(--ff-t);font-weight:700;letter-spacing:3px;text-transform:uppercase;
  font-size:.8rem;color:var(--djaune);display:flex;align-items:center;gap:12px;margin-bottom:18px}
.kicker::before{content:"";width:34px;height:3px;background:var(--grad);border-radius:2px}
.center{text-align:center}
.center .kicker{justify-content:center}

/* ─── Nav ─── */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .3s,box-shadow .3s;padding:14px 0}
.nav.scrolled{background:rgba(36,30,19,.92);backdrop-filter:blur(14px);box-shadow:0 6px 30px rgba(0,0,0,.35)}
.nav .wrap{display:flex;align-items:center;gap:26px}
.nav .logo img{height:44px;width:auto}
.nav ul{display:flex;gap:24px;list-style:none;margin-left:auto;align-items:center}
.nav a.lnk{color:var(--creme);font-weight:700;font-size:.92rem;letter-spacing:.3px}
.nav a.lnk:hover,.nav a.lnk.on{color:var(--djaune)}
.burger{display:none;margin-left:auto;background:none;border:0;cursor:pointer;z-index:70}
.burger span{display:block;width:26px;height:3px;background:var(--djaune);margin:5px 0;border-radius:2px;transition:.3s}

/* ─── Boutons ─── */
.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 30px;border-radius:999px;
  font-family:var(--ff-b);font-weight:700;font-size:.95rem;letter-spacing:.4px;cursor:pointer;border:0;
  transition:transform .2s,box-shadow .2s,background .2s;white-space:nowrap}
.btn.gold{background:var(--grad);color:#2A2211;box-shadow:0 10px 30px rgba(242,145,27,.35)}
.btn.gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(242,145,27,.5);color:#2A2211}
.btn.ghost{background:transparent;color:var(--creme);border:2px solid var(--line)}
.btn.ghost:hover{border-color:var(--djaune);color:var(--djaune);transform:translateY(-2px)}
.btn.sm{padding:10px 20px;font-size:.85rem}

/* ─── Hero ─── */
.hero{position:relative;min-height:92svh;display:flex;align-items:center;overflow:hidden;padding:130px 0 80px}
.hero .bgimg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center}
.hero .veil{position:absolute;inset:0;background:linear-gradient(100deg,rgba(26,21,12,.93) 25%,rgba(36,30,19,.72) 55%,rgba(36,30,19,.35));}
.hero .veil::after{content:"";position:absolute;inset:auto 0 0 0;height:180px;
  background:linear-gradient(180deg,transparent,var(--bg))}
.hero .wrap{position:relative;z-index:2;max-width:1180px}
.hero h1{max-width:14ch}
.hero .lead{max-width:52ch;margin:22px 0 34px;font-size:1.2rem}
.hero .actions{display:flex;gap:16px;flex-wrap:wrap}
.trustline{margin-top:44px;display:flex;gap:34px;flex-wrap:wrap}
.trustline b{font-family:var(--ff-t);font-size:1.5rem;color:var(--djaune);display:block;line-height:1.2}
.trustline span{font-size:.85rem;color:var(--muted)}

/* ─── Cartes & grilles ─── */
.grid{display:grid;gap:22px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}
.card{background:linear-gradient(160deg,var(--bg2),var(--bg3));border:1px solid var(--line);
  border-radius:var(--r);padding:30px;transition:transform .25s,border-color .25s,box-shadow .25s}
.card:hover{transform:translateY(-5px);border-color:rgba(242,183,72,.45);box-shadow:var(--shadow)}
.card .ic{font-size:1.9rem;margin-bottom:14px;display:inline-block;background:rgba(242,183,72,.12);
  width:58px;height:58px;border-radius:16px;display:flex;align-items:center;justify-content:center}
.card h3{margin-bottom:10px}
.card p{color:var(--muted);font-size:.95rem;margin:0}

/* ─── Section photo scindée ─── */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.split .ph{position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow)}
.split .ph img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.split .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(200deg,transparent 55%,rgba(36,30,19,.55))}
.arcmark{position:absolute;top:18px;right:18px;width:64px;opacity:.9;z-index:2}

/* ─── Nos pros ─── */
.cat-card{position:relative;border-radius:var(--r);overflow:hidden;min-height:270px;display:flex;
  align-items:flex-end;border:1px solid var(--line);transition:transform .25s,box-shadow .25s}
.cat-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.cat-card img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s}
.cat-card:hover img.bg{transform:scale(1.06)}
.cat-card .ov{position:absolute;inset:0;background:linear-gradient(190deg,rgba(36,30,19,.15),rgba(26,21,12,.92) 82%)}
.cat-card .inner{position:relative;z-index:2;padding:26px;width:100%}
.cat-card .n{font-size:.85rem;color:var(--djaune);font-weight:700}
.cat-card h3{font-size:1.35rem;margin:4px 0 6px;color:#fff}
.cat-card p{color:var(--texte);font-size:.9rem;margin:0;opacity:.9}
.pro-card{background:linear-gradient(160deg,var(--bg2),var(--bg3));border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s;
  display:flex;flex-direction:column}
.pro-card:hover{transform:translateY(-5px);border-color:rgba(242,183,72,.4);box-shadow:var(--shadow)}
.pro-card .ph{aspect-ratio:1/1;overflow:hidden;position:relative}
.pro-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pro-card:hover .ph img{transform:scale(1.05)}
.pro-card .star{position:absolute;top:12px;right:12px;background:var(--grad);color:#2A2211;font-size:.72rem;
  font-weight:700;padding:5px 12px;border-radius:999px;letter-spacing:.5px}
.pro-card .body{padding:22px;display:flex;flex-direction:column;gap:8px;flex:1}
.pro-card h3{font-size:1.05rem}
.pro-card .tag{color:var(--djaune);font-size:.83rem;font-weight:700}
.pro-card .bio{color:var(--muted);font-size:.9rem;flex:1}
.pro-card .meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.chip{font-size:.74rem;background:rgba(242,183,72,.1);border:1px solid var(--line);color:var(--texte);
  padding:4px 12px;border-radius:999px}
.pro-card .demo{font-size:.88rem;font-weight:700}

/* ─── Témoignages ─── */
.t-card{background:linear-gradient(160deg,var(--bg2),var(--bg3));border:1px solid var(--line);
  border-radius:var(--r);padding:30px;position:relative}
.t-card::before{content:"“";font-family:var(--ff-t);font-size:4.5rem;color:var(--djaune);opacity:.6;
  position:absolute;top:6px;left:22px;line-height:1}
.t-card p{margin:26px 0 18px;font-size:.96rem;color:var(--texte)}
.t-card .who b{color:var(--creme);font-family:var(--ff-t);font-size:.95rem;letter-spacing:.4px}
.t-card .who span{display:block;color:var(--djaune);font-size:.8rem;margin-top:2px}
.stars{color:var(--djaune);letter-spacing:3px;font-size:.9rem}

/* ─── FAQ ─── */
.faq-group{margin-bottom:46px}
.faq-group h2{display:flex;align-items:center;gap:14px;margin-bottom:20px;font-size:1.45rem}
details.faq{background:linear-gradient(160deg,var(--bg2),var(--bg3));border:1px solid var(--line);
  border-radius:var(--rs);margin-bottom:12px;overflow:hidden;transition:border-color .2s}
details.faq[open]{border-color:rgba(242,183,72,.45)}
details.faq summary{cursor:pointer;padding:20px 54px 20px 24px;font-weight:700;color:var(--creme);
  list-style:none;position:relative;font-size:1rem}
details.faq summary::-webkit-details-marker{display:none}
details.faq summary::after{content:"+";font-family:var(--ff-t);position:absolute;right:22px;top:50%;
  transform:translateY(-50%);color:var(--djaune);font-size:1.5rem;transition:transform .25s}
details.faq[open] summary::after{transform:translateY(-50%) rotate(45deg)}
details.faq .a{padding:0 24px 22px;color:var(--muted)}

/* ─── Blogue ─── */
.post-card{background:linear-gradient(160deg,var(--bg2),var(--bg3));border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s,border-color .25s}
.post-card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(242,183,72,.4)}
.post-card .cv{aspect-ratio:16/9;overflow:hidden}
.post-card .cv img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.post-card:hover .cv img{transform:scale(1.05)}
.post-card .body{padding:24px;flex:1;display:flex;flex-direction:column;gap:10px}
.post-card .meta{display:flex;gap:14px;font-size:.8rem;color:var(--muted)}
.post-card .meta .cat{color:var(--djaune);font-weight:700}
.post-card h3{font-size:1.12rem}
.post-card p{color:var(--muted);font-size:.92rem;margin:0;flex:1}
.article{max-width:760px;margin:0 auto}
.article .cover{border-radius:var(--r);overflow:hidden;margin:30px 0;box-shadow:var(--shadow)}
.article-body{font-size:1.05rem}
.article-body h2{margin:44px 0 16px;font-size:1.55rem}
.article-body h3{margin:30px 0 12px;color:var(--djaune)}
.article-body ul,.article-body ol{margin:0 0 1.2em 1.3em}
.article-body li{margin-bottom:.5em}
.article-body strong{color:var(--creme)}

/* ─── Formulaires ─── */
.form-card{background:linear-gradient(160deg,var(--bg2),var(--bg3));border:1px solid var(--line);
  border-radius:var(--r);padding:36px}
.f{display:block;margin-bottom:18px}
.f>span{display:block;font-size:.85rem;font-weight:700;color:var(--creme);margin-bottom:7px;letter-spacing:.3px}
input,select,textarea{width:100%;background:rgba(20,16,9,.55);border:1.5px solid var(--line);
  border-radius:var(--rs);padding:13px 16px;color:var(--creme);font-family:var(--ff-b);font-size:.95rem;
  transition:border-color .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--djaune)}
textarea{min-height:120px;resize:vertical}
select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23F2B748' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.hp{position:absolute;left:-9999px;opacity:0;height:0;overflow:hidden}
.alert{border-radius:var(--rs);padding:16px 20px;margin-bottom:22px;font-weight:600}
.alert.ok{background:rgba(110,190,90,.12);border:1px solid rgba(110,190,90,.4);color:#BBE3A8}
.alert.err{background:rgba(220,90,80,.12);border:1px solid rgba(220,90,80,.4);color:#F2B0A8}

/* ─── RDV ─── */
.slotgrid{display:flex;gap:10px;flex-wrap:wrap;margin:6px 0 4px}
.slot{border:1.5px solid var(--line);border-radius:999px;padding:9px 18px;cursor:pointer;
  color:var(--creme);font-weight:600;font-size:.9rem;background:rgba(20,16,9,.4);transition:.2s}
.slot:hover{border-color:var(--djaune)}
.slot.on{background:var(--grad);color:#2A2211;border-color:transparent}
.daysgrid{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.dayb{border:1.5px solid var(--line);border-radius:var(--rs);padding:10px 14px;text-align:center;
  cursor:pointer;color:var(--creme);background:rgba(20,16,9,.4);font-size:.85rem;transition:.2s;min-width:86px}
.dayb:hover{border-color:var(--djaune)}
.dayb.on{background:var(--grad);color:#2A2211;border-color:transparent;font-weight:700}
.dayb small{display:block;opacity:.75;font-size:.72rem}

/* ─── Diagnostic ─── */
.diag-q{margin-bottom:30px}
.diag-q .lbl{font-weight:700;color:var(--creme);margin-bottom:12px;font-size:1.02rem}
.opt{display:flex;align-items:center;gap:12px;border:1.5px solid var(--line);border-radius:var(--rs);
  padding:14px 18px;margin-bottom:10px;cursor:pointer;transition:.2s;background:rgba(20,16,9,.35)}
.opt:hover{border-color:var(--djaune)}
.opt input{width:auto;accent-color:var(--djaune)}
.opt:has(input:checked){border-color:var(--djaune);background:rgba(242,183,72,.09)}
.score-ring{width:190px;height:190px;border-radius:50%;margin:0 auto 26px;display:flex;align-items:center;
  justify-content:center;background:conic-gradient(var(--djaune) calc(var(--sc)*1%),rgba(242,183,72,.15) 0);
  position:relative}
.score-ring::before{content:"";position:absolute;inset:14px;border-radius:50%;background:var(--bg2)}
.score-ring b{position:relative;font-family:var(--ff-t);font-size:2.6rem;color:var(--creme)}
.score-ring small{position:relative;color:var(--muted)}

/* ─── CTA bande ─── */
.cta-band{position:relative;border-radius:calc(var(--r) + 6px);overflow:hidden;padding:64px 48px;
  background:var(--grad);color:#2A2211;text-align:center}
.cta-band h2{color:#2A2211;font-size:clamp(1.6rem,3.2vw,2.3rem);max-width:22ch;margin:0 auto 14px}
.cta-band p{max-width:52ch;margin:0 auto 28px;font-weight:600}
.cta-band .btn{background:#2A2211;color:var(--eclat)}
.cta-band .btn:hover{transform:translateY(-2px);color:var(--eclat)}
.cta-band img.arc{position:absolute;width:190px;opacity:.25;top:-30px;left:-24px;transform:rotate(160deg)}
.cta-band img.arc.b{top:auto;left:auto;bottom:-34px;right:-20px;transform:rotate(-15deg)}

/* ─── Étapes processus ─── */
.steps{counter-reset:st}
.step{display:flex;gap:22px;padding:26px 0;border-bottom:1px solid var(--line)}
.step:last-child{border-bottom:0}
.step::before{counter-increment:st;content:"0" counter(st);font-family:var(--ff-t);font-weight:900;
  font-size:1.9rem;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;min-width:64px}
.step h3{margin-bottom:6px}
.step p{color:var(--muted);margin:0}
.volet{display:flex;gap:24px;align-items:flex-start;background:linear-gradient(160deg,var(--bg2),var(--bg3));
  border:1px solid var(--line);border-radius:var(--r);padding:28px;margin-bottom:16px}
.volet .num{font-family:var(--ff-t);font-weight:900;font-size:2rem;background:var(--grad);
  -webkit-background-clip:text;background-clip:text;color:transparent;min-width:56px}

/* ─── Footer ─── */
footer{background:#1C1710;border-top:1px solid var(--line);padding:64px 0 30px;margin-top:40px}
footer .cols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:44px}
footer h4{font-family:var(--ff-t);color:var(--creme);margin-bottom:16px;font-size:.95rem;letter-spacing:1px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:var(--muted);font-size:.92rem}
footer a:hover{color:var(--djaune)}
footer .logo img{height:52px;margin-bottom:16px}
footer .base{border-top:1px solid var(--line);padding-top:24px;display:flex;gap:16px;flex-wrap:wrap;
  justify-content:space-between;color:var(--muted);font-size:.82rem}
footer .desc{color:var(--muted);font-size:.9rem;max-width:34ch}

/* ─── Reveal ─── */
.rv{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.rv.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ─── Responsive ─── */
@media (max-width:1020px){
  .g4{grid-template-columns:repeat(2,1fr)}
  .g3{grid-template-columns:repeat(2,1fr)}
  footer .cols{grid-template-columns:1fr 1fr}
  .split{grid-template-columns:1fr;gap:30px}
}
@media (max-width:720px){
  section{padding:60px 0}
  .g2,.g3,.g4{grid-template-columns:1fr}
  .frow{grid-template-columns:1fr}
  .nav ul{position:fixed;inset:0;background:rgba(26,21,12,.98);flex-direction:column;justify-content:center;
    gap:30px;transform:translateX(100%);transition:transform .35s;margin:0}
  .nav ul.open{transform:none}
  .nav a.lnk{font-size:1.2rem}
  .burger{display:block}
  .burger.x span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .hero{min-height:88svh;padding-top:110px}
  .trustline{gap:22px}
  .cta-band{padding:46px 26px}
  .step{flex-direction:column;gap:8px}
  .volet{flex-direction:column;gap:10px}
}
