/* ============================================================
   PLAYZWELL — styles partagés
   Palette issue du logo : noir #1D1D1B / cyan #4FC8E7 / blanc
   Signature : la diagonale du "Z" du logo (skew -14°)
   ============================================================ */
:root{
  --ink:#1D1D1B;
  --ink-soft:#2A2A28;
  --cyan:#4FC8E7;
  --cyan-ink:#0E8FB5;
  --paper:#FFFFFF;
  --mist:#F0F4F6;
  --steel:#55606A;
  --line:#E1E7EA;
  --radius:14px;
  --skew:-14deg;
  --font-display:'Archivo Black',sans-serif;
  --font-body:'Archivo',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
body{overflow-x:clip;font-family:var(--font-body);color:var(--ink);background:var(--paper);line-height:1.65;font-size:16.5px}
img{max-width:100%;display:block}
a{color:var(--cyan-ink)}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- typographie ---------- */
h1,h2,h3{font-family:var(--font-display);font-weight:400;line-height:1.12;letter-spacing:.01em;text-transform:uppercase}
h1{font-size:clamp(1.85rem,5.2vw,3.9rem)}
h2{font-size:clamp(1.5rem,3.4vw,2.4rem);margin-bottom:18px}
h3{font-size:1.08rem;margin-bottom:10px}
p{color:var(--steel)}
.on-dark p{color:#B9C4CA}
.eyebrow{font-family:var(--font-mono);font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--cyan-ink);display:block;margin-bottom:14px}
.on-dark .eyebrow{color:var(--cyan)}

/* le trait "Z" sous les titres */
.z-under{position:relative;display:inline-block;padding-bottom:14px}
.z-under::after{content:"";position:absolute;left:0;bottom:0;width:74px;height:7px;background:var(--cyan);transform:skewX(var(--skew))}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav-logo img{height:42px;width:auto}
.nav-links{display:flex;gap:26px;align-items:center;list-style:none}
.nav-links a{font-weight:600;font-size:.92rem;color:var(--ink);text-decoration:none}
.nav-links a:hover,.nav-links a.active{color:var(--cyan-ink)}
.nav-cta{background:var(--ink);color:#fff!important;padding:10px 20px;border-radius:8px;transform:skewX(var(--skew))}
.nav-cta span{display:inline-block;transform:skewX(calc(var(--skew) * -1))}
.nav-cta:hover{background:var(--cyan-ink)}
.lang-switch{font-family:var(--font-mono);font-size:.78rem;border:1.5px solid var(--ink);border-radius:8px;overflow:hidden;display:flex;cursor:pointer}
.lang-switch button{border:0;background:transparent;padding:6px 10px;font:inherit;cursor:pointer;color:var(--ink)}
.lang-switch button.on{background:var(--ink);color:#fff}
.burger{display:none;background:none;border:0;font-size:1.7rem;cursor:pointer;color:var(--ink)}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;opacity:.28}
.hero-veil{position:absolute;inset:0;background:linear-gradient(100deg,var(--ink) 34%,rgba(29,29,27,.55) 70%,rgba(29,29,27,.25))}
.hero-inner{position:relative;padding-top:110px;padding-bottom:130px}
.hero h1 .cy{color:var(--cyan)}
.hero p.lead{max-width:600px;font-size:1.15rem;color:#C9D3D8;margin:22px 0 34px}
/* diagonale Z en pied de hero */
.hero::after{content:"";position:absolute;left:-6%;bottom:-26px;width:112%;height:52px;background:var(--cyan);transform:rotate(-2.4deg)}

/* ---------- boutons ---------- */
.btn{display:inline-block;font-weight:700;font-size:.95rem;text-decoration:none;padding:14px 28px;border-radius:9px;transform:skewX(var(--skew));transition:background .2s,color .2s}
.btn > span{display:inline-block;transform:skewX(calc(var(--skew) * -1))}
.btn-cyan{background:var(--cyan);color:var(--ink)}
.btn-cyan:hover{background:#fff}
.btn-ghost{border:2px solid #fff;color:#fff;margin-left:12px}
.btn-ghost:hover{background:#fff;color:var(--ink)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:var(--cyan-ink)}

/* ---------- sections ---------- */
section{padding:88px 0}
.sec-mist{background:var(--mist)}
.sec-ink{background:var(--ink);color:#fff}
.sec-head{max-width:720px;margin-bottom:48px}

/* ---------- cartes produits façon logo (boîte pleine + boîte contour décalées) ---------- */
.prod-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:34px}
.prod-card{position:relative;text-decoration:none;color:inherit;display:block}
.prod-frame{position:absolute;inset:14px -14px -14px 14px;border:2.5px solid var(--ink);border-radius:var(--radius);transition:border-color .25s}
.prod-body{position:relative;background:var(--ink);color:#fff;border-radius:var(--radius);overflow:hidden;isolation:isolate;transform:translateZ(0);-webkit-mask-image:-webkit-radial-gradient(white,black);clip-path:inset(0 round var(--radius));transition:transform .25s}
.prod-body img{height:220px;width:100%;object-fit:cover;opacity:.92;border-radius:var(--radius) var(--radius) 0 0}
.prod-txt{padding:24px 26px 30px}
.prod-txt h3{color:#fff}
.prod-txt p{color:#B9C4CA;font-size:.95rem;min-height:72px}
.prod-more{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.14em;color:var(--cyan);text-transform:uppercase}
.prod-card:hover .prod-body{transform:translate(-5px,-5px)}
.prod-card:hover .prod-frame{border-color:var(--cyan)}

/* ---------- bandeau logos clients ---------- */
.logo-belt{overflow:hidden;padding:34px 0;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.logo-track{display:flex;gap:56px;align-items:center;width:max-content;animation:belt 36s linear infinite}
.logo-track img{height:74px;width:auto;border-radius:10px;filter:grayscale(1);opacity:.75;transition:filter .25s,opacity .25s}
.logo-track img:hover{filter:none;opacity:1}
@keyframes belt{to{transform:translateX(-50%)}}

/* ---------- listes de features ---------- */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:26px}
.feat{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px}
.sec-ink .feat{background:var(--ink-soft);border-color:#3A3A38}
.sec-ink .feat h3{color:#fff}
.feat .ico{width:44px;height:44px;border-radius:9px;background:var(--cyan);display:flex;align-items:center;justify-content:center;margin-bottom:16px;transform:skewX(var(--skew))}
.feat .ico svg{width:22px;height:22px;stroke:var(--ink);transform:skewX(calc(var(--skew) * -1))}
.feat p{font-size:.93rem}

ul.checks{list-style:none}
ul.checks li{padding:9px 0 9px 34px;position:relative;color:var(--steel);border-bottom:1px dashed var(--line)}
ul.checks li:last-child{border-bottom:0}
ul.checks li::before{content:"";position:absolute;left:0;top:15px;width:16px;height:9px;background:var(--cyan);transform:skewX(var(--skew))}
.on-dark ul.checks li{color:#B9C4CA;border-color:#3A3A38}

/* ---------- page produit : bandeau titre + duo colonne ---------- */
.p-hero{background:var(--ink);color:#fff;position:relative;overflow:hidden}
.p-hero .hero-inner{padding-top:80px;padding-bottom:90px}
.duo{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.duo .imgbox{position:relative}
.duo .imgbox img{border-radius:var(--radius);width:100%;object-fit:cover}
.duo .imgbox::after{content:"";position:absolute;inset:16px -16px -16px 16px;border:2.5px solid var(--cyan);border-radius:var(--radius);z-index:-1}
.spec{font-family:var(--font-mono);font-size:.82rem;background:var(--mist);border-radius:10px;padding:16px 18px;margin-top:22px;color:var(--ink)}
.spec b{color:var(--cyan-ink)}

/* ---------- bénéfices (bande sombre) ---------- */
.bene{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2px;background:#3A3A38;border-radius:var(--radius);overflow:hidden}
.bene div{background:var(--ink-soft);padding:26px 22px}
.bene div strong{display:block;font-family:var(--font-display);font-size:.95rem;text-transform:uppercase;color:var(--cyan);margin-bottom:8px}
.bene div span{color:#B9C4CA;font-size:.9rem}

/* ---------- CTA final ---------- */
.cta-band{background:var(--cyan);padding:70px 0;position:relative;overflow:hidden}
.cta-band h2{color:var(--ink)}
.cta-band p{color:#12414F;max-width:560px}
.cta-flex{display:flex;align-items:center;justify-content:space-between;gap:34px;flex-wrap:wrap}

/* ---------- formulaire contact ---------- */
form.contact{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:760px}
form.contact .full{grid-column:1/-1}
form.contact label{font-weight:600;font-size:.88rem;display:block;margin-bottom:6px}
form.contact input,form.contact select,form.contact textarea{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:9px;font:inherit;background:#fff}
form.contact input:focus,form.contact select:focus,form.contact textarea:focus{outline:2px solid var(--cyan);border-color:var(--cyan)}
form.contact textarea{min-height:140px;resize:vertical}
.form-note{font-size:.82rem;color:var(--steel)}
.form-status{font-weight:600;margin-top:8px}
.form-status.ok{color:#0B7A3E}
.form-status.err{color:#B3261E}

.contact-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:22px;margin-bottom:52px}
.contact-cards .feat a{font-weight:700;text-decoration:none;color:var(--ink);font-size:1.02rem}
.contact-cards .feat a:hover{color:var(--cyan-ink)}

/* ---------- footer ---------- */
footer{background:var(--ink);color:#9AA6AC;padding:56px 0 32px;font-size:.9rem}
.foot-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:40px;margin-bottom:38px}
footer h4{color:#fff;font-family:var(--font-display);font-size:.9rem;text-transform:uppercase;margin-bottom:14px}
footer ul{list-style:none}
footer li{margin-bottom:9px}
footer a{color:#9AA6AC;text-decoration:none}
footer a:hover{color:var(--cyan)}
.foot-logo{background:#fff;border-radius:10px;padding:10px 14px;display:inline-block;margin-bottom:16px}
.foot-logo img{height:36px}
.foot-base{border-top:1px solid #3A3A38;padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;font-size:.82rem}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .duo{grid-template-columns:1fr}
  .prod-frame{display:none}
  .duo .imgbox::after{display:none}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{position:fixed;inset:74px 0 auto 0;background:#fff;flex-direction:column;align-items:stretch;gap:0;padding:6px 24px 22px;border-bottom:1px solid var(--line);box-shadow:0 20px 34px rgba(29,29,27,.14);display:none}
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:15px 2px;font-size:1.02rem;border-bottom:1px solid var(--line)}
  .nav-links a.nav-cta{display:block;text-align:center;margin-top:18px;padding:14px;border-bottom:0}
  .nav-links li:last-child{display:flex;justify-content:flex-end;padding-top:16px}
  .burger{display:block}
}
@media(max-width:620px){
  form.contact{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr}
  section{padding:64px 0}
  .hero-inner{padding-top:80px;padding-bottom:100px}
  .btn-ghost{margin-left:0;margin-top:12px}
}

/* ---------- affinage mobile ---------- */
@media(max-width:620px){
  .eyebrow{font-size:.66rem;letter-spacing:.14em}
  .hero p.lead{font-size:1.04rem}
  .logo-track{gap:36px}
  .logo-track img{height:56px}
  .btn{display:block;text-align:center;margin-right:0}
  .btn + .btn{margin-top:14px}
  .cta-flex{flex-direction:column;align-items:flex-start}
  .nav-logo img{height:36px}
}

/* ---------- section "pour qui" ---------- */
.aud-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:26px}
.aud{position:relative;border-radius:var(--radius);overflow:hidden;min-height:240px;display:flex;align-items:flex-end;background:var(--ink)}
.aud img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.48}
.aud > div{position:relative;padding:22px;width:100%;background:linear-gradient(transparent,rgba(29,29,27,.88) 45%)}
.aud h3{color:#fff}
.aud p{color:#C9D3D8;font-size:.9rem}

/* ---------- étapes numérotées ---------- */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:26px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px}
.step .n{font-family:var(--font-mono);font-size:.78rem;font-weight:600;letter-spacing:.14em;color:var(--ink);display:inline-block;background:var(--cyan);padding:5px 12px;border-radius:7px;margin-bottom:14px;transform:skewX(var(--skew))}
.step .n span{display:inline-block;transform:skewX(calc(var(--skew) * -1))}
.step p{font-size:.93rem}

/* ---------- FAQ ---------- */
.faq{max-width:840px}
.faq details{border:1px solid var(--line);border-radius:12px;margin-bottom:12px;background:#fff}
.faq summary{cursor:pointer;font-weight:700;padding:17px 48px 17px 20px;list-style:none;position:relative}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:18px;top:50%;transform:translateY(-50%);color:var(--cyan-ink);font-size:1.35rem;font-weight:700}
.faq details[open] summary::after{content:"\2013"}
.faq details p{padding:0 20px 18px;font-size:.95rem}

/* ---------- label bandeau références ---------- */
.belt-label{text-align:center;padding-top:26px;background:#fff}
.belt-label .eyebrow{margin-bottom:0}

/* ---------- visuels détourés ---------- */
.cutout{background:linear-gradient(165deg,#fff,var(--mist));border:1px solid var(--line);border-radius:var(--radius);padding:34px;display:flex;align-items:center;justify-content:center;min-height:320px}
.cutout img{max-height:480px;max-width:100%;width:auto;object-fit:contain}
.on-dark .cutout,.sec-ink .cutout{background:linear-gradient(165deg,var(--ink-soft),#242422);border-color:#3A3A38}

/* ---------- galerie produit ---------- */
.gal{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:20px}
.gal figure{background:linear-gradient(165deg,#fff,var(--mist));border:1px solid var(--line);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:14px;margin:0}
.gal img{max-height:230px;width:auto;max-width:100%;object-fit:contain}
.gal img.photo{width:100%;height:230px;object-fit:cover;border-radius:10px}
.gal figcaption{font-family:var(--font-mono);font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--steel);text-align:center}

/* ---------- bandeau écosystème / partenaire ---------- */
.partner-strip{display:flex;gap:38px;align-items:center;flex-wrap:wrap;background:#fff;border-radius:var(--radius);padding:24px 30px;margin-top:36px}
.partner-strip img{height:58px;width:auto}
.partner-strip .lbl{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--steel)}

/* ---------- logo footer blanc ---------- */
.foot-logo-w{height:42px;width:auto;margin-bottom:16px;display:block}
.duo .imgbox .cutout img{width:auto;height:auto;max-height:480px;object-fit:contain;border-radius:0}

/* ---------- visuel produit illustré (cartes accueil) ---------- */
.prod-visual{height:230px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
  background:
    radial-gradient(circle at 50% 62%, rgba(79,200,231,.30), transparent 62%),
    repeating-linear-gradient(0deg, transparent 0 34px, rgba(79,200,231,.10) 34px 35px),
    repeating-linear-gradient(90deg, transparent 0 34px, rgba(79,200,231,.10) 34px 35px),
    linear-gradient(180deg,#2B2B29,#1D1D1B);
  border-radius:var(--radius) var(--radius) 0 0}
.prod-visual::after{content:"";position:absolute;left:-8%;bottom:-6px;width:116%;height:14px;background:var(--cyan);opacity:.85;transform:rotate(-3deg)}
.prod-visual img{max-height:180px;max-width:76%;width:auto;object-fit:contain;position:relative;filter:drop-shadow(0 16px 26px rgba(0,0,0,.5))}

/* ---------- bannière cookies ---------- */
#cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:120;background:var(--ink);color:#C9D3D8;border-radius:14px;padding:18px 20px;box-shadow:0 18px 40px rgba(0,0,0,.35);display:none;gap:16px;align-items:center;flex-wrap:wrap;font-size:.9rem}
#cookie-banner.show{display:flex}
#cookie-banner p{color:#C9D3D8;margin:0;flex:1 1 320px}
#cookie-banner a{color:var(--cyan)}
#cookie-banner .ck-btns{display:flex;gap:10px;flex-wrap:wrap}
#cookie-banner button{font:inherit;font-weight:700;border:0;border-radius:8px;padding:10px 18px;cursor:pointer}
#ck-ok{background:var(--cyan);color:var(--ink)}
#ck-no{background:transparent;color:#fff;border:1.5px solid #5a5a58}
@media(max-width:620px){#cookie-banner{left:10px;right:10px;bottom:10px}}
