:root{
  --primary:#2458d3;
  --primary2:#4d7eff;
  --accent:#ff7a2f;
  --accent2:#ff9d5c;
  --dark:#101725;
  --dark-soft:#18233a;
  --text:#26303f;
  --muted:#667085;
  --line:#e8edf5;
  --soft:#f6f8fc;
  --white:#ffffff;

  --shadow:0 10px 35px rgba(21,38,79,.08);
  --shadow-md:0 16px 40px rgba(16,23,37,.10);
  --shadow-lg:0 20px 55px rgba(17,24,39,.14);

  --radius:22px;
  --radius-md:18px;
  --radius-sm:14px;

  --grad:linear-gradient(135deg,var(--primary),var(--primary2));
  --grad2:linear-gradient(135deg,var(--accent),var(--accent2));
}

*{
  box-sizing:border-box;
  margin:0;
  padding:0;
}

html{
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
}

body{
  font-family:Roboto,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--text);
  line-height:1.7;
  overflow-x:hidden;
  background:#fff;
  text-rendering:optimizeLegibility;
}

body.no-scroll{
  overflow:hidden;
}

img{
  max-width:100%;
  display:block;
  height:auto;
}

a{
  color:inherit;
  -webkit-tap-highlight-color:transparent;
}

button,
input,
textarea,
select{
  font:inherit;
}

.container{
  width:min(1200px, calc(100% - 32px));
  margin:auto;
}

.section{
  padding:88px 0;
}

.section.soft{
  background:var(--soft);
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 14px;
  border-radius:999px;
  background:#eef3ff;
  color:var(--primary);
  font-weight:700;
  font-size:.92rem;
  margin-bottom:16px;
}

.section-head{
  max-width:760px;
  margin:0 auto 40px;
  text-align:center;
}

.section-head.left,
.section-head.left h2,
.section-head.left p{
  text-align:left;
  margin-left:0;
  margin-right:0;
}

.section-head.left{
  margin:0 0 28px;
}

.section-head.left .eyebrow{
  margin-left:0;
}

h1,h2,h3{
  font-family:Montserrat,sans-serif;
  line-height:1.12;
  color:var(--dark);
}

h1{
  font-size:clamp(2.2rem,4.6vw,4.2rem);
  color:#fff;
}

h2{
  font-size:clamp(1.9rem,3.4vw,3rem);
  margin-bottom:14px;
}

h3{
  font-size:1.22rem;
  margin-bottom:8px;
}

p{
  font-size:1.03rem;
  color:var(--muted);
}

.lead{
  font-size:1.14rem;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:54px;
  padding:14px 26px;
  border-radius:14px;
  background:var(--grad);
  color:#fff;
  text-decoration:none;
  font-weight:700;
  border:1px solid transparent;
  box-shadow:0 14px 28px rgba(36,88,211,.20);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}

.btn:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 34px rgba(36,88,211,.24);
}

.btn.secondary{
  background:rgba(255,255,255,.10);
  color:#fff;
  border-color:rgba(255,255,255,.20);
  box-shadow:none;
  backdrop-filter:blur(8px);
}

.btn.secondary:hover{
  background:rgba(255,255,255,.16);
}

.btn.accent{
  background:var(--grad2);
  box-shadow:0 14px 28px rgba(255,122,47,.22);
}

header{
  position:sticky;
  top:0;
  z-index:1000;
  background:rgba(255,255,255,.90);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(232,237,245,.8);
}

header.scrolled{
  box-shadow:0 10px 24px rgba(16,23,37,.08);
}

.header-container{
  min-height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.logo{
  display:flex;
  align-items:center;
  gap:10px;
  font:800 1.42rem Montserrat,sans-serif;
  color:var(--primary);
  text-decoration:none;
  flex-shrink:0;
}

.logo span{
  color:var(--accent);
}

.logo-icon{
  width:28px;
  height:28px;
  object-fit:contain;
}

.nav-links{
  list-style:none;
  display:flex;
  gap:24px;
}

.nav-links a{
  text-decoration:none;
  font-weight:600;
  position:relative;
  white-space:nowrap;
}

.nav-links a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:0;
  height:2px;
  background:var(--grad);
  transition:width .25s ease;
}

