:root{
  --cpi-blue:#2f63b8;
  --cpi-text:#333333;
  --cpi-light:#edf2f8;
}

.front-page{
  overflow:hidden;
  background:#fff;
}

.top-hero{
  position:relative;
  min-height:1040px;
  padding:0 20px;
  display:flex;
  align-items:center;
  justify-content:center;
  background-position:center center;
  background-size:cover;
  background-repeat:no-repeat;
  color:#fff;
  overflow:hidden;
}

.top-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(0,35,90,.14);
  z-index:0;
}

.top-hero::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:-250px;
  width:172%;
  height:680px;
  background:#fff;
  border-radius:50%;
  transform:translateX(-50%);
  z-index:1;
  pointer-events:none;
}

.top-hero__inner{
  position:relative;
  z-index:2;
  width:100%;
  max-width:1200px;
  margin:0 auto;
}

.top-hero__content{
  max-width:980px;
  margin:0 auto;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  min-height:760px;
  padding-bottom:200px;
}

.top-hero__title{
  margin:0 0 18px;
  font-size:44px;
  line-height:1.28;
  font-weight:700;
  letter-spacing:.02em;
  color:#fff;
  text-shadow:
    0 3px 12px rgba(0,0,0,.60),
    0 1px 3px rgba(0,0,0,.85);
  transform:translateY(-26px);
}

.top-hero__lead{
  margin:0;
  font-size:18px;
  line-height:1.9;
  font-weight:600;
  color:#fff;
  text-shadow:
    0 3px 12px rgba(0,0,0,.55),
    0 1px 3px rgba(0,0,0,.80);
  transform:translateY(-18px);
}

.top-hero__ellipse{
  position:absolute;
  left:50%;
  bottom:-640px;
  width:360%;
  height:1120px;
  background:#fff;
  border-radius:50%;
  transform:translateX(-50%);
  z-index:1;
  pointer-events:none;
}

.top-search-band{
  position:relative;
  z-index:5;
  margin-top:-188px;
  padding:0 20px 18px;
}

.top-search-band__inner{
  max-width:1200px;
  margin:0 auto;
  text-align:center;
}

.top-search{
  width:100%;
  max-width:720px;
  margin:0 auto;
}

.top-search .cpi-search-form{
  max-width:720px;
  margin:0 auto;
}

.top-search .cpi-search-form__keyword{
  min-height:68px;
  box-shadow:none;
}

.top-search .cpi-search-form__input{
  height:68px;
  font-size:16px;
}

.top-search .cpi-search-form__submit{
  flex-basis:108px;
  width:108px;
  min-width:108px;
  height:68px;
  border-radius:0 999px 999px 0;
}

.top-search .cpi-search-form__submit svg{
  width:26px;
  height:26px;
}

.top-search .cpi-search-form__suggestions{
  text-align:left;
}

.top-search .ajaxsearchlite,
.top-search .asl_w{
  width:100% !important;
  max-width:720px !important;
  margin:0 auto !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  filter:none !important;
}

.top-search .ajaxsearchlite .probox,
.top-search .asl_w .probox{
  min-height:68px !important;
  display:flex !important;
  align-items:center !important;
  background:#fff !important;
  border:2px solid var(--cpi-blue) !important;
  border-radius:999px !important;
  overflow:hidden !important;
  padding:0 !important;
  box-shadow:none !important;
  filter:none !important;
}

.top-search .ajaxsearchlite,
.top-search .ajaxsearchlite *,
.top-search .asl_w,
.top-search .asl_w *{
  box-shadow:none !important;
  filter:none !important;
}

.top-search .proinput{
  flex:1 1 auto !important;
  width:auto !important;
  padding:0 0 0 22px !important;
  margin:0 !important;
  background:transparent !important;
}

.top-search .proinput input{
  width:100% !important;
  height:68px !important;
  line-height:68px !important;
  font-size:16px !important;
  color:var(--cpi-text) !important;
  border:0 !important;
  background:transparent !important;
}

.top-search .proinput input::placeholder{
  color:#9aa6b2 !important;
  opacity:1 !important;
}

.top-search .proclose,
.top-search .proloading,
.top-search .prosettings{
  display:none !important;
}

.top-search .promagnifier{
  flex:0 0 108px !important;
  width:108px !important;
  min-width:108px !important;
  height:68px !important;
  margin:0 !important;
  padding:0 !important;
  background:var(--cpi-blue) !important;
  background-image:none !important;
  border:0 !important;
  border-radius:0 999px 999px 0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  opacity:1 !important;
}

.top-search .promagnifier:hover,
.top-search .promagnifier:focus,
.top-search .promagnifier:active{
  background:var(--cpi-blue) !important;
  opacity:.95 !important;
}

.top-search .promagnifier svg,
.top-search .promagnifier path,
.top-search .promagnifier .innericon,
.top-search .promagnifier .innericon *{
  fill:#fff !important;
  color:#fff !important;
  stroke:#fff !important;
}

.top-search .results{
  margin-top:8px !important;
  border-radius:14px !important;
  overflow:hidden !important;
}

