:root{
  --bg:#ffffff;
  --text:#0f2240;
  --muted:#5d6f8f;
  --line:rgba(15,34,64,.12);
  --blue:#1657d8;
  --blue-dark:#0e3c99;
  --red:#ff4747;
  --panel:#f6f9ff;
  --panel-2:#edf3ff;
  --shadow:0 20px 50px rgba(22,87,216,.12);
  --radius:26px;
  --radius-md:20px;
  --container:1180px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top right, rgba(22,87,216,.08), transparent 24%),
    radial-gradient(circle at left center, rgba(255,71,71,.06), transparent 20%),
    #fff;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.container{width:min(calc(100% - 32px), var(--container));margin:0 auto}

.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.header-wrap{
  min-height:84px;
  display:flex;align-items:center;justify-content:space-between;gap:20px;
}
.brand{display:flex;align-items:center;gap:14px}
.brand img{
  width:64px;height:64px;object-fit:contain;background:#fff;border-radius:18px;
  box-shadow:var(--shadow);padding:6px;
}
.brand strong{display:block;font-size:1.1rem}
.brand span{display:block;color:var(--muted);font-size:.94rem}
.nav{display:flex;gap:18px;flex-wrap:wrap}
.nav a{font-weight:700;color:var(--muted)}
.nav a:hover{color:var(--blue)}

.hero{padding:48px 0 28px}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center}
.pill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:9px 14px;border-radius:999px;background:var(--panel-2);color:var(--blue-dark);
  font-weight:700;font-size:.9rem;margin:0 0 16px;
}
.hero h1{font-size:clamp(2.3rem,5vw,4.5rem);line-height:1;margin:0 0 14px}
.lead{font-size:1.18rem;font-weight:700;color:var(--blue-dark)}
.hero p{margin:0 0 12px;line-height:1.8;color:var(--muted)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin:26px 0 0}
.btn{
  min-height:52px;padding:0 24px;border-radius:999px;font-weight:800;
  display:inline-flex;align-items:center;justify-content:center;transition:.2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--blue-dark));color:#fff;box-shadow:0 18px 40px rgba(22,87,216,.25)}
.btn-light{background:#fff;border:1px solid var(--line)}
.full{width:100%}
.hero-list{list-style:none;padding:0;margin:22px 0 0;display:grid;gap:10px}
.hero-list li{display:flex;align-items:flex-start;gap:10px;font-weight:600}
.hero-list li::before{content:"";width:10px;height:10px;border-radius:50%;margin-top:8px;background:linear-gradient(135deg,var(--blue),var(--red));flex:0 0 10px}

.hero-media,.mini-grid{display:grid;gap:18px}
.mini-grid{grid-template-columns:1fr 1fr}
.card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;
}
.image-card img,.image-frame img,.gallery-item img{width:100%;height:100%;object-fit:cover}
.tall{min-height:350px}
.mini-grid .image-card{min-height:190px}

.section{padding:34px 0 72px}
.intro-box{
  background:linear-gradient(135deg,#ffffff,var(--panel));border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:28px;
  display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:center;
}
.intro-box h2,.section-title h2,.showcase-copy h2,.contact-box h2{margin:0 0 10px;font-size:clamp(1.8rem,4vw,3rem)}
.intro-box p:last-child,.section-title p,.showcase-copy p,.contact-box p{margin:0;color:var(--muted);line-height:1.8}
.section-title{max-width:760px;margin-bottom:28px}
.section-title.center{text-align:center;margin-left:auto;margin-right:auto}

.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{
  background:linear-gradient(180deg,#fff,#f9fbff);border:1px solid var(--line);border-radius:var(--radius-md);
  padding:24px;box-shadow:var(--shadow);
}
.service-card h3{margin:0 0 10px;font-size:1.12rem}
.service-card p{margin:0;color:var(--muted);line-height:1.75}

.showcase-grid,.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.image-frame{min-height:560px}
.showcase-copy,.contact-box,.contact-side{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:30px;
}
.check-list{margin:18px 0 0;padding-left:20px;color:var(--muted);line-height:1.95}
.promo-box{margin-top:22px;padding:18px 20px;background:var(--panel);border-radius:18px;border:1px solid var(--line)}
.promo-box p{margin:8px 0 0}

.gallery-grid{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:18px}
.gallery-item{min-height:240px;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow);overflow:hidden}
.gallery-item.large{grid-row:span 2;min-height:500px}
.logo-panel{display:flex;align-items:center;justify-content:center;padding:18px;background:linear-gradient(180deg,#fff,var(--panel))}
.logo-panel img{object-fit:contain}

.contact-items{display:grid;gap:18px}
.contact-items span{display:block;margin-bottom:6px;font-size:.88rem;font-weight:800;color:var(--blue-dark);text-transform:uppercase;letter-spacing:.06em}
.contact-items a,.contact-items p{margin:0;font-size:1.06rem;line-height:1.7}
.contact-side{text-align:center;display:flex;flex-direction:column;justify-content:center;align-items:center}
.contact-side img{width:min(100%,300px);object-fit:contain;margin-bottom:16px}
.contact-side h3{margin:0;font-size:2rem}
.contact-side p{margin:8px 0 22px;color:var(--muted)}

.site-footer{border-top:1px solid var(--line);background:rgba(255,255,255,.92)}
.footer-wrap{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:20px 0;color:var(--muted)}

.fade-up{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .6s ease}
.fade-up.visible{opacity:1;transform:none}
.delay-1{transition-delay:.12s}
.delay-2{transition-delay:.22s}

@media (max-width: 980px){
  .hero-grid,.intro-box,.service-grid,.showcase-grid,.gallery-grid,.contact-grid,.mini-grid{grid-template-columns:1fr}
  .gallery-item.large{grid-row:span 1;min-height:320px}
  .image-frame{min-height:380px}
}
@media (max-width: 720px){
  .header-wrap{padding:14px 0;min-height:auto;flex-direction:column;align-items:flex-start}
  .hero{padding-top:26px}
  .showcase-copy,.contact-box,.contact-side,.service-card,.intro-box{padding:22px}
  .footer-wrap{flex-direction:column}
}
