
:root{
  --bg:#f5f8fc;
  --surface:#ffffff;
  --surface-soft:#f0f5fb;
  --line:#d9e5f3;
  --line-strong:#bdd2ea;
  --text:#0f2748;
  --text-soft:#4c6380;
  --blue:#0d67d8;
  --blue-dark:#12396f;
  --blue-soft:#eaf3ff;
  --shadow:0 14px 40px rgba(18,57,111,.08);
  --radius:24px;
  --max:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(13,103,216,.08), transparent 18%),
    linear-gradient(180deg,#f8fbff 0%, #f5f8fc 42%, #eef4fb 100%);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(calc(100% - 32px), var(--max));margin:0 auto}
.section{padding:86px 0}
.section-tight{padding:64px 0}
.section-head{max-width:760px;margin-bottom:34px}
.section-head h2{margin:14px 0 10px;font-size:clamp(2rem,4vw,3.2rem);line-height:1.06}
.section-head p{margin:0;color:var(--text-soft);font-size:1.05rem}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.9);border:1px solid var(--line);
  color:var(--blue);font-weight:800;font-size:.82rem;
  letter-spacing:.1em;text-transform:uppercase;box-shadow:var(--shadow)
}
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(244,248,253,.98));
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px;
  box-shadow:var(--shadow);
}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:50px;padding:0 22px;border-radius:16px;
  font-weight:800;border:1px solid transparent;transition:.2s ease
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--blue),#2f91ff);color:#fff;box-shadow:0 12px 28px rgba(13,103,216,.22)}
.btn-secondary{background:#fff;border-color:var(--line);color:var(--text)}
.topbar{
  background:rgba(255,255,255,.88);
  border-bottom:1px solid rgba(18,57,111,.08);
  backdrop-filter:blur(12px)
}
.topbar .container{
  min-height:42px;display:flex;align-items:center;justify-content:space-between;
  gap:18px;font-size:.94rem;color:var(--text-soft)
}
.topbar-links{display:flex;gap:18px;flex-wrap:wrap}
.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(18,57,111,.08)
}
.nav{
  min-height:84px;display:flex;align-items:center;justify-content:space-between;gap:18px;
  position:relative
}
.brand{display:flex;align-items:center;gap:14px;min-width:0}
.brand img{
  width:60px;height:60px;object-fit:contain;
  border-radius:14px;background:#fff;padding:6px;border:1px solid var(--line);
  box-shadow:var(--shadow)
}
.brand-copy{min-width:0}
.brand-copy strong{display:block;font-size:1.05rem}
.brand-copy span{display:block;color:var(--text-soft);font-size:.92rem}
.nav-menu{display:flex;align-items:center;gap:24px}
.nav-menu a{font-weight:700;color:var(--text)}
.nav-menu a.active,.nav-menu a:hover{color:var(--blue)}
.nav-cta{display:flex;align-items:center;gap:12px}
.mobile-toggle{
  display:none;width:50px;height:50px;border-radius:14px;border:1px solid var(--line);
  background:#fff;cursor:pointer;padding:0
}
.mobile-toggle span{
  display:block;width:20px;height:2px;background:var(--text);margin:4px auto;border-radius:999px
}

.hero{padding:86px 0 52px}
.hero-wrap{
  display:grid;grid-template-columns:minmax(0,1.08fr) minmax(360px,.92fr);
  gap:52px;align-items:center
}
.hero h1{
  margin:16px 0 18px;
  font-size:clamp(3rem,5vw,5.1rem);
  line-height:.96;
  letter-spacing:-.05em
}
.hero h1 .highlight{
  background:linear-gradient(135deg,var(--text) 0%, var(--blue) 58%, #2f91ff 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent
}
.hero p{font-size:1.08rem;color:var(--text-soft);max-width:60ch;margin:0}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:30px 0 32px}
.hero-points{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.hero-point{
  background:rgba(255,255,255,.84);
  border:1px solid var(--line);
  border-radius:20px;padding:18px;box-shadow:var(--shadow)
}
.hero-point strong{display:block;font-size:1rem;margin-bottom:4px}
.hero-point span{display:block;color:var(--text-soft);font-size:.94rem}

.hero-contact{
  background:linear-gradient(180deg, rgba(255,255,255,.98), rgba(236,244,255,.98));
  border:1px solid var(--line-strong);
  border-radius:32px;padding:30px;box-shadow:var(--shadow);position:relative
}
.hero-contact::before{
  content:"";position:absolute;inset:14px;border:1px solid rgba(13,103,216,.08);
  border-radius:24px;pointer-events:none
}
.hero-contact-top{
  display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px
}
.hero-contact-top img{
  width:92px;height:92px;object-fit:contain;background:#fff;border:1px solid var(--line);
  border-radius:18px;padding:10px;box-shadow:var(--shadow)
}
.hero-contact h2{margin:0 0 10px;font-size:2rem;line-height:1}
.hero-contact p{margin:0 0 18px;color:var(--text-soft);font-size:1rem}
.hero-form{display:grid;gap:12px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.input,
.hero-form input,
.hero-form textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:16px;
  padding:14px 16px;
  font:inherit;
  color:var(--text);
  background:#fff
}
.hero-form textarea{min-height:118px;resize:vertical}
.hero-form button{justify-self:start}
.hero-contact-meta{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px
}
.meta-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px 16px
}
.meta-card strong{display:block;font-size:.95rem;margin-bottom:2px}
.meta-card span{display:block;color:var(--text-soft);font-size:.92rem}