.top-search__filters{
  display:grid;
  grid-template-columns:minmax(180px, 1.15fr) minmax(180px, 1fr) minmax(140px, 0.75fr);
  align-items:end;
  gap:14px;
  margin-top:14px;
  max-width:720px;
  margin-left:auto;
  margin-right:auto;
}

.top-search__filters .cpi-search-form__filter{
  width:100%;
  min-width:0;
}

.top-search__filters .cpi-search-form__filter-label{
  display:block;
  margin:0 0 6px;
  text-align:left;
}

.top-search .cpi-search-form__suggestion--download{
  padding:12px 10px;
}

.top-products{
  position:relative;
  z-index:4;
  padding:34px 20px 90px;
  background:#fff;
}

.top-products__inner{
  max-width:1200px;
  margin:0 auto;
}

.top-products__slider-wrap{
  position:relative;
}

.top-products-swiper{
  overflow:hidden;
}

.top-products__nav{
  position:absolute;
  top:34%;
  width:44px;
  height:44px;
  z-index:10;
  border:0;
  background:transparent;
  cursor:pointer;
}

.top-products__nav::before{
  content:"";
  position:absolute;
  left:50%;
  top:50%;
  width:18px;
  height:18px;
  border-top:2px solid #9ca7b6;
  border-right:2px solid #9ca7b6;
}

.top-products__nav--prev{
  left:-54px;
}

.top-products__nav--prev::before{
  transform:translate(-50%,-50%) rotate(-135deg);
}

.top-products__nav--next{
  right:-54px;
}

.top-products__nav--next::before{
  transform:translate(-50%,-50%) rotate(45deg);
}

.product-card__link{
  color:inherit;
  text-decoration:none;
}

.product-card__image{
  aspect-ratio:4 / 3;
  border:1px solid #e5e5e5;
  background:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
}

.product-card__image img{
  width:100%;
  height:100%;
  max-width:100%;
  max-height:100%;
  object-fit:contain;
  object-position:right center;
}

.product-card__image img.is-centered{
  object-fit:cover;
  object-position:center center;
}

.top-products .product-card__image img.is-centered{
  transform:scale(1.18);
  transform-origin:center center;
}

.product-card__title{
  margin:14px 0 0;
  font-size:17px;
  line-height:1.55;
  font-weight:500;
}

.top-products__empty{
  text-align:center;
  color:#666;
}

.top-topics{
  padding:82px 20px 90px;
  background:var(--cpi-light);
  text-align:center;
}

.top-topics__inner{
  max-width:900px;
  margin:0 auto;
}

.top-topics__title{
  margin:0 0 34px;
  font-size:42px;
  font-weight:500;
  color:#666;
  text-align:center;
}

.top-topics__list{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
}

.top-topics__item{
  width:100%;
  text-align:center;
}

.top-topics__item + .top-topics__item{
  margin-top:18px;
}

.top-topics__item a{
  display:inline-flex;
  gap:18px;
  align-items:center;
  justify-content:center;
  color:#666;
  text-decoration:none;
  font-size:16px;
  text-align:center;
}

.cta-contact{
  padding:88px 20px 108px;
  background:#fff;
  text-align:center;
}

.cta-contact__lead{
  margin:0 0 24px;
  font-size:32px;
  color:#666;
}

.cta-contact__button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:240px;
  height:68px;
  background:var(--cpi-blue);
  color:#fff;
  text-decoration:none;
  font-size:28px;
  font-weight:700;
}

@media (max-width:1024px){
  .top-hero{min-height:820px}
  .top-hero__content{min-height:560px;padding-bottom:140px}
  .top-hero__title{font-size:38px}
  .top-hero__lead{font-size:17px}
  .top-hero__ellipse{bottom:-430px;width:320%;height:760px}
  .top-search-band{margin-top:-128px}
  .top-search,
  .top-search .cpi-search-form{max-width:640px!important}
  .top-search .cpi-search-form__keyword{min-height:64px!important}
  .top-search .cpi-search-form__input{height:64px!important;font-size:16px!important}
  .top-search .cpi-search-form__submit{flex-basis:98px!important;width:98px!important;min-width:98px!important;height:64px!important}
  .top-products__nav--prev{left:-18px}
  .top-products__nav--next{right:-18px}
}

@media (max-width:767px){
  .top-hero{min-height:auto;padding:72px 16px 260px}
  .top-hero__content{min-height:auto;padding-bottom:52px}
  .top-hero__title{font-size:28px;line-height:1.4;margin-bottom:14px;transform:translateY(-6px)}
  .top-hero__lead{font-size:15px;line-height:1.8;transform:translateY(0)}
  .top-hero__ellipse{bottom:-210px;width:340%;height:380px}
  .top-search-band{margin-top:-78px;padding:0 16px 16px}
  .top-search,
  .top-search .cpi-search-form{max-width:100%!important}
  .top-search .cpi-search-form__keyword{min-height:58px!important}
  .top-search .cpi-search-form__input{height:54px!important;font-size:16px!important}
  .top-search .cpi-search-form__submit{flex-basis:82px!important;width:82px!important;min-width:82px!important;height:58px!important}
  .top-search__filters{gap:10px;margin-top:12px}
  .top-products{padding:28px 16px 70px}
  .top-products__nav{display:none}
  .top-topics{padding:60px 16px 70px}
  .top-topics__title{font-size:34px}
  .top-topics__item a{flex-direction:column;gap:6px}
  .cta-contact{padding:64px 16px 78px}
  .cta-contact__lead{font-size:24px}
  .cta-contact__button{min-width:220px;height:58px;font-size:22px}
}
/* ========================================
   TOPICS section
======================================== */
.topics-section{
  padding:100px 0 120px;
  background:#edf2f8;
}

