:root {
  --navy:#061b3a;
  --blue:#0877c9;
  --cyan:#00b8d9;
  --mag:#b02680;
  --gold:#ffc247;
  --ink:#102033;
  --muted:#6b7890;
  --paper:#f7fbff;
  --white:#fff;
  --shadow:0 24px 70px rgba(6,27,58,.18);
  --radius:28px
}
* {
  box-sizing:border-box
}
html {
  scroll-behavior:smooth
}
body {
  margin:0;
  font-family:Inter,Segoe UI,Arial,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6
}
a {
  text-decoration:none;
  color:inherit
}
img {
  max-width:100%
}
.container {
  width:min(1180px,92%);
  margin:auto
}
.topbar {
  background:linear-gradient(90deg,var(--navy),#123e7a,var(--mag));
  color:#fff;
  font-size:.9rem
}
.topbar .container {
  display:flex;
  justify-content:space-between;
  gap:1rem;
  padding:.55rem 0;
  flex-wrap:wrap
}
.header {
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(255,255,255,.84);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(6,27,58,.08)
}
.nav {
  height:82px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem
}
.brand-logo {
  display:flex;
  align-items:center;
  gap:.8rem;
  font-weight:900;
  color:var(--navy)
}
.brand-mark {
  width:52px;
  height:52px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--blue),var(--mag));
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
  box-shadow:0 12px 30px rgba(8,119,201,.3)
}
.brand-logo small {
  display:block;
  color:var(--muted);
  font-weight:700
}
.menu {
  display:flex;
  align-items:center;
  gap:1.2rem;
  font-weight:800
}
.menu a {
  padding:.7rem .2rem
}
.cta {
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  background:linear-gradient(135deg,var(--blue),var(--mag));
  color:#fff!important;
  padding:.85rem 1.1rem!important;
  border-radius:999px;
  box-shadow:0 16px 35px rgba(176,38,128,.26);
  font-weight:900
}
.lang {
  display:flex;
  gap:.35rem;
  border:1px solid rgba(6,27,58,.12);
  padding:.25rem;
  border-radius:999px;
  background:#fff
}
.lang a {
  position:relative;
  overflow:hidden;
  padding:.45rem .65rem;
  border-radius:999px;
  font-weight:950;
  font-size:.82rem
}
.lang a:before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,#007a5e 0 33%,#ce1126 33% 66%,#fcd116 66%);
  opacity:.18
}
.lang a.active {
  background:var(--navy);
  color:white
}
.hamb {
  display:none;
  border:0;
  background:var(--navy);
  color:white;
  border-radius:12px;
  padding:.7rem
}
.hero {
  position:relative;
  overflow:hidden;
  background:radial-gradient(circle at 10% 10%,rgba(0,184,217,.35),transparent 30%),radial-gradient(circle at 90% 0,rgba(176,38,128,.28),transparent 32%),linear-gradient(135deg,#071934,#0b4380 55%,#7f1f6b);
  color:#fff
}
.hero:after {
  content:"";
  position:absolute;
  inset:auto -10% -45% -10%;
  height:60%;
  background:var(--paper);
  border-radius:50% 50% 0 0
}
.hero-grid {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:3rem;
  align-items:center;
  min-height:690px;
  padding:5rem 0
}
.eyebrow {
  display:inline-flex;
  gap:.55rem;
  align-items:center;
  background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.22);
  border-radius:999px;
  padding:.55rem .9rem;
  font-weight:900;
  font-size:.88rem
}
.hero h1 {
  font-size:clamp(2.7rem,6vw,5.8rem);
  line-height:.92;
  margin:1rem 0;
  font-weight:950;
  letter-spacing:-.06em
}
.hero p {
  font-size:1.2rem;
  color:rgba(255,255,255,.88);
  max-width:640px
}
.hero-actions {
  display:flex;
  gap:1rem;
  flex-wrap:wrap;
  margin-top:1.6rem
}
.btn {
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  border-radius:999px;
  padding:1rem 1.25rem;
  font-weight:950;
  border:1px solid rgba(255,255,255,.25)
}
.btn-primary {
  background:#fff;
  color:var(--navy)
}
.btn-soft {
  background:rgba(255,255,255,.13);
  color:#fff
}
.hero-card {
  position:relative;
  min-height:500px
}
.orb-card {
  position:absolute;
  background:rgba(255,255,255,.12);
  backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.25);
  border-radius:34px;
  box-shadow:0 30px 80px rgba(0,0,0,.22);
  padding:1.2rem
}
.orb-card.main {
  inset:8% 0 0 10%;
  background:url('institute-facade.jpg') center/cover,linear-gradient(135deg,#0c5da5,#a72776);
  overflow:hidden
}
.orb-card.main:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.75),rgba(6,27,58,.15))
}
.orb-card.main span {
  position:absolute;
  z-index:2;
  left:1.4rem;
  bottom:1.3rem;
  font-weight:950;
  font-size:1.55rem
}
.orb-card.floating {
  right:0;
  top:0;
  width:210px
}
.orb-card.stats {
  left:0;
  bottom:10%;
  width:245px;
  background:#fff;
  color:var(--navy)
}
.big-num {
  font-size:2.4rem;
  font-weight:950;
  color:var(--mag)
}
.section {
  padding:5rem 0
}
.section-head {
  display:flex;
  justify-content:space-between;
  gap:2rem;
  align-items:end;
  margin-bottom:2rem
}
.section-head h2 {
  font-size:clamp(2rem,4vw,3.3rem);
  line-height:1;
  margin:0;
  color:var(--navy);
  letter-spacing:-.04em
}
.section-head p {
  color:var(--muted);
  max-width:620px
}
.grid {
  display:grid;
  gap:1.2rem
}
.cards-3 {
  grid-template-columns:repeat(3,1fr)
}
.cards-4 {
  grid-template-columns:repeat(4,1fr)
}
.card {
  background:#fff;
  border:1px solid rgba(6,27,58,.08);
  border-radius:var(--radius);
  padding:1.45rem;
  box-shadow:0 18px 45px rgba(6,27,58,.08)
}
.card h3 {
  margin:.3rem 0;
  color:var(--navy);
  line-height:1.1
}
.icon {
  width:54px;
  height:54px;
  border-radius:18px;
  background:linear-gradient(135deg,rgba(0,184,217,.2),rgba(176,38,128,.18));
  display:grid;
  place-items:center;
  font-size:1.6rem
}
.band {
  background:linear-gradient(135deg,var(--navy),#0c5da5,var(--mag));
  color:#fff;
  border-radius:38px;
  padding:3rem;
  position:relative;
  overflow:hidden
}
.band:before {
  content:"";
  position:absolute;
  right:-100px;
  top:-100px;
  width:320px;
  height:320px;
  border-radius:50%;
  border:42px solid rgba(255,255,255,.12)
}
.split {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  align-items:center
}
.programs-wrap {
  display:grid;
  grid-template-columns:360px 1fr;
  gap:1.5rem
}
.filieres {
  display:grid;
  gap:.8rem
}
.filiere-card {
  border:0;
  text-align:left;
  background:#fff;
  border-radius:22px;
  padding:1rem;
  box-shadow:0 12px 35px rgba(6,27,58,.08);
  cursor:pointer;
  font-weight:950;
  color:var(--navy)
}
.filiere-card.active {
  background:linear-gradient(135deg,var(--blue),var(--mag));
  color:#fff
}
.specialties {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem
}
.specialty {
  background:#fff;
  border-radius:24px;
  padding:1rem;
  border:1px solid rgba(6,27,58,.08);
  box-shadow:0 12px 35px rgba(6,27,58,.06);
  cursor:pointer
}
.specialty b {
  color:var(--navy)
}
.pill {
  display:inline-block;
  background:rgba(0,184,217,.12);
  color:#00799a;
  border-radius:999px;
  padding:.35rem .65rem;
  font-size:.82rem;
  font-weight:900
}
.modal {
  position:fixed;
  inset:0;
  background:rgba(6,27,58,.68);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:100;
  padding:1rem
}
.modal.open {
  display:flex
}
.modal-box {
  background:#fff;
  border-radius:30px;
  width:min(620px,96%);
  padding:2rem;
  box-shadow:var(--shadow)
}
.modal-close {
  float:right;
  border:0;
  background:#eef3f8;
  border-radius:50%;
  width:38px;
  height:38px;
  cursor:pointer
}
.table {
  width:100%;
  border-collapse:collapse;
  margin-top:1rem
}
.table th,.table td {
  padding:.9rem;
  border-bottom:1px solid #e8eef5;
  text-align:left
}
.form {
  display:grid;
  gap:1rem
}
.form input,.form select,.form textarea {
  width:100%;
  padding:1rem;
  border-radius:16px;
  border:1px solid #d8e1ec;
  font:inherit
}
.form button {
  border:0
}
.faq details {
  background:#fff;
  border-radius:18px;
  padding:1rem;
  border:1px solid rgba(6,27,58,.08)
}
.faq {
  display:grid;
  gap:.8rem
}
.footer {
  background:#061b3a;
  color:#dce9fb;
  padding:4rem 0 1.2rem
}
.footer-grid {
  display:grid;
  grid-template-columns:1.2fr repeat(3,1fr);
  gap:2rem
}
.footer h3 {
  color:white
}
.copy {
  border-top:1px solid rgba(255,255,255,.12);
  margin-top:2rem;
  padding-top:1rem;
  color:#9fb4d0
}
.whatsapp {
  position:fixed;
  right:22px;
  bottom:22px;
  z-index:90;
  width:64px;
  height:64px;
  border-radius:50%;
  background:#25D366;
  color:white;
  display:grid;
  place-items:center;
  font-size:2rem;
  box-shadow:0 16px 40px rgba(37,211,102,.35)
}
.landing {
  min-height:100vh;
  background:url('assets/institute-facade.jpg') center/cover,linear-gradient(135deg,var(--navy),var(--mag));
  display:grid;
  place-items:center;
  position:relative
}
.landing:before {
  content:"";
  position:absolute;
  inset:0;
  background:rgba(6,27,58,.58)
}
.landing-card {
  position:relative;
  z-index:2;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(20px);
  border-radius:36px;
  padding:3rem;
  width:min(560px,92%);
  text-align:center;
  box-shadow:var(--shadow)
}
.landing-card h1 {
  font-size:clamp(2rem,5vw,4rem);
  line-height:.95;
  color:var(--navy);
  margin:.5rem 0
}
.landing-buttons {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  margin-top:1.5rem
}
.landing-buttons a {
  padding:1.2rem;
  border-radius:20px;
  color:#fff;
  font-weight:950;
  background:linear-gradient(135deg,var(--blue),var(--mag))
}
.page-hero {
  background:linear-gradient(135deg,#071934,#0c5da5 60%,#9d2678);
  color:white;
  padding:5rem 0
}
.page-hero h1 {
  font-size:clamp(2.4rem,5vw,4.8rem);
  line-height:.95;
  margin:0
}
.ad-block {
  background:#fff8e7;
  border:1px dashed #f4b942;
  border-radius:24px;
  padding:1.2rem
}
.reveal {
  opacity:1;
  transform:none;
  transition:.8s;
  visibility:visible
}
.reveal.visible {
  opacity:1;
  transform:none;
  visibility:visible
}
@media(max-width:920px) {
  .hamb {
    display:block
  }
.menu {
  display:none;
  position:absolute;
  top:82px;
  left:0;
  right:0;
  background:#fff;
  padding:1rem 4%;
  box-shadow:var(--shadow);
  flex-direction:column;
  align-items:flex-start
}
.menu.open {
  display:flex
}
.hero-grid,.split,.programs-wrap {
  grid-template-columns:1fr
}
.cards-3,.cards-4,.specialties,.footer-grid {
  grid-template-columns:1fr
}
.hero-grid {
  min-height:auto;
  padding:4rem 0
}
.hero-card {
  min-height:420px
}
.section-head {
  display:block
}
.landing-buttons {
  grid-template-columns:1fr
}
}


/* === Premium update: stronger contrast, images in cards, active menus === */
:root {
  --deep:#031228;
  --hot:#c31b7b;
  --electric:#00c6ff;
  --sun:#ffc247
}
body {
  background:linear-gradient(180deg,#f3f8ff 0%,#fff 42%,#f7fbff 100%)
}
.header {
  background:rgba(255,255,255,.94);
  box-shadow:0 10px 34px rgba(6,27,58,.08)
}
.menu a:not(.cta):not([data-switch]) {
  position:relative;
  border-radius:999px;
  padding:.72rem .85rem;
  transition:.25s ease;
  color:#17325d
}
.menu a:not(.cta):not([data-switch]):hover,.menu a.current:not(.cta) {
  background:linear-gradient(135deg,rgba(0,184,217,.14),rgba(176,38,128,.14));
  color:var(--mag);
  transform:translateY(-2px)
}
.menu a.current:not(.cta)::after {
  content:"";
  position:absolute;
  left:20%;
  right:20%;
  bottom:.25rem;
  height:3px;
  border-radius:99px;
  background:linear-gradient(90deg,var(--blue),var(--mag))
}
.cta,.btn-primary {
  background:linear-gradient(135deg,#008ce3,#c31b7b)!important;
  color:#fff!important;
  border:0!important;
  box-shadow:0 18px 42px rgba(195,27,123,.34),0 10px 24px rgba(0,140,227,.22);
  transition:.25s ease;
  position:relative;
  overflow:hidden
}
.cta:hover,.btn-primary:hover {
  transform:translateY(-3px) scale(1.025);
  box-shadow:0 26px 55px rgba(195,27,123,.42),0 16px 34px rgba(0,140,227,.30);
  filter:saturate(1.15)
}
.btn-soft {
  background:rgba(255,255,255,.95)!important;
  color:var(--navy)!important;
  border:0!important;
  box-shadow:0 18px 40px rgba(0,0,0,.20);
  transition:.25s ease
}
.btn-soft:hover {
  transform:translateY(-3px);
  background:#fff!important;
  color:var(--mag)!important;
  box-shadow:0 24px 50px rgba(0,0,0,.28)
}
.hero:before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(3,18,40,.92),rgba(3,18,40,.58),rgba(195,27,123,.28));
  z-index:1
}
.hero-grid {
  z-index:2
}
.hero h1 {
  text-shadow:0 22px 55px rgba(0,0,0,.45)
}
.hero p {
  color:#fff;
  font-weight:600
}
.eyebrow {
  background:rgba(255,255,255,.22);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.28)
}
.card {
  overflow:hidden;
  transition:.28s ease;
  border:1px solid rgba(6,27,58,.10);
  background:rgba(255,255,255,.96)
}
.card:hover,.specialty:hover,.filiere-card:hover {
  transform:translateY(-7px);
  box-shadow:0 26px 70px rgba(6,27,58,.16)
}
.card-img {
  height:152px;
  margin:-1.45rem -1.45rem 1.1rem;
  border-radius:var(--radius) var(--radius) 18px 18px;
  overflow:hidden;
  position:relative;
  background:linear-gradient(135deg,var(--blue),var(--mag))
}
.card-img img {
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  filter:saturate(1.1) contrast(1.06)
}
.card-img:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.62),transparent 55%)
}
.filiere-card {
  min-height:118px;
  background-size:cover;
  background-position:center;
  color:#fff!important;
  position:relative;
  overflow:hidden;
  padding:1.25rem;
  border:1px solid rgba(255,255,255,.18);
  box-shadow:0 18px 45px rgba(6,27,58,.12)
}
.filiere-card:before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(3,18,40,.88),rgba(8,119,201,.54),rgba(176,38,128,.60));
  transition:.25s ease
}
.filiere-card:hover:before,.filiere-card.active:before {
  background:linear-gradient(135deg,rgba(8,119,201,.86),rgba(195,27,123,.78))
}
.filiere-card span {
  position:relative;
  z-index:1;
  display:block
}
.filiere-card .filiere-title {
  font-size:1.05rem;
  line-height:1.1
}
.filiere-card .filiere-count {
  margin-top:.55rem;
  font-size:.78rem;
  opacity:.88;
  font-weight:800
}
.specialty {
  position:relative;
  overflow:hidden;
  min-height:220px;
  padding:0!important;
  border:0;
  background:#fff
}
.specialty .spec-img {
  height:118px;
  background-size:cover;
  background-position:center;
  position:relative
}
.specialty .spec-img:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.55),transparent 60%)
}
.specialty .spec-body {
  padding:1rem
}
.specialty h3 {
  margin:.55rem 0 .45rem;
  color:var(--navy);
  line-height:1.1
}
.specialty p {
  margin:.2rem 0 .8rem;
  color:#56677f
}
.specialty b {
  color:var(--mag)
}
.landing {
  background:url('institute-facade.jpg') center/cover,linear-gradient(135deg,var(--navy),var(--mag))
}
.landing:before {
  background:linear-gradient(135deg,rgba(3,18,40,.78),rgba(3,18,40,.45),rgba(195,27,123,.35))
}
.landing-card {
  border:1px solid rgba(255,255,255,.60);
  background:rgba(255,255,255,.90)
}
.landing-card .dual {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1rem;
  text-align:left;
  margin:1.25rem 0;
  color:#42526b
}
.landing-card .dual b {
  color:var(--navy)
}
.landing-buttons a {
  transition:.25s ease;
  box-shadow:0 16px 35px rgba(6,27,58,.18)
}
.landing-buttons a:hover {
  transform:translateY(-4px) scale(1.025);
  filter:saturate(1.2);
  box-shadow:0 24px 55px rgba(6,27,58,.28)
}
.page-hero {
  position:relative;
  overflow:hidden;
  background:linear-gradient(135deg,#031228,#074b91 58%,#b02680)
}
.page-hero:after {
  content:"";
  position:absolute;
  right:-6rem;
  top:-7rem;
  width:26rem;
  height:26rem;
  border-radius:50%;
  border:4rem solid rgba(255,255,255,.08)
}
.page-hero .container {
  position:relative;
  z-index:1
}
.page-hero p {
  color:#fff;
  font-weight:600
}
.footer a:hover {
  color:#fff;
  text-decoration:underline
}
.whatsapp:hover {
  transform:translateY(-4px) scale(1.06)
}
.whatsapp {
  transition:.25s ease
}
@media(max-width:920px) {
  .landing-card .dual {
    grid-template-columns:1fr
  }
.menu a:not(.cta):not([data-switch]) {
  width:100%
}
}


/* === V3 Professional Programs Experience === */
.menu a {
  border-radius:999px;
  transition:.25s ease
}
.menu a:hover,.menu a.current {
  background:rgba(8,119,201,.10);
  color:var(--blue)
}
.menu .cta:hover {
  transform:translateY(-2px);
  filter:saturate(1.15);
  background:linear-gradient(135deg,var(--mag),var(--blue))
}
.page-hero-modern {
  padding:5rem 0 4rem;
  color:white
}
.breadcrumb {
  display:flex;
  gap:.5rem;
  align-items:center;
  flex-wrap:wrap;
  margin-bottom:1rem;
  font-weight:850;
  color:rgba(255,255,255,.82)
}
.breadcrumb a {
  color:white;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.18);
  padding:.35rem .65rem;
  border-radius:999px
}
.breadcrumb span {
  opacity:.85
}
.eyebrow.dark {
  background:rgba(8,119,201,.10);
  color:var(--blue);
  border-color:rgba(8,119,201,.15)
}
.filiere-mega-grid {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1.4rem
}
.mega-filiere-card {
  position:relative;
  min-height:330px;
  border-radius:36px;
  overflow:hidden;
  background:#071934;
  color:white;
  box-shadow:var(--shadow);
  display:flex;
  align-items:flex-end;
  isolation:isolate;
  transition:.35s ease;
  border:1px solid rgba(255,255,255,.1)
}
.mega-filiere-card:hover {
  transform:translateY(-8px);
  box-shadow:0 35px 85px rgba(6,27,58,.25)
}
.mega-filiere-card:before {
  content:"";
  position:absolute;
  inset:0;
  background:var(--img) center/cover;
  z-index:-2;
  transform:scale(1.04);
  transition:.6s ease
}
.mega-filiere-card:hover:before {
  transform:scale(1.12)
}
.mega-filiere-card:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.94),rgba(6,27,58,.48),rgba(176,38,128,.15));
  z-index:-1
}
.mega-content {
  padding:2rem
}
.mega-content .count {
  display:inline-flex;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.25);
  padding:.45rem .75rem;
  font-weight:950;
  margin-bottom:1rem
}
.mega-content h3 {
  font-size:clamp(1.7rem,3vw,2.7rem);
  line-height:.98;
  margin:.2rem 0 .6rem;
  color:white
}
.mega-content p {
  color:rgba(255,255,255,.88)
}
.mega-arrow {
  position:absolute;
  right:1.5rem;
  top:1.5rem;
  width:54px;
  height:54px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:white;
  color:var(--navy);
  font-size:1.7rem;
  font-weight:900
}
.detail-layout {
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:2rem;
  align-items:start
}
.detail-panel {
  background:#fff;
  border-radius:34px;
  padding:2rem;
  box-shadow:var(--shadow);
  border:1px solid rgba(6,27,58,.08)
}
.detail-panel h2 {
  font-size:clamp(2rem,4vw,3.6rem);
  line-height:.95;
  margin:.5rem 0 1rem;
  color:var(--navy);
  letter-spacing:-.04em
}
.detail-media {
  min-height:420px;
  border-radius:34px;
  background:var(--img) center/cover;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden
}
.detail-media:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.72),transparent)
}
.detail-stats {
  position:absolute;
  left:1.2rem;
  right:1.2rem;
  bottom:1.2rem;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.75rem
}
.stat-box {
  background:rgba(255,255,255,.92);
  border-radius:20px;
  padding:1rem;
  text-align:center
}
.stat-box b {
  display:block;
  color:var(--mag);
  font-size:1.4rem
}
.tabs {
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  margin:1.4rem 0
}
.tab-btn {
  border:0;
  background:#eef4fb;
  color:var(--navy);
  padding:.8rem 1rem;
  border-radius:999px;
  font-weight:950;
  cursor:pointer;
  transition:.25s
}
.tab-btn:hover,.tab-btn.active {
  background:linear-gradient(135deg,var(--blue),var(--mag));
  color:#fff
}
.tab-panel {
  display:none
}
.tab-panel.active {
  display:block;
  animation:fadeUp .35s ease
}
.specialty-grid-pro {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
  margin-top:1.4rem
}
.specialty-pro {
  display:grid;
  grid-template-columns:120px 1fr;
  gap:1rem;
  background:#fff;
  border-radius:26px;
  padding:1rem;
  border:1px solid rgba(6,27,58,.08);
  box-shadow:0 14px 35px rgba(6,27,58,.07);
  transition:.25s ease
}
.specialty-pro:hover {
  transform:translateY(-5px);
  box-shadow:0 24px 60px rgba(6,27,58,.14)
}
.specialty-pro .thumb {
  border-radius:20px;
  background:var(--img) center/cover;
  min-height:120px
}
.specialty-pro h3 {
  margin:.2rem 0;
  color:var(--navy);
  line-height:1.08
}
.meta-row {
  display:flex;
  gap:.5rem;
  flex-wrap:wrap;
  margin:.7rem 0
}
.meta-row span {
  border-radius:999px;
  background:#f0f7ff;
  color:#075d9e;
  padding:.32rem .6rem;
  font-size:.78rem;
  font-weight:900
}
.accordion {
  display:grid;
  gap:.8rem;
  margin-top:1rem
}
.accordion details {
  background:#fff;
  border:1px solid rgba(6,27,58,.08);
  border-radius:20px;
  padding:1rem;
  box-shadow:0 12px 30px rgba(6,27,58,.06)
}
.accordion summary {
  cursor:pointer;
  font-weight:950;
  color:var(--navy)
}
.spec-hero-card {
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:2rem;
  align-items:stretch
}
.spec-photo {
  border-radius:34px;
  min-height:440px;
  background:var(--img) center/cover;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden
}
.spec-photo:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.70),transparent)
}
.spec-info {
  background:#fff;
  border-radius:34px;
  padding:2rem;
  box-shadow:var(--shadow)
}
.info-table {
  width:100%;
  border-collapse:collapse;
  margin:1.2rem 0
}
.info-table th,.info-table td {
  text-align:left;
  padding:1rem;
  border-bottom:1px solid #e8eef5
}
.info-table th {
  color:var(--navy);
  width:38%
}
.side-note {
  background:linear-gradient(135deg,rgba(0,184,217,.12),rgba(176,38,128,.10));
  border-radius:24px;
  padding:1.2rem;
  border:1px solid rgba(8,119,201,.12)
}
@keyframes fadeUp {
  from {
    opacity:0;
    transform:translateY(12px)
  }
to {
  opacity:1;
  transform:none
}
}
@media(max-width:980px) {
  .filiere-mega-grid,.detail-layout,.spec-hero-card {
    grid-template-columns:1fr
  }
.specialty-grid-pro {
  grid-template-columns:1fr
}
.detail-stats {
  grid-template-columns:1fr
}
.specialty-pro {
  grid-template-columns:1fr
}
.specialty-pro .thumb {
  min-height:180px
}
}


