:root{
  --red:#a40012;
  --red-dark:#6e000a;
  --red-deep:#420006;
  --red-light:#d1001a;
  --black:#101010;
  --text:#151515;
  --muted:#666;
  --line:#e8e8e8;
  --white:#fff;
  --bg:#f6f6f6;
  --shadow:0 18px 45px rgba(0,0,0,.15);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--text);background:#fff;line-height:1.45}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
button,input,select,textarea{font-family:inherit}
.container{width:min(1180px,calc(100% - 32px));margin-inline:auto}
.header-shell{width:min(1440px,calc(100% - 56px));margin-inline:auto}
.hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important}

.btn{display:inline-flex;align-items:center;justify-content:center;min-height:52px;border:0;border-radius:4px;padding:14px 24px;background:linear-gradient(135deg,var(--red),var(--red-light));color:#fff;font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.03em;cursor:pointer;box-shadow:0 12px 24px rgba(164,0,18,.22);transition:transform .25s ease,box-shadow .25s ease,filter .25s ease}.btn:hover{transform:translateY(-2px);filter:brightness(1.05);box-shadow:0 16px 30px rgba(164,0,18,.32)}.btn--wide{width:100%}

.site-header{position:sticky;top:0;z-index:1000;background:#fff;box-shadow:0 8px 28px rgba(0,0,0,.08)}
.header-top{height:48px;background:#fff;border-top:1px solid #181818;border-bottom:1px solid #efefef}.header-top__inner{height:48px;display:flex;align-items:center;justify-content:flex-end;gap:28px}.top-menu{height:40px;display:flex;align-items:stretch;background:linear-gradient(90deg,var(--red-dark),var(--red),var(--red-dark));clip-path:polygon(42px 0,100% 0,calc(100% - 24px) 100%,0 100%);padding-left:56px;padding-right:26px;box-shadow:0 4px 12px rgba(95,0,10,.18)}.top-menu a{display:flex;align-items:center;justify-content:center;min-width:150px;padding:0 26px;color:#fff;font-size:15px;line-height:1;font-weight:900;text-transform:uppercase;letter-spacing:.02em;border-left:1px solid rgba(255,255,255,.13);transition:background .2s ease,box-shadow .2s ease}.top-menu a:first-child{border-left:0}.top-menu a:hover,.top-menu a.is-active{background:rgba(0,0,0,.26);box-shadow:inset 0 -3px 0 #ff4054}.lang-switch{display:flex;align-items:center;gap:8px}.lang-switch a{min-width:48px;height:38px;display:flex;align-items:center;justify-content:center;border:2px solid var(--red);background:#fff;color:var(--red-dark);font-size:14px;font-weight:900;box-shadow:0 10px 22px rgba(164,0,18,.12);transition:background .2s ease,color .2s ease,transform .2s ease}.lang-switch a:hover,.lang-switch a.is-active{background:var(--red);color:#fff;transform:translateY(-1px)}

.header-main{min-height:150px;display:flex;align-items:center;gap:28px}.site-logo{display:flex;align-items:center;gap:20px;min-width:430px;margin-right:auto}.site-logo img{width:126px;height:126px;object-fit:cover;border-radius:50%;box-shadow:0 10px 24px rgba(0,0,0,.18)}.site-logo__text strong{display:block;font-size:30px;line-height:.95;text-transform:uppercase;letter-spacing:.06em;color:#151515}.site-logo__text small{display:block;margin-top:9px;font-size:14px;line-height:1.15;text-transform:uppercase;font-weight:700;color:#333;max-width:320px}.mobile-phone-mini{display:none}
.header-actions{display:flex;align-items:center;gap:18px}.action-tile{height:56px;display:grid;grid-template-columns:74px 1fr;align-items:stretch;border:1.5px solid rgba(164,0,18,.34);background:#fff;color:var(--red-dark);box-shadow:0 8px 20px rgba(0,0,0,.07);transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease,background .25s ease;cursor:pointer;white-space:nowrap}.action-tile__icon{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--red-dark),var(--red));clip-path:polygon(24px 0,100% 0,80% 100%,0 100%);margin:-1.5px 0 -1.5px -1.5px}.action-tile__icon svg{width:36px;height:36px;fill:#fff;filter:drop-shadow(0 2px 1px rgba(0,0,0,.2))}.action-tile__text{display:flex;align-items:center;justify-content:center;min-width:110px;padding:0 22px 0 10px;font-size:17px;font-weight:900;letter-spacing:.01em}.action-tile:hover,.action-tile:focus-visible{border-color:var(--red);box-shadow:0 15px 32px rgba(164,0,18,.22);transform:translateY(-2px);outline:0}.action-tile:hover .action-tile__icon,.action-tile:focus-visible .action-tile__icon{background:linear-gradient(135deg,var(--red),var(--red-light))}.action-tile--callback{border:0;min-width:230px;background:linear-gradient(135deg,var(--red),var(--red-light));color:#fff;text-transform:uppercase;box-shadow:0 12px 26px rgba(164,0,18,.22);grid-template-columns:1fr 76px}.action-tile--callback .action-tile__icon{order:1;margin:-1.5px -1.5px -1.5px 0;clip-path:polygon(20px 0,100% 0,100% 100%,0 100%);background:linear-gradient(135deg,#74000b,#4b0007)}.action-tile--callback .action-tile__text{order:0;color:#fff;font-size:14px;padding:0 18px;line-height:1.15;min-width:auto}.action-tile--callback:hover{border:0;background:linear-gradient(135deg,var(--red-dark),var(--red));box-shadow:0 16px 34px rgba(164,0,18,.36)}
.header-phone{min-width:260px;color:var(--red-dark);text-align:left}.header-phone strong{display:block;font-size:31px;line-height:1;font-weight:900;letter-spacing:.02em}.header-phone span{display:block;margin-top:7px;font-size:17px;line-height:1.1;font-weight:900;text-transform:uppercase;color:var(--red)}.burger{display:none}

.service-nav{background:linear-gradient(180deg,var(--red),#9a0011);border-top:1px solid rgba(255,255,255,.15);border-bottom:1px solid rgba(0,0,0,.15)}.service-nav__inner{display:grid;grid-template-columns:repeat(4,1fr);width:100%;max-width:100%;margin:0}.service-nav__inner>a,.service-dropdown>button{height:68px;display:flex;align-items:center;justify-content:center;width:100%;border:0;border-left:1px solid rgba(255,255,255,.35);background:transparent;color:#fff;font-size:17px;font-weight:900;text-transform:uppercase;letter-spacing:.02em;cursor:pointer;transition:background .2s ease,box-shadow .2s ease}.service-nav__inner>a:first-child{border-left:0}.service-nav__inner>a:hover,.service-nav__inner>a.is-active,.service-dropdown.is-active>button,.service-dropdown:hover>button{background:rgba(0,0,0,.22);box-shadow:inset 0 -4px 0 #ff4054}.service-dropdown{position:relative}.service-dropdown>button span{margin-left:9px;font-size:15px}.service-dropdown__menu{position:absolute;left:50%;top:calc(100% + 14px);z-index:30;min-width:310px;transform:translateX(-50%) translateY(8px);opacity:0;visibility:hidden;background:#fff;border-radius:4px;padding:14px 0;box-shadow:0 16px 35px rgba(0,0,0,.18);transition:opacity .2s ease,visibility .2s ease,transform .2s ease}.service-dropdown__menu:before{content:"";position:absolute;left:50%;top:-12px;width:24px;height:24px;background:#fff;transform:translateX(-50%) rotate(45deg)}.service-dropdown:hover .service-dropdown__menu,.service-dropdown.is-open .service-dropdown__menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}.service-dropdown__menu a{display:block;padding:13px 28px;font-size:15px;font-weight:800;color:#222;transition:background .2s ease,color .2s ease}.service-dropdown__menu a:hover{background:#fff1f3;color:var(--red)}
.mobile-panel{display:none}

.hero{position:relative;overflow:hidden;background:#fff}.hero:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.74),rgba(255,255,255,.78)),url('../img/hero-moving-red.jpg') left center/cover no-repeat;filter:grayscale(15%)}.hero:after{content:"";position:absolute;left:0;bottom:-28px;width:48%;height:72%;background:url('../img/logo.png') left bottom/310px auto no-repeat;opacity:.055;pointer-events:none}.hero__inner{position:relative;z-index:1;min-height:530px;display:grid;grid-template-columns:minmax(0,1fr) 430px;gap:70px;align-items:center;padding:58px 0}.hero__content{max-width:620px}.hero__mark{display:inline-flex;align-items:center;gap:12px;color:var(--red);font-size:14px;font-weight:900;text-transform:uppercase;letter-spacing:.06em}.hero__mark:before{content:"";width:42px;height:18px;background:var(--red);clip-path:polygon(15px 0,100% 0,calc(100% - 15px) 100%,0 100%)}.hero h1{margin:20px 0 18px;font-size:56px;line-height:1.02;font-weight:900;letter-spacing:-.03em;color:#050505}.hero p{max-width:520px;margin:0 0 24px;color:#222;font-size:18px;line-height:1.65}.hero__bullets{display:grid;gap:13px}.hero__bullets span{position:relative;padding-left:52px;font-weight:900;color:#111}.hero__bullets span:before{content:"";position:absolute;left:0;top:4px;width:36px;height:20px;background:linear-gradient(135deg,var(--red),var(--red-light));clip-path:polygon(0 0,70% 0,100% 50%,70% 100%,0 100%,25% 50%)}
.quick-form{position:relative;background:#fff;border-radius:9px;padding:32px 34px 36px;box-shadow:0 18px 55px rgba(0,0,0,.18);border:1px solid rgba(0,0,0,.08)}.quick-form h2{margin:0;color:#121212;text-align:center;font-size:27px;line-height:1.15;font-weight:900}.quick-form h2:after{content:"";display:block;width:54px;height:5px;border-radius:99px;background:var(--red);margin:16px auto 12px}.quick-form__subtitle{margin:0 0 20px!important;text-align:center;color:#333!important;font-size:16px!important;line-height:1.35!important}.quick-form input:not([type=checkbox]){width:100%;height:52px;border:1px solid #cfd3d7;border-radius:4px;background:#fff;color:#111;font-size:15px;padding:0 16px 0 46px;outline:0;transition:border-color .2s ease,box-shadow .2s ease}.quick-form input:not([type=checkbox]):focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(164,0,18,.1)}.field{position:relative;display:block;margin-bottom:12px}.field:before{position:absolute;left:15px;top:50%;z-index:1;transform:translateY(-50%);font-size:20px;color:#9b9b9b}.field--name:before{content:"♙"}.field--phone:before{content:"☎"}.field--from:before,.field--to:before{content:"◎"}.check{display:flex;align-items:flex-start;gap:9px;margin:15px 0 17px;color:#444;font-size:13px;line-height:1.35}.check input{flex:0 0 auto;width:17px;height:17px;accent-color:var(--red)}.form-status{min-height:20px;margin-top:12px;font-size:14px;text-align:center;font-weight:700}.form-status.ok{color:#098b34}.form-status.err{color:#b00020}

.section{padding:74px 0}.section--dark{background:#111;color:#fff}.section--gray{background:#f6f6f6}.section-head{text-align:center;margin-bottom:36px}.section-head.left{text-align:left}.section-head span{display:inline-block;margin-bottom:8px;color:var(--red);font-weight:900;text-transform:uppercase;letter-spacing:.08em}.section-head h2{margin:0;font-size:34px;line-height:1.16}.lead{font-size:18px;line-height:1.75;color:#333}.service-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.service-card{overflow:hidden;background:#fff;border-radius:10px;box-shadow:0 12px 28px rgba(0,0,0,.1)}.service-card img{width:100%;height:220px;object-fit:cover}.service-card__body{padding:24px}.service-card h3{margin:0 0 12px;font-size:22px}.service-card p{min-height:78px;color:#555}.features{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.feature{padding:24px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:8px}.features--light .feature{background:#fff;border-color:#e8e8e8;color:#111;box-shadow:0 8px 20px rgba(0,0,0,.05)}.feature b{display:block;color:var(--red-light);font-size:26px}.feature h3{margin:8px 0}.feature p{margin:0;color:inherit;opacity:.82}.split{display:grid;grid-template-columns:1.15fr .85fr;gap:46px;align-items:center}.split--form{align-items:start}.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.stats div{padding:24px;background:#fff;border-left:5px solid var(--red);box-shadow:0 8px 24px rgba(0,0,0,.08)}.stats b{display:block;font-size:30px;color:var(--red)}.stats span{font-weight:800}.checked-list{list-style:none;padding:0;margin:24px 0 0;display:grid;gap:12px}.checked-list li{position:relative;padding-left:34px;font-size:17px}.checked-list li:before{content:"";position:absolute;left:0;top:7px;width:18px;height:12px;border-left:4px solid var(--red);border-bottom:4px solid var(--red);transform:rotate(-45deg)}
.page-hero{position:relative;overflow:hidden;background:linear-gradient(90deg,rgba(255,255,255,.84),rgba(255,255,255,.72)),url('../img/hero-moving-red.jpg') center/cover no-repeat}.page-hero__inner{min-height:330px;display:grid;grid-template-columns:1fr 420px;gap:40px;align-items:center;padding:54px 0}.page-hero h1{margin:16px 0 14px;font-size:46px;line-height:1.05}.page-hero p{font-size:18px;color:#333}.page-hero img{width:100%;height:260px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow)}.page-hero--plain .page-hero__inner{grid-template-columns:1fr auto}.text-page{max-width:960px}.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.review,.contacts-box{background:#fff;border-radius:10px;padding:26px;box-shadow:0 10px 25px rgba(0,0,0,.08)}.review p{font-size:17px}.contacts-box .quick-form{margin-top:24px;max-width:520px}.footer{background:#090909;color:#fff;padding:46px 0 26px}.footer__grid{display:grid;grid-template-columns:1.4fr .8fr .8fr;gap:34px}.footer__brand{display:flex;gap:18px;align-items:center}.footer__brand img{width:74px;height:74px;border-radius:50%;object-fit:cover}.footer h3{margin:0 0 14px}.footer p,.footer li,.footer a{color:rgba(255,255,255,.78)}.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:7px}.footer a:hover{color:#fff}.copy{margin-top:28px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);font-size:13px;color:rgba(255,255,255,.55)}
.modal{position:fixed;inset:0;z-index:3000;display:none}.modal.is-open{display:block}.modal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.66)}.modal__dialog{position:relative;z-index:1;width:min(720px,calc(100% - 28px));margin:7vh auto;background:#fff;padding:44px 50px;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.35)}.modal__close{position:absolute;right:16px;top:12px;border:0;background:transparent;font-size:34px;line-height:1;color:#111;cursor:pointer}.modal h2{margin:0 0 28px;text-align:center;font-size:38px;line-height:1.25}.modal-form label:not(.check){display:block;margin-bottom:18px;font-size:18px}.modal-form input:not([type=checkbox]){display:block;width:100%;height:58px;margin-top:8px;border:1px solid #ccc;border-radius:4px;font-size:18px;padding:0 18px}.modal__note{text-align:center;color:#555}.mobile-call{display:none}

@media (max-width:1280px){.header-shell{width:min(1180px,calc(100% - 36px))}.site-logo{min-width:350px}.site-logo img{width:104px;height:104px}.site-logo__text strong{font-size:25px}.header-main{gap:18px}.action-tile{height:52px;grid-template-columns:66px 1fr}.action-tile__text{font-size:15px;min-width:92px;padding-right:16px}.action-tile__icon svg{width:32px;height:32px}.action-tile--callback{min-width:198px}.header-phone{min-width:230px}.header-phone strong{font-size:27px}.header-phone span{font-size:15px}.top-menu a{min-width:130px;padding:0 20px}.hero__inner{grid-template-columns:1fr 390px;gap:40px}.hero h1{font-size:48px}.service-nav__inner>a,.service-dropdown>button{font-size:15px}}

@media (max-width:960px){.header-top{display:none}.site-header{position:sticky}.header-shell{width:calc(100% - 20px)}.header-main{min-height:76px;gap:10px;padding:8px 0}.site-logo{min-width:0;gap:8px;margin-right:4px}.site-logo img{width:50px;height:50px}.site-logo__text{display:none}.mobile-phone-mini{display:block;margin-right:auto;color:#1b1b1b;line-height:1.1}.mobile-phone-mini span{display:block;font-size:9px;text-transform:uppercase;font-weight:800;color:var(--red)}.mobile-phone-mini strong{display:block;font-size:15px;font-weight:900;color:#111}.header-actions{gap:7px;margin-left:0}.action-tile{width:42px;height:42px;min-width:42px;display:block;border:0;background:var(--red);box-shadow:0 8px 15px rgba(164,0,18,.2);clip-path:polygon(12px 0,100% 0,calc(100% - 8px) 100%,0 100%)}.action-tile__icon{display:flex;width:100%;height:100%;margin:0;clip-path:none;background:transparent}.action-tile__icon svg{width:26px;height:26px;fill:#fff}.action-tile__text{display:none}.action-tile--callback{display:none}.header-phone{display:none}.burger{display:flex;width:42px;height:42px;border:0;background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0;cursor:pointer}.burger span{display:block;width:25px;height:3px;background:var(--red);border-radius:10px;transition:transform .2s ease,opacity .2s ease}.burger.is-open span:nth-child(1){transform:translateY(8px) rotate(45deg)}.burger.is-open span:nth-child(2){opacity:0}.burger.is-open span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}.service-nav{display:none}.mobile-panel{display:none;position:absolute;left:0;right:0;top:100%;background:#fff;border-top:1px solid var(--line);box-shadow:0 18px 35px rgba(0,0,0,.15);padding:14px 16px 22px}.mobile-panel.is-open{display:block}.mobile-panel a,.mobile-panel button{display:block;width:100%;padding:13px 12px;border:0;border-bottom:1px solid #eee;background:#fff;text-align:left;color:#111;font-size:16px;font-weight:800}.mobile-panel a.is-active{color:var(--red)}.mobile-panel hr{border:0;border-top:1px solid #eee;margin:10px 0}.mobile-panel__langs{display:flex;gap:8px;margin-bottom:8px}.mobile-panel__langs a{width:auto;border:2px solid var(--red);padding:8px 16px;color:var(--red);background:#fff}.mobile-panel__langs a.is-active{background:var(--red);color:#fff}.mobile-panel__callback{margin-top:12px!important;background:var(--red)!important;color:#fff!important;text-align:center!important;text-transform:uppercase!important}.hero:before{background:linear-gradient(90deg,rgba(255,255,255,.86),rgba(255,255,255,.80)),url('../img/hero-moving-red.jpg') center/cover no-repeat}.hero__inner{min-height:auto;grid-template-columns:1fr;padding:50px 0 40px;gap:28px}.hero h1{font-size:38px}.hero p{font-size:16px}.quick-form{padding:26px 20px}.quick-form h2{font-size:24px}.service-grid,.features,.reviews-grid,.footer__grid,.split,.page-hero__inner{grid-template-columns:1fr}.section{padding:52px 0}.section-head h2{font-size:28px}.page-hero__inner{min-height:auto;padding:40px 0}.page-hero h1{font-size:36px}.page-hero img{height:220px}.stats{grid-template-columns:1fr}.footer__brand{align-items:flex-start}.modal__dialog{padding:36px 22px;margin:6vh auto}.modal h2{font-size:28px}.mobile-call{position:fixed;left:14px;right:14px;bottom:12px;z-index:2500;display:none;align-items:center;justify-content:center;height:48px;background:var(--red);color:#fff;border-radius:6px;font-weight:900;text-transform:uppercase;box-shadow:0 12px 24px rgba(0,0,0,.26)}}

@media (max-width:480px){.header-shell{width:calc(100% - 14px)}.header-main{min-height:68px}.site-logo img{width:44px;height:44px}.mobile-phone-mini strong{font-size:13px}.header-actions{gap:5px}.action-tile{width:36px;height:36px;min-width:36px}.action-tile__icon svg{width:23px;height:23px}.burger{width:36px;height:36px}.burger span{width:23px}.hero h1{font-size:31px}.hero__inner{padding-top:36px}.hero__mark{font-size:12px}.quick-form h2{font-size:22px}.service-card img{height:180px}.modal h2{font-size:24px}.modal-form input:not([type=checkbox]){height:52px;font-size:16px}}


/* === Rasimov Moving header desktop fix v3.1 ===
   Smaller fonts, non-sticky desktop header, clean slanted action buttons. */
@media (min-width: 961px){
  .site-header{
    position:relative !important;
    top:auto !important;
    z-index:100;
    box-shadow:0 6px 20px rgba(0,0,0,.06);
  }
  .header-shell{
    width:min(1420px,calc(100% - 54px));
  }
  .header-top{
    height:50px;
    background:#fff;
    border-top:1px solid #dadada;
    border-bottom:1px solid #eee;
  }
  .header-top__inner{
    height:50px;
    justify-content:flex-end;
    gap:22px;
  }
  .top-menu{
    height:42px;
    padding-left:62px;
    padding-right:34px;
    background:linear-gradient(90deg,#7c000a 0%,#b40014 50%,#7c000a 100%);
    clip-path:polygon(44px 0,100% 0,calc(100% - 28px) 100%,0 100%);
    box-shadow:0 6px 14px rgba(120,0,12,.13);
    overflow:hidden;
  }
  .top-menu a{
    min-width:138px;
    padding:0 22px;
    font-size:13px;
    line-height:1;
    letter-spacing:.025em;
    border-left:1px solid rgba(255,255,255,.12);
  }
  .top-menu a:hover,
  .top-menu a.is-active{
    background:rgba(35,0,4,.30);
    box-shadow:inset 0 -3px 0 rgba(255,255,255,.35);
  }
  .lang-switch{
    flex:0 0 auto;
    gap:9px;
    margin-left:12px;
  }
  .lang-switch a{
    min-width:46px;
    height:38px;
    font-size:13px;
    border:2px solid var(--red);
    box-shadow:0 8px 18px rgba(164,0,18,.12);
  }
  .header-main{
    min-height:132px;
    padding:20px 0;
    gap:22px;
  }
  .site-logo{
    min-width:345px;
    gap:18px;
    margin-right:auto;
    flex:0 0 345px;
  }
  .site-logo img{
    width:106px;
    height:106px;
  }
  .site-logo__text strong{
    font-size:28px;
    line-height:.98;
    letter-spacing:.055em;
  }
  .site-logo__text small{
    margin-top:9px;
    font-size:14px;
    line-height:1.18;
    max-width:255px;
  }
  .header-actions{
    flex:0 0 auto;
    display:flex;
    align-items:center;
    gap:18px;
    min-width:0;
  }
  .action-tile{
    position:relative;
    flex:0 0 auto;
    height:52px;
    display:grid;
    align-items:stretch;
    background:#fff;
    color:var(--red-dark);
    border:1.5px solid rgba(164,0,18,.32);
    border-radius:2px;
    box-shadow:0 8px 20px rgba(0,0,0,.055);
    overflow:hidden;
    white-space:nowrap;
    transform:translateZ(0);
  }
  .action-tile--viber{
    width:166px;
    grid-template-columns:62px 1fr;
  }
  .action-tile--telegram{
    width:184px;
    grid-template-columns:68px 1fr;
  }
  .action-tile__icon{
    position:relative;
    z-index:1;
    display:flex;
    align-items:center;
    justify-content:center;
    height:100%;
    margin:0;
    background:linear-gradient(135deg,#8a000c 0%,#b90015 100%);
    clip-path:polygon(20px 0,100% 0,calc(100% - 16px) 100%,0 100%);
  }
  .action-tile__icon svg{
    width:30px;
    height:30px;
    fill:#fff !important;
    filter:drop-shadow(0 2px 1px rgba(0,0,0,.16));
  }
  .action-tile--telegram .action-tile__icon svg{
    width:34px;
    height:34px;
  }
  .action-tile__text{
    display:flex;
    align-items:center;
    justify-content:center;
    min-width:0;
    padding:0 16px 0 8px;
    font-size:15px;
    line-height:1;
    font-weight:900;
    letter-spacing:.01em;
    overflow:hidden;
    text-overflow:ellipsis;
  }
  .action-tile--viber:hover,
  .action-tile--telegram:hover,
  .action-tile--viber:focus-visible,
  .action-tile--telegram:focus-visible{
    border-color:var(--red);
    box-shadow:0 14px 28px rgba(164,0,18,.22);
    transform:translateY(-2px);
    outline:0;
  }
  .action-tile--viber:hover .action-tile__icon,
  .action-tile--telegram:hover .action-tile__icon,
  .action-tile--viber:focus-visible .action-tile__icon,
  .action-tile--telegram:focus-visible .action-tile__icon{
    background:linear-gradient(135deg,#b90015 0%,#de001c 100%);
  }
  .action-tile--callback{
    width:245px;
    min-width:245px;
    grid-template-columns:1fr 66px;
    border:0;
    background:linear-gradient(135deg,#bd0018 0%,#93000d 100%);
    color:#fff;
    text-transform:uppercase;
    box-shadow:0 13px 30px rgba(164,0,18,.24);
  }
  .action-tile--callback:before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(105deg,rgba(255,255,255,.17) 0 45%,transparent 46% 100%);
    pointer-events:none;
  }
  .action-tile--callback .action-tile__text{
    order:0;
    color:#fff;
    padding:0 16px;
    font-size:12px;
    line-height:1.12;
    letter-spacing:.03em;
    text-align:center;
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
  }
  .action-tile--callback .action-tile__icon{
    order:1;
    margin:0;
    background:linear-gradient(135deg,#7a000a 0%,#540006 100%);
    clip-path:polygon(18px 0,100% 0,100% 100%,0 100%);
  }
  .action-tile--callback .action-tile__icon svg{
    width:34px;
    height:34px;
  }
  .action-tile--callback:hover,
  .action-tile--callback:focus-visible{
    background:linear-gradient(135deg,#d1001a 0%,#98000f 100%);
    box-shadow:0 16px 34px rgba(164,0,18,.34);
    transform:translateY(-2px);
    outline:0;
  }
  .header-phone{
    flex:0 0 275px;
    min-width:275px;
    color:var(--red-dark);
    text-align:left;
  }
  .header-phone strong{
    display:block;
    font-size:28px;
    line-height:1.08;
    font-weight:900;
    letter-spacing:.02em;
    white-space:nowrap;
  }
  .header-phone span{
    margin-top:6px;
    font-size:15px;
    line-height:1.1;
    font-weight:900;
    color:var(--red);
  }
  .service-nav{
    background:linear-gradient(180deg,#bb0016 0%,#97000f 100%);
  }
  .service-nav__inner>a,
  .service-dropdown>button{
    height:56px;
    font-size:15px;
    line-height:1.1;
    letter-spacing:.018em;
  }
  .service-dropdown__menu{
    top:calc(100% + 12px);
    min-width:285px;
  }
  .service-dropdown__menu a{
    font-size:14px;
    padding:12px 24px;
  }
}

@media (min-width: 961px) and (max-width: 1280px){
  .header-shell{width:calc(100% - 30px)}
  .header-main{gap:14px;min-height:120px;padding:16px 0}
  .site-logo{flex-basis:292px;min-width:292px;gap:12px}
  .site-logo img{width:88px;height:88px}
  .site-logo__text strong{font-size:22px}
  .site-logo__text small{font-size:12px;max-width:205px}
  .header-actions{gap:10px}
  .action-tile{height:46px}
  .action-tile--viber{width:136px;grid-template-columns:52px 1fr}
  .action-tile--telegram{width:150px;grid-template-columns:56px 1fr}
  .action-tile__text{font-size:13px;padding-right:11px}
  .action-tile__icon svg{width:27px;height:27px}
  .action-tile--telegram .action-tile__icon svg{width:30px;height:30px}
  .action-tile--callback{width:206px;min-width:206px;grid-template-columns:1fr 56px}
  .action-tile--callback .action-tile__text{font-size:10.5px;padding:0 10px}
  .action-tile--callback .action-tile__icon svg{width:28px;height:28px}
  .header-phone{flex-basis:220px;min-width:220px}
  .header-phone strong{font-size:22px}
  .header-phone span{font-size:12px}
  .top-menu a{min-width:112px;font-size:12px;padding:0 16px}
  .lang-switch a{min-width:42px;height:34px;font-size:12px}
  .service-nav__inner>a,.service-dropdown>button{height:52px;font-size:13px}
}

@media (max-width:960px){
  .site-header{position:sticky;top:0;z-index:1000}
  .mobile-phone-mini strong{white-space:nowrap}
}


/* === Rasimov Moving header fix v3.2 ===
   Better desktop action buttons, smaller phone text, no sticky desktop header. */
@media (min-width: 961px){
  .site-header{
    position:relative !important;
    top:auto !important;
  }

  .header-main{
    display:flex !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    min-height:122px !important;
    padding:18px 0 !important;
    gap:22px !important;
    overflow:visible !important;
  }

  .site-logo{
    flex:0 0 330px !important;
    min-width:330px !important;
    max-width:330px !important;
    gap:16px !important;
    margin-right:auto !important;
  }
  .site-logo img{
    width:100px !important;
    height:100px !important;
  }
  .site-logo__text strong{
    font-size:25px !important;
    line-height:1 !important;
    letter-spacing:.045em !important;
  }
  .site-logo__text small{
    font-size:12.5px !important;
    line-height:1.17 !important;
    max-width:225px !important;
  }

  .header-actions{
    flex:0 1 auto !important;
    min-width:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    gap:22px !important;
    overflow:visible !important;
  }

  .action-tile,
  .action-tile:visited{
    box-sizing:border-box !important;
    position:relative !important;
    display:flex !important;
    align-items:center !important;
    justify-content:flex-start !important;
    height:56px !important;
    min-width:0 !important;
    padding:0 !important;
    border:0 !important;
    border-radius:2px !important;
    background:transparent !important;
    color:var(--red-dark) !important;
    box-shadow:none !important;
    overflow:visible !important;
    cursor:pointer !important;
    white-space:nowrap !important;
    transition:transform .24s ease, filter .24s ease !important;
  }

  .action-tile--viber{
    width:190px !important;
  }
  .action-tile--telegram{
    width:210px !important;
  }

  .action-tile:not(.action-tile--callback)::after{
    content:"";
    position:absolute;
    inset:0;
    z-index:0;
    border:2px solid transparent;
    border-radius:2px;
    pointer-events:none;
    transition:border-color .24s ease, box-shadow .24s ease;
  }

  .action-tile:not(.action-tile--callback) .action-tile__icon{
    position:relative !important;
    z-index:2 !important;
    flex:0 0 82px !important;
    width:82px !important;
    height:56px !important;
    margin:0 -18px 0 0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:linear-gradient(135deg,#8b000c 0%,#bd0017 100%) !important;
    clip-path:polygon(22px 0,100% 0,calc(100% - 20px) 100%,0 100%) !important;
    box-shadow:0 10px 22px rgba(145,0,15,.16) !important;
    transition:background .24s ease, box-shadow .24s ease !important;
  }

  .action-tile:not(.action-tile--callback) .action-tile__icon svg{
    width:35px !important;
    height:35px !important;
    fill:#fff !important;
    filter:drop-shadow(0 2px 1px rgba(0,0,0,.16)) !important;
  }
  .action-tile--telegram .action-tile__icon svg{
    width:39px !important;
    height:39px !important;
  }

  .action-tile:not(.action-tile--callback) .action-tile__text{
    position:relative !important;
    z-index:1 !important;
    height:52px !important;
    flex:1 1 auto !important;
    min-width:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 22px 0 34px !important;
    background:#fff !important;
    color:var(--red-dark) !important;
    border:1px solid rgba(164,0,18,.18) !important;
    border-left:0 !important;
    border-radius:0 2px 2px 0 !important;
    font-size:16px !important;
    line-height:1 !important;
    font-weight:900 !important;
    letter-spacing:0 !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
    transition:border-color .24s ease, box-shadow .24s ease, color .24s ease !important;
  }

  .action-tile--viber:hover,
  .action-tile--telegram:hover,
  .action-tile--viber:focus-visible,
  .action-tile--telegram:focus-visible{
    transform:translateY(-2px) !important;
    outline:0 !important;
    filter:none !important;
  }
  .action-tile--viber:hover::after,
  .action-tile--telegram:hover::after,
  .action-tile--viber:focus-visible::after,
  .action-tile--telegram:focus-visible::after{
    border-color:var(--red) !important;
    box-shadow:0 14px 28px rgba(164,0,18,.22) !important;
  }
  .action-tile--viber:hover .action-tile__icon,
  .action-tile--telegram:hover .action-tile__icon,
  .action-tile--viber:focus-visible .action-tile__icon,
  .action-tile--telegram:focus-visible .action-tile__icon{
    background:linear-gradient(135deg,#b00013 0%,#e0001f 100%) !important;
    box-shadow:0 13px 26px rgba(164,0,18,.24) !important;
  }
  .action-tile--viber:hover .action-tile__text,
  .action-tile--telegram:hover .action-tile__text,
  .action-tile--viber:focus-visible .action-tile__text,
  .action-tile--telegram:focus-visible .action-tile__text{
    border-color:transparent !important;
    color:#72000a !important;
  }

  .action-tile--callback{
    flex:0 0 270px !important;
    width:270px !important;
    min-width:270px !important;
    height:56px !important;
    display:grid !important;
    grid-template-columns:1fr 76px !important;
    align-items:stretch !important;
    border:0 !important;
    border-radius:2px !important;
    background:linear-gradient(135deg,#b90015 0%,#8a000c 100%) !important;
    color:#fff !important;
    box-shadow:0 12px 26px rgba(164,0,18,.20) !important;
    overflow:hidden !important;
    text-transform:uppercase !important;
    transition:transform .24s ease, box-shadow .24s ease, background .24s ease !important;
  }
  .action-tile--callback:before{
    content:"";
    position:absolute;
    inset:0;
    background:linear-gradient(105deg,rgba(255,255,255,.15) 0 45%,transparent 46% 100%);
    pointer-events:none;
  }
  .action-tile--callback .action-tile__text{
    order:0 !important;
    min-width:0 !important;
    height:auto !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 18px !important;
    background:transparent !important;
    border:0 !important;
    color:#fff !important;
    font-size:12.5px !important;
    line-height:1.1 !important;
    font-weight:900 !important;
    letter-spacing:.03em !important;
    text-align:center !important;
    white-space:normal !important;
    overflow:visible !important;
    text-overflow:clip !important;
  }
  .action-tile--callback .action-tile__icon{
    order:1 !important;
    position:relative !important;
    z-index:1 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:100% !important;
    height:100% !important;
    margin:0 !important;
    background:linear-gradient(135deg,#78000a 0%,#4c0006 100%) !important;
    clip-path:polygon(20px 0,100% 0,100% 100%,0 100%) !important;
  }
  .action-tile--callback .action-tile__icon svg{
    width:33px !important;
    height:33px !important;
    fill:#fff !important;
  }
  .action-tile--callback:hover,
  .action-tile--callback:focus-visible{
    transform:translateY(-2px) !important;
    background:linear-gradient(135deg,#d0001a 0%,#92000e 100%) !important;
    box-shadow:0 16px 34px rgba(164,0,18,.32) !important;
    outline:0 !important;
  }

  .header-phone{
    flex:0 0 270px !important;
    min-width:270px !important;
    max-width:270px !important;
    text-align:left !important;
    color:var(--red-dark) !important;
  }
  .header-phone strong{
    display:block !important;
    font-size:24px !important;
    line-height:1.06 !important;
    font-weight:900 !important;
    letter-spacing:.01em !important;
    white-space:normal !important;
    overflow-wrap:normal !important;
  }
  .header-phone span{
    display:block !important;
    margin-top:6px !important;
    font-size:13px !important;
    line-height:1.08 !important;
    font-weight:900 !important;
    color:var(--red) !important;
    text-transform:uppercase !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .header-shell{width:calc(100% - 30px) !important;}
  .header-main{gap:14px !important;}
  .site-logo{flex-basis:285px !important;min-width:285px !important;max-width:285px !important;}
  .site-logo img{width:82px !important;height:82px !important;}
  .site-logo__text strong{font-size:21px !important;}
  .site-logo__text small{font-size:11px !important;max-width:185px !important;}
  .header-actions{gap:12px !important;}
  .action-tile{height:48px !important;}
  .action-tile--viber{width:150px !important;}
  .action-tile--telegram{width:168px !important;}
  .action-tile:not(.action-tile--callback) .action-tile__icon{flex-basis:62px !important;width:62px !important;height:48px !important;margin-right:-14px !important;clip-path:polygon(17px 0,100% 0,calc(100% - 15px) 100%,0 100%) !important;}
  .action-tile:not(.action-tile--callback) .action-tile__icon svg{width:29px !important;height:29px !important;}
  .action-tile--telegram .action-tile__icon svg{width:32px !important;height:32px !important;}
  .action-tile:not(.action-tile--callback) .action-tile__text{height:44px !important;padding:0 14px 0 26px !important;font-size:13.5px !important;}
  .action-tile--callback{flex-basis:220px !important;width:220px !important;min-width:220px !important;height:48px !important;grid-template-columns:1fr 60px !important;}
  .action-tile--callback .action-tile__text{font-size:10.5px !important;padding:0 10px !important;}
  .action-tile--callback .action-tile__icon svg{width:28px !important;height:28px !important;}
  .header-phone{flex-basis:220px !important;min-width:220px !important;max-width:220px !important;}
  .header-phone strong{font-size:20px !important;}
  .header-phone span{font-size:11px !important;}
}

@media (min-width: 961px) and (max-width: 1120px){
  .site-logo{flex-basis:245px !important;min-width:245px !important;max-width:245px !important;}
  .site-logo img{width:70px !important;height:70px !important;}
  .site-logo__text strong{font-size:18px !important;}
  .site-logo__text small{font-size:9.5px !important;}
  .action-tile--viber{width:132px !important;}
  .action-tile--telegram{width:145px !important;}
  .action-tile:not(.action-tile--callback) .action-tile__text{font-size:12px !important;padding-right:10px !important;}
  .action-tile--callback{flex-basis:190px !important;width:190px !important;min-width:190px !important;grid-template-columns:1fr 52px !important;}
  .header-phone{flex-basis:190px !important;min-width:190px !important;max-width:190px !important;}
  .header-phone strong{font-size:17px !important;}
  .header-phone span{font-size:9.5px !important;}
}


/* === Rasimov Moving action buttons v3.3 ===
   Real website markup/styles for icon-only Viber/Telegram and red callback button. */
@media (min-width: 961px){
  .header-actions{
    gap:30px !important;
  }

  .action-tile--viber,
  .action-tile--telegram{
    width:94px !important;
    min-width:94px !important;
    max-width:94px !important;
    height:58px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    padding:0 !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    overflow:visible !important;
  }

  .action-tile--viber::after,
  .action-tile--telegram::after{
    content:"" !important;
    position:absolute !important;
    inset:-2px !important;
    border:2px solid transparent !important;
    border-radius:2px !important;
    pointer-events:none !important;
    transition:border-color .25s ease, box-shadow .25s ease !important;
  }

  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon{
    position:relative !important;
    z-index:2 !important;
    flex:0 0 94px !important;
    width:94px !important;
    height:58px !important;
    margin:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    background:linear-gradient(135deg,#8a000c 0%,#c40018 100%) !important;
    clip-path:polygon(22px 0,100% 0,calc(100% - 18px) 100%,0 100%) !important;
    box-shadow:0 12px 22px rgba(120,0,12,.17) !important;
    transition:background .25s ease, box-shadow .25s ease, transform .25s ease !important;
  }

  .action-tile--viber .action-tile__text,
  .action-tile--telegram .action-tile__text{
    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;
    background:transparent !important;
  }

  .action-tile--viber svg,
  .action-tile--telegram svg{
    display:block !important;
    width:38px !important;
    height:38px !important;
    fill:#fff !important;
    filter:drop-shadow(0 2px 1px rgba(0,0,0,.18)) !important;
  }
  .action-tile--viber svg.icon-viber{
    width:40px !important;
    height:40px !important;
  }
  .action-tile--telegram svg.icon-telegram{
    width:42px !important;
    height:42px !important;
    transform:translateX(1px) !important;
  }

  .action-tile--viber:hover,
  .action-tile--telegram:hover,
  .action-tile--viber:focus-visible,
  .action-tile--telegram:focus-visible{
    transform:translateY(-2px) !important;
    outline:0 !important;
  }
  .action-tile--viber:hover::after,
  .action-tile--telegram:hover::after,
  .action-tile--viber:focus-visible::after,
  .action-tile--telegram:focus-visible::after{
    border-color:#c40018 !important;
    box-shadow:0 15px 30px rgba(164,0,18,.24) !important;
  }
  .action-tile--viber:hover .action-tile__icon,
  .action-tile--telegram:hover .action-tile__icon,
  .action-tile--viber:focus-visible .action-tile__icon,
  .action-tile--telegram:focus-visible .action-tile__icon{
    background:linear-gradient(135deg,#b40014 0%,#e30020 100%) !important;
    box-shadow:0 14px 28px rgba(164,0,18,.28) !important;
  }

  .action-tile--callback{
    width:350px !important;
    min-width:350px !important;
    max-width:350px !important;
    height:58px !important;
    display:grid !important;
    grid-template-columns:1fr 90px !important;
    align-items:stretch !important;
    padding:0 !important;
    border:0 !important;
    border-radius:2px !important;
    background:linear-gradient(135deg,#c7001a 0%,#a60014 65%,#8e000d 100%) !important;
    color:#fff !important;
    box-shadow:0 14px 30px rgba(164,0,18,.24) !important;
    overflow:hidden !important;
    text-transform:uppercase !important;
  }
  .action-tile--callback::before{
    content:"" !important;
    position:absolute !important;
    inset:0 !important;
    background:linear-gradient(105deg,transparent 0 52%,rgba(255,255,255,.16) 52% 69%,transparent 69% 100%) !important;
    pointer-events:none !important;
  }
  .action-tile--callback .action-tile__text{
    order:0 !important;
    position:relative !important;
    z-index:1 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    height:auto !important;
    min-width:0 !important;
    padding:0 22px !important;
    border:0 !important;
    background:transparent !important;
    color:#fff !important;
    font-size:16px !important;
    line-height:1 !important;
    font-weight:900 !important;
    letter-spacing:.035em !important;
    text-align:center !important;
    white-space:nowrap !important;
    overflow:visible !important;
  }
  .action-tile--callback .action-tile__icon{
    order:1 !important;
    position:relative !important;
    z-index:2 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:100% !important;
    height:100% !important;
    margin:0 !important;
    background:linear-gradient(135deg,#7a0009 0%,#4b0005 100%) !important;
    clip-path:polygon(24px 0,100% 0,100% 100%,0 100%) !important;
  }
  .action-tile--callback svg.icon-phone{
    width:43px !important;
    height:43px !important;
    fill:#fff !important;
    transform:rotate(-7deg) !important;
    filter:drop-shadow(0 2px 1px rgba(0,0,0,.18)) !important;
  }
  .action-tile--callback:hover,
  .action-tile--callback:focus-visible{
    transform:translateY(-2px) !important;
    background:linear-gradient(135deg,#de001f 0%,#b40014 65%,#92000f 100%) !important;
    box-shadow:0 17px 36px rgba(164,0,18,.34) !important;
    outline:0 !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .header-actions{
    gap:20px !important;
  }
  .action-tile--viber,
  .action-tile--telegram{
    width:76px !important;
    min-width:76px !important;
    max-width:76px !important;
    height:50px !important;
  }
  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon{
    width:76px !important;
    flex-basis:76px !important;
    height:50px !important;
    clip-path:polygon(18px 0,100% 0,calc(100% - 15px) 100%,0 100%) !important;
  }
  .action-tile--viber svg.icon-viber{
    width:34px !important;
    height:34px !important;
  }
  .action-tile--telegram svg.icon-telegram{
    width:36px !important;
    height:36px !important;
  }
  .action-tile--callback{
    width:260px !important;
    min-width:260px !important;
    max-width:260px !important;
    height:50px !important;
    grid-template-columns:1fr 70px !important;
  }
  .action-tile--callback .action-tile__text{
    font-size:12px !important;
    padding:0 12px !important;
  }
  .action-tile--callback svg.icon-phone{
    width:34px !important;
    height:34px !important;
  }
}

@media (min-width: 961px) and (max-width: 1120px){
  .header-actions{
    gap:12px !important;
  }
  .action-tile--viber,
  .action-tile--telegram{
    width:58px !important;
    min-width:58px !important;
    max-width:58px !important;
    height:44px !important;
  }
  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon{
    width:58px !important;
    flex-basis:58px !important;
    height:44px !important;
    clip-path:polygon(15px 0,100% 0,calc(100% - 12px) 100%,0 100%) !important;
  }
  .action-tile--viber svg.icon-viber{
    width:29px !important;
    height:29px !important;
  }
  .action-tile--telegram svg.icon-telegram{
    width:31px !important;
    height:31px !important;
  }
  .action-tile--callback{
    width:205px !important;
    min-width:205px !important;
    max-width:205px !important;
    height:44px !important;
    grid-template-columns:1fr 58px !important;
  }
  .action-tile--callback .action-tile__text{
    font-size:10px !important;
    letter-spacing:.02em !important;
  }
  .action-tile--callback svg.icon-phone{
    width:29px !important;
    height:29px !important;
  }
}


/* === Rasimov Moving header micro-fix v3.4 ===
   Remove desktop header borders, hide messenger labels completely,
   and replace hover border frame with a smooth red shade change. */
@media (min-width: 961px){
  .header-top{
    border-top:0 !important;
    border-bottom:0 !important;
  }

  .action-tile--viber,
  .action-tile--telegram{
    text-indent:0 !important;
  }

  .action-tile--viber .action-tile__text,
  .action-tile--telegram .action-tile__text{
    display:none !important;
  }

  .action-tile--viber::after,
  .action-tile--telegram::after,
  .action-tile--viber:hover::after,
  .action-tile--telegram:hover::after,
  .action-tile--viber:focus-visible::after,
  .action-tile--telegram:focus-visible::after{
    content:none !important;
    display:none !important;
    border:0 !important;
    box-shadow:none !important;
  }

  .action-tile--viber:hover,
  .action-tile--telegram:hover,
  .action-tile--viber:focus-visible,
  .action-tile--telegram:focus-visible{
    transform:none !important;
    box-shadow:none !important;
    filter:none !important;
    outline:0 !important;
  }

  .action-tile--viber:hover .action-tile__icon,
  .action-tile--telegram:hover .action-tile__icon,
  .action-tile--viber:focus-visible .action-tile__icon,
  .action-tile--telegram:focus-visible .action-tile__icon{
    background:linear-gradient(135deg,#5d0910 0%,#bd0017 100%) !important;
    box-shadow:0 12px 22px rgba(93,9,16,.22) !important;
  }
}


/* === Rasimov Moving desktop header spacing v3.5 ===
   Wider top menu with clean gaps, and slightly moved contacts block to the left. */
@media (min-width: 961px){
  .header-top__inner{
    justify-content:flex-end !important;
    gap:42px !important;
  }

  .top-menu{
    width:min(960px, calc(100% - 190px)) !important;
    min-width:860px !important;
    margin-left:26px !important;
    margin-right:0 !important;
    padding-left:70px !important;
    padding-right:48px !important;
    justify-content:stretch !important;
  }

  .top-menu a{
    flex:1 1 0 !important;
    min-width:0 !important;
    padding-left:18px !important;
    padding-right:18px !important;
  }

  .lang-switch{
    margin-left:0 !important;
    flex:0 0 auto !important;
  }

  .header-main{
    justify-content:flex-start !important;
  }

  .site-logo{
    margin-right:38px !important;
  }

  .header-actions{
    margin-left:0 !important;
  }

  .header-phone{
    margin-left:8px !important;
  }
}

@media (min-width: 1381px){
  .header-main{
    gap:24px !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .top-menu{
    width:min(820px, calc(100% - 160px)) !important;
    min-width:680px !important;
    padding-left:54px !important;
    padding-right:36px !important;
  }
  .header-top__inner{
    gap:30px !important;
  }
  .site-logo{
    margin-right:22px !important;
  }
  .header-phone{
    margin-left:2px !important;
  }
}

@media (min-width: 961px) and (max-width: 1120px){
  .top-menu{
    width:min(700px, calc(100% - 140px)) !important;
    min-width:560px !important;
    padding-left:46px !important;
    padding-right:28px !important;
  }
  .top-menu a{
    font-size:12px !important;
    padding-left:10px !important;
    padding-right:10px !important;
  }
  .header-top__inner{
    gap:20px !important;
  }
  .site-logo{
    margin-right:12px !important;
  }
}


/* === Rasimov Moving header width/layout fix v3.6 ===
   Make top and service menu buttons narrower, closer to the competitor proportions. */
@media (min-width: 961px){
  .header-top__inner{
    justify-content:flex-end !important;
    gap:34px !important;
  }

  .top-menu{
    width:auto !important;
    min-width:0 !important;
    max-width:none !important;
    margin-left:0 !important;
    margin-right:0 !important;
    padding-left:58px !important;
    padding-right:44px !important;
  }

  .top-menu a{
    flex:0 0 188px !important;
    min-width:188px !important;
    max-width:188px !important;
    padding-left:14px !important;
    padding-right:14px !important;
    font-size:14px !important;
  }

  .lang-switch{
    margin-left:10px !important;
  }

  .header-main{
    justify-content:center !important;
    gap:22px !important;
  }

  .site-logo{
    margin-right:44px !important;
  }

  .header-actions{
    gap:24px !important;
    margin-left:0 !important;
  }

  .action-tile--viber,
  .action-tile--telegram{
    width:86px !important;
    min-width:86px !important;
    max-width:86px !important;
    height:54px !important;
  }

  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon{
    width:86px !important;
    flex-basis:86px !important;
    height:54px !important;
    clip-path:polygon(21px 0,100% 0,calc(100% - 17px) 100%,0 100%) !important;
  }

  .action-tile--viber svg.icon-viber{
    width:36px !important;
    height:36px !important;
  }

  .action-tile--telegram svg.icon-telegram{
    width:39px !important;
    height:39px !important;
  }

  .action-tile--callback{
    width:300px !important;
    min-width:300px !important;
    max-width:300px !important;
    height:54px !important;
    grid-template-columns:1fr 76px !important;
  }

  .action-tile--callback .action-tile__text{
    font-size:13px !important;
    padding:0 14px !important;
    letter-spacing:.025em !important;
  }

  .action-tile--callback svg.icon-phone{
    width:37px !important;
    height:37px !important;
  }

  .header-phone{
    min-width:240px !important;
    max-width:240px !important;
    flex-basis:240px !important;
    margin-left:0 !important;
  }

  .header-phone strong{
    font-size:24px !important;
    line-height:1.06 !important;
  }

  .header-phone span{
    font-size:13px !important;
    line-height:1.08 !important;
  }

  .service-nav{
    display:flex !important;
    justify-content:center !important;
  }

  .service-nav__inner{
    width:auto !important;
    max-width:none !important;
    margin:0 auto !important;
    display:flex !important;
    align-items:stretch !important;
    justify-content:center !important;
  }

  .service-nav__inner > a,
  .service-dropdown{
    flex:0 0 auto !important;
  }

  .service-nav__inner > a:nth-child(1),
  .service-nav__inner > a:nth-child(2){
    width:320px !important;
  }

  .service-nav__inner > a:nth-child(3){
    width:390px !important;
  }

  .service-dropdown{
    width:320px !important;
  }

  .service-nav__inner>a,
  .service-dropdown>button{
    height:58px !important;
    font-size:15px !important;
    letter-spacing:.01em !important;
    padding-left:18px !important;
    padding-right:18px !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .top-menu{
    padding-left:46px !important;
    padding-right:34px !important;
  }
  .top-menu a{
    flex-basis:150px !important;
    min-width:150px !important;
    max-width:150px !important;
    font-size:12px !important;
  }
  .header-main{
    gap:16px !important;
  }
  .site-logo{
    margin-right:22px !important;
  }
  .header-actions{
    gap:16px !important;
  }
  .action-tile--viber,
  .action-tile--telegram{
    width:72px !important;
    min-width:72px !important;
    max-width:72px !important;
    height:48px !important;
  }
  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon{
    width:72px !important;
    flex-basis:72px !important;
    height:48px !important;
  }
  .action-tile--callback{
    width:240px !important;
    min-width:240px !important;
    max-width:240px !important;
    height:48px !important;
    grid-template-columns:1fr 64px !important;
  }
  .action-tile--callback .action-tile__text{
    font-size:11px !important;
  }
  .header-phone{
    min-width:205px !important;
    max-width:205px !important;
    flex-basis:205px !important;
  }
  .header-phone strong{
    font-size:19px !important;
  }
  .header-phone span{
    font-size:10.5px !important;
  }
  .service-nav__inner > a:nth-child(1),
  .service-nav__inner > a:nth-child(2){
    width:250px !important;
  }
  .service-nav__inner > a:nth-child(3){
    width:315px !important;
  }
  .service-dropdown{
    width:250px !important;
  }
  .service-nav__inner>a,
  .service-dropdown>button{
    height:54px !important;
    font-size:12.5px !important;
  }
}

@media (min-width: 961px) and (max-width: 1120px){
  .top-menu a{
    flex-basis:122px !important;
    min-width:122px !important;
    max-width:122px !important;
    font-size:11px !important;
  }
  .service-nav__inner{
    width:100% !important;
  }
  .service-nav__inner > a:nth-child(1),
  .service-nav__inner > a:nth-child(2),
  .service-dropdown{
    width:24% !important;
  }
  .service-nav__inner > a:nth-child(3){
    width:28% !important;
  }
}

/* === Rasimov Moving header height fix v3.7 ===
   Lower desktop top menu and service menu heights so the whole header is more compact. */
@media (min-width: 961px){
  .header-top{
    height:38px !important;
    min-height:38px !important;
    max-height:38px !important;
  }

  .header-top__inner{
    height:38px !important;
    min-height:38px !important;
    max-height:38px !important;
    align-items:center !important;
  }

  .top-menu{
    height:32px !important;
    min-height:32px !important;
    max-height:32px !important;
    clip-path:polygon(34px 0,100% 0,calc(100% - 20px) 100%,0 100%) !important;
    padding-left:48px !important;
    padding-right:34px !important;
  }

  .top-menu a{
    height:32px !important;
    min-height:32px !important;
    font-size:12.5px !important;
    line-height:1 !important;
  }

  .lang-switch a{
    height:32px !important;
    min-width:42px !important;
    font-size:12.5px !important;
    border-width:2px !important;
  }

  .header-main{
    min-height:120px !important;
    padding:8px 0 !important;
    align-items:center !important;
  }

  .site-logo img{
    width:104px !important;
    height:104px !important;
  }

  .site-logo__text strong{
    font-size:26px !important;
    line-height:.96 !important;
  }

  .site-logo__text small{
    margin-top:6px !important;
    font-size:12.5px !important;
    line-height:1.1 !important;
  }

  .action-tile--viber,
  .action-tile--telegram{
    height:48px !important;
  }

  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon{
    height:48px !important;
  }

  .action-tile--callback{
    height:48px !important;
  }

  .action-tile--callback .action-tile__text{
    font-size:12px !important;
  }

  .header-phone strong{
    font-size:22px !important;
    line-height:1.04 !important;
  }

  .header-phone span{
    margin-top:5px !important;
    font-size:12px !important;
    line-height:1.08 !important;
  }

  .service-nav__inner>a,
  .service-dropdown>button{
    height:46px !important;
    min-height:46px !important;
    font-size:13.5px !important;
    line-height:1 !important;
    padding-top:0 !important;
    padding-bottom:0 !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .header-top,
  .header-top__inner{
    height:36px !important;
    min-height:36px !important;
    max-height:36px !important;
  }

  .top-menu,
  .top-menu a{
    height:30px !important;
    min-height:30px !important;
  }

  .top-menu{
    padding-left:40px !important;
    padding-right:28px !important;
  }

  .top-menu a{
    font-size:11.5px !important;
  }

  .lang-switch a{
    height:30px !important;
    min-width:40px !important;
    font-size:12px !important;
  }

  .header-main{
    min-height:106px !important;
    padding:6px 0 !important;
  }

  .site-logo img{
    width:88px !important;
    height:88px !important;
  }

  .site-logo__text strong{
    font-size:22px !important;
  }

  .site-logo__text small{
    font-size:11px !important;
  }

  .action-tile--viber,
  .action-tile--telegram,
  .action-tile--viber .action-tile__icon,
  .action-tile--telegram .action-tile__icon,
  .action-tile--callback{
    height:42px !important;
  }

  .action-tile--callback .action-tile__text{
    font-size:10.5px !important;
  }

  .header-phone strong{
    font-size:18px !important;
  }

  .header-phone span{
    font-size:10px !important;
  }

  .service-nav__inner>a,
  .service-dropdown>button{
    height:42px !important;
    min-height:42px !important;
    font-size:11.5px !important;
  }
}

@media (min-width: 961px) and (max-width: 1120px){
  .header-main{
    min-height:98px !important;
  }

  .service-nav__inner>a,
  .service-dropdown>button{
    height:40px !important;
    min-height:40px !important;
    font-size:10.8px !important;
  }
}

/* === Rasimov Moving top menu position fix v3.8 ===
   Move the desktop top menu slightly left and add a clearer gap before UA/RU. */
@media (min-width: 961px){
  .header-top__inner{
    justify-content:flex-end !important;
    gap:0 !important;
  }

  .top-menu{
    margin-right:56px !important;
    transform:translateX(-10px) !important;
  }

  .lang-switch{
    margin-left:0 !important;
    flex:0 0 auto !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .top-menu{
    margin-right:42px !important;
    transform:translateX(-6px) !important;
  }
}

@media (min-width: 961px) and (max-width: 1120px){
  .top-menu{
    margin-right:28px !important;
    transform:none !important;
  }
}


/* === Rasimov Moving top menu left offset v3.9 ===
   Move desktop top menu a bit more to the left and add a clearer gap before UA/RU. */
@media (min-width: 961px){
  .header-top__inner{
    justify-content:flex-end !important;
    gap:0 !important;
  }

  .top-menu{
    margin-right:92px !important;
    transform:translateX(-34px) !important;
  }

  .lang-switch{
    margin-left:0 !important;
    flex:0 0 auto !important;
  }
}

@media (min-width: 961px) and (max-width: 1380px){
  .top-menu{
    margin-right:68px !important;
    transform:translateX(-24px) !important;
  }
}

@media (min-width: 961px) and (max-width: 1120px){
  .top-menu{
    margin-right:42px !important;
    transform:translateX(-12px) !important;
  }
}

/* === Rasimov Moving main page first screen v4.1 ===
   First screen after header in competitor-like layout, but in Rasimov red style. */
.home-request-hero{
  position:relative;
  min-height:520px;
  overflow:hidden;
  background:#f5f5f5 url('../img/hero-rasimov-red.jpg') left center/auto 100% no-repeat;
}
.home-request-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(255,255,255,.02) 0%,rgba(255,255,255,.16) 48%,rgba(255,255,255,.96) 68%,#fff 100%);
  pointer-events:none;
}
.home-request-hero__inner{
  position:relative;
  z-index:1;
  width:min(1420px,calc(100% - 56px));
  min-height:520px;
  margin:0 auto;
  display:flex;
  justify-content:flex-end;
  align-items:center;
  padding:28px 0 36px;
}
.home-request-form{
  width:410px;
  margin-right:72px;
  color:#040404;
}
.home-request-form h2{
  margin:0 0 28px;
  font-size:38px;
  line-height:1.08;
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:-.025em;
}
.home-request-form__line{
  display:grid;
  grid-template-columns:112px minmax(0,1fr);
  align-items:center;
  gap:10px;
  min-height:48px;
  border-bottom:1px solid #101010;
  margin-bottom:12px;
}
.home-request-form__line span{
  font-size:18px;
  font-weight:500;
  text-transform:uppercase;
}
.home-request-form__line input,
.home-request-form__line select{
  width:100%;
  height:46px;
  border:0;
  background:transparent;
  color:#111;
  font-size:18px;
  outline:0;
  padding:0 34px 0 0;
}
.home-request-form__line select{
  appearance:none;
  -webkit-appearance:none;
  cursor:pointer;
  background:linear-gradient(45deg,transparent 50%,#000 50%) calc(100% - 13px) 19px/10px 10px no-repeat,
             linear-gradient(135deg,#000 50%,transparent 50%) calc(100% - 4px) 19px/10px 10px no-repeat;
}
.home-request-form__agree{
  display:flex;
  align-items:center;
  gap:10px;
  margin:22px 0 28px;
  color:#111;
  font-size:14px;
  line-height:1.25;
}
.home-request-form__agree input{
  flex:0 0 auto;
  width:18px;
  height:18px;
  accent-color:var(--red);
}
.home-request-form__agree sup{
  color:var(--red);
  font-weight:900;
}
.home-request-form__btn{
  width:100%;
  height:78px;
  display:grid;
  grid-template-columns:112px 1fr;
  align-items:stretch;
  border:0;
  background:#070707;
  color:#fff;
  font-size:20px;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
  transition:transform .22s ease,box-shadow .22s ease,background .22s ease;
}
.home-request-form__btn:hover{
  transform:translateY(-2px);
  box-shadow:0 18px 35px rgba(164,0,18,.24);
  background:#111;
}
.home-request-form__btn:disabled{
  opacity:.72;
  cursor:wait;
  transform:none;
}
.home-request-form__btn-icon{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:42px;
  line-height:1;
  background:linear-gradient(135deg,var(--red-dark),var(--red-light));
  clip-path:polygon(0 0,100% 0,70% 100%,0 100%);
}
.home-request-form__btn span:last-child{
  display:flex;
  align-items:center;
  justify-content:center;
  padding:0 18px 0 0;
}
.home-request-form__detail{
  display:inline-block;
  margin-top:20px;
  color:#030303;
  font-size:14px;
  text-decoration:underline;
}
.home-request-form__detail:hover{color:var(--red)}
.home-request-form .form-status{
  text-align:left;
  min-height:18px;
  margin-top:12px;
}
.home-request-hero__help{
  position:absolute;
  left:300px;
  bottom:-1px;
  z-index:2;
  width:360px;
  min-height:98px;
  display:flex;
  align-items:center;
  gap:20px;
  padding:22px 30px;
  background:#fff;
  color:#000;
  box-shadow:0 -8px 28px rgba(0,0,0,.08);
}
.home-request-hero__arrow{
  flex:0 0 34px;
  font-size:40px;
  line-height:1;
  color:var(--red);
  font-weight:900;
  transform:translateY(-6px);
}
.home-request-hero__help-text strong{
  display:block;
  font-size:28px;
  font-weight:400;
  text-transform:uppercase;
  line-height:1;
}
.home-request-hero__help-text small{
  display:block;
  margin-top:9px;
  font-size:15px;
  line-height:1.15;
}
.home-intro-text{
  position:relative;
  z-index:3;
  background:#fff;
  padding:24px 0 34px;
}
.home-intro-text .container{
  width:min(1160px,calc(100% - 36px));
}
.home-intro-text h1{
  margin:0 0 10px;
  font-size:38px;
  line-height:1.12;
  color:#000;
  text-transform:uppercase;
  font-weight:900;
  letter-spacing:-.02em;
}
.home-intro-text p{
  margin:0;
  color:#111;
  font-size:16px;
  line-height:1.45;
}

@media (min-width: 1500px){
  .home-request-form{margin-right:110px}
  .home-request-hero__help{left:330px}
}

@media (max-width: 1280px){
  .home-request-hero{min-height:480px;background-position:left center;background-size:auto 100%}
  .home-request-hero__inner{width:min(1180px,calc(100% - 36px));min-height:480px}
  .home-request-form{width:370px;margin-right:24px}
  .home-request-form h2{font-size:33px}
  .home-request-form__line{grid-template-columns:100px minmax(0,1fr)}
  .home-request-form__line span{font-size:16px}
  .home-request-form__line input,.home-request-form__line select{font-size:16px}
  .home-request-hero__help{left:235px;width:330px;padding:20px 24px}
  .home-request-hero__help-text strong{font-size:24px}
  .home-intro-text h1{font-size:34px}
}

@media (max-width: 960px){
  .home-request-hero{
    min-height:auto;
    background:#f7f7f7 url('../img/hero-rasimov-red.jpg') left top/auto 330px no-repeat;
  }
  .home-request-hero:before{
    background: linear-gradient(180deg, rgb(255 255 255 / 0%) 0%, rgb(255 255 255 / 23%) 260px, #7c0310 420px);
  }
  .home-request-hero__inner{
    width:calc(100% - 20px);
    min-height:auto;
    display:block;
    padding:280px 0 24px;
  }
  .home-request-form{
    width:100%;
    margin:0;
    background:rgba(255,255,255,.95);
    border:1px solid rgba(0,0,0,.08);
    border-radius:8px;
    padding:22px 18px;
    box-shadow:0 14px 32px rgba(0,0,0,.12);
  }
  .home-request-form h2{
    font-size:27px;
    margin-bottom:18px;
    font-weight:700;
  }
  .home-request-form__line{
    grid-template-columns:1fr;
    gap:2px;
    min-height:58px;
    padding-bottom:6px;
    margin-bottom:10px;
  }
  .home-request-form__line span{font-size:13px;color:#333}
  .home-request-form__line input,.home-request-form__line select{height:34px;font-size:16px}
  .home-request-form__agree{font-size:12px;margin:15px 0 18px}
  .home-request-form__btn{height:60px;grid-template-columns:78px 1fr;font-size:15px}
  .home-request-form__btn-icon{font-size:32px}
  .home-request-form__detail{margin-top:12px}
  .home-request-hero__help{
    position:relative;
    left:auto;
    bottom:auto;
    width:100%;
    min-height:auto;
    margin:14px 0 0;
    padding:16px 18px;
    gap:14px;
    box-shadow:0 8px 22px rgba(0,0,0,.08);
  }
  .home-request-hero__arrow{font-size:32px;flex-basis:28px}
  .home-request-hero__help-text strong{font-size:20px;font-weight:700}
  .home-request-hero__help-text small{font-size:13px}
  .home-intro-text{padding:26px 0 28px}
  .home-intro-text h1{font-size:29px}
  .home-intro-text p{font-size:15px}
}

@media (max-width:480px){
  .home-request-hero{background-size:auto 250px}
  .home-request-hero__inner{width:calc(100% - 16px);padding-top:225px}
  .home-request-form{padding:18px 14px}
  .home-request-form h2{font-size:24px}
  .home-intro-text h1{font-size:24px}
}


/* v4.2 compact help block + detailed order modal */
.home-request-hero__help{
  width:395px !important;
  min-height:76px !important;
  padding:14px 20px 14px 18px !important;
  gap:14px !important;
  align-items:center !important;
  box-shadow:0 -5px 22px rgba(0,0,0,.07) !important;
}
.home-request-hero__arrow{
  flex:0 0 42px !important;
  font-size:36px !important;
  line-height:1 !important;
  transform:translateY(-2px) !important;
}
.home-request-hero__help-text strong{
  font-size:22px !important;
  line-height:1.02 !important;
  font-weight:500 !important;
  letter-spacing:-.02em !important;
}
.home-request-hero__help-text small{
  margin-top:6px !important;
  font-size:14px !important;
  line-height:1.14 !important;
}
.home-request-form__detail{
  cursor:pointer;
}
.modal--order .modal__dialog--order{
  width:min(650px,calc(100% - 28px));
  padding:34px 42px 36px;
  border-radius:0;
  border-top:6px solid var(--red);
}
.modal--order h2{
  margin:0 0 24px;
  font-size:30px;
  line-height:1.18;
  text-transform:uppercase;
  font-weight:900;
}
.detailed-order-form label:not(.check){
  margin:0;
  font-size:15px;
  text-transform:uppercase;
  font-weight:700;
}
.detailed-order-form label:not(.check) span{
  display:block;
  margin-bottom:6px;
}
.detailed-order-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px 18px;
}
.detailed-order-grid__full{
  grid-column:1 / -1;
}
.detailed-order-form input:not([type=checkbox]),
.detailed-order-form select{
  width:100%;
  height:46px;
  margin:0;
  border:1px solid #d5d5d5;
  border-bottom:2px solid #111;
  border-radius:0;
  background:#fff;
  color:#111;
  font-size:16px;
  padding:0 12px;
  outline:0;
}
.detailed-order-form input:focus,
.detailed-order-form select:focus{
  border-color:var(--red);
  box-shadow:0 0 0 3px rgba(164,0,18,.10);
}
.detailed-order-check{
  margin:18px 0 20px;
}
.detailed-order-submit{
  min-height:58px;
  border-radius:0;
  background:linear-gradient(135deg,#070707 0%,#070707 54%,var(--red-dark) 54%,var(--red) 100%);
}
.detailed-order-submit:hover{
  background:linear-gradient(135deg,#141414 0%,#141414 54%,#5d0910 54%,#bd0017 100%);
}
@media (max-width:1280px){
  .home-request-hero__help{
    width:355px !important;
    min-height:72px !important;
    padding:13px 18px !important;
  }
  .home-request-hero__help-text strong{font-size:20px !important;}
  .home-request-hero__help-text small{font-size:13px !important;}
}
@media (max-width:960px){
  .home-request-hero__help{
    width:100% !important;
    min-height:auto !important;
    padding:12px 14px !important;
    gap:12px !important;
  }
  .home-request-hero__arrow{font-size:29px !important;flex-basis:32px !important;}
  .home-request-hero__help-text strong{font-size:18px !important;font-weight:700 !important;}
  .home-request-hero__help-text small{font-size:12.5px !important;}
  .modal--order .modal__dialog--order{padding:30px 20px;margin:4vh auto;}
  .detailed-order-grid{grid-template-columns:1fr;gap:13px;}
  .modal--order h2{font-size:24px;}
}


/* v4.3 turnkey move section */
.turnkey-move{
  background:#050505;
  color:#fff;
  padding:58px 0 72px;
  border-bottom:1px solid rgba(255,255,255,.18);
  position:relative;
  overflow:hidden;
}
.turnkey-move:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 82% 24%, rgba(164,0,18,.18), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,.03), transparent 42%);
  pointer-events:none;
}
.turnkey-move__inner{
  position:relative;
  z-index:1;
  width:min(1180px, calc(100% - 32px));
  margin:0 auto;
}
.turnkey-move__head h2{
  margin:0;
  font-family:Georgia, 'Times New Roman', serif;
  font-size:42px;
  line-height:1.05;
  text-transform:uppercase;
  color:#fff;
  letter-spacing:.01em;
  text-shadow:2px 2px 0 rgba(164,0,18,.5);
}
.turnkey-move__head h2 span{color:#ff001f;white-space:nowrap}
.turnkey-move__head p{
  margin:20px 0 34px;
  font-size:17px;
  line-height:1.45;
  font-weight:700;
  color:#f3f3f3;
  max-width:1050px;
}
.turnkey-move__layout{
  display:grid;
  grid-template-columns:330px 190px minmax(0, 1fr);
  gap:34px;
  align-items:start;
}
.turnkey-move__tabs{
  display:grid;
  gap:9px;
  padding-top:4px;
}
.turnkey-move__tab{
  position:relative;
  width:100%;
  min-height:57px;
  border:0;
  background:transparent;
  color:#ff0021;
  text-align:left;
  padding:0 22px 0 28px;
  font-size:22px;
  line-height:1.1;
  text-transform:uppercase;
  cursor:pointer;
  font-weight:500;
  transition:color .2s ease, background .2s ease, transform .2s ease;
}
.turnkey-move__tab span{
  display:inline-block;
  margin-right:9px;
  font-weight:900;
  transform:translateY(-1px);
}
.turnkey-move__tab:hover{color:#fff;transform:translateX(3px)}
.turnkey-move__tab.is-active{
  background:linear-gradient(90deg,#b00014 0%,#f00020 82%,transparent 82%);
  color:#fff;
  clip-path:polygon(0 0,calc(100% - 26px) 0,100% 50%,calc(100% - 26px) 100%,0 100%);
  font-weight:800;
}
.turnkey-move__summary{
  display:grid;
  gap:22px;
  padding-top:4px;
}
.turnkey-move__meta{
  display:grid;
  grid-template-columns:40px 1fr;
  gap:14px;
  align-items:center;
}
.turnkey-move__icon{
  width:40px;
  height:40px;
  color:#ff001f;
  filter:drop-shadow(0 0 10px rgba(255,0,31,.25));
}
.turnkey-move__icon svg{width:100%;height:100%;fill:currentColor}
.turnkey-move__meta small{
  display:block;
  color:#fff;
  font-size:14px;
  line-height:1.15;
  font-weight:700;
}
.turnkey-move__meta strong{
  display:block;
  margin-top:3px;
  color:#ff001f;
  font-size:20px;
  line-height:1.1;
  font-weight:900;
}
.turnkey-move__content{
  padding-top:1px;
  max-width:450px;
}
.turnkey-move__content h3{
  margin:0 0 18px;
  color:#ff001f;
  font-size:29px;
  line-height:1.05;
  text-transform:uppercase;
  font-weight:900;
}
.turnkey-move__content p{
  margin:0 0 24px;
  color:#fff;
  font-size:17px;
  line-height:1.35;
  font-weight:700;
}
.turnkey-move__order{
  min-width:210px;
  height:60px;
  border:0;
  background:linear-gradient(135deg,var(--red),var(--red-light));
  color:#fff;
  font-size:20px;
  line-height:1;
  text-transform:uppercase;
  cursor:pointer;
  box-shadow:0 14px 28px rgba(164,0,18,.25);
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.turnkey-move__order:hover{
  background:linear-gradient(135deg,#5d0910 0%,#bd0017 100%);
  transform:translateY(-2px);
  box-shadow:0 18px 34px rgba(164,0,18,.35);
}
.turnkey-order-summary{
  display:none;
  margin:18px 0 22px;
  background:linear-gradient(135deg,var(--red),var(--red-light));
  color:#fff;
  padding:14px 18px;
  grid-template-columns:1fr 1fr;
  gap:14px 28px;
  font-size:15px;
  text-transform:uppercase;
}
.turnkey-order-summary.is-visible{display:grid}
.turnkey-order-summary b{font-weight:900;color:#fff}
.turnkey-order-summary span{display:block;font-weight:700;color:#fff}
.turnkey-order-summary strong{font-size:17px;color:#fff}
@media (max-width:1100px){
  .turnkey-move{padding:48px 0 58px}
  .turnkey-move__head h2{font-size:36px}
  .turnkey-move__layout{grid-template-columns:290px 170px 1fr;gap:24px}
  .turnkey-move__tab{font-size:19px;min-height:52px;padding-left:22px}
  .turnkey-move__content h3{font-size:25px}
  .turnkey-move__content p{font-size:15px}
}
@media (max-width:860px){
  .turnkey-move{padding:40px 0 48px}
  .turnkey-move__inner{width:calc(100% - 22px)}
  .turnkey-move__head h2{font-size:30px}
  .turnkey-move__head p{font-size:15px;margin:14px 0 24px}
  .turnkey-move__layout{grid-template-columns:1fr;gap:22px}
  .turnkey-move__tabs{gap:6px}
  .turnkey-move__tab{min-height:48px;font-size:17px}
  .turnkey-move__summary{grid-template-columns:1fr;gap:12px;background:#0e0e0e;border:1px solid rgba(255,0,31,.22);padding:16px}
  .turnkey-move__meta{grid-template-columns:34px 1fr;gap:12px}
  .turnkey-move__icon{width:34px;height:34px}
  .turnkey-move__content{max-width:none}
  .turnkey-move__content h3{font-size:23px}
  .turnkey-move__order{width:100%;font-size:17px}
  .turnkey-order-summary{grid-template-columns:1fr;font-size:13px}
}


/* v6.9: global success modal */
.modal--success .modal__dialog{
  width:min(860px,calc(100% - 28px));
  padding:56px 44px 54px;
  text-align:center;
  border-radius:0;
  border-top:8px solid var(--red);
  box-shadow:0 32px 90px rgba(0,0,0,.42);
}
.modal--success .modal__close{
  right:-52px;
  top:0;
  width:52px;
  height:52px;
  background:#080808;
  color:#fff;
  font-size:36px;
}
.modal-success__title{
  margin:0 0 24px !important;
  font-size:48px !important;
  line-height:1.12 !important;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:#080808;
}
.modal-success__phone{
  display:inline-block;
  margin:4px 0 24px;
  color:var(--red);
  font-size:34px;
  line-height:1;
  font-weight:900;
  text-decoration:none;
  background:linear-gradient(90deg,#080808 0%,var(--red) 35%,#d60018 55%,#080808 100%);
  background-size:220% 100%;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  animation:successPhoneFlow 3.2s linear infinite;
}
.modal-success__text{
  margin:0 auto 34px;
  max-width:460px;
  color:#0b0b0b;
  font-size:21px;
  line-height:1.25;
  font-weight:900;
  text-transform:uppercase;
}
.modal-success__ok{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:260px;
  height:68px;
  border:0;
  background:linear-gradient(135deg,#8a0010 0%,#d00019 100%);
  color:#fff;
  font-size:26px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 14px 32px rgba(176,0,23,.25);
  transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
}
.modal-success__ok:hover{
  transform:translateY(-2px);
  filter:brightness(1.05);
  box-shadow:0 18px 40px rgba(176,0,23,.35);
}
@keyframes successPhoneFlow{0%{background-position:0% 50%}100%{background-position:220% 50%}}
@media (max-width:960px){
  .modal--success .modal__close{right:10px;top:8px;background:transparent;color:#111;}
  .modal-success__title{font-size:34px !important;}
  .modal-success__phone{font-size:27px;}
  .modal-success__text{font-size:17px;}
  .modal-success__ok{width:100%;min-width:0;}
}


/* v8.8: scrollable detailed modal and Ukraine address map picker */
.modal--order .modal__dialog--order{
  max-height:calc(100vh - 28px) !important;
  overflow-y:auto !important;
  overscroll-behavior:contain;
  scrollbar-width:thin;
}
.modal--order .modal__dialog--order::-webkit-scrollbar{width:8px}
.modal--order .modal__dialog--order::-webkit-scrollbar-thumb{background:#b90016;border-radius:20px}
.detailed-order-address{
  display:block;
  font-size:13px;
  font-weight:800;
  color:#161616;
  text-transform:uppercase;
  letter-spacing:.03em;
}
.detailed-order-address>span{display:block;margin-bottom:7px}
.address-input-row{
  display:grid;
  grid-template-columns:minmax(0,1fr) 104px;
  gap:8px;
  align-items:center;
}
.address-input-row input{
  width:100%;
  height:48px;
  border:1px solid #ddd;
  border-radius:14px;
  padding:0 14px;
  font-size:15px;
  background:#fff;
  color:#151515;
}
.address-map-btn{
  height:48px;
  border:0;
  border-radius:14px;
  cursor:pointer;
  color:#fff;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.04em;
  background:linear-gradient(135deg,#5d0910 0%,#bd0017 100%);
  box-shadow:0 12px 24px rgba(189,0,23,.22);
  transition:transform .2s ease,box-shadow .2s ease,filter .2s ease;
}
.address-map-btn:hover{transform:translateY(-2px);box-shadow:0 16px 30px rgba(189,0,23,.30);filter:saturate(1.1)}
.address-distance{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  margin:14px 0 4px;
  padding:12px 16px;
  border-radius:16px;
  background:linear-gradient(135deg,rgba(93,9,16,.08),rgba(189,0,23,.10));
  border:1px solid rgba(189,0,23,.16);
  color:#222;
}
.address-distance strong{color:#bd0017;font-size:20px}
.address-map-panel{
  margin:16px 0 4px;
  padding:14px;
  border-radius:22px;
  background:#101014;
  color:#fff;
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 45px rgba(0,0,0,.32);
}
.address-map-panel[hidden]{display:none!important}
.address-map-panel__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  margin-bottom:12px;
}
.address-map-panel__head strong{
  display:block;
  color:#fff;
  font-size:18px;
  line-height:1.2;
}
.address-map-panel__head small{
  display:block;
  margin-top:4px;
  color:rgba(255,255,255,.68);
  font-size:13px;
  line-height:1.35;
}
.address-map-panel__close{
  width:34px;
  height:34px;
  border:0;
  border-radius:50%;
  cursor:pointer;
  color:#fff;
  background:linear-gradient(135deg,#5d0910,#bd0017);
  font-size:22px;
  line-height:1;
}
.address-map-panel__search{
  display:grid;
  grid-template-columns:minmax(0,1fr) 106px;
  gap:8px;
  margin-bottom:10px;
}
.address-map-panel__search input{
  height:46px;
  border:1px solid rgba(255,255,255,.16);
  border-radius:14px;
  padding:0 14px;
  color:#fff;
  background:rgba(255,255,255,.08);
  outline:none;
}
.address-map-panel__search input:focus{border-color:#bd0017;box-shadow:0 0 0 3px rgba(189,0,23,.18)}
.address-map-panel__search button,
.address-map-panel__ok{
  border:0;
  border-radius:14px;
  color:#fff;
  cursor:pointer;
  font-weight:900;
  text-transform:uppercase;
  background:linear-gradient(135deg,#5d0910,#bd0017);
  box-shadow:0 10px 20px rgba(189,0,23,.24);
}
.address-map-panel__results{
  display:grid;
  gap:6px;
  max-height:150px;
  overflow:auto;
  margin-bottom:10px;
}
.address-result{
  display:block;
  width:100%;
  text-align:left;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.06);
  color:#fff;
  border-radius:12px;
  padding:9px 11px;
  cursor:pointer;
  font-size:13px;
  line-height:1.35;
}
.address-result:hover{background:rgba(189,0,23,.24);border-color:rgba(189,0,23,.48)}
.address-result--message{cursor:default;color:rgba(255,255,255,.72)}
.address-map-panel__map{
  width:100%;
  height:340px;
  border-radius:18px;
  overflow:hidden;
  background:#222;
  border:1px solid rgba(255,255,255,.12);
}
.address-map-panel__map .leaflet-control-attribution{font-size:10px}
.address-map-panel__bottom{
  display:grid;
  grid-template-columns:minmax(0,1fr) 96px;
  gap:10px;
  align-items:center;
  margin-top:10px;
}
.address-map-panel__bottom span{
  min-height:42px;
  display:flex;
  align-items:center;
  padding:9px 12px;
  border-radius:14px;
  background:rgba(255,255,255,.07);
  color:rgba(255,255,255,.86);
  font-size:13px;
  line-height:1.35;
}
.address-map-panel__ok{height:44px}
@media(max-width:760px){
  .modal--order .modal__dialog--order{max-height:calc(100vh - 16px) !important;margin:8px auto!important;padding-bottom:18px!important}
  .address-input-row{grid-template-columns:1fr}
  .address-map-btn{width:100%}
  .address-map-panel{margin-left:-4px;margin-right:-4px;padding:10px;border-radius:18px}
  .address-map-panel__search{grid-template-columns:1fr}
  .address-map-panel__map{height:285px;border-radius:14px}
  .address-map-panel__bottom{grid-template-columns:1fr}
  .address-map-panel__ok{width:100%}
  .address-distance{display:block;text-align:center}.address-distance strong{display:block;margin-top:5px}
}

/* v8.9: адреса з форми відкриває карту, пошук працює прямо в модальному вікні */
.address-input-row{grid-template-columns:minmax(0,1fr) 46px!important}
.address-input-row input[data-address-open]{cursor:pointer;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23bd0017' stroke-width='2.3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12S4 16 4 10a8 8 0 1 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E") no-repeat right 14px center;padding-right:44px!important}
.address-map-btn{width:46px!important;font-size:20px!important;padding:0!important;border-radius:13px!important;line-height:1!important}
.address-map-panel{
  position:fixed!important;
  z-index:99999!important;
  left:50%!important;
  top:50%!important;
  transform:translate(-50%,-50%) scale(.98);
  width:min(920px,calc(100vw - 24px))!important;
  max-height:calc(100vh - 24px)!important;
  overflow:auto!important;
  margin:0!important;
  opacity:0;
  transition:opacity .18s ease,transform .18s ease;
}
.address-map-panel.is-open{opacity:1;transform:translate(-50%,-50%) scale(1)}
.address-picker-open:before{content:"";position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:99998;backdrop-filter:blur(2px)}
.address-map-panel__search{grid-template-columns:minmax(0,1fr) 112px!important}
.address-map-panel__results:empty{display:none}
.address-map-panel__results{max-height:135px!important}
.address-map-panel__bottom{grid-template-columns:minmax(0,1fr) 110px!important}
.address-map-panel__bottom span{font-size:12px!important;max-height:58px;overflow:hidden}
.address-map-panel__ok{font-size:15px!important}
@media(max-width:760px){
  .address-input-row{grid-template-columns:1fr 46px!important}
  .address-map-panel{width:calc(100vw - 16px)!important;max-height:calc(100vh - 16px)!important;padding:10px!important;border-radius:18px!important}
  .address-map-panel__head strong{font-size:16px!important}
  .address-map-panel__head small{font-size:12px!important}
  .address-map-panel__search{grid-template-columns:1fr!important}
  .address-map-panel__bottom{grid-template-columns:1fr!important}
}


/* v9.0: clean address map modal, globe button, full-size Leaflet map */
.address-picker-open:before{
  background:rgba(10,10,12,.62)!important;
  backdrop-filter:none!important;
  -webkit-backdrop-filter:none!important;
}
.address-map-panel{
  background:#fff!important;
  color:#151515!important;
  border:1px solid rgba(189,0,23,.18)!important;
  box-shadow:0 26px 70px rgba(0,0,0,.38)!important;
  padding:16px!important;
}
.address-map-panel__head strong{color:#151515!important}
.address-map-panel__head small{color:#667085!important}
.address-map-panel__search input{
  color:#151515!important;
  background:#fff!important;
  border:1px solid #ddd!important;
}
.address-map-panel__search input::placeholder{color:#9aa3b2!important}
.address-result{
  color:#202020!important;
  background:#fff!important;
  border:1px solid #eceff3!important;
}
.address-result:hover{
  color:#bd0017!important;
  background:#fff4f5!important;
  border-color:rgba(189,0,23,.35)!important;
}
.address-result--message{color:#667085!important}
.address-map-panel__map{
  width:100%!important;
  height:430px!important;
  min-height:430px!important;
  border-radius:18px!important;
  border:1px solid #e5e7eb!important;
  background:#f1f5f9!important;
  position:relative!important;
  overflow:hidden!important;
}
.address-map-panel__map .leaflet-container,
.address-map-panel__map .leaflet-pane,
.address-map-panel__map .leaflet-map-pane{
  width:100%!important;
  height:100%!important;
}
.address-map-panel .leaflet-container{
  width:100%!important;
  height:100%!important;
  filter:none!important;
  opacity:1!important;
}
.address-map-panel__bottom span{
  color:#1f2937!important;
  background:#f7f7f8!important;
  border:1px solid #eef0f3!important;
}
.address-map-btn{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  width:46px!important;
  min-width:46px!important;
  height:46px!important;
  padding:0!important;
  font-size:0!important;
}
.address-map-btn__icon{
  width:20px!important;
  height:20px!important;
  fill:none!important;
  stroke:#fff!important;
  stroke-width:2!important;
  stroke-linecap:round!important;
  stroke-linejoin:round!important;
  display:block!important;
}
.address-map-panel__close{background:#111!important;box-shadow:none!important}
@media(max-width:760px){
  .address-map-panel{padding:12px!important}
  .address-map-panel__map{height:360px!important;min-height:360px!important}
  .address-map-btn{width:44px!important;min-width:44px!important;height:44px!important;border-radius:12px!important}
  .address-map-btn__icon{width:19px!important;height:19px!important}
}

/* v9.1: address picker fixes — clear map, compact globe icons, hidden distance */
.address-distance[hidden],
.quick-address-distance[hidden]{display:none!important;}
body.address-picker-open:before{display:none!important;content:none!important;}
.address-map-panel{
  z-index:3900!important;
  opacity:1!important;
  filter:none!important;
  -webkit-filter:none!important;
  background:#fff!important;
}
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container{
  display:block!important;
  width:100%!important;
  height:min(58vh,520px)!important;
  min-height:430px!important;
  background:#eef2f6!important;
  opacity:1!important;
  filter:none!important;
  -webkit-filter:none!important;
}
.address-map-panel__map.leaflet-container .leaflet-pane,
.address-map-panel__map.leaflet-container .leaflet-map-pane,
.address-map-panel__map.leaflet-container .leaflet-tile-pane,
.address-map-panel__map.leaflet-container .leaflet-overlay-pane,
.address-map-panel__map.leaflet-container .leaflet-marker-pane,
.address-map-panel__map.leaflet-container .leaflet-tile-container{
  opacity:1!important;
  filter:none!important;
}
.address-map-btn{
  background:#fff!important;
  color:#bd0017!important;
  border:1px solid rgba(189,0,23,.22)!important;
  box-shadow:0 8px 22px rgba(189,0,23,.10)!important;
  border-radius:14px!important;
}
.address-map-btn:hover{
  background:#fff4f5!important;
  transform:translateY(-1px)!important;
  box-shadow:0 12px 26px rgba(189,0,23,.18)!important;
}
.address-map-btn svg{display:none!important;}
.address-map-btn:before{
  content:"";
  width:22px;
  height:22px;
  display:block;
  background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23bd0017' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M3 12h18'/%3E%3Cpath d='M12 3c2.4 2.7 3.6 5.7 3.6 9s-1.2 6.3-3.6 9'/%3E%3Cpath d='M12 3c-2.4 2.7-3.6 5.7-3.6 9s1.2 6.3 3.6 9'/%3E%3C/svg%3E");
}
.address-input-row input[data-address-open]{
  background:#fff!important;
  padding-right:14px!important;
}
.quick-form .field--address input{
  cursor:pointer;
  padding-right:48px!important;
  background:#fff!important;
}
.quick-form .field--address:after{
  content:"";
  position:absolute;
  right:15px;
  top:50%;
  transform:translateY(-50%);
  width:20px;
  height:20px;
  pointer-events:none;
  background:center/contain no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23bd0017' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12S4 16 4 10a8 8 0 1 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E");
}
.quick-address-distance{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin:0 0 14px;
  padding:10px 13px;
  border-radius:14px;
  background:#fff6f7;
  border:1px solid rgba(189,0,23,.16);
  font-size:13px;
  color:#222;
}
.quick-address-distance strong{color:#bd0017;font-size:18px;white-space:nowrap;}
.address-picker-modal[hidden]{display:none!important;}
.address-picker-modal{position:fixed;inset:0;z-index:7000;display:block;}
.address-picker-modal__overlay{position:absolute;inset:0;background:rgba(12,12,14,.64);}
.address-picker-modal__dialog{
  position:relative;
  z-index:2;
  width:min(940px,calc(100vw - 24px));
  max-height:calc(100vh - 24px);
  margin:12px auto;
  overflow:auto;
  background:#fff;
  border:1px solid rgba(189,0,23,.18);
  border-radius:24px;
  padding:16px;
  box-shadow:0 28px 80px rgba(0,0,0,.38);
}
.address-picker-modal__head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:14px;}
.address-picker-modal__head strong{display:block;color:#111;font-size:24px;line-height:1.15;font-weight:900;}
.address-picker-modal__head small{display:block;margin-top:5px;color:#667085;font-size:14px;line-height:1.3;}
.address-picker-modal__close{width:44px;height:44px;border:0;border-radius:50%;background:#111;color:#fff;font-size:30px;line-height:1;cursor:pointer;}
.address-picker-modal__search{display:grid;grid-template-columns:minmax(0,1fr) 120px;gap:12px;margin-bottom:12px;}
.address-picker-modal__search input{height:54px;border:1px solid #d7dbe2;border-radius:14px;padding:0 16px;color:#111;background:#fff;font-size:16px;}
.address-picker-modal__search button,
.address-picker-modal__bottom button{border:0;border-radius:14px;background:linear-gradient(135deg,#74000d,#bd0017);color:#fff;font-weight:900;text-transform:uppercase;cursor:pointer;}
.address-picker-modal__results{display:grid;gap:7px;max-height:145px;overflow:auto;margin-bottom:12px;}
.address-picker-modal__results:empty{display:none;}
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{display:block!important;width:100%!important;height:min(58vh,520px)!important;min-height:430px!important;border-radius:18px;border:1px solid #e5e7eb;background:#eef2f6!important;overflow:hidden;}
.address-picker-modal__bottom{display:grid;grid-template-columns:minmax(0,1fr) 110px;gap:12px;margin-top:12px;align-items:center;}
.address-picker-modal__bottom span{min-height:44px;display:flex;align-items:center;padding:10px 12px;border:1px solid #eef0f3;border-radius:14px;background:#f8fafc;color:#1f2937;font-size:13px;line-height:1.3;max-height:62px;overflow:hidden;}
.address-picker-modal__bottom button{height:44px;}
@media(max-width:760px){
  .address-map-panel__map,#orderAddressMap,#orderAddressMap.leaflet-container,.address-picker-modal__map,#globalAddressMap,#globalAddressMap.leaflet-container{height:360px!important;min-height:360px!important;}
  .address-picker-modal__dialog{width:calc(100vw - 16px);max-height:calc(100vh - 16px);margin:8px auto;padding:12px;border-radius:18px;}
  .address-picker-modal__search,.address-picker-modal__bottom{grid-template-columns:1fr;}
  .address-picker-modal__head strong{font-size:18px;}
  .address-picker-modal__head small{font-size:12px;}
  .quick-address-distance{display:block;text-align:center;}
  .quick-address-distance strong{display:block;margin-top:4px;}
}

/* v9.2: address picker polish — full Leaflet map, no separate globe button in detailed modal */
.address-input-row.address-input-row--single{
  display:block!important;
  grid-template-columns:1fr!important;
}
.address-input-row--single .address-field-input,
.address-input-row--single input[data-address-open]{
  cursor:pointer!important;
  padding-right:48px!important;
  background:#fff center right 15px / 20px 20px no-repeat url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%23bd0017' stroke-width='2.25' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 10c0 6-8 12-8 12S4 16 4 10a8 8 0 1 1 16 0Z'/%3E%3Ccircle cx='12' cy='10' r='3'/%3E%3C/svg%3E")!important;
}
.address-map-panel{
  width:min(1120px,calc(100vw - 32px))!important;
  max-height:calc(100vh - 32px)!important;
}
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container,
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{
  width:100%!important;
  height:min(62vh,560px)!important;
  min-height:460px!important;
  box-sizing:border-box!important;
  background:#eef2f6!important;
}
.address-map-panel__map .leaflet-container,
.address-picker-modal__map .leaflet-container,
#orderAddressMap.leaflet-container,
#globalAddressMap.leaflet-container{
  width:100%!important;
  height:100%!important;
}
.address-map-panel__map .leaflet-tile,
.address-picker-modal__map .leaflet-tile,
#orderAddressMap .leaflet-tile,
#globalAddressMap .leaflet-tile{
  max-width:none!important;
  max-height:none!important;
}
.address-map-panel .leaflet-map-pane,
.address-picker-modal .leaflet-map-pane{
  will-change:transform;
}
@media(max-width:760px){
  .address-map-panel__map,
  #orderAddressMap,
  #orderAddressMap.leaflet-container,
  .address-picker-modal__map,
  #globalAddressMap,
  #globalAddressMap.leaflet-container{
    height:390px!important;
    min-height:390px!important;
  }
}


/* v9.3: Ukraine-only address picker map, compact modal map height */
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container,
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{
  height:420px!important;
  min-height:420px!important;
  max-height:420px!important;
  width:100%!important;
  background:#eef2f6!important;
}
.address-map-panel,
.address-picker-modal__dialog{
  max-height:calc(100vh - 36px)!important;
}
.address-map-panel .leaflet-container,
.address-picker-modal .leaflet-container{
  background:#eef2f6!important;
}
.address-map-panel .leaflet-control-attribution,
.address-picker-modal .leaflet-control-attribution{
  font-size:10px!important;
}
@media(max-width:760px){
  .address-map-panel__map,
  #orderAddressMap,
  #orderAddressMap.leaflet-container,
  .address-picker-modal__map,
  #globalAddressMap,
  #globalAddressMap.leaflet-container{
    height:320px!important;
    min-height:320px!important;
    max-height:320px!important;
  }
}

/* v9.4: map picker loads full visible Ukraine tiles and keeps modal compact */
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container,
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{
  height:360px!important;
  min-height:360px!important;
  max-height:360px!important;
  width:100%!important;
  max-width:100%!important;
  background:#eef2f6!important;
}
.address-map-panel .leaflet-container,
.address-picker-modal .leaflet-container,
#orderAddressMap.leaflet-container,
#globalAddressMap.leaflet-container{
  width:100%!important;
  height:100%!important;
  background:#eef2f6!important;
  overflow:hidden!important;
}
.address-map-panel .leaflet-tile,
.address-picker-modal .leaflet-tile,
#orderAddressMap .leaflet-tile,
#globalAddressMap .leaflet-tile{
  max-width:none!important;
  max-height:none!important;
  width:256px!important;
  height:256px!important;
}
.address-map-panel .leaflet-tile-container,
.address-picker-modal .leaflet-tile-container{
  opacity:1!important;
  transform-origin:0 0!important;
}
.address-map-panel,
.address-picker-modal__dialog{
  width:min(980px,calc(100vw - 28px))!important;
  max-height:calc(100vh - 28px)!important;
  overflow:auto!important;
}
.address-picker-modal__overlay{background:rgba(12,12,14,.52)!important;}
@media(max-width:760px){
  .address-map-panel__map,
  #orderAddressMap,
  #orderAddressMap.leaflet-container,
  .address-picker-modal__map,
  #globalAddressMap,
  #globalAddressMap.leaflet-container{
    height:300px!important;
    min-height:300px!important;
    max-height:300px!important;
  }
}

/* v9.5: faster map rendering, no grey tile gaps while zooming */
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container,
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{
  position:relative!important;
  background:#e8edf3!important;
}
.address-map-panel__map .leaflet-tile,
.address-picker-modal__map .leaflet-tile,
#orderAddressMap .leaflet-tile,
#globalAddressMap .leaflet-tile{
  opacity:1!important;
  visibility:visible!important;
  image-rendering:auto!important;
  filter:none!important;
  -webkit-filter:none!important;
  backface-visibility:hidden!important;
}
.address-map-panel__map .leaflet-tile-container,
.address-picker-modal__map .leaflet-tile-container,
#orderAddressMap .leaflet-tile-container,
#globalAddressMap .leaflet-tile-container{
  opacity:1!important;
  will-change:transform!important;
}
.address-map-panel__map.is-loading:after,
.address-picker-modal__map.is-loading:after,
#orderAddressMap.is-loading:after,
#globalAddressMap.is-loading:after{
  content:"Карта завантажується...";
  position:absolute;
  left:50%;
  bottom:14px;
  transform:translateX(-50%);
  z-index:700;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(12,12,14,.84);
  color:#fff;
  font-size:13px;
  font-weight:800;
  pointer-events:none;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
}
.address-map-panel .leaflet-control-zoom a,
.address-picker-modal .leaflet-control-zoom a{
  color:#7c0010!important;
  font-weight:900!important;
}

/* v9.6: stable full-size Leaflet map in address picker */
.address-map-panel{
  top:14px!important;
  left:0!important;
  right:0!important;
  bottom:auto!important;
  margin:0 auto!important;
  transform:none!important;
  width:min(1080px,calc(100vw - 28px))!important;
}
.address-map-panel.is-open{transform:none!important;}
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container,
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{
  display:block!important;
  width:100%!important;
  height:360px!important;
  min-height:360px!important;
  max-height:360px!important;
  overflow:hidden!important;
  background:#eef2f6!important;
  box-sizing:border-box!important;
}
.address-map-panel__map .leaflet-container,
.address-picker-modal__map .leaflet-container,
#orderAddressMap.leaflet-container,
#globalAddressMap.leaflet-container{
  display:block!important;
  width:100%!important;
  height:100%!important;
  min-width:100%!important;
  min-height:100%!important;
  overflow:hidden!important;
}
.address-map-panel__map .leaflet-pane,
.address-picker-modal__map .leaflet-pane,
#orderAddressMap .leaflet-pane,
#globalAddressMap .leaflet-pane,
.address-map-panel__map .leaflet-tile-pane,
.address-picker-modal__map .leaflet-tile-pane,
#orderAddressMap .leaflet-tile-pane,
#globalAddressMap .leaflet-tile-pane,
.address-map-panel__map .leaflet-tile-container,
.address-picker-modal__map .leaflet-tile-container,
#orderAddressMap .leaflet-tile-container,
#globalAddressMap .leaflet-tile-container{
  overflow:visible!important;
  filter:none!important;
  opacity:1!important;
}
.address-map-panel__map .leaflet-tile,
.address-picker-modal__map .leaflet-tile,
#orderAddressMap .leaflet-tile,
#globalAddressMap .leaflet-tile{
  display:block!important;
  visibility:visible!important;
  opacity:1!important;
  max-width:none!important;
  max-height:none!important;
}
.address-map-panel__map.is-loading:after,
.address-picker-modal__map.is-loading:after,
#orderAddressMap.is-loading:after,
#globalAddressMap.is-loading:after{
  content:"Карта завантажується...";
  position:absolute;
  left:50%;
  bottom:12px;
  transform:translateX(-50%);
  z-index:700;
  padding:7px 13px;
  border-radius:999px;
  background:rgba(12,12,14,.80);
  color:#fff;
  font-size:12px;
  font-weight:800;
  pointer-events:none;
}
@media(max-width:760px){
  .address-map-panel{top:8px!important;width:calc(100vw - 16px)!important;}
  .address-map-panel__map,
  #orderAddressMap,
  #orderAddressMap.leaflet-container,
  .address-picker-modal__map,
  #globalAddressMap,
  #globalAddressMap.leaflet-container{
    height:300px!important;
    min-height:300px!important;
    max-height:300px!important;
  }
}


/* v9.7: local Leaflet core CSS fallback + final full-tile map fix
   Якщо зовнішній leaflet.css не підвантажився, тайли ставали одним квадратом. */
.leaflet-container{
  position:relative!important;
  overflow:hidden!important;
  width:100%!important;
  height:100%!important;
  background:#e9eef5!important;
  outline:0!important;
  font:12px/1.5 "Helvetica Neue",Arial,Helvetica,sans-serif!important;
  touch-action:pan-x pan-y!important;
}
.leaflet-pane,
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow,
.leaflet-tile-container,
.leaflet-pane > svg,
.leaflet-pane > canvas,
.leaflet-zoom-box,
.leaflet-image-layer,
.leaflet-layer{
  position:absolute!important;
  left:0;
  top:0;
}
.leaflet-tile,
.leaflet-marker-icon,
.leaflet-marker-shadow{
  -webkit-user-select:none!important;
  -moz-user-select:none!important;
  user-select:none!important;
  -webkit-user-drag:none!important;
}
.leaflet-tile{
  visibility:visible!important;
  opacity:1!important;
  max-width:none!important;
  max-height:none!important;
  width:256px!important;
  height:256px!important;
  border:0!important;
  padding:0!important;
  margin:0!important;
  transform-origin:0 0!important;
}
.leaflet-tile-container{
  pointer-events:none!important;
  transform-origin:0 0!important;
}
.leaflet-pane{z-index:400!important;}
.leaflet-tile-pane{z-index:200!important;}
.leaflet-overlay-pane{z-index:400!important;}
.leaflet-shadow-pane{z-index:500!important;}
.leaflet-marker-pane{z-index:600!important;}
.leaflet-tooltip-pane{z-index:650!important;}
.leaflet-popup-pane{z-index:700!important;}
.leaflet-map-pane canvas{z-index:100!important;}
.leaflet-map-pane svg{z-index:200!important;}
.leaflet-zoom-animated{transform-origin:0 0!important;}
.leaflet-interactive{cursor:pointer!important;}
.leaflet-grab{cursor:grab!important;}
.leaflet-dragging .leaflet-grab{cursor:move!important;cursor:grabbing!important;}
.leaflet-control{
  position:relative!important;
  z-index:800!important;
  pointer-events:auto!important;
  float:left!important;
  clear:both!important;
}
.leaflet-top,
.leaflet-bottom{
  position:absolute!important;
  z-index:1000!important;
  pointer-events:none!important;
}
.leaflet-top{top:0!important;}
.leaflet-right{right:0!important;}
.leaflet-bottom{bottom:0!important;}
.leaflet-left{left:0!important;}
.leaflet-left .leaflet-control{margin-left:10px!important;}
.leaflet-top .leaflet-control{margin-top:10px!important;}
.leaflet-right .leaflet-control{float:right!important;margin-right:10px!important;}
.leaflet-bottom .leaflet-control{margin-bottom:10px!important;}
.leaflet-control-zoom a{
  display:block!important;
  width:30px!important;
  height:30px!important;
  line-height:30px!important;
  text-align:center!important;
  text-decoration:none!important;
  background:#fff!important;
  color:#7c0010!important;
  border-bottom:1px solid #ccc!important;
  font-size:20px!important;
  font-weight:900!important;
}
.leaflet-control-zoom a:hover{background:#f4f4f4!important;}
.leaflet-control-zoom-in{border-radius:4px 4px 0 0!important;}
.leaflet-control-zoom-out{border-radius:0 0 4px 4px!important;border-bottom:0!important;}
.leaflet-control-attribution{
  background:rgba(255,255,255,.78)!important;
  padding:0 5px!important;
  color:#333!important;
  font-size:10px!important;
}
.address-map-panel__map,
#orderAddressMap,
#orderAddressMap.leaflet-container,
.address-picker-modal__map,
#globalAddressMap,
#globalAddressMap.leaflet-container{
  display:block!important;
  position:relative!important;
  width:100%!important;
  min-width:100%!important;
  height:380px!important;
  min-height:380px!important;
  max-height:380px!important;
  overflow:hidden!important;
  background:#e9eef5!important;
  border-radius:18px!important;
  box-sizing:border-box!important;
}
.address-map-panel__map .leaflet-map-pane,
#orderAddressMap .leaflet-map-pane,
.address-picker-modal__map .leaflet-map-pane,
#globalAddressMap .leaflet-map-pane{
  width:100%!important;
  height:100%!important;
}
@media(max-width:760px){
  .address-map-panel__map,
  #orderAddressMap,
  #orderAddressMap.leaflet-container,
  .address-picker-modal__map,
  #globalAddressMap,
  #globalAddressMap.leaflet-container{
    height:310px!important;
    min-height:310px!important;
    max-height:310px!important;
  }
}

/* v10.0: менша видима точка вибору адреси на карті */
.rasimov-address-marker{
  width:26px!important;
  height:34px!important;
  margin-left:-13px!important;
  margin-top:-33px!important;
  background:transparent!important;
  border:0!important;
}
.rasimov-address-marker span{
  position:absolute;
  left:50%;
  top:0;
  width:23px;
  height:23px;
  transform:translateX(-50%) rotate(45deg);
  border-radius:50% 50% 50% 4px;
  background:linear-gradient(135deg,#bd0017,#74000d);
  box-shadow:0 8px 18px rgba(189,0,23,.34);
}
.rasimov-address-marker span:before{
  content:"";
  position:absolute;
  left:6px;
  top:6px;
  width:11px;
  height:11px;
  border-radius:50%;
  background:#fff;
  box-shadow:inset 0 0 0 2px rgba(116,0,13,.13);
}
.rasimov-address-marker span:after{
  content:"";
  position:absolute;
  left:2px;
  top:2px;
  right:2px;
  bottom:2px;
  border-radius:50% 50% 50% 4px;
  border:1px solid rgba(255,255,255,.5);
}
.address-map-panel__bottom span,
.address-picker-modal__bottom span{
  white-space:normal!important;
}

/* v10.1: підсвічування обраної адреси у списку та швидша візуальна реакція */
.address-result.is-selected{
  border-color:rgba(189,0,23,.78)!important;
  background:linear-gradient(135deg,rgba(189,0,23,.12),rgba(93,9,16,.08))!important;
  color:#5d0910!important;
  box-shadow:0 8px 20px rgba(189,0,23,.12)!important;
}
.address-picker-modal__map .rasimov-address-marker,
.address-map-panel__map .rasimov-address-marker{
  z-index:650!important;
}
