:root{
  --navy:#000030;
  --green:#00A060;
  --bg:#ffffff;
  --muted:#5b6472;
  --line:rgba(0,0,48,.10);
  --card:#ffffff;
  --soft:rgba(0,0,48,.04);
  --radius:18px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--navy);
  background:var(--bg);
  line-height:1.5;
}
.hp{
  position:absolute;
  left:-9999px;
  width:1px;height:1px;
  overflow:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1180px,92%);margin:0 auto}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5rem;border-radius:999px;padding:.8rem 1.05rem;
  border:1px solid var(--line);background:#fff;color:var(--navy);
  cursor:pointer;transition:.18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  background:linear-gradient(135deg, var(--green), #22c27a);
  border-color:transparent;color:#fff;
}
.btn-ghost{background:transparent}
.btn-sm{padding:.55rem .85rem;font-size:.92rem}

.muted{color:var(--muted)}
.small{font-size:.92rem}
.link{color:var(--green);font-weight:650}
.section{padding:56px 0}
.section-alt{background:linear-gradient(180deg, var(--soft), transparent)}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:18px}
.section-head h2{margin:0;font-size:1.6rem}
.prose h2{margin:.2rem 0 1rem}
.prose p{margin:.75rem 0}

.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);
  backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid var(--line);
}
.header-row{display:flex;align-items:center;gap:18px;padding:14px 0}
.brand-logo{height:34px;width:auto}
.nav{margin-left:auto}
.nav-toggle{display:none}
.nav-menu{list-style:none;display:flex;gap:14px;margin:0;padding:0;align-items:center}
.nav-menu a {
    padding: 0.30rem 5px;
    border-radius: 999px;
}
.nav-menu a:hover{background:var(--soft)}

.has-dropdown{position:relative}
.dropdown{
  position:absolute;top:110%;left:0;min-width:240px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:10px;display:none;box-shadow:0 18px 45px rgba(0,0,48,.10);
}
.has-dropdown:hover .dropdown{display:block}
.dropdown{list-style:none;margin:0}
.dropdown a{display:block;border-radius:10px}

.header-cta{display:flex;align-items:center;gap:10px}
.phone{font-weight:700}

.hero{
  padding:26px 0 44px;
  background:
    radial-gradient(900px 380px at 12% 10%, rgba(0,160,96,.18), transparent 60%),
    radial-gradient(900px 380px at 88% 0%, rgba(0,0,48,.12), transparent 60%);
}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:stretch}
.badge{display:inline-flex;gap:.5rem;align-items:center;padding:.35rem .7rem;border-radius:999px;background:rgba(0,160,96,.10);color:var(--navy);font-weight:650}
.hero h1{margin:.7rem 0 0;font-size:2rem;line-height:1.15}
.lead{color:var(--muted);font-size:1.05rem;margin:.9rem 0 1.2rem}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap}
.hero-kpis{display:flex;gap:12px;margin-top:18px;flex-wrap:wrap}
.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:10px 12px;min-width:140px}
.kpi strong{display:block;font-size:1.05rem}
.kpi span{color:var(--muted);font-size:.92rem}

