/* Media Mir top panel + MegaMenu */
:root{--yellow:#ffd400;--red:#ee2538;--purple:#6f1fa2;--dark:#121627;--text:#303746;--muted:#697386;--line:#e7e9ef;--shadow:0 12px 32px rgba(18,22,39,.09)}
*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:#fff}a{text-decoration:none;color:inherit}img{display:block;max-width:100%}.mm-container{width:min(1320px,calc(100% - 36px));margin:0 auto}.mm-top{position:relative;z-index:100;background:#fff;border-bottom:1px solid var(--line)}
.mm-top__row{min-height:82px;display:grid;grid-template-columns:168px 1fr;gap:24px;align-items:center}.mm-logo img{width:156px}.mm-contact-panel{justify-self:end;display:flex;align-items:center;gap:14px}.mm-contact-group{display:flex;align-items:center;gap:13px;min-width:0}.mm-contact-item{display:flex;align-items:center;gap:7px;min-width:0;color:var(--dark);font-size:14px;font-weight:800;white-space:nowrap}.mm-address{max-width:310px}.mm-contact-item span{overflow:hidden;text-overflow:ellipsis}.mm-contact-item i{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:none;background:#f4edff;color:var(--purple);font-style:normal;font-weight:900;font-size:13px}.mm-divider{width:1px;height:24px;background:var(--line);flex:none}.mm-panel-actions{display:flex;align-items:center;gap:9px;flex:none}.mm-branches-button,.mm-callback-button{height:42px;border:0;border-radius:12px;font-size:14px;font-weight:900;padding:0 15px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;white-space:nowrap}.mm-branches-button{background:var(--dark);color:#fff;box-shadow:0 10px 22px rgba(18,22,39,.16)}.mm-branches-button span{width:23px;height:23px;border-radius:50%;display:grid;place-items:center;background:var(--yellow);color:#171000}.mm-callback-button{background:var(--yellow);color:#1b1200}
.mm-menu-row{border-top:1px solid var(--line);background:#fff;position:relative}.mm-menu-wrap{height:58px;display:flex;align-items:center;justify-content:space-between;gap:18px}.mm-main-nav{height:100%;display:flex;align-items:stretch;gap:6px}.mm-nav-item{height:100%;display:flex;align-items:stretch;position:static}.mm-nav-link{height:100%;display:flex;align-items:center;padding:0 15px;font-size:15px;font-weight:600;color:var(--dark);border-bottom:3px solid transparent;line-height:1.25;text-align:left}.mm-nav-link:hover,.mm-nav-link.is-active{color:var(--red);border-bottom-color:var(--red)}.mm-nav-link.has-mega:after{content:'⌄';margin-left:7px;color:var(--purple);font-size:12px}
.mm-mega{display:none;position:absolute;top:100%;left:calc((1320px - 100vw)/2);width:100vw;background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);box-shadow:0 22px 45px rgba(18,22,39,.12);padding:22px 0}.mm-nav-item:hover .mm-mega{display:block}.mm-mega__inner{width:min(1320px,calc(100% - 36px));margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:22px;align-items:stretch;min-height:250px}.mm-mega-card{border-radius:18px;background:linear-gradient(135deg,#fff9d8,#f4edff);padding:18px;height:100%}.mm-mega-card h3{margin:0 0 8px;color:var(--dark);font-size:20px;font-weight:600}.mm-mega-card p{margin:0 0 14px;color:var(--muted);font-size:14px;line-height:1.35}.mm-mega-card a{display:inline-flex;height:38px;align-items:center;padding:0 14px;border-radius:10px;background:var(--dark);color:#fff;font-size:13px;font-weight:600}.mm-mega-col h4{margin:0 0 11px;color:var(--dark);font-size:14px;text-transform:uppercase;font-weight:600;letter-spacing:.02em}.mm-mega-col ul{margin:0;padding:0;list-style:none;display:grid;gap:8px}.mm-mega-col a{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:7px 0;color:#303746;font-size:14px;font-weight:400;border-bottom:1px solid #f0f1f5;line-height:1.25}.mm-mega-col a:hover{color:var(--purple)}.mm-mega-col a:after{content:'→';color:var(--purple);font-weight:900}.mm-menu-extra{display:flex;align-items:center;gap:9px}.mm-menu-extra a{height:36px;display:inline-flex;align-items:center;padding:0 14px;border-radius:10px;background:#f4edff;color:var(--purple);font-weight:600;font-size:13px}.mm-mobile-menu-btn{display:none;height:40px;border:0;border-radius:10px;background:var(--dark);color:#fff;font-weight:900;padding:0 16px}
.mm-branches-panel{display:none;border-top:1px solid var(--line);background:linear-gradient(180deg,#fff,#fbfbfe);padding:16px 0 22px}.mm-branches-panel.is-open{display:block}.mm-panel-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:14px}.mm-panel-head h2{margin:0 0 4px;color:var(--dark);font-size:24px}.mm-panel-head p{margin:0;color:var(--muted);font-size:14px}.mm-collapse-button{height:36px;border:0;border-radius:10px;background:var(--dark);color:#fff;font-weight:900;padding:0 15px;cursor:pointer}.mm-branches-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px}.mm-branch-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:16px;padding:15px;box-shadow:var(--shadow)}.mm-branch-card:before{content:'';position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,var(--yellow),var(--red),var(--purple))}.mm-branch-title{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:11px}.mm-branch-title h3{margin:0;color:var(--dark);font-size:17px}.mm-branch-title span{display:inline-flex;padding:5px 9px;border-radius:999px;background:#f2e8ff;color:var(--purple);font-size:12px;font-weight:900;white-space:nowrap}.mm-branch-list{display:grid;gap:8px;margin-bottom:11px}.mm-branch-list div{display:grid;grid-template-columns:22px 1fr;gap:7px;align-items:start}.mm-branch-list i{width:22px;height:22px;border-radius:50%;display:grid;place-items:center;background:#f5efff;color:var(--purple);font-size:11px;font-style:normal;font-weight:900}.mm-branch-list p{margin:0;font-size:13px;line-height:1.3;color:#1f2633}.mm-branch-list b{display:block;color:var(--dark);margin-bottom:1px}.mm-schedule{display:grid;gap:5px;padding-top:9px;margin-bottom:12px;border-top:1px dashed #d8dbe5}.mm-schedule div{display:flex;justify-content:space-between;gap:8px;font-size:13px}.mm-schedule span{color:var(--muted)}.mm-schedule strong{color:var(--dark)}.mm-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}.mm-actions a{height:37px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:13px}.mm-route{background:#f2e8ff;color:var(--purple)}.mm-call{background:var(--yellow);color:#1b1200}.mm-demo-content{display:none!important}.mm-demo-content .mm-container{border:2px dashed #d9dce6;border-radius:18px;padding:26px;text-align:center;color:var(--muted);background:#fbfbfd}.mm-demo-content h1{margin:0 0 8px;color:var(--dark);font-size:28px}
@media(max-width:1120px){.mm-top__row{grid-template-columns:150px 1fr;gap:16px}.mm-logo img{width:146px}.mm-contact-panel{gap:10px}.mm-contact-group{gap:9px}.mm-contact-item{font-size:13px}.mm-address{max-width:230px}.mm-branches-button,.mm-callback-button{padding:0 12px;font-size:13px}.mm-nav-link{padding:0 10px;font-size:14px;font-weight:600}.mm-mega__inner{grid-template-columns:1fr 1fr 1fr}}
@media(max-width:960px){.mm-top__row{grid-template-columns:1fr;gap:12px;padding:14px 0}.mm-contact-panel{justify-self:stretch;display:grid;grid-template-columns:1fr}.mm-contact-group{display:grid;grid-template-columns:1fr 1fr;gap:9px}.mm-divider{display:none}.mm-panel-actions{display:grid;grid-template-columns:1fr 1fr}.mm-main-nav,.mm-menu-extra{display:none}.mm-mobile-menu-btn{display:inline-flex}.mm-menu-wrap{justify-content:flex-end}.mm-branches-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.mm-container{width:min(100% - 24px,1320px)}.mm-logo img{width:148px}.mm-contact-group{grid-template-columns:1fr}.mm-address{max-width:100%}.mm-panel-actions{grid-template-columns:1fr}.mm-panel-head{display:block}.mm-collapse-button{margin-top:12px}.mm-branches-grid{grid-template-columns:1fr}}

/* Menu alignment fixes */
.mm-nav-link.has-mega::after {
  flex: 0 0 auto;
}
.mm-mega-col li {
  margin: 0;
}


/* MegaMenu final alignment */
.mm-menu-row,
.menu-row {
  position: relative;
}

.mm-nav-item,
.nav-item {
  position: static;
}

.mm-mega,
.mega {
  left: 0;
  right: 0;
  width: 100%;
  min-height: 310px;
}

.mm-mega__inner,
.mega-inner {
  margin-left: auto;
  margin-right: auto;
  align-items: stretch;
  min-height: 250px;
}

.mm-mega-card,
.mega-card {
  height: 100%;
}

.mm-mega-col,
.mega-col {
  min-height: 250px;
}

.mm-mega-col a,
.mega-col a {
  font-weight: 400;
  line-height: 1.25;
}


/* Hero slider */
.mm-hero-slider {
  background: #f2f3f7;
}

.mm-slider {
  position: relative;
  height: 520px;
  overflow: hidden;
  background: #111827;
}

.mm-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  transition: opacity .45s ease, visibility .45s ease;
}

.mm-slide.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
}

.mm-slide-bg,
.mm-slide-overlay {
  position: absolute;
  inset: 0;
}

.mm-slide-bg {
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}

.mm-slide-bg-1 {
  background:
    radial-gradient(circle at 78% 32%, rgba(255, 212, 0, .38), transparent 0 18%, transparent 35%),
    radial-gradient(circle at 90% 85%, rgba(227, 38, 117, .36), transparent 0 24%, transparent 42%),
    linear-gradient(120deg, #10152e 0%, #2a0952 45%, #711058 72%, #f05b16 100%);
}

.mm-slide-bg-2 {
  background:
    radial-gradient(circle at 82% 24%, rgba(255, 212, 0, .42), transparent 0 22%, transparent 38%),
    linear-gradient(120deg, #39104f 0%, #81206a 48%, #ef6b20 100%);
}

.mm-slide-bg-3 {
  background:
    radial-gradient(circle at 82% 28%, rgba(255, 212, 0, .34), transparent 0 20%, transparent 36%),
    linear-gradient(120deg, #102039 0%, #28316d 48%, #6f1fa2 100%);
}

.mm-slide-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(112deg, transparent 0 42%, rgba(255,255,255,.08) 42% 43%, transparent 43%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.08) 0 2px, transparent 2px 18px);
  opacity: .35;
}

.mm-slide-overlay {
  background:
    linear-gradient(90deg, rgba(10, 12, 24, .78) 0%, rgba(10, 12, 24, .58) 43%, rgba(10, 12, 24, .18) 100%),
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,.22) 100%);
}

.mm-slide-content {
  position: relative;
  z-index: 3;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  color: #fff;
  padding-top: 36px;
  padding-bottom: 36px;
}

.mm-slide-label {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 8px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.24);
  font-size: 14px;
  font-weight: 700;
}

.mm-slide h1,
.mm-slide h2 {
  max-width: 710px;
  margin: 0 0 16px;
  font-size: clamp(36px, 4.8vw, 64px);
  line-height: 1.02;
  letter-spacing: -1.4px;
  font-weight: 700;
}

.mm-slide p {
  max-width: 620px;
  margin: 0 0 28px;
  color: rgba(255,255,255,.86);
  font-size: clamp(17px, 1.5vw, 21px);
  line-height: 1.45;
}

.mm-slide-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.mm-slide-btn {
  min-height: 50px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 22px;
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
  transition: transform .2s ease, box-shadow .2s ease;
}

.mm-slide-btn:hover {
  transform: translateY(-2px);
}

.mm-slide-btn-primary {
  background: var(--yellow);
  color: #1b1200;
  box-shadow: 0 12px 26px rgba(255, 212, 0, .24);
}

.mm-slide-btn-light {
  background: rgba(255,255,255,.12);
  color: #fff;
  border: 1px solid rgba(255,255,255,.38);
}

.mm-slider-arrow {
  position: absolute;
  z-index: 5;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  border: 0;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,.92);
  color: var(--dark);
  font-size: 34px;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 12px 26px rgba(18,22,39,.18);
}

.mm-slider-prev {
  left: max(18px, calc((100vw - 1320px) / 2 - 64px));
}

.mm-slider-next {
  right: max(18px, calc((100vw - 1320px) / 2 - 64px));
}

.mm-slider-dots {
  position: absolute;
  z-index: 5;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  display: flex;
  gap: 9px;
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.22);
  backdrop-filter: blur(8px);
}

