:root{
  --bg:#f3f6fa;
  --surface:#ffffff;
  --surface-2:#f8fbff;
  --ink:#0b1f33;
  --muted:#4b5f75;
  --line:#d9e3ee;
  --brand:#0b2e59;
  --brand-2:#123d73;
  --accent:#c8a45b;
  --accent-soft:#f3ebda;
  --shadow:0 8px 24px rgba(11,31,51,.06);
  --radius:8px;
  --radius-sm:6px;
  --max:1280px;
}
html{scroll-behavior:smooth}
*{box-sizing:border-box}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  background:var(--bg);
  color:var(--ink);
  line-height:1.55;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button,input,select,textarea{font:inherit}
.container{width:min(var(--max), calc(100% - 32px));margin:0 auto}
.utility-bar{
  background:var(--brand);
  color:#fff;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.utility-wrap{
  min-height:42px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  font-size:13px;
  letter-spacing:.02em;
}
.utility-links{display:flex;gap:18px;flex-wrap:wrap}
.site-header{
  background:#fff;
  border-bottom:1px solid var(--line);
  position:sticky;
  top:0;
  z-index:40;
}
.header-wrap{
  min-height:94px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
}
.brand{display:flex;align-items:center;gap:16px}
.brand img{width:220px;max-width:44vw;height:auto}
.brand small{
  display:block;
  margin-top:3px;
  color:var(--muted);
  font-size:12px;
  max-width:420px;
}
.header-actions{display:flex;align-items:center;gap:10px}
.lang-switch,.btn{
  min-height:42px;
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  background:#fff;
  color:var(--ink);
  padding:0 14px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.btn-primary{
  background:var(--brand);
  color:#fff;
  border-color:var(--brand);
  font-weight:700;
}
.main-nav{
  border-top:1px solid var(--line);
  background:#fff;
}
.nav-wrap{
  min-height:58px;
  display:flex;
  align-items:center;
  gap:8px 14px;
  flex-wrap:wrap;
}
.nav-wrap a{
  padding:10px 12px;
  border-radius:4px;
  color:var(--brand);
  font-weight:700;
}
.nav-wrap a.active,.nav-wrap a:hover{
  background:#eef3f8;
}
.hero{
  padding:26px 0 10px;
}
.hero-grid,.two-col,.contact-grid,.about-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:22px;
}
.panel{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.hero-copy{padding:30px}
.hero-visual{padding:18px}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.12em;
  color:var(--brand);
  text-transform:uppercase;
}
.eyebrow::before{
  content:"";
  width:34px;
  height:2px;
  background:var(--accent);
}
h1,h2,h3{margin:0 0 12px;letter-spacing:.01em;color:var(--ink)}
h1{font-size:44px;line-height:1.06}
h2{font-size:30px;line-height:1.12}
h3{font-size:20px;line-height:1.18}
p{margin:0 0 12px;color:var(--muted)}
.hero-list{
  margin:20px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:10px;
}
.hero-list li{
  padding:10px 12px;
  background:var(--surface-2);
  border:1px solid var(--line);
  border-left:4px solid var(--accent);
  color:var(--ink);
  font-weight:700;
}
.actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.section{padding:14px 0 30px}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,0), rgba(255,255,255,.65))}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:16px;
}
.section-link{
  color:var(--brand);
  font-weight:700;
}
.stats-grid,.service-grid,.cases-grid,.team-grid,.partner-grid,.facts-grid{
  display:grid;
  gap:16px;
}
.stats-grid{grid-template-columns:repeat(4,1fr)}
.service-grid{grid-template-columns:repeat(2,1fr)}
.cases-grid{grid-template-columns:repeat(3,1fr)}
.team-grid{grid-template-columns:repeat(3,1fr)}
.partner-grid{grid-template-columns:repeat(4,1fr)}
.facts-grid{grid-template-columns:repeat(2,1fr)}
.stat-card,.service-card,.case-card,.team-card,.partner-card,.fact-card,.contact-card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.stat-card,.service-card,.case-card .inner,.team-card .inner,.partner-card,.fact-card,.contact-card{
  padding:18px;
}
.stat-card strong{
  display:block;
  font-size:34px;
  line-height:1;
  color:var(--brand);
  margin-bottom:10px;
}
.stat-card span{
  display:block;
  font-weight:700;
  margin-bottom:6px;
}
.mini{
  font-size:13px;
  color:var(--muted);
}
.service-card{
  border-top:3px solid var(--brand);
}
.case-media{
  aspect-ratio:16/9;
  overflow:hidden;
  border-bottom:1px solid var(--line);
}
.case-media img{width:100%;height:100%;object-fit:cover}
.chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin-top:12px;
}
.chip{
  font-size:12px;
  font-weight:700;
  color:var(--brand);
  background:#eef3f8;
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 10px;
}
.partner-card{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height:78px;
  font-weight:800;
  color:var(--brand);
  letter-spacing:.04em;
}
.about-block,.contact-card{
  padding:20px;
}
.contact-card strong{
  display:block;
  margin-bottom:8px;
}
.contact-list{
  display:grid;
  gap:10px;
}
.notice{
  margin-top:14px;
  padding:14px 16px;
  border:1px solid var(--line);
  border-left:4px solid var(--accent);
  background:#fff;
  color:var(--ink);
}
.cta-strip{
  background:var(--brand);
  color:#fff;
  padding:22px;
  border-radius:var(--radius);
  border:1px solid rgba(255,255,255,.12);
}
.cta-strip p{color:rgba(255,255,255,.85)}
.site-footer{
  margin-top:12px;
  background:var(--brand);
  color:#fff;
  border-top:4px solid var(--accent);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr .9fr .8fr .8fr;
  gap:18px;
  padding:28px 0;
}
.site-footer h3,.site-footer h4{margin:0 0 10px;color:#fff}
.site-footer p,.site-footer a{color:rgba(255,255,255,.86);display:block;margin:0 0 8px}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.14);
  padding:14px 0 18px;
  color:rgba(255,255,255,.75);
  font-size:13px;
}
@media (max-width:1080px){
  .stats-grid,.partner-grid{grid-template-columns:repeat(2,1fr)}
  .cases-grid,.team-grid{grid-template-columns:1fr 1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:820px){
  .hero-grid,.two-col,.contact-grid,.about-grid,.service-grid,.facts-grid{grid-template-columns:1fr}
  .cases-grid,.team-grid,.partner-grid,.stats-grid{grid-template-columns:1fr}
  .header-wrap{padding:14px 0;align-items:flex-start;flex-direction:column}
  .brand img{width:190px}
  .header-actions{width:100%;justify-content:space-between}
  .main-nav{overflow-x:auto}
  .nav-wrap{flex-wrap:nowrap;white-space:nowrap}
  h1{font-size:34px}
  h2{font-size:26px}
  .footer-grid{grid-template-columns:1fr}
}
.service-grid{grid-template-columns:repeat(3,1fr)}
.cases-grid{grid-template-columns:repeat(3,1fr)}
.team-grid{grid-template-columns:repeat(3,1fr)}
@media (max-width: 1100px){.service-grid,.cases-grid,.team-grid,.partner-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 720px){.service-grid,.cases-grid,.team-grid,.partner-grid,.stats-grid,.facts-grid,.hero-grid,.two-col,.contact-grid,.about-grid{grid-template-columns:1fr}.brand img{width:180px}.header-wrap{min-height:82px}.hero-copy{padding:22px}h1{font-size:34px}.utility-wrap{min-height:unset;padding:8px 0}.nav-wrap{min-height:52px}}


:root{
 --bg:#eef2f7; --text:#10233e; --panel:#ffffff; --border:#d8e1eb;
}
html[data-theme="dark"]{
 --bg:#0b1220; --text:#e8eef8; --panel:#111a2b; --border:#22324d;
}
body{background:var(--bg)!important;color:var(--text)!important;transition:.25s;}
.panel,.card,.service-card,.case-card,.team-card,.stat-card,.partner-card,.wrap{background:var(--panel)!important;color:var(--text)!important;border-color:var(--border)!important;}
.theme-toggle{cursor:pointer;border:1px solid var(--border);background:var(--panel);color:var(--text);padding:8px 12px;border-radius:10px;font-weight:700}

:root{
--bg:#eef2f7;--text:#10233e;--panel:rgba(255,255,255,.88);--border:rgba(255,255,255,.55);
--shadow:0 20px 50px rgba(16,35,62,.10);--accent:#1d4ed8;
}
html[data-theme="dark"]{
--bg:radial-gradient(circle at top,#10203d 0%,#0a1120 45%,#060b16 100%);
--text:#edf4ff;--panel:rgba(18,28,45,.72);--border:rgba(110,160,255,.18);
--shadow:0 20px 60px rgba(0,0,0,.45),0 0 30px rgba(59,130,246,.10);--accent:#60a5fa;
}
body{background:var(--bg)!important;color:var(--text)!important;transition:.3s ease}
.panel,.card,.service-card,.case-card,.team-card,.stat-card,.partner-card,.wrap,header{
background:var(--panel)!important;color:var(--text)!important;border:1px solid var(--border)!important;
backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
box-shadow:var(--shadow)!important;
}
.theme-fab{
position:fixed;right:18px;bottom:18px;z-index:9999;width:54px;height:54px;border-radius:50%;
display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer;
background:linear-gradient(135deg,#ffffff,#dbeafe);color:#10233e;border:1px solid rgba(255,255,255,.7);
box-shadow:0 12px 30px rgba(0,0,0,.15);
}
html[data-theme="dark"] .theme-fab{
background:linear-gradient(135deg,#1e3a8a,#0f172a);color:#fff;
box-shadow:0 12px 35px rgba(59,130,246,.25),0 0 20px rgba(59,130,246,.15);
}
a.btn,.btn{box-shadow:0 10px 25px rgba(29,78,216,.18)}
