/* =========================================
   FITVIBE CONNECT – Marketing Page (scoped)
   depends on partner-marketing-page.css
   ========================================= */
main.main{
  min-height: 400px;
  /* background: var(--main-white-pure-color); */
  background: var(--main-white-color);
  /* min-height: calc(100vh - 100px - 0px); */
  transition: 0.3s linear 0s;
}

.connect-page{ background: var(--main-white-color); }

/* HERO tweaks (map card look) */
.connect-hero-section .partners-hero-layout{
  align-items: stretch;
}

.connect-hero-image-wrapper .partners-hero-image{
  position: relative;
  overflow: hidden;
  border-radius: 49px;
  background: #00000008;
  box-shadow: 0 12px 26px #0b122014;
  min-height: 420px;
}

.connect-hero-map{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  /* transform: scale(1.01); */
  border-radius: 49px;
}

.connect-hero-overlay{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 22px;
  /* background: #0b1220b3; */
  background: unset;
}

.connect-hero-brand{
  text-align: center;
  color: #ffffff;
  max-width: 600px;
}

.connect-hero-brand__logo{
  display: inline-flex;
  gap: 10px;
  margin-bottom: 25px;
}

.connect-hero-brand__fit{
  font-size: 56px;
  font-weight: var(--fw-xbold);
  line-height: 1;
}

.connect-hero-brand__connect{
  font-size: 28px;
  font-weight: var(--fw-semibold);
  opacity: 0.95;
  line-height: 1;
}

.connect-hero-brand__text{
  margin: 0;
  font-size: 30px;
  line-height: 1.45;
  color: #ffffffd9;
  font-weight: 600;
}

/* Title underline vibe */
.connect-accent{ color: var(--main-primary-color); }
.connect-accent-2{ font-weight: 700; }

/* 3 mini cards section */
.connect-benefits-mini{
  padding: 30px 0 0px;
  /* margin-bottom: 100px; */
}

.connect-benefits-mini__title{
  margin: 0 0 18px;
  font-size: 34px;
  /* font-weight: var(--fw-semibold); */
  /* font-weight: 200; */
  /* color: var(--main-blueblack-color); */
  text-align: center;
  color: #2D2D2D;
  font-weight: 600;
  margin: 0 0 30px;
}

.connect-mini-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-bottom: 90px;
}