.mm-slider-dots button {
  width: 10px;
  height: 10px;
  border: 0;
  padding: 0;
  border-radius: 50%;
  background: rgba(255,255,255,.55);
  cursor: pointer;
}

.mm-slider-dots button.is-active {
  width: 28px;
  border-radius: 999px;
  background: var(--yellow);
}

@media (max-width: 960px) {
  .mm-slider {
    height: 470px;
  }

  .mm-slider-arrow {
    display: none;
  }

  .mm-slide-content {
    padding-left: 0;
    padding-right: 0;
  }
}

@media (max-width: 620px) {
  .mm-slider {
    height: 520px;
  }

  .mm-slide h1,
  .mm-slide h2 {
    font-size: 34px;
  }

  .mm-slide p {
    font-size: 16px;
  }

  .mm-slide-actions {
    width: 100%;
  }

  .mm-slide-btn {
    width: 100%;
  }
}


/* Slider compact version */
.mm-slider {
  height: 430px;
}

.mm-slide-content {
  padding-top: 32px;
  padding-bottom: 46px;
}

.mm-slide-label {
  margin-bottom: 13px;
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 600;
}

.mm-slide h1,
.mm-slide h2 {
  max-width: 620px;
  margin-bottom: 13px;
  font-size: clamp(30px, 3.7vw, 48px);
  line-height: 1.06;
  letter-spacing: -0.8px;
  font-weight: 650;
}

.mm-slide p {
  max-width: 560px;
  margin-bottom: 22px;
  font-size: clamp(15px, 1.25vw, 18px);
  line-height: 1.45;
}

.mm-slide-actions {
  gap: 10px;
}

.mm-slide-btn {
  min-height: 44px;
  padding: 0 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 650;
}

.mm-slider-arrow,
.mm-slider-prev,
.mm-slider-next {
  display: none !important;
}

.mm-slider-dots {
  bottom: 18px;
  padding: 7px 9px;
  gap: 8px;
}

.mm-slider-dots button {
  width: 9px;
  height: 9px;
}

.mm-slider-dots button.is-active {
  width: 26px;
}

@media (max-width: 960px) {
  .mm-slider {
    height: 400px;
  }
}

@media (max-width: 620px) {
  .mm-slider {
    height: 440px;
  }

  .mm-slide h1,
  .mm-slide h2 {
    font-size: 30px;
  }

  .mm-slide p {
    font-size: 15px;
  }

  .mm-slide-btn {
    min-height: 44px;
  }
}


/* Popular services */
.mm-popular-services {
  padding: 54px 0 58px;
  background: #fff;
}

.mm-section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 24px;
  margin-bottom: 26px;
}

.mm-section-label {
  display: inline-flex;
  margin-bottom: 9px;
  padding: 6px 11px;
  border-radius: 999px;
  background: #f4edff;
  color: var(--purple);
  font-size: 13px;
  font-weight: 650;
}

.mm-section-head h2 {
  margin: 0 0 8px;
  color: var(--dark);
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1.1;
  font-weight: 650;
}

.mm-section-head p {
  max-width: 650px;
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.45;
}

.mm-section-link {
  flex: 0 0 auto;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  padding: 0 15px;
  border-radius: 10px;
  background: #f4edff;
  color: var(--purple);
  font-size: 14px;
  font-weight: 650;
}

.mm-services-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 18px;
}

.mm-service-card {
  min-width: 0;
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 10px 26px rgba(18, 22, 39, .06);
  transition: transform .2s ease, box-shadow .2s ease;
}

.mm-service-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 34px rgba(18, 22, 39, .10);
}

.mm-service-image {
  height: 190px;
  display: block;
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}

.mm-service-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 75% 25%, rgba(255, 212, 0, .40), transparent 0 24%, transparent 46%),
    linear-gradient(135deg, rgba(255,255,255,.08), rgba(0,0,0,.12));
}

.mm-service-image::after {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 58px;
  filter: drop-shadow(0 12px 16px rgba(0,0,0,.16));
}

