/* =========================================================
   RESEO - CUSTOM CSS CLEAN
   ========================================================= */

/* =========================================================
   VARIABLES
   ========================================================= */

:root {
  --rx-bg: #eef4f8;
  --rx-bg-soft: #f7fbfd;
  --rx-surface: #ffffff;
  --rx-surface-2: #f3f8fc;
  --rx-border: #d9e6ef;
  --rx-border-strong: #bfd4e2;

  --rx-text: #102033;
  --rx-text-soft: #5a6f82;
  --rx-text-muted: #7c90a2;

  --rx-primary: #0a2245;
  --rx-primary-2: #12315f;
  --rx-accent: #5eead4;
  --rx-accent-2: #60a5fa;
  --rx-accent-dark: #0f766e;

  --rx-success: #22c55e;
  --rx-warning: #f59e0b;
  --rx-danger: #ef4444;

  --rx-shadow-sm: 0 8px 24px rgba(15, 23, 42, 0.06);
  --rx-shadow: 0 18px 48px rgba(15, 23, 42, 0.08);
  --rx-shadow-lg: 0 24px 70px rgba(8, 20, 45, 0.12);

  --rx-radius-xs: 8px;
  --rx-radius-sm: 12px;
  --rx-radius: 18px;
  --rx-radius-lg: 24px;

  --rx-transition: all 0.22s ease;
}

/* =========================================================
   BASE
   ========================================================= */

html,
body {
  background: var(--rx-bg) !important;
  color: var(--rx-text) !important;
  font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body,
p,
li,
td,
th,
input,
textarea,
select,
button {
  font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif !important;
}

body {
  font-size: 16px !important;
  line-height: 1.6 !important;
}

#wrapper {
  background: linear-gradient(180deg, #f6fafc 0%, #eef4f8 100%) !important;
  padding-top: 24px !important;
}

.container,
.container-fluid {
  max-width: 1240px;
}

/* =========================================================
   BLOCS GLOBAUX
   ========================================================= */

.page-content.page-cms,
.page-customer-account #content,
.page-authentication #content,
.page-registration #content,
.contact-form,
.block_newsletter,
#search_filters,
#search_filters_brands,
#search_filters_suppliers,
.block-categories,
.card,
.tabs,
.block-category,
.page-not-found,
.page-addresses .address,
.page-order-detail .box,
.cart-grid-right .card,
.cart-grid-body .card-block,
#main .page-content {
  background: var(--rx-surface) !important;
  border: 1px solid var(--rx-border) !important;
  border-radius: 20px !important;
  box-shadow: var(--rx-shadow-sm) !important;
}

.page-content.page-cms,
.block_newsletter,
.contact-form,
.block-categories,
#search_filters,
#search_filters_brands,
#search_filters_suppliers,
.page-addresses .address,
.page-order-detail .box,
.cart-grid-right .card,
.cart-grid-body .card-block,
.tabs,
.block-category,
#main .page-content {
  padding: 24px !important;
}

.page-content.page-cms {
  text-align: left !important;
}

.card-block {
  padding: 22px !important;
}

.cart-grid-body .card-block,
.cart-grid-right .card .cart-summary-subtotals-container,
body#checkout section.checkout-step .content {
  padding: 22px !important;
}

.card-header,
.card-footer {
  background: transparent !important;
  border-color: rgba(191, 212, 226, 0.6) !important;
}

.separator,
hr {
  border-color: rgba(191, 212, 226, 0.7) !important;
}

/* =========================================================
   TYPO
   ========================================================= */

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  font-family: Inter, "Segoe UI", Roboto, Arial, sans-serif !important;
  color: var(--rx-text) !important;
  text-transform: none !important;
  letter-spacing: -0.02em !important;
}

h1, .h1 {
  font-size: 44px !important;
  line-height: 1.05 !important;
  font-weight: 800 !important;
  margin-bottom: 16px !important;
}

h2, .h2 {
  font-size: 34px !important;
  line-height: 1.12 !important;
  font-weight: 800 !important;
  margin-bottom: 14px !important;
}

