/*
Theme Name:  themeCig
Theme URI:   https://EDITIONCIG.fr
Author:      VotreAgence
Author URI:  https://EDITIONCIG.fr
Description: Thème sur mesure – Régie publicitaire éducative. Palette bleue moderne. Bootstrap 5.3 + ACF + Rev Slider.
Version:     1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License:     GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: themecig
Tags:        custom-colors, custom-logo, responsive-layout, full-width-template
*/
 
/* ============================================================
   VARIABLES PALETTE
   ============================================================ */
:root {
  --tc-bg:          #F4F7FB;
  --tc-white:       #FFFFFF;
  --tc-ivory:       #EEF4FF;
  --tc-ivory-muted: rgba(220,232,255,0.65);
  --tc-brown:       #425969;
  --tc-brown-mid:   #6A8A9A;
  --tc-brown-light: #8AAABB;
  --tc-beige:       #E8EFF3;
  --tc-beige-mid:   #C8D8DF;
  --tc-beige-dark:  #A8C0CC;
  --tc-accent:      #1E3340;
  --tc-text:        #1A2830;
  --tc-muted:       #5A7080;
  --tc-border:      #C8D8E0;

  --tc-hover:       #E68429;
  --tc-warm:        #92756F;
  --tc-btn:         #C4AE41;
  --tc-btn-dark:    #A89030;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Georgia', serif !important;
  background-color: var(--tc-bg) !important;
  color: var(--tc-text) !important;
  margin: 0;
  padding: 0;
}

a { color: var(--tc-brown-light); text-decoration: none; transition: color .18s; }
a:hover { color: var(--tc-brown); }

img { max-width: 100%; height: auto; }

/* ============================================================
   ECRASEMENT BOOTSTRAP — COULEURS PRINCIPALES
   ============================================================ */

.btn-primary,
.btn-primary:visited {
  background-color: var(--tc-btn) !important;
  border-color:     var(--tc-btn) !important;
  color:            #fff !important;
  border-radius:    40px !important;
  font-family:      system-ui, sans-serif !important;
  font-weight:      700 !important;
  padding:          11px 26px !important;
  transition:       background .18s, transform .12s !important;
}
.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--tc-btn-dark) !important;
  border-color:     var(--tc-btn-dark) !important;
  color:            #fff !important;
  transform:        translateY(-1px);
}

.btn-ivory {
  background-color: var(--tc-white) !important;
  border-color:     var(--tc-white) !important;
  color:            var(--tc-brown) !important;
  border-radius:    40px !important;
  font-family:      system-ui, sans-serif !important;
  font-weight:      700 !important;
  padding:          11px 26px !important;
}
.btn-ivory:hover {
  background-color: var(--tc-ivory) !important;
  color:            var(--tc-brown) !important;
  transform:        translateY(-1px);
}

.btn-outline-ivory {
  background-color: transparent !important;
  border:           1.5px solid rgba(220,232,255,0.38) !important;
  color:            var(--tc-ivory) !important;
  border-radius:    40px !important;
  font-family:      system-ui, sans-serif !important;
  font-weight:      500 !important;
  padding:          11px 26px !important;
}
.btn-outline-ivory:hover {
  border-color:     var(--tc-ivory) !important;
  background-color: rgba(220,232,255,0.07) !important;
  color:            var(--tc-ivory) !important;
}

.btn-secondary {
  background-color: var(--tc-btn) !important;
  border-color:     var(--tc-btn) !important;
  color:            #fff !important;
  border-radius:    40px !important;
}
.btn-secondary:hover {
  background-color: var(--tc-btn-dark) !important;
  border-color:     var(--tc-btn-dark) !important;
  color:            #fff !important;
}

.alert {
  border-radius:  10px !important;
  font-family:    system-ui, sans-serif !important;
  font-size:      14px !important;
}
.alert-primary {
  background-color: rgba(66,89,105,0.08) !important;
  border-color:     rgba(66,89,105,0.2) !important;
  color:            var(--tc-brown-mid) !important;
}
.alert-success {
  background-color: rgba(66,89,105,0.06) !important;
  border-color:     rgba(66,89,105,0.15) !important;
  color:            var(--tc-brown) !important;
}
.alert-warning {
  background-color: rgba(232,239,243,0.7) !important;
  border-color:     var(--tc-beige-dark) !important;
  color:            var(--tc-brown-mid) !important;
}
.alert-danger {
  background-color: rgba(220,50,50,0.08) !important;
  border-color:     rgba(220,50,50,0.2) !important;
  color:            #2a3a40 !important;
}