.mm-service-image-1 { background: linear-gradient(135deg, #e8f2ff, #ffffff); }
.mm-service-image-1::after { content: "📷"; }

.mm-service-image-2 { background: linear-gradient(135deg, #fff4cf, #f4edff); }
.mm-service-image-2::after { content: "🖼️"; }

.mm-service-image-3 { background: linear-gradient(135deg, #fff8dc, #f7d7ea); }
.mm-service-image-3::after { content: "☕"; }

.mm-service-image-4 { background: linear-gradient(135deg, #eef3ff, #ffffff); }
.mm-service-image-4::after { content: "👕"; }

.mm-service-image-5 { background: linear-gradient(135deg, #fff0cf, #dfe9ff); }
.mm-service-image-5::after { content: "🌅"; }

.mm-service-image-6 { background: linear-gradient(135deg, #ffffff, #eee7ff); }
.mm-service-image-6::after { content: "💼"; }

.mm-service-image-7 { background: linear-gradient(135deg, #fff4d8, #ffe6e6); }
.mm-service-image-7::after { content: "📄"; }

.mm-service-image-8 { background: linear-gradient(135deg, #e6f7ff, #fff7df); }
.mm-service-image-8::after { content: "🖨️"; }

.mm-service-image-9 { background: linear-gradient(135deg, #f4edff, #ffffff); }
.mm-service-image-9::after { content: "✨"; }

.mm-service-image-10 { background: linear-gradient(135deg, #fff1d6, #f4edff); }
.mm-service-image-10::after { content: "🖼"; }

.mm-service-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 17px;
}

.mm-service-body h3 {
  min-height: 44px;
  margin: 0 0 8px;
  color: var(--dark);
  font-size: 18px;
  line-height: 1.22;
  font-weight: 650;
}

.mm-service-body p {
  flex: 1;
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.4;
}

.mm-service-more {
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  align-self: flex-start;
  padding: 0 15px;
  border-radius: 10px;
  background: var(--dark);
  color: #fff;
  font-size: 14px;
  font-weight: 650;
}

.mm-service-more:hover {
  background: var(--purple);
}

@media (max-width: 1120px) {
  .mm-services-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}

@media (max-width: 900px) {
  .mm-services-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .mm-section-head {
    display: block;
  }

  .mm-section-link {
    margin-top: 16px;
  }
}

@media (max-width: 680px) {
  .mm-services-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px;
  }

  .mm-service-image {
    height: 155px;
  }

  .mm-service-body {
    padding: 14px;
  }
}

@media (max-width: 460px) {
  .mm-services-grid {
    grid-template-columns: 1fr;
  }

  .mm-service-image {
    height: 180px;
  }
}


/* Popular services v2 */
.mm-popular-services {
  padding: 52px 0 60px;
}

.mm-section-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  margin-bottom: 28px;
}

.mm-section-label {
  display: none;
}

.mm-section-head h2 {
  margin: 0;
  color: var(--dark);
  font-size: clamp(30px, 2.8vw, 42px);
  line-height: 1.1;
  font-weight: 600;
}

.mm-section-head p {
  display: none;
}

.mm-section-link {
  min-height: 42px;
  padding: 0 16px;
  border-radius: 10px;
  background: #f4edff;
  color: var(--purple);
  font-size: 14px;
  font-weight: 600;
}

.mm-services-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 22px;
}

.mm-service-card {
  border-radius: 20px;
  box-shadow: 0 12px 28px rgba(18, 22, 39, .07);
}

.mm-service-image {
  height: 235px;
  border-bottom: 1px solid #f1f2f6;
}

.mm-service-body {
  padding: 18px 18px 20px;
}

.mm-service-body h3 {
  min-height: 48px;
  margin: 0 0 10px;
  font-size: 21px;
  line-height: 1.22;
  font-weight: 600;
}

.mm-service-body p {
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.45;
}

.mm-service-more {
  height: 42px;
  padding: 0 16px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
}

@media (max-width: 1120px) {
  .mm-services-grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 18px;
  }

  .mm-service-image {
    height: 210px;
  }

  .mm-service-body h3 {
    font-size: 19px;
  }
}

@media (max-width: 900px) {
  .mm-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .mm-services-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
  }
}

@media (max-width: 520px) {
  .mm-section-head {
    display: block;
  }

  .mm-section-link {
    margin-top: 14px;
  }

  .mm-services-grid {
    grid-template-columns: 1fr;
  }

  .mm-service-image {
    height: 210px;
  }
}


/* Popular products layout like reference */
.mm-popular-services {
  padding: 46px 0 58px;
  background: #fff;
}

.mm-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 26px;
}

.mm-section-head h2 {
  margin: 0;
  color: var(--dark);
  font-size: clamp(30px, 2.8vw, 42px);
  line-height: 1.1;
  font-weight: 400;
  letter-spacing: -0.5px;
}

.mm-section-link {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  padding: 0 15px;
  border-radius: 10px;
  background: #f4edff;
  color: var(--purple);
  font-size: 14px;
  font-weight: 600;
}

.mm-services-grid {
  display: none;
}

.mm-products-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 34px 24px;
}

.mm-product-card {
  display: block;
  color: inherit;
}

.mm-product-image {
  height: 220px;
  display: block;
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  background: #dcefe8;
  box-shadow: 0 9px 18px rgba(18, 22, 39, .10);
}

.mm-product-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 42%, rgba(255,255,255,.58), transparent 0 34%, transparent 60%),
    linear-gradient(135deg, rgba(255,255,255,.18), rgba(0,0,0,.05));
}

.mm-product-image::after {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 82px;
  filter: drop-shadow(0 14px 18px rgba(18,22,39,.16));
}

.mm-product-image-1::after { content: "📖"; }
.mm-product-image-2::after { content: "🖼️"; }
.mm-product-image-3::after { content: "📅"; }
.mm-product-image-4::after { content: "🗓️"; }
.mm-product-image-5::after { content: "👕"; }
.mm-product-image-6::after { content: "☕"; }
.mm-product-image-7::after { content: "📷"; }
.mm-product-image-8::after { content: "🖼"; }

.mm-product-info {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
  padding: 13px 5px 0;
}

.mm-product-info strong {
  display: block;
  color: var(--dark);
  font-size: 18px;
  line-height: 1.15;
  font-weight: 400;
}

.mm-product-info small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.2;
}

.mm-product-info b {
  color: var(--red);
  font-size: 17px;
  line-height: 1.15;
  font-weight: 600;
  white-space: nowrap;
}

.mm-product-card:hover .mm-product-image {
  transform: translateY(-2px);
  box-shadow: 0 14px 26px rgba(18, 22, 39, .14);
}

.mm-product-image {
  transition: transform .2s ease, box-shadow .2s ease;
}

@media (max-width: 1120px) {
  .mm-products-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 820px) {
  .mm-products-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 28px 18px;
  }

  .mm-product-image {
    height: 195px;
  }
}

@media (max-width: 520px) {
  .mm-section-head {
    display: block;
  }

  .mm-section-link {
    margin-top: 14px;
  }

  .mm-products-grid {
    grid-template-columns: 1fr;
  }

  .mm-product-image {
    height: 215px;
  }
}


/* Wide layout adjustment */
.mm-container,
.mm-mega__inner,
.mega-inner {
  width: min(1320px, calc(100% - 48px));
}

.mm-slider-prev {
  left: max(18px, calc((100vw - 1320px) / 2 - 64px));
}

.mm-slider-next {
  right: max(18px, calc((100vw - 1320px) / 2 - 64px));
}

.mm-products-grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 36px 28px;
}

.mm-product-image {
  height: 240px;
}

@media (max-width: 1380px) {
  .mm-container,
  .mm-mega__inner,
  .mega-inner {
    width: min(1280px, calc(100% - 40px));
  }

  .mm-product-image {
    height: 225px;
  }
}

@media (max-width: 1120px) {
  .mm-container,
  .mm-mega__inner,
  .mega-inner {
    width: min(100% - 36px, 1320px);
  }
}


/* About / Advantages block */
.mm-about-advantages {
  padding: 58px 0 66px;
  background: #ffffff;
}

.mm-advantages-head {
  margin-bottom: 26px;
}

.mm-advantages-head h2 {
  margin: 0;
  color: var(--dark);
  font-size: clamp(34px, 3.6vw, 58px);
  line-height: 1.06;
  font-weight: 400;
  letter-spacing: -0.8px;
}

.mm-advantages-head h2 span {
  position: relative;
  display: inline-block;
}

.mm-advantages-head h2 span::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -8px;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--yellow) 0%, var(--red) 50%, var(--purple) 100%);
}

.mm-advantages-text {
  max-width: 1240px;
  margin-bottom: 28px;
}

.mm-advantages-text p {
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.65;
}

.mm-advantages-text p:last-child {
  margin-bottom: 0;
}

.mm-advantages-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px 54px;
  margin-top: 34px;
}

.mm-adv-card h3 {
  margin: 0 0 10px;
  color: var(--dark);
  font-size: 18px;
  line-height: 1.25;
  font-weight: 600;
}

.mm-adv-card p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.6;
}

.mm-advantages-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 30px;
}

.mm-adv-btn {
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 28px;
  border: 1px solid #dedee6;
  background: #ffffff;
  color: var(--dark);
  border-radius: 0;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
}

.mm-adv-btn-primary {
  background: #a856bb;
  border-color: #a856bb;
  color: #ffffff;
}

@media (max-width: 980px) {
  .mm-advantages-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 24px 28px;
  }
}

