/* ===========================================================
   Dr. Crousty — Design System (web)  ·  dr-crousty.fr
   =========================================================== */
:root{
  --magenta:#EC008C; --magenta-deep:#A8005F; --cyan:#22B2E8; --yellow:#FFD500;
  --purple:#7E2E8F; --black:#0A0A0A; --ink:#140a16; --white:#fff;
  --orange:#E8801A; --neon:#FF2DAE;
  --grad:linear-gradient(135deg,#EC008C 0%,#7E2E8F 100%);
  --grad-dark:radial-gradient(110% 90% at 78% 12%,rgba(126,46,143,.55) 0%,transparent 55%),
              radial-gradient(90% 80% at 10% 92%,rgba(236,0,140,.42) 0%,transparent 55%),#0A0A0A;
  --glow:0 0 24px rgba(255,45,174,.6); --shadow:0 14px 44px rgba(0,0,0,.5);
  --f-display:"Anton",system-ui,sans-serif; --f-bubble:"Baloo 2",system-ui,sans-serif;
  --f-marker:"Permanent Marker",cursive; --f-body:"Poppins",system-ui,sans-serif;
  --maxw:1200px; --pill:999px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--f-body);background:var(--black);color:var(--white);line-height:1.6;
  overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,video{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:var(--f-display);text-transform:uppercase;line-height:.95;letter-spacing:.01em;font-weight:400}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.hl{color:var(--yellow)} .mag{color:var(--magenta)} .cy{color:var(--cyan)}
section{position:relative}
.eyebrow{font-family:var(--f-marker);color:var(--cyan);font-size:1.05rem;transform:rotate(-1.5deg);display:inline-block;margin-bottom:.4rem}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--f-bubble);font-weight:800;
  font-size:1.02rem;padding:.8em 1.5em;border-radius:var(--pill);border:2px solid transparent;
  cursor:pointer;transition:transform .15s,box-shadow .2s,background .2s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--magenta);color:#fff;box-shadow:var(--glow)}