/* === FINAL CONTENT-RICH PAGES === */
.story-grid {
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:2rem;
  align-items:center
}
.story-card {
  background:#fff;
  border-radius:34px;
  padding:2rem;
  box-shadow:var(--shadow);
  border:1px solid rgba(6,27,58,.08)
}
.story-card h2,.content-panel h2 {
  font-size:clamp(1.9rem,3vw,3rem);
  line-height:1;
  margin:.4rem 0 1rem;
  color:var(--navy);
  letter-spacing:-.035em
}
.story-visual {
  min-height:430px;
  border-radius:34px;
  background:linear-gradient(to top,rgba(6,27,58,.78),transparent),var(--img) center/cover;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden
}
.story-visual .float-badge {
  position:absolute;
  left:1.4rem;
  bottom:1.4rem;
  right:1.4rem;
  background:rgba(255,255,255,.94);
  border-radius:24px;
  padding:1.2rem;
  color:var(--navy);
  box-shadow:0 18px 45px rgba(0,0,0,.2)
}
.kpi-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1rem;
  margin-top:1.5rem
}
.kpi {
  background:#fff;
  border-radius:26px;
  padding:1.4rem;
  box-shadow:0 16px 45px rgba(6,27,58,.08);
  border:1px solid rgba(6,27,58,.08)
}
.kpi b {
  display:block;
  font-size:2rem;
  color:var(--mag);
  line-height:1
}
.kpi span {
  font-weight:850;
  color:var(--navy)
}
.content-panel {
  background:#fff;
  border-radius:34px;
  padding:2rem;
  box-shadow:var(--shadow);
  border:1px solid rgba(6,27,58,.08)
}
.feature-list {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem;
  margin-top:1.2rem
}
.feature-item {
  display:flex;
  gap:.9rem;
  align-items:flex-start;
  background:#f5f9ff;
  border-radius:22px;
  padding:1rem;
  border:1px solid #e8eef7
}
.feature-item .bubble {
  flex:0 0 42px;
  width:42px;
  height:42px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--blue),var(--mag));
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900
}
.timeline {
  display:grid;
  gap:1rem;
  counter-reset:step
}
.timeline-item {
  position:relative;
  background:#fff;
  border-radius:26px;
  padding:1.2rem 1.2rem 1.2rem 4.6rem;
  box-shadow:0 14px 38px rgba(6,27,58,.08);
  border:1px solid rgba(6,27,58,.08)
}
.timeline-item:before {
  counter-increment:step;
  content:counter(step);
  position:absolute;
  left:1.2rem;
  top:1.2rem;
  width:44px;
  height:44px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--gold),var(--mag));
  display:grid;
  place-items:center;
  color:#fff;
  font-weight:950
}
.promo-strip {
  border-radius:34px;
  padding:2rem;
  background:linear-gradient(135deg,var(--navy),var(--blue),var(--mag));
  color:#fff;
  display:grid;
  grid-template-columns:1fr auto;
  gap:1.2rem;
  align-items:center;
  box-shadow:var(--shadow);
  overflow:hidden;
  position:relative
}
.promo-strip:after {
  content:"";
  position:absolute;
  right:-80px;
  top:-120px;
  width:280px;
  height:280px;
  border-radius:50%;
  border:42px solid rgba(255,255,255,.08)
}
.promo-strip h2 {
  margin:0;
  color:#fff;
  font-size:clamp(1.8rem,3vw,2.7rem);
  line-height:1
}
.mini-cards {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem
}
.mini-card {
  background:#fff;
  border-radius:28px;
  padding:1.4rem;
  box-shadow:0 16px 45px rgba(6,27,58,.08);
  border:1px solid rgba(6,27,58,.08)
}
.mini-card h3 {
  color:var(--navy);
  margin:.2rem 0 .5rem
}
.quote-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem
}
.quote {
  background:#fff;
  border-radius:28px;
  padding:1.5rem;
  box-shadow:0 16px 45px rgba(6,27,58,.08);
  border:1px solid rgba(6,27,58,.08)
}
.quote p {
  font-style:italic;
  color:#4d5d73
}
.quote b {
  color:var(--navy)
}
.programs-intro-grid {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:1rem;
  margin-top:1.5rem
}
.program-info-card {
  background:#fff;
  border-radius:28px;
  padding:1.5rem;
  box-shadow:0 16px 45px rgba(6,27,58,.08);
  border:1px solid rgba(6,27,58,.08)
}
.program-info-card h3 {
  color:var(--navy);
  margin:.2rem 0 .6rem
}
.admission-box {
  background:#fff;
  border-radius:30px;
  padding:1.5rem;
  border:1px solid rgba(6,27,58,.08);
  box-shadow:0 14px 38px rgba(6,27,58,.08)
}
.check-list {
  display:grid;
  gap:.65rem;
  margin:1rem 0
}
.check-list li {
  list-style:none;
  padding:.75rem 1rem;
  border-radius:18px;
  background:#f5f9ff;
  font-weight:750
}
.check-list li:before {
  content:"✓";
  color:var(--mag);
  font-weight:950;
  margin-right:.5rem
}
.form-pro {
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1rem
}
.form-pro label {
  font-weight:850;
  color:var(--navy)
}
.form-pro input,.form-pro select,.form-pro textarea {
  width:100%;
  margin-top:.35rem;
  border:1px solid #dbe6f3;
  border-radius:18px;
  padding:1rem;
  font:inherit;
  background:#fff
}
.form-pro .full {
  grid-column:1/-1
}
.form-note {
  background:linear-gradient(135deg,rgba(0,184,217,.12),rgba(176,38,128,.10));
  border:1px solid rgba(8,119,201,.12);
  border-radius:24px;
  padding:1.2rem
}
.hero-photo {
  border-radius:36px;
  min-height:420px;
  background:linear-gradient(to top,rgba(6,27,58,.68),transparent),var(--img) center/cover;
  box-shadow:var(--shadow);
  position:relative;
  overflow:hidden
}
.hero-photo-card {
  position:absolute;
  left:1.3rem;
  right:1.3rem;
  bottom:1.3rem;
  background:rgba(255,255,255,.94);
  color:var(--navy);
  border-radius:26px;
  padding:1.2rem
}
.icon-row {
  display:flex;
  gap:.6rem;
  flex-wrap:wrap;
  margin-top:1rem
}
.icon-row span {
  background:#f0f7ff;
  color:#075d9e;
  border-radius:999px;
  padding:.45rem .75rem;
  font-weight:900;
  font-size:.84rem
}
@media(max-width:980px) {
  .story-grid,.promo-strip {
    grid-template-columns:1fr
  }
.kpi-grid,.mini-cards,.quote-grid,.programs-intro-grid {
  grid-template-columns:1fr 1fr
}
.form-pro {
  grid-template-columns:1fr
}
}
@media(max-width:640px) {
  .kpi-grid,.mini-cards,.quote-grid,.programs-intro-grid,.feature-list {
    grid-template-columns:1fr
  }
.promo-strip {
  padding:1.4rem
}
.story-card,.content-panel {
  padding:1.4rem
}
}