.nav-links a:hover::after{
  width:100%;
}

.nav-links > li{
  position:relative;
  display:flex;
  align-items:center;
}

.nav-links > li > a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 0;
}

.has-dropdown{
  position:relative;
}

.nav-links .fa-chevron-down{
  font-size:.78em;
  transition:transform .2s ease;
}

.dropdown-menu{
  position:absolute;
  top:calc(100% + 14px);
  left:0;
  min-width:260px;
  padding:10px;
  margin:0;
  list-style:none;
  background:#fff;
  border:1px solid rgba(18,38,84,.10);
  border-radius:18px;
  box-shadow:0 20px 45px rgba(15,23,42,.12);
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:opacity .2s ease, visibility .2s ease, transform .2s ease;
  z-index:1200;
}

.dropdown-menu li + li{
  margin-top:4px;
}

.dropdown-menu a{
  display:block;
  padding:12px 14px;
  border-radius:12px;
  text-decoration:none;
  font-weight:600;
}

.dropdown-menu a::after{
  display:none;
}

.dropdown-menu a:hover,
.dropdown-menu a:focus-visible{
  background:#f4f7ff;
  color:var(--primary);
}

.has-dropdown:hover .dropdown-menu,
.has-dropdown:focus-within .dropdown-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.has-dropdown:hover > a .fa-chevron-down,
.has-dropdown:focus-within > a .fa-chevron-down{
  transform:rotate(180deg);
}


.header-actions{
  display:flex;
  align-items:center;
  gap:14px;
}

.header-phone{
  display:inline-flex;
  flex-direction:column;
  justify-content:center;
  min-height:56px;
  min-width:190px;
  padding:10px 18px;
  text-decoration:none;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(18,38,84,.10);
  border-radius:16px;
  box-shadow:0 10px 30px rgba(16,24,40,.08);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  flex-shrink:0;
}

.header-phone:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 34px rgba(16,24,40,.12);
  border-color:rgba(20,88,255,.18);
}

.phone-label{
  font-size:12px;
  line-height:1;
  color:#6b7280;
  margin-bottom:4px;
  font-weight:500;
}

.phone-number{
  font-size:18px;
  line-height:1.1;
  font-weight:800;
  color:#0f172a;
  letter-spacing:.2px;
  white-space:nowrap;
}

.mobile-menu-btn{
  display:none;
  width:48px;
  height:48px;
  border:none;
  border-radius:14px;
  background:#f4f7ff;
  color:var(--primary);
  cursor:pointer;
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline:3px solid rgba(36,88,211,.24);
  outline-offset:3px;
}

.hero{
  position:relative;
  padding:68px 0 40px;
  background:
    linear-gradient(rgba(10,20,40,.88), rgba(10,20,40,.88)),
    radial-gradient(circle at left top, rgba(92,135,255,.28), transparent 32%),
    radial-gradient(circle at 86% 10%, rgba(255,152,93,.24), transparent 26%),
    url("images/hero-bg.jpg");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
}

.hero::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:100px;
  background:linear-gradient(to top,#fff,transparent);
}

.hero-grid{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:40px;
  align-items:center;
}

.hero-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 16px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:999px;
  background:rgba(255,255,255,.08);
  color:#fff;
  font-weight:700;
  margin-bottom:18px;
}

.hero p{
  color:rgba(255,255,255,.85);
}

.hero-list{
  list-style:none;
  display:grid;
  gap:12px;
  margin:24px 0;
}

.hero-list li{
  position:relative;
  padding-left:30px;
  color:#fff;
}

.hero-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color:#70f1bf;
  font-weight:900;
}

.hero-status{
  margin-top:10px;
  font-size:14px;
  color:rgba(255,255,255,.88);
  display:flex;
  align-items:center;
  gap:8px;
}

.status-dot{
  width:8px;
  height:8px;
  background:#22c55e;
  border-radius:50%;
  display:inline-block;
  flex:0 0 auto;
}

