/* Sora — auto-hébergée (RGPD : plus de requête vers Google Fonts) */
/* latin-ext */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/sora-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(../assets/fonts/sora-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/sora-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(../assets/fonts/sora-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/sora-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(../assets/fonts/sora-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../assets/fonts/sora-latin-ext.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(../assets/fonts/sora-latin.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/* ══════════════════════════════════════════════
   ECO-GREEN — Light-Only Premium Design System
   No dark mode. Clean, modern, conversion-focused.
   ══════════════════════════════════════════════ */

/* ══ RESET ══ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:"Sora",sans-serif;overflow-x:hidden;line-height:1.6;background:#fff;color:#1a2e1f}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}

/* ══ DESIGN TOKENS ══ */
:root{
  --g:#00b84a; --g2:#00a041; --g3:#34d058; --g-dark:#007a2f;
  --gd:rgba(0,184,74,.07); --gb:rgba(0,184,74,.18);
  --bg:#ffffff; --bg2:#f8faf9; --bg3:#eef5f0;
  --card:#ffffff; --card-hover:#f0f9f2;
  --border:rgba(0,80,40,.08); --border-strong:rgba(0,80,40,.14);
  --text:#1a2e1f; --text2:#2d4a35; --muted:#4a6b52;
  --shadow:0 2px 12px rgba(0,50,25,.06);
  --shadow-lg:0 16px 48px rgba(0,50,25,.1);
  --shadow-xl:0 24px 64px rgba(0,50,25,.12);
  --font:"Sora",sans-serif; --mono:"JetBrains Mono",monospace;
  --ease:cubic-bezier(0,0,.2,1); --spring:cubic-bezier(.34,1.56,.64,1);
  --r:14px; --rm:22px; --rl:32px;
}

/* ══ ANIMATIONS ══ */
@keyframes fade-up{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes slide-in{from{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:none}}
@keyframes pulse-ring{0%{transform:scale(1);opacity:.8}100%{transform:scale(1.8);opacity:0}}
@keyframes dot-blink{0%,100%{opacity:1}50%{opacity:.2}}
@keyframes glow-breathe{0%,100%{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes check-in{from{transform:scale(0)}to{transform:scale(1)}}
@keyframes scroll-anim{0%{top:0;opacity:1}100%{top:40px;opacity:0}}
@keyframes energy-flow{0%{stroke-dashoffset:20}100%{stroke-dashoffset:0}}

.rv{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.18s}.d4{transition-delay:.24s}.d5{transition-delay:.30s}

/* ══ LAYOUT ══ */
.cnt{width:100%;max-width:1200px;margin:0 auto;padding:0 28px}
.cnt-sm{max-width:900px;margin:0 auto;padding:0 28px}
section{padding:100px 0}

/* ══ TYPOGRAPHY ══ */
.section-tag{display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--g);margin-bottom:14px}
.section-tag-dot{width:6px;height:6px;border-radius:50%;background:var(--g)}
.section-title{font-size:clamp(28px,4vw,52px);font-weight:800;letter-spacing:-.05em;line-height:1.05;margin-bottom:14px;color:var(--text)}
.section-lead{font-size:17px;color:var(--muted);font-weight:300;max-width:580px;margin:0 auto;line-height:1.7}
.section-header{text-align:center;margin-bottom:64px}

/* ══ BUTTONS ══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 28px;border-radius:var(--r);font-family:var(--font);font-weight:700;font-size:15px;cursor:pointer;border:none;transition:all .22s var(--ease);white-space:nowrap;letter-spacing:-.01em;position:relative;overflow:hidden}
.btn-prime{background:var(--g-dark);color:#fff;font-weight:800;box-shadow:0 4px 20px rgba(0,184,74,.25)}
.btn-prime:hover{background:var(--g-dark);transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,184,74,.35)}
.btn-prime:active{transform:none}
.btn-outline{background:transparent;border:1.5px solid var(--border-strong);color:var(--text)}
.btn-outline:hover{border-color:var(--g);color:var(--g)}
.btn-ghost{background:var(--bg3);color:var(--text2)}
.btn-ghost:hover{background:var(--gd)}
.btn-lg{padding:18px 36px;font-size:17px;border-radius:var(--rm)}
.btn-xl{padding:20px 44px;font-size:18px;border-radius:var(--rm);letter-spacing:-.02em}
.btn-full{width:100%}
.btn-sm{padding:10px 20px;font-size:13px;border-radius:10px}

/* ══ HEADER ══ */
.hdr{position:fixed;top:0;left:0;right:0;z-index:900;padding:14px 0;transition:all .35s;background:rgba(255,255,255,.85);backdrop-filter:blur(20px) saturate(1.4);border-bottom:1px solid transparent}
.hdr.solid{border-bottom-color:var(--border);box-shadow:var(--shadow)}
.hdr-inner{display:flex;align-items:center;justify-content:space-between;gap:12px}
.hdr-logo{flex-shrink:0;display:flex;align-items:center}
.hdr-logo img{display:block;height:38px;width:auto;max-width:160px;object-fit:contain}
.hdr-logo a{display:flex}
.hdr-nav{display:flex;align-items:center;gap:4px}
.hdr-nav a{font-size:13px;font-weight:500;color:var(--muted);padding:8px 14px;border-radius:10px;transition:all .2s}
.hdr-nav a:hover,.hdr-nav a.active{color:var(--g-dark);background:var(--gd)}
.hdr-actions{display:flex;align-items:center;gap:10px}
.hdr-phone{font-size:13px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:6px;transition:color .2s}
.hdr-phone:hover{color:var(--g)}
.hdr-btn{padding:10px 20px;font-size:13px;border-radius:10px}

/* Language switch — minimal, pushed far right */
.lang-switch{display:inline-flex;gap:0;align-items:center}
.lang-btn{padding:2px 6px;font-size:10.5px;font-weight:500;letter-spacing:.04em;color:var(--muted);transition:color .15s ease,opacity .15s ease;cursor:pointer;border:none;background:none;font-family:var(--font);opacity:.55;line-height:1}
.lang-btn + .lang-btn{border-left:1px solid rgba(0,0,0,.08)}
.lang-btn.active{color:var(--text);opacity:.9}
.lang-btn:hover:not(.active){color:var(--text);opacity:.8}
/* In header: push to far right, separate from CTA cluster */
.hdr-actions .lang-switch{order:99;margin-left:auto;padding-left:10px;border-left:1px solid rgba(0,0,0,.06)}

/* Mega menu */
.hdr-nav-item{position:relative}
.hdr-nav-item>a,.hdr-nav-item>.hdr-nav-trigger{font-size:13px;font-weight:500;color:var(--muted);padding:8px 14px;border-radius:10px;transition:all .2s;display:flex;align-items:center;gap:4px;cursor:pointer;background:none;border:0;font-family:inherit;line-height:inherit}
.hdr-nav-item>a:hover,.hdr-nav-item.open>a,.hdr-nav-item>.hdr-nav-trigger:hover,.hdr-nav-item.open>.hdr-nav-trigger{color:var(--g-dark);background:var(--gd)}
.hdr-nav-trigger:focus-visible{outline:2px solid var(--g);outline-offset:2px}
.hdr-nav-item .chevron{width:10px;height:10px;border:none;display:inline-block;transition:transform .2s}
.hdr-nav-item .chevron::after{content:"";display:block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px)}
.hdr-nav-item.open .chevron::after{transform:rotate(-135deg) translateY(-2px)}
.mega{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:260px;background:#fff;border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow-lg);padding:16px;padding-top:28px;opacity:0;visibility:hidden;transition:opacity .2s,transform .2s;pointer-events:none;z-index:950}
.mega::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px;background:transparent}
.mega::after{content:"";position:absolute;top:16px;left:50%;width:14px;height:14px;background:#fff;border-left:1px solid var(--border);border-top:1px solid var(--border);transform:translateX(-50%) rotate(45deg)}
.hdr-nav-item.open .mega{opacity:1;visibility:visible;pointer-events:auto}
.mega-title{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;padding:4px 8px}
.mega a{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:500;color:var(--text2);transition:all .15s}
.mega a:hover{background:var(--gd);color:var(--g-dark)}
.mega a .mega-ico{font-size:16px;width:24px;text-align:center;flex-shrink:0}
.mega-divider{height:1px;background:var(--border);margin:8px 0}
.mega a.mega-hub{font-weight:700;color:var(--g-dark);border-top:1px solid var(--border);margin-top:8px;padding-top:12px}
.mega a.mega-hub:hover{background:var(--gb)}

/* Grouped mega-menu (multi-column with sub-headings) */
.mega-grouped{display:grid;grid-template-columns:repeat(var(--mega-cols,3),minmax(180px,1fr));gap:8px 12px;min-width:auto;padding:20px 18px}
.mega-grouped::after{display:none}
.mega-col{display:flex;flex-direction:column;gap:2px;padding:2px}
.mega-col-title{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);padding:6px 10px 8px;border-bottom:1px solid var(--border);margin-bottom:6px}
.mega-grouped a{padding:8px 10px;font-size:13px;border-radius:8px}
.mega-grouped .mega-hub{font-weight:600;color:var(--g);border-top:1px solid var(--border);margin-top:6px;padding-top:10px;font-size:12px}
.mega-grouped .mega-sub{font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--text2);padding:8px 10px 4px;text-transform:uppercase;opacity:.7}
.mega-grouped .mega-sub-link{padding-left:18px;font-size:12.5px;color:var(--text2)}

/* Mobile nav accordion */
.mob-section{border-bottom:1px solid var(--border)}
.mob-section-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:16px;font-size:18px;font-weight:600;color:var(--text);cursor:pointer;background:none;border:none;font-family:var(--font)}
.mob-section-toggle .mob-chevron{font-size:12px;transition:transform .2s;color:var(--muted)}
.mob-section.open .mob-chevron{transform:rotate(180deg)}
.mob-section-links{display:none;padding:0 16px 12px}
.mob-section.open .mob-section-links{display:block}
.mob-section-links a{display:flex;align-items:center;padding:12px 14px;font-size:15px;font-weight:500;color:var(--text2);border-radius:10px;transition:all .15s;min-height:44px}
.mob-section-links a:hover,.mob-section-links a:active{background:var(--gd);color:var(--g)}
/* Mobile nav — nested sub-sections */
.mob-subsection{margin:2px 0}
.mob-subsection-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;background:none;border:none;font-family:var(--font);border-radius:10px;text-align:left}
.mob-subsection-toggle:hover{background:var(--gd)}
.mob-subsection-toggle .mob-chevron{font-size:10px;transition:transform .2s;color:var(--muted)}
.mob-subsection.open .mob-chevron{transform:rotate(180deg)}
.mob-subsection-links{display:none;padding:0 0 6px 12px;border-left:2px solid var(--border);margin-left:14px}
.mob-subsection.open .mob-subsection-links{display:block}
.mob-subsection-links a{padding:10px 12px;font-size:14px;min-height:40px;color:var(--text2)}

/* Mobile menu */
.hdr-burger{display:none;flex-direction:column;gap:5px;padding:10px;cursor:pointer;min-width:44px;min-height:44px;align-items:center;justify-content:center;border-radius:10px;transition:background .2s;background:none;border:0}
.hdr-burger:active{background:var(--gd)}
.hdr-burger:focus-visible{outline:2px solid var(--g);outline-offset:2px}
.hdr-burger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.mobile-nav{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:899;padding:80px 20px 28px;flex-direction:column;gap:4px;overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-nav.open{display:flex}
.mobile-nav a{font-size:18px;font-weight:600;padding:16px;border-radius:12px;color:var(--text);transition:all .2s}
.mobile-nav a:hover{background:var(--gd);color:var(--g)}
.mobile-nav a[data-i18n="nav.quote"]{display:none}

/* ══ HERO — Premium text & content layer ══ */

/* Badge */
.hero-badge{display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,0,0,.35);backdrop-filter:blur(16px) saturate(1.3);
  border:1px solid rgba(255,255,255,.12);border-radius:999px;
  padding:9px 20px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85);
  margin-bottom:28px;animation:fade-up .6s .1s both}
.badge-live{width:8px;height:8px;border-radius:50%;background:var(--g3);box-shadow:0 0 6px var(--g3);position:relative}
.badge-live::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--g3);animation:pulse-ring 1.5s ease-out infinite}

