*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Barlow',sans-serif;background:#F4F7FB;color:#0F2057;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,svg{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

:root{
  /* ── Logo-derived palette ── */
  --blue-deep:#0F2057;        /* darkest navy from logo outer ring */
  --blue-royal:#1A3A8F;       /* main royal blue of logo rings */
  --blue-mid:#2351B5;         /* slightly lighter royal blue */
  --blue-light:#EEF2FB;       /* very light blue tint for section bg */
  --blue-pale:rgba(26,58,143,0.08);
  --blue-border:rgba(26,58,143,0.2);

  --crimson:#8B1A1A;          /* dark red slash in logo */
  --crimson-light:#A82020;
  --crimson-pale:rgba(139,26,26,0.10);
  --crimson-border:rgba(139,26,26,0.25);

  --white:#FFFFFF;
  --grey-light:#F4F7FB;       /* section alternating bg */
  --grey-mid:#E8EDF6;

  /* text */
  --txt-dark:#0F2057;
  --txt-mid:#2C3E6B;
  --txt-soft:rgba(15,32,87,0.6);
  --txt-faint:rgba(15,32,87,0.35);

  /* dark section overrides (hero, footer) */
  --w:#fff;
  --w90:rgba(255,255,255,0.9);
  --w60:rgba(255,255,255,0.6);
  --w30:rgba(255,255,255,0.3);
  --w08:rgba(255,255,255,0.08);
  --w04:rgba(255,255,255,0.04);
  --b06:rgba(255,255,255,0.08);
}

/* ═══════════════════ NAV ═══════════════════ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  height:68px;display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(16px,4vw,60px);
  background:rgba(15,32,87,0.85);
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-bottom:1px solid rgba(255,255,255,0.08);
  transition:background .3s;
}
#nav.scrolled{background:rgba(15,32,87,0.98)}

.nav-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-mark{width:34px;height:34px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-name{font-family:'Bebas Neue',sans-serif;font-size:clamp(16px,2.2vw,21px);letter-spacing:2px;color:var(--w)}
.logo-tagline{font-family:'Barlow Condensed',sans-serif;font-size:9px;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,0.55);margin-top:2px}

.nav-links{display:flex;align-items:center;gap:clamp(18px,2.8vw,38px);list-style:none}
.nav-links a{
  font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--w60);transition:color .25s;position:relative
}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--crimson);transition:width .3s}
.nav-links a:hover,.nav-links a.active{color:var(--w)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

.nav-btn{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--w);background:var(--crimson);
  padding:9px 22px;border:none;cursor:pointer;
  clip-path:polygon(6px 0%,100% 0%,calc(100% - 6px) 100%,0% 100%);
  transition:background .25s,transform .2s;white-space:nowrap;flex-shrink:0
}
.nav-btn:hover{background:var(--crimson-light);transform:translateY(-1px)}

/* Hamburger */
.nav-burger{
  display:none;flex-direction:column;justify-content:center;gap:5px;
  width:36px;height:36px;background:none;border:none;cursor:pointer;padding:4px;flex-shrink:0
}
.nav-burger span{display:block;width:100%;height:2px;background:var(--w);border-radius:2px;transition:transform .3s,opacity .3s;transform-origin:center}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Drawer */
.nav-drawer{
  display:none;position:fixed;top:68px;left:0;right:0;
  background:rgba(15,32,87,0.98);backdrop-filter:blur(22px);
  flex-direction:column;padding:20px clamp(16px,5vw,40px) 28px;
  border-bottom:1px solid rgba(255,255,255,0.08);z-index:490;
  opacity:0;transform:translateY(-6px);
  transition:opacity .25s,transform .25s;pointer-events:none
}
.nav-drawer.open{display:flex;opacity:1;transform:translateY(0);pointer-events:all}
.nav-drawer a{
  font-family:'Barlow Condensed',sans-serif;font-size:17px;letter-spacing:2px;
  text-transform:uppercase;color:var(--w60);padding:13px 0;
  border-bottom:1px solid rgba(255,255,255,0.07);transition:color .2s
}
.nav-drawer a:last-of-type{border:none}
.nav-drawer a:hover{color:var(--w)}
.drawer-cta{
  margin-top:18px;display:block;background:var(--crimson);color:var(--w);
  text-align:center;padding:13px 24px;
  font-family:'Barlow Condensed',sans-serif;font-size:13px;letter-spacing:2.5px;text-transform:uppercase;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)
}

