:root{
  --bg:#f4f7fb;--surface:#ffffff;--text:#162235;--muted:#5c6b80;--line:#dde5f0;
  --brand:#1d63c6;--brand2:#4fd3c4;--hero:#0f2b46;--hero2:#133a60;--accent:#eef4ff;
  --shadow:0 18px 40px rgba(20,41,74,.08);--radius:24px;
}
*{box-sizing:border-box} html{scroll-behavior:smooth;scroll-padding-top:96px} body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;color:var(--text);background:var(--bg);line-height:1.6}
a{text-decoration:none;color:inherit} img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 40px));margin:0 auto}
.site-header{position:sticky;top:0;z-index:30;background:rgba(15,43,70,.94);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.08)}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:18px}
.brand{display:flex;align-items:center;color:#fff;min-width:0}.brand img{height:72px;width:auto;max-width:min(58vw,500px)}
.nav{display:flex;align-items:center;gap:22px;flex-wrap:wrap}.nav a{color:#e9f0f8;font-weight:700;opacity:.96}.nav a:hover,.lang a:hover{color:#fff}
.lang{display:flex;gap:10px}.lang a{color:#bad0ea;font-size:14px;font-weight:800;padding:8px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.12)}.lang a.active{background:#fff;color:#0f2b46}
.hero{background:linear-gradient(100deg,rgba(15,43,70,.96) 0%, rgba(15,43,70,.90) 36%, rgba(15,43,70,.55) 65%, rgba(15,43,70,.18) 100%), url('assets/hero.png') center/cover no-repeat;color:#fff}
.hero .container{padding:88px 0 90px}.hero-copy{max-width:660px}.hero h1{margin:0 0 16px;font-size:clamp(40px,5vw,64px);line-height:1.04;color:#fff;text-shadow:0 2px 16px rgba(0,0,0,.18)}.hero p{margin:0 0 30px;font-size:20px;color:#e3edf7;max-width:640px}.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 22px;border-radius:12px;font-weight:800;border:1px solid transparent;transition:.2s ease}.btn.primary{background:linear-gradient(90deg,var(--brand),#2b86f7);color:#fff;box-shadow:0 10px 24px rgba(29,99,198,.3)}.btn.secondary{background:#fff;color:#123050}.btn.ghost{background:transparent;border-color:#a8bfdc;color:#fff}
section{padding:72px 0}.section-intro{margin-bottom:28px}.section-intro h2{margin:0 0 12px;font-size:clamp(30px,4vw,44px);line-height:1.08}.section-intro p{margin:0;max-width:940px;color:var(--muted);font-size:19px}
.focus-title{font-size:clamp(26px,3vw,34px);margin:28px 0 18px}
.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px}.card{background:var(--surface);border:1px solid var(--line);border-radius:22px;overflow:hidden;box-shadow:var(--shadow)}.card img{height:200px;width:100%;object-fit:cover}.card-body{padding:22px}.card h3{margin:0 0 10px;font-size:28px;line-height:1.06}.card p{margin:0;color:var(--muted);font-size:17px}
.band{background:linear-gradient(90deg,rgba(15,43,70,.96),rgba(15,43,70,.88)), url('assets/training.png') center/cover no-repeat;color:#fff}.band-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}.band h2{margin:0 0 14px;font-size:clamp(30px,4vw,46px)}.band h3{margin:0 0 16px;font-size:clamp(22px,3vw,30px);color:#fff}.band p,.band li{color:#e2edf8;font-size:18px}.band .image-panel img{border-radius:22px;box-shadow:var(--shadow)}
.about-section .panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.about-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:center}.about-wrap img{border-radius:22px;box-shadow:var(--shadow)}.panel h2{margin:0 0 16px;font-size:clamp(28px,3vw,40px)}.panel p{font-size:18px}.ticks{padding:0;margin:20px 0 0;list-style:none}.ticks li{padding-left:28px;position:relative;margin:0 0 10px;color:var(--muted);font-size:18px}.ticks li::before{content:'✓';position:absolute;left:0;top:0;color:var(--brand);font-weight:900}
.contact-panel{margin-top:28px;background:linear-gradient(180deg,#ffffff,#f6f9ff);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.contact-layout{display:grid;grid-template-columns:320px 1fr;gap:30px;align-items:center}.contact-photo img{width:100%;aspect-ratio:9/11;object-fit:cover;border-radius:22px;box-shadow:var(--shadow)}
.contact-copy p,.contact-list,.contact-note{font-size:19px}.contact-list{display:grid;gap:14px;margin:20px 0 22px}.contact-item{display:flex;gap:12px;align-items:flex-start;color:var(--text)}.contact-item .emoji{width:26px;display:inline-block}.contact-item strong{color:var(--text)}.contact-item a{color:var(--brand)}
.contact-note{color:var(--muted);max-width:48rem}
.legal-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px}.legal-card{background:var(--surface);border:1px solid var(--line);border-radius:20px;padding:22px;box-shadow:var(--shadow)}.legal-card h3{margin:0 0 10px}
footer{background:#0f2b46;color:#d8e4f4;padding:26px 0}.footer-inner{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap}.footer-links{display:flex;gap:16px;flex-wrap:wrap}.legal-page{padding:70px 0}.legal-page h1{font-size:42px;margin:0 0 20px}.legal-page h2{margin-top:30px}
.anchor-target{scroll-margin-top:100px}
@media (max-width: 1080px){.cards{grid-template-columns:repeat(2,minmax(0,1fr))}.band-inner,.about-wrap,.contact-layout{grid-template-columns:1fr}.nav{gap:16px}.contact-photo img{max-width:420px}}
@media (max-width: 820px){.header-inner{flex-wrap:wrap;justify-content:center}.nav{order:3;width:100%;justify-content:center}.brand{justify-content:center;width:100%}.brand img{max-width:min(86vw,500px);height:auto}.lang{order:2}}
@media (max-width: 720px){.container{width:min(100% - 28px,1180px)}.hero .container{padding:64px 0 68px}.hero h1{font-size:40px}.hero p{font-size:18px}.cards,.legal-grid{grid-template-columns:1fr}.card img{height:220px}.section-intro p,.band p,.band li,.contact-copy p,.contact-list,.contact-note,.panel p,.ticks li{font-size:17px}.footer-inner{flex-direction:column}}

/* v12 fixes */
.audience-visual img,
.who-visual img,
.target-visual img,
.two-col img,
.about-grid img,
.section-media img{
  width:100%;
  height:auto !important;
  object-fit:contain !important;
  display:block;
}

/* Contact / training cards */
.card-media img,
.service-card img,
.contact-image img{
  object-fit:cover;
}


/* v13 final image fixes */
.band .image-panel img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  object-position:center top;
  display:block;
}
/* ===============================
   CONTACT FORM
================================ */
.contact-form-wrap{
  margin-top:30px;
}

.contact-form{
  display:grid;
  gap:18px;
  background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.08);
  padding:24px;
  border-radius:16px;
}

.form-row{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.form-row label{
  font-weight:600;
  color:var(--text);
}

.contact-form input,
.contact-form textarea,
.contact-form select{
  width:100%;
  padding:12px 14px;
  border-radius:10px;
  border:1px solid rgba(22,34,53,0.12);
  background:rgba(255,255,255,0.9);
  color:var(--text);
  font:inherit;
  box-sizing:border-box;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder{
  color:#6b7280;
}

.contact-form textarea{
  resize:vertical;
  min-height:120px;
}

.contact-form select option{
  color:#111827;
}

.contact-form .btn,
.contact-form button{
  align-self:flex-start;
  margin-top:10px;
  padding:14px 18px;
  border-radius:12px;
  border:none;
  background:#06b6d4;
  color:#fff;
  font-weight:600;
  cursor:pointer;
}

.contact-form .btn:hover,
.contact-form button:hover{
  background:#0891b2;
}

.contact-note{
  margin-top:24px;
  margin-bottom:18px;
  color:var(--muted);
  line-height:1.6;
}

.contact-small{
  font-size:14px;
  opacity:.8;
  margin-top:10px;
}
.news-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
gap:30px;
margin-top:40px;
}

.news-card{
padding:28px;
border-radius:16px;
background:rgba(255,255,255,0.05);
border:1px solid rgba(255,255,255,0.08);
}

.news-card h2{
margin-bottom:14px;
font-size:20px;
}

.news-card p{
margin-bottom:20px;
line-height:1.6;
}
.news-source{
font-size:12px;
font-weight:600;
letter-spacing:1px;
text-transform:uppercase;
color:#06b6d4;
margin-bottom:8px;
}