/* Title — strong text-shadow for readability */
.hero h1{font-size:clamp(38px,5.5vw,74px);font-weight:800;line-height:.98;letter-spacing:-.05em;margin-bottom:28px;animation:fade-up .6s .25s both;color:#fff;
  text-shadow:0 2px 8px rgba(0,0,0,.5),0 8px 32px rgba(0,0,0,.3)}
.hero h1 .accent{color:var(--g3);text-shadow:0 2px 8px rgba(0,0,0,.5),0 0 40px rgba(0,184,74,.2)}

/* Subtitle */
.hero-sub{font-size:clamp(15px,1.8vw,19px);color:rgba(255,255,255,.75);line-height:1.7;max-width:620px;margin:0 auto 40px;animation:fade-up .6s .4s both;font-weight:300;
  text-shadow:0 1px 4px rgba(0,0,0,.4)}
.hero-sub strong{color:#fff;font-weight:600}

/* CTA buttons */
.hero-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;animation:fade-up .6s .7s both;width:100%}
.hero-actions .btn-prime{background:#fff;color:var(--g-dark);font-weight:800;
  box-shadow:0 4px 24px rgba(0,0,0,.25),0 0 0 1px rgba(255,255,255,.1);font-size:16px;padding:18px 36px;border-radius:16px}
.hero-actions .btn-prime:hover{background:var(--g3);color:#fff;box-shadow:0 12px 40px rgba(0,184,74,.4),0 0 0 1px rgba(0,184,74,.3);transform:translateY(-2px)}
.hero-actions .btn-outline{border:1.5px solid rgba(255,255,255,.25);color:#fff;
  background:rgba(255,255,255,.04);backdrop-filter:blur(8px);font-size:16px;padding:18px 36px;border-radius:16px}
.hero-actions .btn-outline:hover{border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.1);transform:translateY(-2px)}

/* Micro trust line */
.hero-micro{font-size:12px;color:rgba(255,255,255,.7);text-align:center;margin-top:16px;animation:fade-up .6s .85s both;
  text-shadow:0 1px 3px rgba(0,0,0,.4);letter-spacing:.01em}

/* Energy ticker — glassmorphism */
.energy-ticker{display:inline-flex;align-items:center;gap:18px;
  background:rgba(0,0,0,.4);backdrop-filter:blur(20px) saturate(1.4);
  border:1px solid rgba(255,255,255,.08);border-radius:18px;
  padding:16px 28px;margin-bottom:40px;animation:fade-up .6s .55s both;flex-wrap:wrap}
.et-label{font-size:11px;color:rgba(255,255,255,.72);font-weight:600;text-transform:uppercase;letter-spacing:.1em}
.et-val{font-family:var(--mono);font-size:20px;font-weight:600;color:var(--g3);letter-spacing:-.02em;
  text-shadow:0 0 12px rgba(0,184,74,.2)}
.et-unit{font-size:11px;color:rgba(255,255,255,.72)}
.et-sep{width:1px;height:28px;background:rgba(255,255,255,.08)}

/* Scroll indicator */
.scroll-ind{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.62);font-size:10px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;animation:fade-up 1s 1.5s both}
.scroll-track{width:2px;height:40px;background:rgba(255,255,255,.1);border-radius:2px;position:relative;overflow:hidden}
.scroll-dot{position:absolute;width:2px;height:12px;background:var(--g3);border-radius:2px;animation:scroll-anim 2s ease-in-out infinite}