h3, .h3 {
  font-size: 24px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  margin-bottom: 12px !important;
}

h4, .h4 {
  font-size: 20px !important;
  line-height: 1.25 !important;
  font-weight: 700 !important;
}

p,
.page-content.page-cms p,
.page-content.page-cms ul,
.page-content.page-cms li {
  color: var(--rx-text-soft) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
}

small,
.text-muted,
label,
.form-control-comment,
.form-control-feedback,
caption {
  color: var(--rx-text-muted) !important;
}

strong,
b {
  color: var(--rx-text) !important;
}

/* =========================================================
   LIENS
   ========================================================= */

a {
  color: var(--rx-primary-2) !important;
  transition: var(--rx-transition) !important;
}

a:hover,
a:focus {
  color: var(--rx-accent-dark) !important;
  text-decoration: none !important;
}

/* =========================================================
   HEADER
   ========================================================= */

#header {
  background: rgba(255,255,255,0.92) !important;
  backdrop-filter: blur(12px);
  box-shadow: 0 12px 34px rgba(15, 23, 42, 0.08) !important;
  border-bottom: 1px solid rgba(191, 212, 226, 0.7) !important;
}

#header .header-nav {
  border-bottom: 1px solid rgba(191, 212, 226, 0.55) !important;
}

#header .header-top {
  padding: 16px 0 !important;
}

#header a,
#header #_desktop_logo h1,
#header .top-menu a[data-depth="0"] {
  color: var(--rx-text) !important;
}

#header .top-menu a[data-depth="0"] {
  font-size: 14px !important;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

#header .top-menu a[data-depth="0"]:hover,
#header a:hover {
  color: var(--rx-accent-dark) !important;
}

.top-menu .sub-menu,
.dropdown-menu {
  background: #ffffff !important;
  border: 1px solid var(--rx-border) !important;
  border-radius: 16px !important;
  box-shadow: var(--rx-shadow) !important;
}

.top-menu a:not([data-depth="0"]),
.dropdown-item {
  color: var(--rx-text-soft) !important;
}

.top-menu a:not([data-depth="0"]):hover,
.dropdown-item:hover {
  color: var(--rx-primary) !important;
  background: var(--rx-surface-2) !important;
}

#header .header-top > .container > .row:first-of-type {
  align-items: center;
}

#header .search-widget form input[type="text"] {
  padding-left: 44px !important;
  padding-right: 14px !important;
}

#header .header-nav .blockcart,
#header .header-nav .cart-preview {
  border-radius: 14px !important;
  overflow: hidden;
}

/* =========================================================
   ALIGNEMENT ICONES HEADER
   ========================================================= */

#header .header-nav .user-info a,
#header .header-nav #_desktop_user_info .user-info a,
#header .header-nav .blockcart a,
#header .header-nav .cart-preview a,
#header .header-nav .cart-preview .header,
#header .header-nav .cart-preview.active a {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px;
  line-height: 1 !important;
}

#header .header-nav .user-info a i,
#header .header-nav #_desktop_user_info .user-info a i,
#header .header-nav .user-info a .material-icons,
#header .header-nav #_desktop_user_info .user-info a .material-icons,
#header .header-nav .blockcart a i,
#header .header-nav .blockcart a .material-icons,
#header .header-nav .cart-preview a i,
#header .header-nav .cart-preview a .material-icons,
#header .header-nav .cart-preview .shopping-cart {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 20px;
  height: 20px;
  margin: 0 !important;
  line-height: 1 !important;
  font-size: 20px !important;
  vertical-align: middle !important;
  position: relative;
  top: -1px;
}

#header .header-nav .blockcart,
#header .header-nav .cart-preview,
#header .header-nav .user-info,
#header .header-nav #_desktop_user_info,
#header .header-nav .cart-preview .body,
#header .header-nav .blockcart .body,
#header .header-nav .user-info a span,
#header .header-nav .blockcart .header,
#header .header-nav .cart-preview .header {
  display: inline-flex !important;
  align-items: center !important;
}