.hero-actions,
.hero-messengers{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.hero-actions .btn,
.hero-messengers a{
  min-height:52px;
}

.hero-helper{
  margin-top:10px;
  font-size:14px;
  color:rgba(255,255,255,.72);
}

.hero-messengers{
  margin-top:18px;
}

.hero-messengers a{
  text-decoration:none;
  color:#fff;
  padding:10px 14px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:12px;
  background:rgba(255,255,255,.06);
  transition:background .25s ease, transform .25s ease, border-color .25s ease;
}

.hero-messengers a:hover{
  transform:translateY(-2px);
  background:rgba(255,255,255,.10);
  border-color:rgba(255,255,255,.28);
}

.hero-card{
  position:relative;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.10);
  border-radius:24px;
  padding:16px;
  backdrop-filter:blur(12px);
  box-shadow:0 30px 80px rgba(0,0,0,.45);
  overflow:hidden;
  transition:transform .4s ease, box-shadow .4s ease;
}

.hero-card::before{
  content:"";
  position:absolute;
  inset:-20px;
  background:radial-gradient(circle, rgba(59,130,246,.25), transparent 70%);
  filter:blur(40px);
  z-index:-1;
}

.hero-card:hover{
  transform:translateY(-6px);
}

.hero-card img{
  width:100%;
  aspect-ratio:16/11;
  height:100%;
  object-fit:cover;
  object-position:center;
  border-radius:18px;
}

.hero-mini-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  margin-top:14px;
}

.hero-mini{
  padding:14px 12px;
  border-radius:16px;
  background:rgba(255,255,255,.08);
  text-align:center;
}

.hero-mini strong{
  display:block;
  color:#fff;
  font:800 1.15rem Montserrat,sans-serif;
}

.hero-mini span{
  color:rgba(255,255,255,.78);
  font-size:.92rem;
}

.trust-strip{
  padding-top:10px;
}

.trust-grid,
.grid-3,
.portfolio-grid,
.steps,
.reviews,
.compare-grid,
.contacts-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.trust-grid{
  grid-template-columns:repeat(4,1fr);
}

.trust-item,
.card,
.step,
.contact-item{
  background:#fff;
  border:1px solid var(--line);
  border-radius:20px;
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}

.trust-item{
  padding:22px 18px;
  text-align:center;
  background:var(--soft);
}

.trust-item strong{
  display:block;
  color:var(--primary);
  font:800 1.24rem Montserrat,sans-serif;
  margin-bottom:6px;
}

.card,
.step,
.contact-item{
  padding:28px;
}

.card:hover,
.contact-item:hover,
.step:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 48px rgba(16,23,37,.09);
}

.icon{
  width:64px;
  height:64px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--grad);
  color:#fff;
  font-size:1.5rem;
  margin-bottom:16px;
  box-shadow:0 12px 24px rgba(36,88,211,.18);
}

.grid-3 .card:nth-child(2n) .icon{
  background:var(--grad2);
}

.check{
  list-style:none;
  display:grid;
  gap:12px;
}

.check li{
  position:relative;
  padding-left:26px;
}

.check li::before{
  content:"✓";
  position:absolute;
  left:0;
  color:#10b981;
  font-weight:900;
}

.price{
  font:800 2rem Montserrat,sans-serif;
  color:var(--primary);
  margin-top:12px;
}

.featured{
  border-color:#bfd1ff;
  box-shadow:0 20px 55px rgba(36,88,211,.13);
  position:relative;
}

.featured::before{
  content:"Популярно";
  position:absolute;
  top:18px;
  right:18px;
  background:var(--grad2);
  color:#fff;
  border-radius:999px;
  padding:7px 11px;
  font-size:.78rem;
  font-weight:800;
}

.compare{
  overflow:hidden;
  padding:0;
}

.compare .img{
  position:relative;
  aspect-ratio:4/3;
}

.compare .img img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.label{
  position:absolute;
  left:14px;
  top:14px;
  padding:8px 12px;
  border-radius:999px;
  background:rgba(16,23,37,.76);
  color:#fff;
  font-weight:700;
  font-size:.84rem;
}

.compare .body{
  padding:22px;
}

.portfolio-grid .work-card{
  position:relative;
  display:block;
  overflow:hidden;
  border-radius:18px;
  box-shadow:var(--shadow);
}

.portfolio-grid .work-card:focus-visible{
  outline:none;
  box-shadow:0 0 0 4px rgba(36,88,211,.18), var(--shadow-md);
}