/* ═══════════════════ HERO ═══════════════════ */
#hero{
  position:relative;width:100%;height:130svh;min-height:580px;
  display:flex;align-items:center;overflow:hidden
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.hero-veil{
  position:absolute;inset:0;z-index:3;
  background:linear-gradient(100deg,rgba(15,32,87,.97) 0%,rgba(15,32,87,.88) 38%,rgba(15,32,87,.42) 62%,rgba(15,32,87,.04) 100%)
}
.hero-content{
  position:relative;z-index:10;
  padding:80px clamp(16px,5vw,60px) 140px;
  max-width:min(640px,92vw);
  animation:fadeUp 1s ease both
}
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:none}}

.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:18px;animation:fadeUp 1s .1s ease both}
.eyebrow-bar{width:36px;height:2px;background:var(--crimson);flex-shrink:0}
.eyebrow-txt{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,0.65);font-weight:600}

.hero-h1{
  font-family:'Bebas Neue',sans-serif;
  font-size:clamp(42px,7.2vw,86px);
  line-height:.93;letter-spacing:1px;color:var(--w);
  margin-bottom:20px;animation:fadeUp 1s .18s ease both
}
.hero-h1 em{color:#C0D4FF;font-style:normal}

.hero-p{
  font-size:clamp(14px,1.7vw,16px);font-weight:300;line-height:1.78;
  color:var(--w60);max-width:430px;margin-bottom:34px;
  animation:fadeUp 1s .28s ease both
}
.hero-btns{display:flex;align-items:center;gap:14px;flex-wrap:wrap;animation:fadeUp 1s .38s ease both}

.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:2.5px;
  text-transform:uppercase;font-weight:600;cursor:pointer;border:none;
  transition:all .25s;white-space:nowrap;
  clip-path:polygon(8px 0%,100% 0%,calc(100% - 8px) 100%,0% 100%)
}
.btn-crimson{color:var(--w);background:var(--crimson);padding:13px 28px}
.btn-crimson:hover{background:var(--crimson-light);transform:translateY(-2px);box-shadow:0 10px 30px rgba(139,26,26,.45)}
.btn-outline{color:var(--w60);background:transparent;border:1px solid var(--w30);padding:12px 24px}
.btn-outline:hover{color:var(--w);border-color:var(--w60)}
.btn svg{width:15px;height:15px;flex-shrink:0;transition:transform .25s}
.btn:hover svg{transform:translateX(3px)}

