/* ===== Public UI refinement v2 ===== */
:root{
  --public-brand:#0d5c9b;
  --public-brand-dark:#12314d;
  --public-accent:#26b07f;
  --public-line:rgba(15,23,42,.08);
  --public-shadow:0 24px 70px rgba(15,23,42,.12);
}
html body{
  font-family:"Alexandria","Manrope",system-ui,-apple-system,"Segoe UI",Tahoma,Arial,sans-serif !important;
}
body{padding-top:0 !important;}
.container{max-width:1180px !important;}
.topbar{
  position:sticky !important;
  top:0 !important;
  margin:0 auto !important;
  border-radius:0 0 22px 22px !important;
  border:1px solid rgba(255,255,255,.65) !important;
  background:rgba(255,255,255,.96) !important;
  backdrop-filter:blur(14px) !important;
  box-shadow:0 18px 40px rgba(15,23,42,.08) !important;
}
.topbar-inner{padding:14px 20px !important;}
.brand img{width:50px !important;height:50px !important;}
.brand strong{font-size:15px !important;}
.brand span,.nav a,.btn{font-family:inherit !important;}
.nav a{
  color:#42566b !important;
  border-radius:12px !important;
  padding:10px 12px !important;
}
.nav a:hover,.nav a.active{background:rgba(13,92,155,.08) !important;color:var(--public-brand-dark) !important;}
.btn{border-radius:14px !important;padding:11px 16px !important;}
.btn.primary{background:linear-gradient(135deg,var(--public-brand),#1976b8) !important;color:#fff !important;border-color:transparent !important;}
.hero{
  margin:28px 0 30px !important;
  min-height:640px !important;
  border-radius:34px !important;
  background:#0c2033 !important;
  border:1px solid rgba(255,255,255,.08) !important;
  box-shadow:0 36px 90px rgba(10,27,43,.20) !important;
}
.hero .slides,.hero .slide,.hero .slide img{height:100% !important;}
.hero .slide img{transform:scale(1.01) !important;}
.hero-overlay{
  background:linear-gradient(115deg, rgba(7,20,34,.18) 6%, rgba(7,20,34,.32) 36%, rgba(9,27,44,.68) 58%, rgba(9,27,44,.90) 100%) !important;
}
[dir="ltr"] .hero-overlay{
  background:linear-gradient(245deg, rgba(7,20,34,.18) 6%, rgba(7,20,34,.32) 36%, rgba(9,27,44,.68) 58%, rgba(9,27,44,.90) 100%) !important;
}
.hero-content{
  align-items:center !important;
  padding:48px 34px !important;
}
.hero-grid{
  width:100%;
  display:grid;
  grid-template-columns:minmax(0,1.3fr) minmax(300px,.8fr);
  gap:24px;
  align-items:end;
}
.hero-copy{display:flex;flex-direction:column;gap:18px;max-width:700px;}
.hero-title{
  margin:0 !important;
  max-width:13ch !important;
  font-size:clamp(2.25rem,4.2vw,4.75rem) !important;
  line-height:1.16 !important;
  text-wrap:balance;
}
.hero-desc{
  margin:0 !important;
  max-width:60ch !important;
  font-size:1rem !important;
  line-height:2 !important;
  color:rgba(255,255,255,.88) !important;
}
.hero-actions{display:flex !important;gap:12px !important;flex-wrap:wrap !important;}
.hero-actions .btn{
  min-width:unset !important;
  padding:13px 18px !important;
  border-radius:14px !important;
  font-size:13px !important;
  font-weight:800 !important;
}
.hero-actions .btn.primary{
  background:#ffffff !important;
  color:var(--public-brand-dark) !important;
  border-color:#ffffff !important;
  box-shadow:0 12px 30px rgba(255,255,255,.12) !important;
}
.hero-actions .btn:not(.primary){
  background:rgba(255,255,255,.10) !important;
  color:#fff !important;
  border-color:rgba(255,255,255,.18) !important;
}
.hero-badges{display:flex;flex-wrap:wrap;gap:10px;}
.hero-badges span{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.16);
  color:#fff;
  font-size:.84rem;
  font-weight:700;
}
.hero-aside{display:grid;gap:14px;align-self:stretch;}
.hero-aside-card,.hero-mini-card{
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.14);
  border-radius:24px;
  backdrop-filter:blur(10px);
  box-shadow:0 18px 36px rgba(5,18,31,.16);
}
.hero-aside-primary{padding:22px 22px 20px;display:flex;flex-direction:column;gap:10px;}
.hero-eyebrow{
  display:inline-flex;
  width:max-content;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.12);
  color:#fff;
  font-size:.78rem;
  font-weight:700;
}
.hero-aside-primary strong{color:#fff;font-size:1.18rem;line-height:1.6;}
.hero-aside-primary p{margin:0;color:rgba(255,255,255,.80);line-height:1.9;font-size:.92rem;}
.hero-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.hero-mini-card{padding:16px;display:flex;gap:12px;align-items:flex-start;}
.hero-mini-card i{
  width:42px;height:42px;display:grid;place-items:center;flex:0 0 42px;
  border-radius:14px;background:#fff;color:var(--public-brand);font-size:1rem;
}
.hero-mini-card strong{display:block;color:#fff;font-size:.96rem;line-height:1.55;margin-bottom:4px;}
.hero-mini-card span{display:block;color:rgba(255,255,255,.78);font-size:.82rem;line-height:1.8;}
.controls{bottom:24px !important;inset-inline-end:24px !important;top:auto !important;}
.iconbtn{
  width:42px !important;height:42px !important;border-radius:14px !important;
  background:rgba(255,255,255,.10) !important;border:1px solid rgba(255,255,255,.16) !important;
}
.dots{inset-inline-start:26px !important;bottom:28px !important;}
.dot{background:rgba(255,255,255,.28) !important;}
.dot.active{background:#fff !important;}
#focus .sec-head{margin-bottom:20px !important;}
.focus-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.focus-card{
  grid-column:auto !important;
  min-height:unset !important;
  padding:18px 16px !important;
  border-radius:20px !important;
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  background:#fff !important;
  border:1px solid rgba(15,23,42,.08) !important;
  box-shadow:0 16px 32px rgba(15,23,42,.06) !important;
}
.focus-copy{display:flex;flex-direction:column;gap:6px;}
.focus-ic{
  width:48px !important;
  height:48px !important;
  border-radius:16px !important;
  margin:0 !important;
  background:linear-gradient(135deg,var(--public-brand),#1e86cb) !important;
  color:#fff !important;
  box-shadow:0 16px 28px rgba(13,92,155,.20) !important;
}
.focus-card h3{font-size:.95rem !important;line-height:1.55 !important;}
.focus-card p{font-size:.84rem !important;line-height:1.85 !important;}
.site-footer{
  margin-top:44px !important;
  padding:34px 28px 18px !important;
  border-radius:32px 32px 0 0 !important;
  background:linear-gradient(135deg,#102132,#16314c 58%, #1d4d79 100%) !important;
  border:none !important;
  color:#fff !important;
}
.foot-top{
  display:grid;
  grid-template-columns:1.35fr .85fr .85fr 1fr;
  gap:18px;
  align-items:start;
}
.foot-brand{display:flex;gap:16px;align-items:flex-start;}
.foot-logo{
  width:72px;height:72px;display:grid;place-items:center;flex:0 0 72px;
  border-radius:20px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);
}
.foot-logo img{max-width:52px;max-height:52px;object-fit:contain;}
.foot-brand-copy strong,.foot-title{color:#fff !important;}
.foot-brand-copy .muted,.foot-brand-desc,.foot-contact,.foot-contact span,
.site-footer .muted{color:rgba(255,255,255,.72) !important;}
.foot-brand-desc{margin:12px 0 0;line-height:2;font-size:.92rem;}
.foot-social{margin-top:16px;display:flex;gap:10px;}
.foot-social .soc{
  background:rgba(255,255,255,.10) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  color:#fff !important;
}
.foot-social .soc:hover{background:#fff !important;color:var(--public-brand-dark) !important;}
.foot-col,.foot-cta-box{padding:8px 0;}
.foot-links{display:flex;flex-direction:column;gap:10px;}
.foot-links a{
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  padding:11px 14px;border-radius:16px;
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.88) !important;
  border:1px solid rgba(255,255,255,.10);
}
.foot-links a:hover{background:rgba(255,255,255,.14);transform:translateY(-1px);}
.foot-contact{display:grid;gap:10px;line-height:1.9 !important;}
.foot-contact div{display:flex;gap:10px;align-items:flex-start;}
.foot-cta-box{
  padding:20px !important;
  border-radius:22px;
  background:#ffffff;
  color:#102132 !important;
  box-shadow:0 22px 40px rgba(6,16,27,.15);
}
.foot-cta-box .foot-title,.foot-cta-box p{color:#102132 !important;}
.foot-cta-box p{margin:0 0 14px;line-height:1.9;font-size:.92rem;}
.foot-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 18px;border-radius:14px;
  background:var(--public-brand);
  color:#fff !important;
  font-weight:800;border:1px solid transparent;
}
.foot-cta:hover{background:#0a497b;}
.foot-bottom{
  margin-top:22px;padding-top:16px;border-top:1px solid rgba(255,255,255,.12);
  color:rgba(255,255,255,.72) !important;
}
.foot-bottom a{color:#fff !important;font-weight:700;}
@media (max-width:1199px){
  .hero-grid{grid-template-columns:minmax(0,1fr) 340px;}
  .focus-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .foot-top{grid-template-columns:1.2fr 1fr 1fr;}
  .foot-cta-box{grid-column:1 / -1;}
}
@media (max-width:991px){
  .topbar{border-radius:0 0 18px 18px !important;}
  .hero{min-height:unset !important;}
  .hero-content{padding:34px 20px 74px !important;}
  .hero-grid{grid-template-columns:1fr;gap:18px;}
  .hero-copy{max-width:100%;}
  .hero-mini-grid{grid-template-columns:1fr 1fr;}
  .focus-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .foot-top{grid-template-columns:1fr 1fr;}
  .foot-brand{grid-column:1 / -1;}
}
@media (max-width:767px){
  .topbar-inner{padding:12px 14px !important;}
  .hero{margin:18px 0 24px !important;border-radius:26px !important;}
  .hero-content{padding:24px 16px 72px !important;}
  .hero-title{font-size:clamp(1.9rem,8vw,2.9rem) !important;max-width:100% !important;line-height:1.22 !important;}
  .hero-desc{font-size:.93rem !important;}
  .hero-actions{flex-direction:column;align-items:stretch !important;}
  .hero-actions .btn{width:100%;justify-content:center;}
  .hero-mini-grid{grid-template-columns:1fr;}
  .focus-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
  .focus-card{padding:16px 14px !important;border-radius:18px !important;}
  .focus-ic{width:44px !important;height:44px !important;}
  .site-footer{padding:28px 18px 18px !important;border-radius:28px 28px 0 0 !important;}
  .foot-top{grid-template-columns:1fr;gap:16px;}
}
@media (max-width:420px){
  .focus-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .focus-card h3{font-size:.88rem !important;}
  .focus-card p{font-size:.78rem !important;}
}