.card {
  background-color: var(--tc-white) !important;
  border:           1px solid var(--tc-border) !important;
  border-radius:    14px !important;
}
.card-header {
  background-color: var(--tc-beige) !important;
  border-bottom:    1px solid var(--tc-border) !important;
  color:            var(--tc-brown) !important;
  font-weight:      700 !important;
}
.card-footer {
  background-color: var(--tc-beige) !important;
  border-top:       1px solid var(--tc-border) !important;
}

.badge.bg-primary   { background-color: var(--tc-brown) !important; color: var(--tc-ivory) !important; border-radius: 40px !important; }
.badge.bg-secondary { background-color: var(--tc-brown-mid) !important; color: var(--tc-ivory) !important; border-radius: 40px !important; }

.nav-tabs { border-color: var(--tc-border) !important; }
.nav-tabs .nav-link {
  color:          var(--tc-muted) !important;
  font-family:    system-ui, sans-serif !important;
  font-size:      14px !important;
  border-radius:  8px 8px 0 0 !important;
}
.nav-tabs .nav-link.active {
  color:            var(--tc-brown) !important;
  background-color: var(--tc-white) !important;
  border-color:     var(--tc-border) var(--tc-border) var(--tc-white) !important;
}

.form-control,
.form-select {
  background-color: var(--tc-bg) !important;
  border:           1px solid var(--tc-border) !important;
  border-radius:    8px !important;
  color:            var(--tc-text) !important;
  font-family:      system-ui, sans-serif !important;
  font-size:        14px !important;
  padding:          11px 14px !important;
  transition:       border-color .18s !important;
}
.form-control:focus,
.form-select:focus {
  border-color:     var(--tc-brown-light) !important;
  box-shadow:       none !important;
  background-color: var(--tc-white) !important;
}
.form-label {
  font-family:   system-ui, sans-serif !important;
  font-size:     12.5px !important;
  font-weight:   600 !important;
  color:         var(--tc-brown-mid) !important;
  margin-bottom: 6px !important;
}

.pagination .page-link {
  color:            var(--tc-brown-mid) !important;
  background-color: transparent !important;
  border:           1px solid var(--tc-border) !important;
  border-radius:    40px !important;
  font-family:      system-ui, sans-serif !important;
  font-size:        14px !important;
  width:            38px !important;
  height:           38px !important;
  display:          flex !important;
  align-items:      center !important;
  justify-content:  center !important;
  margin:           0 3px !important;
  transition:       all .18s !important;
}
.pagination .page-link:hover {
  background-color: var(--tc-beige) !important;
  color:            var(--tc-brown) !important;
  border-color:     var(--tc-beige-dark) !important;
}
.pagination .page-item.active .page-link {
  background-color: var(--tc-brown) !important;
  border-color:     var(--tc-brown) !important;
  color:            var(--tc-ivory) !important;
}

.dropdown-menu {
  border:        1px solid var(--tc-border) !important;
  border-radius: 12px !important;
  padding:       8px !important;
  box-shadow:    0 12px 40px rgba(0,0,0,0.09) !important;
  background:    var(--tc-white) !important;
}
.dropdown-item {
  font-family:   system-ui, sans-serif !important;
  font-size:     13.5px !important;
  color:         var(--tc-text) !important;
  border-radius: 8px !important;
  padding:       9px 14px !important;
  transition:    background .15s !important;
}
.dropdown-item:hover, .dropdown-item:focus {
  background-color: var(--tc-beige) !important;
  color:            var(--tc-brown) !important;
}

.modal-content {
  border-radius: 16px !important;
  border:        1px solid var(--tc-border) !important;
}
.modal-header {
  border-bottom:    1px solid var(--tc-border) !important;
  background-color: var(--tc-beige) !important;
}
.modal-title  { color: var(--tc-brown) !important; font-weight: 700 !important; }
.modal-footer { border-top: 1px solid var(--tc-border) !important; }
.btn-close    { filter: none !important; opacity: .6 !important; }