.portfolio-grid img{
  width:100%;
  height:240px;
  object-fit:cover;
  transition:transform .35s ease;
}

.portfolio-grid .work-card:hover img{
  transform:scale(1.05);
}

.portfolio-grid .work-card::after{
  content:"Открыть фото";
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  padding:10px 14px;
  border-radius:12px;
  background:rgba(16,23,37,.72);
  color:#fff;
  font-weight:700;
  opacity:0;
  transform:translateY(8px);
  transition:opacity .25s ease, transform .25s ease;
}

.portfolio-grid .work-card:hover::after{
  opacity:1;
  transform:translateY(0);
}

.steps{
  grid-template-columns:repeat(6,1fr);
}

.step{
  text-align:center;
}

.step-num{
  width:58px;
  height:58px;
  margin:0 auto 16px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--grad);
  color:#fff;
  font:800 1.35rem Montserrat,sans-serif;
}

.review-stars{
  color:#f59e0b;
  letter-spacing:2px;
  margin-bottom:10px;
}

.review-meta{
  margin-top:16px;
  display:flex;
  justify-content:space-between;
  gap:12px;
  font-size:.94rem;
  color:var(--muted);
}

.review-name{
  font-weight:700;
  color:var(--dark);
}

.about{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:28px;
  align-items:center;
}

.about-img{
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}

.about-img img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.stats{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:24px;
}

.stat{
  padding:18px 16px;
  background:var(--soft);
  border:1px solid var(--line);
  border-radius:16px;
  text-align:center;
}

.stat strong{
  display:block;
  font:800 1.6rem Montserrat,sans-serif;
  color:var(--primary);
}

.faq-list{
  display:grid;
  gap:14px;
  max-width:940px;
  margin:auto;
}

.faq{
  overflow:hidden;
  padding:0;
}

.faq-q{
  width:100%;
  padding:22px 24px;
  border:none;
  background:#fff;
  text-align:left;
  font-weight:700;
  display:flex;
  justify-content:space-between;
  gap:20px;
  cursor:pointer;
}

.faq-q i{
  transition:transform .25s ease;
}

.faq-a{
  display:none;
  padding:0 24px 22px;
}

.faq.active .faq-a{
  display:block;
}

.faq.active .faq-q i{
  transform:rotate(180deg);
}

.contact-grid{
  display:grid;
  grid-template-columns:.98fr 1.02fr;
  gap:20px;
}

.contact-form{
  padding:34px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow-lg);
  transition:transform .25s ease, box-shadow .25s ease;
}

.contact-form:hover{
  transform:translateY(-2px);
}

.lead-card{
  background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);
}

.lead-points{
  display:grid;
  gap:14px;
  margin-top:20px;
}

.lead-point{
  display:flex;
  gap:14px;
  align-items:flex-start;
}

.lead-point i{
  color:var(--primary);
  margin-top:5px;
}

.form-row{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:16px;
}

.form-group{
  margin-bottom:16px;
}

.form-group label{
  display:block;
  margin-bottom:8px;
  font-weight:700;
  color:var(--dark);
}

.form-control{
  width:100%;
  min-height:54px;
  padding:14px 16px;
  border:1px solid #d9e3f2;
  border-radius:14px;
  background:#f9fbff;
  transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
  appearance:none;
}

.form-control:focus{
  outline:none;
  border-color:#b6c8f5;
  box-shadow:0 0 0 4px rgba(36,88,211,.08);
  background:#fff;
}

textarea.form-control{
  min-height:150px;
  resize:vertical;
}

.form-note,
.form-error{
  margin-top:12px;
  font-size:.92rem;
}

.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}

.form-error{
  color:#dc2626;
}

.form-control[aria-invalid="true"]{
  border-color:#dc2626;
  box-shadow:0 0 0 4px rgba(220,38,38,.12);
}

.success{
  display:none;
  margin-top:16px;
  padding:18px;
  border-radius:16px;
  background:#ecfdf5;
  border:1px solid #b7efd2;
  color:#065f46;
}

.success[hidden]{
  display:none !important;
}

