
:root{
  --cri-infra-accent:#f6ede8;
  --cri-infra-soft:#f6f8f7;
  --cri-infra-border:rgba(14,53,49,.10);
  --cri-infra-text:#4d635f;
}

.cri-infra-breadcrumb{
  min-height:520px;
  background-image:linear-gradient(180deg, rgba(14,53,49,.78) 0%, rgba(14,53,49,.9) 100%), url("https://orientalinvest.ma/wp-content/uploads/2020/09/voieexpress1.png");
  background-position:center;
  background-size:cover;
  background-repeat:no-repeat;
}
.cri-infra-breadcrumb .breadcrumb__overlay::after,
.cri-infra-breadcrumb.breadcrumb__overlay::after{
  background:transparent;
}
.cri-infra-breadcrumb__content{padding-top:18px;}
.cri-infra-breadcrumb__eyebrow{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 18px;
  border-radius:999px;
  color:#fff;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.14);
  font-size:14px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  margin-bottom:24px;
}
.cri-infra-breadcrumb__text{
  max-width:840px;
  margin:18px auto 20px;
  color:rgba(255,255,255,.82);
  font-size:18px;
  line-height:1.85;
}

.cri-infra-overview{
  position:relative;
  margin-top:-82px;
  z-index:5;
}
.cri-infra-overview__panel{
  background:linear-gradient(135deg, var(--tp-theme-2) 0%, #174742 100%);
  border-radius:30px;
  padding:32px;
  box-shadow:0 26px 70px rgba(14,53,49,.16);
}
.cri-infra-overview__grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:18px;
}
.cri-infra-overview__item{
  min-height:185px;
  border-radius:24px;
  padding:24px 20px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.09);
  color:#fff;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
}
.cri-infra-overview__icon{
  width:58px;
  height:58px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  background:rgba(230,120,80,.14);
  color:var(--tp-theme-1);
  font-size:22px;
  margin-bottom:18px;
}
.cri-infra-overview__item strong{
  font-size:42px;
  line-height:1;
  color:#fff;
  margin-bottom:10px;
}
.cri-infra-overview__item p{
  margin:0;
  color:rgba(255,255,255,.84);
  line-height:1.75;
}

.cri-infra-section--soft{background:var(--cri-infra-soft);}
.cri-infra-heading .tp-section-title{
  font-size:42px;
  line-height:1.2;
  font-weight:700;
}
.cri-infra-lead{
  color:var(--cri-infra-text);
  line-height:1.85;
  font-size:17px;
  margin:18px 0 0;
}
.cri-infra-lead--center{
  max-width:860px;
  margin-left:auto;
  margin-right:auto;
}
.cri-infra-actions{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
  margin:0 0 32px;
}

.cri-infra-quick-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px;
}
.cri-infra-quick-card,
.cri-infra-project-card,
.cri-infra-strategy-card,
.cri-infra-cta{
  border-radius:30px;
  background:#fff;
  border:1px solid var(--cri-infra-border);
  box-shadow:0 18px 50px rgba(14,53,49,.06);
}
.cri-infra-quick-card{
  padding:22px 20px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.cri-infra-quick-card__icon{
  width:52px;
  height:52px;
  border-radius:16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--cri-infra-accent);
  color:var(--tp-theme-1);
  font-size:19px;
  flex:0 0 auto;
}
.cri-infra-quick-card h4{
  font-size:18px;
  color:var(--tp-theme-2);
  margin:4px 0 8px;
}
.cri-infra-quick-card p{
  margin:0;
  color:var(--cri-infra-text);
  line-height:1.75;
}