/* Stats bar */
.hero-stats{
  position:absolute;bottom:0;left:0;right:0;z-index:10;
  display:flex;flex-wrap:wrap;
  background:rgba(15,32,87,0.92);backdrop-filter:blur(20px);
  border-top:1px solid rgba(255,255,255,0.08);
  animation:fadeUp 1s .55s ease both
}
.stat{
  flex:1 1 110px;padding:clamp(12px,2vw,20px) clamp(14px,2.5vw,38px);
  border-right:1px solid rgba(255,255,255,0.07);display:flex;flex-direction:column;gap:3px
}
.stat:last-child{border-right:none}
.stat-n{font-family:'Bebas Neue',sans-serif;font-size:clamp(24px,3.5vw,34px);color:#C0D4FF;line-height:1}
.stat-l{font-family:'Barlow Condensed',sans-serif;font-size:clamp(9px,1.1vw,11px);letter-spacing:2px;text-transform:uppercase;color:var(--w60)}

/* ═══════════════════ SECTION UTILS ═══════════════════ */
section{width:100%}
.container{max-width:1280px;margin:0 auto;padding:0 clamp(16px,5vw,60px)}
.section-pad{padding:clamp(60px,8vw,100px) clamp(16px,5vw,60px)}

.sec-label{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.sec-dot{width:7px;height:7px;background:var(--crimson);transform:rotate(45deg);flex-shrink:0}
.sec-label-txt{font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:3.5px;text-transform:uppercase;color:var(--crimson);font-weight:600}

/* Light section headings */
.sec-h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(30px,4.5vw,54px);letter-spacing:1px;line-height:.95;color:var(--blue-deep)}
.sec-p{font-size:clamp(14px,1.5vw,15px);font-weight:300;line-height:1.82;color:var(--txt-soft)}

/* Dark section overrides */
.dark-section .sec-h2{color:var(--w)}
.dark-section .sec-p{color:var(--w60)}
.dark-section .sec-label-txt{color:rgba(192,212,255,0.8)}
.dark-section .sec-dot{background:var(--crimson)}

.divider{width:100%;height:1px;background:var(--grey-mid)}

/* fade-up on scroll */
.fu{opacity:0;transform:translateY(32px);transition:opacity .7s ease,transform .7s ease}
.fu.vis{opacity:1;transform:none}
.fu-d1{transition-delay:.1s}.fu-d2{transition-delay:.2s}.fu-d3{transition-delay:.3s}.fu-d4{transition-delay:.4s}

/* ═══════════════════ ABOUT ═══════════════════ */
#about{background:var(--blue-light)}
.about-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:clamp(36px,6vw,80px);align-items:center
}
.about-frame{position:relative}
.about-inner{
  width:100%;aspect-ratio:4/3;
  background:linear-gradient(135deg,#0F2057 0%,#1A3A8F 55%,#2351B5 100%);
  border:1px solid var(--blue-border);position:relative;overflow:hidden;
  display:flex;align-items:center;justify-content:center
}
.corner-mark{position:absolute;width:22px;height:22px;border-color:var(--crimson);border-style:solid;border-width:0}
.cm-tl{top:-1px;left:-1px;border-top-width:2px;border-left-width:2px}
.cm-tr{top:-1px;right:-1px;border-top-width:2px;border-right-width:2px}
.cm-bl{bottom:-1px;left:-1px;border-bottom-width:2px;border-left-width:2px}
.cm-br{bottom:-1px;right:-1px;border-bottom-width:2px;border-right-width:2px}

.about-badge{
  position:absolute;bottom:-16px;right:-16px;
  background:var(--crimson);padding:18px 22px;text-align:center
}
.badge-n{font-family:'Bebas Neue',sans-serif;font-size:clamp(30px,4vw,42px);color:var(--w);line-height:1;display:block}
.badge-t{font-family:'Barlow Condensed',sans-serif;font-size:9px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.85);display:block;margin-top:2px}

.about-text .sec-h2{margin-bottom:18px}
.about-text .sec-p{margin-bottom:24px}
.check-list{display:flex;flex-direction:column;gap:11px;margin-bottom:36px}
.check-item{display:flex;align-items:flex-start;gap:12px;font-family:'Barlow Condensed',sans-serif;font-size:clamp(12px,1.4vw,14px);letter-spacing:.8px;text-transform:uppercase;color:var(--txt-dark);line-height:1.4}
.check-box{width:20px;height:20px;background:var(--crimson-pale);border:1px solid var(--crimson-border);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.check-box svg{color:var(--crimson)}

/* ═══════════════════ SERVICES ═══════════════════ */
#services{background:var(--blue-light)}
.services-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:clamp(36px,5vw,56px)}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--grey-mid);border:1px solid var(--grey-mid)}
.svc{
  background:var(--white);padding:clamp(22px,3vw,36px) clamp(18px,2.5vw,30px);
  position:relative;overflow:hidden;cursor:pointer;
  transition:background .3s,box-shadow .3s
}
.svc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--crimson);transform:scaleX(0);transform-origin:left;transition:transform .35s}
.svc:hover{background:#F8F0F0;box-shadow:0 4px 24px rgba(139,26,26,.08)}
.svc:hover::after{transform:scaleX(1)}
.svc-num{position:absolute;top:18px;right:18px;font-family:'Bebas Neue',sans-serif;font-size:44px;color:rgba(26,58,143,.06);line-height:1;pointer-events:none}
.svc-icon{width:42px;height:42px;color:var(--blue-royal);margin-bottom:18px}
.svc-name{font-family:'Barlow Condensed',sans-serif;font-size:clamp(14px,1.7vw,18px);font-weight:600;text-transform:uppercase;color:var(--blue-deep);margin-bottom:10px;letter-spacing:.5px}
.svc-desc{font-size:clamp(12px,1.3vw,14px);font-weight:300;line-height:1.65;color:var(--txt-soft)}

/* ═══════════════════ VALUES + VISION ═══════════════════ */
#values{background:var(--blue-deep)}
.vv-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,56px)}
.vv-card{
  background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);
  padding:clamp(28px,3.5vw,44px);position:relative;overflow:hidden
}
.vv-card::before{content:'';position:absolute;top:0;left:0;width:3px;height:100%;background:var(--crimson)}
.vv-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(26px,3.5vw,40px);color:#C0D4FF;margin-bottom:24px;letter-spacing:1px}
.vv-list{display:flex;flex-direction:column;gap:14px}
.vv-item{display:flex;align-items:flex-start;gap:12px;font-size:clamp(13px,1.5vw,15px);font-weight:300;line-height:1.65;color:var(--w60)}
.vv-bullet{width:6px;height:6px;background:var(--crimson);transform:rotate(45deg);flex-shrink:0;margin-top:7px}