.btn-primary:hover{box-shadow:0 0 34px rgba(255,45,174,.9)}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.6)}
.btn-ghost:hover{background:rgba(255,255,255,.14)}
.btn-cyan{background:var(--cyan);color:#062436;box-shadow:0 0 22px rgba(34,178,232,.5)}

/* ---------- Badges / pastilles ---------- */
.badge{display:inline-flex;align-items:center;gap:.45em;font-family:var(--f-bubble);font-weight:800;
  font-size:.92rem;padding:.5em 1em;border-radius:var(--pill);border:2px solid #fff;background:var(--grad)}
.badge.halal{background:linear-gradient(135deg,#1aa34a,#0c7d34)}
.badge .tick{display:grid;place-items:center;width:1.35em;height:1.35em;border-radius:50%;background:#fff;color:var(--magenta);font-size:.8em}
.stars{color:var(--yellow);letter-spacing:1px}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;backdrop-filter:blur(10px);
  background:rgba(10,10,10,.72);border-bottom:1px solid rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.6rem 22px;max-width:var(--maxw);margin:0 auto}
.nav .logo{height:50px;width:auto}
.nav ul{display:flex;gap:1.4rem;list-style:none;font-family:var(--f-bubble);font-weight:700}
.nav ul a{padding:.3em 0;border-bottom:2px solid transparent;transition:border-color .2s,color .2s}
.nav ul a:hover{color:var(--magenta);border-color:var(--magenta)}
.nav-cta{display:flex;align-items:center;gap:.6rem}
.burger{display:none;background:none;border:0;color:#fff;font-size:1.7rem;cursor:pointer}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:92vh;display:grid;align-items:center;background:var(--grad-dark);overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.85) 1px,transparent 1.4px);background-size:16px 16px;opacity:.06}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:2rem;align-items:center;position:relative;z-index:2}
.hero h1{font-size:clamp(2.6rem,6vw,5.2rem);text-shadow:var(--glow)}
.hero .lead{font-size:1.15rem;color:#efdcec;max-width:33ch;margin:1rem 0 1.4rem;font-weight:500}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-bottom:1.3rem}
.hero-trust{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center}
.hero-media{position:relative}
.hero-media video,.hero-media img{width:100%;border-radius:1.4rem;border:.28em solid #fff;
  box-shadow:0 0 3em rgba(255,45,174,.55),var(--shadow);aspect-ratio:16/10;object-fit:cover}
.hero-media .floatprice{position:absolute;bottom:-14px;right:-8px;background:var(--magenta);color:#fff;
  font-family:var(--f-bubble);font-weight:800;border:3px solid #fff;border-radius:var(--pill);
  padding:.5em 1em;box-shadow:var(--glow)}
.hero-media .floatprice b{font-size:1.5rem}

/* ---------- Ticker ---------- */
.ticker{background:var(--grad);border-block:3px solid #fff;overflow:hidden;display:flex}
.ticker-track{display:flex;gap:2.2rem;white-space:nowrap;padding:.6rem 0;
  font-family:var(--f-bubble);font-weight:800;font-size:1.15rem;animation:scroll 26s linear infinite}
.ticker i{color:var(--yellow);font-style:normal}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- Sections ---------- */
.sec{padding:clamp(3rem,7vw,5.5rem) 0}
.sec h2{font-size:clamp(2rem,4.5vw,3.4rem);margin-bottom:.3rem}
.sec .sub{color:#cdbccb;max-width:55ch;margin-bottom:2rem}
.sec-dark{background:#0c0712}
.center{text-align:center;margin-inline:auto}

/* tiers */
.tiers{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem}
.tier{flex:1 1 220px;max-width:300px;text-align:center;padding:1.4rem;border-radius:1.2rem;
  border:2px solid rgba(255,255,255,.85);background:rgba(255,255,255,.03)}
.tier b{font-family:var(--f-bubble);font-weight:800;display:block;font-size:1.3rem}
.tier .amt{font-family:var(--f-display);font-size:2.6rem;color:var(--yellow);line-height:1}
.tier.kil{background:linear-gradient(135deg,var(--yellow),#e0a800);color:#3a2b00;border-color:#fff}
.tier.kil .amt{color:#3a2b00}
.tier.giga{background:linear-gradient(135deg,var(--cyan),#1577c4);border-color:#fff}

/* recettes grid */
.grid{display:grid;gap:1.1rem}
.recettes{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.recette{background:#160a1a;border:1px solid rgba(255,255,255,.08);border-radius:1rem;overflow:hidden;
  transition:transform .2s,box-shadow .2s}
.recette:hover{transform:translateY(-4px);box-shadow:var(--glow)}
.recette img{aspect-ratio:1;object-fit:cover}
.recette .n{font-family:var(--f-bubble);font-weight:800;padding:.7rem .8rem .2rem;font-size:1.15rem}
.recette .s{padding:0 .8rem .9rem;color:#b59cb3;font-size:.85rem}
.recette .tag{position:absolute}

/* why / features (cutouts) */
.feats{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.feat{background:linear-gradient(180deg,rgba(126,46,143,.18),transparent);border:1px solid rgba(255,255,255,.08);
  border-radius:1.2rem;padding:1.6rem;text-align:center}
.feat img{height:120px;margin:0 auto .8rem;width:auto;filter:drop-shadow(0 10px 20px rgba(0,0,0,.5))}
.feat h3{font-family:var(--f-bubble);font-size:1.3rem;text-transform:none;color:#fff;margin-bottom:.3rem}
.feat p{color:#c9b6c7;font-size:.95rem}

/* social proof */
.proof{display:grid;grid-template-columns:auto 1fr;gap:2rem;align-items:center;flex-wrap:wrap}
.proof .big{font-family:var(--f-display);font-size:4.5rem;color:var(--yellow);line-height:.9}
.reviews{display:grid;gap:.9rem}
.review{background:#160a1a;border-left:3px solid var(--magenta);border-radius:.6rem;padding:.9rem 1.1rem}
.review .who{font-family:var(--f-bubble);font-weight:700;font-size:.95rem;color:#fff}

/* localisation */
.loc{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
.loc .card{background:#0c0712;border:1px solid rgba(255,255,255,.1);border-radius:1.2rem;padding:1.6rem}
.loc iframe,.loc .map{width:100%;height:320px;border:0;border-radius:1.2rem;filter:saturate(1.1)}
.infoline{display:flex;gap:.6rem;align-items:flex-start;margin:.7rem 0}
.infoline svg{flex:0 0 22px;margin-top:3px}

/* FAQ */
.faq details{background:#160a1a;border:1px solid rgba(255,255,255,.1);border-radius:.8rem;margin-bottom:.7rem;overflow:hidden}
.faq summary{cursor:pointer;padding:1rem 1.2rem;font-family:var(--f-bubble);font-weight:700;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--magenta);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq p{padding:0 1.2rem 1.1rem;color:#c9b6c7}

/* footer */
.site-footer{background:#070309;border-top:1px solid rgba(255,255,255,.1);padding:3rem 0 1.4rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem}
.foot-grid h4{font-family:var(--f-bubble);font-size:1.05rem;margin-bottom:.8rem;color:#fff}
.foot-grid a,.foot-grid p{color:#b59cb3;font-size:.92rem;display:block;margin-bottom:.4rem}
.foot-grid a:hover{color:var(--magenta)}
.foot-logo{height:64px;margin-bottom:1rem}
.socials{display:flex;gap:.8rem;margin-top:.6rem}
.socials a{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:rgba(255,255,255,.08);transition:background .2s}
.socials a:hover{background:var(--magenta)}
.copyright{text-align:center;color:#6b5a6a;font-size:.82rem;margin-top:2rem;border-top:1px solid rgba(255,255,255,.07);padding-top:1.2rem}

/* reveal anim */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}
@keyframes breathe{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}

/* ---------- Responsive ---------- */
@media(max-width:860px){
  .nav ul,.nav .nav-cta .btn-ghost{display:none}
  .burger{display:block}
  .nav.open ul{display:flex;position:absolute;top:64px;left:0;right:0;flex-direction:column;gap:0;
    background:rgba(10,10,10,.97);padding:1rem 22px;border-bottom:1px solid rgba(255,255,255,.1)}
  .nav.open ul a{padding:.8rem 0;border-bottom:1px solid rgba(255,255,255,.08)}
  .hero-grid,.loc,.proof{grid-template-columns:1fr}
  .hero-media{order:-1}
  .foot-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:520px){ .foot-grid{grid-template-columns:1fr} .proof .big{font-size:3.4rem} }
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}