.cri-infra-collage-wrap{
  position:relative;
  padding-left:28px;
}
.cri-infra-collage{
  display:grid;
  grid-template-columns:1.18fr .82fr;
  grid-template-rows:260px 190px;
  gap:18px;
}
.cri-infra-collage__item{
  position:relative;
  overflow:hidden;
  border-radius:28px;
  box-shadow:0 28px 60px rgba(8, 30, 52, .18);
  min-width:0;
}
.cri-infra-collage__item--large{grid-row:1 / 3;}
.cri-infra-collage__item::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(4,16,30,0) 35%, rgba(4,16,30,.6) 100%);
  z-index:1;
}
.cri-infra-collage__item img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .7s ease;
}
.cri-infra-collage__item:hover img{transform:scale(1.07);}
.cri-infra-collage__caption{
  position:absolute;
  left:22px;
  right:22px;
  bottom:18px;
  z-index:2;
  color:#fff;
}
.cri-infra-collage__caption span{
  display:inline-block;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:8px;
  color:rgba(255,255,255,.85);
}
.cri-infra-collage__caption h3{
  font-size:21px;
  line-height:1.3;
  color:#fff;
  margin:0;
}
.cri-infra-floating-card{
  position:absolute;
  left:0;
  bottom:18px;
  max-width:280px;
  padding:22px 24px;
  border-radius:24px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(255,255,255,.55);
  box-shadow:0 24px 50px rgba(8,30,52,.12);
  backdrop-filter:blur(10px);
}
.cri-infra-floating-card__top{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:14px;
  color:var(--tp-theme-2);
  font-weight:700;
}
.cri-infra-floating-card__icon{
  width:42px;
  height:42px;
  border-radius:14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:var(--cri-infra-accent);
  color:var(--tp-theme-1);
}
.cri-infra-floating-card h4{
  font-size:28px;
  line-height:1.2;
  margin-bottom:8px;
  color:var(--tp-theme-2);
}
.cri-infra-floating-card p{
  margin:0;
  color:var(--cri-infra-text);
  line-height:1.7;
}

.cri-infra-filter-bar{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:12px;
  margin:0 0 42px;
}
.cri-infra-filter-btn{
  border:none;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:12px 20px;
  border-radius:999px;
  background:#fff;
  color:var(--tp-theme-2);
  border:1px solid var(--cri-infra-border);
  font-weight:700;
  transition:all .25s ease;
}
.cri-infra-filter-btn:hover,
.cri-infra-filter-btn.is-active{
  background:var(--tp-theme-1);
  border-color:var(--tp-theme-1);
  color:#fff;
}