#header .header-nav .user-info a span,
#header .header-nav .blockcart .header,
#header .header-nav .cart-preview .header {
  line-height: 1.1 !important;
}

#header .header-nav .blockcart {
  min-height: 52px;
  padding: 0 18px !important;
}

#header .header-nav .user-info a:before,
#header .header-nav .blockcart a:before,
#header .header-nav .cart-preview a:before {
  vertical-align: middle;
}

/* =========================================================
   BOUTONS
   ========================================================= */

.btn,
button,
input[type="submit"],
input[type="button"],
input[type="reset"] {
  border-radius: 14px !important;
  font-weight: 700 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  transition: var(--rx-transition) !important;
  box-shadow: none !important;
}

.btn-primary,
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active,
.btn-primary.active,
input[type="submit"].btn-primary,
input[type="button"].btn-primary {
  background: linear-gradient(135deg, var(--rx-primary) 0%, var(--rx-primary-2) 100%) !important;
  color: #ffffff !important;
  border: 1px solid transparent !important;
  box-shadow: 0 14px 34px rgba(10, 34, 69, 0.18) !important;
}

.btn-primary:hover,
.btn-primary:focus {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

.btn-secondary,
.btn-secondary:hover,
.btn-secondary:focus,
.btn-tertiary,
.btn-outline-primary {
  background: #ffffff !important;
  color: var(--rx-primary) !important;
  border: 1px solid var(--rx-border-strong) !important;
}

.btn-secondary:hover,
.btn-tertiary:hover,
.btn-outline-primary:hover {
  background: var(--rx-surface-2) !important;
  color: var(--rx-accent-dark) !important;
  border-color: var(--rx-accent) !important;
}

.btn-link {
  color: var(--rx-primary-2) !important;
}

.btn-link:hover {
  color: var(--rx-accent-dark) !important;
}

.btn-primary,
.btn-secondary {
  padding: 0.7rem 1.3rem !important;
}

/* =========================================================
   FORMULAIRES
   ========================================================= */

.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
textarea,
select,
.custom-select,
.form-control-select {
  background: #ffffff !important;
  border: 1px solid var(--rx-border-strong) !important;
  color: var(--rx-text) !important;
  border-radius: 14px !important;
  box-shadow: none !important;
}

.form-control,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="tel"],
input[type="number"],
select,
.custom-select,
.form-control-select {
  min-height: 46px !important;
}

textarea {
  min-height: 130px !important;
}

.form-control:focus,
input:focus,
textarea:focus,
select:focus,
.custom-select:focus {
  border-color: var(--rx-accent-2) !important;
  outline: none !important;
  box-shadow: 0 0 0 4px rgba(96, 165, 250, 0.12) !important;
  background: #ffffff !important;
}

::placeholder {
  color: #8da0b1 !important;
  opacity: 1 !important;
}

label,
.form-control-label {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--rx-text) !important;
  text-transform: none !important;
  text-align: left !important;
}

.block_newsletter form,
.search-widget form {
  padding: 0 !important;
}

/* =========================================================
   ALERTES / BADGES
   ========================================================= */

.alert {
  border-radius: 16px !important;
  border-width: 1px !important;
}

.alert-success {
  background: rgba(34, 197, 94, 0.08) !important;
  border-color: rgba(34, 197, 94, 0.2) !important;
  color: #166534 !important;
}

.alert-info {
  background: rgba(96, 165, 250, 0.08) !important;
  border-color: rgba(96, 165, 250, 0.2) !important;
  color: #1d4ed8 !important;
}

.alert-warning {
  background: rgba(245, 158, 11, 0.1) !important;
  border-color: rgba(245, 158, 11, 0.22) !important;
  color: #92400e !important;
}

.alert-danger {
  background: rgba(239, 68, 68, 0.08) !important;
  border-color: rgba(239, 68, 68, 0.2) !important;
  color: #991b1b !important;
}