/* ══ STATS ROW ══ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border-radius:20px;overflow:hidden;margin-bottom:80px}
.stat-block{background:var(--card);padding:32px 24px;text-align:center}
.stat-num{font-family:var(--mono);font-size:44px;font-weight:600;color:var(--g);letter-spacing:-.04em;line-height:1;display:block}
.stat-label{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.1em;margin-top:6px}

/* ══ COLORED SOLUTION CARDS (Homepage) ══ */
.sol-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sol-grid-hub{grid-template-columns:repeat(3,1fr);gap:24px}
.sol-grid-2{grid-template-columns:repeat(2,1fr)}
.sol-card{display:flex;flex-direction:column;border-radius:24px;padding:32px 28px;position:relative;overflow:hidden;transition:all .35s var(--ease);cursor:pointer;text-decoration:none;color:#fff;min-height:320px;box-shadow:0 8px 32px rgba(0,0,0,.12)}
.sol-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:var(--shadow-xl)}
.sol-card::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.06) 0%,rgba(0,0,0,.1) 100%);pointer-events:none}
.sol-card::after{content:"";position:absolute;top:-50%;right:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.07),transparent 60%);pointer-events:none;opacity:0;transition:opacity .4s}
.sol-card:hover::after{opacity:1}
.sol-ico{font-size:40px;margin-bottom:16px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.15));line-height:1}
.sol-badge{display:inline-block;font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:5px 12px;border-radius:999px;background:rgba(255,255,255,.18);backdrop-filter:blur(4px);color:#fff;margin-bottom:14px;width:fit-content;border:1px solid rgba(255,255,255,.2)}
.sol-title{font-size:20px;font-weight:800;letter-spacing:-.03em;margin-bottom:10px;color:#fff;line-height:1.2}
.sol-desc{font-size:13px;color:rgba(255,255,255,.75);line-height:1.65;margin-bottom:auto;flex:1}
.sol-benefit{display:flex;align-items:baseline;gap:8px;margin-top:20px;padding-top:16px;border-top:1px solid rgba(255,255,255,.15)}
.sol-benefit-num{font-family:var(--mono);font-size:28px;font-weight:800;color:#fff;letter-spacing:-.03em;line-height:1}
.sol-benefit-text{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);line-height:1.3}
.sol-arrow{position:absolute;top:28px;right:28px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;transition:all .3s}
.sol-card:hover .sol-arrow{background:rgba(255,255,255,.3);transform:translateX(3px)}
.sol-solar{background:linear-gradient(135deg,#e8a317,#f59e0b,#d97706)}
.sol-battery{background:linear-gradient(135deg,#7c3aed,#8b5cf6,#6d28d9)}
.sol-heatpump{background:linear-gradient(135deg,#dc2626,#ef4444,#b91c1c)}
.sol-water{background:linear-gradient(135deg,#2563eb,#3b82f6,#1d4ed8)}
.sol-ev{background:linear-gradient(135deg,#0891b2,#06b6d4,#0e7490)}
.sol-insulation{background:linear-gradient(135deg,#16a34a,#22c55e,#15803d)}

/* ══ SERVICE LIST inside sol-cards ══ */
.sol-svc-list{list-style:none;padding:0;margin:0 0 auto}
.sol-svc-list li a{display:flex;align-items:center;gap:8px;padding:6px 10px;margin:0 -10px;border-radius:8px;font-size:13px;font-weight:500;color:rgba(255,255,255,.85);text-decoration:none;transition:all .15s}
.sol-svc-list li a:hover{background:rgba(255,255,255,.15);color:#fff}
.sol-svc-list li a::before{content:"";width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);flex-shrink:0}
.sol-svc-list li a:hover::before{background:#fff}
.sol-svc-tag{font-size:9px;font-weight:700;letter-spacing:.08em;padding:2px 6px;border-radius:4px;background:rgba(255,255,255,.2);color:#fff;margin-left:auto}
.sol-svc-sub{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.5);padding:10px 0 2px}
.sol-svc-sub:first-child{padding-top:0}
.sol-more{display:inline-block;margin-top:16px;font-size:13px;font-weight:700;color:#fff;text-decoration:none;padding:8px 16px;border-radius:10px;background:rgba(255,255,255,.15);transition:all .2s;border:1px solid rgba(255,255,255,.2)}
.sol-more:hover{background:rgba(255,255,255,.25)}

/* ══ FUTURISTIC SOLUTION CARDS v2 (Homepage) ══ */
@keyframes sol-particle-float{
  0%{transform:translateY(0) scale(1);opacity:.6}
  50%{transform:translateY(-40px) scale(1.2);opacity:1}
  100%{transform:translateY(-80px) scale(.8);opacity:0}
}
@keyframes sol-glow-pulse{
  0%,100%{opacity:.35;transform:scale(1)}
  50%{opacity:.55;transform:scale(1.1)}
}
@keyframes sol-stat-count{
  from{opacity:0;transform:translateY(12px)}
  to{opacity:1;transform:none}
}

.sol-section{background:var(--bg2);padding:100px 0;position:relative;overflow:hidden}

.sol-flex{display:flex;gap:24px;align-items:stretch}

.sol-v2{position:relative;flex:1;border-radius:20px;overflow:hidden;display:flex;flex-direction:column;text-decoration:none;color:#fff;transition:transform .5s var(--ease),box-shadow .5s var(--ease);box-shadow:0 8px 32px rgba(0,0,0,.12);cursor:pointer}
.sol-v2:hover{transform:translateY(-8px) scale(1.015);box-shadow:var(--shadow-xl)}

/* Image */
.sol-v2-img{position:relative;height:240px;overflow:hidden;flex-shrink:0}
.sol-v2-img img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),filter .7s var(--ease);filter:brightness(.85) saturate(1.1)}
.sol-v2:hover .sol-v2-img img{transform:scale(1.08);filter:brightness(.75) saturate(1.2)}

/* Glow overlay */
.sol-v2-glow{position:absolute;inset:0;pointer-events:none}
.sol-v2[data-sol="solar"] .sol-v2-glow{background:radial-gradient(ellipse at 30% 80%,rgba(245,158,11,.35),transparent 65%)}
.sol-v2[data-sol="heat"] .sol-v2-glow{background:radial-gradient(ellipse at 30% 80%,rgba(239,68,68,.35),transparent 65%)}
.sol-v2[data-sol="reno"] .sol-v2-glow{background:radial-gradient(ellipse at 30% 80%,rgba(34,197,94,.35),transparent 65%)}
.sol-v2:hover .sol-v2-glow{animation:sol-glow-pulse 2s ease-in-out infinite}

/* Body — colored gradient per card */
.sol-v2-body{flex:1;display:flex;flex-direction:column;padding:28px 24px 24px;position:relative}
.sol-v2[data-sol="solar"] .sol-v2-body{background:linear-gradient(135deg,#e8a317,#f59e0b,#d97706)}
.sol-v2[data-sol="heat"] .sol-v2-body{background:linear-gradient(135deg,#dc2626,#ef4444,#b91c1c)}
.sol-v2[data-sol="reno"] .sol-v2-body{background:linear-gradient(135deg,#16a34a,#22c55e,#15803d)}

/* Badge */
.sol-v2-badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border-radius:999px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.2);color:#fff;width:fit-content;margin-bottom:14px;backdrop-filter:blur(4px)}

/* Title */
.sol-v2-title{font-size:22px;font-weight:800;letter-spacing:-.03em;margin-bottom:14px;color:#fff;line-height:1.2}

/* List */
.sol-v2-list{list-style:none;padding:0;margin:0 0 20px;display:flex;flex-direction:column;gap:7px}
.sol-v2-list li{display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:400;color:rgba(255,255,255,.7);line-height:1.5}
.sol-v2-list li::before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0;background:rgba(255,255,255,.5)}

/* Tag (RO / RR labels) */
.sol-v2-tag{font-size:9px;font-weight:700;letter-spacing:.08em;padding:2px 7px;border-radius:4px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.5);margin-left:4px}

/* Stat */
.sol-v2-stat{display:flex;align-items:baseline;gap:10px;margin-top:auto;padding-top:18px;border-top:1px solid rgba(255,255,255,.15)}
.sol-v2-stat-num{font-family:var(--mono);font-size:36px;font-weight:700;letter-spacing:-.04em;line-height:1;color:#fff}
.sol-v2-stat-label{font-size:12px;font-weight:600;color:rgba(255,255,255,.7);line-height:1.4}

/* CTA */
.sol-v2-cta{display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:14px;font-weight:700;padding:10px 20px;border-radius:12px;transition:all .3s var(--ease);width:fit-content;color:#fff;background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.2)}
.sol-v2:hover .sol-v2-cta{transform:translateX(4px);background:rgba(255,255,255,.25);border-color:rgba(255,255,255,.35)}
.sol-v2-cta svg{transition:transform .3s var(--ease)}
.sol-v2:hover .sol-v2-cta svg{transform:translateX(3px)}

/* Particles */
.sol-v2-particles{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.sol-v2-particles span{position:absolute;width:4px;height:4px;border-radius:50%;opacity:0}
.sol-v2:hover .sol-v2-particles span{animation:sol-particle-float 2.5s ease-in-out infinite}
.sol-v2-particles span{background:rgba(255,255,255,.6)}
.sol-v2-particles span:nth-child(1){left:10%;bottom:20%;animation-delay:0s}
.sol-v2-particles span:nth-child(2){left:30%;bottom:10%;animation-delay:.4s;width:3px;height:3px}
.sol-v2-particles span:nth-child(3){left:55%;bottom:25%;animation-delay:.8s;width:5px;height:5px}
.sol-v2-particles span:nth-child(4){left:75%;bottom:15%;animation-delay:1.2s}
.sol-v2-particles span:nth-child(5){left:90%;bottom:30%;animation-delay:1.6s;width:3px;height:3px}

/* Reveal animation for sol-v2 cards */
.sol-v2{opacity:0;transform:translateY(40px)}
.sol-v2.in{opacity:1;transform:translateY(0);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.sol-v2.in:nth-child(2){transition-delay:.12s}
.sol-v2.in:nth-child(3){transition-delay:.24s}


/* ══ HOW IT WORKS ══ */
.how-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;position:relative}
.how-connector{position:absolute;top:36px;left:calc(12.5% + 8px);right:calc(12.5% + 8px);height:2px;background:linear-gradient(90deg,var(--border),rgba(0,184,74,.12) 50%,var(--border))}
.how-step{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:28px 22px;position:relative;z-index:1;transition:all .3s;box-shadow:var(--shadow)}
.how-step:hover{border-color:var(--gb);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.how-n{width:52px;height:52px;border-radius:16px;background:linear-gradient(135deg,var(--g),var(--g2));color:#fff;font-weight:900;font-size:20px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.how-step h3{font-size:15px;font-weight:800;letter-spacing:-.02em;margin-bottom:8px;color:var(--text)}
.how-step p{font-size:13px;color:var(--muted);line-height:1.65}
.how-step .how-tag{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--g);margin-bottom:10px}

/* ══ SERVICE NAV (sticky pill tabs) ══ */
.svc-nav{position:sticky;top:64px;z-index:850;background:rgba(255,255,255,.92);backdrop-filter:blur(16px) saturate(1.3);-webkit-backdrop-filter:blur(16px) saturate(1.3);border-bottom:1px solid var(--border);padding:10px 0;transition:box-shadow .3s var(--ease)}
.svc-nav.shadowed{box-shadow:0 4px 20px rgba(0,50,25,.06)}
.svc-nav-track{display:flex;gap:6px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch;padding:2px 0}
.svc-nav-track::-webkit-scrollbar{display:none}
.svc-nav-pill{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:999px;font-size:13px;font-weight:600;color:var(--muted);background:transparent;border:1px solid transparent;white-space:nowrap;text-decoration:none;transition:all .2s var(--ease);flex-shrink:0}
.svc-nav-pill:hover{color:var(--text);background:var(--bg2);border-color:var(--border)}
.svc-nav[data-category="solar"] .svc-nav-pill.active{background:rgba(245,158,11,.1);color:#d97706;border-color:rgba(245,158,11,.25)}
.svc-nav[data-category="heat"] .svc-nav-pill.active{background:rgba(239,68,68,.1);color:#dc2626;border-color:rgba(239,68,68,.25)}
.svc-nav[data-category="reno"] .svc-nav-pill.active{background:rgba(34,197,94,.1);color:#16a34a;border-color:rgba(34,197,94,.25)}
.svc-nav-ico{font-size:14px;line-height:1}

/* ══ SERVICE FEATURE (side-by-side text + image) ══ */
.svc-feature{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.svc-feature.reverse .svc-feature-img{order:2}
.svc-feature.reverse .svc-feature-text{order:1}
.svc-feature-img{border-radius:var(--rl);overflow:hidden;box-shadow:var(--shadow-lg)}
.svc-feature-img img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .6s var(--ease)}
.svc-feature:hover .svc-feature-img img{transform:scale(1.03)}
.svc-feature-text .section-tag{margin-bottom:14px}
.svc-feature-text h2{font-size:clamp(24px,3vw,36px);font-weight:800;letter-spacing:-.04em;margin-bottom:16px;color:var(--text)}
.svc-feature-text p{font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:12px}
.svc-feature-text p:last-child{margin-bottom:0}
.svc-feature-check{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:8px}
.svc-feature-check li{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--text2)}
.svc-feature-check li::before{content:"✓";display:flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--gd);color:var(--g);font-size:12px;font-weight:800;flex-shrink:0}

/* ══ SLIDE REVEAL VARIANTS ══ */
.rv-left{opacity:0;transform:translateX(-40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-left.in{opacity:1;transform:none}
.rv-right{opacity:0;transform:translateX(40px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv-right.in{opacity:1;transform:none}
.rv-scale{opacity:0;transform:scale(.92);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.rv-scale.in{opacity:1;transform:none}

/* ══ TESTIMONIALS ══ */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.testi-card{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:26px;transition:all .3s;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.testi-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--g),var(--g3));opacity:0;transition:opacity .3s}
.testi-card:hover{border-color:var(--gb);transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.testi-card:hover::before{opacity:1}
.testi-stars{display:flex;gap:3px;margin-bottom:14px}
.star{color:#f59e0b;font-size:15px}
.testi-quote{font-size:15px;line-height:1.75;color:var(--muted);margin-bottom:20px;font-style:italic}
.testi-author{display:flex;align-items:center;gap:12px}
.t-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--g2));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:14px;color:#fff;flex-shrink:0}
.t-name{font-weight:700;font-size:14px;color:var(--text)}
.t-loc{font-size:12px;color:var(--muted);margin-top:1px}
.t-save{display:inline-flex;align-items:center;gap:5px;background:var(--gd);border:1px solid var(--gb);border-radius:999px;padding:4px 10px;font-size:11px;font-weight:700;color:var(--g);margin-top:10px}

/* ══ CTA BAND ══ */
.cta-band{background:linear-gradient(135deg,#eafef0,#d5f5e3);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:80px 0;position:relative;overflow:hidden}
.cta-band::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 50% 50%,rgba(0,184,74,.05),transparent)}
.cta-band-inner{display:flex;align-items:center;justify-content:space-between;gap:40px;flex-wrap:wrap;position:relative;z-index:1}
.cta-band h2{font-size:clamp(24px,3.5vw,42px);font-weight:800;letter-spacing:-.04em;line-height:1.1;margin-bottom:10px;color:var(--text)}
.cta-band p{font-size:16px;color:var(--muted);max-width:500px}
.cta-band-right{display:flex;flex-direction:column;gap:12px;flex-shrink:0}

/* ══ FAQ ══ */
.faq-grid{display:grid;grid-template-columns:380px 1fr;gap:64px;align-items:start}
.faq-sticky{position:sticky;top:110px}
.faq-sticky h2{font-size:clamp(26px,3.5vw,44px);font-weight:800;letter-spacing:-.05em;line-height:1.08;margin-bottom:14px}
.faq-sticky p{font-size:15px;color:var(--muted);line-height:1.75;margin-bottom:28px;font-weight:300}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-item{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;transition:border-color .25s;box-shadow:var(--shadow)}
.faq-item.open{border-color:var(--gb)}
.faq-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;background:transparent;border:none;cursor:pointer;font-family:var(--font);font-size:14px;font-weight:700;color:var(--text);text-align:left}
.faq-icon{width:28px;height:28px;border-radius:9px;background:var(--gd);flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:17px;transition:all .28s;line-height:1;font-weight:300}
.faq-item.open .faq-icon{background:var(--gd);color:var(--g);transform:rotate(45deg)}
.faq-body{max-height:0;overflow:hidden;transition:max-height .32s ease}
.faq-body.open{max-height:280px}
.faq-inner{padding:0 22px 20px;font-size:14px;color:var(--muted);line-height:1.8;font-weight:300}
.faq-inner strong{color:var(--text);font-weight:600}

/* ══ SIMULATOR (Shared) ══ */
.sim-section{padding:100px 0;background:var(--bg2)}
.sim-outer{display:grid;grid-template-columns:1fr 480px;gap:32px;align-items:start}
.sim-inputs{display:flex;flex-direction:column;gap:20px}
.sim-block{background:var(--card);border:1px solid var(--border);border-radius:22px;padding:28px;transition:border-color .25s;box-shadow:var(--shadow)}
.sim-block:focus-within{border-color:var(--gb)}
.sb-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.sb-title{font-size:14px;font-weight:700;color:var(--text)}
.sb-val{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--g);background:var(--gd);border:1px solid var(--gb);padding:4px 12px;border-radius:8px}
.range-wrap{position:relative;padding-bottom:20px}
.range{width:100%;-webkit-appearance:none;height:6px;border-radius:999px;background:var(--bg3);outline:none;cursor:pointer}
.range::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:var(--g);cursor:pointer;border:3px solid #fff;box-shadow:0 0 0 3px rgba(0,184,74,.25)}
.range::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 6px rgba(0,184,74,.15)}
.range:focus-visible{outline:2px solid var(--g-dark);outline-offset:3px}
.range-fill{position:absolute;left:0;top:0;height:6px;border-radius:999px;background:linear-gradient(90deg,var(--g),var(--g3));pointer-events:none}
.range-labels{display:flex;justify-content:space-between;font-size:11px;color:var(--muted);font-weight:600;margin-top:10px}
.choices{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.choices-2{grid-template-columns:1fr 1fr}
.choice{background:var(--bg3);border:1.5px solid var(--border);border-radius:12px;padding:12px 10px;cursor:pointer;transition:all .2s;text-align:center;color:var(--muted);font-size:13px;font-weight:600}
.choice .ch-icon{font-size:20px;margin-bottom:5px;display:block}
.choice:hover{border-color:var(--gb);color:var(--text)}
.choice.sel{border-color:var(--g);color:var(--g);background:var(--gd)}
.extras{display:flex;flex-wrap:wrap;gap:8px}
.extra{display:flex;align-items:center;gap:7px;background:var(--bg3);border:1.5px solid var(--border);border-radius:999px;padding:8px 14px;cursor:pointer;transition:all .2s;font-size:12px;font-weight:700;color:var(--muted)}
.extra-check{width:16px;height:16px;border-radius:50%;border:2px solid currentColor;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}
.extra.sel{border-color:var(--g);color:var(--g);background:var(--gd)}
.extra.sel .extra-check{background:var(--g);border-color:var(--g)}
.extra.sel .extra-check::after{content:"✓";font-size:9px;color:#fff;font-weight:900}

/* Results panel */
.sim-results{position:sticky;top:100px;background:var(--card);border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg)}
.sr-top{background:linear-gradient(135deg,#eafef0,#d5f5e3);padding:28px;border-bottom:1px solid var(--border);position:relative;overflow:hidden}
.sr-top::before{content:"";position:absolute;top:-40px;right:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(0,184,74,.08),transparent 70%)}
.sr-live{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--g);margin-bottom:12px}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--g);animation:dot-blink 1.2s ease-in-out infinite}
.sr-main-label{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:4px}
.sr-main-val{font-size:52px;font-weight:800;color:var(--g);letter-spacing:-.05em;line-height:1;margin-bottom:2px;font-variant-numeric:tabular-nums}
.sr-main-period{font-size:16px;font-weight:400;color:var(--muted)}
.sr-sub{font-size:13px;color:var(--muted);margin-top:4px}
.sr-body{padding:24px}
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.kpi{background:var(--bg3);border:1px solid var(--border);border-radius:14px;padding:14px 16px;position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--kc,var(--g))}
.kpi-v{font-family:var(--mono);font-size:22px;font-weight:600;line-height:1;margin-bottom:3px}
.kpi-l{font-size:10px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.kpi-trend{position:absolute;top:10px;right:12px;font-size:11px;font-weight:700;color:var(--g)}
.roi-bar{margin-bottom:20px}
.roi-bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.roi-bar-label{font-size:12px;font-weight:700;color:var(--muted)}
.roi-bar-val{font-family:var(--mono);font-size:12px;color:var(--g);font-weight:600}
.roi-track{height:8px;background:var(--bg3);border-radius:999px;overflow:hidden;margin-bottom:6px}
.roi-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--g),var(--g3));transition:width .8s var(--ease)}
.roi-ticks{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);font-family:var(--mono);opacity:.5}
.chart-wrap{margin-bottom:20px;background:var(--bg3);border-radius:14px;padding:16px}
.chart-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px;display:flex;justify-content:space-between}
.sr-cta{padding:0 24px 24px}
.sr-cta-note{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);margin-top:10px;justify-content:center}

/* ══ FORM ══ */
.form-sec{padding:100px 0;background:var(--bg2)}
.form-outer{display:grid;grid-template-columns:1fr 520px;gap:64px;align-items:center}
.form-copy .section-title{text-align:left}
.form-copy .section-lead{text-align:left;margin:0 0 28px}
.social-count{display:flex;align-items:center;gap:14px;margin-bottom:32px;flex-wrap:wrap}
.avatars{display:flex}
.avatar{width:36px;height:36px;border-radius:50%;border:2px solid var(--bg2);background:linear-gradient(135deg,var(--g),var(--g2));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;margin-left:-8px;flex-shrink:0}
.avatar:first-child{margin-left:0}
.social-text{font-size:14px;color:var(--muted);line-height:1.5}
.social-text strong{color:var(--text);font-weight:700}
.form-benefits{display:flex;flex-direction:column;gap:12px}
.fb{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--muted)}
.fb-icon{width:28px;height:28px;border-radius:9px;background:var(--gd);border:1px solid var(--gb);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fb strong{color:var(--text);font-weight:600;display:block}
.form-card{background:var(--card);border:1px solid var(--border);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-xl)}
.form-progress-bar{height:3px;background:var(--bg3)}
.form-progress-fill{height:100%;background:linear-gradient(90deg,var(--g),var(--g3));transition:width .5s var(--ease)}
.form-inner{padding:32px}
.form-step-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.fsl-title{font-size:17px;font-weight:800;color:var(--text)}
.fsl-count{font-size:12px;font-weight:600;color:var(--muted);background:var(--bg3);padding:4px 10px;border-radius:20px}
.fi-group{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.fi-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.fi{width:100%;padding:14px 16px;background:var(--bg3);border:1.5px solid var(--border);border-radius:12px;color:var(--text);font-size:15px;transition:all .2s;outline:none}
.fi:focus{border-color:var(--g);background:var(--gd);box-shadow:0 0 0 3px rgba(0,184,74,.08)}
.fi::placeholder{color:var(--muted)}
.fi-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.step-panel{display:none}
.step-panel.active{display:block;animation:slide-in .3s ease}
.step-choices{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}
.sc-btn{background:var(--bg3);border:1.5px solid var(--border);border-radius:14px;padding:16px 14px;cursor:pointer;transition:all .2s;text-align:left;position:relative;overflow:hidden}
.sc-btn:hover{border-color:var(--gb);background:var(--gd)}
.sc-btn.sel{border-color:var(--g);background:var(--gd)}
.sc-btn.sel::after{content:"✓";position:absolute;top:10px;right:12px;width:20px;height:20px;border-radius:50%;background:var(--g);color:#fff;font-size:11px;font-weight:900;display:flex;align-items:center;justify-content:center;animation:check-in .25s var(--spring) both}
.sc-icon{font-size:24px;margin-bottom:8px;display:block}
.sc-title{font-size:14px;font-weight:700;color:var(--text)}
.sc-sub{font-size:12px;color:var(--muted);margin-top:2px}
.form-nav{display:flex;gap:10px;margin-top:20px}
.btn-back{background:var(--bg3);color:var(--muted);padding:13px 18px;border-radius:12px;font-family:var(--font);font-weight:700;font-size:14px;cursor:pointer;transition:all .2s;display:none}
.btn-back:hover{background:var(--gd);color:var(--text)}
.btn-back.show{display:flex}
.btn-fwd{flex:1;padding:15px;font-size:15px;border-radius:12px}
.form-success{padding:40px 32px;text-align:center;display:none}
.form-success.show{display:block;animation:fade-up .4s ease}
.success-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--g),var(--g3));display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:32px;animation:glow-breathe 2s ease-in-out infinite}
.success-h{font-size:22px;font-weight:800;margin-bottom:8px}
.success-p{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:24px}
.success-steps{display:flex;flex-direction:column;gap:10px;text-align:left}
.ss-item{display:flex;align-items:center;gap:12px;background:var(--bg3);border:1px solid var(--border);border-radius:12px;padding:14px}
.ss-n{width:28px;height:28px;border-radius:50%;background:var(--g);color:#fff;font-weight:900;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ss-t{font-size:13px;font-weight:600;color:var(--text2)}

/* ══ PAGE HERO (inner pages) ══ */
.page-hero{padding:140px 0 60px;background:var(--bg2);text-align:center;position:relative}
.page-hero::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 60% 60% at 50% 0%,rgba(0,184,74,.04),transparent)}
.page-hero h1{font-size:clamp(32px,4.5vw,56px);font-weight:800;letter-spacing:-.05em;line-height:1.05;margin-bottom:14px}
.page-hero p{font-size:17px;color:var(--muted);max-width:600px;margin:0 auto;font-weight:300;line-height:1.7}

/* ══ STICKY CTA MOBILE ══ */
.sticky-mob{display:none;position:fixed;bottom:0;left:0;right:0;z-index:800;background:#fff;border-top:1px solid var(--border);padding:12px 16px calc(12px + env(safe-area-inset-bottom,0));gap:8px;box-shadow:0 -4px 20px rgba(0,50,25,.08)}
.sticky-mob .btn{min-height:48px;border-radius:12px}
@media(max-width:768px){.sticky-mob{display:flex}
body{padding-bottom:calc(72px + env(safe-area-inset-bottom,0))}}

/* ══ FOOTER ══ */
/* ══ WHATSAPP FAB — Floating contact button (auto-injected) ══ */
.wa-fab{position:fixed;right:22px;bottom:22px;z-index:850;
  width:58px;height:58px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:#25D366;color:#fff;text-decoration:none;
  box-shadow:0 8px 22px rgba(37,211,102,.4),0 4px 10px rgba(0,0,0,.12),0 0 0 4px rgba(37,211,102,.12);
  transition:transform .25s var(--spring),box-shadow .3s var(--ease),opacity .35s var(--ease);
  opacity:0;transform:translateY(16px) scale(.9);pointer-events:none}
.wa-fab.wa-show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.wa-fab:hover,.wa-fab:focus-visible{transform:translateY(0) scale(1.06);
  box-shadow:0 12px 28px rgba(37,211,102,.55),0 4px 10px rgba(0,0,0,.18),0 0 0 6px rgba(37,211,102,.18);
  outline:none}
.wa-fab:focus-visible{box-shadow:0 12px 28px rgba(37,211,102,.55),0 4px 10px rgba(0,0,0,.18),0 0 0 4px #fff,0 0 0 6px #25D366}
.wa-fab svg{width:30px;height:30px;display:block;fill:currentColor}
.wa-fab::after{content:"";position:absolute;inset:0;border-radius:50%;
  border:2px solid #25D366;opacity:.4;animation:wa-pulse 2.4s ease-out infinite;pointer-events:none}
@keyframes wa-pulse{0%{transform:scale(1);opacity:.4}70%{transform:scale(1.55);opacity:0}100%{transform:scale(1.55);opacity:0}}

/* Optional tooltip on desktop hover */
.wa-fab-tip{position:absolute;right:calc(100% + 12px);top:50%;transform:translateY(-50%);
  background:#0a1f0e;color:#fff;padding:8px 14px;border-radius:10px;
  font-size:13px;font-weight:600;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .2s var(--ease);
  box-shadow:0 6px 18px rgba(0,0,0,.18)}
.wa-fab-tip::after{content:"";position:absolute;top:50%;left:100%;transform:translateY(-50%);
  border:6px solid transparent;border-left-color:#0a1f0e}
.wa-fab:hover .wa-fab-tip,.wa-fab:focus-visible .wa-fab-tip{opacity:1}
@media(hover:none){.wa-fab-tip{display:none}}

/* Position above the mobile sticky CTA bar on mobile */
@media(max-width:768px){
  .wa-fab{width:54px;height:54px;right:16px;bottom:calc(80px + env(safe-area-inset-bottom,0))}
  .wa-fab svg{width:28px;height:28px}
}
@media(prefers-reduced-motion:reduce){
  .wa-fab,.wa-fab::after{animation:none;transition:opacity .2s ease}
}

/* ══ IMPORTANT NOTICE — Identity-usurpation alert popup (auto-injected) ══ */
.notice-overlay{position:fixed;inset:0;z-index:10001;background:rgba(7,18,12,.55);
  -webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);
  display:flex;align-items:center;justify-content:center;padding:20px;
  opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
.notice-overlay.notice-open{opacity:1;pointer-events:auto}
.notice-card{position:relative;background:#fff;border-radius:18px;max-width:580px;width:100%;
  max-height:calc(100vh - 40px);overflow-y:auto;-webkit-overflow-scrolling:touch;
  box-shadow:0 25px 70px rgba(0,0,0,.30),0 0 0 1px rgba(0,0,0,.04);
  transform:translateY(16px) scale(.96);
  transition:transform .35s var(--spring),opacity .3s var(--ease)}
.notice-overlay.notice-open .notice-card{transform:translateY(0) scale(1)}
.notice-card::before{content:"";display:block;height:4px;
  background:linear-gradient(90deg,#f59e0b 0%,#fbbf24 50%,#f59e0b 100%);
  border-radius:18px 18px 0 0}
.notice-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;
  background:rgba(0,0,0,.05);color:#374151;display:flex;align-items:center;justify-content:center;
  font-size:20px;line-height:1;cursor:pointer;border:none;font-family:inherit;
  transition:background .15s ease,color .15s ease;z-index:2}
.notice-close:hover{background:rgba(0,0,0,.1);color:#000}
.notice-close:focus-visible{outline:2px solid var(--g);outline-offset:2px}
.notice-content{padding:34px 34px 24px}
.notice-title{font-size:19px;font-weight:700;line-height:1.35;margin:0 0 18px;color:#1a1a1a;
  letter-spacing:-.01em;padding-right:48px}
.notice-content p{font-size:14.5px;line-height:1.65;color:#374151;margin:0 0 12px;font-weight:400}
.notice-content p:last-of-type{margin-bottom:0}
.notice-mail{color:var(--g);font-weight:600;text-decoration:none;
  border-bottom:1px solid rgba(0,200,83,.3);transition:border-color .15s ease}
.notice-mail:hover{border-bottom-color:var(--g)}
.notice-actions{padding:8px 34px 30px;display:flex;justify-content:flex-end;gap:10px}
.notice-actions .btn{font-size:14px;padding:11px 24px}
body.notice-locked{overflow:hidden}
@media(max-width:560px){
  .notice-overlay{padding:0;align-items:flex-end}
  .notice-card{border-radius:18px 18px 0 0;max-height:92vh;width:100%;
    transform:translateY(40px);transition:transform .4s var(--spring),opacity .3s var(--ease)}
  .notice-overlay.notice-open .notice-card{transform:translateY(0)}
  .notice-content{padding:26px 22px 18px}
  .notice-title{font-size:17px;margin-bottom:14px;padding-right:38px}
  .notice-content p{font-size:14px;line-height:1.6}
  .notice-actions{padding:6px 22px 22px}
  .notice-close{top:12px;right:12px;width:34px;height:34px}
}
@media(prefers-reduced-motion:reduce){
  .notice-overlay,.notice-card{transition:none}
  .notice-card{transform:none}
}

/* ══ PARTNERS — Infinite logo carousel (auto-injected above footer) ══ */
.partners{background:#fafafa;border-top:1px solid rgba(0,0,0,.05);padding:40px 0;overflow:hidden;position:relative;box-shadow:0 -1px 0 rgba(0,0,0,.02)}
.partners-viewport{position:relative;width:100%;overflow:hidden;mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 8%,#000 92%,transparent 100%)}
.partners-track{display:flex;align-items:center;gap:64px;width:max-content;animation:partners-scroll 50s linear infinite;will-change:transform}
.partners-track:hover{animation-play-state:paused}
.partners-logo{flex-shrink:0;height:48px;width:auto;max-width:160px;object-fit:contain;filter:grayscale(0%);opacity:1;transition:filter .35s ease,opacity .35s ease,transform .35s ease;display:block}
.partners-logo:hover{filter:grayscale(100%);opacity:.55;transform:scale(1.04)}

/* Cartes-marques par catégorie (documentation fabricant) */
.brand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;max-width:920px;margin:24px auto 0}
.brand-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:24px 16px;background:#fff;border:1px solid var(--border,#e6e9e7);border-radius:16px;text-decoration:none;transition:box-shadow .25s ease,transform .25s ease,border-color .25s ease}
.brand-card:hover{box-shadow:var(--shadow-lg,0 18px 40px rgba(0,0,0,.12));transform:translateY(-3px);border-color:var(--g3,#00b84a)}
.brand-card img{height:32px;width:auto;max-width:150px;object-fit:contain}
.brand-card-name{font-weight:700;font-size:15px;color:var(--ink,#0b1f12)}
.brand-card-cat{font-size:12px;color:var(--muted,#5b6b60)}
.brand-card-doc{font-size:12px;font-weight:600;color:var(--g-dark,#007a2f)}
.brand-card--nolink{cursor:default}
.brand-card--nolink:hover{box-shadow:none;transform:none;border-color:var(--border,#e6e9e7)}
.brand-card-doc--muted{color:var(--muted,#5b6b60);font-weight:500}
@keyframes partners-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
/* Respect reduced motion */
@media(prefers-reduced-motion:reduce){.partners-track{animation:none;justify-content:center;flex-wrap:wrap;gap:32px}}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}.rv,.rv-left,.rv-right,.rv-scale{opacity:1!important;transform:none!important}}
/* Responsive */
@media(max-width:768px){.partners{padding:30px 0}.partners-track{gap:44px;animation-duration:42s}.partners-logo{height:36px;max-width:120px}}
@media(max-width:480px){.partners{padding:24px 0}.partners-track{gap:36px;animation-duration:38s}.partners-logo{height:30px;max-width:100px}}

.footer{background:#0a1f0e;padding:60px 0 28px;border-top:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.7)}
.footer-top{display:grid;grid-template-columns:240px 1fr 1fr 1fr 1fr;gap:32px;margin-bottom:48px}
.footer-brand p{font-size:13px;color:rgba(255,255,255,.55);margin-top:12px;line-height:1.65;font-weight:300}
.footer-col h4,.footer-col .footer-h{font-size:11px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:.14em;text-transform:uppercase;margin-bottom:16px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:8px}
.footer-col li a{font-size:13px;color:rgba(255,255,255,.55);transition:color .2s;font-weight:300}
.footer-col li a:hover{color:var(--g3)}
/* Footer social */
.footer-social{margin-top:20px}
.footer-social-label{display:block;font-size:11px;font-weight:700;color:rgba(255,255,255,.5);letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.footer-social-icons{display:flex;gap:10px}
.footer-social-link{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.62);transition:all .25s}
.footer-social-link:hover{color:#fff;background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.2);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.2)}
.footer-social-link svg{display:block}

.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:12px;color:rgba(255,255,255,.7)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.72);transition:color .2s}
.footer-legal a:hover{color:rgba(255,255,255,.7)}
.footer-cookie-btn{font-size:12px;color:rgba(255,255,255,.72);transition:color .2s;background:none;border:none;cursor:pointer;padding:0;font-family:var(--font)}
.footer-cookie-btn:hover{color:rgba(255,255,255,.7)}

/* ══ EMAILJS ══ */
.btn-sending{position:relative;pointer-events:none;opacity:.8}
.btn-sending::before{content:"";position:absolute;left:16px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.25);border-top-color:#fff;animation:spin 0.7s linear infinite}

/* ══ RESPONSIVE GRID UTILITIES ══ */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

/* ══ RESPONSIVE ══ */
@media(max-width:1100px){
  .sim-outer,.form-outer,.footer-top{grid-template-columns:1fr}
  .sim-results{position:relative;top:0}
  .faq-grid{grid-template-columns:1fr}
  .faq-sticky{position:relative;top:0}
}
@media(max-width:1024px){
  .hdr-actions .btn-prime.hdr-btn{display:none}
}
@media(max-width:900px){
  .grid-3,.grid-4,.sol-why-grid,.sol-compare-grid{grid-template-columns:1fr 1fr}
  .hero h1{font-size:40px}
  .hero-sub{font-size:16px}
  section{padding:72px 0}
  .section-header{margin-bottom:48px}
  .testi-grid{grid-template-columns:1fr 1fr}
  .sol-grid{grid-template-columns:1fr}
  .sol-grid-hub{grid-template-columns:repeat(2,1fr)}
  .sol-flex{flex-direction:column}
  .sol-v2-img{height:200px}
  .svc-nav{top:56px}
  .svc-nav-pill{padding:7px 12px;font-size:12px}
  .svc-feature{grid-template-columns:1fr;gap:32px}
  .svc-feature.reverse .svc-feature-img{order:0}
  .svc-feature.reverse .svc-feature-text{order:0}
  .how-grid{grid-template-columns:1fr 1fr}
  .how-connector{display:none}
  .stats-row{grid-template-columns:1fr 1fr}
  .scroll-ind{display:none}
  .energy-ticker{flex-wrap:wrap;justify-content:center;gap:10px}
  .et-sep{display:none}
  .hdr-nav{display:none}
  .hdr-phone{display:none}
  .hdr-burger{display:flex}
  .sol-card{padding:28px 22px}
  .page-hero{padding:100px 0 44px}
}
@media(max-width:640px){
  .grid-3,.grid-4,.sol-why-grid,.sol-compare-grid{grid-template-columns:1fr}
  .hdr{padding:10px 0}
  .sol-grid-hub{grid-template-columns:1fr}
  .svc-nav{top:52px;padding:8px 0}
  .svc-nav-pill{padding:6px 10px;font-size:11px;gap:4px}
  .svc-nav-ico{font-size:12px}
  .svc-feature-img{border-radius:var(--rm)}
  .svc-feature-text h2{font-size:22px}
  .hdr-logo img{height:34px;max-width:130px}
  .cnt{padding:0 20px}
  .cnt-sm{padding:0 20px}
  section{padding:48px 0}
  .section-header{margin-bottom:36px}
  .section-lead{font-size:15px;line-height:1.65}
  .hero{padding:70px 0 50px;min-height:90svh}
  .hero h1{font-size:30px;letter-spacing:-.04em;margin-bottom:16px}
  .hero-sub{font-size:14px;margin:8px auto 20px;line-height:1.65}
  .hero-badge{font-size:9px;padding:7px 14px;flex-wrap:wrap;justify-content:center}
  .hero-actions{flex-direction:column;align-items:center;gap:10px}
  .hero-actions .btn-prime,.hero-actions .btn-outline{width:100%;max-width:320px;font-size:15px;padding:16px 24px;border-radius:14px}
  .hero-micro{font-size:10px;margin-top:12px}
  .hero-actions .btn{width:100%;max-width:320px}
  .energy-ticker{flex-direction:column;align-items:center;gap:10px;padding:14px 16px;text-align:center}
  .et-sep{display:none}
  .choices{grid-template-columns:1fr 1fr}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .sr-main-val{font-size:40px}
  .step-choices{grid-template-columns:1fr}
  .fi-row{grid-template-columns:1fr}
  .testi-grid,.sol-grid,.how-grid,.stats-row{grid-template-columns:1fr}
  .sol-card{min-height:auto;padding:24px 20px;border-radius:18px}
  .sol-flex{flex-direction:column;gap:18px}
  .sol-v2{border-radius:16px}
  .sol-v2-img{height:180px}
  .sol-v2-body{padding:22px 20px 20px}
  .sol-v2-title{font-size:19px}
  .sol-v2-stat-num{font-size:30px}
  .sol-section{padding:60px 0}
  .sol-ico{font-size:32px;margin-bottom:12px}
  .sol-title{font-size:18px}
  .sol-svc-list li a{font-size:14px;padding:8px 10px}
  .sol-more{font-size:14px;padding:10px 20px;width:100%;text-align:center;border-radius:12px}
  .cta-band-inner{flex-direction:column;gap:20px}
  .cta-band-right{width:100%}
  .cta-band h2{font-size:20px}
  .section-title{font-size:26px}
  .how-step{padding:20px 16px}
  .how-n{width:44px;height:44px;font-size:18px;border-radius:12px;margin-bottom:14px}
  .how-step h3{font-size:14px}
  .how-step p{font-size:12px}
  .stat-block{padding:20px 14px}
  .stat-num{font-size:32px}
  .stat-label{font-size:10px}
  .testi-card{padding:20px}
  .faq-grid{gap:24px}
  .faq-btn{padding:16px;font-size:13px}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start}
  .page-hero{padding:90px 0 36px}
  .page-hero h1{font-size:26px}
  .page-hero p{font-size:14px}
  /* Touch-friendly targets */
  .btn-sm{padding:12px 20px;font-size:13px;min-height:44px}
  .footer-social-link{width:44px;height:44px}
  .mob-section-toggle{min-height:52px}
  .mob-link{min-height:48px;display:flex;align-items:center}
}
@media(max-width:380px){
  .cnt{padding:0 16px}
  .cnt-sm{padding:0 16px}
  .hero h1{font-size:26px}
  .hero-sub{font-size:13px}
  .section-title{font-size:24px}
  .hero-actions .btn-prime,.hero-actions .btn-outline{padding:14px 20px;font-size:14px}
  .footer-top{grid-template-columns:1fr}
  .sol-card{padding:20px 16px}
  .sol-v2-body{padding:18px 16px 16px}
  .sol-v2-badge{font-size:10px;padding:5px 10px}
  .sol-v2-title{font-size:17px}
  .sol-v2-list li{font-size:12.5px}
  .sol-v2-stat-num{font-size:26px}
  .sol-v2-cta{font-size:13px;padding:8px 16px}
}

/* ══ COOKIE CONSENT BANNER ══ */
.ck-banner{position:fixed;bottom:0;left:0;right:0;z-index:9999;padding:20px;display:flex;justify-content:center;pointer-events:none;opacity:0;transform:translateY(20px);transition:opacity .35s ease,transform .35s ease}
.ck-banner.ck-show{opacity:1;transform:translateY(0);pointer-events:auto}
.ck-banner.ck-hide{opacity:0;transform:translateY(20px);pointer-events:none}
.ck-card{background:#fff;border-radius:20px;box-shadow:0 12px 48px rgba(0,30,15,.12),0 0 0 1px rgba(0,0,0,.04);max-width:440px;width:100%;padding:28px;position:relative;overflow:hidden}
.ck-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--g),var(--g3))}
.ck-card-detail{max-width:500px}
.ck-body{margin-bottom:20px}
.ck-icon{font-size:32px;margin-bottom:10px}
.ck-title{font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.03em;margin-bottom:8px}
.ck-desc{font-size:13px;color:var(--muted);line-height:1.7;font-weight:300}
.ck-actions{display:flex;gap:8px;flex-wrap:wrap}
.ck-btn{padding:11px 20px;border-radius:12px;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all .2s;font-family:var(--font)}
.ck-btn-prime{background:var(--g);color:#fff;flex:1}
.ck-btn-prime:hover{background:var(--g2);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,184,74,.25)}
.ck-btn-ghost{background:var(--bg3);color:var(--text);border:1px solid var(--border);flex:1}
.ck-btn-ghost:hover{border-color:var(--g);color:var(--g)}
.ck-btn-link{background:none;color:var(--muted);text-decoration:underline;font-weight:500;padding:8px 12px}
.ck-btn-link:hover{color:var(--g)}
.ck-policy{display:block;text-align:center;margin-top:14px;font-size:12px;color:var(--muted);text-decoration:underline;font-weight:300}
.ck-policy:hover{color:var(--g)}

/* Cookie categories */
.ck-cat{padding:14px 0;border-bottom:1px solid var(--border)}
.ck-cat:last-of-type{border-bottom:none}
.ck-cat-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.ck-cat-info{flex:1}
.ck-cat-info strong{display:block;font-size:13px;font-weight:700;color:var(--text);margin-bottom:2px}
.ck-cat-info span{font-size:12px;color:var(--muted);line-height:1.5;font-weight:300}
.ck-always{font-size:11px;font-weight:700;color:var(--g);background:var(--gd);padding:4px 10px;border-radius:8px;white-space:nowrap}

/* Toggle switch */
.ck-switch{position:relative;width:44px;height:24px;flex-shrink:0}
.ck-switch input{opacity:0;width:0;height:0;position:absolute}
.ck-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg3);border:1px solid var(--border);border-radius:24px;transition:all .25s}
.ck-slider::before{content:"";position:absolute;height:18px;width:18px;left:2px;bottom:2px;background:#fff;border-radius:50%;transition:all .25s;box-shadow:0 1px 4px rgba(0,0,0,.12)}
.ck-switch input:checked+.ck-slider{background:var(--g);border-color:var(--g)}
.ck-switch input:checked+.ck-slider::before{transform:translateX(20px)}

/* Toast */
.ck-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--text);color:#fff;padding:12px 24px;border-radius:12px;font-size:13px;font-weight:600;font-family:var(--font);z-index:10000;opacity:0;transition:all .3s ease;pointer-events:none;box-shadow:0 8px 32px rgba(0,0,0,.2)}
.ck-toast-show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ══ BREADCRUMBS ══ */
.breadcrumb-section{padding:100px 0 0}
.breadcrumb-section-alt{padding:90px 0 0;background:var(--bg2)}
.breadcrumb{font-size:13px;color:var(--muted);padding:16px 0}
.breadcrumb a{color:var(--g);font-weight:600;text-decoration:none}
.breadcrumb a:hover{text-decoration:underline}
.breadcrumb .sep{margin:0 8px}
.breadcrumb .sep-light{margin:0 8px;opacity:.4}

/* ══ MOBILE NAV UTILITIES ══ */
.mob-bottom{margin-top:auto;padding:20px 0;display:flex;gap:8px}
.mob-link{padding:16px;font-size:18px;font-weight:600;display:block;text-decoration:none;color:var(--text)}

/* ══ STICKY CTA ══ */
.sticky-call{flex:1;font-size:13px}
.sticky-quote{flex:2;font-size:14px}

/* Cookie banner responsive */
@media(max-width:480px){
  .ck-banner{padding:12px}
  .ck-card{padding:22px;border-radius:16px}
  .ck-actions{flex-direction:column}
  .ck-btn{width:100%;text-align:center}
}