/* === FINAL OPTIMIZATION PATCH === */
:root {
  --section-tight:3.25rem
}
.page-hero {
  padding-bottom:3.25rem!important;
  margin-bottom:0!important
}
.page-hero-modern {
  min-height:auto!important
}
.page-hero + .section {
  padding-top:2.25rem!important
}
.section {
  padding:var(--section-tight) 0!important
}
.programs-showcase {
  padding-top:2rem!important
}
.filiere-mega-grid {
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:1.25rem!important;
  align-items:stretch!important
}
.mega-filiere-card {
  min-height:385px!important
}
.mega-content {
  padding:1.65rem!important
}
.mega-content h3 {
  font-size:clamp(1.55rem,2.25vw,2.25rem)!important
}
.mega-content p {
  font-size:.97rem!important
}
.grid,.cards-3,.cards-4,.programs-intro-grid,.mini-cards,.quote-grid,.kpi-grid,.feature-list {
  align-items:stretch
}
.card,.mini-card,.program-info-card,.quote,.content-panel,.admission-box {
  height:100%
}
.flyer-zone {
  background:linear-gradient(135deg,#eef8ff,#fff4fb);
  border-top:1px solid rgba(6,27,58,.06);
  border-bottom:1px solid rgba(6,27,58,.06)
}
.flyer-wrap {
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:1.5rem;
  align-items:center
}
.flyer-copy h2 {
  font-size:clamp(1.9rem,3.6vw,3.1rem);
  line-height:.98;
  margin:.4rem 0 1rem;
  color:var(--navy);
  letter-spacing:-.04em
}
.flyer-copy p {
  color:var(--muted);
  max-width:650px
}
.flyer-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1rem
}
.flyer-preview {
  position:relative;
  min-height:250px;
  border-radius:28px;
  overflow:hidden;
  background:var(--img) center/cover;
  box-shadow:0 18px 45px rgba(6,27,58,.14);
  display:flex;
  align-items:flex-end;
  color:#fff;
  isolation:isolate;
  transition:.3s ease;
  border:1px solid rgba(255,255,255,.4)
}
.flyer-preview:hover {
  transform:translateY(-6px);
  box-shadow:0 30px 70px rgba(6,27,58,.22)
}
.flyer-preview:after {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(6,27,58,.88),rgba(6,27,58,.20));
  z-index:-1
}
.flyer-preview div {
  padding:1.2rem
}
.flyer-preview b {
  display:block;
  font-size:1.15rem;
  line-height:1.1
}
.flyer-preview span {
  font-size:.82rem;
  color:rgba(255,255,255,.86)
}
.download-pill {
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  margin-top:.9rem;
  border-radius:999px;
  background:linear-gradient(135deg,var(--blue),var(--mag));
  color:#fff;
  padding:.85rem 1.1rem;
  font-weight:950;
  box-shadow:0 16px 35px rgba(176,38,128,.22)
}
.specialty-picker {
  display:none;
  margin-top:1rem;
  padding:1.1rem;
  border-radius:24px;
  background:#f5f9ff;
  border:1px solid #dbe6f3
}
.specialty-picker.show {
  display:block
}
.specialty-picker strong {
  display:block;
  color:var(--navy);
  margin-bottom:.7rem
}
.specialty-options {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.65rem
}
.option-chip {
  display:flex;
  align-items:center;
  gap:.55rem;
  background:#fff;
  border:1px solid #dbe6f3;
  border-radius:16px;
  padding:.75rem;
  font-weight:800;
  color:var(--navy);
  cursor:pointer
}
.option-chip:hover {
  border-color:var(--mag);
  box-shadow:0 10px 24px rgba(176,38,128,.12)
}
.option-chip input {
  width:auto!important;
  margin:0!important
}
.form-pro select:focus,.form-pro input:focus,.form-pro textarea:focus {
  outline:3px solid rgba(0,184,217,.22);
  border-color:var(--blue)
}
@media(max-width:1100px) {
  .filiere-mega-grid {
    grid-template-columns:repeat(2,minmax(0,1fr))!important
  }
.flyer-wrap {
  grid-template-columns:1fr
}
.flyer-grid {
  grid-template-columns:repeat(3,1fr)
}
}
@media(max-width:760px) {
  .filiere-mega-grid,.flyer-grid,.specialty-options {
    grid-template-columns:1fr!important
  }
.mega-filiere-card {
  min-height:310px!important
}
.section {
  padding:2.4rem 0!important
}
.page-hero + .section {
  padding-top:1.4rem!important
}
.flyer-preview {
  min-height:220px
}
}