.label,
.tag,
.badge,
.product-flags li.product-flag {
  border-radius: 999px !important;
  font-weight: 700 !important;
}

.tag-primary,
.product-flags li.product-flag,
.page-item.active .page-link {
  background: linear-gradient(135deg, var(--rx-primary) 0%, var(--rx-primary-2) 100%) !important;
  border-color: transparent !important;
  color: #fff !important;
}

.product-flags li.product-flag.discount,
.product-flags li.product-flag.discount-amount,
.product-flags li.product-flag.discount-percentage,
.has-discount .discount {
  background: linear-gradient(135deg, #fb923c 0%, #f97316 100%) !important;
}

/* =========================================================
   TABLEAUX / PAGINATION
   ========================================================= */

.table,
.table td,
.table th {
  border-color: rgba(191, 212, 226, 0.7) !important;
}

.table thead th,
.thead-default th {
  background: var(--rx-surface-2) !important;
  color: var(--rx-text) !important;
}

.table-striped tbody tr:nth-of-type(odd) {
  background: rgba(243, 248, 252, 0.85) !important;
}

.pagination .page-list,
.pagination .page-link {
  border-radius: 12px !important;
}

.page-link {
  border: 1px solid var(--rx-border) !important;
  color: var(--rx-primary) !important;
  background: #ffffff !important;
}

.page-link:hover {
  background: var(--rx-surface-2) !important;
  color: var(--rx-accent-dark) !important;
}

/* =========================================================
   SIDEBAR / FILTRES / CATEGORIES
   ========================================================= */

.block-categories .category-sub-menu,
#search_filters .facet {
  margin-top: 10px !important;
}

.block-categories .category-sub-menu li[data-depth="0"] > a,
#search_filters .facet .facet-label a {
  padding-top: 4px;
  padding-bottom: 4px;
  display: inline-block;
}

#search_filters .facet .facet-title,
.block-categories .h6,
#search_filters > .h6 {
  color: var(--rx-text) !important;
  font-weight: 800 !important;
  text-transform: none !important;
}

#search_filters .facet .facet-label a,
.block-categories a,
.facet-dropdown .select-title,
.products-sort-order .select-title {
  color: var(--rx-text-soft) !important;
}

.facet-dropdown,
.products-sort-order .dropdown-menu,
.brands-sort .dropdown-menu,
.suppliers-sort .dropdown-menu {
  background: #fff !important;
  border: 1px solid var(--rx-border) !important;
  border-radius: 14px !important;
  box-shadow: var(--rx-shadow-sm) !important;
}

.facet-dropdown .select-list:hover,
.products-sort-order .select-list:hover,
.brands-sort .select-list:hover,
.suppliers-sort .select-list:hover {
  background: var(--rx-primary) !important;
  color: #fff !important;
}

.products-selection,
#js-product-list-top,
#js-product-list {
  margin-bottom: 20px !important;
}

.products-sort-order .select-title,
.brands-sort .select-title,
.suppliers-sort .select-title {
  padding: 12px 16px !important;
  border-radius: 14px !important;
}

.block-category .block-category-inner {
  gap: 24px;
  align-items: center;
}

/* =========================================================
   PRODUITS
   ========================================================= */

.product-miniature .product {
  padding: 0 !important;
}

.product-miniature .thumbnail-container {
  background: #ffffff !important;
  overflow: hidden !important;
  transition: var(--rx-transition) !important;
  padding: 14px !important;
}

.product-miniature .thumbnail-container:hover {
  transform: translateY(-4px);
  box-shadow: var(--rx-shadow) !important;
}

.product-miniature .product-title {
  margin-top: 12px !important;
}

.product-miniature .product-title a {
  font-size: 15px !important;
  line-height: 1.5 !important;
  font-weight: 700 !important;
  color: var(--rx-text) !important;
  text-transform: none !important;
}

.product-miniature .product-title a:hover {
  color: var(--rx-accent-dark) !important;
}