.connect-mini-card{
  /* background: var(--main-white-pure-color); */
  border-radius: 24px;
  padding: 25px 25px 20px;
  /* box-shadow: 0 10px 24px #0b12200f; */
  border: 1px solid var(--Primary-Greyser, #A3A3A3);
}

.connect-mini-ill{
  /* width: 58px; */
  /* height: 58px; */
  /* border-radius: 14px; */
  /* background: #325de60f; */
  display: grid;
  place-items: center;
  margin-bottom: 20px;
  overflow: hidden;
  justify-content: flex-start;
}

.connect-mini-ill .fv-plus-img{
  /* width: 40px; */
  /* height: 40px; */
  /* object-fit: contain; */
  /* display: block; */
}

.connect-mini-title{
  margin: 0 0 6px;
  font-size: 24px;
  font-weight: var(--fw-semibold);
  color: #0B3558;
  margin-bottom: 15px;
  font-weight: 500;
}

.connect-mini-text{
  margin: 0;
  font-size: 14px;
  /* line-height: 1.5; */
  color: #5F6E95;
  margin-bottom: 20px;
  font-weight: 600;
}

/* Risk section */
.connect-risk{
  padding: 26px 0 40px;
  background: linear-gradient(to bottom, #f2f2f2 0%, #f2f2f2 20%, #B6CCF1 100%);
  border-radius: 0px 0px 70px 70px;
}

.connect-risk-grid{
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: 100px;
  align-items: center;
  margin-bottom: 75px;
}

.connect-risk-visual{
  border-radius: 22px;
  overflow: hidden;
  /* box-shadow: 0 12px 26px #0b122012; */
}

.connect-risk-img{
  width: 100%;
  height: auto;
  display: block;
}

.connect-risk-title{
  margin: 0 0 30px;
  font-size: 34px;
  font-weight: var(--fw-semibold);
  color: #0B3558;
  line-height: 1.15;
  font-weight: 600;
}

.connect-risk-text{
  margin: 0 0 10px;
  font-size: 16px;
  line-height: 1.6;
  color: #5F6E95;
  font-weight: var(--fw-xthin);
  font-weight: 400;
}

/* =========================================
   CONNECT – Dashboard section (text left / image right)
   ========================================= */
.connect-dashboard{
  padding: 42px 0 18px;
  background: var(--main-white-color);
}

.connect-dashboard-grid{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.3fr);
  grid-template-columns: auto 600px;
  align-items: center;
  margin-top: 100px;
  margin-bottom: 100px;
  grid-gap: 50px;
}

.connect-dashboard-title{
  margin: 0 0 30px;
  font-size: 34px;
  font-weight: 600;
  color: #0B3558;
  letter-spacing: -0.02em;
  line-height: 1.12;
  font-weight: 600;
}

.connect-dashboard-list{
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.connect-dashboard-list li{
  font-size: 16px;
  line-height: 1.55;
  color: #5F6E95;
  font-weight: 400;
}

.connect-dashboard-list__label{
  color: #5F6E95;
  font-weight: var(--fw-semibold);
}

.connect-dashboard-visual{
  display: grid;
  place-items: center;
}

.connect-dashboard-img{height: auto;width: 100%;}

/* =========================================
   CONNECT – FitCoins Swiper section
   ========================================= */
.connect-fitcoins{
  padding: 28px 0 54px;
  background: var(--main-white-color);
  background: var(--main-white-pure-color);
  border-radius: 70px;
}

.connect-fitcoins-title{
  margin: 0 0 16px;
  margin: 0 0 30px;
  font-size: 34px;
  letter-spacing: -0.02em;
  font-weight: 200;
  color: var(--main-blueblack-color);
  text-align: center;
  color: #2D2D2D;
  margin-top: 35px;
  margin-bottom: 35px;
  font-weight: 600;
}

.connect-fitcoins-card{
  /* background: var(--main-white-color); */
  border: 1px solid var(--Primary-Greyser, #A3A3A3);
  border-radius: 18px;
  /* box-shadow: 0 14px 30px #0b122012; */
  padding: 18px;
}

.connect-fitcoins-slide{
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 0.95fr);
  gap: 18px;
  align-items: center;
  min-height: 220px;
}

.connect-fitcoins-left{
  /* display: flex; */
  display: grid;
  gap: 14px;
  place-content: end;
  margin-left: 65px;
}

.connect-fitcoins-step{
  width: 56px;
  height: 56px;
  border-radius: 999px;
  background-color: #e4ebff;
  color: #2f5cff;
  display: grid;
  place-items: center;
  font-weight: 600;
  font-size: 30px;
  flex: 0 0 auto;
}

.connect-fitcoins-text{ min-width: 0; }

.connect-fitcoins-subtitle{
  margin: 2px 0 6px;
  font-size: 24px;
  font-weight: var(--fw-semibold);
  color: var(--main-blueblack-color);
}

.connect-fitcoins-desc{
  margin: 0 0 14px;
  font-size: 13px;
  line-height: 1.55;
  color: var(--main-darkgray-color);
  max-width: 520px;
  color: #5F6E95;
  font-weight: 600;
}

.connect-fitcoins-right{
  display: grid;
  place-items: center;
}

.connect-fitcoins-ill{
  width: 100%;
  max-width: 260px;
  height: auto;
  display: block;
}

.connect-fitcoins-ill.is-empty{
  width: 260px;
  height: 180px;
  border-radius: 14px;
  background: #0b122008;
  border: 1px dashed #0b12201a;
}

/* Swiper pagination as 3 small bars (bottom-left) */
.connect-fitcoins-pagination{
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
  padding-left: 70px; /* 56px κύκλος + gap */
  margin-top: 35px;
}

.connect-fitcoins-pagination .swiper-pagination-bullet{
  width: 44px;
  height: 6px;
  border-radius: 999px;
  background: #0b122014;
  opacity: 1;
  margin: 0 !important;
}

.connect-fitcoins-pagination .swiper-pagination-bullet-active{
  background: var(--main-primary-color);
}

/* =========================
   Connect mini cards — MOBILE SWIPER ONLY
   ========================= */
/* default: κρυφό */
.connect-mini-swiper{ display: none; }

/* =========================
   Pagination bars (ίδιο style με πριν)
   ========================= */
.connect-mini-pagination{
  position: static;
  margin-top: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}

.connect-mini-pagination .swiper-pagination-bullet{
  width: 42px;
  height: 8px;
  border-radius: 999px;
  background: #D9D9D9;
  opacity: 1;
  margin: 0;
}

.connect-mini-pagination .swiper-pagination-bullet-active{
  background: var(--main-primary-color);
}

/* =========================
   Responsive
   ========================= */
@media (max-width: 1350px){
  .connect-dashboard-grid{
    grid-template-columns: 350px auto;
  }
}

@media (max-width: 1050px){
  .connect-dashboard-img{
    width: 100%;
    height: auto;
  }

  .connect-risk-img{
    width: 100%;
    height: auto;
    display: block;
    width: auto;
  }
}

@media (max-width: 980px){
  .connect-risk-grid{ grid-template-columns: 1fr; }
  .connect-hero-brand__fit{ font-size: 48px; }
  .connect-hero-brand__connect{ font-size: 24px; }

  /* Mini cards: 2 columns on tablet */
  .connect-mini-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }

  /* Dashboard: stack */
  .connect-dashboard-grid{
    grid-template-columns: 1fr;
    gap: 50px;
  }
}

/* ===== Connect hero: force clean stacking on tablet & mobile ===== */
@media (max-width: 920px){
  .connect-hero-layout{
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .connect-hero-image-wrapper{ order: 1; }
  .partners-hero-form-wrapper{ order: 2; }
}

/* ===== Map height tuning ===== */
@media (max-width: 768px){
  .connect-hero-image-wrapper .partners-hero-image{
    min-height: 340px;
    border-radius: 22px;
  }
   .connect-risk-img{
    width: 100%;
    height: auto;
    display: block;
    width: auto;
  }
  .connect-risk-grid {
    display: grid;
    gap: 75px;
    align-items: center;
    margin-bottom: 10px;
}
  .connect-dashboard-title {
    margin: 0 0 14px;
    font-size: 24px;
    font-weight: 600;
    color: #0B3558;
    letter-spacing: -0.02em;
    line-height: 1.12;
    margin: 0 0 30px;
}
  .connect-mini-pagination .swiper-pagination-bullet {
    width: 42px;
    height: 6px;
  }
  .connect-risk-title {
      margin: 0 0 30px;
      font-size: 24px;
      font-weight: var(--fw-semibold);
      color: #0B3558;
      line-height: 1.15;
  }
  .connect-dashboard-list li {
    font-size: 16px;
    line-height: 1.55;
    color: #5F6E95;
    font-weight: 400;
}
  .connect-hero-brand__fit{ font-size: 44px; }
  .connect-hero-brand__connect{ font-size: 22px; }
  .connect-hero-brand__text{font-size: 24px;}

  img.connect-logo{
    width: 100%;
    height: 90px;
  }

  .connect-benefits-mini__title{
    margin: 0 0 18px;
    font-size: 24px;
    /* font-weight: var(--fw-semibold); */
    /* font-weight: 200; */
    /* color: var(--main-blueblack-color); */
    text-align: center;
    /* margin-top: 60px; */
  }

  /* hero layout γίνεται column */
  .connect-hero-layout{
    display: flex;
    flex-direction: column-reverse;
  }

  /* image πρώτα */
  .connect-hero-image-wrapper{
    order: 1;
    margin-bottom: 52px;
  }

  .connect-hero-layout .partners-hero-form-wrapper{
    order: 3;
  }

  /* FitCoins responsive */
  .connect-fitcoins-title{font-size: 24px;}

  .connect-fitcoins-card{ padding: 14px; }

  .connect-fitcoins-slide{
    grid-template-columns: 1fr;
    gap: 14px;
    min-height: auto;
  }

  .connect-fitcoins-right{order: 2;display: grid;justify-content: left;padding-left: 30px;}
  .connect-fitcoins-left{order: 1;margin-left: 35px;display: grid;justify-content: left;}

  .connect-fitcoins-ill,
  .connect-fitcoins-ill.is-empty{
    max-width: 240px;
  }

  img.fv-plus-img.connect-dashboard-img{
    width: 100%;
    height: auto;
  }

  .connect-dashboard{
    padding: 0px 0 0px;
    background: var(--main-white-color);
  }

  .connect-dashboard-grid{
    display: grid;
    /* grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); */
    align-items: center;
    margin-top: 100px;
    margin-bottom: 65px;
    margin-top: 50px;
  }

  .connect-benefits-mini{
    padding: 0px 0 20px;
    margin-bottom: 0px;
  }

  .connect-risk{
    padding: 26px 0 40px;
    background: linear-gradient(to bottom, #f2f2f2 0%, #f2f2f2 20%, #B6CCF1 100%);
    border-radius: 0px 0px 30px 30px;
  }

  /* mobile: κρύβουμε grid, δείχνουμε swiper */
  .connect-mini-grid{ display: none; }
  .connect-mini-swiper{
    display: block;
    margin-bottom: 50px;
  }

  .connect-mini-swiper .swiper-slide{
    display: flex;
    justify-content: center;
    padding: 8px 2px 18px;
  }

  /* το card σου έχει fixed width, το κεντράρουμε */
  .connect-mini-swiper .connect-mini-card{
    width: 300px; /* ίδιο με το δικό σου */
  }
    .connect-fitcoins-pagination .swiper-pagination-bullet{
    width: 44px;
    height: 6px;
   
    opacity: 1;
    margin: 0 !important;
  }
}

@media (max-width: 640px){
  .connect-mini-grid{ grid-template-columns: 1fr; }
   .connect-risk-img {
        width: 100%;
        height: auto;
        display: block;
        width: 100%;
    }
  .connect-fitcoins {
    padding: 28px 0 54px;
    background: var(--main-white-color);
    background: var(--main-white-pure-color);
    border-radius: 30px;
}
}

@media (max-width: 420px){
  .connect-hero-image-wrapper .partners-hero-image{
    min-height: 300px;
    border-radius: 49px;
  }
 
}