/* ═══════════════════ PROJECTS ═══════════════════ */
#projects{background:var(--white)}
.proj-tabs{display:flex;gap:0;margin-bottom:clamp(28px,4vw,44px);border-bottom:2px solid var(--grey-mid)}
.proj-tab{
  font-family:'Barlow Condensed',sans-serif;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--txt-soft);padding:12px 24px;cursor:pointer;background:none;border:none;
  border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .25s
}
.proj-tab.active{color:var(--crimson);border-bottom-color:var(--crimson)}
.proj-tab:hover{color:var(--blue-deep)}

.proj-table{width:100%;border-collapse:collapse}
.proj-table th{
  font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:var(--blue-royal);padding:12px 20px;text-align:left;border-bottom:2px solid var(--grey-mid);
  background:var(--blue-light)
}
.proj-table td{
  padding:16px 20px;font-size:14px;font-weight:300;color:var(--txt-mid);
  border-bottom:1px solid var(--grey-mid);vertical-align:top
}
.proj-table tr:hover td{background:var(--blue-light);color:var(--blue-deep)}
.proj-table td:first-child{
  font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--blue-royal);
  width:56px;text-align:center
}
.proj-partner{
  display:inline-block;font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;padding:3px 10px;border:1px solid var(--crimson-border);
  color:var(--crimson);margin-bottom:4px
}
.proj-name{font-size:14px;font-weight:400;color:var(--blue-deep);margin-bottom:4px}
.proj-region{font-size:13px;font-weight:300;color:var(--txt-soft)}

.proj-panel{display:none}
.proj-panel.active{display:block}

/* ═══════════════════ TEAM / RESOURCES ═══════════════════ */
#team{background:var(--blue-light)}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,4vw,52px)}
.res-block{background:var(--white);border:1px solid var(--grey-mid);padding:clamp(24px,3vw,38px)}
.res-title{
  font-family:'Barlow Condensed',sans-serif;font-size:11px;letter-spacing:3px;text-transform:uppercase;
  color:var(--blue-royal);margin-bottom:24px;display:flex;align-items:center;gap:10px
}
.res-title::after{content:'';flex:1;height:1px;background:var(--grey-mid)}
.res-list{display:flex;flex-direction:column;gap:12px}
.res-item{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;background:var(--blue-light);
  border-left:2px solid var(--blue-royal)
}
.res-role{font-family:'Barlow Condensed',sans-serif;font-size:13px;letter-spacing:1px;text-transform:uppercase;color:var(--blue-deep)}
.res-count{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--blue-royal);line-height:1}

/* ═══════════════════ CONTACT ═══════════════════ */
#contact{background:var(--blue-deep);position:relative;overflow:hidden}
#contact::before{
  content:'CONTACT';
  position:absolute;font-family:'Bebas Neue',sans-serif;
  font-size:clamp(80px,15vw,200px);color:rgba(255,255,255,.03);
  right:-20px;top:50%;transform:translateY(-50%);
  pointer-events:none;letter-spacing:4px;white-space:nowrap
}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,72px);align-items:start}
.contact-info .sec-h2{margin-bottom:20px;color:var(--w)}
.contact-info .sec-p{margin-bottom:36px;color:var(--w60)}