.contacts{
  background:linear-gradient(135deg,#101725 0%,#18233a 100%);
  color:#fff;
}

.contacts h2,
.contacts h3{
  color:#fff;
}

.contacts p{
  color:rgba(255,255,255,.8);
}

.contact-item{
  background:rgba(255,255,255,.06);
  border-color:rgba(255,255,255,.12);
}

.contact-item a{
  text-decoration:none;
  color:#fff;
}

.messenger-links{
  display:flex;
  flex-wrap:wrap;
  gap:14px;
  justify-content:center;
  margin-top:26px;
}

.messenger-link{
  width:58px;
  height:58px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  background:#fff;
  color:var(--dark);
  font-size:1.5rem;
  box-shadow:var(--shadow);
  transition:transform .25s ease, box-shadow .25s ease;
}

.messenger-link:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
}

footer{
  background:#0d1320;
  color:#99a4b3;
  padding:28px 0;
}

.footer-content{
  display:flex;
  justify-content:space-between;
  gap:18px;
  align-items:center;
  flex-wrap:wrap;
}

.footer-logo{
  font:800 1.22rem Montserrat,sans-serif;
  color:#fff;
  text-decoration:none;
}

.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}

.footer-links a{
  text-decoration:none;
  color:#b9c2ce;
}

.mobile-menu-overlay{
  position:fixed;
  inset:0;
  display:none;
  z-index:1300;
}

.mobile-menu-overlay.active{
  display:block;
}

.mobile-menu-backdrop{
  position:absolute;
  inset:0;
  background:rgba(4,10,20,.62);
}

.mobile-menu-panel{
  position:absolute;
  top:0;
  right:0;
  width:min(92vw,420px);
  height:100%;
  background:#fff;
  padding:22px;
  box-shadow:-20px 0 40px rgba(0,0,0,.18);
  overflow:auto;
  overscroll-behavior:contain;
}

.mobile-menu-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  margin-bottom:18px;
}

.mobile-menu-close{
  width:42px;
  height:42px;
  border:none;
  border-radius:12px;
  background:#f4f7ff;
  cursor:pointer;
}

.mobile-nav-links{
  list-style:none;
  display:grid;
  gap:8px;
}

.mobile-nav-links a{
  display:block;
  padding:14px 16px;
  border-radius:14px;
  text-decoration:none;
  font-weight:700;
  background:#f7f9fd;
}

.mobile-menu-cta,
.mobile-messengers{
  display:grid;
  gap:12px;
  margin-top:18px;
}

.mobile-messenger-link{
  display:flex;
  gap:12px;
  align-items:center;
  padding:14px 16px;
  text-decoration:none;
  background:#f7f9fd;
  border-radius:14px;
  font-weight:700;
}

.floating{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:1100;
  display:flex;
  flex-direction:column;
  gap:12px;
}

.float-btn{
  width:60px;
  height:60px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  text-decoration:none;
  box-shadow:0 18px 32px rgba(0,0,0,.20);
}

.float-btn.phone{
  background:var(--grad2);
}

.float-btn.telegram{
  background:#229ED9;
}

.float-btn.whatsapp{
  background:#25D366;
}

.mobile-bottom{
  display:none;
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:1050;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.96);
  backdrop-filter:blur(16px);
  border-top:1px solid #e6ebf4;
}

.mobile-bottom div{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:10px;
}

.mobile-bottom a{
  min-height:50px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  text-decoration:none;
  font-size:.95rem;
  font-weight:800;
  box-shadow:var(--shadow);
}

.mobile-bottom .call{
  background:var(--grad2);
  color:#fff;
}

.mobile-bottom .write{
  background:#229ED9;
  color:#fff;
}

.mobile-bottom .quote{
  background:var(--grad);
  color:#fff;
}

.lightbox{
  position:fixed;
  inset:0;
  display:none;
  z-index:2000;
}

.lightbox.is-open{
  display:block;
}

.lightbox-bg{
  position:absolute;
  inset:0;
  background:rgba(7,12,20,.82);
}

.lightbox img{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  width:min(92vw,1100px);
  max-height:88vh;
  object-fit:contain;
  border-radius:18px;
  background:#fff;
  box-shadow:var(--shadow-lg);
}

.lightbox-close{
  position:absolute;
  top:20px;
  right:20px;
  width:46px;
  height:46px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.14);
  color:#fff;
  font-size:1.8rem;
  cursor:pointer;
}