.hero-slider{border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);background:#fff}
.slides {
    position: relative;
    height: 405px;
}
.slide{position:absolute;inset:0;opacity:0;transition:opacity .35s ease}
.slide.is-active{opacity:1}
.slide img {
    width: 100%;
    height: 100%;
    min-height: 430px;
    object-fit: ;
}
.slide-caption {
    position: absolute;
    left: 14px;
    bottom: 60px;
    background: rgba(0, 0, 48, .78);
    color: #fff;
    border-radius: 14px;
    padding: 10px 12px;
    max-width: 80%;
}
.slide-caption strong{display:block}
.slider-controls {
    height: 50px;
    display: flex;
    gap: 8px;
    padding: 12px;
    background: #ffffffba;
    position: absolute;
    align-items: center;
    width: 530px;
    justify-content: center;
    margin-top: -50px;
}
.dot{width:10px;height:10px;border-radius:999px;border:1px solid var(--line);background:#fff;cursor:pointer}
.dot.is-active{background:var(--green);border-color:transparent}

.grid{display:grid;gap:14px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-5{
  display: flex;
  flex-wrap: wrap;
  justify-content: center;   /* центрируем строки */
  gap: 32px 40px;
}

.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:0 14px 40px rgba(0,0,48,.06);
}
.card-media img{height:170px;width:100%;object-fit:cover}
.card-body{padding:14px}
.card-title{margin:0 0 10px;font-size:1.02rem}
.card-meta{display:flex;align-items:center;justify-content:space-between;gap:10px}
.card-catalog{display:flex;align-items:center}
.note{margin-top:10px}

.icon-card{
  border:1px solid var(--line);border-radius:var(--radius);
  background:linear-gradient(180deg, rgba(0,0,48,.02), #fff);
  padding:16px;min-height:132px;
}
.icon-card h3{margin:0 0 8px}
.icon-card p{margin:0;color:var(--muted)}

.bubble{
  border:1px solid var(--line);border-radius:999px;padding:12px 12px;
  display:flex;align-items:center;gap:10px;background:#fff;
}
.bubble-dot{width:14px;height:14px;border-radius:999px;background:var(--green);box-shadow:0 0 0 6px rgba(0,160,96,.14)}

.split{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:start}
.side-figure{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;
  box-shadow:0 14px 40px rgba(0,0,48,.06);
}
.side-figure img {
    height: 430px;
    max-height: 440px;
    object-fit: cover;
}
.side-badge{padding:12px;color:var(--muted);border-top:1px solid var(--line)}

.reason-box{
  border:1px solid var(--line);border-radius:var(--radius);
  background:
    radial-gradient(700px 200px at 10% 0%, rgba(0,160,96,.16), transparent 60%),
    #fff;
  padding:18px;
}
.reasons{margin:0;padding-left:18px}
.reasons li{margin:10px 0;color:var(--muted)}
.reasons strong{color:var(--navy)}

.app-card{
  border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff;
  box-shadow:0 14px 40px rgba(0,0,48,.06);
  padding-bottom:14px;
}
.app-card img{height:170px;width:100%;object-fit:cover}
.app-card h3{margin:12px 14px 6px}
.app-card p{margin:0 14px 10px}
.app-card .link{margin-left:14px}

.lead-form{
  border:1px solid var(--line);border-radius:calc(var(--radius) + 6px);
  background:
    radial-gradient(900px 260px at 0% 0%, rgba(0,160,96,.22), transparent 55%),
    radial-gradient(900px 260px at 100% 0%, rgba(0,0,48,.14), transparent 55%),
    #fff;
  padding:18px;box-shadow:0 14px 40px rgba(0,0,48,.08);
}
.lead-form-head h2{margin:0 0 6px}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:10px}
.form-grid .span-2{grid-column:span 2}
label span{display:block;font-size:.92rem;color:var(--muted);margin:0 0 6px}
input,select{
  width:100%;padding:.85rem .9rem;border-radius:14px;border:1px solid var(--line);
  outline:none;background:#fff
}
input:focus,select:focus{border-color:rgba(0,160,96,.55);box-shadow:0 0 0 5px rgba(0,160,96,.12)}
.form-actions{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;flex-wrap:wrap}

.faq-item{
  border:1px solid var(--line);border-radius:14px;background:#fff;
  padding:10px 12px;margin:10px 0
}
.faq-item summary{cursor:pointer;font-weight:700}
.faq-body{padding:10px 0 0;color:var(--muted)}

.site-footer{
  background:var(--navy);
  color:#fff;
  padding:44px 0 26px;
  margin-top:30px;
}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding-bottom:22px;border-bottom:1px solid rgba(255,255,255,.14)}
.site-footer h3,.site-footer h4{margin:0 0 10px}
.site-footer ul{list-style:none;margin:0;padding:0}
.site-footer li{margin:8px 0}
.site-footer a{color:rgba(255,255,255,.86)}
.site-footer a:hover{color:#fff}

.map-thumb{display:block;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.18)}
.footer-bottom{display:grid;grid-template-columns:1.2fr 1fr .8fr;gap:18px;padding:18px 0}
.footer-logo{height:30px;width:auto}
.footer-bottom-left{display:flex;gap:12px;align-items:flex-start}
.footer-address{color:rgba(255,255,255,.82)}
.cities-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.social{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.footer-copy{display:flex;justify-content:space-between;gap:10px;color:rgba(255,255,255,.72);font-size:.92rem;border-top:1px solid rgba(255,255,255,.14);padding-top:14px}

@media (max-width: 980px){
  .hero-grid{grid-template-columns:1fr}
  .slides{height:300px}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-5{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .footer-bottom{grid-template-columns:1fr}
}

@media (max-width: 720px){
  .nav-toggle{display:inline-flex}
  .nav-menu{
    position:absolute;right:4%;left:4%;top:62px;
    background:#fff;border:1px solid var(--line);
    border-radius:18px;box-shadow:0 18px 45px rgba(0,0,48,.12);
    padding:10px;flex-direction:column;align-items:stretch;display:none;
  }
  .nav-menu.is-open{display:flex}
  .header-cta{display:none}
  .grid-3{grid-template-columns:1fr}
  .grid-4{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .form-grid .span-2{grid-column:auto}
}
.services-grid { gap: 18px; }

.service-card{
  display:flex;
  flex-direction:column;
  text-decoration:none;
  color:inherit;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  border-radius: 18px;
  overflow:hidden;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
  min-height: 280px;
}

.service-card:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.22);
  background: rgba(255,255,255,.06);
}

.service-card:focus-visible{
  outline:2px solid rgba(90,153,255,.9);
  outline-offset:3px;
}

.service-card-img {
    width: 100%;
    height: 250px;
    object-fit: cover;
    display: block;
}

.service-card-body {
    padding: 16px 16px 18px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    background: #00002e;
}

.service-card-title {
    margin: 0;
    font-size: 18px;
    line-height: 1.2;
    color: white;
}

.service-card-text{
  margin:0;
  color: rgba(255,255,255,.75);
  font-size: 14px;
  line-height: 1.5;
  flex:1;
}

.service-card-more {
    font-weight: 600;
    font-size: 14px;
    opacity: .9;
    color: white;
}
.bubble-icon {
    width: 120px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, .06);
    color: #7aa2ff;
    margin-bottom: 2px;
    margin-left: -25px;
}
.section-head.kasthead {
    display: flex;
    justify-content: center;
    margin-bottom: 50px;
}