@media (max-width: 680px) {
  .mm-about-advantages {
    padding: 46px 0 54px;
  }

  .mm-advantages-text p {
    font-size: 15px;
    line-height: 1.55;
  }

  .mm-advantages-grid {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .mm-advantages-actions {
    gap: 12px;
  }

  .mm-adv-btn {
    width: 100%;
    padding: 0 18px;
  }
}


/* Category strip under slider */
.mm-category-strip {
  padding: 20px 0 18px;
  background: #ffffff;
}

.mm-category-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

.mm-cat-card {
  position: relative;
  min-height: 236px;
  display: flex;
  align-items: center;
  overflow: hidden;
  text-decoration: none;
}

.mm-cat-card--blue { background: #0f7bc1; }
.mm-cat-card--red { background: #d80c2f; }
.mm-cat-card--green { background: #7ebb2f; }
.mm-cat-card--black { background: #000000; }

.mm-cat-copy {
  position: relative;
  z-index: 2;
  width: 56%;
  padding: 24px 16px 24px 28px;
}

.mm-cat-copy h3 {
  margin: 0 0 10px;
  color: #ffffff;
  font-size: clamp(28px, 2vw, 34px);
  line-height: 1.05;
  font-weight: 600;
}

.mm-cat-copy p {
  margin: 0;
  color: rgba(255,255,255,.95);
  font-size: 15px;
  line-height: 1.35;
  font-weight: 400;
}

.mm-cat-visual {
  position: absolute;
  inset: 0 0 0 auto;
  width: 50%;
}

/* Photo visual */
.mm-polaroid {
  position: absolute;
  display: block;
  width: 110px;
  height: 140px;
  background: #ffffff;
  border-radius: 3px;
  box-shadow: 0 14px 24px rgba(0,0,0,.22);
}

.mm-polaroid::before {
  content: '';
  position: absolute;
  left: 8px;
  right: 8px;
  top: 8px;
  height: 92px;
  background: linear-gradient(135deg, #fed447 0%, #9f3ed8 100%);
}

.mm-polaroid::after {
  content: '';
  position: absolute;
  left: 22px;
  bottom: 16px;
  width: 34px;
  height: 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.66);
}

.mm-polaroid--1 { top: 12px; right: 36px; transform: rotate(7deg); }
.mm-polaroid--2 { top: 74px; right: 70px; transform: rotate(-9deg); }
.mm-polaroid--3 { top: 118px; right: 18px; transform: rotate(8deg); }

/* Paper visual */
.mm-sheet {
  position: absolute;
  display: block;
  background: #ffffff;
  box-shadow: 0 14px 24px rgba(0,0,0,.18);
}

.mm-sheet::before {
  content: '';
  position: absolute;
  inset: 12px;
  background:
    linear-gradient(180deg, transparent 0 10px, #e8edf7 10px 12px, transparent 12px),
    linear-gradient(135deg, #1d49b3 0%, #ffffff 65%);
}

.mm-sheet--1 { width: 128px; height: 168px; right: 0; top: 56px; transform: rotate(6deg); }
.mm-sheet--2 { width: 110px; height: 142px; right: 104px; top: 52px; transform: rotate(-8deg); }
.mm-sheet--3 { width: 48px; height: 48px; right: 72px; top: 20px; border-radius: 10px; background: #1655ca; }

.mm-sheet--3::before { inset: 10px; background: linear-gradient(180deg, #ffffff 0%, #d8e5ff 100%); border-radius: 6px; }

/* Shirts visual */
.mm-shirt {
  position: absolute;
  display: block;
  width: 110px;
  height: 126px;
  background: #ffffff;
  clip-path: polygon(18% 10%, 32% 0, 45% 10%, 55% 10%, 68% 0, 82% 10%, 100% 28%, 88% 38%, 88% 100%, 12% 100%, 12% 38%, 0 28%);
  box-shadow: 0 14px 24px rgba(0,0,0,.16);
}

.mm-shirt::before {
  content: '';
  position: absolute;
  inset: 22px 18px 18px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(0,0,0,.16), rgba(255,255,255,.10));
}

.mm-shirt--1 { top: 56px; right: 98px; background: #ffffff; transform: rotate(-8deg); }
.mm-shirt--2 { top: 42px; right: 18px; background: #f06a8f; transform: rotate(7deg); }

/* Printer visual */
.mm-printer-body {
  position: absolute;
  top: 26px;
  right: 22px;
  width: 160px;
  height: 72px;
  border-radius: 6px 6px 0 0;
  background: linear-gradient(180deg, #5f6a73 0%, #8c99a3 100%);
  box-shadow: 0 16px 24px rgba(0,0,0,.30);
}

.mm-printer-body::before {
  content: '';
  position: absolute;
  left: 10px;
  top: 10px;
  width: 64px;
  height: 14px;
  background: linear-gradient(90deg, #f06b7a, #46b6ff, #9dd94c, #ffd95b);
  border-radius: 3px;
}

.mm-printer-roll {
  position: absolute;
  top: 92px;
  right: 22px;
  width: 160px;
  height: 18px;
  background: #2a2f36;
}

.mm-printer-print {
  position: absolute;
  top: 110px;
  right: 44px;
  width: 126px;
  height: 96px;
  background: linear-gradient(180deg, #18a7e1 0%, #64c7ff 45%, #1f2a45 45%, #1f2a45 100%);
  box-shadow: 0 16px 26px rgba(0,0,0,.28);
}

.mm-printer-print::before {
  content: '';
  position: absolute;
  left: 18px;
  top: 8px;
  width: 90px;
  height: 62px;
  background: radial-gradient(circle at 50% 30%, #8ee2ff 0 18%, transparent 19%), radial-gradient(circle at 62% 28%, #4ac3f1 0 20%, transparent 21%), radial-gradient(circle at 54% 52%, #22a0d7 0 28%, transparent 29%);
}

.mm-cat-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(18, 22, 39, .10);
}

.mm-cat-card {
  transition: transform .22s ease, box-shadow .22s ease;
}

@media (max-width: 1180px) {
  .mm-category-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 760px) {
  .mm-category-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .mm-cat-card {
    min-height: 220px;
  }

  .mm-cat-copy {
    width: 58%;
    padding-left: 22px;
    padding-right: 10px;
  }

  .mm-cat-copy h3 {
    font-size: 30px;
  }

  .mm-cat-copy p {
    font-size: 14px;
  }
}

@media (max-width: 520px) {
  .mm-cat-card {
    min-height: 200px;
  }

  .mm-cat-copy {
    width: 60%;
    padding: 18px 10px 18px 18px;
  }

  .mm-cat-copy h3 {
    font-size: 24px;
  }

  .mm-cat-copy p {
    font-size: 13px;
    line-height: 1.3;
  }

  .mm-cat-visual {
    width: 48%;
  }

  .mm-polaroid, .mm-sheet--1, .mm-sheet--2, .mm-shirt {
    transform: scale(.82) !important;
    transform-origin: center center;
  }

  .mm-printer-body, .mm-printer-roll, .mm-printer-print {
    transform: scale(.82);
    transform-origin: top right;
  }
}


/* Category strip v2: 3 wider cards, centered content */
.mm-category-strip {
  padding: 20px 0 18px;
}

.mm-category-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}

.mm-cat-card {
  min-height: 236px;
  display: flex;
  align-items: center;
}

.mm-cat-copy {
  position: relative;
  z-index: 2;
  width: 54%;
  padding: 22px 14px 22px 30px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}

.mm-cat-copy h3 {
  margin: 0 0 10px;
  font-size: clamp(28px, 2vw, 34px);
  line-height: 1.08;
  font-weight: 600;
  text-align: left;
}

.mm-cat-copy p {
  margin: 0;
  max-width: 240px;
  font-size: 15px;
  line-height: 1.35;
  text-align: left;
}

.mm-cat-visual {
  width: 50%;
}

/* stretch visuals a bit for 3-card layout */
.mm-polaroid { width: 122px; height: 152px; }
.mm-polaroid--1 { top: 6px; right: 30px; transform: rotate(7deg); }
.mm-polaroid--2 { top: 72px; right: 92px; transform: rotate(-9deg); }
.mm-polaroid--3 { top: 120px; right: 24px; transform: rotate(8deg); }

.mm-sheet--1 { width: 140px; height: 180px; right: 0; top: 52px; transform: rotate(6deg); }
.mm-sheet--2 { width: 120px; height: 150px; right: 118px; top: 48px; transform: rotate(-8deg); }
.mm-sheet--3 { width: 52px; height: 52px; right: 86px; top: 18px; }

.mm-shirt { width: 122px; height: 138px; }
.mm-shirt--1 { top: 54px; right: 118px; transform: rotate(-8deg); }
.mm-shirt--2 { top: 38px; right: 22px; transform: rotate(7deg); }

@media (max-width: 1180px) {
  .mm-category-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }

  .mm-cat-copy {
    width: 56%;
    padding-left: 24px;
  }

  .mm-cat-copy h3 {
    font-size: 30px;
  }

  .mm-cat-copy p {
    font-size: 14px;
  }
}

@media (max-width: 980px) {
  .mm-category-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .mm-cat-card {
    min-height: 218px;
  }

  .mm-cat-copy {
    width: 56%;
    padding-left: 24px;
  }
}

@media (max-width: 520px) {
  .mm-cat-card {
    min-height: 198px;
  }

  .mm-cat-copy {
    width: 60%;
    padding: 18px 10px 18px 18px;
  }

  .mm-cat-copy h3 {
    font-size: 24px;
  }

  .mm-cat-copy p {
    max-width: 180px;
    font-size: 13px;
  }
}


/* Category strip compact height */
.mm-category-strip {
  padding: 16px 0 14px;
}

.mm-cat-card {
  min-height: 190px;
}

.mm-cat-copy {
  padding-top: 18px;
  padding-bottom: 18px;
}

.mm-cat-copy h3 {
  font-size: clamp(25px, 1.8vw, 31px);
  margin-bottom: 8px;
}

.mm-cat-copy p {
  font-size: 14px;
}

.mm-polaroid {
  width: 104px;
  height: 130px;
}

.mm-polaroid::before {
  height: 82px;
}

.mm-polaroid--1 { top: 4px; right: 28px; }
.mm-polaroid--2 { top: 56px; right: 84px; }
.mm-polaroid--3 { top: 92px; right: 18px; }

.mm-sheet--1 {
  width: 120px;
  height: 156px;
  top: 36px;
  right: 0;
}

.mm-sheet--2 {
  width: 104px;
  height: 132px;
  top: 34px;
  right: 100px;
}

.mm-sheet--3 {
  width: 46px;
  height: 46px;
  top: 10px;
  right: 74px;
}

.mm-shirt {
  width: 104px;
  height: 118px;
}

.mm-shirt--1 {
  top: 44px;
  right: 104px;
}

.mm-shirt--2 {
  top: 30px;
  right: 18px;
}

@media (max-width: 980px) {
  .mm-cat-card {
    min-height: 190px;
  }
}

@media (max-width: 520px) {
  .mm-cat-card {
    min-height: 178px;
  }
}

/* News section */
.mm-news-section {
  padding: 54px 0 58px;
  background: #f8f8fb;
}

.mm-news-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  margin-bottom: 28px;
}

.mm-news-head h2 {
  margin: 0;
  color: var(--dark);
  font-size: clamp(30px, 2.8vw, 42px);
  line-height: 1.1;
  font-weight: 400;
  letter-spacing: -0.5px;
}

.mm-news-all {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  padding: 0 15px;
  border-radius: 10px;
  background: #f4edff;
  color: var(--purple);
  font-size: 14px;
  font-weight: 600;
}

.mm-news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.mm-news-card {
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 12px 28px rgba(18, 22, 39, .07);
  transition: transform .2s ease, box-shadow .2s ease;
}

.mm-news-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 34px rgba(18, 22, 39, .11);
}

.mm-news-image {
  height: 210px;
  display: block;
  position: relative;
  overflow: hidden;
  background-size: cover;
  background-position: center;
}

.mm-news-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 74% 22%, rgba(255, 212, 0, .35), transparent 0 26%, transparent 48%),
    linear-gradient(135deg, rgba(255,255,255,.12), rgba(0,0,0,.08));
}

.mm-news-image::after {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 72px;
  filter: drop-shadow(0 14px 18px rgba(18,22,39,.16));
}

.mm-news-image-1 {
  background: linear-gradient(135deg, #fff5d9, #f4edff);
}

.mm-news-image-1::after {
  content: "🎁";
}

.mm-news-image-2 {
  background: linear-gradient(135deg, #e8f2ff, #fff5d9);
}

.mm-news-image-2::after {
  content: "📄";
}

.mm-news-image-3 {
  background: linear-gradient(135deg, #fff1d8, #f4edff);
}

.mm-news-image-3::after {
  content: "🖼";
}

.mm-news-body {
  padding: 20px;
}

.mm-news-body time {
  display: block;
  margin-bottom: 10px;
  color: var(--purple);
  font-size: 13px;
  font-weight: 600;
}

.mm-news-body h3 {
  margin: 0 0 10px;
  color: var(--dark);
  font-size: 20px;
  line-height: 1.25;
  font-weight: 600;
}

.mm-news-body p {
  margin: 0 0 18px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

.mm-news-link {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  padding: 0 14px;
  border-radius: 10px;
  background: var(--dark);
  color: #ffffff;
  font-size: 14px;
  font-weight: 600;
}

.mm-news-link:hover {
  background: var(--purple);
}

@media (max-width: 980px) {
  .mm-news-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 620px) {
  .mm-news-head {
    display: block;
  }

  .mm-news-all {
    margin-top: 14px;
  }

  .mm-news-grid {
    grid-template-columns: 1fr;
  }

  .mm-news-image {
    height: 190px;
  }
}


/* Footer */
.mm-footer {
  background: #060606;
  color: #ffffff;
}

.mm-footer-main {
  padding: 42px 0 30px;
}

.mm-footer-grid {
  display: grid;
  grid-template-columns: 1.25fr 1fr 1fr 1fr .9fr;
  gap: 36px;
  align-items: start;
}

.mm-footer-brand {
  max-width: 360px;
}

.mm-footer-logo {
  display: inline-block;
  margin-bottom: 18px;
}

.mm-footer-logo img {
  width: 240px;
  filter: brightness(1.03);
}

.mm-footer-text {
  margin: 0 0 18px;
  color: rgba(255,255,255,.92);
  font-size: 15px;
  line-height: 1.45;
}

.mm-footer-contacts p {
  margin: 0 0 8px;
  color: #ffffff;
  font-size: 15px;
  line-height: 1.4;
}

.mm-footer-contacts a,
.mm-footer-col a {
  color: #ffffff;
}

.mm-footer-col h3 {
  margin: 2px 0 18px;
  color: #ffffff;
  font-size: 18px;
  line-height: 1.2;
  font-weight: 700;
  text-transform: uppercase;
}

.mm-footer-col ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.mm-footer-col li {
  margin: 0 0 14px;
}

.mm-footer-col li:last-child {
  margin-bottom: 0;
}

.mm-footer-col a {
  display: inline-block;
  color: rgba(255,255,255,.95);
  font-size: 15px;
  line-height: 1.35;
}

.mm-footer-col a:hover,
.mm-footer-contacts a:hover {
  color: var(--yellow);
}

.mm-footer-col--reviews {
  min-width: 0;
}

.mm-review-box {
  display: inline-block;
  min-width: 150px;
  padding: 10px 12px;
  border-radius: 4px;
  background: #ffffff;
  color: #222222;
}

.mm-review-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.mm-review-map {
  font-size: 15px;
}

.mm-review-rating {
  font-size: 22px;
  line-height: 1;
  font-weight: 600;
}

.mm-review-stars {
  color: #ffcf3e;
  letter-spacing: 1px;
  font-size: 15px;
}

.mm-review-caption {
  color: #666666;
  font-size: 11px;
  line-height: 1.25;
}

.mm-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.12);
  background: #050505;
}

.mm-footer-bottom-inner {
  padding: 18px 0 16px;
}

.mm-footer-bottom-inner p {
  margin: 0 0 8px;
  color: #ffffff;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 600;
}

.mm-footer-bottom-inner p:last-child {
  margin-bottom: 0;
  font-weight: 500;
}

@media (max-width: 1180px) {
  .mm-footer-grid {
    grid-template-columns: 1.2fr 1fr 1fr 1fr;
  }

  .mm-footer-col--reviews {
    grid-column: 1 / -1;
  }
}

@media (max-width: 900px) {
  .mm-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: 28px 22px;
  }

  .mm-footer-brand {
    max-width: none;
    grid-column: 1 / -1;
  }
}

@media (max-width: 620px) {
  .mm-footer-main {
    padding: 34px 0 24px;
  }

  .mm-footer-grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .mm-footer-logo img {
    width: 210px;
  }

  .mm-footer-col h3 {
    margin-bottom: 14px;
    font-size: 16px;
  }

  .mm-footer-col li {
    margin-bottom: 10px;
  }

  .mm-footer-bottom-inner {
    padding: 16px 0 14px;
  }

  .mm-footer-bottom-inner p {
    font-size: 13px;
  }
}


/* Final cleanup: remove demo spacing and unify typography */
html {
  font-size: 16px;
}

body {
  font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: 16px;
  line-height: 1.5;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

.mm-demo-content,
.mm-scroll-demo {
  display: none !important;
  min-height: 0 !important;
  height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

.mm-top,
.mm-slider,
.mm-category-strip,
.mm-popular-services,
.mm-about-advantages,
.mm-news-section,
.mm-footer {
  font-family: inherit;
}

/* Header */
.mm-contact-item {
  font-size: 14px;
  font-weight: 500;
}

.mm-branches-button,
.mm-callback-button,
.mm-menu-extra a,
.mm-mobile-menu-btn {
  font-weight: 600;
}

.mm-nav-link {
  font-size: 15px;
  font-weight: 500;
  line-height: 1.25;
}

.mm-mega-card h3 {
  font-size: 20px;
  font-weight: 600;
}

.mm-mega-card p,
.mm-mega-col a {
  font-size: 14px;
  font-weight: 400;
}

.mm-mega-col h4 {
  font-size: 14px;
  font-weight: 600;
}

/* Slider */
.mm-slide h1,
.mm-slide h2 {
  font-size: clamp(30px, 3.4vw, 46px);
  font-weight: 600;
  letter-spacing: -0.6px;
}

.mm-slide p {
  font-size: clamp(15px, 1.2vw, 18px);
  font-weight: 400;
}

.mm-slide-label,
.mm-slide-btn {
  font-weight: 600;
}

/* Category strip */
.mm-cat-copy h3 {
  font-size: clamp(25px, 1.8vw, 31px);
  font-weight: 600;
}

.mm-cat-copy p {
  font-size: 14px;
  font-weight: 400;
}

/* Popular products */
.mm-popular-services {
  padding-top: 42px;
  padding-bottom: 50px;
}

.mm-section-head h2,
.mm-news-head h2,
.mm-advantages-head h2 {
  font-weight: 400;
  letter-spacing: -0.4px;
}

.mm-section-head h2,
.mm-news-head h2 {
  font-size: clamp(30px, 2.6vw, 40px);
}

.mm-product-info strong {
  font-size: 18px;
  font-weight: 400;
}

.mm-product-info small {
  font-size: 13px;
  font-weight: 400;
}

.mm-product-info b {
  font-size: 17px;
  font-weight: 600;
}

/* Advantages */
.mm-about-advantages {
  padding-top: 50px;
  padding-bottom: 58px;
}

.mm-advantages-head h2 {
  font-size: clamp(34px, 3.2vw, 52px);
}

.mm-advantages-text p {
  font-size: 15px;
  line-height: 1.65;
  font-weight: 400;
}

.mm-adv-card h3 {
  font-size: 18px;
  font-weight: 600;
}

.mm-adv-card p {
  font-size: 15px;
  font-weight: 400;
}

.mm-adv-btn {
  font-size: 14px;
  font-weight: 600;
}

/* News */
.mm-news-section {
  padding-top: 50px;
  padding-bottom: 58px;
}

.mm-news-body time {
  font-size: 13px;
  font-weight: 600;
}

.mm-news-body h3 {
  font-size: 20px;
  font-weight: 600;
}

.mm-news-body p {
  font-size: 15px;
  font-weight: 400;
}

.mm-news-link,
.mm-news-all,
.mm-section-link {
  font-weight: 600;
}

/* Footer */
.mm-footer-text,
.mm-footer-contacts p,
.mm-footer-col a {
  font-size: 15px;
  font-weight: 400;
}

.mm-footer-col h3 {
  font-size: 16px;
  font-weight: 600;
}

.mm-footer-bottom-inner p {
  font-size: 13px;
  font-weight: 500;
}

@media (max-width: 620px) {
  body {
    font-size: 15px;
  }

  .mm-slide h1,
  .mm-slide h2 {
    font-size: 30px;
  }

  .mm-section-head h2,
  .mm-news-head h2 {
    font-size: 30px;
  }

  .mm-advantages-head h2 {
    font-size: 34px;
  }
}


/* WordPress content */
.mm-page {
  padding: 46px 0 60px;
  background: #fff;
}

.mm-wp-content {
  max-width: 980px;
}

.mm-wp-content h1 {
  margin: 0 0 24px;
  color: var(--dark);
  font-size: clamp(32px, 3vw, 46px);
  font-weight: 500;
  line-height: 1.1;
}

.mm-wp-content p,
.mm-wp-content li {
  color: var(--text);
  font-size: 16px;
  line-height: 1.65;
}

.mm-wp-menu,
.mm-wp-menu ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.mm-wp-menu {
  display: flex;
  align-items: stretch;
  gap: 4px;
  height: 100%;
}

.mm-wp-menu > li {
  position: relative;
  display: flex;
  align-items: stretch;
}

.mm-wp-menu > li > a {
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 15px;
  color: var(--dark);
  font-size: 15px;
  font-weight: 500;
  border-bottom: 3px solid transparent;
}

.mm-wp-menu > li:hover > a,
.mm-wp-menu > li.current-menu-item > a {
  color: var(--red);
  border-bottom-color: var(--red);
}

.mm-wp-menu .sub-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 260px;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 16px 34px rgba(18,22,39,.12);
  z-index: 50;
}

.mm-wp-menu li:hover > .sub-menu {
  display: block;
}

.mm-wp-menu .sub-menu a {
  display: block;
  padding: 9px 10px;
  color: var(--dark);
  font-size: 14px;
  font-weight: 400;
}

.mm-wp-menu .sub-menu a:hover {
  color: var(--purple);
}

/* WordPress logo compatibility */
.mm-logo .custom-logo {
  width: 156px;
  height: auto;
}

.mm-footer-logo .custom-logo {
  width: 240px;
  height: auto;
}


/* Admin-driven menu */
.mm-main-nav .mm-wp-menu,
.mm-main-nav .menu {
  margin: 0;
  padding: 0;
  list-style: none;
  height: 100%;
  display: flex;
  align-items: stretch;
  gap: 4px;
}

.mm-main-nav .mm-wp-menu > li,
.mm-main-nav .menu > li {
  display: flex;
  align-items: stretch;
  position: relative;
}

.mm-main-nav .mm-wp-menu > li > a,
.mm-main-nav .menu > li > a {
  height: 100%;
  display: flex;
  align-items: center;
  padding: 0 15px;
  color: var(--dark);
  font-size: 15px;
  font-weight: 500;
  border-bottom: 3px solid transparent;
}

.mm-main-nav .mm-wp-menu > li:hover > a,
.mm-main-nav .mm-wp-menu > li.current-menu-item > a,
.mm-main-nav .menu > li:hover > a,
.mm-main-nav .menu > li.current-menu-item > a {
  color: var(--red);
  border-bottom-color: var(--red);
}

.mm-main-nav .sub-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 260px;
  margin: 0;
  padding: 12px;
  list-style: none;
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: 0 16px 34px rgba(18,22,39,.12);
  z-index: 50;
}

.mm-main-nav li:hover > .sub-menu {
  display: block;
}

.mm-main-nav .sub-menu a {
  display: block;
  padding: 9px 10px;
  color: var(--dark);
  font-size: 14px;
  font-weight: 400;
}

.mm-main-nav .sub-menu a:hover {
  color: var(--purple);
}

.mm-yandex-widget iframe {
  max-width: 100%;
}


/* Media library images */
.mm-slide-bg[style] {
  background-size: cover;
  background-position: center;
}

.mm-cat-card--image {
  background-size: cover;
  background-position: center;
}

.mm-cat-card--image::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.48) 0%, rgba(0,0,0,.18) 65%, rgba(0,0,0,.05) 100%);
  z-index: 1;
}

.mm-cat-card--image .mm-cat-copy {
  position: relative;
  z-index: 2;
}

.mm-cat-card--image .mm-cat-visual {
  display: none;
}


/* Regular pages */
.mm-page {
  padding: 52px 0 64px;
  background: #fff;
}

.mm-entry-content {
  max-width: 980px;
}

.mm-entry-content p,
.mm-entry-content li {
  color: var(--text);
  font-size: 16px;
  line-height: 1.65;
}

/* Callback modal */
.mm-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: none;
  padding: 24px;
}

.mm-modal.is-open {
  display: grid;
  place-items: center;
}

.mm-modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(8, 10, 18, .62);
  backdrop-filter: blur(3px);
}

.mm-modal__dialog {
  position: relative;
  z-index: 2;
  width: min(560px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 30px;
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 26px 70px rgba(0,0,0,.30);
}

.mm-modal__close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 50%;
  background: #f4edff;
  color: var(--purple);
  font-size: 26px;
  line-height: 1;
  cursor: pointer;
}

.mm-modal__dialog h2 {
  margin: 0 44px 12px 0;
  color: var(--dark);
  font-size: 28px;
  line-height: 1.15;
  font-weight: 600;
}

.mm-modal__text {
  margin-bottom: 18px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.55;
}

.mm-modal__text p {
  margin: 0 0 10px;
}

.mm-modal__form input[type="text"],
.mm-modal__form input[type="tel"],
.mm-modal__form input[type="email"],
.mm-modal__form textarea {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  font: inherit;
}

.mm-modal__form input[type="submit"],
.mm-modal__form button[type="submit"] {
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: 10px;
  background: var(--yellow);
  color: #1b1200;
  font-weight: 600;
  cursor: pointer;
}

.mm-shortcode-placeholder {
  padding: 16px;
  border-radius: 12px;
  background: #f8f8fb;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

body.mm-modal-open {
  overflow: hidden;
}

@media (max-width: 620px) {
  .mm-modal {
    padding: 14px;
  }

  .mm-modal__dialog {
    padding: 24px 18px;
    border-radius: 16px;
  }

  .mm-modal__dialog h2 {
    font-size: 24px;
  }
}


/* Page banner */
.mm-page {
  background: #fff;
}

.mm-page-hero {
  position: relative;
  min-height: 330px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: linear-gradient(120deg, #10152e 0%, #2a0952 52%, #6f1fa2 100%);
  background-size: cover;
  background-position: center;
}

.mm-page-hero--image {
  min-height: 380px;
}

.mm-page-hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(10, 12, 24, .76) 0%, rgba(10, 12, 24, .54) 48%, rgba(10, 12, 24, .18) 100%),
    linear-gradient(180deg, rgba(0,0,0,.12) 0%, rgba(0,0,0,.22) 100%);
}

.mm-page-hero--plain .mm-page-hero__overlay {
  background:
    radial-gradient(circle at 82% 28%, rgba(255, 212, 0, .28), transparent 0 20%, transparent 38%),
    linear-gradient(90deg, rgba(10, 12, 24, .35), rgba(10, 12, 24, .10));
}

.mm-page-hero__content {
  position: relative;
  z-index: 2;
  color: #fff;
  padding-top: 54px;
  padding-bottom: 54px;
}

.mm-page-hero__content h1 {
  max-width: 760px;
  margin: 0 0 14px;
  font-size: clamp(34px, 4vw, 56px);
  line-height: 1.06;
  font-weight: 600;
  letter-spacing: -0.6px;
}

.mm-page-hero__content p {
  max-width: 660px;
  margin: 0;
  color: rgba(255,255,255,.88);
  font-size: clamp(16px, 1.35vw, 20px);
  line-height: 1.5;
}

.mm-page-content {
  padding: 48px 0 64px;
}

.mm-page-content .mm-wp-content {
  max-width: 980px;
}

@media (max-width: 760px) {
  .mm-page-hero,
  .mm-page-hero--image {
    min-height: 300px;
  }

  .mm-page-hero__content {
    padding-top: 42px;
    padding-bottom: 42px;
  }

  .mm-page-hero__content h1 {
    font-size: 34px;
  }

  .mm-page-content {
    padding: 38px 0 52px;
  }
}


/* Page banner fixes v0.4.1 */
.mm-page-template,
body.page .mm-page {
  padding: 0 !important;
  margin: 0 !important;
}

.mm-page-hero {
  margin-top: 0 !important;
}

.mm-page-hero--image {
  background-image: var(--mm-page-banner-image) !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}

.mm-page-hero--image .mm-page-hero__overlay {
  background:
    linear-gradient(90deg, rgba(10, 12, 24, .58) 0%, rgba(10, 12, 24, .36) 48%, rgba(10, 12, 24, .08) 100%),
    linear-gradient(180deg, rgba(0,0,0,.05) 0%, rgba(0,0,0,.16) 100%) !important;
}

.mm-page-hero__content p {
  display: block;
  margin-top: 8px;
  max-width: 720px;
  color: rgba(255,255,255,.92);
  font-size: clamp(16px, 1.35vw, 20px);
  line-height: 1.5;
}


/* Popular services shortcode area */
.mm-home-services-shortcode {
  min-width: 0;
}

.mm-home-services-shortcode .mm-services-grid,
.mm-home-services-shortcode .mms-services-grid,
.mm-home-services-shortcode .media-mir-services-grid {
  margin: 0;
}

.mm-home-services-shortcode:empty {
  display: none;
}


/* MegaMenu admin module */
.mm-menu-row { position: relative; }
.mm-main-nav, .mm-main-nav .mm-wp-menu, .mm-main-nav .menu { position: static; }
.mm-main-nav .mm-wp-menu > li, .mm-main-nav .menu > li, .mm-main-nav li.menu-item-has-mega { position: static; }
.mm-main-nav li.menu-item-has-mega > a::after { content: "⌄"; margin-left: 7px; color: var(--purple); font-size: 12px; }
.mm-main-nav li.menu-item-has-mega .mm-mega { display: none; }
.mm-main-nav li.menu-item-has-mega:hover .mm-mega { display: block; }

.mm-mega {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  width: 100%;
  min-height: 310px;
  background: #fff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 22px 45px rgba(18,22,39,.12);
  padding: 24px 0;
  z-index: 100;
}

.mm-mega__inner {
  width: min(1320px, calc(100% - 48px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 22px;
  align-items: stretch;
  min-height: 250px;
}

.mm-mega-card { height: 100%; border-radius: 18px; background: linear-gradient(135deg,#fff9d8,#f4edff); padding: 18px; }
.mm-mega-card h3 { margin: 0 0 8px; color: var(--dark); font-size: 20px; font-weight: 600; }
.mm-mega-card p { margin: 0 0 14px; color: var(--muted); font-size: 14px; line-height: 1.35; }
.mm-mega-card a { display: inline-flex; min-height: 38px; align-items: center; padding: 0 14px; border-radius: 10px; background: var(--dark); color: #fff; font-size: 13px; font-weight: 600; }

.mm-mega-col h4 { margin: 0 0 11px; color: var(--dark); font-size: 14px; text-transform: uppercase; font-weight: 600; letter-spacing: .02em; }
.mm-mega-col ul { margin: 0; padding: 0; list-style: none; display: grid; gap: 8px; }
.mm-mega-col a { display: flex; align-items: center; justify-content: space-between; gap: 8px; padding: 7px 0; color: #303746; font-size: 14px; font-weight: 400; border-bottom: 1px solid #f0f1f5; line-height: 1.25; }
.mm-mega-col a:hover { color: var(--purple); }
.mm-mega-col a::after { content: "→"; color: var(--purple); font-weight: 900; }

@media (max-width: 1120px) { .mm-mega__inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 960px) { .mm-main-nav li.menu-item-has-mega .mm-mega { display: none !important; } }


/* Single news page */
.mm-news-hero {
  position: relative;
  min-height: 390px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: linear-gradient(120deg, #10152e 0%, #2a0952 55%, #6f1fa2 100%);
  background-size: cover;
  background-position: center;
}

.mm-news-hero--image {
  background-image: var(--mm-news-hero-image);
  background-size: cover;
  background-position: center;
}

.mm-news-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(10,12,24,.76) 0%, rgba(10,12,24,.48) 52%, rgba(10,12,24,.16) 100%), linear-gradient(180deg, rgba(0,0,0,.08) 0%, rgba(0,0,0,.20) 100%);
}

.mm-news-hero--plain .mm-news-hero__overlay {
  background: radial-gradient(circle at 82% 28%, rgba(255,212,0,.28), transparent 0 20%, transparent 38%), linear-gradient(90deg, rgba(10,12,24,.35), rgba(10,12,24,.10));
}

.mm-news-hero__content {
  position: relative;
  z-index: 2;
  color: #fff;
  padding: 58px 0;
}

.mm-news-hero__content time {
  display: inline-flex;
  margin-bottom: 16px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.24);
  color: rgba(255,255,255,.92);
  font-size: 14px;
  font-weight: 600;
}

.mm-news-hero__content h1 {
  max-width: 880px;
  margin: 0 0 14px;
  color: #fff;
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.06;
  font-weight: 600;
  letter-spacing: -0.6px;
}

.mm-news-hero__content p {
  max-width: 760px;
  margin: 0;
  color: rgba(255,255,255,.90);
  font-size: clamp(16px, 1.35vw, 20px);
  line-height: 1.5;
}

.mm-news-single-section {
  padding: 52px 0 70px;
  background: #fff;
}

.mm-news-single-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 40px;
  align-items: start;
}

.mm-news-article-meta {
  margin-bottom: 22px;
  color: var(--muted);
  font-size: 14px;
}

.mm-news-article .mm-entry-content {
  max-width: 900px;
}

.mm-news-article .mm-entry-content h2,
.mm-news-article .mm-entry-content h3 {
  color: var(--dark);
  font-weight: 600;
  line-height: 1.2;
}

.mm-news-article .mm-entry-content p,
.mm-news-article .mm-entry-content li {
  color: var(--text);
  font-size: 17px;
  line-height: 1.75;
}

.mm-news-article .mm-entry-content img {
  height: auto;
  border-radius: 18px;
  margin: 26px 0;
}

.mm-news-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 28px;
}

.mm-news-tags a {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  background: #f4edff;
  color: var(--purple);
  font-size: 13px;
  font-weight: 600;
}

.mm-news-sidebar {
  position: sticky;
  top: 22px;
  display: grid;
  gap: 18px;
}

.mm-news-side-card {
  padding: 20px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(18,22,39,.07);
}

.mm-news-side-card h2 {
  margin: 0 0 14px;
  color: var(--dark);
  font-size: 21px;
  line-height: 1.2;
  font-weight: 600;
}

.mm-news-category-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.mm-news-category-list a {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 12px;
  border-radius: 12px;
  background: #f8f8fb;
  color: var(--dark);
  font-size: 14px;
  font-weight: 500;
}

.mm-news-category-list a:hover {
  background: #f4edff;
  color: var(--purple);
}

.mm-news-category-list b {
  min-width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #fff;
  color: var(--muted);
  font-size: 12px;
}

.mm-share-list {
  display: grid;
  gap: 8px;
}

.mm-share-list a,
.mm-share-list button {
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  color: var(--dark);
  font: inherit;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}

.mm-share-list a:hover,
.mm-share-list button:hover {
  border-color: #e7ddff;
  background: #f4edff;
  color: var(--purple);
}

.mm-news-side-card--accent {
  background: linear-gradient(135deg, #fff9d8, #f4edff);
}

.mm-news-side-text {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}

.mm-news-side-text p {
  margin: 0 0 12px;
}

.mm-news-side-shortcode {
  margin-top: 14px;
}

.mm-news-side-btn {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 14px;
  padding: 0 16px;
  border-radius: 12px;
  background: var(--dark);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
}

@media (max-width: 980px) {
  .mm-news-single-layout {
    grid-template-columns: 1fr;
  }

  .mm-news-sidebar {
    position: static;
  }
}

@media (max-width: 620px) {
  .mm-news-hero {
    min-height: 320px;
  }

  .mm-news-hero__content {
    padding: 44px 0;
  }

  .mm-news-hero__content h1 {
    font-size: 32px;
  }

  .mm-news-single-section {
    padding: 40px 0 56px;
  }

  .mm-news-article .mm-entry-content p,
  .mm-news-article .mm-entry-content li {
    font-size: 16px;
    line-height: 1.65;
  }
}


/* News: share block removed */
.mm-share-list {
  display: none;
}

/* MegaMenu improvements */
.mm-main-nav li.menu-item-has-children {
  position: relative;
}

.mm-main-nav li.menu-item-has-children > a::after,
.mm-main-nav li.menu-item-has-mega > a::after {
  content: "⌄";
  margin-left: 7px;
  color: var(--purple);
  font-size: 12px;
}

.mm-main-nav li.menu-item-has-children > .sub-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 260px;
  margin: 0;
  padding: 12px;
  list-style: none;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 0 0 14px 14px;
  box-shadow: 0 16px 34px rgba(18, 22, 39, .12);
  z-index: 120;
}

.mm-main-nav li.menu-item-has-children:hover > .sub-menu {
  display: block;
}

.mm-main-nav .sub-menu li {
  position: relative;
}

.mm-main-nav .sub-menu .sub-menu {
  top: -12px;
  left: 100%;
}

.mm-main-nav .sub-menu a {
  display: block;
  min-height: auto;
  padding: 9px 10px;
  border: 0;
  color: var(--dark);
  font-size: 14px;
  font-weight: 400;
  line-height: 1.3;
}

.mm-main-nav .sub-menu a:hover {
  color: var(--purple);
  background: #f8f8fb;
  border-radius: 9px;
}

.mm-mega-card--image {
  position: relative;
  overflow: hidden;
  background-image:
    linear-gradient(135deg, rgba(18,22,39,.82), rgba(111,31,162,.52)),
    var(--mm-mega-card-image);
  background-size: cover;
  background-position: center;
  color: #fff;
}

.mm-mega-card--image h3,
.mm-mega-card--image p {
  color: #fff;
}

.mm-mega-card--image .mm-mega-card__content {
  position: relative;
  z-index: 2;
}

.mm-mega-card__content {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.mm-mega-card__content p {
  flex: 1;
}

@media (max-width: 960px) {
  .mm-main-nav li.menu-item-has-children > .sub-menu {
    display: none !important;
  }
}


/* Custom main menu */
.mm-custom-menu-list {
  display: flex;
  align-items: stretch;
  gap: 4px;
  height: 100%;
}

.mm-main-nav li.menu-item-has-children,
.mm-main-nav li.menu-item-has-mega {
  position: static;
}

.mm-main-nav li.menu-item-has-children {
  position: relative;
}

.mm-main-nav li.menu-item-has-children > a::after,
.mm-main-nav li.menu-item-has-mega > a::after {
  content: "⌄";
  margin-left: 7px;
  color: var(--purple);
  font-size: 12px;
}


/* Contacts page */
.mm-contacts-page {
  background: #fff;
}

.mm-contacts-section {
  padding: 54px 0 68px;
}

.mm-contacts-head {
  margin-bottom: 42px;
}

.mm-contacts-head h1 {
  display: inline;
  margin: 0;
  color: var(--dark);
  font-size: clamp(34px, 3.6vw, 54px);
  line-height: 1.08;
  font-weight: 400;
  letter-spacing: -0.6px;
  background-image: linear-gradient(90deg, var(--yellow), var(--red), var(--purple));
  background-repeat: no-repeat;
  background-size: 100% 4px;
  background-position: 0 100%;
}

.mm-contacts-head p {
  max-width: 780px;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.55;
}

.mm-contacts-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 30px;
}

.mm-contact-office {
  min-width: 0;
}

.mm-contact-city {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  margin-bottom: 12px;
  padding: 0 10px;
  background: #f2f2f2;
  color: var(--dark);
  font-size: 14px;
  font-weight: 700;
}

.mm-contact-office h2 {
  margin: 0 0 12px;
  color: var(--dark);
  font-size: 18px;
  line-height: 1.25;
  font-weight: 700;
}

.mm-contact-time {
  min-height: 48px;
  margin-bottom: 20px;
}

.mm-contact-time p {
  margin: 0 0 3px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.35;
}

.mm-contact-office-line {
  height: 1px;
  margin: 0 0 16px;
  background: var(--line);
}

.mm-contact-details {
  min-height: 58px;
}

.mm-contact-details p {
  margin: 0 0 5px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.35;
}

.mm-contact-details strong {
  color: var(--dark);
  font-weight: 700;
}

.mm-contact-details a {
  color: var(--muted);
}

.mm-contact-details a:hover {
  color: var(--purple);
}

.mm-contact-actions {
  display: grid;
  gap: 18px;
  margin-top: 28px;
}

.mm-contact-actions a {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: 12px;
  align-items: center;
  color: var(--dark);
  font-size: 15px;
  line-height: 1.25;
}

.mm-contact-actions span {
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  font-size: 34px;
}

.mm-contact-actions a:hover {
  color: var(--purple);
}

.mm-contact-socials {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 34px;
  color: var(--muted);
  font-size: 15px;
}

.mm-contact-socials div {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.mm-contact-socials a {
  width: 25px;
  height: 25px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  background: var(--purple);
  font-size: 11px;
  font-weight: 700;
}

.mm-contact-socials a:nth-child(1) { background: #e94d85; }
.mm-contact-socials a:nth-child(2) { background: #f58220; }
.mm-contact-socials a:nth-child(3) { background: #2ca5e0; }
.mm-contact-socials a:nth-child(4) { background: #7360f2; }
.mm-contact-socials a:nth-child(5) { background: #2787f5; }
.mm-contact-socials a:nth-child(6) { background: #25d366; }

.mm-contact-map {
  margin-top: 36px;
  overflow: hidden;
  border-radius: 4px;
  background: #f2f3f7;
}

.mm-contact-map iframe {
  width: 100%;
  min-height: 420px;
  display: block;
  border: 0;
}

.mm-contact-extra-content {
  max-width: 980px;
  margin-top: 42px;
}

@media (max-width: 1120px) {
  .mm-contacts-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 34px 28px;
  }
}

@media (max-width: 680px) {
  .mm-contacts-section {
    padding: 42px 0 54px;
  }

  .mm-contacts-grid {
    grid-template-columns: 1fr;
  }

  .mm-contacts-head h1 {
    font-size: 34px;
  }

  .mm-contact-socials {
    align-items: flex-start;
    flex-direction: column;
  }

  .mm-contact-map iframe {
    min-height: 340px;
  }
}


/* Contacts page compact cards v0.6.2 */
.mm-contacts-section {
  padding: 38px 0 58px;
}

.mm-contacts-head {
  margin-bottom: 30px;
}

.mm-contacts-head h1 {
  display: inline;
  font-size: clamp(28px, 2.6vw, 42px) !important;
  line-height: 1.12;
  font-weight: 400;
  letter-spacing: -0.35px;
  background-size: 100% 3px;
}

.mm-contacts-head p {
  margin-top: 14px;
  font-size: 15px;
}

.mm-contacts-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.mm-contact-office {
  min-width: 0;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(18,22,39,.06);
}

.mm-contact-city {
  min-height: 25px;
  margin-bottom: 10px;
  padding: 0 9px;
  border-radius: 6px;
  background: #f4f5f8;
  font-size: 13px;
}

.mm-contact-office h2 {
  min-height: 44px;
  margin-bottom: 10px;
  font-size: 17px;
  line-height: 1.25;
}

.mm-contact-time {
  min-height: 48px;
  margin-bottom: 14px;
}

.mm-contact-time p {
  font-size: 14px;
}

.mm-contact-office-line {
  margin-bottom: 13px;
}

.mm-contact-details {
  min-height: 58px;
}

.mm-contact-details p {
  font-size: 14px;
}

.mm-contact-actions {
  gap: 12px;
  margin-top: 20px;
}

.mm-contact-actions a {
  grid-template-columns: 34px 1fr;
  gap: 10px;
  font-size: 14px;
}

.mm-contact-actions span {
  width: 34px;
  height: 34px;
  font-size: 25px;
}

.mm-contact-socials {
  margin-top: 28px;
}

.mm-contact-map {
  margin-top: 30px;
  border-radius: 18px;
  border: 1px solid var(--line);
  overflow: hidden;
  box-shadow: 0 10px 24px rgba(18,22,39,.06);
}

.mm-contact-map iframe {
  min-height: 400px;
}

/* Yandex constructor usually inserts script + iframe/div */
.mm-contact-map > ymaps,
.mm-contact-map > div,
.mm-contact-map .ymaps-2-1-79-map,
.mm-contact-map .ymaps-2-1-79-inner-panes {
  max-width: 100%;
}

.mm-contact-map script + * {
  width: 100% !important;
}

@media (max-width: 1180px) {
  .mm-contacts-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .mm-contact-office h2,
  .mm-contact-time,
  .mm-contact-details {
    min-height: 0;
  }
}

@media (max-width: 680px) {
  .mm-contacts-section {
    padding: 32px 0 48px;
  }

  .mm-contacts-grid {
    grid-template-columns: 1fr;
  }

  .mm-contacts-head h1 {
    font-size: 30px !important;
  }

  .mm-contact-office {
    padding: 16px;
  }

  .mm-contact-map iframe {
    min-height: 330px;
  }
}