.anchor{
  scroll-margin-top:94px;
}

.before-after-note{
  max-width:760px;
  margin:18px auto 0;
  text-align:center;
  color:var(--muted);
}

#services,
#prices,
#calculator,
#portfolio,
#reviews,
#faq,
#contact-form,
#cases,
#key-service,
#packages,
#result,
#timing-block{
  scroll-margin-top:110px;
}

.calc-helper{
  margin-top:10px;
  font-size:14px;
  color:#6b7280;
}

.calculator-card{
  max-width:840px;
  margin:0 auto;
}

.calc-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px;
}

.calc-result{
  margin-top:20px;
  padding:18px;
  border-radius:18px;
  background:rgba(24,37,62,.06);
  border:1px solid rgba(24,37,62,.08);
}

.calc-result strong{
  display:block;
  font-size:15px;
  margin-bottom:8px;
}

.calc-result-value{
  font-size:28px;
  font-weight:800;
  color:#ff7a2f;
  line-height:1.15;
}

.calc-result-note{
  margin-top:8px;
  color:#586174;
  font-size:14px;
}

.calc-result-action{
  margin-top:20px;
}

.case-grid,
.seo-grid,
.timing-grid{
  display:grid;
  gap:24px;
}

.case-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.seo-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.timing-grid{
  grid-template-columns:repeat(3,minmax(0,1fr));
}

.case-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:14px;
}

.case-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  font-weight:700;
  color:#18253e;
  background:rgba(24,37,62,.08);
  border-radius:999px;
  padding:8px 12px;
  white-space:nowrap;
}

.case-price{
  margin-top:16px;
  font-size:24px;
  font-weight:800;
  color:#ff7a2f;
}

.seo-card{
  text-decoration:none;
  color:inherit;
  transition:transform .2s ease, box-shadow .2s ease;
}

.seo-card:hover{
  transform:translateY(-4px);
}

.app-bottom-bar{
  position:fixed;
  left:12px;
  right:12px;
  bottom:max(10px, env(safe-area-inset-bottom));
  z-index:1000;
  display:none;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  padding:8px;
  border-radius:20px;
  background:rgba(12,20,40,.88);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  box-shadow:0 12px 30px rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.08);
}

.app-bottom-bar__item{
  min-height:60px;
  border-radius:14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
  text-decoration:none;
  color:#fff;
  font-weight:700;
  font-size:12px;
  line-height:1.1;
  text-align:center;
  padding:8px 6px;
  transition:transform .2s ease, opacity .2s ease;
}

.app-bottom-bar__item:active{
  transform:scale(.98);
}

.app-bottom-bar__icon{
  font-size:20px;
  line-height:1;
}

.app-bottom-bar__text{
  display:block;
  white-space:nowrap;
}