/* ============================================================
   HEADER
   ============================================================ */
#site-header,
header#masthead,
.site-header {
  position:      sticky !important;
  top:           0 !important;
  z-index:       1000 !important;
  background:    linear-gradient(135deg, #1E3340 0%, #425969 55%, #6A8A9A 100%) !important;
  border-bottom: none !important;
  height:        120px !important;
  display:       flex !important;
  align-items:   center !important;
  transition:    box-shadow .35s ease !important;
  box-shadow:    0 4px 32px rgba(30,51,64,0.18),
                 0 1px 6px rgba(30,51,64,0.10) !important;
}
#site-header.scrolled,
header#masthead.scrolled {
  box-shadow: 0 4px 24px rgba(30,51,64,0.12) !important;
}

/* Logo texte */
.site-branding a,
.navbar-brand {
  font-size:       20px !important;
  font-weight:     700 !important;
  font-family:     'Georgia', serif !important;
  color:           #FFFFFF !important;
  letter-spacing:  -0.5px !important;
  text-decoration: none !important;
  display:         flex !important;
  align-items:     center !important;
  line-height:     1 !important;
}

/* Logo image */
.site-branding img,
.navbar-brand img,
.custom-logo,
.navbar-brand .custom-logo {
  display:    block !important;
  width:      150px !important;
  height:     auto !important;
  max-width:  none !important;
  object-fit: contain !important;
  filter:     brightness(0) invert(1) !important;
}

/* Navbar Bootstrap override */
.navbar {
  padding:     0 max(20px, calc((100% - 1140px)/2 + 20px)) !important;
  height:      80px !important;
  background:  transparent !important;
  width:       100% !important;
  align-items: center !important;
}

.navbar-brand {
  padding-top:    0 !important;
  padding-bottom: 0 !important;
  margin-right:   24px !important;
  height:         80px !important;
  display:        flex !important;
  align-items:    center !important;
}

/* ── Logo shimmer animé en boucle ── */
.custom-logo-link {
  position: relative !important;
  overflow: hidden !important;
  display:  inline-block !important;
}
.custom-logo-link::after {
  content:        '' !important;
  position:       absolute !important;
  top:            0 !important;
  left:           -100% !important;
  width:          55% !important;
  height:         100% !important;
  background:     linear-gradient(
    120deg,
    transparent            0%,
    rgba(255,255,255,0.55) 50%,
    transparent            100%
  ) !important;
  pointer-events: none !important;
  z-index:        2 !important;
  animation:      logoShimmer 4s ease-in-out infinite !important;
}
@keyframes logoShimmer {
  0%   { left: -100%; }
  35%  { left: 160%; }
  100% { left: 160%; }
}

/* Liens nav : blanc par défaut, orange au hover */
.navbar-nav .nav-link {
  font-family:   system-ui, sans-serif !important;
  font-size:     13.5px !important;
  font-weight:   500 !important;
  color:         #FFFFFF !important;
  padding:       8px 14px !important;
  border-radius: 8px !important;
  transition:    color .18s, background .18s !important;
}
.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus,
.navbar-nav .nav-link.active,
.navbar-nav .nav-item.active .nav-link {
  color:            var(--tc-hover) !important;
  background-color: rgba(230,132,41,0.08) !important;
}

.navbar-toggler {
  border:        none !important;
  padding:       6px !important;
  border-radius: 8px !important;
}
.navbar-toggler:focus { box-shadow: none !important; }
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='%23FFFFFF' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}

/* CTA nav button */
.nav-cta-btn {
  background-color: var(--tc-btn) !important;
  color:            #fff !important;
  border-radius:    40px !important;
  padding:          9px 22px !important;
  font-family:      system-ui, sans-serif !important;
  font-weight:      600 !important;
  font-size:        13px !important;
  border:           none !important;
  transition:       background .18s !important;
  white-space:      nowrap !important;
}
.nav-cta-btn:hover {
  background-color: var(--tc-btn-dark) !important;
  color:            #fff !important;
}