.service-card{display:flex;flex-direction:column;gap:14px;height:100%}
.service-head{display:flex;align-items:flex-start;gap:14px}

.service-head h3{
  flex:1;
  min-width:0;
  word-break:normal;
  overflow-wrap:break-word;
  hyphens:auto;
  line-height:1.2;
}
flex:1;min-width:0;overflow-wrap:anywhere;word-break:break-word}
.icon-box{
  width:58px;height:58px;border-radius:18px;
  display:grid;place-items:center;
  background:linear-gradient(135deg,var(--blue),#1e56ae);
  color:#fff;box-shadow:0 12px 24px rgba(13,103,216,.18)
}
.icon-box svg{width:28px;height:28px}
.service-card h3{margin:0;font-size:1.32rem;line-height:1.12}
.service-card p{margin:0;color:var(--text-soft)}
.service-list{margin:0;padding-left:18px;color:var(--text-soft)}
.service-list li+li{margin-top:7px}
.info-band{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px
}
.band-card{
  background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:var(--shadow)
}
.band-card strong{display:block;font-size:1.02rem;margin-bottom:6px}
.band-card span{display:block;color:var(--text-soft)}

.about-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:28px;align-items:start}
.logo-card{
  display:flex;align-items:center;justify-content:center;min-height:360px
}
.logo-card img{width:min(100%,420px);object-fit:contain}
.list-check{display:grid;gap:12px;margin:22px 0 0}
.list-check div{display:flex;gap:12px;align-items:flex-start}
.check{
  width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--blue),#2f91ff);
  color:#fff;display:grid;place-items:center;font-size:.9rem;font-weight:900;flex:0 0 auto
}

.contact-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:28px}
.contact-box h3{margin:0 0 12px;font-size:1.34rem}
.contact-box p{margin:0;color:var(--text-soft)}
.contact-list{display:grid;gap:14px;margin-top:22px}
.contact-item{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:16px
}
.contact-item strong{display:block;margin-bottom:3px}
.contact-item span,.contact-item a{color:var(--text-soft)}
.notice{
  background:var(--blue-soft);border:1px solid var(--line);padding:14px 16px;border-radius:16px;
  color:var(--text-soft);font-size:.95rem;margin-top:16px
}

.page-hero{padding:70px 0 30px}
.page-hero h1{margin:16px 0 12px;font-size:clamp(2.4rem,4vw,4rem);line-height:1}
.page-hero p{margin:0;color:var(--text-soft);max-width:65ch}

.footer{
  margin-top:70px;padding:28px 0 34px;border-top:1px solid rgba(18,57,111,.08);
  background:rgba(255,255,255,.75)
}
.footer-inner{
  display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center
}
.footer-copy{color:var(--text-soft);font-size:.95rem}
.footer-links{display:flex;gap:18px;flex-wrap:wrap}
.footer-links a{color:var(--text-soft);font-weight:600}
.footer-links a:hover{color:var(--blue)}

.legal{max-width:880px}
.legal h2{margin:32px 0 10px;font-size:1.5rem}
.legal p,.legal li{color:var(--text-soft)}
.legal ul{padding-left:20px}

.success-box{
  max-width:720px;margin:0 auto;background:#fff;border:1px solid var(--line);
  border-radius:28px;padding:38px;box-shadow:var(--shadow);text-align:center
}
.success-box h1{margin:14px 0 10px;font-size:2.4rem}
.success-box p{margin:0 0 24px;color:var(--text-soft)}

@media (max-width: 1100px){
  .hero-wrap{grid-template-columns:1fr;gap:28px}
  .hero-contact{max-width:720px}
  .hero-points{grid-template-columns:1fr}
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-grid,.about-grid{grid-template-columns:1fr}
}

@media (max-width: 860px){
  .topbar{display:none}
  .mobile-toggle{display:block}
  .nav-menu{
    position:absolute;left:0;right:0;top:100%;
    background:rgba(255,255,255,.98);border:1px solid var(--line);
    border-radius:20px;box-shadow:var(--shadow);padding:14px;
    display:none;flex-direction:column;align-items:flex-start
  }
  .nav-menu.open{display:flex}
  .nav-cta .btn{display:none}
  .form-row,.hero-contact-meta,.grid-3,.grid-2,.grid-4,.info-band{grid-template-columns:1fr}
  .hero h1{font-size:clamp(2.5rem,12vw,4.2rem)}
  .hero-contact{padding:22px}
  .hero-contact-top{align-items:center}
  .hero-contact-top img{width:78px;height:78px}
  .section{padding:68px 0}
  .footer-inner{grid-template-columns:1fr}
}
