/*
Theme Name: Neoka Energies v2
Theme URI: https://neoka-energies.fr
Author: Neoka Energies
Description: Thème sur-mesure Neoka Energies — séparation B2B / B2C, simulateur de sélection produit, livre d'or et actualités. Charte bleu marine + orange, logo blanc. À l'activation, les pages, la page d'accueil et le menu sont créés automatiquement.
Version: 1.0
Requires at least: 6.0
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: neoka-energies-v2
*/

/* ============================================================
   NEOKA Energies — charte commune
   ============================================================ */
:root{
  --navy:#0f2c45; --navy-2:#143a5a; --blue:#1f5d8c; --blue-light:#2980b9;
  --accent:#e8a020; --accent-2:#f3b53d; --accent-dark:#cf8c14;
  --b2c:#1f9d74; --b2c-dark:#16805e;
  --ink:#1c2733; --muted:#5b6b7a; --line:#e2e8f0; --bg:#f6f8fb; --card:#ffffff;
  --shadow:0 18px 50px rgba(15,44,69,.10); --shadow-sm:0 6px 20px rgba(15,44,69,.08);
  --radius:16px; --radius-sm:10px; --maxw:1180px;
  --sans:'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.6;font-size:16px;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
h1,h2,h3,h4{line-height:1.18;color:var(--navy);font-weight:800;letter-spacing:-.01em}
h2.section-title{font-size:clamp(26px,3.4vw,40px);margin-bottom:10px}
.eyebrow{display:inline-block;font-size:13px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.lead{color:var(--muted);font-size:clamp(16px,1.5vw,19px);max-width:680px}
.center{text-align:center}.center .lead{margin-left:auto;margin-right:auto}
.pad{padding:clamp(56px,8vw,110px) 0}

.btn{display:inline-flex;align-items:center;gap:9px;padding:14px 26px;border-radius:50px;font-weight:700;font-size:15px;
  border:2px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s,background .2s;white-space:nowrap}
.btn:hover{transform:translateY(-2px)}
.btn-accent{background:var(--accent);color:#fff;box-shadow:0 10px 24px rgba(232,160,32,.35)}
.btn-accent:hover{background:var(--accent-dark)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-navy{background:var(--navy);color:#fff}.btn-navy:hover{background:var(--navy-2)}
.btn-b2c{background:var(--b2c);color:#fff;box-shadow:0 10px 24px rgba(31,157,116,.32)}
.btn-b2c:hover{background:var(--b2c-dark)}
.btn-outline{background:#fff;color:var(--navy);border-color:var(--line)}
.btn-outline:hover{border-color:var(--accent);color:var(--accent-dark)}
.btn-lg{padding:17px 34px;font-size:16px}

.site-header{position:sticky;top:0;z-index:100;background:rgba(15,44,69,.96);backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(255,255,255,.08)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.nav .logo img{height:38px;width:auto}
.nav-links{display:flex;align-items:center;gap:6px;list-style:none}
.nav-links a{color:rgba(255,255,255,.86);font-weight:600;font-size:15px;padding:9px 14px;border-radius:8px;transition:.18s}
.nav-links a:hover,.nav-links a.active,.nav-links li.current-menu-item a{color:#fff;background:rgba(255,255,255,.10)}
.nav-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:26px;height:3px;background:#fff;border-radius:2px;transition:.25s}
@media(max-width:960px){
  .nav-links{position:fixed;inset:74px 0 auto 0;background:var(--navy);flex-direction:column;align-items:stretch;
    gap:0;padding:10px 18px 24px;transform:translateY(-150%);transition:transform .3s;border-bottom:1px solid rgba(255,255,255,.1)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{padding:14px 10px;border-bottom:1px solid rgba(255,255,255,.07)}
  .burger{display:flex}
  .nav-cta .btn-text{display:none}
}

.hero{position:relative;color:#fff;background:radial-gradient(1200px 600px at 80% -10%,rgba(232,160,32,.18),transparent),
  linear-gradient(160deg,#0c243a 0%,#143a5a 55%,#1f5d8c 120%);overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background-image:
  radial-gradient(circle at 12% 80%,rgba(255,255,255,.05) 0 2px,transparent 3px),
  radial-gradient(circle at 90% 30%,rgba(255,255,255,.04) 0 2px,transparent 3px);background-size:120px 120px;opacity:.6;pointer-events:none}
.hero-inner{position:relative;z-index:2;padding:clamp(56px,9vw,120px) 0 clamp(56px,9vw,110px);max-width:780px}
.hero h1{color:#fff;font-size:clamp(34px,5.6vw,62px);line-height:1.05;margin-bottom:20px}
.hero h1 .hl{color:var(--accent-2)}
.hero p{font-size:clamp(16px,1.8vw,20px);color:rgba(255,255,255,.9);max-width:600px;margin-bottom:30px}
.hero-badge{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.2);
  padding:8px 16px;border-radius:50px;font-size:13px;font-weight:700;letter-spacing:.06em;margin-bottom:24px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-wave{position:absolute;bottom:-1px;left:0;width:100%;z-index:1;line-height:0}

.stats{display:flex;flex-wrap:wrap;gap:20px;margin-top:40px}
.stat{flex:1;min-width:120px}
.stat .num{font-size:clamp(30px,4vw,46px);font-weight:800;color:var(--accent-2)}
.stat .lab{font-size:14px;color:rgba(255,255,255,.78)}

.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:960px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-sm);
  transition:transform .2s,box-shadow .2s}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.card .ico{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;font-size:26px;margin-bottom:16px;
  background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff}
.card h3{font-size:20px;margin-bottom:10px}
.card p{color:var(--muted);font-size:15px}
.chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.chip{font-size:12px;font-weight:700;padding:4px 11px;border-radius:50px;background:#eef4f9;color:var(--blue)}
.chip.accent{background:#fdf2dd;color:var(--accent-dark)}
.chip.green{background:#e4f5ee;color:var(--b2c-dark)}

.split{display:grid;grid-template-columns:1fr 1fr;gap:26px}
@media(max-width:820px){.split{grid-template-columns:1fr}}
.universe{position:relative;border-radius:22px;overflow:hidden;color:#fff;padding:44px;min-height:330px;display:flex;flex-direction:column;
  justify-content:flex-end;box-shadow:var(--shadow);transition:transform .25s}
.universe:hover{transform:translateY(-6px)}
.universe.b2b{background:linear-gradient(150deg,#0c243a,#1f5d8c)}
.universe.b2c{background:linear-gradient(150deg,#14613f,#27b083)}
.universe .tag{align-self:flex-start;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.3);
  padding:6px 14px;border-radius:50px;font-size:12px;font-weight:800;letter-spacing:.1em;margin-bottom:auto}
.universe h3{color:#fff;font-size:28px;margin:18px 0 8px}
.universe p{color:rgba(255,255,255,.9);font-size:15px;margin-bottom:20px}
.universe .arrow{display:inline-flex;align-items:center;gap:10px;font-weight:800}
.universe svg.bgicon{position:absolute;right:-30px;top:-20px;width:230px;height:230px;opacity:.12}

.news-card{display:flex;flex-direction:column;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s;height:100%}
.news-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.news-thumb{height:150px;display:grid;place-items:center;font-size:50px;color:#fff}
.news-body{padding:22px;display:flex;flex-direction:column;flex:1}
.news-cat{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--accent-dark);margin-bottom:8px}
.news-card h3{font-size:18px;margin-bottom:10px}
.news-card .more{margin-top:auto;font-weight:800;color:var(--blue);display:inline-flex;gap:7px;align-items:center}

.bg-white{background:#fff}
.bg-navy{background:var(--navy);color:#fff}
.bg-navy h2,.bg-navy h3{color:#fff}.bg-navy .lead{color:rgba(255,255,255,.8)}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
@media(max-width:820px){.feature-row{grid-template-columns:1fr}}
.feature-list{list-style:none;margin-top:20px;display:grid;gap:14px}
.feature-list li{display:flex;gap:12px;align-items:flex-start}
.feature-list .dot{flex:none;width:26px;height:26px;border-radius:50%;background:#fdf2dd;color:var(--accent-dark);display:grid;place-items:center;font-weight:800;margin-top:2px}

.brands{display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:center}
.brand-pill{padding:12px 22px;background:#fff;border:1px solid var(--line);border-radius:12px;font-weight:800;color:var(--navy);
  font-size:17px;box-shadow:var(--shadow-sm)}

.form{display:grid;gap:16px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:640px){.form .row{grid-template-columns:1fr}}
label{font-weight:700;font-size:14px;color:var(--navy);display:block;margin-bottom:6px}
input,select,textarea{width:100%;padding:13px 15px;border:1.6px solid var(--line);border-radius:10px;font-size:15px;font-family:inherit;background:#fff;transition:border .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue)}

.site-footer{background:#0a1f31;color:rgba(255,255,255,.75);padding:60px 0 28px;font-size:14px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:34px;margin-bottom:36px}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer img.flogo{height:34px;margin-bottom:16px}
.site-footer h4{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:14px}
.site-footer ul{list-style:none;display:grid;gap:9px}
.site-footer a:hover{color:var(--accent-2)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px}
.footer-contact b{color:#fff;display:block;font-size:17px}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.float{animation:float 6s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.float{animation:none}}

.cta-band{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;border-radius:24px;padding:48px;text-align:center;box-shadow:var(--shadow)}
.cta-band h2{color:#fff;margin-bottom:12px}
.cta-band p{color:rgba(255,255,255,.85);max-width:560px;margin:0 auto 24px}

/* Univers B2C */
.b2c-hero{background:radial-gradient(1100px 600px at 80% -10%,rgba(39,176,131,.25),transparent),linear-gradient(160deg,#0c243a 0%,#14613f 70%,#27b083 130%)}
.b2c-hero .hero-badge{background:rgba(255,255,255,.12)}
.b2c-hero h1 .hl{color:#7ff0c4}

/* Simulateur */
.sim{background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.sim-head{background:linear-gradient(135deg,#14613f,#27b083);color:#fff;padding:28px 32px}
.sim-head h2{color:#fff;font-size:24px}
.sim-head p{color:rgba(255,255,255,.9);margin-top:6px}
.sim-body{padding:30px 32px}
.opts{display:flex;flex-wrap:wrap;gap:10px}
.opt{position:relative}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer}
.opt span{display:inline-flex;align-items:center;gap:8px;padding:11px 16px;border:1.8px solid var(--line);border-radius:12px;font-weight:600;font-size:14px;cursor:pointer;transition:.15s;background:#fff}
.opt input:checked + span{border-color:var(--b2c);background:#e9f8f1;color:var(--b2c-dark)}
.sim-field{margin-bottom:22px}
.sim-field>label{font-size:15px;margin-bottom:10px}
.result{display:none;margin-top:6px}
.result.show{display:block;animation:fadeup .5s ease}
@keyframes fadeup{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.reco{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:680px){.reco{grid-template-columns:1fr}}
.reco-main{background:linear-gradient(135deg,#0c243a,#14613f);color:#fff;border-radius:18px;padding:26px}
.reco-main .k{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#7ff0c4}
.reco-main h3{color:#fff;font-size:26px;margin:8px 0 10px}
.reco-main p{color:rgba(255,255,255,.9);font-size:15px}
.reco-side{display:grid;gap:14px}
.reco-side .box{border:1px solid var(--line);border-radius:14px;padding:16px 18px;background:var(--bg)}
.reco-side .box b{color:var(--navy)}
.brand-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.brand-row .bp{padding:8px 14px;border-radius:10px;background:#fff;border:1px solid var(--line);font-weight:800;color:var(--navy);font-size:14px}
.progress{height:6px;background:var(--line);border-radius:6px;overflow:hidden;margin-bottom:24px}
.progress i{display:block;height:100%;background:var(--b2c);width:0;transition:width .3s}

/* Livre d'or */
.reviews{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:760px){.reviews{grid-template-columns:1fr}}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.review .stars{color:var(--accent);font-size:18px;letter-spacing:2px}
.review p{color:var(--ink);margin:12px 0 16px;font-size:15px}
.review .who{display:flex;align-items:center;gap:12px}
.review .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;display:grid;place-items:center;font-weight:800}
.review .who b{color:var(--navy)}
.review .who span{font-size:13px;color:var(--muted);display:block}
.star-pick{display:flex;gap:6px;font-size:28px;cursor:pointer}
.star-pick span{color:var(--line);transition:.1s}
.star-pick span.on{color:var(--accent)}
.note{background:#eef4f9;border-radius:12px;padding:14px 16px;font-size:13px;color:var(--muted);margin-top:14px}
