/*
Theme Name: SOTEJ Group
Theme URI: https://sotej-group.local
Author: SOTEJ GROUP SARL
Author URI: https://sotej-group.local
Description: Thème WordPress moderne, clair et professionnel pour SOTEJ GROUP SARL — entreprise béninoise spécialisée en BTP, transit & douane, transport & logistique, énergie solaire, matériaux et commerce international. Compatible Elementor.
Version: 1.5.2
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: sotej
Tags: business, construction, elementor, responsive, custom-colors, custom-menu, custom-logo, featured-images, threaded-comments, translation-ready
*/

/* ---------- Reset & Base ---------- */
:root{
  --sotej-primary:#181e72;
  --sotej-secondary:#ffc000;
  --sotej-white:#ffffff;
  --sotej-light:#f5f6fa;
  --sotej-grey:#e6e8ef;
  --sotej-dark:#222433;
  --sotej-text:#3c4257;
  --sotej-radius:10px;
  --sotej-shadow:0 10px 30px rgba(24,30,114,.08);
  --sotej-trans:all .35s ease;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Inter','Segoe UI',Arial,sans-serif;
  color:var(--sotej-text);background:var(--sotej-white);
  line-height:1.65;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--sotej-primary);text-decoration:none;transition:var(--sotej-trans)}