.product-miniature .product-price-and-shipping,
.product-price,
.product-prices,
.product-line-grid-right .product-price {
  color: var(--rx-primary) !important;
  font-weight: 800 !important;
}

.product-miniature .product-price-and-shipping {
  margin-top: 8px !important;
}

.product-miniature .regular-price,
.product-discount .regular-price {
  color: var(--rx-text-muted) !important;
}

.product-miniature .product-description,
.product-miniature .variant-links,
.product-miniature .highlighted-informations {
  background: #ffffff !important;
}

.product-miniature .product-description {
  padding: 12px 8px 8px 8px !important;
}

.product-miniature .highlighted-informations {
  padding-top: 10px !important;
  padding-bottom: 10px !important;
}

.product-cover img,
.product-miniature .thumbnail-container .product-thumbnail img {
  border-radius: 14px !important;
}

/* =========================================================
   PAGE PRODUIT
   ========================================================= */

#product #content,
.product-information,
.product-pack,
.product-customization,
#block-reassurance {
  background: transparent !important;
}

.tabs .nav-tabs {
  border-bottom: 1px solid var(--rx-border) !important;
}

.tabs .nav-tabs .nav-link {
  color: var(--rx-text-soft) !important;
  border-bottom: 3px solid transparent !important;
  text-transform: none !important;
  font-weight: 700 !important;
}

.tabs .nav-tabs .nav-link.active,
.tabs .nav-tabs .nav-link:hover {
  color: var(--rx-primary) !important;
  border-bottom-color: var(--rx-accent) !important;
}

.product-actions .add-to-cart,
.product-actions .btn-primary {
  background: linear-gradient(135deg, var(--rx-primary) 0%, var(--rx-primary-2) 100%) !important;
  color: #fff !important;
  border-radius: 14px !important;
}

.product-quantity #quantity_wanted,
.bootstrap-touchspin input.form-control {
  border-radius: 12px !important;
  border: 1px solid var(--rx-border-strong) !important;
}

.bootstrap-touchspin .btn-touchspin {
  background: #fff !important;
  border: 1px solid var(--rx-border-strong) !important;
}

.bootstrap-touchspin .btn-touchspin:hover {
  background: var(--rx-surface-2) !important;
}

/* =========================================================
   PANIER / CHECKOUT
   ========================================================= */

.cart-summary-line,
.block-promo .promo-code,
body#checkout section.checkout-step,
body#checkout .cart-grid-right .card .cart-summary-subtotals-container,
body#checkout #order-summary-content .summary-selected-carrier {
  background: #ffffff !important;
  border-radius: 18px !important;
}

body#checkout section.checkout-step .step-title {
  color: var(--rx-text) !important;
  border-bottom-color: var(--rx-border) !important;
  text-transform: none !important;
  font-weight: 800 !important;
}

body#checkout section.checkout-step.-reachable.-current .step-number,
body#checkout section.checkout-step.-reachable.-complete .step-number {
  background: linear-gradient(135deg, var(--rx-primary) 0%, var(--rx-primary-2) 100%) !important;
  border-color: transparent !important;
  color: #fff !important;
}

.cart-summary-line .label,
.cart-summary-line .value {
  color: var(--rx-text) !important;
}

.block-promo .promo-input {
  border-radius: 12px !important;
  border: 1px solid var(--rx-border-strong) !important;
}

.block-promo .promo-code .alert-danger {
  border-radius: 14px !important;
}

/* =========================================================
   FOOTER
   ========================================================= */