.topics-section .inner,
.topics-section__inner{
  max-width:1200px;
  margin:0 auto;
  padding:0 20px;
}

.topics-section__title{
  margin:0 0 56px;
  text-align:center;
  font-size:clamp(42px,5vw,72px);
  line-height:1.2;
  font-weight:500;
  color:#555;
}

.topics-list{
  list-style:none;
  max-width:980px;
  margin:0 auto;
  padding:0;
}

.topics-list__item{
  margin:0;
  padding:0;
  border-bottom:1px solid #d6deea;
}

.topics-list__link{
  display:grid;
  grid-template-columns:140px 1fr;
  gap:24px;
  align-items:start;
  padding:22px 0;
  color:#444;
}

.topics-list__date{
  display:block;
  color:#666;
  font-size:28px;
  line-height:1.2;
  font-weight:500;
  white-space:nowrap;
  font-variant-numeric:tabular-nums;
}

.topics-list__title{
  display:block;
  color:#555;
  font-size:28px;
  line-height:1.6;
  font-weight:500;
  text-align:left;
  word-break:break-word;
}

.topics-list__link:hover .topics-list__title{
  color:var(--cpi-blue);
}

@media (max-width:767px){
  .topics-section{
    padding:60px 0 80px;
  }

  .topics-section__title{
    margin-bottom:32px;
  }

  .topics-list__link{
    grid-template-columns:1fr;
    gap:10px;
    padding:16px 0;
  }

  .topics-list__date{
    font-size:16px;
  }

  .topics-list__title{
    font-size:18px;
    line-height:1.5;
  }
}


/* =========================================================
   Hero curve / topics tuning
   ========================================================= */
.top-hero__ellipse{
  display:none;
}

.top-hero__curve{
  position:absolute;
  inset:auto 0 0;
  height:82px;
  z-index:2;
  display:block;
  background:#fff;
  pointer-events:none;
}

.top-hero__content{
  max-width:1200px;
  min-height:680px;
  padding-bottom:215px;
}

.top-hero__title{
  white-space:nowrap;
  font-size:clamp(34px, 4.2vw, 64px);
  transform:none;
  margin:0 0 28px;
}

.top-hero__lead{
  transform:none;
  font-size:clamp(18px, 1.45vw, 24px);
  line-height:1.8;
  max-width:1040px;
}

.top-search-band{
  margin-top:-280px;
}

.top-search__filters select{
  width:100%;
  min-width:0;
  height:44px;
  padding:0 42px 0 14px;
  font-size:16px;
}

.topics-section__title{
  margin:0 0 28px;
  font-size:32px;
}

.topics-list{
  max-width:760px;
}

.topics-list__link{
  grid-template-columns:120px 1fr;
  gap:18px;
  align-items:baseline;
  padding:16px 0;
}

.topics-list__date{
  font-size:14px;
  line-height:1.7;
  font-weight:600;
}

.topics-list__title{
  font-size:16px;
  line-height:1.7;
  font-weight:500;
}

@media (max-width:1024px){
  .top-hero__content{
    min-height:600px;
    padding-bottom:168px;
  }

  .top-search-band{
    margin-top:-228px;
  }

  .top-hero::after{
    bottom:-198px;
    width:188%;
    height:540px;
  }

  .top-hero__curve{
    height:64px;
  }
  .top-hero__title{
    white-space:normal;
    margin:0 0 22px;
  }
  .top-hero__lead{
    font-size:18px;
  }

  .top-search__filters{
    max-width:680px;
    gap:12px;
  }
  .top-search__filters select{font-size:15px}
}

@media (max-width:767px){
  .top-hero__content{
    min-height:auto;
    padding-bottom:122px;
  }

  .top-search-band{
    margin-top:-132px;
  }

  .top-hero::after{
    bottom:-118px;
    width:220%;
    height:330px;
  }

  .top-hero__curve{
    height:40px;
  }
  .top-hero__title{
    white-space:normal;
    margin:0 0 16px;
  }
  .top-hero__lead{
    font-size:16px;
    line-height:1.75;
  }

  .top-search__filters{
    grid-template-columns:1fr;
    gap:10px;
    max-width:100%;
  }
  .top-search__filters .cpi-search-form__filter{
    width:100%;
  }
  .top-search__filters select{
    width:100%;
    min-width:0;
    height:40px;
    font-size:14px;
  }
  .topics-section__title{
    font-size:28px;
  }
  .topics-list__link{
    grid-template-columns:1fr;
    gap:4px;
  }
}