/* === OPEN DAY POPUP === */
.openhouse-modal {
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  opacity:0;
  visibility:hidden;
  transition:.35s ease;
  padding:1rem
}
.openhouse-modal.show {
  opacity:1;
  visibility:visible
}
.openhouse-backdrop {
  position:absolute;
  inset:0;
  background:rgba(5,18,45,.68);
  backdrop-filter:blur(10px)
}
.openhouse-card {
  position:relative;
  z-index:2;
  width:min(620px,94vw);
  border-radius:34px;
  padding:2rem;
  background:linear-gradient(135deg,rgba(255,255,255,.98),rgba(240,249,255,.96));
  box-shadow:0 40px 110px rgba(0,0,0,.32);
  border:1px solid rgba(255,255,255,.75);
  overflow:hidden;
  transform:translateY(20px) scale(.96);
  transition:.35s ease;
  color:#10213f
}
.openhouse-modal.show .openhouse-card {
  transform:translateY(0) scale(1)
}
.openhouse-card:before {
  content:"";
  position:absolute;
  right:-80px;
  top:-90px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--blue,#00b8d9),var(--mag,#b02680));
  opacity:.15
}
.openhouse-card:after {
  content:"";
  position:absolute;
  left:-90px;
  bottom:-120px;
  width:280px;
  height:280px;
  border-radius:50%;
  background:linear-gradient(135deg,var(--gold,#ffc107),var(--blue,#00b8d9));
  opacity:.12
}
.openhouse-close {
  position:absolute;
  right:18px;
  top:16px;
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:#10213f;
  color:#fff;
  font-size:1.7rem;
  line-height:1;
  cursor:pointer;
  z-index:3;
  transition:.25s ease
}
.openhouse-close:hover {
  transform:rotate(90deg) scale(1.05);
  background:var(--mag,#b02680)
}
.openhouse-badge {
  display:inline-flex;
  position:relative;
  z-index:2;
  padding:.55rem .9rem;
  border-radius:999px;
  background:linear-gradient(135deg,var(--blue,#00b8d9),var(--mag,#b02680));
  color:#fff;
  font-size:.78rem;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
  box-shadow:0 14px 30px rgba(176,38,128,.22)
}
.openhouse-card h2 {
  position:relative;
  z-index:2;
  margin:1rem 0 .8rem;
  font-size:clamp(2.2rem,5vw,4.2rem);
  line-height:.9;
  color:var(--navy,#061b3a);
  letter-spacing:-.06em;
  text-transform:uppercase
}
.openhouse-card h2 span {
  color:var(--mag,#b02680)
}
.openhouse-lead {
  position:relative;
  z-index:2;
  font-size:1.05rem;
  line-height:1.55;
  color:#44546a;
  max-width:92%
}
.openhouse-info {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:.8rem;
  margin:1.25rem 0
}
.openhouse-info span {
  background:#fff;
  border:1px solid rgba(6,27,58,.08);
  box-shadow:0 12px 30px rgba(6,27,58,.08);
  border-radius:18px;
  padding:.85rem;
  font-weight:850;
  font-size:.88rem;
  color:var(--navy,#061b3a)
}
.openhouse-actions {
  position:relative;
  z-index:2;
  display:flex;
  gap:.8rem;
  flex-wrap:wrap;
  margin-top:1rem
}
.openhouse-actions a {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  border-radius:999px;
  padding:1rem 1.15rem;
  font-weight:950;
  transition:.25s ease
}
.openhouse-primary {
  background:linear-gradient(135deg,var(--navy,#061b3a),var(--mag,#b02680));
  color:#fff;
  box-shadow:0 18px 40px rgba(176,38,128,.22)
}
.openhouse-secondary {
  background:#fff;
  color:var(--navy,#061b3a);
  border:1px solid rgba(6,27,58,.12)
}
.openhouse-actions a:hover {
  transform:translateY(-3px);
  box-shadow:0 20px 42px rgba(6,27,58,.18)
}
@media(max-width:640px) {
  .openhouse-card {
    padding:1.35rem;
    border-radius:28px
  }
.openhouse-info {
  grid-template-columns:1fr
}
.openhouse-lead {
  max-width:100%
}
.openhouse-actions {
  display:grid
}
.openhouse-actions a {
  width:100%
}
}


/* Contact page */
.contact-hero {
  background:radial-gradient(circle at 15% 20%,rgba(0,184,217,.34),transparent 30%),radial-gradient(circle at 85% 0,rgba(176,38,128,.30),transparent 32%),linear-gradient(135deg,#061b3a,#0b4b87 55%,#9a226f)!important
}
.contact-layout {
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:1.5rem;
  align-items:start
}
.contact-panel {
  background:#fff;
  border:1px solid rgba(6,27,58,.08);
  border-radius:34px;
  padding:2rem;
  box-shadow:var(--shadow)
}
.contact-panel h2 {
  font-size:clamp(1.8rem,3.4vw,3rem);
  line-height:1;
  margin:.5rem 0 1rem;
  color:var(--navy);
  letter-spacing:-.04em
}
.contact-form {
  display:grid;
  gap:1rem;
  margin-top:1.2rem
}
.form-grid.two {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem
}
.contact-form label {
  display:grid;
  gap:.45rem;
  font-weight:900;
  color:var(--navy)
}
.contact-form input,.contact-form select,.contact-form textarea {
  width:100%;
  border:1px solid rgba(6,27,58,.14);
  background:#f8fbff;
  border-radius:18px;
  padding:1rem;
  font:inherit;
  color:var(--ink);
  outline:none;
  transition:.25s ease
}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus {
  border-color:var(--blue);
  box-shadow:0 0 0 4px rgba(8,119,201,.12);
  background:#fff
}
.contact-list {
  display:grid;
  gap:.8rem;
  margin:1.2rem 0
}
.contact-list a {
  display:block;
  border:1px solid rgba(6,27,58,.08);
  background:linear-gradient(135deg,#f7fbff,#fff);
  border-radius:22px;
  padding:1rem;
  transition:.25s ease
}
.contact-list a:hover {
  transform:translateY(-3px);
  box-shadow:0 16px 35px rgba(6,27,58,.10)
}
.contact-list b {
  display:block;
  color:var(--navy)
}
.contact-list span {
  color:var(--muted)
}
.contact-cta-box {
  margin-top:1rem;
  border-radius:28px;
  padding:1.3rem;
  background:linear-gradient(135deg,rgba(0,184,217,.13),rgba(176,38,128,.12));
  border:1px solid rgba(8,119,201,.12)
}
.contact-cta-box h3 {
  margin:0 0 .4rem;
  color:var(--navy)
}
.map-placeholder {
  min-height:390px;
  border-radius:34px;
  background:linear-gradient(135deg,rgba(6,27,58,.85),rgba(8,119,201,.62)),url('institute-facade.jpg') center/cover;
  box-shadow:var(--shadow);
  display:grid;
  place-items:center;
  color:#fff;
  text-align:center;
  overflow:hidden;
  position:relative
}
.map-placeholder:after {
  content:"";
  position:absolute;
  inset:1.1rem;
  border:2px dashed rgba(255,255,255,.35);
  border-radius:26px
}
.map-placeholder div {
  position:relative;
  z-index:2;
  background:rgba(255,255,255,.13);
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(12px);
  padding:1.4rem;
  border-radius:24px
}
.map-placeholder b {
  display:block;
  font-size:1.3rem
}
.map-placeholder span {
  color:rgba(255,255,255,.86)
}
@media(max-width:900px) {
  .contact-layout,.form-grid.two {
    grid-template-columns:1fr
  }
}


/* === Contact page final alignment fix === */
.contact-section {
  padding-top:clamp(2.5rem,4vw,4rem);
  padding-bottom:clamp(2.5rem,4vw,4rem)
}
.contact-layout {
  display:grid;
  grid-template-columns:minmax(0,1.05fr) minmax(340px,.95fr);
  gap:1.5rem;
  align-items:stretch
}
.contact-panel {
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:flex-start
}
.contact-form-card,.contact-info-card {
  min-height:100%
}
.contact-form-card>p,.contact-info-card>p {
  min-height:3rem
}
.contact-form {
  flex:1;
  display:flex;
  flex-direction:column;
  gap:1rem
}
.contact-form .btn {
  align-self:flex-start;
  margin-top:auto
}
.form-grid.two {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:1rem;
  align-items:end
}
.contact-list {
  display:grid;
  grid-template-columns:1fr;
  gap:.85rem;
  margin:1.2rem 0;
  flex:1
}
.contact-list a {
  min-height:78px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:.2rem
}
.contact-cta-box {
  margin-top:auto
}
.contact-map-zone .split {
  align-items:stretch;
  gap:1.5rem
}
.contact-map-zone .content-panel,.contact-map-zone .map-placeholder {
  height:100%;
  min-height:390px
}
.map-placeholder {
  height:100%
}
.flyer-zone .flyer-wrap {
  align-items:stretch;
  gap:1.5rem
}
.flyer-zone .flyer-copy,.flyer-zone .flyer-grid {
  height:100%
}
.flyer-zone .flyer-grid {
  align-content:stretch
}
.flyer-preview {
  min-height:190px
}
@media(max-width:980px) {
  .contact-layout {
    grid-template-columns:1fr
  }
.contact-form-card>p,.contact-info-card>p {
  min-height:auto
}
.contact-map-zone .content-panel,.contact-map-zone .map-placeholder {
  min-height:auto
}
.map-placeholder {
  min-height:320px
}
}
@media(max-width:640px) {
  .form-grid.two {
    grid-template-columns:1fr
  }
.contact-panel {
  padding:1.35rem;
  border-radius:24px
}
.contact-list a {
  min-height:auto
}
.contact-form .btn {
  width:100%
}
}


/* === FINAL HERO + FOOTER RESPONSIVE ALIGNMENT PATCH === */
.hero-grid {
  min-height:620px!important;
  gap:2.2rem!important;
  padding:4.2rem 0 3.4rem!important;
  align-items:center!important
}
.hero h1 {
  font-size:clamp(2.35rem,5vw,4.85rem)!important;
  line-height:.95!important;
  max-width:760px!important;
  margin:.9rem 0 1rem!important
}
.hero p {
  font-size:clamp(1rem,1.6vw,1.14rem)!important;
  max-width:600px!important
}
.hero-card {
  position:relative!important;
  min-height:520px!important;
  display:grid!important;
  grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;
  grid-template-rows:minmax(330px,1fr) auto!important;
  gap:1rem!important;
  align-items:stretch!important
}
.hero-card .orb-card {
  position:relative!important;
  inset:auto!important;
  left:auto!important;
  right:auto!important;
  top:auto!important;
  bottom:auto!important;
  width:auto!important;
  height:auto!important;
  display:flex!important;
  flex-direction:column!important;
  justify-content:flex-end!important
}
.hero-card .orb-card.main {
  grid-column:1 / -1!important;
  min-height:330px!important;
  border-radius:34px!important
}
.hero-card .orb-card.main span {
  font-size:clamp(1.15rem,2vw,1.45rem)!important;
  line-height:1.15!important;
  max-width:85%!important
}
.hero-card .orb-card.floating,.hero-card .orb-card.stats {
  min-height:150px!important;
  padding:1.25rem!important;
  border-radius:28px!important
}
.hero-card .orb-card.floating p {
  font-size:.92rem!important;
  margin:.35rem 0 0!important;
  color:rgba(255,255,255,.9)!important
}
.hero-card .orb-card.stats {
  align-items:flex-start!important;
  justify-content:center!important;
  background:#fff!important;
  color:var(--navy)!important
}
.hero-card .big-num {
  font-size:2.3rem!important;
  line-height:1!important
}
.hero-card b {
  line-height:1.15!important
}
.hero:after {
  height:42%!important;
  bottom:-34%!important
}
.icon-row {
  display:flex;
  gap:.65rem;
  flex-wrap:wrap;
  align-items:center
}
.icon-row span {
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:.5rem .75rem;
  border-radius:999px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.20);
  font-weight:850;
  color:#fff
}
.footer-grid {
  align-items:start!important
}
.social-links {
  display:flex;
  gap:.65rem;
  margin-top:1rem;
  flex-wrap:wrap
}
.social-links a {
  width:38px;
  height:38px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  color:#fff!important;
  font-weight:950;
  text-decoration:none!important;
  transition:.25s ease
}
.social-links a:hover {
  transform:translateY(-3px);
  background:linear-gradient(135deg,var(--blue),var(--mag));
  box-shadow:0 14px 30px rgba(0,0,0,.22)
}
.copy {
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:1rem!important;
  flex-wrap:wrap!important
}
.legal-links {
  display:flex;
  gap:.65rem;
  flex-wrap:wrap
}
.legal-links a {
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(255,255,255,.15);
  border-radius:999px;
  padding:.55rem .8rem;
  color:#dce9fb!important;
  text-decoration:none!important;
  font-weight:800
}
.legal-links a:hover {
  background:rgba(255,255,255,.10);
  color:#fff!important
}
@media(max-width:980px) {
  .hero-grid {
    grid-template-columns:1fr!important;
    min-height:auto!important;
    padding:3.2rem 0 2.4rem!important
  }
.hero-card {
  min-height:auto!important;
  grid-template-rows:minmax(280px,auto) auto!important
}
.hero-card .orb-card.main {
  min-height:280px!important
}
.hero h1 {
  font-size:clamp(2.2rem,9vw,3.6rem)!important
}
.hero p {
  font-size:1rem!important
}
.hero-actions .btn {
  width:auto!important
}
}
@media(max-width:640px) {
  .hero-grid {
    padding:2.4rem 0 1.8rem!important;
    gap:1.5rem!important
  }
.hero-card {
  grid-template-columns:1fr!important;
  grid-template-rows:auto!important
}
.hero-card .orb-card.main {
  grid-column:auto!important;
  min-height:250px!important
}
.hero-card .orb-card.floating,.hero-card .orb-card.stats {
  min-height:auto!important
}
.hero h1 {
  font-size:2.25rem!important;
  letter-spacing:-.045em!important
}
.hero-actions {
  display:grid!important
}
.hero-actions .btn {
  justify-content:center
}
.icon-row span {
  font-size:.85rem;
  min-height:34px
}
.footer {
  padding:3rem 0 1rem!important
}
.copy {
  align-items:flex-start!important;
  flex-direction:column!important
}
.legal-links {
  width:100%
}
.legal-links a {
  flex:1;
  justify-content:center
}
.social-links a {
  width:36px;
  height:36px
}
}


/* === Final optimization: compact hero gap, scholarship/orientation pages, footer hover === */
.hero + .section {
  padding-top:2rem!important;
  margin-top:-.5rem
}
.hero-grid {
  padding-bottom:3.2rem!important;
  min-height:620px!important
}
.hero:after {
  bottom:-55%!important
}
.section {
  padding-top:3.4rem;
  padding-bottom:3.4rem
}
.tight-section {
  padding-top:2.8rem!important
}
.compact-hero {
  padding:4rem 0 3.4rem!important
}
.page-hero + .section {
  padding-top:2.6rem!important
}
.promo-strip .btn {
  position:relative;
  z-index:2
}
.btn-outline-dark {
  background:#fff!important;
  color:var(--navy)!important;
  border:1px solid rgba(6,27,58,.14)!important
}
.service-actions {
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  margin-top:1rem
}
.scholarship-mini,.scholarship-note {
  margin-top:1rem;
  border-radius:22px;
  padding:1rem;
  background:linear-gradient(135deg,rgba(255,194,71,.22),rgba(176,38,128,.10));
  border:1px solid rgba(176,38,128,.14)
}
.orientation-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2rem;
  align-items:start
}
.form-card {
  height:100%
}
.appointment-feedback {
  min-height:1.2rem;
  font-weight:850;
  color:var(--mag)
}
.appointment-feedback.ok {
  color:#087b55
}
.footer a {
  text-decoration:none!important;
  transition:.25s ease;
  color:#dce9fb
}
.footer a:hover {
  color:var(--gold)!important;
  text-decoration:none!important
}
.legal-links {
  display:inline-flex;
  gap:1rem;
  flex-wrap:wrap
}
.copy {
  display:flex;
  justify-content:space-between;
  gap:1rem;
  align-items:center;
  flex-wrap:wrap
}
.footer-grid p {
  line-height:1.85
}
.filiere-mega-grid {
  align-items:stretch
}
@media(max-width:980px) {
  .orientation-grid {
    grid-template-columns:1fr
  }
.hero + .section {
  margin-top:0
}
.hero-grid {
  min-height:auto!important;
  padding-bottom:2rem!important
}
.section {
  padding-top:2.8rem;
  padding-bottom:2.8rem
}
}
@media(max-width:640px) {
  .hero + .section {
    padding-top:1.5rem!important
  }
.compact-hero {
  padding:3rem 0 2.5rem!important
}
.legal-links {
  width:100%;
}
.copy {
  align-items:flex-start
}
}

/* Final legal & scholarship refinements */
.legal-content {
  display:grid;
  grid-template-columns:minmax(0,1fr) 320px;
  gap:2rem;
  align-items:start
}
.legal-article {
  background:#fff;
  border:1px solid rgba(15,23,42,.08);
  border-radius:28px;
  padding:2rem;
  box-shadow:0 18px 45px rgba(15,23,42,.08)
}
.legal-article h2 {
  margin-top:1.6rem
}
.legal-article h2:first-child {
  margin-top:0
}
.legal-sidebar {
  position:sticky;
  top:110px;
  background:linear-gradient(135deg,#052b63,#8b1e74);
  color:#fff;
  border-radius:28px;
  padding:1.5rem;
  box-shadow:0 18px 45px rgba(15,23,42,.18)
}
.legal-sidebar a {
  display:block;
  color:#fff;
  text-decoration:none;
  padding:.65rem 0;
  border-bottom:1px solid rgba(255,255,255,.18)
}
.legal-sidebar a:hover {
  color:#ffd166
}
.specialty-picker {
  display:none;
  margin-top:.25rem
}
.specialty-picker.show {
  display:block
}
.form-help {
  display:block;
  margin:0 0 .65rem;
  font-weight:800;
  color:#0f2954
}
.option-grid {
  display:flex;
  flex-wrap:wrap;
  gap:.65rem
}
.option-chip {
  cursor:pointer
}
.option-chip input {
  position:absolute;
  opacity:0;
  pointer-events:none
}
.option-chip span {
  display:inline-flex;
  align-items:center;
  border:1px solid rgba(15,23,42,.16);
  border-radius:999px;
  padding:.75rem 1rem;
  background:#fff;
  font-weight:800;
  transition:.2s ease
}
.option-chip input:checked + span {
  background:linear-gradient(135deg,#00a7e1,#8b1e74);
  color:#fff;
  border-color:transparent;
  box-shadow:0 12px 28px rgba(0,167,225,.22)
}
.footer a {
  text-decoration:none
}
.footer a:hover {
  color:#00d2ff
}
@media(max-width:850px) {
  .legal-content {
    grid-template-columns:1fr
  }
.legal-sidebar {
  position:static
}
.option-grid {
  display:grid;
  grid-template-columns:1fr
}
.option-chip span {
  width:100%;
  justify-content:center
}
}
/* === WhatsApp Floating Button === */

.floating_btn {
  position: fixed;
  bottom: 30px;
  right: 30px;
  width: 100px;
  height: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

@keyframes pulsing {
  to {
    box-shadow: 0 0 0 30px rgba(232, 76, 61, 0);
  }
}

.contact_icon {
  background-color: #42db87;
  color: #fff;
  width: 60px;
  height: 60px;
  font-size: 30px;
  border-radius: 50px;
  text-align: center;
  box-shadow: 2px 2px 3px #999;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: translateY(0px);
  box-shadow: 0 0 0 0 #42db87;
  -webkit-animation: pulsing 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
  -moz-animation: pulsing 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
  -ms-animation: pulsing 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
  animation: pulsing 1.25s infinite cubic-bezier(0.66, 0, 0, 1);
  font-weight: normal;
  font-family: sans-serif;
  text-decoration: none !important;
  transition: all 300ms ease-in-out;
}

.contact_icon:hover {
  transform: scale(1.08);
}

.text_icon {
  margin-top: 8px;
  color: #ffffff;
  font-size: 13px;
  font-weight: 800;
  text-shadow: 0 2px 10px rgba(0,0,0,.25);
}

/* === WhatsApp SVG inline icons - small fixed size === */
.topbar-whatsapp,
.footer-whatsapp-line {
  display:inline-flex !important;
  align-items:center !important;
  gap:6px !important;
  line-height:1.4 !important;
}

.wa-inline-icon {
  width:13px !important;
  height:13px !important;
  min-width:13px !important;
  max-width:13px !important;
  min-height:13px !important;
  max-height:13px !important;
  object-fit:contain !important;
  display:inline-block !important;
  vertical-align:middle !important;
  flex:0 0 13px !important;
}

.footer-whatsapp-line .wa-inline-icon {
  width:14px !important;
  height:14px !important;
  min-width:14px !important;
  max-width:14px !important;
  min-height:14px !important;
  max-height:14px !important;
  flex-basis:14px !important;
}

/* === FIX SECTION ACCUEIL INVISIBLE === */
.story-card.reveal,
.story-visual.reveal,
.section-head.reveal {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.story-grid {
  display: grid;
}

.story-visual {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

/* === FINAL HARD FIX: SECTIONS ACCUEIL VISIBLES === */
.reveal,
.reveal.visible,
.story-card,
.story-visual,
.section-head,
.mini-cards,
.mini-card {
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.story-grid {
  display: grid !important;
  grid-template-columns: 1.1fr .9fr !important;
  gap: 2rem !important;
  align-items: center !important;
}

.story-card {
  display: block !important;
  background: #fff !important;
  color: var(--ink) !important;
  border-radius: 34px !important;
  padding: 2rem !important;
  box-shadow: var(--shadow) !important;
  border: 1px solid rgba(6,27,58,.08) !important;
  position: relative !important;
  z-index: 2 !important;
}

.story-card h2,
.section-head h2 {
  color: var(--navy) !important;
}

.story-card p,
.section-head p,
.feature-item {
  color: var(--ink) !important;
}

.story-visual {
  display: block !important;
  min-height: 430px !important;
  border-radius: 34px !important;
  background: linear-gradient(to top,rgba(6,27,58,.78),transparent),var(--img) center/cover no-repeat !important;
  box-shadow: var(--shadow) !important;
  position: relative !important;
  overflow: hidden !important;
  z-index: 1 !important;
}

.story-visual .float-badge {
  display: block !important;
  position: absolute !important;
  left: 1.4rem !important;
  right: 1.4rem !important;
  bottom: 1.4rem !important;
  background: rgba(255,255,255,.94) !important;
  color: var(--navy) !important;
  border-radius: 24px !important;
  padding: 1.2rem !important;
  box-shadow: 0 18px 45px rgba(0,0,0,.2) !important;
}

.section-head {
  display: flex !important;
  justify-content: space-between !important;
  gap: 2rem !important;
  align-items: end !important;
  margin-bottom: 2rem !important;
}

.mini-cards {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 1rem !important;
}

.mini-card {
  display: block !important;
  background: #fff !important;
  color: var(--ink) !important;
  border-radius: 28px !important;
  padding: 1.4rem !important;
  box-shadow: 0 16px 45px rgba(6,27,58,.08) !important;
  border: 1px solid rgba(6,27,58,.08) !important;
}

@media(max-width:980px) {
  .story-grid,
  .mini-cards {
    grid-template-columns: 1fr !important;
  }

.section-head {
  display: block !important;
}
}

/* =========================================================
ALIGNEMENT PREMIUM : NOTRE PROMESSE + EXPERIENCE PREMIUM
Ne touche pas à la section "Domaines de formation"
========================================================= */

.story-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, .95fr) !important;
  gap: 2rem !important;
  align-items: stretch !important;
}

.story-card,
.story-visual {
  min-height: 520px !important;
  height: 100% !important;
}

.story-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%) !important;
  border-radius: 34px !important;
  padding: clamp(1.5rem, 3vw, 2.4rem) !important;
  border: 1px solid rgba(6, 27, 58, .08) !important;
  box-shadow: 0 24px 70px rgba(6, 27, 58, .12) !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  position: relative !important;
  overflow: hidden !important;
  animation: storyFadeLeft .9s ease both !important;
}

.story-card::before {
  content: "" !important;
  position: absolute !important;
  top: -90px !important;
  right: -90px !important;
  width: 220px !important;
  height: 220px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, rgba(8,119,201,.18), rgba(176,38,128,.16)) !important;
}

.story-card > * {
  position: relative !important;
  z-index: 2 !important;
}

.story-card h2 {
  margin-top: .8rem !important;
  margin-bottom: 1rem !important;
  max-width: 620px !important;
}

.story-card p {
  max-width: 680px !important;
}

.story-card .feature-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: .9rem !important;
  margin-top: 1.4rem !important;
}

.story-card .feature-item {
  min-height: 118px !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: .85rem !important;
  padding: 1rem !important;
  border-radius: 22px !important;
  background: #ffffff !important;
  border: 1px solid rgba(6, 27, 58, .08) !important;
  box-shadow: 0 12px 30px rgba(6, 27, 58, .06) !important;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease !important;
}

.story-card .feature-item:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 22px 48px rgba(6, 27, 58, .13) !important;
  border-color: rgba(176, 38, 128, .18) !important;
}

.story-card .bubble {
  flex: 0 0 42px !important;
  width: 42px !important;
  height: 42px !important;
}

.story-visual {
  border-radius: 34px !important;
  background:
  linear-gradient(to top, rgba(6, 27, 58, .82), rgba(6, 27, 58, .08)),
  var(--img) center/cover !important;
  box-shadow: 0 24px 70px rgba(6, 27, 58, .16) !important;
  position: relative !important;
  overflow: hidden !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
  animation: storyFadeRight .9s ease .12s both !important;
}

.story-visual::before {
  content: "" !important;
  position: absolute !important;
  inset: 1rem !important;
  border: 1px solid rgba(255,255,255,.25) !important;
  border-radius: 26px !important;
  pointer-events: none !important;
}

.story-visual::after {
  content: "" !important;
  position: absolute !important;
  width: 220px !important;
  height: 220px !important;
  right: -70px !important;
  top: -70px !important;
  border-radius: 50% !important;
  background: rgba(255,255,255,.12) !important;
  pointer-events: none !important;
}

.story-visual .float-badge {
  position: absolute !important;
  left: 1.4rem !important;
  right: 1.4rem !important;
  bottom: 1.4rem !important;
  background: rgba(255,255,255,.95) !important;
  color: var(--navy) !important;
  border-radius: 26px !important;
  padding: 1.35rem !important;
  box-shadow: 0 22px 52px rgba(0,0,0,.24) !important;
  backdrop-filter: blur(14px) !important;
  animation: badgeLift .9s ease .35s both !important;
}

.story-visual .float-badge b {
  display: block !important;
  font-size: 1.15rem !important;
  line-height: 1.15 !important;
  margin-bottom: .35rem !important;
}

.story-visual .float-badge p {
  margin: 0 !important;
  color: #4d5d73 !important;
}

@keyframes storyFadeLeft {
  from {
    opacity: 0;
    transform: translateX(-26px);
  }
to {
  opacity: 1;
  transform: translateX(0);
}
}

@keyframes storyFadeRight {
  from {
    opacity: 0;
    transform: translateX(26px);
  }
to {
  opacity: 1;
  transform: translateX(0);
}
}

@keyframes badgeLift {
  from {
    opacity: 0;
    transform: translateY(18px) scale(.97);
  }
to {
  opacity: 1;
  transform: translateY(0) scale(1);
}
}

@media (max-width: 980px) {
  .story-grid {
    grid-template-columns: 1fr !important;
  }

.story-card,
.story-visual {
  min-height: auto !important;
}

.story-visual {
  min-height: 420px !important;
}
}

@media (max-width: 640px) {
  .story-card {
    padding: 1.35rem !important;
  }

.story-card .feature-list {
  grid-template-columns: 1fr !important;
}

.story-card .feature-item {
  min-height: auto !important;
}

.story-visual {
  min-height: 360px !important;
}

.story-visual .float-badge {
  left: 1rem !important;
  right: 1rem !important;
  bottom: 1rem !important;
  padding: 1rem !important;
}
}

/* =========================================================
SECTION PREMIUM : NOTRE PROMESSE + EXPERIENCE PREMIUM
Cette section remplace uniquement l'ancien bloc story-grid.
========================================================= */

.premium-story-section {
  position: relative !important;
  overflow: hidden !important;
  padding-top: 4rem !important;
  padding-bottom: 4rem !important;
}

.premium-story-section::before {
  content: "" !important;
  position: absolute !important;
  inset: 8% auto auto -120px !important;
  width: 260px !important;
  height: 260px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(0,184,217,.18), transparent 68%) !important;
  pointer-events: none !important;
}

.premium-story-section::after {
  content: "" !important;
  position: absolute !important;
  right: -140px !important;
  bottom: -100px !important;
  width: 320px !important;
  height: 320px !important;
  border-radius: 50% !important;
  background: radial-gradient(circle, rgba(176,38,128,.16), transparent 70%) !important;
  pointer-events: none !important;
}

.premium-story-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(390px, .92fr) !important;
  gap: 2rem !important;
  align-items: stretch !important;
  position: relative !important;
  z-index: 2 !important;
}

.premium-story-card,
.premium-story-visual {
  min-height: 620px !important;
  height: 100% !important;
  opacity: 1 !important;
  visibility: visible !important;
  transform: none !important;
}

.premium-story-card {
  position: relative !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  overflow: hidden !important;
  border-radius: 38px !important;
  padding: clamp(1.6rem, 3vw, 2.5rem) !important;
  background:
  linear-gradient(135deg, rgba(255,255,255,.98), rgba(246,250,255,.96)),
  radial-gradient(circle at 90% 0%, rgba(8,119,201,.12), transparent 35%) !important;
  border: 1px solid rgba(6,27,58,.08) !important;
  box-shadow: 0 30px 90px rgba(6,27,58,.12) !important;
  animation: premiumSlideLeft .9s ease both !important;
}

.premium-story-card::before {
  content: "" !important;
  position: absolute !important;
  top: -140px !important;
  right: -140px !important;
  width: 310px !important;
  height: 310px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, rgba(8,119,201,.20), rgba(176,38,128,.18)) !important;
  filter: blur(.2px) !important;
}

.premium-story-card::after {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  bottom: 0 !important;
  width: 8px !important;
  background: linear-gradient(180deg, var(--blue), var(--mag), var(--gold)) !important;
}

.premium-story-card > * {
  position: relative !important;
  z-index: 2 !important;
}

.premium-story-card h2 {
  max-width: 720px !important;
  margin: .8rem 0 1rem !important;
  font-size: clamp(2rem, 4vw, 3.35rem) !important;
  line-height: .98 !important;
}

.premium-story-card .story-lead {
  font-size: 1.05rem !important;
  color: #40536d !important;
  font-weight: 650 !important;
}

.story-metrics {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .85rem !important;
  margin: 1.25rem 0 1.35rem !important;
}

.story-metrics div {
  padding: 1rem !important;
  border-radius: 22px !important;
  background: linear-gradient(135deg, rgba(8,119,201,.08), rgba(176,38,128,.08)) !important;
  border: 1px solid rgba(6,27,58,.08) !important;
  text-align: center !important;
  transition: transform .28s ease, box-shadow .28s ease !important;
}

.story-metrics div:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 18px 42px rgba(6,27,58,.10) !important;
}

.story-metrics strong {
  display: block !important;
  color: var(--mag) !important;
  font-size: 1.65rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.story-metrics span {
  display: block !important;
  margin-top: .35rem !important;
  color: var(--navy) !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.premium-feature-list {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: .9rem !important;
  margin-top: .25rem !important;
}

.premium-feature-list .feature-item {
  min-height: 122px !important;
  background: #fff !important;
  border: 1px solid rgba(6,27,58,.08) !important;
  box-shadow: 0 14px 36px rgba(6,27,58,.07) !important;
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease !important;
}

.premium-feature-list .feature-item:hover {
  transform: translateY(-7px) !important;
  box-shadow: 0 26px 60px rgba(6,27,58,.15) !important;
  border-color: rgba(176,38,128,.24) !important;
}

.premium-feature-list .feature-item:nth-child(1) {
  animation: premiumRise .7s ease .10s both !important;
}

.premium-feature-list .feature-item:nth-child(2) {
  animation: premiumRise .7s ease .20s both !important;
}

.premium-feature-list .feature-item:nth-child(3) {
  animation: premiumRise .7s ease .30s both !important;
}

.premium-feature-list .feature-item:nth-child(4) {
  animation: premiumRise .7s ease .40s both !important;
}

.premium-story-visual {
  position: relative !important;
  border-radius: 38px !important;
  overflow: hidden !important;
  background:
  linear-gradient(180deg, rgba(6,27,58,.08), rgba(6,27,58,.88)),
  var(--img) center/cover !important;
  box-shadow: 0 30px 90px rgba(6,27,58,.18) !important;
  isolation: isolate !important;
  animation: premiumSlideRight .9s ease .1s both !important;
}

.premium-story-visual::before {
  content: "" !important;
  position: absolute !important;
  inset: 1.1rem !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  border-radius: 30px !important;
  z-index: 2 !important;
  pointer-events: none !important;
}

.premium-story-visual::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.20) 45%, transparent 70%) !important;
  transform: translateX(-120%) !important;
  animation: premiumShine 4.8s ease-in-out infinite !important;
  z-index: 3 !important;
  pointer-events: none !important;
}

.story-glass-card {
  position: absolute !important;
  z-index: 4 !important;
  left: 1.6rem !important;
  top: 1.6rem !important;
  right: 1.6rem !important;
  padding: 1.05rem 1.15rem !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.16) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  backdrop-filter: blur(16px) !important;
  color: #fff !important;
  box-shadow: 0 22px 55px rgba(0,0,0,.18) !important;
}

.story-glass-card span {
  display: block !important;
  font-size: .78rem !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: rgba(255,255,255,.76) !important;
  font-weight: 900 !important;
}

.story-glass-card b {
  display: block !important;
  margin-top: .25rem !important;
  font-size: 1.18rem !important;
  line-height: 1.15 !important;
}

.story-orbit {
  position: absolute !important;
  z-index: 1 !important;
  border-radius: 50% !important;
  border: 1px solid rgba(255,255,255,.22) !important;
  pointer-events: none !important;
}

.story-orbit-one {
  width: 230px !important;
  height: 230px !important;
  right: -70px !important;
  top: 26% !important;
  animation: orbitFloat 7s ease-in-out infinite !important;
}

.story-orbit-two {
  width: 160px !important;
  height: 160px !important;
  left: -54px !important;
  bottom: 18% !important;
  animation: orbitFloat 6.5s ease-in-out infinite reverse !important;
}

.premium-story-visual .float-badge {
  position: absolute !important;
  z-index: 5 !important;
  left: 1.6rem !important;
  right: 1.6rem !important;
  bottom: 1.6rem !important;
  padding: 1.4rem !important;
  border-radius: 28px !important;
  background: rgba(255,255,255,.96) !important;
  color: var(--navy) !important;
  border: 1px solid rgba(255,255,255,.70) !important;
  box-shadow: 0 26px 65px rgba(0,0,0,.26) !important;
  backdrop-filter: blur(18px) !important;
  animation: premiumBadgeUp .85s ease .35s both !important;
}

.premium-story-visual .badge-kicker {
  display: inline-flex !important;
  margin-bottom: .65rem !important;
  border-radius: 999px !important;
  padding: .42rem .7rem !important;
  color: #fff !important;
  background: linear-gradient(135deg, var(--blue), var(--mag)) !important;
  font-size: .75rem !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

.premium-story-visual .float-badge b {
  display: block !important;
  font-size: 1.35rem !important;
  line-height: 1.05 !important;
  margin-bottom: .45rem !important;
}

.premium-story-visual .float-badge p {
  margin: 0 !important;
  color: #526176 !important;
  font-weight: 650 !important;
}

.premium-story-card:hover,
.premium-story-visual:hover {
  transform: translateY(-4px) !important;
  transition: transform .35s ease, box-shadow .35s ease !important;
}

@keyframes premiumSlideLeft {
  from {
    opacity: 0;
    transform: translateX(-34px);
  }
to {
  opacity: 1;
  transform: translateX(0);
}
}

@keyframes premiumSlideRight {
  from {
    opacity: 0;
    transform: translateX(34px);
  }
to {
  opacity: 1;
  transform: translateX(0);
}
}

@keyframes premiumRise {
  from {
    opacity: 0;
    transform: translateY(18px);
  }
to {
  opacity: 1;
  transform: translateY(0);
}
}

@keyframes premiumBadgeUp {
  from {
    opacity: 0;
    transform: translateY(24px) scale(.96);
  }
to {
  opacity: 1;
  transform: translateY(0) scale(1);
}
}

@keyframes premiumShine {
  0%, 55% {
    transform: translateX(-120%);
  }
75%, 100% {
  transform: translateX(120%);
}
}

@keyframes orbitFloat {
  0%, 100% {
    transform: translateY(0) scale(1);
  }
50% {
  transform: translateY(-18px) scale(1.05);
}
}

@media (max-width: 1080px) {
  .premium-story-grid {
    grid-template-columns: 1fr !important;
  }

.premium-story-card,
.premium-story-visual {
  min-height: auto !important;
}

.premium-story-visual {
  min-height: 520px !important;
}
}

@media (max-width: 680px) {
  .premium-story-section {
    padding-top: 2.4rem !important;
    padding-bottom: 2.4rem !important;
  }

.premium-story-card {
  padding: 1.35rem !important;
  border-radius: 28px !important;
}

.story-metrics,
.premium-feature-list {
  grid-template-columns: 1fr !important;
}

.premium-feature-list .feature-item {
  min-height: auto !important;
}

.premium-story-visual {
  min-height: 430px !important;
  border-radius: 28px !important;
}

.story-glass-card,
.premium-story-visual .float-badge {
  left: 1rem !important;
  right: 1rem !important;
}

.story-glass-card {
  top: 1rem !important;
}

.premium-story-visual .float-badge {
  bottom: 1rem !important;
  padding: 1.05rem !important;
}
}

/* =========================================================
PROFESSIONAL TWO-COLUMN SECTION — PROMESSE + EXPERIENCE
IMPORTANT: this CSS must be in the file loaded by the HTML.
========================================================= */

.pe-section {
  position: relative !important;
  overflow: hidden !important;
  padding: clamp(3rem, 6vw, 5.5rem) 0 !important;
  background:
  radial-gradient(circle at 8% 10%, rgba(0, 184, 217, .16), transparent 26%),
  radial-gradient(circle at 92% 80%, rgba(176, 38, 128, .14), transparent 30%),
  linear-gradient(180deg, #f7fbff 0%, #ffffff 100%) !important;
}

.pe-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 1fr) !important;
  gap: clamp(1.5rem, 3vw, 2.4rem) !important;
  align-items: stretch !important;
}

.pe-left-card,
.pe-right-card {
  min-height: 680px !important;
  height: 100% !important;
  border-radius: 42px !important;
  overflow: hidden !important;
  position: relative !important;
  opacity: 1 !important;
  visibility: visible !important;
}

.pe-left-card {
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  padding: clamp(1.6rem, 3vw, 2.6rem) !important;
  background:
  linear-gradient(135deg, rgba(255,255,255,.98), rgba(246,250,255,.98)),
  radial-gradient(circle at 100% 0%, rgba(8,119,201,.16), transparent 35%) !important;
  border: 1px solid rgba(6,27,58,.08) !important;
  box-shadow: 0 32px 90px rgba(6,27,58,.12) !important;
  animation: peLeftIn .9s ease both !important;
}

.pe-left-card::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 10px !important;
  height: 100% !important;
  background: linear-gradient(180deg, #0877c9, #b02680, #ffc247) !important;
}

.pe-left-card::after {
  content: "" !important;
  position: absolute !important;
  right: -110px !important;
  top: -110px !important;
  width: 285px !important;
  height: 285px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, rgba(8,119,201,.17), rgba(176,38,128,.14)) !important;
}

.pe-left-card > * {
  position: relative !important;
  z-index: 2 !important;
}

.pe-label-row {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 1rem !important;
  flex-wrap: wrap !important;
}

.pe-mini-label {
  display: inline-flex !important;
  border-radius: 999px !important;
  padding: .55rem .9rem !important;
  background: #ffffff !important;
  color: #b02680 !important;
  border: 1px solid rgba(176,38,128,.18) !important;
  box-shadow: 0 12px 30px rgba(6,27,58,.07) !important;
  font-size: .78rem !important;
  font-weight: 950 !important;
}

.pe-left-card h2 {
  margin: 1rem 0 .9rem !important;
  max-width: 720px !important;
  color: #061b3a !important;
  font-size: clamp(2.2rem, 4.4vw, 3.7rem) !important;
  line-height: .95 !important;
  letter-spacing: -.06em !important;
}

.pe-intro {
  color: #40536d !important;
  font-size: 1.08rem !important;
  line-height: 1.7 !important;
  font-weight: 650 !important;
  max-width: 760px !important;
}

.pe-values {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: .95rem !important;
  margin: 1.35rem 0 !important;
}

.pe-value-card {
  min-height: 150px !important;
  padding: 1.15rem !important;
  border-radius: 26px !important;
  background: #ffffff !important;
  border: 1px solid rgba(6,27,58,.08) !important;
  box-shadow: 0 14px 36px rgba(6,27,58,.07) !important;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease !important;
  animation: peCardUp .8s ease both !important;
}

.pe-value-card:nth-child(1) { animation-delay: .05s !important; }
.pe-value-card:nth-child(2) { animation-delay: .14s !important; }
.pe-value-card:nth-child(3) { animation-delay: .23s !important; }
.pe-value-card:nth-child(4) { animation-delay: .32s !important; }

.pe-value-card:hover {
  transform: translateY(-7px) !important;
  box-shadow: 0 26px 60px rgba(6,27,58,.15) !important;
  border-color: rgba(176,38,128,.22) !important;
}

.pe-value-card span {
  display: inline-grid !important;
  place-items: center !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 16px !important;
  background: linear-gradient(135deg, #0877c9, #b02680) !important;
  color: #fff !important;
  font-weight: 950 !important;
  margin-bottom: .75rem !important;
}

.pe-value-card b {
  display: block !important;
  color: #061b3a !important;
  font-size: 1.05rem !important;
  line-height: 1.1 !important;
  margin-bottom: .35rem !important;
}

.pe-value-card p {
  margin: 0 !important;
  color: #526176 !important;
  font-size: .93rem !important;
  line-height: 1.45 !important;
  font-weight: 650 !important;
}

.pe-bottom-strip {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: .8rem !important;
  padding-top: .5rem !important;
}

.pe-bottom-strip div {
  border-radius: 22px !important;
  padding: 1rem !important;
  background: linear-gradient(135deg, rgba(8,119,201,.10), rgba(176,38,128,.08)) !important;
  border: 1px solid rgba(6,27,58,.07) !important;
  text-align: center !important;
}

.pe-bottom-strip strong {
  display: block !important;
  color: #b02680 !important;
  font-size: 1.3rem !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.pe-bottom-strip span {
  display: block !important;
  margin-top: .4rem !important;
  color: #061b3a !important;
  font-size: .78rem !important;
  font-weight: 900 !important;
}

.pe-right-card {
  background:
  linear-gradient(180deg, rgba(6,27,58,.08), rgba(6,27,58,.90)),
  var(--img) center/cover !important;
  border: 1px solid rgba(255,255,255,.38) !important;
  box-shadow: 0 32px 90px rgba(6,27,58,.18) !important;
  animation: peRightIn .9s ease .12s both !important;
  isolation: isolate !important;
}

.pe-image-layer {
  position: absolute !important;
  inset: 0 !important;
  background:
  radial-gradient(circle at 15% 18%, rgba(0,184,217,.32), transparent 28%),
  radial-gradient(circle at 82% 18%, rgba(255,194,71,.20), transparent 22%),
  linear-gradient(135deg, rgba(6,27,58,.12), rgba(176,38,128,.18)) !important;
  z-index: 1 !important;
}

.pe-right-card::before {
  content: "" !important;
  position: absolute !important;
  inset: 1.15rem !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  border-radius: 31px !important;
  z-index: 3 !important;
  pointer-events: none !important;
}

.pe-right-card::after {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  background: linear-gradient(115deg, transparent 0%, rgba(255,255,255,.24) 45%, transparent 70%) !important;
  transform: translateX(-130%) !important;
  animation: peShine 5.4s ease-in-out infinite !important;
  z-index: 4 !important;
  pointer-events: none !important;
}

.pe-floating-card,
.pe-main-box {
  position: absolute !important;
  z-index: 5 !important;
}

.pe-floating-card {
  border-radius: 26px !important;
  backdrop-filter: blur(18px) !important;
  box-shadow: 0 22px 55px rgba(0,0,0,.22) !important;
}

.pe-top {
  left: 1.6rem !important;
  right: 1.6rem !important;
  top: 1.6rem !important;
  padding: 1.15rem 1.25rem !important;
  background: rgba(255,255,255,.16) !important;
  border: 1px solid rgba(255,255,255,.28) !important;
  color: #fff !important;
}

.pe-top span {
  display: block !important;
  font-size: .76rem !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  color: rgba(255,255,255,.78) !important;
  font-weight: 950 !important;
}

.pe-top b {
  display: block !important;
  margin-top: .35rem !important;
  font-size: 1.25rem !important;
  line-height: 1.15 !important;
}

.pe-middle {
  left: 1.6rem !important;
  right: 1.6rem !important;
  top: 35% !important;
  padding: 1rem 1.15rem !important;
  background: rgba(255,255,255,.92) !important;
  border: 1px solid rgba(255,255,255,.60) !important;
  color: #061b3a !important;
  animation: peFloat 5.2s ease-in-out infinite !important;
}

.pe-middle strong {
  display: block !important;
  color: #b02680 !important;
  font-size: 1.05rem !important;
  line-height: 1.1 !important;
}

.pe-middle p {
  margin: .35rem 0 0 !important;
  color: #526176 !important;
  font-weight: 650 !important;
}

.pe-main-box {
  left: 1.6rem !important;
  right: 1.6rem !important;
  bottom: 1.6rem !important;
  padding: 1.45rem !important;
  border-radius: 30px !important;
  background: rgba(255,255,255,.97) !important;
  border: 1px solid rgba(255,255,255,.70) !important;
  color: #061b3a !important;
  box-shadow: 0 30px 70px rgba(0,0,0,.28) !important;
  backdrop-filter: blur(18px) !important;
  animation: peBoxUp .9s ease .35s both !important;
}

.pe-badge {
  display: inline-flex !important;
  margin-bottom: .75rem !important;
  border-radius: 999px !important;
  padding: .45rem .75rem !important;
  background: linear-gradient(135deg, #0877c9, #b02680) !important;
  color: #fff !important;
  font-size: .72rem !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
}

.pe-main-box h3 {
  margin: 0 0 .65rem !important;
  color: #061b3a !important;
  font-size: clamp(1.5rem, 2.5vw, 2.2rem) !important;
  line-height: 1.03 !important;
  letter-spacing: -.04em !important;
}

.pe-main-box p {
  margin: 0 !important;
  color: #526176 !important;
  font-weight: 650 !important;
  line-height: 1.6 !important;
}

.pe-check-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: .55rem !important;
  margin-top: 1rem !important;
}

.pe-check-grid span {
  padding: .68rem .78rem !important;
  border-radius: 16px !important;
  background: #f4f8ff !important;
  color: #061b3a !important;
  font-size: .82rem !important;
  font-weight: 850 !important;
}

@keyframes peLeftIn {
  from { opacity: 0; transform: translateX(-34px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes peRightIn {
  from { opacity: 0; transform: translateX(34px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes peCardUp {
  from { opacity: 0; transform: translateY(18px); }
  to { opacity: 1; transform: translateY(0); }
}

@keyframes peBoxUp {
  from { opacity: 0; transform: translateY(26px) scale(.96); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes peShine {
  0%, 56% { transform: translateX(-130%); }
  76%, 100% { transform: translateX(130%); }
}

@keyframes peFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-14px); }
}

@media (max-width: 1100px) {
  .pe-grid {
    grid-template-columns: 1fr !important;
  }

.pe-left-card,
.pe-right-card {
  min-height: auto !important;
}

.pe-right-card {
  min-height: 650px !important;
}
}

@media (max-width: 720px) {
  .pe-section {
    padding: 2.5rem 0 !important;
  }

.pe-left-card,
.pe-right-card {
  border-radius: 30px !important;
}

.pe-left-card {
  padding: 1.35rem !important;
}

.pe-values,
.pe-bottom-strip,
.pe-check-grid {
  grid-template-columns: 1fr !important;
}

.pe-value-card {
  min-height: auto !important;
}

.pe-right-card {
  min-height: 650px !important;
}

.pe-top,
.pe-middle,
.pe-main-box {
  left: 1rem !important;
  right: 1rem !important;
}

.pe-top {
  top: 1rem !important;
}

.pe-middle {
  top: 31% !important;
}

.pe-main-box {
  bottom: 1rem !important;
  padding: 1.05rem !important;
}
}

@media (max-width: 460px) {
  .pe-right-card {
    min-height: 720px !important;
  }

.pe-left-card h2 {
  font-size: 2.15rem !important;
}
}
.social-links {
  display: flex;
  align-items: center;
  gap: 12px;
}

.social-links a {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: center;
  transition:
  background .3s ease,
  transform .3s ease,
  box-shadow .3s ease;
}

.social-links a:hover {
  background: #b02680;
  transform: translateY(-4px);
  box-shadow: 0 10px 25px rgba(176,38,128,.45);
}

.social-links img {
  width: 15px;
  height: 15px;
  object-fit: contain;
  display: block;
}

/* ===== Logo institutionnel mis à jour ===== */
.site-logo,
.logo img,
.brand img,
.nav-logo img,
.header-logo img {
  max-height: 64px;
  width: auto;
  object-fit: contain;
}

/* ===== Images filières/spécialités ===== */
.program-card img,
.specialty-card img,
.filiere-card img,
.course-card img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}


/* ===== Correctif final logo + images filières ===== */
.site-logo,
.brand img.site-logo,
.logo img.site-logo,
.navbar-brand img.site-logo,
.nav-brand img.site-logo,
.header-logo img.site-logo {
  width: auto;
  max-width: 78px;
  max-height: 78px;
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}

.brand,
.logo,
.navbar-brand,
.nav-brand,
.header-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.brand-text {
  display: inline-flex;
  flex-direction: column;
  line-height: 1.05;
}

.brand-text strong {
  color: var(--navy, #061b3a);
  font-weight: 900;
  letter-spacing: .02em;
}

.brand-text small {
  color: var(--mag, #b02680);
  font-weight: 700;
  font-size: .78rem;
}

.program-card img,
.specialty-card img,
.filiere-card img,
.course-card img,
.card img {
  object-fit: cover;
}


/* ===== Correctif final brand-logo demandé ===== */
.brand-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: var(--navy, #061b3a);
}

.brand-logo .site-logo {
  width: auto;
  max-width: 76px;
  max-height: 76px;
  object-fit: contain;
  display: block;
}

.brand-logo span {
  display: inline-flex;
  flex-direction: column;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: .02em;
}

.brand-logo small {
  display: block;
  color: var(--mag, #b02680);
  font-size: .78rem;
  font-weight: 750;
  margin-top: 3px;
}

@media (max-width: 640px) {
  .brand-logo .site-logo {
    max-width: 58px;
    max-height: 58px;
  }

.brand-logo span {
  font-size: .86rem;
}

.brand-logo small {
  font-size: .68rem;
}
}


/* =====================================================
SECTION REDESIGN — APPROCHE PEDAGOGIQUE / LEARNING
===================================================== */

.promise-redesign-section {
  position: relative;
  overflow: hidden;
  padding: clamp(3rem, 6vw, 5rem) 0 !important;
  background:
  radial-gradient(circle at 8% 18%, rgba(8,119,201,.11), transparent 30%),
  radial-gradient(circle at 92% 82%, rgba(176,38,128,.10), transparent 32%),
  linear-gradient(180deg, #f7fbff 0%, #ffffff 100%);
}

.promise-redesign-section::before {
  content: "";
  position: absolute;
  left: -120px;
  top: 20%;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  border: 45px solid rgba(8,119,201,.06);
  pointer-events: none;
}

.promise-redesign-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(390px, .96fr);
  gap: clamp(1.4rem, 3vw, 2.2rem);
  align-items: stretch;
  position: relative;
  z-index: 2;
}

.promise-redesign-content,
.promise-redesign-panel {
  min-height: 620px;
  border-radius: 38px;
  overflow: hidden;
  position: relative;
}

.promise-redesign-content {
  background:
  linear-gradient(135deg, rgba(255,255,255,.98), rgba(247,251,255,.96)),
  radial-gradient(circle at 100% 0%, rgba(8,119,201,.14), transparent 35%);
  border: 1px solid rgba(6,27,58,.08);
  box-shadow: 0 28px 80px rgba(6,27,58,.12);
  padding: clamp(1.5rem, 3vw, 2.45rem);
  display: flex;
  flex-direction: column;
  justify-content: center;
  animation: promiseFadeLeft .85s ease both;
}

.promise-redesign-content::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 9px;
  background: linear-gradient(180deg, var(--blue), var(--mag), var(--gold));
}

.promise-redesign-content::after {
  content: "";
  position: absolute;
  right: -110px;
  top: -110px;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(8,119,201,.16), rgba(176,38,128,.12));
}

.promise-redesign-content > * {
  position: relative;
  z-index: 2;
}

.promise-redesign-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .9rem;
  flex-wrap: wrap;
  margin-bottom: 1rem;
}

.promise-redesign-pill {
  border-radius: 999px;
  background: #fff;
  border: 1px solid rgba(176,38,128,.16);
  color: var(--mag);
  padding: .55rem .85rem;
  font-size: .78rem;
  font-weight: 950;
  box-shadow: 0 12px 28px rgba(6,27,58,.07);
}

.promise-redesign-content h2 {
  color: var(--navy);
  font-size: clamp(2rem, 4.2vw, 3.55rem);
  line-height: .96;
  letter-spacing: -.055em;
  margin: .7rem 0 1rem;
}

.promise-redesign-lead {
  color: #40536d;
  font-size: 1.07rem;
  line-height: 1.68;
  font-weight: 650;
  max-width: 760px;
}

.promise-redesign-steps {
  display: grid;
  gap: .85rem;
  margin-top: 1.5rem;
}

.promise-step {
  display: grid;
  grid-template-columns: 62px 1fr;
  gap: .9rem;
  align-items: start;
  border-radius: 24px;
  background: #fff;
  border: 1px solid rgba(6,27,58,.08);
  padding: 1rem;
  box-shadow: 0 14px 34px rgba(6,27,58,.06);
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
}

.promise-step:hover {
  transform: translateX(7px);
  box-shadow: 0 22px 50px rgba(6,27,58,.13);
  border-color: rgba(176,38,128,.18);
}

.promise-step > span {
  width: 48px;
  height: 48px;
  border-radius: 17px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--blue), var(--mag));
  color: #fff;
  font-weight: 950;
}

.promise-step b {
  display: block;
  color: var(--navy);
  font-size: 1.05rem;
  margin-bottom: .25rem;
}

.promise-step p {
  margin: 0;
  color: #526176;
  font-weight: 620;
  line-height: 1.45;
}

.promise-redesign-panel {
  background:
  linear-gradient(180deg, rgba(6,27,58,.05), rgba(6,27,58,.88)),
  var(--img) center/cover;
  border: 1px solid rgba(255,255,255,.38);
  box-shadow: 0 28px 80px rgba(6,27,58,.18);
  animation: promiseFadeRight .85s ease .12s both;
}

.promise-redesign-panel::before {
  content: "";
  position: absolute;
  inset: 1rem;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 30px;
  z-index: 2;
  pointer-events: none;
}

.promise-panel-overlay {
  position: absolute;
  inset: 0;
  background:
  radial-gradient(circle at 18% 20%, rgba(0,184,217,.30), transparent 28%),
  radial-gradient(circle at 88% 12%, rgba(255,194,71,.20), transparent 24%),
  linear-gradient(135deg, rgba(6,27,58,.10), rgba(176,38,128,.16));
}

.promise-panel-card {
  position: absolute;
  left: 1.5rem;
  right: 1.5rem;
  z-index: 4;
}

.promise-panel-card.top {
  top: 1.5rem;
  padding: 1.1rem 1.2rem;
  border-radius: 25px;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.28);
  color: #fff;
  backdrop-filter: blur(16px);
  box-shadow: 0 22px 55px rgba(0,0,0,.20);
}

.promise-panel-card.top span {
  display: block;
  color: rgba(255,255,255,.78);
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .75rem;
  font-weight: 950;
}

.promise-panel-card.top b {
  display: block;
  margin-top: .3rem;
  font-size: 1.16rem;
  line-height: 1.15;
}

.promise-panel-card.main {
  bottom: 7.2rem;
  padding: 1.35rem;
  border-radius: 28px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(255,255,255,.68);
  color: var(--navy);
  box-shadow: 0 28px 68px rgba(0,0,0,.26);
  backdrop-filter: blur(18px);
}

.promise-badge {
  display: inline-flex;
  border-radius: 999px;
  padding: .45rem .75rem;
  color: #fff;
  background: linear-gradient(135deg, var(--blue), var(--mag));
  font-size: .72rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: .7rem;
}

.promise-panel-card.main h3 {
  margin: 0 0 .6rem;
  font-size: clamp(1.35rem, 2.4vw, 2rem);
  line-height: 1.05;
  color: var(--navy);
  letter-spacing: -.035em;
}

.promise-panel-card.main p {
  color: #526176;
  font-weight: 650;
  margin: 0;
}

.promise-checks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .55rem;
  margin-top: 1rem;
}

.promise-checks span {
  border-radius: 15px;
  background: #f4f8ff;
  color: var(--navy);
  padding: .65rem .75rem;
  font-size: .82rem;
  font-weight: 850;
}

.promise-mini-stats {
  position: absolute;
  left: 1.5rem;
  right: 1.5rem;
  bottom: 1.5rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .65rem;
  z-index: 5;
}

.promise-mini-stats div {
  background: rgba(255,255,255,.92);
  border-radius: 20px;
  padding: .85rem;
  text-align: center;
  box-shadow: 0 16px 35px rgba(0,0,0,.18);
}

.promise-mini-stats strong {
  display: block;
  color: var(--mag);
  font-size: 1.05rem;
  line-height: 1;
  font-weight: 950;
}

.promise-mini-stats span {
  display: block;
  margin-top: .35rem;
  color: #526176;
  font-size: .74rem;
  font-weight: 850;
}

@keyframes promiseFadeLeft {
  from { opacity: 0; transform: translateX(-28px); }
  to { opacity: 1; transform: translateX(0); }
}

@keyframes promiseFadeRight {
  from { opacity: 0; transform: translateX(28px); }
  to { opacity: 1; transform: translateX(0); }
}

@media (max-width: 1060px) {
  .promise-redesign-grid {
    grid-template-columns: 1fr;
  }

.promise-redesign-content,
.promise-redesign-panel {
  min-height: auto;
}

.promise-redesign-panel {
  min-height: 620px;
}
}

@media (max-width: 680px) {
  .promise-step {
    grid-template-columns: 1fr;
  }

.promise-redesign-panel {
  min-height: 720px;
}

.promise-checks,
.promise-mini-stats {
  grid-template-columns: 1fr;
}

.promise-panel-card.main {
  bottom: 13.2rem;
}
}


/* ===== Listes dépendantes filière / spécialité ===== */
.dependent-specialty-label {
  display: block;
}

.specialty-dependent-select {
  width: 100%;
}

select[data-field-select],
select[data-specialty-select] {
  cursor: pointer;
}


/* ===== Sécurité formulaires email ===== */
.form-hp-field {
  position: absolute !important;
  left: -99999px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

/* Scholarship highlight section */
.scholarship-highlight-section {
  background: radial-gradient(circle at top left, rgba(0, 122, 153, 0.12), transparent 34%), linear-gradient(135deg, rgba(248, 250, 252, 0.98), rgba(255, 255, 255, 0.98));
}

.scholarship-highlight-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(360px, 0.82fr);
  gap: 2rem;
  align-items: stretch;
}

.scholarship-media-card,
.scholarship-highlight-content {
  min-height: 100%;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 30px;
  background: #ffffff;
  box-shadow: 0 22px 55px rgba(2, 8, 23, 0.1);
}

.scholarship-media-card {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.scholarship-highlight-image {
  overflow: hidden;
  background: #ffffff;
}

.scholarship-highlight-image img {
  display: block;
  width: 100%;
  height: auto;
}

.scholarship-image-caption {
  display: flex;
  flex: 1;
  flex-direction: column;
  padding: 1.6rem 1.8rem 1.8rem;
}

.scholarship-image-caption > span,
.scholarship-deadline-box span {
  display: inline-flex;
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.scholarship-image-caption h3 {
  margin: 0.55rem 0 0.65rem;
  color: var(--navy);
  font-size: clamp(1.25rem, 2vw, 1.7rem);
  line-height: 1.15;
}

.scholarship-image-caption p,
.scholarship-highlight-content p,
.scholarship-advantages span,
.scholarship-left-details span {
  color: var(--muted);
  line-height: 1.7;
}

.scholarship-left-details {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
  margin: 1.15rem 0;
}

.scholarship-left-details div,
.scholarship-left-note {
  padding: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.95);
}

.scholarship-left-details strong,
.scholarship-left-note b,
.scholarship-advantages strong {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--navy);
}

.scholarship-left-note {
  margin-top: auto;
  border-left: 5px solid var(--accent);
}

.scholarship-left-note p {
  margin-bottom: 0;
}

.scholarship-highlight-content {
  display: flex;
  flex-direction: column;
  padding: 2rem;
}

.scholarship-highlight-content h2 {
  margin: 0.7rem 0 1rem;
  font-size: clamp(1.8rem, 3vw, 2.55rem);
  line-height: 1.05;
}

.scholarship-advantages {
  display: grid;
  gap: 0.85rem;
  margin: 1.3rem 0;
}

.scholarship-advantages div {
  padding: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  background: rgba(248, 250, 252, 0.9);
}

.scholarship-process-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.65rem;
  margin: auto 0 1.1rem;
}

.scholarship-process-row div {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.8rem;
  border-radius: 16px;
  background: rgba(0, 122, 153, 0.08);
  color: var(--navy);
  font-size: 0.9rem;
  font-weight: 800;
}

.scholarship-process-row span {
  display: inline-grid;
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  place-items: center;
  border-radius: 999px;
  background: var(--accent);
  color: #ffffff;
  font-size: 0.8rem;
}

.scholarship-deadline-box {
  margin: 0 0 1.3rem;
  padding: 1.15rem 1.25rem;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--navy), #062a5f);
  color: #ffffff;
}

.scholarship-deadline-box span {
  color: rgba(255, 255, 255, 0.76);
}

.scholarship-deadline-box strong {
  display: block;
  margin-top: 0.25rem;
  font-size: 1.65rem;
  line-height: 1;
}

.scholarship-cta {
  width: 100%;
  justify-content: center;
}

@media (max-width: 900px) {
  .scholarship-highlight-grid {
    grid-template-columns: 1fr;
  }

  .scholarship-highlight-content,
  .scholarship-image-caption {
    padding: 1.5rem;
  }

  .scholarship-left-details,
  .scholarship-process-row {
    grid-template-columns: 1fr;
  }
}

/* Final scholarship section balance fix */
.scholarship-highlight-grid {
  align-items: stretch;
}

.scholarship-media-card,
.scholarship-highlight-content {
  height: 100%;
}

.scholarship-media-card {
  justify-content: flex-start;
}

.scholarship-highlight-image img {
  aspect-ratio: 1536 / 724;
  object-fit: cover;
}

.scholarship-image-caption {
  flex: 1;
  justify-content: flex-start;
  gap: 0.95rem;
}

.scholarship-image-caption h3,
.scholarship-image-caption p,
.scholarship-left-note p,
.scholarship-deadline-box p {
  margin-top: 0;
}

.scholarship-left-details {
  margin: 0;
}

.scholarship-left-impact {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.scholarship-left-impact div {
  padding: 1rem;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 18px;
  background: rgba(0, 122, 153, 0.06);
}

.scholarship-left-impact b {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--navy);
}

.scholarship-left-impact p {
  margin-bottom: 0;
  color: var(--muted);
  line-height: 1.65;
}

.scholarship-left-note {
  margin-top: 0;
}

.scholarship-highlight-content {
  justify-content: flex-start;
  gap: 1.05rem;
}

.scholarship-advantages {
  margin: 0;
}

.scholarship-process-row {
  margin: 0;
}

.scholarship-deadline-box {
  margin: 0;
}

.scholarship-deadline-box p {
  margin: 0.65rem 0 0;
  color: rgba(255, 255, 255, 0.82);
  line-height: 1.55;
}

@media (max-width: 900px) {
  .scholarship-left-impact {
    grid-template-columns: 1fr;
  }
}

/* Scholarship application steps moved to the visual column */
.scholarship-steps-card {
  display: grid;
  gap: 0.9rem;
  margin-top: 0.15rem;
}

.scholarship-step-card {
  position: relative;
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 1rem;
  align-items: center;
  padding: 1rem 1.05rem;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 22px;
  background: linear-gradient(135deg, #ffffff, #f8fafc);
  box-shadow: 0 14px 34px rgba(2, 8, 23, 0.08);
}

.scholarship-step-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 7px;
  background: var(--accent);
}

.scholarship-step-card.step-two::before {
  background: #c40d46;
}

.scholarship-step-card.step-three::before {
  background: #007a99;
}

.scholarship-step-card .step-number {
  position: relative;
  display: grid;
  width: 64px;
  height: 64px;
  place-items: center;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--navy), #083875);
  color: #ffffff;
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: 0.03em;
  box-shadow: 0 12px 24px rgba(2, 8, 23, 0.18);
}

.scholarship-step-card.step-two .step-number {
  background: linear-gradient(135deg, #c40d46, #e64273);
}

.scholarship-step-card.step-three .step-number {
  background: linear-gradient(135deg, #007a99, #08a7bd);
}

.scholarship-step-card strong {
  display: block;
  color: var(--navy);
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.scholarship-step-card p {
  margin: 0.25rem 0 0;
  color: var(--muted);
  line-height: 1.55;
}

.scholarship-left-deadline {
  margin-top: 0.15rem;
  margin-bottom: 0;
  border: 1px solid rgba(255, 193, 7, 0.34);
  background: linear-gradient(135deg, var(--navy), #031a3d 62%, #062a5f);
  box-shadow: 0 16px 36px rgba(2, 8, 23, 0.16);
}

.scholarship-left-deadline strong {
  color: #ffffff;
  font-size: clamp(1.65rem, 3vw, 2.15rem);
}

.scholarship-highlight-content {
  justify-content: space-between;
  gap: 1.2rem;
}

.scholarship-highlight-content .scholarship-advantages {
  margin-bottom: auto;
}

.scholarship-cta {
  margin-top: 0.4rem;
}

@media (max-width: 900px) {
  .scholarship-step-card {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .scholarship-step-card .step-number {
    width: 54px;
    height: 54px;
    border-radius: 18px;
  }
}


/* Horizontal scholarship banner with visible call-to-action */
.scholarship-banner-section {
  background: linear-gradient(135deg, rgba(248, 250, 252, 0.96), rgba(255, 255, 255, 0.98));
}

.scholarship-banner-card {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  background: var(--navy);
  box-shadow: 0 24px 60px rgba(2, 8, 23, 0.18);
}

.scholarship-banner-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1536 / 724;
  object-fit: cover;
}

.scholarship-banner-overlay {
  position: absolute;
  right: 2rem;
  bottom: 2rem;
  left: 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  padding: 1.1rem 1.25rem;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 24px;
  background: rgba(2, 8, 23, 0.72);
  box-shadow: 0 18px 38px rgba(2, 8, 23, 0.28);
  backdrop-filter: blur(8px);
}

.scholarship-banner-text span {
  display: inline-flex;
  margin-bottom: 0.25rem;
  color: #fbbf24;
  font-size: 0.82rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.scholarship-banner-text h2 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.25rem, 2.4vw, 2.2rem);
  line-height: 1.05;
}

.scholarship-banner-cta {
  flex: 0 0 auto;
  min-width: 220px;
  justify-content: center;
  border: 2px solid rgba(255, 255, 255, 0.92);
  box-shadow: 0 16px 34px rgba(196, 13, 70, 0.38);
}

@media (max-width: 760px) {
  .scholarship-banner-card {
    border-radius: 22px;
  }

  .scholarship-banner-overlay {
    right: 1rem;
    bottom: 1rem;
    left: 1rem;
    flex-direction: column;
    align-items: stretch;
    padding: 1rem;
  }

  .scholarship-banner-cta {
    width: 100%;
    min-width: 0;
  }
}


/* === Global background update: soft dark institutional tone === */
:root {
  --paper:#edf3f8;
}
html,
body {
  background:linear-gradient(180deg,#e5ecf4 0%,#edf3f8 42%,#e8eef6 100%);
}
main {
  background:transparent;
}

/* === Final global refinement: institutional darker background inspired by logo colors === */
:root {
  --paper:#dbe5f0;
}
html,
body {
  background:
    radial-gradient(circle at 8% 0%, rgba(0,184,217,.16), transparent 28%),
    radial-gradient(circle at 92% 8%, rgba(176,38,128,.13), transparent 30%),
    linear-gradient(180deg,#d4dfeb 0%,#e1e8f1 44%,#d8e2ec 100%) !important;
}
main {
  background:transparent !important;
}
.header {
  background:rgba(255,255,255,.91) !important;
}
.section .container > .content-panel,
.story-card,
.kpi,
.mini-card,
.quote,
.form-card,
.scholarship-banner-card,
.promo-strip,
.flyer-wrap,
.detail-panel,
.spec-hero-card,
.tab-panel,
.contact-card {
  box-shadow:0 18px 45px rgba(6,27,58,.12);
}
.section-head {
  align-items:flex-start;
}
.section-head h2,
.content-panel h2,
.story-card h2 {
  letter-spacing:-.025em;
}
.check-list li,
.feature-item,
.kpi,
.mini-card,
.quote {
  text-wrap:pretty;
}
.appointment-feedback {
  display: none !important;
}

/* === Landing/index language selector refinement === */
.landing-card {
  width: min(340px, 88%) !important;
  padding: 1.45rem 1.35rem !important;
  border-radius: 22px !important;
}

.landing-logo {
  width: 92px;
  height: 92px;
  object-fit: contain;
  display: block;
  margin: 0 auto .35rem;
}

.landing-card h1,
.welcome-line {
  white-space: nowrap;
  font-size: clamp(1.35rem, 3vw, 1.85rem) !important;
  line-height: 1.05 !important;
  margin: .35rem 0 .65rem !important;
  text-align: center;
}

.landing-card .dual {
  gap: .65rem !important;
  margin: .85rem 0 !important;
  font-size: .78rem !important;
  line-height: 1.45 !important;
}

.landing-card .dual p {
  margin: 0;
}

.landing-card .dual b,
.institute-name b {
  display: inline-block;
  margin-bottom: .25rem;
  font-size: .85rem;
}

.institute-name {
  font-size: .78rem;
  line-height: 1.45;
  text-align: center;
}

.landing-buttons {
  gap: .7rem !important;
  margin-top: .9rem !important;
}

.landing-buttons a {
  padding: .8rem .7rem !important;
  border-radius: 14px !important;
  font-size: .86rem !important;
}

@media(max-width:520px) {
  .landing-card {
    width: min(320px, 90%) !important;
  }

  .landing-card .dual {
    grid-template-columns: 1fr !important;
    text-align: center;
  }

  .landing-card h1,
  .welcome-line {
    font-size: 1.35rem !important;
  }
}


/* === Landing page final correction: +25% sizing, no duplicate language labels === */
.landing-card {
  width:min(425px,92%);
  padding:1.85rem 1.7rem;
  border-radius:28px;
}
.landing-logo {
  width:115px;
  height:115px;
  object-fit:contain;
  display:block;
  margin:0 auto .45rem;
}
.landing-card h1 {
  white-space:nowrap;
  font-size:clamp(1.7rem,3.75vw,2.32rem);
  line-height:1.05;
  margin:.45rem 0 .85rem;
}
.landing-card .dual {
  gap:.85rem;
  margin:1.05rem 0;
  font-size:.98rem;
  line-height:1.48;
}
.landing-card .dual p {
  margin:0;
}
.landing-card .dual b {
  display:none;
}
.landing-buttons {
  gap:.9rem;
  margin-top:1.15rem;
}
.landing-buttons a {
  padding:1rem .9rem;
  border-radius:18px;
  font-size:1.08rem;
}
@media(max-width:520px) {
  .landing-card {
    width:min(390px,92%);
    padding:1.55rem 1.25rem;
  }
  .landing-card .dual {
    grid-template-columns:1fr;
    text-align:center;
  }
  .landing-card h1 {
    font-size:1.58rem;
  }
  .landing-logo {
    width:100px;
    height:100px;
  }
  .landing-buttons a {
    font-size:1rem;
  }
}


/* === Landing page typography enhancement === */
.landing-card .dual {
  gap: 1rem !important;
  margin: 1.1rem 0 !important;
  font-size: 1.18rem !important;
  line-height: 1.6 !important;
  font-weight: 600 !important;
}

.landing-card .dual p,
.landing-card .dual div {
  margin: 0 !important;
  color: var(--navy) !important;
}

.landing-card {
  width: min(700px, 94%) !important;
  padding: 3.6rem !important;
}

.landing-card h1 {
  font-size: clamp(2.6rem, 5vw, 4.6rem) !important;
}

.landing-buttons a {
  padding: 1.35rem !important;
  font-size: 1.05rem !important;
  font-weight: 900 !important;
}

@media(max-width: 640px) {
  .landing-card .dual {
    font-size: 1rem !important;
    line-height: 1.5 !important;
  }

  .landing-card {
    padding: 2rem !important;
  }
}


/* === LANDING / INDEX FINAL ADJUSTMENTS === */

.landing-logo{
  width:155px !important;
  height:auto !important;
  object-fit:contain !important;
  display:block !important;
  margin:0 auto 1rem !important;
}

/* bilingual descriptions */
.landing-card .dual{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:1.4rem !important;
  margin:1.4rem 0 1.6rem !important;
  align-items:start !important;
}

.landing-card .dual > div{
  text-align:center !important;
}

.landing-card .dual p{
  margin:0 0 1rem !important;
  color:#4B0082 !important;
  font-size:1.15rem !important;
  line-height:1.55 !important;
  font-weight:700 !important;
}

@media(max-width:640px){
  .landing-card .dual{
    grid-template-columns:1fr !important;
  }

  .landing-card .dual p{
    font-size:1rem !important;
  }

  .landing-logo{
    width:130px !important;
  }
}
/* === Landing text spacing optimization === */

.landing-card .dual p{
  line-height:1.18 !important;   /* réduit l’interligne */
  margin-bottom:.22rem !important; /* réduit fortement l’espace avant les boutons */
}

.landing-buttons{
  margin-top:.35rem !important;
}

/* === ROOT LANDING PAGE FINAL SAFETY PATCH === */
.landing-card h2{
  white-space:nowrap !important;
  font-size:clamp(1.7rem,3.75vw,2.32rem) !important;
  line-height:1.05 !important;
  margin:.45rem 0 .85rem !important;
  color:var(--navy) !important;
  text-align:center !important;
}
.landing-card .dual p{
  text-align:center !important;
  color:#4B0082 !important;
  line-height:1.18 !important;
  margin-bottom:.22rem !important;
}
.landing-buttons{
  margin-top:.35rem !important;
}
@media(max-width:520px){
  .landing-card h2{
    white-space:normal !important;
    font-size:1.58rem !important;
  }
}