.contact-cards{display:flex;flex-direction:column;gap:16px;margin-bottom:36px}
.ccard{
  display:flex;align-items:center;gap:16px;
  padding:18px 20px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);
  border-left:2px solid var(--crimson)
}
.ccard-icon{width:38px;height:38px;background:var(--crimson-pale);border:1px solid var(--crimson-border);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ccard-icon svg{width:18px;height:18px;color:#C0D4FF}
.ccard-label{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,212,255,0.7);margin-bottom:3px}
.ccard-val{font-size:14px;font-weight:300;color:var(--w90)}

.contact-persons{display:flex;flex-direction:column;gap:16px}
.person{padding:22px 24px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1)}
.person-name{font-family:'Barlow Condensed',sans-serif;font-size:clamp(15px,1.8vw,18px);font-weight:600;text-transform:uppercase;color:var(--w);letter-spacing:.5px;margin-bottom:4px}
.person-role{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,212,255,0.7);margin-bottom:14px}
.person-contacts{display:flex;flex-direction:column;gap:6px}
.person-contacts a{font-size:13px;font-weight:300;color:var(--w60);transition:color .2s;display:flex;align-items:center;gap:8px}
.person-contacts a:hover{color:#C0D4FF}
.person-contacts a svg{width:14px;height:14px;flex-shrink:0;opacity:.5}

/* Contact form */
.cform{display:flex;flex-direction:column;gap:16px}
.cform-group{display:flex;flex-direction:column;gap:6px}
.cform-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cform label{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(192,212,255,0.7)}
.cform input,.cform textarea,.cform select{
  width:100%;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);
  color:var(--w);font-family:'Barlow',sans-serif;font-size:14px;font-weight:300;
  padding:12px 16px;outline:none;
  transition:border-color .25s,background .25s
}
.cform input::placeholder,.cform textarea::placeholder{color:rgba(255,255,255,.25);font-size:13px}
.cform input:focus,.cform textarea:focus,.cform select:focus{border-color:rgba(139,26,26,.6);background:rgba(255,255,255,.09)}
.cform textarea{resize:vertical;min-height:120px}
.cform select{appearance:none;cursor:pointer}
.cform option{background:#0F2057;color:#fff}

/* ═══════════════════ FOOTER ═══════════════════ */
footer{background:#080F2A;padding:clamp(40px,5vw,60px) clamp(16px,5vw,60px) clamp(20px,3vw,32px);border-top:1px solid rgba(255,255,255,.06)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(20px,4vw,44px);margin-bottom:clamp(30px,4vw,48px)}
.footer-brand p{font-size:13px;font-weight:300;line-height:1.72;color:var(--w60);margin-top:14px;max-width:250px}
.footer-col h5{font-family:'Barlow Condensed',sans-serif;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:rgba(192,212,255,0.6);margin-bottom:18px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:13px;font-weight:300;color:var(--w60);transition:color .2s}
.footer-col ul a:hover{color:var(--w)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.05);padding-top:22px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-copy{font-size:12px;color:rgba(255,255,255,.25);font-weight:300}
.footer-legal{display:flex;gap:20px;flex-wrap:wrap}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.25);transition:color .2s}
.footer-legal a:hover{color:var(--w60)}

/* ═══════════════════ RESPONSIVE ═══════════════════ */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
}
@media(max-width:768px){
  .nav-links,.nav-btn{display:none}
  .nav-burger{display:flex}
  .hero-veil{background:linear-gradient(175deg,rgba(15,32,87,.96) 0%,rgba(15,32,87,.84) 60%,rgba(15,32,87,.65) 100%)}
  .hero-content{padding-bottom:150px}
  .about-grid{grid-template-columns:1fr}
  .about-frame{order:-1}
  .about-badge{bottom:-12px;right:-12px}
  .vv-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .cform-row{grid-template-columns:1fr}
  .stat{flex:1 1 45%;border-right:none;border-bottom:1px solid rgba(255,255,255,.07)}
  .stat:nth-child(odd){border-right:1px solid rgba(255,255,255,.07)}
  .stat:nth-last-child(-n+2){border-bottom:none}
}
@media(max-width:480px){
  #nav{height:60px}
  .nav-drawer{top:60px}
  .hero-btns{flex-direction:column;align-items:flex-start}
  .btn{width:100%;justify-content:center}
  .services-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .proj-table td,.proj-table th{padding:10px 12px}
  .proj-table td:first-child{display:none}
  .about-badge{position:static;display:inline-block;margin-top:14px}
}
/* Empêcher le tableau de briser la mise en page sur mobile */
.proj-panel {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.proj-table {
  min-width: 600px; /* Force une largeur minimale pour garder le tableau lisible en scroll horizontal */
  width: 100%;
}
/* 1. Ensure every logo card shares the exact same grid/flex space */
.partner-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 15px;
  box-sizing: border-box;
}

/* 2. Create a uniform boundary for the logo container */
.partner-logo-wrap {
  width: 100%;         /* Spans the width of the card */
  height: 80px;        /* 🎯 Forces every logo area to have the exact same height */
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px; /* Space between logo and text */
  border-radius: 6px;  /* Optional: rounds the backdrop corners */
  padding: 10px;       /* Keeps logos from touching the very edge */
  box-sizing: border-box;
}