.app-bottom-bar__item:nth-child(1){
  background:linear-gradient(135deg,#ff7a2f,#ff9f5a);
}

.app-bottom-bar__item:nth-child(2){
  background:linear-gradient(135deg,#1f9bd1,#39b3e6);
}

.app-bottom-bar__item:nth-child(3){
  background:linear-gradient(135deg,#3157f4,#4f74ff);
}

@media (max-width:1180px){
  .hero-grid,
  .about,
  .contact-grid{
    grid-template-columns:1fr;
  }

  .steps{
    grid-template-columns:repeat(3,1fr);
  }
}

@media (max-width:1100px){
  .nav-links{
    display:none;
  }

  .header-actions{
    display:flex;
    margin-left:auto;
  }

  .header-phone{
    min-height:50px;
    padding:10px 14px;
  }

  .phone-number{
    font-size:16px;
  }

  .mobile-menu-btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
  }
}

@media (max-width:900px){
  .header-actions{
    display:none;
  }

  .trust-grid,
  .grid-3,
  .portfolio-grid,
  .reviews,
  .compare-grid,
  .contacts-grid,
  .stats,
  .calc-grid,
  .case-grid,
  .seo-grid,
  .timing-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .case-card-top{
    align-items:flex-start;
    flex-direction:column;
  }

  .hero{
    padding:48px 0 30px;
  }
}

@media (max-width:768px){
  .app-bottom-bar{
    display:grid;
  }

  body{
    padding-bottom:calc(96px + env(safe-area-inset-bottom));
  }

  .floating{
    display:none !important;
  }

  .mobile-bottom,
  .mobile-sticky-buttons,
  .floating-cta{
    display:none !important;
  }
}

@media (max-width:640px){
  .container{
    width:min(1200px, calc(100% - 24px));
  }

  .section{
    padding:64px 0;
  }

  h1{
    font-size:32px;
    line-height:1.15;
  }

  .hero{
    padding:36px 0 20px;
  }

  .hero-actions{
    display:grid;
    grid-template-columns:1fr 1fr;
  }

  .hero-actions .btn{
    width:100%;
  }

  .hero-messengers{
    display:grid;
    grid-template-columns:1fr 1fr 1fr;
  }

  .hero-messengers a{
    justify-content:center;
    text-align:center;
    font-size:.92rem;
  }

  .form-row,
  .trust-grid,
  .grid-3,
  .portfolio-grid,
  .reviews,
  .compare-grid,
  .contacts-grid,
  .stats,
  .steps,
  .calc-grid,
  .case-grid,
  .seo-grid,
  .timing-grid{
    grid-template-columns:1fr;
  }

  .hero-card{
    padding:12px;
    margin-top:12px;
  }

  .hero-card img{
    aspect-ratio:16/11;
    min-height:220px;
  }

  .hero-mini-grid{
    grid-template-columns:repeat(3,1fr);
    gap:10px;
  }

  .hero-mini{
    padding:10px;
    border-radius:14px;
  }

  .hero-mini strong{
    font-size:16px;
  }

  .hero-mini span{
    font-size:12px;
  }

  .card,
  .step,
  .contact-item,
  .contact-form{
    padding:22px;
  }

  .mobile-bottom a{
    min-height:52px;
    font-size:.9rem;
  }

  .portfolio-grid img{
    height:210px;
  }

  .mobile-bottom{
    display:none;
  }

  .footer-content{
    justify-content:center;
    text-align:center;
  }
}

@media (max-width:420px){
  .hero-actions,
  .hero-messengers{
    grid-template-columns:1fr;
  }

  .hero-badge{
    font-size:.88rem;
  }
}

@media (max-width:380px){
  .app-bottom-bar{
    left:10px;
    right:10px;
    gap:6px;
    padding:6px;
    border-radius:18px;
  }

  .app-bottom-bar__item{
    min-height:56px;
    font-size:11px;
    border-radius:12px;
    padding:7px 4px;
  }

  .app-bottom-bar__icon{
    font-size:18px;
  }
}

.nav-links{
  gap:18px;
}

.header-phone{
  min-width:185px;
  padding:10px 16px;
  flex-shrink:0;
}

.phone-number{
  white-space:nowrap;
}

.header-actions .btn{
  min-height:56px;
  padding:12px 20px;
  white-space:nowrap;
  flex-shrink:0;
}

@media (max-width: 1280px){
  .header-actions .btn{
    display:none;
  }
}



.mobile-nav-title{
  margin:18px 0 8px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#667085;
}

.mobile-nav-links .is-current{
  background:#eef3ff;
  color:var(--primary);
}

@media (max-width:1100px){
  .dropdown-menu{
    display:none;
  }
}


/* === Header/menu fixes === */
header{
  position:sticky;
  top:0;
  z-index:1200;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(18,38,84,.08);
}

.header-container{
  flex-wrap:nowrap;
}

.nav-links{
  flex:1 1 auto;
  justify-content:center;
  align-items:center;
  min-width:0;
}

.nav-links > li{
  flex:0 0 auto;
}

.header-actions{
  flex:0 0 auto;
}

.dropdown-menu{
  width:max-content;
  max-width:min(320px, calc(100vw - 32px));
}

.mobile-menu-panel .logo{
  pointer-events:none;
}

@media (max-width:1280px){
  .nav-links{
    gap:16px;
  }
}

@media (max-width:1100px){
  .header-container{
    gap:12px;
  }
}

.visually-hidden{position:absolute!important;width:1px!important;height:1px!important;padding:0!important;margin:-1px!important;overflow:hidden!important;clip:rect(0,0,0,0)!important;white-space:nowrap!important;border:0!important;}
