/* cmsms stylesheet: jacob modified: Friday, June 12, 2026 7:01:16 PM */
:root {
  --blue: #0060C0; --blue-dk: #004A99;
  --pink: #D91B60; --amber: #F0A500; --amber-dk: #C8850A;
}
body { font-family: 'Open Sans', sans-serif; color: #1A1A2E; }
.ff-montserrat { font-family: 'Montserrat', sans-serif; }

.bar-top { height: 8px; background: rgba(0,96,192,.12); }
.navbar { border-bottom: 2px solid var(--blue); }
.navbar-brand img { height: 85px; }
.nav-link {
  font-family: 'Montserrat', sans-serif; font-size: 11.5px;
  font-weight: 500; color: #6B7280 !important; letter-spacing: .2px;
  border-bottom: 2px solid transparent; padding: 4px 7px;
  white-space: nowrap; transition: color .2s, border-color .2s;
text-transform: uppercase;
}
.nav-link:hover, .nav-link.active {
  color: var(--blue) !important; border-bottom-color: var(--blue); font-weight: 700;
}
@media(max-width:1199px) {
  .nav-link { border-bottom: none; padding: 10px 0; font-size: 14px; white-space: normal; }
}

.box-blue { background: var(--blue); border-radius: 8px; color: #fff; box-shadow: 0 4px 16px rgba(0,96,192,.2); }
.box-blue h1 { font-size: 15px; line-height: 1.45; }
.box-blue p  { font-size: 13px; line-height: 1.75; text-align: justify; opacity: .95; }
.box-blue h2 { font-size: 13px; }
.box-blue li { font-size: 12.5px; line-height: 1.65; opacity: .92; text-align: justify; }
.sep { width: 40px; height: 3px; background: rgba(255,255,255,.5); border-radius: 2px; }

.btn-amber {
  background: var(--amber); color: #fff; border: none;
  font-family: 'Montserrat', sans-serif; font-weight: 700;
  font-size: 12px; letter-spacing: .5px;
  box-shadow: 0 2px 10px rgba(240,165,0,.35); transition: background .2s;
  border-radius: 6px; padding: 14px 16px;
}
.btn-amber:hover { background: var(--amber-dk); color: #fff; }

.accroche-line { flex: 1; height: 1px; background: rgba(0,96,192,.25); }
.accroche-title { font-size: 14px; color: var(--blue); line-height: 1.5; letter-spacing: .3px; }

.photo-item { position: relative; overflow: hidden; border-radius: 8px; cursor: pointer; box-shadow: 0 3px 12px rgba(0,96,192,.13); }
.photo-item img { width: 100%; aspect-ratio: 4/3; object-fit: cover; display: block; transition: transform .45s ease; }
.photo-item:hover img { transform: scale(1.07); }
.photo-overlay {
  position: absolute; inset: 0; background: rgba(0,48,120,.84);
  display: flex; align-items: center; justify-content: center;
  padding: 18px; opacity: 0; transition: opacity .35s ease;
}
.photo-item:hover .photo-overlay { opacity: 1; }
.photo-overlay p {
  color: #fff; font-family: 'Montserrat', sans-serif; font-weight: 600;
  font-size: 13px; line-height: 1.6; text-align: center; margin: 0;
}
.photo-overlay .credit {
  font-size: 10.5px; font-weight: 400; opacity: .8;
  font-style: italic; display: block; margin-top: 8px;
}

.sect-title-bg { background: var(--blue); border-radius: 4px; }
.sect-title-bg h2 { font-size: 15px; color: #fff; letter-spacing: 1px; }
.sect-col-title { font-size: 13px; color: var(--blue); text-transform: uppercase; line-height: 1.5; }
.sect-col-mode  { font-size: 12.5px; color: #6B7280; font-style: italic; font-weight: 600; }
@media(min-width:768px) { .border-start-blue { border-left: 1px solid rgba(0,96,192,.25) !important; } }

.bloc-blue { background: var(--blue); border-radius: 8px; color: #fff; box-shadow: 0 3px 12px rgba(0,96,192,.18); }
.bloc-blue h4 { font-size: 13px; }
.bloc-blue p  { font-size: 12.5px; line-height: 1.65; opacity: .92; text-align: justify; margin: 0; }

.subnav-amber { background: var(--amber); }
.subnav-amber a {
  flex: 1 1 auto; color: #fff; text-decoration: none;
  font-family: 'Montserrat', sans-serif; font-weight: 700;
  font-size: 10px; letter-spacing: .4px; text-transform: uppercase;
  padding: 14px 10px; text-align: center;
  border-right: 1px solid rgba(0,0,0,.15); transition: background .2s;
  display: flex; align-items: center; justify-content: center;
}
.subnav-amber a:last-child { border-right: none; }
.subnav-amber a:hover { background: var(--amber-dk); }
@media(max-width:767px) {
  .subnav-amber { flex-direction: column; }
  .subnav-amber a { border-right: none; border-bottom: 1px solid rgba(0,0,0,.1); }
}

.footer-dark { background: #2a2a2a; }
.foot-brand-name { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 14px; color: var(--pink); letter-spacing: .5px; }
.foot-section-title { font-family: 'Montserrat', sans-serif; font-weight: 700; font-size: 11px; color: rgba(255,255,255,.5); letter-spacing: 1px; text-transform: uppercase; }
.foot-text { font-size: 12px; color: rgba(255,255,255,.75); line-height: 1.7; }
.foot-nav a { display: block; font-size: 12px; color: rgba(255,255,255,.75); text-decoration: none; transition: color .2s; margin-bottom: 10px; }
.foot-nav a::before { content: '› '; color: var(--pink); }
.foot-nav a:hover { color: #fff; }
.foot-contact-addr { font-family: 'Montserrat', sans-serif; font-weight: 800; font-size: 13px; color: #fff; }
.foot-contact-text { font-size: 12.5px; color: rgba(255,255,255,.8); line-height: 1.8; }
.foot-lbl { color: var(--pink); font-weight: 700; }
.foot-acad { font-size: 12px; color: rgba(255,255,255,.75); font-weight: 600; letter-spacing: 1px; border-left: 3px solid var(--pink); padding-left: 8px; }
.foot-linkedin-icon { background: #0077B5; border-radius: 4px; width: 28px; height: 28px; font-weight: 800; font-size: 14px; color: #fff; }
.foot-credits { font-size: 10px; color: rgba(255,255,255,.35); line-height: 1.6; }
a {
    color: #FFF;
    text-decoration: none;
}