/* Mobile menu offcanvas */
.offcanvas {
  background-color: var(--tc-white) !important;
}
.offcanvas-header {
  border-bottom: 1px solid var(--tc-border) !important;
}
.offcanvas .navbar-nav .nav-link {
  font-size:     15px !important;
  padding:       13px 0 !important;
  color:         var(--tc-text) !important;
  border-bottom: 1px solid var(--tc-beige) !important;
  border-radius: 0 !important;
}
.offcanvas .navbar-nav .nav-link:hover {
  color:            var(--tc-hover) !important;
  background-color: transparent !important;
}

/* ============================================================
   CONTENU PRINCIPAL
   ============================================================ */
#content,
.site-content,
main#main {
  background-color: var(--tc-bg) !important;
  min-height:       60vh !important;
}

.rev_slider_wrapper,
.tp-bannertimer { width: 100% !important; }

.tc-dark {
  background-color: var(--tc-brown) !important;
  padding:          56px max(20px, calc((100% - 1140px)/2 + 20px)) !important;
}
.tc-dark h1, .tc-dark h2, .tc-dark h3,
.tc-dark .tc-title {
  color: var(--tc-ivory) !important;
}
.tc-dark p, .tc-dark .lead {
  color: var(--tc-ivory-muted) !important;
}
.tc-dark .tc-eyebrow {
  color: var(--tc-ivory-muted) !important;
}