#footer,
.footer-container {
  background: linear-gradient(180deg, #ffffff 0%, #f5f9fc 100%) !important;
  border-top: 1px solid rgba(191, 212, 226, 0.7) !important;
}

.footer-container {
  padding-top: 28px !important;
}

.footer-container .links ul,
.footer-container .wrapper,
.footer-container .row > div {
  padding-top: 0;
}

.footer-container .h3,
.footer-container .h4,
.block-contact-title,
.blockcms-title,
.myaccount-title,
.myaccount-title a {
  color: var(--rx-text) !important;
  text-transform: none !important;
  font-weight: 800 !important;
  margin-bottom: 14px !important;
}

.footer-container li {
  margin-bottom: 10px !important;
}

.footer-container li a,
.block-contact,
.contact-rich,
.contact-rich .block .data {
  color: var(--rx-text-soft) !important;
}

.footer-container li a:hover,
.account-list a:hover {
  color: var(--rx-accent-dark) !important;
}

.block-social ul li {
  background-color: #eaf2f7 !important;
  border-radius: 12px !important;
  transition: var(--rx-transition) !important;
}

.block-social ul li:hover {
  background-color: var(--rx-primary) !important;
}

/* =========================================================
   CARROUSEL / HOME
   ========================================================= */

.carousel,
#carousel,
.carousel .carousel-inner,
.carousel .carousel-item img {
  border-radius: 18px !important;
  overflow: hidden !important;
}

.carousel {
  box-shadow: var(--rx-shadow) !important;
}

.carousel .carousel-item .caption {
  text-shadow: none !important;
}

.carousel .carousel-item .caption .display-1 {
  color: #ffffff !important;
  text-transform: none !important;
  font-weight: 800 !important;
}

.page-index .page-content.page-cms,
.page-index #custom-text,
.page-index .block_newsletter,
.page-index .featured-products,
.page-index .products-section-title {
  position: relative;
}

.page-index .products-section-title {
  color: var(--rx-text) !important;
  font-weight: 800 !important;
  text-transform: none !important;
}

/* =========================================================
   RESEO HOME V3
   ========================================================= */

#custom-text {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 0 32px 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}

#custom-text > .reseo-home-v3 {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
}

.reseo-home-v3,
.reseo-home-v3 div,
.reseo-home-v3 section,
.reseo-home-v3 article,
.reseo-home-v3 span,
.reseo-home-v3 a,
.reseo-home-v3 p,
.reseo-home-v3 h1,
.reseo-home-v3 h2,
.reseo-home-v3 h3,
.reseo-home-v3 ul,
.reseo-home-v3 li {
  box-sizing: border-box;
}

.reseo-home-v3 .reseo-wrap {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto 26px auto;
  padding: 0 18px;
}

.reseo-home-v3 .reseo-hero-main {
  padding: 48px !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at top left, rgba(94, 234, 212, 0.18), transparent 28%),
    radial-gradient(circle at right center, rgba(96, 165, 250, 0.18), transparent 32%),
    linear-gradient(135deg, #07182d 0%, #0a2245 58%, #0d1730 100%) !important;
  box-shadow: 0 24px 70px rgba(8, 20, 45, 0.18) !important;
}

.reseo-home-v3 .reseo-kicker {
  display: inline-block;
  margin-bottom: 16px !important;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.1);
  color: #b8fff2 !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}

.reseo-home-v3 .reseo-hero-main h1 {
  margin: 0 0 16px !important;
  font-size: 64px !important;
  line-height: 0.98 !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  color: #ffffff !important;
  text-transform: none !important;
  max-width: 920px;
}

.reseo-home-v3 .reseo-lead {
  margin: 0 !important;
  max-width: 860px;
  font-size: 20px !important;
  line-height: 1.7 !important;
  color: rgba(255,255,255,0.82) !important;
}

.reseo-home-v3 .reseo-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 26px;
}

.reseo-home-v3 .reseo-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 54px;
  padding: 0 24px !important;
  border-radius: 14px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  text-transform: none !important;
  transition: all 0.2s ease;
}

.reseo-home-v3 .reseo-btn-main {
  background: linear-gradient(135deg, #5eead4 0%, #60a5fa 100%) !important;
  color: #08111f !important;
  box-shadow: 0 14px 34px rgba(96,165,250,0.25);
}

.reseo-home-v3 .reseo-btn-alt {
  background: rgba(255,255,255,0.08) !important;
  border: 1px solid rgba(255,255,255,0.14) !important;
  color: #ffffff !important;
}

.reseo-home-v3 .reseo-mini-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 28px;
}

