/*
Theme Name: JIDATA Image Style V17
Theme URI: https://jidata.fr
Author: OpenAI
Description: Thème WordPress inspiré du visuel fourni pour JIDATA.
Version: 2.2.0
Text Domain: jidata-image-style
*/

:root{
  --navy:#071a33;
  --navy-2:#0c2a54;
  --blue:#59a9ff;
  --blue-2:#3d8fe8;
  --light:#f3f4f8;
  --text:#17345a;
  --muted:#6d7d96;
  --white:#ffffff;
  --border:#e9edf4;
  --shadow:0 10px 28px rgba(16,33,61,.10);
  --container:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--light);
  color:var(--text);
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
ul{margin:0;padding:0;list-style:none}
input,textarea,button{font:inherit}

.container{
  width:min(calc(100% - 32px), var(--container));
  margin:0 auto;
}

.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:linear-gradient(180deg, rgba(5,18,36,.96), rgba(8,27,51,.92));
  box-shadow:0 2px 14px rgba(0,0,0,.14);
}
.site-header__inner{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.logo{
  color:#fff;
  font-size:2rem;
  font-weight:800;
  letter-spacing:.02em;
}
.nav{
  display:flex;
  align-items:center;
  gap:34px;
}
.nav a{
  color:rgba(255,255,255,.92);
  font-size:1rem;
}
.nav .cta{
  padding:14px 18px;
  border-radius:6px;
  background:linear-gradient(180deg, #69b7ff, #4a9cf0);
  font-weight:700;
  box-shadow:0 8px 18px rgba(60,130,220,.30);
}

.hero{
  position:relative;
  overflow:hidden;
  min-height:600px;
  background:
    linear-gradient(90deg, rgba(7,27,52,.96) 0%, rgba(11,40,80,.86) 39%, rgba(9,26,50,.42) 64%, rgba(9,26,50,.12) 100%),
    url('assets/hero.jpg') center/cover no-repeat;
}
.hero::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(135deg, rgba(63,117,190,.20), transparent 45%),
    linear-gradient(150deg, rgba(87,155,241,.18), transparent 50%);
}
.hero__inner{
  position:relative;
  z-index:1;
  display:flex;
  align-items:center;
  min-height:600px;
}
.hero__content{
  max-width:560px;
  color:#fff;
  padding:50px 0;
}
.hero h1{
  margin:0 0 10px;
  font-size:3.35rem;
  line-height:1.12;
  font-weight:800;
}
.hero h2{
  margin:0 0 26px;
  font-size:2.15rem;
  line-height:1.2;
  color:rgba(255,255,255,.95);
  font-weight:400;
}
.hero p{
  margin:0 0 28px;
  max-width:470px;
  font-size:1.08rem;
  line-height:1.7;
  color:rgba(255,255,255,.90);
}
.primary-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:0 24px;
  border:none;
  border-radius:4px;
  background:linear-gradient(180deg, #69b7ff, #4a9cf0);
  color:#fff;
  font-weight:700;
  box-shadow:0 12px 22px rgba(60,130,220,.28);
  cursor:pointer;
}

.section{
  padding:54px 0;
}
.section-title{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  margin-bottom:30px;
}
.section-title::before,
.section-title::after{
  content:"";
  width:160px;
  max-width:20vw;
  height:1px;
  background:#dde4ef;
}
.section-title h3{
  margin:0;
  color:#183764;
  font-size:2.05rem;
  text-align:center;
}

.features-row{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.mini-feature{
  text-align:center;
  padding:10px 18px;
}
.icon-badge{
  width:64px;
  height:64px;
  margin:0 auto 16px;
  border-radius:18px;
  background:linear-gradient(180deg,#61afff,#3f8fe6);
  display:grid;
  place-items:center;
  color:#fff;
  font-size:30px;
  box-shadow:0 10px 22px rgba(63,143,230,.24);
}
.mini-feature h4{
  margin:0 0 8px;
  color:#17345a;
  font-size:1.05rem;
}
.mini-feature p{
  margin:0 auto;
  color:#6a7990;
  line-height:1.6;
  max-width:250px;
}

.services-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.service-card{
  background:#fff;
  border-radius:3px;
  box-shadow:var(--shadow);
  padding:34px 24px;
  text-align:center;
  min-height:252px;
}
.service-card h4{
  margin:0 0 10px;
  color:#17345a;
  font-size:1.2rem;
}
.service-card p{
  margin:0 auto;
  color:#6a7990;
  max-width:220px;
  line-height:1.7;
}

.targets-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}
.target-item{
  text-align:center;
  padding:8px 6px;
}
.target-item .icon-badge{
  margin-bottom:12px;
}
.target-item h4{
  margin:0;
  font-size:1.05rem;
}

.contact-band{
  background:#eef1f7;
  padding:46px 0 54px;
}
.contact-wrap{
  max-width:660px;
  margin:0 auto;
  text-align:center;
}
.contact-wrap p{
  margin:0 0 24px;
  color:#5f7089;
  font-size:1.05rem;
}
.notice{
  margin:0 auto 18px;
  max-width:660px;
  padding:14px 16px;
  border-radius:6px;
  font-weight:700;
}
.notice.success{
  background:#ecfdf3;
  color:#166534;
  border:1px solid #bbf7d0;
}
.notice.error{
  background:#fef2f2;
  color:#991b1b;
  border:1px solid #fecaca;
}
.form-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px 14px;
}
.form-grid .full{
  grid-column:1 / -1;
}
.contact-form input,
.contact-form textarea{
  width:100%;
  min-height:50px;
  border:1px solid #dde5f0;
  background:#fff;
  border-radius:2px;
  padding:12px 14px;
  color:#17345a;
}
.contact-form textarea{
  min-height:56px;
  resize:vertical;
}
.contact-form .submit-wrap{
  display:flex;
  justify-content:flex-end;
  margin-top:16px;
}
.hp{
  position:absolute!important;
  left:-9999px!important;
}
.site-footer{
  background:#071a33;
  color:rgba(255,255,255,.84);
  font-size:.92rem;
}
.site-footer__inner{
  min-height:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}
.site-footer a{color:rgba(255,255,255,.88)}

@media (max-width: 980px){
  .services-grid,
  .features-row,
  .targets-grid{
    grid-template-columns:repeat(2,1fr);
  }
  .hero h1{font-size:2.7rem}
  .hero h2{font-size:1.8rem}
}
@media (max-width: 720px){
  .site-header__inner{
    flex-direction:column;
    padding:14px 0 18px;
  }
  .nav{
    flex-wrap:wrap;
    justify-content:center;
    gap:16px;
  }
  .features-row,
  .services-grid,
  .targets-grid,
  .form-grid{
    grid-template-columns:1fr;
  }
  .contact-form .submit-wrap{
    justify-content:center;
  }
  .hero{
    min-height:auto;
    background-position:center right;
  }
  .hero__inner{
    min-height:auto;
  }
  .hero__content{
    padding:44px 0 52px;
  }
  .hero h1{font-size:2.2rem}
  .hero h2{font-size:1.45rem}
}

.notice{max-width:660px;text-align:center}
.contact-form input::placeholder,.contact-form textarea::placeholder{color:#7e8ca3}


.contact-form{position:relative;z-index:2}
.contact-form button,
.contact-form .primary-btn{
  appearance:none;
  -webkit-appearance:none;
  position:relative;
  z-index:3;
  pointer-events:auto;
}
.contact-form input,
.contact-form textarea,
.contact-form button{
  width:100%;
}
.contact-form .submit-wrap{
  display:block;
}
.contact-form .submit-wrap .primary-btn{
  width:auto;
  min-width:180px;
}


.contact-wrap{max-width:700px;margin:0 auto;text-align:center;position:relative;z-index:2}
.contact-form{display:block;position:relative;z-index:3;background:transparent}
.form-grid{display:grid;grid-template-columns:1fr;gap:12px}
.form-grid .full{grid-column:1/-1}
.contact-form input,.contact-form textarea{
  display:block;
  width:100%;
  position:relative;
  z-index:3;
  border:1px solid #dde5f0;
  background:#fff;
  padding:14px 16px;
  border-radius:2px;
}
.contact-form textarea{min-height:120px}
.submit-wrap{display:flex;justify-content:center;margin-top:16px;position:relative;z-index:4}
.contact-form button.primary-btn{
  display:inline-flex;
  width:auto;
  min-width:180px;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  border:0;
  pointer-events:auto;
}
.notice{max-width:700px;margin:0 auto 18px}
.hp{position:absolute!important;left:-9999px!important;top:auto!important;width:1px!important;height:1px!important;overflow:hidden!important}


.expertise-section{
  padding-top:54px;
  padding-bottom:54px;
}
.expertise-wrap{
  display:grid;
  grid-template-columns:360px 1fr;
  gap:32px;
  align-items:center;
  max-width:980px;
  margin:0 auto;
}
.expertise-media{
  display:flex;
  justify-content:center;
}
.expertise-photo{
  width:100%;
  max-width:360px;
  aspect-ratio:4 / 5;
  object-fit:cover;
  border-radius:8px;
  box-shadow:0 10px 28px rgba(16,33,61,.10);
  background:#e9edf4;
}
.expertise-photo--placeholder{
  min-height:420px;
}
.expertise-content{
  text-align:left;
}
.expertise-content p{
  margin:0 0 14px;
  color:#5f7089;
  line-height:1.75;
}
.expertise-box{
  margin:18px 0;
  padding:18px 20px;
  background:#ffffff;
  border:1px solid #e9edf4;
  box-shadow:0 10px 28px rgba(16,33,61,.06);
  border-radius:6px;
}
.expertise-box__title{
  margin:0 0 10px;
  color:#17345a;
  font-weight:700;
}
.expertise-list{
  list-style:none;
  padding:0;
  margin:0;
}
.expertise-list li{
  position:relative;
  padding-left:18px;
  margin:0 0 8px;
  color:#5f7089;
}
.expertise-list li::before{
  content:"•";
  position:absolute;
  left:0;
  top:0;
  color:#3f8fe6;
  font-weight:700;
}
.expertise-highlight{
  margin-top:8px;
  color:#17345a !important;
  font-weight:700;
}
@media (max-width: 900px){
  .expertise-wrap{
    grid-template-columns:1fr;
    gap:24px;
  }
  .expertise-photo{
    max-width:320px;
  }
}


.expertise-media{
  display:flex;
  flex-direction:column;
  align-items:center;
}
.expertise-identity{
  text-align:center;
  margin-top:12px;
}
.expertise-identity strong{
  display:block;
  color:#17345a;
  font-weight:700;
  font-size:1rem;
  line-height:1.4;
}
.expertise-identity span{
  display:block;
  color:#5f7089;
  font-size:.92rem;
  line-height:1.5;
}


.expertise-media{
  display:flex;
  flex-direction:column;
  align-items:center;
}
.expertise-identity{
  display:block;
  text-align:center;
  margin-top:12px;
  width:100%;
}
.expertise-identity strong{
  display:block !important;
  color:#17345a !important;
  font-weight:700 !important;
  font-size:1rem !important;
  line-height:1.4 !important;
}
.expertise-identity span{
  display:block !important;
  color:#5f7089 !important;
  font-size:.92rem !important;
  line-height:1.5 !important;
}
.expertise-name-title{
  margin:0 0 4px !important;
  color:#17345a !important;
  font-size:1.2rem !important;
  line-height:1.3 !important;
  font-weight:700 !important;
}
.expertise-name-role{
  margin:0 0 14px !important;
  color:#5f7089 !important;
  font-size:.95rem !important;
  line-height:1.5 !important;
  font-weight:600 !important;
}