.cri-infra-project-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:24px;
}
.cri-infra-project-card{
  overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease, opacity .3s ease;
}
.cri-infra-project-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 60px rgba(14,53,49,.1);
}
.cri-infra-project-card.is-hidden{display:none !important;}
.cri-infra-project-card__thumb{
  position:relative;
  overflow:hidden;
  height:240px;
  background:linear-gradient(180deg,#f8f7f4 0%, #f3f0eb 100%);
}
.cri-infra-project-card__thumb::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(9,22,38,0) 0%, rgba(9,22,38,.45) 100%);
}
.cri-infra-project-card__thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transition:transform .45s ease;
}
.cri-infra-project-card:hover .cri-infra-project-card__thumb img{
  transform:scale(1.05);
}
.cri-infra-project-card__tag{
  position:absolute;
  top:18px;
  left:18px;
  z-index:2;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:9px 14px;
  font-size:12px;
  font-weight:800;
  border-radius:999px;
  text-transform:uppercase;
  letter-spacing:.08em;
  background:rgba(255,255,255,.94);
  color:var(--tp-theme-2);
}
.cri-infra-project-card__body{padding:26px 24px 24px;}
.cri-infra-project-card__meta{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:16px;
}
.cri-infra-project-card__meta span{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding:8px 12px;
  border-radius:999px;
  background:var(--cri-infra-soft);
  color:var(--tp-theme-2);
  font-size:13px;
  font-weight:700;
}
.cri-infra-project-card__body h3{
  font-size:24px;
  line-height:1.35;
  margin-bottom:14px;
  color:var(--tp-theme-2);
}
.cri-infra-project-card__body p{
  margin-bottom:16px;
  color:var(--cri-infra-text);
  line-height:1.8;
}
.cri-infra-project-card__body ul{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.cri-infra-project-card__body li{
  position:relative;
  padding-left:22px;
  color:var(--tp-theme-2);
  line-height:1.7;
}
.cri-infra-project-card__body li::before{
  content:'•';
  position:absolute;
  left:0;
  top:0;
  color:var(--tp-theme-1);
  font-size:20px;
  line-height:1;
}

.cri-infra-strategy{
  background:linear-gradient(135deg, var(--tp-theme-2), #174742 58%, #256f69 100%);
  border-radius:34px;
  overflow:hidden;
  position:relative;
  color:#fff;
  padding:55px;
  box-shadow:0 30px 70px rgba(6,26,52,.24);
}
.cri-infra-strategy::before,
.cri-infra-strategy::after{
  content:'';
  position:absolute;
  border-radius:50%;
  background:rgba(255,255,255,.06);
}
.cri-infra-strategy::before{right:-80px; top:-80px; width:260px; height:260px;}
.cri-infra-strategy::after{left:-80px; bottom:-100px; width:260px; height:260px;}
.cri-infra-strategy > *{position:relative; z-index:1;}
.cri-infra-strategy .tp-section-subtitle-2,
.cri-infra-strategy .tp-section-title,
.cri-infra-strategy__lead,
.cri-infra-strategy h3,
.cri-infra-strategy p{color:#fff;}
.cri-infra-strategy__lead{
  max-width:880px;
  color:rgba(255,255,255,.85);
}
.cri-infra-strategy__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  margin-top:34px;
}
.cri-infra-strategy-card{
  padding:26px 24px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(255,255,255,.16);
  border-radius:24px;
  backdrop-filter:blur(6px);
  box-shadow:none;
}
.cri-infra-strategy-card__icon{
  width:56px;
  height:56px;
  border-radius:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,.14);
  margin-bottom:18px;
  font-size:22px;
  color:#fff;
}
.cri-infra-strategy-card h3{
  font-size:22px;
  margin-bottom:12px;
}
.cri-infra-strategy-card p{
  margin:0;
  color:rgba(255,255,255,.88);
  line-height:1.75;
}

.cri-infra-cta{
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:28px;
  align-items:center;
  padding:40px;
}
.cri-infra-cta__actions{
  display:flex;
  gap:16px;
  justify-content:flex-end;
  flex-wrap:wrap;
}

/* anti-conflict fixes */
.cri-infrastructure-page .cri-infra-quick-card,
.cri-infrastructure-page .cri-infra-project-card,
.cri-infrastructure-page .cri-infra-strategy-card,
.cri-infrastructure-page .cri-infra-cta,
.cri-infrastructure-page .cri-infra-collage__item{
  min-width:0;
}
.cri-infrastructure-page .cri-infra-collage__item img,
.cri-infrastructure-page .cri-infra-project-card__thumb img{
  max-width:100%;
}
.cri-infrastructure-page .cri-infra-quick-card > *,
.cri-infrastructure-page .cri-infra-project-card__body > *,
.cri-infrastructure-page .cri-infra-strategy-card > *{
  max-width:100%;
}

@media (max-width: 1399px){
  .cri-infra-overview__grid,
  .cri-infra-project-grid,
  .cri-infra-strategy__grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .cri-infra-heading .tp-section-title{font-size:36px;}
}
@media (max-width: 1199px){
  .cri-infra-overview{margin-top:40px;}
  .cri-infra-collage-wrap{padding-left:0; margin-top:24px;}
  .cri-infra-project-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .cri-infra-cta{grid-template-columns:1fr;}
  .cri-infra-cta__actions{justify-content:flex-start;}
}
@media (max-width: 991px){
  .cri-infra-breadcrumb{min-height:460px;}
  .cri-infra-breadcrumb__text{font-size:16px;}
  .cri-infra-heading .tp-section-title{font-size:32px;}
  .cri-infra-quick-grid,
  .cri-infra-collage,
  .cri-infra-overview__grid,
  .cri-infra-project-grid,
  .cri-infra-strategy__grid{grid-template-columns:1fr;}
  .cri-infra-collage{grid-template-rows:250px 220px 220px;}
  .cri-infra-collage__item--large{grid-row:auto;}
  .cri-infra-floating-card{position:relative; left:auto; bottom:auto; max-width:100%; margin-top:20px;}
  .cri-infra-strategy,
  .cri-infra-cta{padding:34px 28px;}
}
@media (max-width: 767px){
  .cri-infra-overview__panel{padding:24px;}
  .cri-infra-overview__item strong{font-size:36px;}
  .cri-infra-heading .tp-section-title{font-size:28px;}
  .cri-infra-actions{flex-direction:column; align-items:flex-start;}
  .cri-infra-project-card__body{padding:22px 20px;}
  .cri-infra-project-card__body h3{font-size:22px;}
  .cri-infra-strategy,
  .cri-infra-cta{padding:26px 22px; border-radius:24px;}
}


/* =========================================================
   SAFE LAYOUT FIXES ONLY
   These overrides are intentionally minimal so they do not
   change the original design system of the page.
   ========================================================= */

/* keep cards vertical and stop any template flex/float conflict */
.cri-infrastructure-page .cri-infra-project-grid{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:24px !important;
  align-items:stretch !important;
}

.cri-infrastructure-page .cri-infra-project-card{
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  justify-content:flex-start !important;
  width:100% !important;
  min-width:0 !important;
  height:100%;
  overflow:hidden;
}

.cri-infrastructure-page .cri-infra-project-card > .cri-infra-project-card__thumb,
.cri-infrastructure-page .cri-infra-project-card > .cri-infra-project-card__body{
  width:100% !important;
  max-width:100% !important;
  min-width:0 !important;
  float:none !important;
  clear:both !important;
}

.cri-infrastructure-page .cri-infra-project-card > .cri-infra-project-card__thumb{
  display:block !important;
  flex:0 0 240px !important;
  height:240px !important;
}

.cri-infrastructure-page .cri-infra-project-card > .cri-infra-project-card__body{
  display:block !important;
  flex:1 1 auto !important;
}

.cri-infrastructure-page .cri-infra-project-card__thumb img{
  display:block !important;
  width:100% !important;
  max-width:none !important;
  height:100% !important;
  object-fit:cover !important;
}

.cri-infrastructure-page .cri-infra-project-card__body,
.cri-infrastructure-page .cri-infra-project-card__body h3,
.cri-infrastructure-page .cri-infra-project-card__body p,
.cri-infrastructure-page .cri-infra-project-card__body li{
  word-break:normal;
  overflow-wrap:anywhere;
}

.cri-infrastructure-page .cri-infra-project-card__meta{
  display:flex !important;
  flex-wrap:wrap !important;
  gap:10px !important;
}

.cri-infrastructure-page .cri-infra-project-card__body ul{
  display:grid !important;
  gap:10px !important;
}

/* fix strategy section if a global stylesheet turns inner blocks into columns/flex rows */
.cri-infrastructure-page .cri-infra-strategy{
  display:block !important;
}

.cri-infrastructure-page .cri-infra-strategy .cri-infra-heading{
  display:block !important;
  width:100% !important;
  max-width:100% !important;
  margin-bottom:34px !important;
}

.cri-infrastructure-page .cri-infra-strategy .tp-section-title,
.cri-infrastructure-page .cri-infra-strategy .cri-infra-strategy__lead{
  max-width:100% !important;
}

.cri-infrastructure-page .cri-infra-strategy__grid{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:22px !important;
  width:100% !important;
  align-items:stretch !important;
}

.cri-infrastructure-page .cri-infra-strategy-card{
  display:flex !important;
  flex-direction:column !important;
  align-items:flex-start !important;
  justify-content:flex-start !important;
  min-width:0 !important;
  width:100% !important;
}

.cri-infrastructure-page .cri-infra-strategy-card > *{
  max-width:100% !important;
}

/* filtered hidden state */
.cri-infrastructure-page .cri-infra-project-card.is-hidden,
.cri-infrastructure-page .cri-infra-project-card[hidden]{
  display:none !important;
}

/* responsive keep original behavior but enforce anti-conflict layout */
@media (max-width: 1399px){
  .cri-infrastructure-page .cri-infra-project-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
  .cri-infrastructure-page .cri-infra-strategy__grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}

@media (max-width: 991px){
  .cri-infrastructure-page .cri-infra-project-grid,
  .cri-infrastructure-page .cri-infra-strategy__grid{
    grid-template-columns:1fr !important;
  }

  .cri-infrastructure-page .cri-infra-project-card > .cri-infra-project-card__thumb{
    flex-basis:220px !important;
    height:220px !important;
  }
}

@media (max-width: 767px){
  .cri-infrastructure-page .cri-infra-project-card > .cri-infra-project-card__thumb{
    flex-basis:200px !important;
    height:200px !important;
  }
}




.breadcrumb__title {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  text-align: center !important;
}