.tc-beige { background-color: #C4AE41!important; }

.tc-eyebrow {
  font-family:    system-ui, sans-serif !important;
  font-size:      11px !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color:          var(--tc-brown-light) !important;
  margin-bottom:  10px !important;
  display:        block !important;
}

h1, h2, h3, h4, h5, h6 {
  color:          var(--tc-brown) !important;
  font-family:    'Georgia', serif !important;
  letter-spacing: -0.5px !important;
  line-height:    1.2 !important;
}
h1 { font-size: clamp(28px, 4vw, 50px) !important; }
h2 { font-size: clamp(24px, 3vw, 38px) !important; }
h3 { font-size: 22px !important; }

p, li, td, th {
  font-family: system-ui, sans-serif !important;
  color:       var(--tc-text) !important;
  line-height: 1.75 !important;
}
.text-muted { color: var(--tc-muted) !important; }

/* ============================================================
   STATS BAR
   ============================================================ */
.tc-stats {
  background-color: var(--tc-beige) !important;
  border-bottom:    1px solid var(--tc-border) !important;
  display:          grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
}
.tc-stat {
  padding:      28px 24px !important;
  border-right: 1px solid var(--tc-border) !important;
  text-align:   center !important;
}
.tc-stat:last-child { border-right: none !important; }
.tc-stat-num {
  font-size:   28px !important;
  font-weight: 700 !important;
  color:       var(--tc-brown) !important;
  font-family: 'Georgia', serif !important;
}
.tc-stat-label {
  font-size:   12.5px !important;
  color:       var(--tc-muted) !important;
  margin-top:  4px !important;
  font-family: system-ui, sans-serif !important;
}

/* ============================================================
   CARDS
   ============================================================ */
.tc-card {
  background-color: var(--tc-white) !important;
  border:           1px solid var(--tc-border) !important;
  border-radius:    14px !important;
  padding:          28px !important;
  transition:       border-color .2s, transform .2s !important;
  cursor:           pointer !important;
}
.tc-card:hover {
  border-color: var(--tc-brown-light) !important;
  transform:    translateY(-3px) !important;
}
.tc-card h3 {
  font-size:     16px !important;
  font-weight:   700 !important;
  color:         var(--tc-brown) !important;
  margin-bottom: 8px !important;
}
.tc-card p {
  font-size:   13.5px !important;
  color:       var(--tc-muted) !important;
  line-height: 1.65 !important;
}
.tc-card-icon {
  width:           48px !important;
  height:          48px !important;
  border-radius:   10px !important;
  background:      var(--tc-beige) !important;
  display:         flex !important;
  align-items:     center !important;
  justify-content: center !important;
  margin-bottom:   16px !important;
}
.tc-card-link {
  font-size:    12.5px !important;
  font-weight:  600 !important;
  color:        var(--tc-brown-light) !important;
  margin-top:   12px !important;
  display:      inline-block !important;
  transition:   letter-spacing .2s !important;
}
.tc-card:hover .tc-card-link { letter-spacing: 0.3px !important; }

.tc-tag {
  font-size:      10.5px !important;
  font-weight:    600 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  font-family:    system-ui, sans-serif !important;
  padding:        4px 12px !important;
  border-radius:  40px !important;
  background:     var(--tc-warm) !important;
  color:          #fff !important;
  display:        inline-block !important;
}

/* ============================================================
   CARROUSEL CLIENTS
   ============================================================ */
.tc-carousel-wrap {
  overflow:  hidden !important;
  position:  relative !important;
  padding:   40px 0 !important;
}
.tc-carousel-track {
  display:   flex !important;
  gap:       28px !important;
  width:     max-content !important;
  animation: tcSlide 28s linear infinite !important;
}
.tc-carousel-wrap:hover .tc-carousel-track {
  animation-play-state: paused !important;
}
@keyframes tcSlide { to { transform: translateX(-50%); } }

.tc-client-card {
  flex-shrink:     0 !important;
  width:           200px !important;
  height:          130px !important;
  background:      var(--tc-white) !important;
  border:          1px solid var(--tc-border) !important;
  border-radius:   12px !important;
  display:         flex !important;
  flex-direction:  column !important;
  align-items:     center !important;
  justify-content: center !important;
  gap:             10px !important;
  text-decoration: none !important;
  padding:         16px !important;
  transition:      border-color .2s, transform .18s !important;
}
.tc-client-card:hover {
  border-color: var(--tc-hover) !important;
  transform:    translateY(-2px) !important;
}
.tc-client-card img,
.tc-client-thumb {
  width:         120px !important;
  height:        72px !important;
  object-fit:    contain !important;
  border-radius: 6px !important;
  display:       block !important;
}
.tc-client-name {
  font-size:   11.5px !important;
  font-family: system-ui, sans-serif !important;
  font-weight: 600 !important;
  color:       var(--tc-brown-mid) !important;
  text-align:  center !important;
}

/* ============================================================
   BLOG
   ============================================================ */
.tc-blog-grid {
  display:               grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap:                   24px !important;
}
.tc-article-card {
  background:    var(--tc-white) !important;
  border:        1px solid var(--tc-border) !important;
  border-radius: 14px !important;
  overflow:      hidden !important;
  transition:    transform .25s, border-color .2s !important;
  cursor:        pointer !important;
}
.tc-article-card:hover {
  transform:    translateY(-4px) !important;
  border-color: var(--tc-beige-dark) !important;
}
.tc-article-card .tc-article-thumb {
  aspect-ratio: 16/9 !important;
  overflow:     hidden !important;
}
.tc-article-card .tc-article-thumb img {
  width:      100% !important;
  height:     100% !important;
  object-fit: cover !important;
  transition: transform .35s !important;
}
.tc-article-card:hover .tc-article-thumb img {
  transform: scale(1.04) !important;
}
.tc-article-body { padding: 18px 18px 16px !important; }
.tc-article-body h3, .tc-article-body .entry-title {
  font-size:     15px !important;
  font-weight:   700 !important;
  color:         var(--tc-brown) !important;
  margin-bottom: 6px !important;
}
.tc-article-meta {
  font-size:     12px !important;
  color:         var(--tc-muted) !important;
  font-family:   system-ui, sans-serif !important;
  margin-bottom: 10px !important;
}
.tc-article-excerpt {
  font-size:   13px !important;
  color:       var(--tc-muted) !important;
  line-height: 1.6 !important;
  font-family: system-ui, sans-serif !important;
}

/* ============================================================
   FOOTER
   ============================================================ */
#colophon,
footer#masthead,
.site-footer,
footer.site-footer {
  background: linear-gradient(135deg, #1E3340 0%, #425969 60%, #5A7A8A 100%) !important;
  color:       rgba(220,232,255,0.6) !important;
  padding:     52px max(20px, calc((100% - 1140px)/2 + 20px)) 24px !important;
}
.site-footer .footer-logo,
.site-footer .site-title a {
  font-size:   20px !important;
  font-weight: 700 !important;
  font-family: 'Georgia', serif !important;
  color:       var(--tc-ivory) !important;
}
.site-footer h4, .site-footer .widget-title {
  font-size:      12px !important;
  font-weight:    700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  color:          rgba(220,232,255,0.4) !important;
  font-family:    system-ui, sans-serif !important;
  margin-bottom:  14px !important;
}
.site-footer p,
.site-footer li,
.site-footer .footer-desc {
  font-size:   13px !important;
  color:       rgba(220,232,255,0.5) !important;
  line-height: 1.7 !important;
  font-family: system-ui, sans-serif !important;
}
.site-footer a,
.site-footer .widget ul li a {
  color:           rgba(220,232,255,0.6) !important;
  text-decoration: none !important;
  font-size:       13.5px !important;
  transition:      color .18s !important;
  display:         block !important;
  padding:         3px 0 !important;
}
.site-footer a:hover,
.site-footer .widget ul li a:hover {
  color: var(--tc-hover) !important;
}
.site-footer .footer-bottom {
  border-top:  1px solid rgba(220,232,255,0.1) !important;
  padding-top: 20px !important;
  margin-top:  40px !important;
  font-size:   12.5px !important;
  color:       rgba(220,232,255,0.3) !important;
  font-family: system-ui, sans-serif !important;
}

/* ============================================================
   PAGE HÉRO
   ============================================================ */
.tc-page-hero {
  background-color: var(--tc-brown) !important;
  padding:          56px max(20px, calc((100% - 1140px)/2 + 20px)) !important;
}
.tc-page-hero h1,
.tc-page-hero .page-title {
  color:          var(--tc-ivory) !important;
  font-size:      clamp(28px, 4vw, 44px) !important;
  font-weight:    700 !important;
  letter-spacing: -1px !important;
  line-height:    1.15 !important;
  margin-bottom:  14px !important;
}
.tc-page-hero p, .tc-page-hero .lead {
  color:     var(--tc-ivory-muted) !important;
  font-size: 15px !important;
  max-width: 520px !important;
}

/* ============================================================
   CTA BAND
   ============================================================ */
.tc-cta-band {
  background-color: var(--tc-brown) !important;
  padding:          64px max(20px, calc((100% - 1140px)/2 + 20px)) !important;
  text-align:       center !important;
}
.tc-cta-band h2 { color: var(--tc-ivory) !important; }
.tc-cta-band p  { color: var(--tc-ivory-muted) !important; font-family: system-ui, sans-serif !important; }

/* ============================================================
   SINGLE ARTICLE
   ============================================================ */
.single .entry-content,
article.post .entry-content {
  max-width:   720px !important;
  margin:      0 auto !important;
  font-size:   16.5px !important;
  line-height: 1.85 !important;
  color:       var(--tc-text) !important;
}
.single .entry-content h2 {
  font-size:   22px !important;
  color:       var(--tc-brown) !important;
  margin:      36px 0 14px !important;
}
.single .entry-content blockquote {
  border-left:   3px solid var(--tc-warm) !important;
  padding:       16px 24px !important;
  margin:        28px 0 !important;
  background:    var(--tc-beige) !important;
  border-radius: 0 10px 10px 0 !important;
  font-style:    italic !important;
  color:         var(--tc-warm) !important;
}

/* ============================================================
   CPT CLIENT — CARROUSEL
   ============================================================ */
.tc-client-initials {
  width:           120px !important;
  height:          72px !important;
  border-radius:   6px !important;
  background:      var(--tc-beige) !important;
  display:         flex !important;
  align-items:     center !important;
  justify-content: center !important;
  font-size:       20px !important;
  font-weight:     700 !important;
  color:           var(--tc-brown-mid) !important;
  font-family:     'Georgia', serif !important;
  letter-spacing:  -0.5px !important;
}

.tc-carousel-fade-l {
  position:       absolute !important;
  left:0;top:0;bottom:0;
  width:          80px !important;
  background:     linear-gradient(to right, var(--tc-beige), transparent) !important;
  z-index:        2 !important;
  pointer-events: none !important;
}
.tc-carousel-fade-r {
  position:       absolute !important;
  right:0;top:0;bottom:0;
  width:          80px !important;
  background:     linear-gradient(to left, var(--tc-beige), transparent) !important;
  z-index:        2 !important;
  pointer-events: none !important;
}

.tc-client-card            { text-decoration: none !important; }
.tc-client-card:hover      { text-decoration: none !important; }
.tc-client-nolink          { cursor: default !important; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 991px) {
  .tc-stats { grid-template-columns: repeat(2, 1fr) !important; }
  .tc-stat:nth-child(2) { border-right: none !important; }
  .tc-blog-grid { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 576px) {
  .tc-stats { grid-template-columns: 1fr 1fr !important; }
  .tc-blog-grid { grid-template-columns: 1fr !important; }
  .tc-carousel-track { gap: 16px !important; }
}

/* ============================================================
   CF7
   ============================================================ */
.tc-cf7-wrap { display:flex; flex-direction:column; gap:16px; }
.tc-cf7-grid { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.tc-field { display:flex; flex-direction:column; gap:6px; }
.tc-field label { font-size:12px; font-weight:600; color:#1E3340; letter-spacing:.3px; }
.tc-field .req { color:#425969; }
.tc-field .opt { font-size:11px; font-weight:400; color:#5A7080; }
.wpcf7 input[type=text], .wpcf7 input[type=email],
.wpcf7 input[type=tel], .wpcf7 select, .wpcf7 textarea {
  width:100% !important; padding:12px 16px !important;
  font-size:14px !important; color:#1A2830 !important;
  background:#F4F7FB !important; border:1.5px solid #C8D8E0 !important;
  border-radius:10px !important; outline:none !important;
  transition:border-color .18s !important; appearance:none !important;
}
.wpcf7 input:focus, .wpcf7 select:focus, .wpcf7 textarea:focus {
  border-color:#425969 !important; background:#fff !important;
}
.wpcf7 textarea { height:120px !important; resize:none !important; }
.tc-cf7-footer { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; margin-top:12px; }
.tc-cf7-note { font-size:12px; color:#5A7080; }
.wpcf7 input[type=submit] {
  background:linear-gradient(135deg,#C4AE41,#A89030) !important; color:#ffffff !important;
  font-size:14px !important; font-weight:600 !important;
  padding:13px 32px !important; border-radius:40px !important;
  border:none !important; cursor:pointer !important;
  transition:background .18s, box-shadow .18s !important;
  box-shadow:0 4px 20px rgba(196,174,65,0.28) !important;
}
.wpcf7 input[type=submit]:hover {
  background:linear-gradient(135deg,#A89030,#8A7428) !important;
  box-shadow:0 8px 28px rgba(196,174,65,0.40) !important;
}
@media(max-width:520px){ .tc-cf7-grid { grid-template-columns:1fr !important; } }

.cig-light{
  font-weight:200; /* fine */
  font-family:'Poppins', sans-serif;
  letter-spacing:1px;
}

.cig-subtitle{
  font-weight:300;
}

.cig-desc{
  font-weight:300;
}


/* ── Slider mobile responsive ── */
@media (max-width: 767px) {
  .cig-slide-wrapper {
    padding: 0 16px !important;
    gap: 4px !important;
  }
  .cig-title {
    font-size: clamp(18px, 5vw, 28px) !important;
    line-height: 1.15 !important;
  }
  .cig-subtitle {
    font-size: 13px !important;
    letter-spacing: 0 !important;
    line-height: 1.3 !important;
  }
  .cig-desc {
    font-size: 11px !important;
    line-height: 1.3 !important;
  }
  .cig-btn {
    font-size: 11px !important;
    padding: 8px 18px !important;
    margin-top: 4px !important;
  }
}

@media (max-width: 480px) {
  .cig-title {
    font-size: clamp(16px, 4.5vw, 22px) !important;
    FONT-SIZE:12px!important;
  }
  .cig-subtitle {
    font-size: 11px !important;
  }
  .cig-desc {
    display: none !important; /* masque la desc sur très petit écran */
  }
  .cig-btn {
    font-size: 10px !important;
    padding: 7px 14px !important;
  }
}