a:hover{color:var(--sotej-secondary)}
h1,h2,h3,h4,h5,h6{font-family:'Poppins','Inter',sans-serif;color:var(--sotej-primary);margin:0 0 .6em;line-height:1.25;font-weight:700}
h1{font-size:clamp(2rem,4vw,3.2rem)}
h2{font-size:clamp(1.6rem,3vw,2.4rem)}
h3{font-size:1.25rem}
p{margin:0 0 1em}
.container{max-width:1200px;margin:0 auto;padding:0 20px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-block;padding:13px 28px;border-radius:var(--sotej-radius);
  font-weight:600;letter-spacing:.3px;border:2px solid transparent;
  transition:var(--sotej-trans);cursor:pointer;font-size:.95rem;
}
.btn-primary{background:var(--sotej-secondary);color:var(--sotej-primary)!important;border-color:var(--sotej-secondary)}
.btn-primary:hover{background:transparent;color:var(--sotej-secondary)!important;border-color:var(--sotej-secondary)}
.btn-outline{background:transparent;color:#fff!important;border-color:#fff}
.btn-outline:hover{background:#fff;color:var(--sotej-primary)!important}
.btn-dark{background:var(--sotej-primary);color:#fff!important;border-color:var(--sotej-primary)}
.btn-dark:hover{background:var(--sotej-secondary);color:var(--sotej-primary)!important;border-color:var(--sotej-secondary)}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;left:0;width:100%;z-index:999;
  background:#fff;box-shadow:0 2px 14px rgba(24,30,114,.07);
  transition:var(--sotej-trans);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:20px;flex-wrap:wrap}
.site-branding{display:flex;align-items:center;gap:12px}
.site-logo-link{display:inline-flex;align-items:center}
.site-logo-img{height:64px;width:auto;display:block;max-width:220px;object-fit:contain}
.custom-logo{height:64px!important;width:auto!important;max-width:220px}
.site-logo-text{font-family:'Poppins',sans-serif;font-weight:800;font-size:1.3rem;color:var(--sotej-primary);line-height:1}
.site-logo-text span{color:var(--sotej-secondary)}
.site-tagline{font-size:.72rem;color:#888;letter-spacing:.5px;text-transform:uppercase}
.main-navigation ul{list-style:none;margin:0;padding:0;display:flex;gap:6px}
.main-navigation a{
  display:block;padding:10px 16px;color:var(--sotej-primary);font-weight:600;
  border-radius:6px;font-size:.95rem;
}
.main-navigation a:hover,.main-navigation .current-menu-item>a,.main-navigation .current_page_item>a{
  background:var(--sotej-light);color:var(--sotej-secondary);
}
.menu-toggle{
  display:none;background:none;border:0;cursor:pointer;width:44px;height:44px;
  flex-direction:column;justify-content:center;gap:5px;
}
.menu-toggle span{display:block;width:24px;height:2px;background:var(--sotej-primary);transition:var(--sotej-trans)}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.active span:nth-child(2){opacity:0}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:900px){
  .menu-toggle{display:flex}
  .main-navigation{position:absolute;top:100%;left:0;right:0;background:#fff;border-top:1px solid var(--sotej-grey);max-height:0;overflow:hidden;transition:var(--sotej-trans)}
  .main-navigation.open{max-height:80vh;overflow:auto}
  .main-navigation ul{flex-direction:column;padding:10px 20px 20px}
  .main-navigation a{padding:14px 10px;border-bottom:1px solid var(--sotej-light)}
}

/* ---------- Hero Carousel ---------- */
.hero-carousel{position:relative;overflow:hidden;background:var(--sotej-primary)}
.hero-slide{
  position:relative;min-height:78vh;display:flex;align-items:center;
  background-size:cover;background-position:center;
}
.hero-slide::before{content:'';position:absolute;inset:0;background:linear-gradient(120deg,rgba(24,30,114,.85),rgba(24,30,114,.55))}
.hero-content{position:relative;z-index:2;max-width:780px;color:#fff;padding:80px 0}
.hero-content h1{color:#fff;font-size:clamp(2rem,4.2vw,3.4rem);margin-bottom:18px}
.hero-content p{font-size:1.15rem;margin-bottom:30px;opacity:.95}
.hero-buttons{display:flex;gap:14px;flex-wrap:wrap}
.hero-slides{display:flex;transition:transform .9s cubic-bezier(.65,.05,.36,1)}
.hero-slide{flex:0 0 100%}
.hero-nav{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:5}
.hero-dot{width:38px;height:4px;background:rgba(255,255,255,.4);border:0;cursor:pointer;border-radius:2px;transition:var(--sotej-trans)}
.hero-dot.active{background:var(--sotej-secondary);width:54px}
.hero-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;font-size:22px;
  display:flex;align-items:center;justify-content:center;transition:var(--sotej-trans);
}
.hero-arrow:hover{background:var(--sotej-secondary);color:var(--sotej-primary);border-color:var(--sotej-secondary)}
.hero-prev{left:20px}.hero-next{right:20px}

/* ---------- Sections ---------- */
section.block{padding:90px 0}
.section-head{text-align:center;max-width:720px;margin:0 auto 50px}
.section-head .eyebrow{
  display:inline-block;color:var(--sotej-secondary);font-weight:700;
  letter-spacing:2px;font-size:.8rem;text-transform:uppercase;margin-bottom:10px;
}
.section-head h2{margin-bottom:14px}
.section-head p{color:#666}
.bg-light{background:var(--sotej-light)}
.bg-dark{background:var(--sotej-primary);color:#fff}
.bg-dark h1,.bg-dark h2,.bg-dark h3{color:#fff}

/* Intro */
.intro-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:50px;align-items:center}
.intro-grid img{border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow)}
@media (max-width:800px){.intro-grid{grid-template-columns:1fr}}

/* Cards grid */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid-3,.grid-4,.grid-2{grid-template-columns:1fr}}

.service-card{
  background:#fff;border-radius:var(--sotej-radius);overflow:hidden;
  box-shadow:var(--sotej-shadow);transition:var(--sotej-trans);
  display:flex;flex-direction:column;
}
.service-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(24,30,114,.15)}
.service-card .card-img{height:200px;background-size:cover;background-position:center}
.service-card .card-body{padding:24px;flex:1;display:flex;flex-direction:column}
.service-card .card-icon{
  width:54px;height:54px;border-radius:12px;background:var(--sotej-light);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
  color:var(--sotej-primary);font-size:24px;
}
.service-card h3{margin-bottom:10px}
.service-card .card-link{margin-top:auto;color:var(--sotej-secondary);font-weight:600;display:inline-flex;align-items:center;gap:6px}

.feature-card{
  background:#fff;border-radius:var(--sotej-radius);padding:34px 26px;text-align:center;
  box-shadow:var(--sotej-shadow);transition:var(--sotej-trans);border-top:4px solid var(--sotej-secondary);
}
.feature-card:hover{transform:translateY(-5px)}
.feature-card .icon{
  width:70px;height:70px;border-radius:50%;background:var(--sotej-primary);color:#fff;
  font-size:28px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;
}

.value-card{background:#fff;padding:30px;border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow);border-left:4px solid var(--sotej-secondary)}
.value-card h3{display:flex;align-items:center;gap:10px}
.value-card h3::before{content:'';width:10px;height:10px;background:var(--sotej-secondary);border-radius:50%}

.mv-card{background:#fff;padding:40px;border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow)}
.mv-card h3{color:var(--sotej-secondary);font-size:1.4rem}

/* Gallery */
.gallery-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-bottom:35px}
.gallery-filter{
  background:#fff;border:2px solid var(--sotej-grey);padding:9px 20px;border-radius:50px;
  cursor:pointer;font-weight:600;color:var(--sotej-primary);transition:var(--sotej-trans);font-size:.9rem;
}
.gallery-filter:hover,.gallery-filter.active{background:var(--sotej-primary);color:#fff;border-color:var(--sotej-primary)}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
@media (max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.gallery-grid{grid-template-columns:1fr}}
.gallery-item{
  position:relative;overflow:hidden;border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow);
  background:#000;aspect-ratio:4/3;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.08);opacity:.7}
.gallery-overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:22px;color:#fff;background:linear-gradient(to top,rgba(24,30,114,.95) 0%,transparent 70%);
  opacity:0;transition:var(--sotej-trans);
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-overlay h3{color:#fff;margin-bottom:4px;font-size:1.1rem}
.gallery-overlay .cat{color:var(--sotej-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:1px;font-weight:600;margin-bottom:6px}
.gallery-overlay p{font-size:.85rem;margin:0;opacity:.9}
.gallery-item.hide{display:none}

/* CTA */
.cta-section{background:linear-gradient(120deg,var(--sotej-primary),#2a3091);color:#fff;text-align:center;padding:80px 20px}
.cta-section h2{color:#fff}
.cta-section .buttons{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:25px}

/* Page banner */
.page-banner{
  background:linear-gradient(120deg,rgba(24,30,114,.92),rgba(24,30,114,.7)),url('assets/img/construction-1.jpg') center/cover;
  color:#fff;padding:120px 20px 80px;text-align:center;
}
.page-banner h1{color:#fff}
.breadcrumbs{font-size:.9rem;opacity:.9}
.breadcrumbs a{color:var(--sotej-secondary)}

/* Service detail block */
.service-block{
  display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:60px 0;
  border-bottom:1px solid var(--sotej-grey);
}
.service-block:nth-child(even) .service-img{order:2}
.service-block img{border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow)}
.service-block ul{padding-left:0;list-style:none}
.service-block li{padding:8px 0 8px 30px;position:relative}
.service-block li::before{
  content:'✓';position:absolute;left:0;top:8px;width:20px;height:20px;
  background:var(--sotej-secondary);color:var(--sotej-primary);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;
}
@media (max-width:800px){.service-block{grid-template-columns:1fr}.service-block:nth-child(even) .service-img{order:0}}

/* Contact */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-card{
  background:#fff;border-radius:var(--sotej-radius);padding:26px;box-shadow:var(--sotej-shadow);
  margin-bottom:18px;border-left:4px solid var(--sotej-secondary);
}
.contact-card h3{color:var(--sotej-primary);margin-bottom:10px;display:flex;align-items:center;gap:10px}
.contact-card .ico{
  width:42px;height:42px;border-radius:50%;background:var(--sotej-primary);color:#fff;
  display:flex;align-items:center;justify-content:center;font-size:18px;
}
.contact-form{background:#fff;padding:36px;border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow)}
.contact-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.contact-form input,.contact-form textarea,.contact-form select{
  width:100%;padding:14px 16px;border:1.5px solid var(--sotej-grey);border-radius:8px;
  font-family:inherit;font-size:.95rem;transition:var(--sotej-trans);background:#fafbfd;
}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{
  outline:none;border-color:var(--sotej-primary);background:#fff;
}
.contact-form textarea{min-height:140px;resize:vertical}
.contact-form button{width:100%;margin-top:8px}
@media (max-width:600px){.contact-form .form-row{grid-template-columns:1fr}}
.map-embed{width:100%;height:380px;border:0;border-radius:var(--sotej-radius);box-shadow:var(--sotej-shadow);margin-top:20px}

/* Footer */
.site-footer{background:var(--sotej-dark);color:#c8cad6;padding:70px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:50px}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.footer-grid{grid-template-columns:1fr}}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:18px;position:relative;padding-bottom:10px}
.site-footer h4::after{content:'';position:absolute;left:0;bottom:0;width:40px;height:3px;background:var(--sotej-secondary);border-radius:2px}
.site-footer a{color:#c8cad6}
.site-footer a:hover{color:var(--sotej-secondary)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer li{padding:6px 0;font-size:.92rem}
.footer-contact li{display:flex;gap:10px;align-items:flex-start;line-height:1.5}
.footer-contact .ico{color:var(--sotej-secondary);min-width:18px;margin-top:4px}
.social-icons{display:flex;gap:10px;margin-top:14px}
.social-icons a{
  width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);
  display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;
}
.social-icons a:hover{background:var(--sotej-secondary);color:var(--sotej-primary)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:22px 0;text-align:center;font-size:.88rem}

/* WhatsApp & Back-to-top */
.whatsapp-float{
  position:fixed;bottom:24px;right:24px;width:58px;height:58px;border-radius:50%;
  background:#25d366;color:#fff;display:flex;align-items:center;justify-content:center;
  z-index:998;box-shadow:0 6px 20px rgba(37,211,102,.4);font-size:28px;
  animation:pulse 2s infinite;
}
.whatsapp-float:hover{transform:scale(1.1);color:#fff}
@keyframes pulse{0%,100%{box-shadow:0 6px 20px rgba(37,211,102,.4)}50%{box-shadow:0 6px 25px rgba(37,211,102,.7)}}

.back-to-top{
  position:fixed;bottom:24px;left:24px;width:46px;height:46px;border-radius:50%;
  background:var(--sotej-primary);color:#fff;display:none;align-items:center;justify-content:center;
  z-index:998;border:0;cursor:pointer;font-size:20px;box-shadow:var(--sotej-shadow);transition:var(--sotej-trans);
}
.back-to-top:hover{background:var(--sotej-secondary);color:var(--sotej-primary)}
.back-to-top.show{display:flex}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Form notice */
.form-notice{padding:14px;border-radius:8px;margin-bottom:18px;font-weight:600;display:none}
.form-notice.success{background:#e6fff0;color:#065f46;display:block}
.form-notice.error{background:#ffe6e6;color:#7f1d1d;display:block}

/* ============= Témoignages ============= */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-top:30px}
.testimonial-card{background:#fff;border-radius:var(--sotej-radius);padding:28px;box-shadow:var(--sotej-shadow);position:relative;display:flex;flex-direction:column;gap:16px;border-top:4px solid var(--sotej-secondary)}
.testimonial-quote{color:var(--sotej-secondary);font-size:1.6rem;opacity:.6}
.testimonial-text{color:#444;font-style:italic;line-height:1.6;flex:1}
.testimonial-author{display:flex;align-items:center;gap:12px;border-top:1px solid #eee;padding-top:14px}
.testimonial-author img{width:52px;height:52px;border-radius:50%;object-fit:cover;border:2px solid var(--sotej-secondary)}
.testimonial-author strong{display:block;color:var(--sotej-primary);font-size:.95rem}
.testimonial-author span{color:#777;font-size:.82rem}

/* ============= Service détail ============= */
.service-detail-list{list-style:none;padding:0;margin:18px 0 24px}
.service-detail-list li{padding:8px 0;color:#333;display:flex;align-items:center;gap:10px}
.service-detail-list li i{color:var(--sotej-secondary)}
.detail-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:24px}
.detail-gallery-item{border-radius:var(--sotej-radius);overflow:hidden;box-shadow:var(--sotej-shadow);aspect-ratio:4/3}
.detail-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.detail-gallery-item:hover img{transform:scale(1.05)}

/* ============= Réalisation détail ============= */
.realisation-header{text-align:center;max-width:820px;margin:0 auto 30px}
.realisation-header .cat-tag{display:inline-block;background:var(--sotej-secondary);color:var(--sotej-primary);font-weight:700;padding:6px 14px;border-radius:999px;font-size:.8rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}
.realisation-header h2{color:var(--sotej-primary)}
.realisation-desc{color:#555;line-height:1.7;font-size:1.05rem}
.realisation-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;background:#f8f9ff;border-left:4px solid var(--sotej-secondary);padding:20px;border-radius:var(--sotej-radius);margin:24px 0 36px}
.realisation-meta .meta-item{display:flex;flex-direction:column;gap:4px}
.realisation-meta .meta-item span{color:#888;font-size:.78rem;text-transform:uppercase;letter-spacing:1px}
.realisation-meta .meta-item strong{color:var(--sotej-primary);font-size:1rem}
.realisation-gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.realisation-gallery-item{border-radius:var(--sotej-radius);overflow:hidden;box-shadow:var(--sotej-shadow);aspect-ratio:4/3}
.realisation-gallery-item.featured{grid-column:span 2;aspect-ratio:21/9}
.realisation-gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.realisation-gallery-item:hover img{transform:scale(1.04)}
@media (max-width:760px){.realisation-gallery{grid-template-columns:1fr}.realisation-gallery-item.featured{grid-column:span 1;aspect-ratio:4/3}}

/* ============= Partenaires ============= */
.partners-grid{
  display:grid;grid-template-columns:repeat(6,1fr);gap:18px;margin-top:30px;
}
.partner-logo{
  background:#fff;border-radius:var(--sotej-radius);border:1px solid var(--sotej-grey);
  aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;padding:14px;
  transition:var(--sotej-trans);box-shadow:0 4px 14px rgba(24,30,114,.05);
}
.partner-logo:hover{transform:translateY(-4px);box-shadow:var(--sotej-shadow);border-color:var(--sotej-secondary)}
.partner-logo img{width:100%;height:100%;object-fit:contain;filter:grayscale(20%);transition:var(--sotej-trans)}
.partner-logo:hover img{filter:grayscale(0)}
@media (max-width:1100px){.partners-grid{grid-template-columns:repeat(4,1fr)}}
@media (max-width:700px){.partners-grid{grid-template-columns:repeat(3,1fr);gap:12px}}
@media (max-width:420px){.partners-grid{grid-template-columns:repeat(2,1fr)}}

/* ============= Galerie d'activités ============= */
.activites-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;margin-top:30px;
}
.activite-card{
  background:#fff;border-radius:var(--sotej-radius);overflow:hidden;display:block;
  color:inherit;text-decoration:none;box-shadow:var(--sotej-shadow);transition:var(--sotej-trans);
  display:flex;flex-direction:column;border:1px solid transparent;
}
.activite-card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(24,30,114,.18);border-color:var(--sotej-secondary)}
.activite-thumb{position:relative;aspect-ratio:16/10;overflow:hidden;background:#000}
.activite-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.activite-card:hover .activite-thumb img{transform:scale(1.06)}
.activite-badge{
  position:absolute;top:12px;left:12px;background:rgba(24,30,114,.92);color:var(--sotej-secondary);
  padding:6px 12px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;display:inline-flex;align-items:center;gap:6px;
}
.activite-body{padding:22px 22px 24px;display:flex;flex-direction:column;gap:8px;flex:1}
.activite-cat{color:var(--sotej-secondary);font-size:.78rem;font-weight:700;letter-spacing:1px;text-transform:uppercase}
.activite-body h3{margin:0;color:var(--sotej-primary);font-size:1.15rem}
.activite-body p{color:#555;font-size:.95rem;margin:0;flex:1}
.activite-body .card-link{margin-top:10px;color:var(--sotej-secondary);font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* ============= Vidéos ============= */
.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px;margin-top:24px}
.video-frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--sotej-radius);overflow:hidden;box-shadow:var(--sotej-shadow);background:#000}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ============= Responsive enhancements ============= */
@media (max-width:1024px){
  section.block{padding:70px 0}
  .intro-grid{gap:36px}
}
@media (max-width:760px){
  section.block{padding:54px 0}
  .section-head{margin-bottom:34px}
  .hero-slide{min-height:62vh}
  .hero-content{padding:60px 0}
  .hero-content h1{font-size:clamp(1.6rem,7vw,2.2rem)}
  .hero-content p{font-size:1rem}
  .hero-arrow{width:40px;height:40px;font-size:18px}
  .hero-prev{left:8px}.hero-next{right:8px}
  .page-banner{padding:90px 16px 60px}
  .service-block{gap:30px;padding:40px 0}
  .footer-grid{gap:30px}
  .cta-section{padding:60px 16px}
  .whatsapp-float{width:50px;height:50px;font-size:24px;bottom:18px;right:18px}
  .back-to-top{width:40px;height:40px;font-size:16px;bottom:18px;left:18px}
  .site-logo-img,.custom-logo{height:50px!important}
  .hero-buttons .btn,.cta-section .buttons .btn{padding:11px 22px;font-size:.9rem}
}
@media (max-width:480px){
  .container{padding:0 16px}
  .hero-buttons{flex-direction:column;align-items:stretch}
  .hero-buttons .btn{text-align:center}
  .testimonials-grid{gap:18px}
  .testimonial-card{padding:22px}
  .contact-form{padding:24px}
  .realisation-meta{padding:16px}
}