.reseo-home-v3 .reseo-mini-card {
  padding: 20px 18px !important;
  border-radius: 18px !important;
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
}

.reseo-home-v3 .reseo-mini-card strong {
  display: block;
  margin-bottom: 6px !important;
  color: #ffffff !important;
  font-size: 20px !important;
  font-weight: 800 !important;
}

.reseo-home-v3 .reseo-mini-card span {
  color: rgba(255,255,255,0.76) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
}

.reseo-home-v3 .reseo-hero-intro {
  padding: 38px !important;
  border-radius: 28px !important;
  background: linear-gradient(180deg, #ffffff 0%, #f6f9ff 100%) !important;
  border: 1px solid rgba(10,34,69,0.08) !important;
  box-shadow: 0 24px 70px rgba(8, 20, 45, 0.08) !important;
}

.reseo-home-v3 .reseo-section-tag {
  display: inline-block;
  margin-bottom: 10px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #0f766e !important;
}

.reseo-home-v3 .reseo-hero-intro h2,
.reseo-home-v3 .reseo-heading h2,
.reseo-home-v3 .reseo-final-box h2 {
  margin: 0 0 12px !important;
  font-size: 40px !important;
  line-height: 1.08 !important;
  font-weight: 800 !important;
  color: #0f172a !important;
  text-transform: none !important;
}

.reseo-home-v3 .reseo-hero-intro p,
.reseo-home-v3 .reseo-final-box p {
  margin: 0 !important;
  max-width: 900px;
  font-size: 18px !important;
  line-height: 1.75 !important;
  color: #475569 !important;
}

.reseo-home-v3 .reseo-intro-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px 24px;
  margin: 24px 0 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.reseo-home-v3 .reseo-intro-list li {
  position: relative;
  padding-left: 22px !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  color: #0f172a !important;
}

.reseo-home-v3 .reseo-intro-list li:before {
  content: "";
  position: absolute;
  left: 0;
  top: 9px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: linear-gradient(135deg, #5eead4 0%, #60a5fa 100%);
}

.reseo-home-v3 .reseo-intro-divider {
  height: 1px;
  margin: 28px 0;
  background: rgba(15, 23, 42, 0.08);
}

.reseo-home-v3 .reseo-services-anchor {
  margin-top: 24px !important;
}

.reseo-home-v3 .reseo-block {
  margin-top: 4px;
}

.reseo-home-v3 .reseo-heading {
  margin-bottom: 22px;
}

.reseo-home-v3 .reseo-center {
  text-align: center;
}

.reseo-home-v3 .reseo-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.reseo-home-v3 .reseo-card,
.reseo-home-v3 .reseo-tool,
.reseo-home-v3 .reseo-step {
  background: #ffffff !important;
  border: 1px solid rgba(15, 23, 42, 0.08) !important;
  border-radius: 22px !important;
  box-shadow: 0 14px 40px rgba(15, 23, 42, 0.05) !important;
}

.reseo-home-v3 .reseo-card,
.reseo-home-v3 .reseo-tool {
  padding: 28px !important;
}

.reseo-home-v3 .reseo-card-num {
  width: 52px;
  height: 52px;
  margin-bottom: 14px !important;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #dffcf5 0%, #e6f0ff 100%);
  color: #0f766e !important;
  font-size: 16px !important;
  font-weight: 800 !important;
}

.reseo-home-v3 .reseo-card h3,
.reseo-home-v3 .reseo-tool h3,
.reseo-home-v3 .reseo-step h3 {
  margin: 0 0 10px !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  color: #0f172a !important;
  text-transform: none !important;
}

.reseo-home-v3 .reseo-card p,
.reseo-home-v3 .reseo-tool p,
.reseo-home-v3 .reseo-step p {
  margin: 0 !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  color: #475569 !important;
}

.reseo-home-v3 .reseo-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.reseo-home-v3 .reseo-step {
  padding: 24px !important;
}

.reseo-home-v3 .reseo-step span {
  display: inline-flex;
  width: 44px;
  height: 44px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  margin-bottom: 14px;
  background: linear-gradient(135deg, #5eead4 0%, #60a5fa 100%);
  color: #08111f !important;
  font-size: 18px !important;
  font-weight: 900 !important;
}

.reseo-home-v3 .reseo-final-box {
  padding: 40px 30px !important;
  border-radius: 28px !important;
  text-align: center;
  background: linear-gradient(135deg, #07182d 0%, #0b2244 100%) !important;
  box-shadow: 0 24px 70px rgba(8, 20, 45, 0.18) !important;
}

.reseo-home-v3 .reseo-final-box h2 {
  color: #ffffff !important;
}

.reseo-home-v3 .reseo-final-box p {
  color: rgba(255,255,255,0.8) !important;
  margin: 0 auto 24px auto !important;
}

.reseo-home-v3 .reseo-final-box .reseo-section-tag {
  color: #8af5e6 !important;
}

/* =========================================================
   RESPONSIVE
   ========================================================= */

@media (max-width: 1199px) {
  .reseo-home-v3 .reseo-grid-2,
  .reseo-home-v3 .reseo-steps {
    grid-template-columns: 1fr;
  }

  .reseo-home-v3 .reseo-mini-cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  h1, .h1 {
    font-size: 36px !important;
  }

  h2, .h2 {
    font-size: 28px !important;
  }

  h3, .h3 {
    font-size: 22px !important;
  }

  .page-content.page-cms {
    padding: 20px !important;
  }

  #wrapper {
    padding-top: 16px !important;
  }
}

@media (max-width: 767px) {
  body {
    font-size: 15px !important;
  }

  .page-content.page-cms,
  .card,
  .block_newsletter,
  #search_filters,
  .block-categories,
  .contact-form,
  .block-category,
  .card-block,
  .tabs,
  #main .page-content {
    padding: 18px !important;
    border-radius: 16px !important;
  }

  #custom-text {
    margin-bottom: 22px !important;
  }

  .reseo-home-v3 .reseo-wrap {
    padding: 0 12px;
    margin-bottom: 20px;
  }

  .reseo-home-v3 .reseo-hero-main,
  .reseo-home-v3 .reseo-hero-intro,
  .reseo-home-v3 .reseo-card,
  .reseo-home-v3 .reseo-tool,
  .reseo-home-v3 .reseo-step,
  .reseo-home-v3 .reseo-final-box {
    padding: 22px !important;
  }

  .reseo-home-v3 .reseo-hero-main h1 {
    font-size: 40px !important;
    line-height: 1.04 !important;
  }

  .reseo-home-v3 .reseo-hero-intro h2,
  .reseo-home-v3 .reseo-heading h2,
  .reseo-home-v3 .reseo-final-box h2 {
    font-size: 30px !important;
  }

  .reseo-home-v3 .reseo-intro-list {
    grid-template-columns: 1fr;
  }

  .reseo-home-v3 .reseo-actions {
    flex-direction: column;
  }

  .reseo-home-v3 .reseo-btn {
    width: 100%;
  }

  .btn,
  .btn-primary,
  .btn-secondary {
    width: auto;
    min-height: 46px !important;
  }

  #header .header-top {
    padding: 12px 0 !important;
  }
}


/* =========================================================
   RESEO - PATCH BLOCK CATEGORY IMAGE FULL WIDTH
   ========================================================= */

.block-category .block-category-inner {
  display: block !important;
}

.block-category .block-category-inner .category-cover {
  width: 100% !important;
  max-width: none !important;
  margin-top: 18px !important;
}

.block-category .block-category-inner .category-cover img {
  display: block !important;
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  border-radius: 16px !important;
  object-fit: cover;
}

.block-category .block-category-inner #category-description {
  width: 100% !important;
  max-width: none !important;
}

/* si tu veux garder un peu d’air entre titre/texte et image */
.block-category .block-category-inner {
  gap: 0 !important;
}