/* 3. Standardize the image behavior inside the container */
.partner-logo {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  /* 🎯 Crucial: prevents stretching; fits any aspect ratio beautifully */
  object-fit: contain; 
}

/* 4. Fix fallback text boxes to match the exact same size */
.partner-fallback {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 1.1rem;
  color: #555;
}
.carousel-viewport {
  overflow: hidden; /* Hides elements waiting in queue */
  width: 100%;
}

.carousel-track {
  display: flex;
  transition: transform 0.4s ease-in-out; /* Makes the slide smooth */
  width: 100%;
}

.partner-card {
  flex: 0 0 25%; /* Default for 4 items per view (100% / 4) */
  box-sizing: border-box;
}

/* Responsive adjustments matching the JS break points */
@media (max-width: 1023px) { .partner-card { flex: 0 0 33.333%; } }
@media (max-width: 767px)  { .partner-card { flex: 0 0 50%; } }
@media (max-width: 479px)  { .partner-card { flex: 0 0 100%; } }





/* ==========================================================================
   ── GALLERY GRID LAYOUT 
   ========================================================================== */
.gallery-grid {
  display: grid;
  /* Configures a clean 3-column system that wraps naturally */
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
  grid-auto-flow: dense; /* Instructs the browser to fill grid gaps automatically */
  width: 100%;
}

.gal-item {
  position: relative;
  overflow: hidden;
  border-radius: 6px;
  height: 250px; /* Forces all standard gallery slots to share equal height */
  background: var(--blue-deep);
}

/* Fixes the wide card structural allocation */
.gal-item.gal-wide {
  grid-column: span 2;
}

.gal-item img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* Prevents raw image files from getting squished/warped */
  transition: transform 0.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.gal-item:hover img {
  transform: scale(1.06); /* Adds a premium interactive zoom on hover */
}

/* Image label text styles */
.gal-caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(15, 32, 87, 0.85));
  padding: 24px 16px 12px;
  color: var(--white);
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 15px;
  letter-spacing: 1px;
  text-transform: uppercase;
  pointer-events: none;
}

/* Invisible block fallback if an Unsplash file breaks or fails to download */
.gal-error {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--grey-mid);
}
.gal-error::before {
  content: "📷 Image en cours de chargement...";
  color: var(--txt-soft);
  font-size: 13px;
}
.gal-error img {
  display: none !important;
}

/* Mobile responsive tracks override */
@media (max-width: 768px) {
  .gallery-grid {
    grid-template-columns: 1fr; /* Switch to a safe 1-column layout on phones */
  }
  .gal-item.gal-wide {
    grid-column: span 1; /* Turn off double width spanning on small viewports */
  }
}
  .search-section { background: #ffffff; padding: 30px; border-radius: 4px; border: 1px solid var(--blue-border); margin-top: -40px; box-shadow: 0 4px 20px rgba(15,32,87,0.05); z-index: 10; position: relative; }
  .search-form { display: grid; grid-template-columns: 2fr 1fr auto; gap: 15px; }
  @media(max-width:768px){ .search-form { grid-template-columns: 1fr; } }
  
  .form-control { width: 100%; padding: 12px; font-family: 'Barlow', sans-serif; border: 1px solid var(--blue-border); background: #fff; color: var(--blue-deep); border-radius: 4px; font-size: 0.95rem; }
  .form-control:focus { border-color: var(--blue-royal); outline: none; }
  
  .job-card { background: #ffffff; padding: 30px; border: 1px solid var(--blue-border); border-radius: 4px; margin-bottom: 20px; display: flex; justify-content: space-between; align-items: center; gap: 20px; transition: all 0.3s ease; }
  .job-card:hover { transform: translateY(-2px); box-shadow: 0 5px 15px rgba(15,32,87,0.06); border-color: var(--blue-royal); }
  @media(max-width:576px){ .job-card { flex-direction: column; align-items: flex-start; } .job-card .btn { width: 100%; text-align: center; justify-content: center; } }
  
  .badge-exp { display: inline-block; padding: 4px 10px; background: var(--blue-light); color: var(--blue-royal); font-family: 'Barlow', sans-serif; font-size: 0.8rem; font-weight: 500; border-radius: 4px; margin-top: 5px; }