/* FAQ wrapper */
.faq{
  display:flex;
  flex-direction:column;
  gap: 12px;
}

/* item card */
.faq-item{
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 14px 34px rgba(0,0,0,.22);
  overflow: hidden;
}

/* question button */
.faq-q{
  width: 100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 14px;
  padding: 16px 18px;
  background: transparent;
  border: 0;
  cursor: pointer;
  text-align: left;
  
  font: inherit;
  line-height: 1.35;
}

.faq-q span[itemprop="name"]{
  font-size: 16px;
  font-weight: 600;
  letter-spacing: .1px;
}

/* caret */
.faq-q::after{
  content:"";
  width: 12px;
  height: 12px;
  flex: 0 0 12px;
  border-right: 2px solid rgba(255,255,255,.70);
  border-bottom: 2px solid rgba(255,255,255,.70);
  transform: rotate(45deg);
  transition: transform .18s ease, opacity .18s ease;
  opacity: .85;
}

/* hover */
.faq-item:hover{
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.05);
}

/* focus (keyboard) */
.faq-q:focus-visible{
  outline: 2px solid rgba(122,162,255,.85);
  outline-offset: 2px;
}

/* expanded state: rotate caret */
.faq-q[aria-expanded="true"]::after{
  transform: rotate(-135deg);
  opacity: 1;
}

/* answer */
.faq-a{
  padding: 0 18px 16px;
 
  font-size: 14px;
  line-height: 1.65;

  /* анимация раскрытия */
  transform-origin: top;
  animation: faqIn .18s ease;
}

.faq-a div[itemprop="text"]{
  padding-top: 6px;
  border-top: 1px solid rgba(255,255,255,.08);
}

/* subtle accent line on the left */
.faq-item{
  position: relative;
}
.faq-item::before{
  content:"";
  position:absolute;
  left:0; top:0; bottom:0;
  width: 3px;
  background: linear-gradient(180deg, rgba(34, 209, 156, .85), rgba(122,162,255,.65));
  opacity: .0;
  transition: opacity .18s ease;
}
.faq-q[aria-expanded="true"] ~ .faq-a,
.faq-q[aria-expanded="true"]{
  /* nothing, just for readability */
}
.faq-q[aria-expanded="true"]{
  background: rgba(255,255,255,.03);
}
.faq-q[aria-expanded="true"] + .faq-a{
  /* show accent line only when open */
}
.faq-item:has(.faq-q[aria-expanded="true"])::before{
  opacity: .95;
}

/* animation */
@keyframes faqIn{
  from{ opacity: 0; transform: translateY(-4px); }
  to{ opacity: 1; transform: translateY(0); }
}

/* mobile */
@media (max-width: 600px){
  .faq-q{ padding: 14px 14px; }
  .faq-a{ padding: 0 14px 14px; }
  .faq-q span[itemprop="name"]{ font-size: 15px; }
}
.section-tight {
    padding: 14px 0;
    background: #00002e;
}

.breadcrumbs{
  display:flex;
  align-items:center;
  gap: 10px;
  font-size: 13px;
  color: rgba(255,255,255,.70);
}

.breadcrumbs .crumb{
  color: rgba(255,255,255,.78);
  text-decoration:none;
}

.breadcrumbs .crumb:hover{ color:#fff; }

.breadcrumbs .crumb-sep{
  opacity:.45;
}

.breadcrumbs .current{
  color: rgba(255,255,255,.95);
}
.apps-grid{ gap: 18px; }

.app-hub-card{
  text-decoration:none;
  color: inherit;
  display:block;
}

.app-card.is-hub{
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: 0 14px 34px rgba(0,0,0,.22);
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.app-card.is-hub:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
}

.app-card.is-hub img{
  width:100%;
  height: 170px;
  object-fit: cover;
  display:block;
}

.app-card-body{
  padding: 14px 16px 16px;
}

.app-card-title{
  margin: 0 0 8px;
  font-size: 18px;
  line-height: 1.2;
}
