@import url('https://fonts.googleapis.com/css2?family=Onest:wght@100..900&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --index:1;
  --accent:#2563eb;--accent-h:#1d4ed8;--accent-soft:#dbeafe;--accent-bg:rgba(37,99,235,.08);
  --dark:#3A3C45;--text:#3A3C45;--mute:#888B99;--light:#F5F5F7;--line:#DBD7D4;--line2:#E1E1E1;--white:#fff;
  --r:calc(40px * var(--index));--r-sm:calc(20px * var(--index));--tr:all .3s ease
}
html{scroll-behavior:smooth}
body{font-family:'Onest',sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased;line-height:1.4}
h1,h2,h3,h4,h5,h6{color:var(--dark);font-weight:500;line-height:1.275}
a{color:inherit;text-decoration:none;transition:var(--tr)}
img{max-width:100%;display:block}
button{cursor:pointer;border:none;font-family:inherit;background:none}
.w{max-width:1560px;margin:0 auto;padding:0 20px}

/* TOPBAR */
.topbar{position:absolute;top:0;left:0;right:0;z-index:1000;padding:10px 0;font-size:13px;border-bottom:1px solid rgba(255,255,255,.1)}
.topbar .w{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.topbar-addr{color:rgba(255,255,255,.6);font-size:12px}
.topbar-phones{display:flex;gap:20px}
.topbar-phones a{font-weight:600;color:var(--white);text-shadow:0 1px 4px rgba(0,0,0,.3)}
.topbar-phones a:hover{color:var(--accent-soft)}
.topbar-socials{display:flex;gap:6px}
.topbar-socials a{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.1);transition:var(--tr)}
.topbar-socials a:hover{background:rgba(255,255,255,.2)}
.topbar-socials svg{width:14px;height:14px;fill:var(--white)}

/* HEADER */
header{position:fixed;top:0;left:0;right:0;z-index:999;padding:18px 0;transition:var(--tr);background:transparent;border-bottom:none}
header .w{display:flex;align-items:center;justify-content:space-between;gap:36px}
header.stuck{top:0;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:rgba(255,255,255,.95);border-bottom:1px solid var(--line);box-shadow:0 2px 20px rgba(0,0,0,.06);padding:10px 0}
header.stuck .mainnav>a,header.stuck .dd>a{color:var(--dark);text-shadow:none}
header.stuck .hdr-phone{color:var(--dark);text-shadow:none}
header.stuck .logo-white{display:none}
header.stuck .logo-dark{display:block}
header.stuck .burger span{background:var(--dark)}
/* Sub-pages: header always white bg, dark text */
.subpage .topbar{display:none!important}
body.subpage header,body.subpage header#hdr,body.subpage header.stuck{position:fixed!important;top:0!important;left:0!important;right:0!important;background:#ffffff!important;border-bottom:1px solid #DBD7D4!important;box-shadow:0 2px 20px rgba(0,0,0,.06)!important;padding:12px 0!important;z-index:999!important}
body.subpage header .mainnav>a,body.subpage header .dd>a{color:#3A3C45!important;text-shadow:none!important}
body.subpage header .hdr-phone{color:#3A3C45!important;text-shadow:none!important}
body.subpage header .logo-white{display:none!important}
body.subpage header .logo-dark{display:block!important}
body.subpage header .burger span{background:#3A3C45!important}
body.subpage header .mainnav>a:hover,body.subpage header .dd:hover>a{color:#2563eb!important}
body.subpage header .btn-sm{border-color:#2563eb!important;color:#2563eb!important}
body.subpage header .btn-fill{background:#2563eb!important;color:#fff!important}
body.subpage header .btn-fill.btn-sm{background:#2563eb!important;color:#fff!important;border-color:#2563eb!important}
.logo{display:flex;align-items:center;flex-shrink:0;position:relative}
.logo img{height:50px;transition:var(--tr);image-rendering:-webkit-optimize-contrast}
.logo-dark{display:none}
.logo::after{display:none}
.mainnav{display:flex;align-items:center;gap:12px;flex:1;justify-content:center}
.mainnav>a,.dd>a{font-size:16px;font-weight:500;color:var(--white);padding:12px 22px;position:relative;transition:var(--tr);white-space:nowrap;text-shadow:0 1px 6px rgba(0,0,0,.4);letter-spacing:.01em}
.mainnav>a::after{content:'';position:absolute;bottom:4px;left:50%;transform:translateX(-50%) scaleX(0);width:50%;height:2px;background:var(--accent);transition:transform .25s ease;transform-origin:center;border-radius:1px}
.mainnav>a:hover::after{transform:translateX(-50%) scaleX(1)}
.mainnav>a:hover,.dd:hover>a{color:var(--accent-soft)}
header.stuck .mainnav>a:hover,header.stuck .dd:hover>a{color:var(--accent)}
.dd{position:relative}
.dd-menu{position:absolute;top:calc(100% + 10px);left:0;min-width:220px;background:var(--dark);padding:24px;border-radius:var(--r-sm);opacity:0;visibility:hidden;transform:scaleY(0);transform-origin:top;transition:var(--tr);z-index:100}
.dd-menu::before{content:'';position:absolute;top:-6px;left:28px;width:12px;height:12px;background:var(--dark);transform:rotate(45deg)}
.dd:hover .dd-menu{opacity:1;visibility:visible;transform:scaleY(1)}
.dd-menu a{display:block;padding:8px 0;font-size:13px;color:var(--white);transition:var(--tr)}
.dd-menu a:hover{color:var(--accent)}
.hdr-right{display:flex;align-items:center;gap:24px;flex-shrink:0}
.hdr-right .btn-sm{padding:12px 28px;border-radius:14px;font-size:13px;font-weight:600;border-width:2px;letter-spacing:.02em}
.hdr-phone{font-size:17px;font-weight:600;color:var(--white);white-space:nowrap;text-shadow:0 1px 6px rgba(0,0,0,.4)}
.hdr-phone:hover{color:var(--accent-soft)}

/* CITY SELECTOR */
.city-sel{position:relative}
.city-sel-btn{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--white);text-shadow:0 1px 6px rgba(0,0,0,.4);padding:6px 0;cursor:pointer;background:none;border:none;font-family:inherit;transition:var(--tr)}
.city-sel-btn svg:first-child{flex-shrink:0}
.city-sel-arr{transition:transform .2s ease;margin-left:2px}
.city-sel:hover .city-sel-arr{transform:rotate(180deg)}
header.stuck .city-sel-btn{color:var(--dark);text-shadow:none}
body.subpage header .city-sel-btn{color:#3A3C45!important;text-shadow:none!important}
.city-sel-drop{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) scaleY(0);transform-origin:top;min-width:160px;background:var(--white);border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.15);padding:8px 0;opacity:0;visibility:hidden;transition:all .2s ease;z-index:100}
.city-sel:hover .city-sel-drop{opacity:1;visibility:visible;transform:translateX(-50%) scaleY(1)}
.city-sel-item{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;font-size:14px;color:var(--dark);cursor:pointer;transition:var(--tr);text-shadow:none;white-space:nowrap}
.city-sel-item:hover{background:var(--accent-bg);color:var(--accent)}
.city-sel-active{font-weight:600;color:var(--accent)}
.city-sel-disabled{color:var(--mute);cursor:default;pointer-events:none}
.city-sel-disabled:hover{background:none}
.city-sel-soon{font-size:11px;background:var(--light);color:var(--mute);padding:2px 8px;border-radius:8px;margin-left:10px}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:calc(14px * var(--index)) calc(36px * var(--index));border-radius:var(--r);font-size:clamp(13px,calc(15px * var(--index)),15px);font-weight:500;transition:var(--tr);white-space:nowrap;cursor:pointer;border:3px solid transparent}
.btn-fill{background:var(--accent);color:var(--white);border-color:var(--accent)}
.btn-fill:hover{background:var(--accent-h);border-color:var(--accent-h);transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.3)}
.btn-outline{border-color:var(--dark);color:var(--dark);background:transparent}
.btn-outline:hover{background:var(--dark);color:var(--white)}
.btn-outline-w{border-color:rgba(255,255,255,.4);color:var(--white);background:transparent}
.btn-outline-w:hover{border-color:var(--white);color:var(--white);background:rgba(255,255,255,.1);backdrop-filter:blur(20px)}
.btn-sm{font-size:clamp(12px,calc(13px * var(--index)),13px);padding:calc(9px * var(--index)) calc(18px * var(--index))}

.burger{display:none;width:26px;height:18px;flex-direction:column;justify-content:space-between}
.burger span{height:2px;background:var(--white);border-radius:2px;transition:var(--tr)}
.burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mmenu{position:fixed;inset:0;background:var(--white);z-index:998;padding:90px 24px 40px;display:flex;flex-direction:column;opacity:0;visibility:hidden;transition:var(--tr)}
.mmenu.on{opacity:1;visibility:visible}
.mmenu a{font-size:17px;font-weight:500;color:var(--dark);padding:16px 0;border-bottom:1px solid var(--line)}

/* HERO */
.hero{width:100%;height:100vh;display:flex;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 20%;transition:transform 8s ease}
.hero:hover .hero-bg img{transform:scale(1.03)}
.hero-bg::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.45);z-index:1}
.hero-blur-layer{position:absolute;inset:0;z-index:3;background:rgba(0,0,0,.05);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);opacity:1;transition:opacity .8s ease;pointer-events:none}
.hero:hover .hero-blur-layer{opacity:0}
.hero-noise{position:absolute;inset:0;z-index:4;pointer-events:none;opacity:.06;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-repeat:repeat;background-size:128px 128px}
.hero-particles{position:absolute;inset:0;z-index:4;pointer-events:none}
.hero-top-grad{position:absolute;top:0;left:0;right:0;height:160px;background:linear-gradient(to bottom,rgba(0,0,0,.35) 0%,transparent 100%);z-index:2;pointer-events:none}
.hero .w{position:relative;z-index:5}
/* hero grid */
.hero-grid{display:flex;flex-direction:column;height:100vh;padding-top:74px;padding-bottom:48px;max-width:1560px;width:100%}
.hg-top{display:flex;justify-content:space-between;align-items:center;animation:fadeInDown .8s ease .2s both;gap:20px;margin-bottom:auto;padding-top:6px;position:relative}
.hg-label{font-size:16px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--white)}
.hg-top-sep{flex:1;height:1px;background:rgba(255,255,255,.15)}
.hg-cities{font-size:16px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.85)}
.hg-mid{flex:0;margin-top:auto;animation:fadeInDown .8s ease .4s both}
.hg-tagline{font-size:clamp(14px,1.1vw,17px);color:rgba(255,255,255,.8);max-width:340px;line-height:1.6;margin-bottom:0}
.hg-bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;margin-bottom:18vh;padding-top:20px;animation:fadeInDown .8s ease .6s both}
.hg-title{font-size:clamp(64px,8.5vw,140px);color:var(--white);font-weight:800;line-height:.95;letter-spacing:-.03em;text-shadow:0 4px 40px rgba(0,0,0,.25);margin:0}
.hg-title-sub{font-size:.28em;font-weight:500;letter-spacing:.03em;display:block;margin-top:.12em;opacity:.8}
.hg-actions{display:flex;flex-direction:column;gap:14px;align-items:flex-end;flex-shrink:0}
.hg-actions-row{display:flex;gap:10px}
/* main CTA -- animated gradient border + glow pulse */
.hero-btn-main{display:inline-flex;align-items:center;justify-content:center;padding:20px 48px;background:var(--accent);color:var(--white);font-size:16px;font-weight:700;border-radius:60px;transition:all .4s cubic-bezier(.4,0,.2,1);letter-spacing:.02em;white-space:nowrap;position:relative;z-index:1;overflow:visible;text-transform:uppercase;cursor:pointer}
.hero-btn-main span{position:relative;z-index:2}
/* outer glow ring */
.hero-btn-main::before{content:'';position:absolute;inset:-3px;border-radius:60px;background:linear-gradient(135deg,#60a5fa,#2563eb,#7c3aed,#2563eb,#60a5fa);background-size:300% 300%;animation:btnGradient 4s ease infinite;z-index:-1;opacity:.7;filter:blur(6px);transition:all .4s ease}
/* shine sweep */
.hero-btn-main::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.25) 50%,transparent 80%);z-index:3;border-radius:60px;transition:none;animation:btnShine 3s ease-in-out infinite}
.hero-btn-main:hover{transform:translateY(-3px) scale(1.04);box-shadow:0 8px 40px rgba(37,99,235,.6),0 0 60px rgba(37,99,235,.25)}
.hero-btn-main:hover::before{inset:-5px;opacity:1;filter:blur(10px)}
.hero-btn-main:active{transform:translateY(0) scale(.98)}
.hero-btn-laser{display:inline-flex;align-items:center;justify-content:center;padding:16px 40px;background:transparent;color:var(--white);font-size:15px;font-weight:600;border-radius:60px;border:2px solid rgba(255,255,255,.35);transition:all .4s cubic-bezier(.4,0,.2,1);letter-spacing:.02em;white-space:nowrap;text-transform:uppercase;cursor:pointer;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero-btn-laser span{position:relative;z-index:2}
.hero-btn-laser:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.6);transform:translateY(-2px);box-shadow:0 4px 20px rgba(255,255,255,.15)}
@keyframes btnGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
@keyframes btnShine{0%,100%{left:-100%}50%{left:120%}}
/* ghost buttons */
.hero-btn-ghost{display:inline-flex;align-items:center;padding:16px 28px;background:rgba(255,255,255,.08);color:var(--white);font-size:14px;font-weight:500;border:1px solid rgba(255,255,255,.25);border-radius:60px;transition:all .3s ease;white-space:nowrap;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.hero-btn-ghost:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.45);transform:translateY(-2px)}
.hero-btn-ghost:active{transform:translateY(0)}
@keyframes fadeInDown{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* MARQUEE TICKER */
.marquee{overflow:hidden;padding:calc(18px * var(--index)) 0;background:var(--dark);position:relative}
.marquee-track{display:flex;gap:calc(60px * var(--index));animation:marqueeScroll 30s linear infinite;white-space:nowrap;width:max-content}
.marquee-item{font-size:clamp(13px,calc(15px * var(--index)),15px);font-weight:500;color:rgba(255,255,255,.4);display:flex;align-items:center;gap:calc(12px * var(--index))}
.marquee-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* SECTIONS */
section{padding:calc(70px * var(--index)) 0}
.line-top{border-top:1px solid var(--line)}
.sec-light{background:var(--light)}
.sec-head{margin-bottom:calc(40px * var(--index))}
.sec-head.center{text-align:center}
.sec-title{font-size:clamp(24px,calc(40px * var(--index)),40px);font-weight:600;margin-bottom:calc(12px * var(--index))}
.sec-sub{font-size:clamp(14px,calc(17px * var(--index)),17px);color:var(--mute);max-width:580px;line-height:1.6}
.sec-head.center .sec-sub{margin:0 auto}
.sec-top{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:calc(40px * var(--index))}
.sec-top .sec-head{margin-bottom:0}
.sec-top .sec-title{margin-bottom:4px}

/* SERVICES */
.svc-grid{display:flex;gap:calc(14px * var(--index));flex-wrap:wrap}
.svc-card{position:relative;flex:1;min-width:260px;height:calc(400px * var(--index));border-radius:var(--r);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer}
.svc-card:first-child{flex:2;min-width:380px}
.svc-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.svc-card:hover img{transform:scale(1.04)}
.svc-info{position:relative;z-index:2;background:rgba(108,105,102,.52);backdrop-filter:blur(10px);padding:calc(24px * var(--index));border-radius:var(--r);margin:calc(14px * var(--index));display:flex;align-items:flex-end;justify-content:space-between;gap:14px;transition:var(--tr)}
.svc-card:hover .svc-info{backdrop-filter:blur(0);background:rgba(58,60,69,.7)}
.svc-info h3{font-size:clamp(15px,calc(18px * var(--index)),18px);color:var(--white);font-weight:500}
.svc-info p{font-size:12px;color:rgba(255,255,255,.65);margin-top:4px}
.svc-arrow{width:40px;height:40px;min-width:40px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;transition:var(--tr);flex-shrink:0}
.svc-card:hover .svc-arrow{background:var(--white)}
.svc-arrow svg{width:16px;height:16px;color:var(--white);transition:transform .3s ease,color .3s ease}
.svc-card:hover .svc-arrow svg{color:var(--accent);transform:rotate(45deg)}

/* SPECIALISTS */
.spec-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:calc(16px * var(--index));margin-bottom:calc(40px * var(--index))}
.spec-card{background:var(--light);border-radius:var(--r);overflow:hidden;transition:var(--tr);cursor:pointer;display:flex;flex-direction:column}
.spec-card:hover{box-shadow:0 12px 40px rgba(58,60,69,.1);transform:translateY(-4px)}
.sc-photo{position:relative;overflow:hidden;aspect-ratio:5/6}
.sc-photo img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .5s ease}
.spec-card:hover .sc-photo img{transform:scale(1.04)}
.sc-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 50%);pointer-events:none}
.sc-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px;z-index:2;color:#fff}
.sc-overlay-exp{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;opacity:.85;margin-bottom:4px}
.sc-overlay-work{font-size:13px;opacity:.75;line-height:1.3}
.sc-arrow{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;transition:var(--tr);z-index:2}
.sc-arrow:hover{background:var(--accent)}
.sc-arrow svg{width:15px;height:15px;color:var(--white);transition:transform .3s ease}
.spec-card:hover .sc-arrow svg{transform:rotate(45deg)}
.sc-exp{display:none}
.sc-work{display:none}
.sc-bottom{padding:16px 20px;border-top:3px solid var(--accent)}
.sc-name{font-size:clamp(16px,calc(19px * var(--index)),19px);font-weight:600;color:var(--dark)}
.sc-cat{font-size:13px;color:var(--mute);margin-top:4px}
.spec-circles{display:flex;flex-wrap:wrap;gap:calc(28px * var(--index));justify-content:center;padding-top:calc(32px * var(--index));border-top:2px solid var(--accent);position:relative}
.spec-circles::before{content:'Все специалисты';position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--white);padding:0 16px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.spec-circ{text-align:center;width:calc(150px * var(--index));cursor:pointer;transition:var(--tr)}
.spec-circ:hover{transform:translateY(-4px)}
.spec-circ-img{width:calc(100px * var(--index));height:calc(100px * var(--index));border-radius:50%;overflow:hidden;margin:0 auto calc(10px * var(--index));border:3px solid var(--accent-bg,#eff6ff);transition:var(--tr)}
.spec-circ:hover .spec-circ-img{border-color:var(--accent);box-shadow:0 6px 24px rgba(37,99,235,.2)}
.spec-circ-img img{width:100%;height:100%;object-fit:cover;object-position:center 15%}
.spec-circ-name{font-size:clamp(12px,calc(13px * var(--index)),13px);font-weight:600;color:var(--dark);line-height:1.3;margin-bottom:2px}
.spec-circ-cat{font-size:11px;color:var(--accent);line-height:1.3}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);border-top:2px solid var(--accent);margin-top:calc(36px * var(--index))}
.stat-item{padding:calc(24px * var(--index)) calc(16px * var(--index));border-right:1px solid var(--line)}
.stat-item:last-child{border-right:none}
.stat-num{font-size:clamp(28px,calc(40px * var(--index)),40px);font-weight:700;color:var(--accent);line-height:1;margin-bottom:6px}
.stat-label{font-size:clamp(13px,calc(15px * var(--index)),15px);color:var(--mute)}

/* ADVANTAGES */
.adv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:calc(14px * var(--index))}
.adv-card{background:var(--white);border-radius:var(--r);padding:calc(32px * var(--index));transition:var(--tr);border:1px solid var(--line);position:relative;overflow:hidden}
.adv-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:0;background:var(--accent);transition:height .4s ease;border-radius:0 0 2px 2px}
.adv-card:hover::before{height:100%}
.adv-card:hover{box-shadow:0 12px 40px rgba(37,99,235,.08);border-color:rgba(37,99,235,.15);transform:translateY(-4px)}
.adv-num{font-size:clamp(48px,calc(72px * var(--index)),72px);font-weight:800;color:var(--accent);opacity:.15;line-height:1;margin-bottom:calc(16px * var(--index));transition:var(--tr)}
.adv-card:hover .adv-num{opacity:.3}
.adv-card h3{font-size:clamp(16px,calc(19px * var(--index)),19px);font-weight:600;margin-bottom:10px}
.adv-card p{font-size:clamp(13px,calc(14px * var(--index)),14px);color:var(--mute);line-height:1.7}
.adv-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:14px}
.adv-tags span{font-size:11px;font-weight:500;padding:5px 12px;border-radius:30px;background:var(--accent-bg);color:var(--accent);border:1px solid rgba(37,99,235,.1)}

/* TECH BANNER */
.tech-banner{background:linear-gradient(135deg,#0f172a 0%,#1e3a5f 50%,#0f172a 100%);padding:calc(80px * var(--index)) 0;position:relative;overflow:hidden}
.tech-banner::before{content:'ТЕХНОЛОГИИ';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(60px,10vw,160px);font-weight:900;color:rgba(255,255,255,.02);white-space:nowrap;pointer-events:none}
.tech-banner .w{position:relative;z-index:1;display:grid;grid-template-columns:1fr 1fr;gap:calc(48px * var(--index));align-items:center}
.tech-info h2{font-size:clamp(24px,calc(36px * var(--index)),36px);font-weight:700;color:var(--white);margin-bottom:calc(20px * var(--index))}
.tech-info p{font-size:clamp(14px,calc(16px * var(--index)),16px);color:rgba(255,255,255,.6);line-height:1.7;margin-bottom:12px}
.tech-features{display:grid;grid-template-columns:1fr 1fr;gap:calc(14px * var(--index))}
.tech-feat{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:var(--r-sm);padding:calc(24px * var(--index));transition:var(--tr)}
.tech-feat:hover{background:rgba(255,255,255,.08);border-color:rgba(37,99,235,.3);transform:translateY(-2px)}
.tech-feat-icon{width:44px;height:44px;border-radius:12px;background:rgba(37,99,235,.15);display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.tech-feat-icon svg{width:22px;height:22px;color:var(--accent)}
.tech-feat h4{font-size:15px;font-weight:600;color:var(--white);margin-bottom:6px}
.tech-feat p{font-size:12px;color:rgba(255,255,255,.4);line-height:1.5}

/* PROCESS STEPS */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:calc(14px * var(--index));counter-reset:step}
.proc-step{position:relative;padding:calc(32px * var(--index));background:var(--white);border-radius:var(--r);border:1px solid var(--line);transition:var(--tr);counter-increment:step}
.proc-step:hover{border-color:var(--accent);box-shadow:0 8px 28px rgba(37,99,235,.08);transform:translateY(-4px)}
.proc-step::before{content:counter(step,decimal-leading-zero);font-size:clamp(36px,calc(48px * var(--index)),48px);font-weight:800;color:var(--accent);opacity:.15;line-height:1;display:block;margin-bottom:calc(14px * var(--index))}
.proc-step h3{font-size:clamp(15px,calc(17px * var(--index)),17px);font-weight:600;margin-bottom:8px}
.proc-step p{font-size:13px;color:var(--mute);line-height:1.6}
.proc-connector{display:flex;align-items:center;justify-content:center;position:absolute;right:-18px;top:50%;transform:translateY(-50%);z-index:2;color:var(--accent);opacity:.3}
.proc-step:last-child .proc-connector{display:none}

/* CTA BANNER */
.cta-banner{background:var(--accent);position:relative;overflow:hidden;padding:calc(56px * var(--index)) 0}
.cta-banner::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}
.cta-banner .w{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cta-banner h2{font-size:clamp(20px,calc(28px * var(--index)),28px);font-weight:600;color:var(--white)}
.cta-banner p{font-size:clamp(14px,calc(16px * var(--index)),16px);color:rgba(255,255,255,.7);max-width:520px}
.cta-banner .btn{background:var(--white);color:var(--accent);border-color:var(--white);font-weight:600}
.cta-banner .btn:hover{background:transparent;color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}

/* ABOUT */
.about-block{display:grid;grid-template-columns:1fr 1fr;gap:calc(14px * var(--index));align-items:stretch}
.about-img{border-radius:var(--r);overflow:hidden;position:relative}
.about-img img{width:100%;height:100%;object-fit:cover;min-height:380px;transition:transform .5s ease}
.about-img:hover img{transform:scale(1.03)}
.about-text{background:var(--light);border-radius:var(--r);padding:calc(36px * var(--index));display:flex;flex-direction:column;justify-content:center}
.about-text h2{font-size:clamp(20px,calc(32px * var(--index)),32px);margin-bottom:calc(16px * var(--index))}
.about-text p{font-size:clamp(14px,calc(15px * var(--index)),15px);color:var(--mute);line-height:1.7;margin-bottom:12px}

/* AI */
.ai-sec{background:var(--light);position:relative;overflow:visible}
.ai-robot{position:absolute;right:calc(400px * var(--index) + 60px);bottom:-20px;width:100px;z-index:2;opacity:.7;animation:robotPeek 4s ease-in-out infinite;pointer-events:none}
.ai-robot svg{width:100%;height:auto}
@keyframes robotPeek{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.ai-sec .w{display:grid;grid-template-columns:1fr calc(400px * var(--index));gap:calc(36px * var(--index));align-items:center}
.ai-info h2{font-size:clamp(20px,calc(32px * var(--index)),32px);margin-bottom:calc(14px * var(--index))}
.ai-info p{font-size:clamp(14px,calc(15px * var(--index)),15px);color:var(--mute);line-height:1.7;margin-bottom:8px}
.ai-disclaimer{font-size:12px;color:var(--mute);opacity:.5;margin-top:14px;font-style:italic}
.ai-card{background:var(--white);border-radius:var(--r);padding:calc(28px * var(--index))}
.ai-drop{border:2px dashed var(--line);border-radius:var(--r-sm);padding:calc(36px * var(--index)) 16px;text-align:center;cursor:pointer;transition:var(--tr)}
.ai-drop:hover,.ai-drop.over{border-color:var(--accent);background:var(--accent-bg)}
.ai-drop-ic{margin:0 auto 12px}
.ai-drop-ic svg{width:28px;height:28px;color:var(--mute);transition:var(--tr)}
.ai-drop:hover .ai-drop-ic svg{color:var(--accent)}
.ai-drop-t{font-size:14px;color:var(--mute)}.ai-drop-t b{color:var(--dark);font-weight:600}
.ai-preview{margin-top:16px;display:none}.ai-preview img{max-height:160px;border-radius:var(--r-sm);margin:0 auto}
.ai-loading{display:none;padding:24px;text-align:center;font-size:14px;color:var(--accent)}
.ai-loading .sp{width:22px;height:22px;border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:sp .7s linear infinite;margin:0 auto 10px}
@keyframes sp{to{transform:rotate(360deg)}}
.ai-result{margin-top:16px;padding:20px;background:var(--light);border-radius:var(--r-sm);display:none;font-size:14px;color:var(--text);line-height:1.7}

/* CITIES */
.city-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:calc(14px * var(--index))}
.city-card{border-radius:var(--r);overflow:hidden;position:relative;height:calc(340px * var(--index));display:flex;align-items:flex-end;cursor:pointer;transition:var(--tr)}
.city-card:hover{transform:translateY(-4px);box-shadow:0 16px 48px rgba(58,60,69,.15)}
.city-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.city-card:hover img{transform:scale(1.04)}
.city-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 60%,transparent);z-index:1}
.city-card--soon{background:linear-gradient(135deg,rgba(37,99,235,.15) 0%,rgba(124,58,237,.1) 100%);border:1px dashed rgba(37,99,235,.3);cursor:default;backdrop-filter:blur(4px)}
.city-card--soon:hover{transform:none;box-shadow:none}
.city-card-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:.2}
.city-soon-badge{position:absolute;top:calc(18px * var(--index));right:calc(18px * var(--index));z-index:3;background:var(--accent);color:var(--white);font-size:12px;font-weight:600;padding:6px 14px;border-radius:20px;letter-spacing:.03em;text-transform:uppercase}
.city-info{position:relative;z-index:2;padding:calc(28px * var(--index));width:100%}
.city-info h3{font-size:clamp(24px,calc(30px * var(--index)),30px);font-weight:700;color:var(--white);margin-bottom:10px;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.city-info p{font-size:14px;color:rgba(255,255,255,.8);line-height:1.5;margin-bottom:10px}
.city-info a{font-size:clamp(17px,calc(20px * var(--index)),20px);font-weight:700;color:var(--white)}
.city-info a:hover{color:var(--accent)}

/* SVO */
.svo-block{background:var(--accent-soft);border-radius:var(--r);padding:calc(36px * var(--index)) calc(44px * var(--index));display:grid;grid-template-columns:2fr 1fr;gap:calc(36px * var(--index));align-items:center}
.svo-block h2{font-size:clamp(17px,calc(22px * var(--index)),22px);margin-bottom:calc(16px * var(--index))}
.svo-block ul{list-style:none}
.svo-block li{padding:10px 0 10px 22px;position:relative;font-size:clamp(13px,calc(15px * var(--index)),15px);border-bottom:1px solid rgba(37,99,235,.1)}
.svo-block li:last-child{border-bottom:none}
.svo-block li::before{content:'';position:absolute;left:0;top:16px;width:7px;height:7px;border-radius:50%;background:var(--accent)}
.svo-cta{display:flex;align-items:center;justify-content:center}
.svo-btn{border-color:var(--accent);color:var(--accent);font-weight:600;border-radius:var(--r);padding:18px 36px;font-size:15px}
.svo-btn:hover{background:var(--accent);color:var(--white);transform:translateY(-2px);box-shadow:0 8px 24px rgba(37,99,235,.25)}

/* REVIEWS */
.revs-wrap{position:relative}
.revs{display:flex;gap:calc(14px * var(--index));overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding-bottom:8px;scrollbar-width:none;scroll-behavior:smooth}
.revs::-webkit-scrollbar{display:none}
.rev{flex:0 0 calc(33.333% - 10px);scroll-snap-align:start;background:var(--white);border-radius:var(--r);padding:calc(32px * var(--index));display:flex;flex-direction:column;position:relative;min-width:320px;border:1px solid var(--line);transition:var(--tr)}
.rev:hover{box-shadow:0 12px 40px rgba(58,60,69,.08);border-color:rgba(37,99,235,.15);transform:translateY(-2px)}
.rev-quote{position:absolute;top:14px;right:26px;font-size:54px;color:var(--accent);opacity:.1;font-family:serif;line-height:1}
.rev-stars{display:flex;gap:2px;margin-bottom:14px}
.rev-stars svg{width:15px;height:15px;fill:#f59e0b}
.rev-text{font-size:clamp(13px,calc(14px * var(--index)),14px);color:var(--text);line-height:1.75;margin-bottom:16px;flex:1}
.rev-bottom{display:flex;align-items:center;justify-content:space-between;gap:10px}
.rev-name{font-size:clamp(15px,calc(17px * var(--index)),17px);font-weight:600;color:var(--dark)}
.rev-link{font-size:11px;color:var(--accent);font-weight:500;opacity:.7;transition:var(--tr)}
.rev-link:hover{opacity:1}
.rev-badges{display:flex;gap:14px;margin-bottom:calc(28px * var(--index));flex-wrap:wrap;align-items:center}
.rev-badge{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--dark);background:var(--white);padding:12px 24px;border-radius:var(--r);border:1px solid var(--line);transition:var(--tr)}
.rev-badge:hover{border-color:var(--accent);box-shadow:0 4px 16px rgba(37,99,235,.1)}
.rev-badge span{font-size:18px;font-weight:800;color:var(--accent)}
.rev-badge .rb-stars{display:flex;gap:2px;margin-left:2px}
.rev-badge .rb-stars svg{width:14px;height:14px;fill:#f59e0b}
.rev-nav{display:flex;gap:8px;margin-top:calc(20px * var(--index));justify-content:center}
.rev-nav button{width:44px;height:44px;border-radius:50%;background:var(--light);display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.rev-nav button:hover{background:var(--accent);color:var(--white)}
.rev-nav button svg{width:18px;height:18px;stroke:currentColor}

/* PROMOS */
.promo-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:calc(14px * var(--index))}
.promo{border-radius:var(--r);padding:calc(32px * var(--index));transition:var(--tr);display:flex;flex-direction:column;border:1px solid var(--line);background:var(--white)}
.promo:hover{transform:translateY(-4px);box-shadow:0 12px 40px rgba(37,99,235,.1);border-color:var(--accent)}
.promo-badge{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);padding:5px 12px;border-radius:16px;margin-bottom:calc(16px * var(--index));align-self:flex-start}
.promo-badge svg{width:13px;height:13px}
.promo h3{font-size:clamp(16px,calc(20px * var(--index)),20px);font-weight:600;margin-bottom:12px;line-height:1.35}
.promo p{font-size:clamp(13px,calc(14px * var(--index)),14px);color:var(--mute);line-height:1.7;flex:1}
.promo-date{margin-top:14px;font-size:12px;font-weight:600;color:var(--dark);padding-top:14px;border-top:1px solid var(--line)}
.promo-img{width:100%;height:240px;object-fit:cover;object-position:center top;border-radius:calc(var(--r) - 8px);margin-bottom:14px}
.promo-img-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#93c5fd 0%,#60a5fa 30%,#a78bfa 60%,#c4b5fd 100%);background-size:200% 200%;animation:placeholderShift 6s ease infinite}
@keyframes placeholderShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.promo-link{display:inline-block;margin-top:12px;font-size:13px;font-weight:600;color:var(--accent);transition:var(--tr)}
.promo-link:hover{color:var(--accent-h);text-decoration:underline}
.promo:first-child .promo-link{color:rgba(255,255,255,.9)}
.promo:first-child .promo-link:hover{color:var(--white)}
.promo:first-child{background:linear-gradient(135deg,#1e40af,var(--accent));border:none;color:var(--white)}
.promo:first-child h3,.promo:first-child .promo-date{color:var(--white)}
.promo:first-child p{color:rgba(255,255,255,.8)}
.promo:first-child .promo-badge{background:rgba(255,255,255,.2);color:var(--white)}
.promo:first-child .promo-date{border-top-color:rgba(255,255,255,.2)}
.promo-btns{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.promo-btns .btn{font-size:13px;padding:8px 18px;border-radius:8px;text-decoration:none;font-weight:600;transition:var(--tr);white-space:nowrap}
.promo-btns .btn-fill{background:var(--accent);color:#fff;border:none}
.promo-btns .btn-fill:hover{background:var(--accent-h)}
.promo-btns .btn-outline{background:transparent;color:var(--accent);border:1.5px solid var(--accent)}
.promo-btns .btn-outline:hover{background:var(--accent);color:#fff}
.promo:first-child .promo-btns .btn-fill{background:rgba(255,255,255,.2);color:#fff;border:1.5px solid rgba(255,255,255,.4)}
.promo:first-child .promo-btns .btn-fill:hover{background:rgba(255,255,255,.35)}
.promo:first-child .promo-btns .btn-outline{color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.4)}
.promo:first-child .promo-btns .btn-outline:hover{background:rgba(255,255,255,.2);color:#fff}

/* QUALITY */
.qbar{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:calc(20px * var(--index)) calc(32px * var(--index));background:var(--light);border-radius:var(--r);flex-wrap:wrap}
.qbar-i{display:flex;align-items:center;gap:16px}
.qbar-i img{height:44px}

/* FOOTER */
footer{background:var(--dark);color:rgba(255,255,255,.5)}
.f-form-sec{padding:calc(60px * var(--index)) 0;border-bottom:1px solid rgba(255,255,255,.08)}
.f-form-sec .w{display:grid;grid-template-columns:1fr 1fr;gap:calc(40px * var(--index));align-items:center}
.f-form-title{font-size:clamp(24px,calc(36px * var(--index)),36px);font-weight:600;color:var(--white);margin-bottom:12px}
.f-form-sub{font-size:clamp(14px,calc(16px * var(--index)),16px);color:rgba(255,255,255,.5);line-height:1.6}
.f-form{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.f-input{padding:16px 18px;border:none;border-bottom:2px solid rgba(255,255,255,.12);font-family:inherit;font-size:15px;color:var(--white);background:rgba(255,255,255,.06);outline:none;transition:var(--tr);border-radius:12px;-webkit-appearance:none;appearance:none}
.f-input:focus{border-bottom-color:var(--accent);background:rgba(255,255,255,.1)}
.f-input::placeholder{color:rgba(255,255,255,.3)}
.f-input option{color:var(--dark);background:var(--white)}
.f-input.fw{grid-column:1/-1}
.f-form .btn{grid-column:1/-1;margin-top:4px}
.f-agree{grid-column:1/-1;font-size:11px;color:rgba(255,255,255,.25);line-height:1.5}
.f-agree a{color:var(--accent);text-decoration:underline}
.f-contact-map{padding:calc(48px * var(--index)) 0;border-bottom:1px solid rgba(255,255,255,.06)}
.f-contact-map p{font-size:13px;color:rgba(255,255,255,.3);line-height:1.7;margin-bottom:0}
.f-map{border-radius:var(--r);overflow:hidden;height:460px;margin-top:0;border-top:1px solid rgba(255,255,255,.05)}
.f-map iframe{width:100%;height:100%;border:none;filter:grayscale(.3)}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:calc(36px * var(--index));padding:calc(48px * var(--index)) 0}
.fb p{font-size:13px;color:rgba(255,255,255,.3);margin-top:14px;line-height:1.7}
.fb img{height:32px;filter:brightness(0) invert(1) opacity(.6)}
.fcol h4{font-size:10px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:16px}
.fcol a{display:block;font-size:13px;color:rgba(255,255,255,.35);padding:5px 0;transition:var(--tr)}
.fcol a:hover{color:var(--white)}
.fbot{display:flex;align-items:center;justify-content:space-between;padding:calc(20px * var(--index)) 0;border-top:1px solid rgba(255,255,255,.06);font-size:11px;color:rgba(255,255,255,.2);flex-wrap:wrap;gap:12px}
.fsoc{display:flex;gap:6px}
.fsoc a{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:rgba(255,255,255,.05);color:rgba(255,255,255,.35);transition:var(--tr)}
.fsoc a:hover{background:var(--accent);color:var(--white)}
.fsoc svg{width:14px;height:14px}

/* POPUP */
.ov{display:none;position:fixed;inset:0;background:rgba(58,60,69,.5);backdrop-filter:blur(6px);z-index:2000;align-items:center;justify-content:center}
.ov.on{display:flex}
.modal{background:var(--white);border-radius:var(--r);padding:calc(44px * var(--index));max-width:600px;width:92%;max-height:92vh;overflow-y:auto;position:relative;animation:mIn .3s ease}
@keyframes mIn{from{opacity:0;transform:scale(.97)}}
.mx{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;background:var(--light);color:var(--mute);font-size:17px;display:flex;align-items:center;justify-content:center;transition:var(--tr)}
.mx:hover{background:var(--line)}
.modal h2{font-size:clamp(20px,calc(28px * var(--index)),28px);margin-bottom:6px}
.modal .ms{font-size:13px;color:var(--mute);margin-bottom:calc(24px * var(--index))}
.fg{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.fi{display:flex;flex-direction:column}.fi.fw{grid-column:1/-1}
.fi label{font-size:10px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--mute);margin-bottom:5px}
.fi input,.fi select{padding:12px 14px;border:none;border-bottom:2px solid var(--line2);font-family:inherit;font-size:14px;color:var(--dark);background:none;outline:none;transition:var(--tr)}
.fi input:focus,.fi select:focus{border-bottom-color:var(--accent)}
.fc{font-size:11px;color:var(--mute);margin-bottom:16px;line-height:1.5}.fc a{color:var(--accent);text-decoration:underline}

@keyframes cardSwap{0%{opacity:0;transform:scale(.95)}100%{opacity:1;transform:scale(1)}}

/* REVEAL */
.rv{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.rv.vis{opacity:1;transform:none}
.rv1{transition-delay:.1s}.rv2{transition-delay:.2s}.rv3{transition-delay:.3s}

/* DECORATIVE */
.sec-deco{position:relative;overflow:hidden}
.sec-deco::before{content:attr(data-deco);position:absolute;top:50%;left:0;transform:translateY(-50%);font-size:clamp(120px,18vw,280px);font-weight:900;color:transparent;-webkit-text-stroke:1.5px rgba(37,99,235,.1);pointer-events:none;white-space:nowrap;line-height:1;letter-spacing:.08em;animation:decoScroll 50s linear infinite;width:max-content;z-index:0}
.sec-deco>.w{position:relative;z-index:1}
@keyframes decoScroll{0%{transform:translateY(-50%) translateX(0)}100%{transform:translateY(-50%) translateX(-50%)}}
.sec-divider{height:2px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:.15;margin:0 auto;max-width:600px}

/* SECTION FLOATING ICONS */
.sec-float-icon{position:absolute;pointer-events:none;z-index:0;opacity:.10;animation:floatIcon 6s ease-in-out infinite}
.sec-float-icon svg{width:100%;height:100%}
.sec-float-icon.fi-tl{top:22%;left:14%;width:clamp(70px,9vw,140px)}
.sec-float-icon.fi-tr{top:18%;right:13%;width:clamp(60px,8vw,120px);animation-delay:-2s}
.sec-float-icon.fi-br{bottom:20%;right:15%;width:clamp(55px,7vw,110px);animation-delay:-4s}
.sec-float-icon.fi-bl{bottom:22%;left:14%;width:clamp(60px,8vw,120px);animation-delay:-3s}
.sec-float-icon.fi-md{top:50%;right:18%;width:clamp(55px,7vw,100px);animation-delay:-1s;transform:translateY(-50%)}
@keyframes floatIcon{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-12px) rotate(3deg)}}

/* SUB-PAGE COMMON */
.page-hero{background:linear-gradient(135deg,#1e40af 0%,#0f172a 100%);padding:calc(50px * var(--index) + 80px) 0 calc(36px * var(--index));margin-top:0;position:relative;overflow:hidden}
.page-hero::before{content:attr(data-deco);position:absolute;top:calc(50% + 40px);left:0;transform:translateY(-50%);font-size:clamp(80px,14vw,200px);font-weight:900;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.07);pointer-events:none;white-space:nowrap;line-height:1;letter-spacing:.08em;animation:decoScroll 50s linear infinite;width:max-content;z-index:0}
.page-hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.015'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.page-hero .w{position:relative;z-index:1}
.page-hero h1{font-size:clamp(28px,calc(44px * var(--index)),44px);font-weight:700;color:var(--white);margin-bottom:calc(10px * var(--index))}
.page-hero p{font-size:clamp(14px,calc(17px * var(--index)),17px);color:rgba(255,255,255,.6);max-width:600px;line-height:1.6}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:rgba(255,255,255,.4);margin-bottom:calc(16px * var(--index))}
.breadcrumb a{color:rgba(255,255,255,.5);transition:var(--tr)}
.breadcrumb a:hover{color:var(--white)}
.breadcrumb span{color:rgba(255,255,255,.25)}

/* CONTENT BLOCKS */
.content-block{padding:calc(48px * var(--index)) 0;width:100%;max-width:100%}
.content-block>.w{max-width:1560px;margin:0 auto;padding:0 20px}
.content-block h2{font-size:clamp(22px,calc(34px * var(--index)),34px);font-weight:600;margin-bottom:calc(20px * var(--index))}
.content-block h3{font-size:clamp(18px,calc(24px * var(--index)),24px);font-weight:600;margin-bottom:calc(14px * var(--index))}
.content-block p{font-size:clamp(14px,calc(15px * var(--index)),15px);color:var(--mute);line-height:1.8;margin-bottom:calc(12px * var(--index))}
.content-block ul{list-style:none;margin-bottom:calc(16px * var(--index))}
.content-block ul li{position:relative;padding-left:24px;font-size:clamp(14px,calc(15px * var(--index)),15px);color:var(--mute);line-height:1.8;margin-bottom:8px}
.content-block ul li::before{content:'';position:absolute;left:0;top:10px;width:8px;height:8px;border-radius:50%;background:var(--accent);opacity:.4}

/* PRICE TABLE */
.price-table{width:100%;border-collapse:collapse;margin-bottom:calc(24px * var(--index))}
.price-table th{text-align:left;font-size:12px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--mute);padding:12px 16px;border-bottom:2px solid var(--accent);background:var(--light)}
.price-table td{padding:14px 16px;border-bottom:1px solid var(--line);font-size:14px;color:var(--text);vertical-align:top;line-height:1.5}
.price-table tr:hover td{background:var(--accent-bg)}
.price-table .price-val{font-weight:700;color:var(--accent);white-space:nowrap;text-align:right}
.price-cat{font-size:clamp(16px,calc(22px * var(--index)),22px);font-weight:600;color:var(--dark);padding:calc(24px * var(--index)) 0 calc(12px * var(--index));border-bottom:2px solid var(--accent);display:inline-block;margin-bottom:calc(14px * var(--index))}

/* SPOILER/ACCORDION */
.spoiler{border:1px solid var(--line);border-radius:var(--r-sm);margin-bottom:calc(10px * var(--index));overflow:hidden;transition:var(--tr)}
.spoiler:hover{border-color:rgba(37,99,235,.2)}
.spoiler-head{display:flex;align-items:center;justify-content:space-between;padding:calc(18px * var(--index)) calc(24px * var(--index));cursor:pointer;gap:16px;font-size:clamp(15px,calc(17px * var(--index)),17px);font-weight:600;color:var(--dark);transition:var(--tr);user-select:none}
.spoiler-head:hover{color:var(--accent)}
.spoiler-head svg{width:20px;height:20px;flex-shrink:0;transition:transform .3s ease;color:var(--mute)}
.spoiler.open .spoiler-head svg{transform:rotate(180deg);color:var(--accent)}
.spoiler-body{max-height:0;overflow:hidden;transition:max-height .4s ease;padding:0 calc(24px * var(--index))}
.spoiler.open .spoiler-body{max-height:3000px;padding-bottom:calc(24px * var(--index))}
.spoiler-body p{font-size:14px;color:var(--mute);line-height:1.8;margin-bottom:10px}
.spoiler-body ul{list-style:none;margin-bottom:12px}
.spoiler-body ul li{position:relative;padding-left:20px;font-size:14px;color:var(--mute);line-height:1.8;margin-bottom:6px}
.spoiler-body ul li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.4}
.spoiler-inner{padding:0}
.spoiler-inner p{font-size:14px;color:var(--mute);line-height:1.8;margin-bottom:10px}
.spoiler-inner ul{list-style:none;margin-bottom:12px}
.spoiler-inner ul li{position:relative;padding-left:20px;font-size:14px;color:var(--mute);line-height:1.8;margin-bottom:6px}
.spoiler-inner ul li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:.4}

/* SERVICE CARDS (sub-pages link grid) */
.svc-link-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:calc(16px * var(--index))}
.svc-link-card{border-radius:var(--r);overflow:hidden;border:1px solid var(--line);background:var(--white);transition:var(--tr);display:flex;flex-direction:column}
.svc-link-card:hover{box-shadow:0 16px 48px rgba(58,60,69,.1);transform:translateY(-4px);border-color:rgba(37,99,235,.15)}
.svc-link-card img{width:100%;height:200px;object-fit:cover;transition:transform .5s ease}
.svc-link-card:hover img{transform:scale(1.04)}
.svc-link-card-body{padding:calc(20px * var(--index));flex:1;display:flex;flex-direction:column}
.svc-link-card-body h3{font-size:clamp(16px,calc(20px * var(--index)),20px);font-weight:600;margin-bottom:8px}
.svc-link-card-body p{font-size:14px;color:var(--mute);line-height:1.6;margin-bottom:auto;padding-bottom:14px}
.svc-link-card .btn{align-self:flex-start}

/* TABS */
.tab-nav{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:calc(24px * var(--index));padding-bottom:calc(12px * var(--index));border-bottom:1px solid var(--line)}
.tab-btn{padding:8px 18px;border-radius:100px;font-size:13px;font-weight:600;color:var(--mute);background:transparent;border:1px solid var(--line);cursor:pointer;transition:var(--tr)}
.tab-btn:hover{color:var(--accent);border-color:var(--accent)}
.tab-btn.active{background:var(--accent);color:var(--white);border-color:var(--accent)}
.tab-panel{display:none}
.tab-panel.active{display:block}

/* DISEASE CARDS */
.disease-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:calc(14px * var(--index))}
.disease-card{padding:calc(24px * var(--index));border-radius:var(--r);border:1px solid var(--line);background:var(--white);transition:var(--tr);display:flex;flex-direction:column;gap:10px}
.disease-card:hover{box-shadow:0 12px 36px rgba(58,60,69,.08);transform:translateY(-3px);border-color:rgba(37,99,235,.15)}
.disease-card h3{font-size:clamp(15px,calc(18px * var(--index)),18px);font-weight:600}
.disease-card p{font-size:13px;color:var(--mute);line-height:1.6}
.disease-card .card-icon{width:48px;height:48px;border-radius:14px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center}
.disease-card .card-icon svg{width:24px;height:24px;color:var(--accent)}

/* GUIDE DOWNLOAD */
.dl-link{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--r-sm);background:var(--accent-bg);color:var(--accent);font-size:14px;font-weight:600;transition:var(--tr)}
.dl-link:hover{background:var(--accent);color:var(--white)}
.dl-link svg{width:18px;height:18px}

/* RESPONSIVE */
@media(max-width:1200px){
  :root{--index:.85}
  .svc-card:first-child{min-width:260px;flex:1}
  .spec-cards{grid-template-columns:repeat(2,1fr)}
  .tech-banner .w{grid-template-columns:1fr}
  .tech-features{grid-template-columns:1fr 1fr}
  .proc-grid{grid-template-columns:repeat(2,1fr)}
  .proc-connector{display:none}
}
.mob-tabs{display:none}
@media(max-width:1024px){
  :root{--index:.8}
  .hero{height:100vh}
  .svc-grid{flex-direction:column}.svc-card,.svc-card:first-child{min-width:0;height:280px}
  .adv-grid,.promo-grid{grid-template-columns:1fr}
  .about-block{grid-template-columns:1fr}.about-img img{min-height:260px;max-height:320px}
  .city-grid{grid-template-columns:1fr 1fr}
  .svo-block{grid-template-columns:1fr;text-align:center}.svo-block li::before{display:none}.svo-block li{padding-left:0}
  .fgrid{grid-template-columns:1fr 1fr;gap:24px}
  .spec-cards{grid-template-columns:1fr}
  .f-form-sec .w{grid-template-columns:1fr}
  .rev{flex:0 0 calc(50% - 8px);min-width:280px}
  .tech-features{grid-template-columns:1fr}
}
@media(max-width:768px){
  :root{--index:.75}
  .topbar{display:none}
  header{top:0}
  .mainnav,.hdr-phone,.city-sel{display:none}
  .burger{display:flex;flex-direction:column;justify-content:space-around;width:32px;height:32px;background:none;border:none;cursor:pointer;padding:6px;margin-left:8px}
  .burger span{display:block;height:2px;width:100%;background:var(--dark);border-radius:2px;transition:all .3s}
  .burger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .burger.active span:nth-child(2){opacity:0}
  .burger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .mmenu{display:none;position:fixed;top:60px;left:0;right:0;bottom:0;background:var(--white);padding:24px 20px;overflow-y:auto;z-index:998;border-top:1px solid var(--line);box-shadow:0 4px 20px rgba(0,0,0,.08);padding-bottom:96px}
  .mmenu.on{display:flex;flex-direction:column;gap:6px}
  .mmenu a{display:block;padding:14px 4px;font-size:16px;color:var(--dark);text-decoration:none;border-bottom:1px solid var(--line2,#f1f5f9)}
  .mmenu a:last-child{border-bottom:none}
  .hero{height:100vh}
  .hero-grid{padding-top:80px;padding-bottom:32px}
  .hg-title{font-size:clamp(38px,10vw,64px)}
  .hg-bottom{flex-direction:column;align-items:flex-start;gap:20px}
  .hg-actions{flex-wrap:wrap}
  .hg-tagline{font-size:13px;max-width:260px}
  .ai-sec .w{grid-template-columns:1fr}
  .ai-robot{display:none}
  .spec-cards{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr}.stat-item{border-right:none;border-bottom:1px solid var(--line)}.stat-item:last-child{border-bottom:none}
  .city-grid{grid-template-columns:1fr}
  .fg,.f-form{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .qbar{flex-direction:column;text-align:center}
  .rev{flex:0 0 85%;min-width:0}
  .proc-grid{grid-template-columns:1fr}
  .cta-banner .w{flex-direction:column;text-align:center}
  .marquee-track{animation-duration:20s}
  /* bottom tab bar */
  .mob-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:9999;background:var(--white);border-top:1px solid var(--line);padding:6px 0 env(safe-area-inset-bottom,8px);justify-content:space-around;align-items:center;box-shadow:0 -2px 20px rgba(0,0,0,.06)}
  .mob-tab{display:flex;flex-direction:column;align-items:center;gap:3px;text-decoration:none;color:var(--mute);font-size:10px;font-weight:500;transition:color .2s ease;padding:4px 8px;-webkit-tap-highlight-color:transparent}
  .mob-tab svg{width:22px;height:22px;transition:all .2s ease}
  .mob-tab.active{color:var(--accent)}
  .mob-tab.active svg{stroke:var(--accent)}
  .mob-tab-cta{position:relative;margin-top:-20px}
  .mob-tab-cta svg{stroke:var(--white);background:var(--accent);border-radius:50%;padding:10px;width:46px;height:46px;box-shadow:0 4px 16px rgba(37,99,235,.35);transition:all .3s ease}
  .mob-tab-cta span{color:var(--accent);font-weight:600}
  .mob-tab-cta:active svg{transform:scale(.95)}
  body{padding-bottom:72px}
  .ai-chat-fab{bottom:84px!important}
  .ai-chat-panel{bottom:148px!important}
}
@media(max-width:480px){.hero{height:100vh}.hero-grid{padding-top:72px;padding-bottom:24px}.hg-top{flex-direction:column;align-items:flex-start;gap:6px}.hg-label{font-size:13px;letter-spacing:.14em}.hg-cities{font-size:24px;font-weight:700;letter-spacing:.02em;color:#fff;text-align:left;align-self:flex-start;text-shadow:0 2px 16px rgba(0,0,0,.4)}.hg-top-sep{display:none}.hg-title{font-size:64px;line-height:.92}.hg-title-sub{font-size:.32em}.hg-actions{flex-direction:column;width:100%;gap:10px;align-items:stretch}.hg-actions-row{flex-direction:column;width:100%;gap:10px}.hero-btn-main,.hero-btn-ghost,.hero-btn-laser{width:100%;justify-content:center;padding:16px 20px;font-size:15px}.hg-tagline{font-size:12px}.bvi-hero-btn{position:fixed;left:0;top:auto;bottom:84px;transform:none;z-index:60;padding:7px 8px;border-radius:0 10px 10px 0}.bvi-hero-btn span{display:none}.rev{flex:0 0 90%}.sec-deco::before{display:none}}

/* SEARCH */
.hdr-search-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,.1);border:none;cursor:pointer;transition:var(--tr);color:var(--white)}
.hdr-search-btn:hover{background:rgba(255,255,255,.2)}
header.stuck .hdr-search-btn{color:var(--dark);background:var(--light)}
header.stuck .hdr-search-btn:hover{background:var(--line)}
body.subpage header .hdr-search-btn{color:#3A3C45!important;background:var(--light)!important}
body.subpage header .hdr-search-btn:hover{background:var(--line)!important}

.search-ov{position:fixed;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:flex-start;justify-content:center;padding-top:10vh;opacity:0;visibility:hidden;transition:all .25s ease}
.search-ov.on{opacity:1;visibility:visible}
.search-modal{width:640px;max-width:calc(100vw - 32px);background:var(--white);border-radius:20px;box-shadow:0 20px 80px rgba(0,0,0,.25);overflow:hidden;transform:translateY(-20px) scale(.97);transition:all .25s ease;max-height:80vh;display:flex;flex-direction:column}
.search-ov.on .search-modal{transform:translateY(0) scale(1)}
.search-head{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--line)}
.search-head input{flex:1;border:none;outline:none;font-size:16px;font-family:inherit;color:var(--dark);background:transparent}
.search-head input::placeholder{color:var(--mute)}
.search-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--mute);border:none;background:var(--light);border-radius:8px;cursor:pointer;transition:var(--tr)}
.search-close:hover{background:var(--line);color:var(--dark)}
.search-results{flex:1;overflow-y:auto;padding:8px 0}
.search-hint,.search-empty,.search-loading{padding:32px 20px;text-align:center;color:var(--mute);font-size:14px}
.search-group{padding:4px 0}
.search-group-label{padding:8px 20px 4px;font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.search-item{display:block;padding:10px 20px;transition:background .15s;cursor:pointer;text-decoration:none}
.search-item:hover{background:var(--accent-bg)}
.search-item-title{font-size:15px;font-weight:500;color:var(--dark)}
.search-item-title mark{background:var(--accent-soft);color:var(--accent);border-radius:2px;padding:0 2px}
.search-item-desc{font-size:13px;color:var(--mute);margin-top:2px}
.search-popular{padding:12px 20px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.search-popular-label{font-size:12px;color:var(--mute);font-weight:500}
.search-popular button{font-size:12px;padding:4px 12px;border-radius:20px;border:1px solid var(--line);background:var(--white);color:var(--dark);cursor:pointer;transition:var(--tr);font-family:inherit}
.search-popular button:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-bg)}
@media(max-width:768px){.hdr-search-btn{width:36px;height:36px}.search-modal{width:100%;max-width:100%;border-radius:0;max-height:100vh;height:100vh}}

/* AI Chat Widget */
.ai-chat-fab{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;border:none;cursor:pointer;z-index:9000;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,99,235,.4);transition:all .3s ease}
.ai-chat-fab:hover{transform:scale(1.08);box-shadow:0 6px 30px rgba(37,99,235,.5)}
.ai-chat-fab svg{width:28px;height:28px;transition:transform .3s ease}
.ai-chat-fab.open svg{transform:rotate(90deg)}
.ai-chat-fab-pulse{position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(37,99,235,.4);animation:fabPulse 2s ease-in-out infinite}
@keyframes fabPulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:0}}
.ai-chat-badge{position:absolute;top:-2px;right:-2px;width:18px;height:18px;background:#ef4444;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid #fff}
.ai-chat-panel{position:fixed;bottom:96px;right:24px;width:380px;max-height:520px;background:#fff;border-radius:20px;box-shadow:0 20px 60px rgba(0,0,0,.15);z-index:9001;display:flex;flex-direction:column;overflow:hidden;transform:translateY(20px) scale(.95);opacity:0;pointer-events:none;transition:all .3s cubic-bezier(.4,0,.2,1)}
.ai-chat-panel.open{transform:translateY(0) scale(1);opacity:1;pointer-events:auto}
.ai-chat-head{background:linear-gradient(135deg,#2563eb,#1e40af);color:#fff;padding:16px 20px;display:flex;align-items:center;gap:12px}
.ai-chat-head-ava{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-chat-head-ava svg{width:20px;height:20px}
.ai-chat-head-info h4{font-size:14px;font-weight:600;margin-bottom:2px;color:#fff}
.ai-chat-head-info span{font-size:11px;opacity:.7}
.ai-chat-close{margin-left:auto;background:none;border:none;color:#fff;cursor:pointer;opacity:.7;transition:opacity .2s}
.ai-chat-close:hover{opacity:1}
.ai-chat-close svg{width:20px;height:20px}
.ai-chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;min-height:280px;max-height:340px;background:#f8fafc}
.ai-msg{max-width:85%;padding:10px 14px;border-radius:14px;font-size:13px;line-height:1.55;animation:msgIn .3s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.ai-msg.bot{background:#fff;color:var(--dark);align-self:flex-start;border:1px solid var(--line);border-bottom-left-radius:4px}
.ai-msg.user{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.ai-msg.bot a{color:var(--accent);text-decoration:underline}
.ai-msg.bot a:hover{text-decoration:none}
.ai-typing{display:inline-block;animation:dotBounce 1s ease-in-out infinite;font-size:18px;letter-spacing:2px;color:var(--mute)}
.ai-msg.typing{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.ai-msg.typing .dots{display:flex;gap:4px}
.ai-msg.typing .dots span{width:6px;height:6px;border-radius:50%;background:var(--mute);animation:dotBounce 1.4s ease-in-out infinite}
.ai-msg.typing .dots span:nth-child(2){animation-delay:.2s}
.ai-msg.typing .dots span:nth-child(3){animation-delay:.4s}
@keyframes dotBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-4px)}}
.ai-chat-foot{padding:12px 16px;border-top:1px solid var(--line);display:flex;gap:8px;background:#fff}
.ai-chat-foot input{flex:1;border:1px solid var(--line);border-radius:12px;padding:10px 14px;font-size:13px;font-family:inherit;outline:none;transition:border-color .2s}
.ai-chat-foot input:focus{border-color:var(--accent)}
.ai-chat-foot button{width:38px;height:38px;border-radius:12px;background:var(--accent);color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}
.ai-chat-foot button:hover{background:var(--accent-h)}
.ai-chat-foot button svg{width:18px;height:18px}
@media(max-width:480px){.ai-chat-panel{right:8px;left:8px;width:auto;bottom:88px;max-height:70vh}.ai-chat-fab{bottom:16px;right:16px;width:52px;height:52px}}

/* ===== GENERIC TEMPLATES (Bryansk, Tula) ===== */

/* Doctor grid (specialists page & homepage) */
.doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:calc(24px * var(--index));margin-top:calc(32px * var(--index))}
.doc-card{display:flex;flex-direction:column;background:var(--white);border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--line);transition:var(--tr);text-decoration:none}
.doc-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:var(--accent)}
.doc-card img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top}
.doc-card h3{padding:16px 16px 4px;font-size:calc(15px * var(--index));font-weight:600;color:var(--dark);line-height:1.3}
.doc-card p{padding:0 16px;font-size:calc(13px * var(--index));color:var(--mute);line-height:1.4}
.doc-exp{display:inline-block;margin:8px 16px 16px;padding:4px 10px;background:var(--accent-bg);color:var(--accent);border-radius:8px;font-size:12px;font-weight:500}

/* Doctor detail page */
.doc-profile{display:flex;gap:calc(40px * var(--index));align-items:flex-start;flex-wrap:wrap}
.doc-photo{width:320px;flex-shrink:0;border-radius:var(--r-sm);overflow:hidden}
.doc-photo img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:top}
.doc-info{flex:1;min-width:280px}
.doc-info h1{font-size:calc(28px * var(--index));margin-bottom:12px}
.doc-position{font-size:calc(16px * var(--index));color:var(--accent);font-weight:500;margin-bottom:16px}
.doc-info p{font-size:calc(15px * var(--index));line-height:1.6;margin-bottom:8px}
.doc-edu,.doc-bio{margin-top:16px;font-size:calc(14px * var(--index));line-height:1.7;color:var(--text)}
.doc-section{margin-bottom:20px}
.doc-section-title{font-size:calc(15px * var(--index));font-weight:600;color:var(--dark);margin-bottom:8px}
.doc-section p{margin-bottom:4px}

/* Service/Disease/Equipment/Guide grid */
.srv-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:calc(24px * var(--index));margin-top:calc(32px * var(--index))}
.srv{display:flex;flex-direction:column;background:var(--white);border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--line);transition:var(--tr);text-decoration:none}
.srv:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:var(--accent)}
.srv-img{width:100%;aspect-ratio:16/9;object-fit:cover}
.srv h3{padding:16px 16px 6px;font-size:calc(16px * var(--index));font-weight:600}
.srv p{padding:0 16px 16px;font-size:calc(13px * var(--index));color:var(--mute);line-height:1.5}

/* Contacts page */
.contacts-block{max-width:700px;margin:0 auto}
.contact-item{padding:12px 0;border-bottom:1px solid var(--line);font-size:calc(15px * var(--index));line-height:1.6}
.contact-item:last-child{border-bottom:none}
.contact-item strong{color:var(--dark);font-weight:600;margin-right:8px}
.contact-item a{color:var(--accent);font-weight:500}
.contact-item a:hover{text-decoration:underline}

/* Reviews page */
.rev-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:calc(24px * var(--index));margin-top:calc(32px * var(--index))}
.rev-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-sm);padding:calc(24px * var(--index));transition:var(--tr)}
.rev-card:hover{box-shadow:0 8px 24px rgba(0,0,0,.06)}
.rev-author{font-weight:600;color:var(--dark);font-size:calc(16px * var(--index));margin-bottom:4px}
.rev-date{font-size:12px;color:var(--mute);margin-bottom:8px}
.rev-source{font-size:12px;color:var(--mute);margin-top:12px}
.rev-stars{display:flex;gap:2px;margin-bottom:12px}
.rev-stars svg{width:16px;height:16px;fill:var(--accent)}
.star-off{opacity:.2}
.rev-card p{font-size:calc(14px * var(--index));line-height:1.6;color:var(--text)}

/* Prices page */
.prices{margin-top:calc(32px * var(--index))}
.prices h3{font-size:calc(20px * var(--index));margin:calc(32px * var(--index)) 0 calc(16px * var(--index));padding-bottom:8px;border-bottom:2px solid var(--accent)}
.prices h3:first-child{margin-top:0}
.prices table{width:100%;border-collapse:collapse;margin-bottom:calc(16px * var(--index))}
.prices th,.prices td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--line);font-size:calc(14px * var(--index))}
.prices th{background:var(--light);font-weight:600;color:var(--dark)}
.prices td:last-child{text-align:right;font-weight:600;white-space:nowrap;color:var(--dark)}

/* Promo page */
.promo-link{text-decoration:none;color:inherit}
.promo-link:hover .promo{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}

/* Generic page-hero override removed — main .page-hero definition is at line 455 with blue gradient */

@media(max-width:768px){
  .doc-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .doc-card h3{font-size:14px;padding:10px 10px 2px}
  .doc-card p{font-size:12px;padding:0 10px 10px}
  .doc-profile{flex-direction:column}
  .doc-photo{width:100%;max-width:320px}
  .srv-grid{grid-template-columns:1fr}
  .rev-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .doc-grid{grid-template-columns:repeat(2,1fr)}
}

/* CONTACTS MAP */
.contacts-map-section{margin-top:calc(56px * var(--index));background:var(--white);border-radius:var(--r);border:1px solid var(--line);overflow:hidden}
.contacts-map-title{display:flex;align-items:center;gap:12px;padding:calc(28px * var(--index)) calc(32px * var(--index));font-size:clamp(20px,calc(24px * var(--index)),24px);font-weight:600;color:var(--dark);border-bottom:1px solid var(--line)}
.contacts-map-title svg{color:var(--accent);flex-shrink:0;width:24px;height:24px}
.contacts-map{height:560px;position:relative}
.contacts-map iframe{width:100%;height:100%;border:none;display:block}
@media(max-width:768px){.contacts-map{height:400px}}

/* === PROMO DATE PILL === */
.promo{position:relative}
.promo-date-pill{position:absolute;top:calc(32px * var(--index) + 14px);right:calc(32px * var(--index) + 14px);display:inline-flex;align-items:center;gap:8px;font-size:16px;font-weight:700;color:#0f172a;background:#fff;padding:10px 18px;border-radius:999px;box-shadow:0 8px 24px rgba(15,23,42,.22),0 2px 6px rgba(15,23,42,.1);font-feature-settings:"tnum";letter-spacing:-.01em;line-height:1;white-space:nowrap;z-index:3;border:1px solid rgba(15,23,42,.06);overflow:hidden;animation:pillFloat 3.6s ease-in-out infinite}
.promo-date-pill svg{width:17px;height:17px;color:var(--accent);flex-shrink:0;animation:pillCal 2.4s ease-in-out infinite}
.promo-date-pill::before{content:"";position:absolute;top:0;left:-80%;width:60%;height:100%;background:linear-gradient(110deg,transparent 0%,rgba(37,99,235,.18) 50%,transparent 100%);transform:skewX(-20deg);animation:pillShine 2.8s ease-in-out infinite}
@keyframes pillShine{0%,55%{left:-80%}70%{left:130%}100%{left:130%}}
@keyframes pillFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-3px)}}
@keyframes pillCal{0%,100%{transform:rotate(0deg)}25%{transform:rotate(-7deg)}75%{transform:rotate(7deg)}}
.promo:first-child .promo-date-pill{color:#1e3a8a;background:#fff}
.promo:first-child .promo-date-pill svg{color:var(--accent)}
.promo:first-child .promo-date-pill::before{background:linear-gradient(110deg,transparent 0%,rgba(167,139,250,.22) 50%,transparent 100%)}
@media(max-width:640px){.promo-date-pill{font-size:14px;padding:8px 14px;gap:6px;top:calc(20px + 14px);right:calc(20px + 14px)}.promo-date-pill svg{width:15px;height:15px}}

/* ==== MOBILE FIXES (big batch) ==== */
@media(max-width:768px){
  html,body{overflow-x:hidden;max-width:100%}
  .ai-chat-fab,.ai-chat-panel{display:none!important}
  .logo img{height:40px}
  /* частицы тише на мобиле */
  .hero-particles{opacity:.6}
  /* нижнее моб-меню: подпись видно, выше иконки */
  .mob-tabs{padding:8px 0 calc(env(safe-area-inset-bottom,8px) + 6px)}
  .mob-tabs a,.mob-tabs button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;font-size:10px;line-height:1.1;min-width:0;flex:1;text-align:center;white-space:nowrap}
  .mob-tabs svg{width:22px;height:22px;flex-shrink:0}
  .mob-tabs span{display:block;font-size:10px;line-height:1.1;overflow:visible;white-space:nowrap}
  /* контент не залезает под нижнее меню */
  footer{padding-bottom:84px}
}

/* ==== Красивое мобильное меню (гамбургер) ==== */
.mmenu{gap:0!important}
.mm-search{display:flex;align-items:center;gap:10px;width:100%;padding:13px 16px;background:var(--light);border:1px solid var(--line);border-radius:14px;color:var(--mute);font-size:15px;font-family:inherit;cursor:pointer;margin-bottom:18px}
.mm-search svg{flex-shrink:0;color:var(--accent)}
.mm-city-label{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--mute);margin-bottom:10px}
.mm-cities{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:22px}
.mm-city{display:flex;align-items:center;gap:7px;padding:12px 14px;background:var(--light);border:1px solid var(--line);border-radius:12px;font-size:14px;font-weight:600;color:var(--dark);border-bottom:1px solid var(--line)!important}
.mm-city svg{flex-shrink:0;color:var(--accent)}
.mm-city-active{background:var(--accent);color:#fff;border-color:var(--accent)}
.mm-city-active svg{color:#fff}
.mm-links{display:flex;flex-direction:column;margin-bottom:14px}
.mm-links a{padding:14px 4px;font-size:16px;color:var(--dark);border-bottom:1px solid var(--line2,#f1f5f9)}
.mm-phone{display:block;text-align:center;padding:14px;font-size:18px;font-weight:700;color:var(--accent)!important;border-bottom:none!important}
.mm-cta{display:block;text-align:center;padding:16px;background:var(--accent);color:#fff!important;border-radius:14px;font-size:16px;font-weight:700;margin-top:6px;border-bottom:none!important}

/* ==== СЕКЦИИ: мобильные фиксы (направления/врачи/промо/отзывы) ==== */
@media(max-width:768px){
  /* НАПРАВЛЕНИЯ: надпись ПОД картинкой, а не поверх */
  .svc-card{height:auto;min-height:0;display:block;border-radius:18px;background:var(--light)}
  .svc-card:first-child{flex:1}
  .svc-card img{position:relative;inset:auto;width:100%;height:180px;display:block;border-radius:18px 18px 0 0}
  .svc-info{position:relative;z-index:2;background:#fff;backdrop-filter:none;margin:0;border-radius:0 0 18px 18px;padding:14px 16px;align-items:center}
  .svc-card:hover .svc-info{background:#fff}
  .svc-info h3{color:var(--dark);font-size:16px;font-weight:600}
  .svc-info p{color:var(--mute)}
  .svc-arrow{width:34px;height:34px;min-width:34px}
  .svc-arrow svg{color:#fff}

  /* ВРАЧИ: 2 основных в ряд (как урезанный ПК) */
  .spec-cards{grid-template-columns:repeat(2,1fr)!important;gap:12px}
  .spec-circles{gap:18px 14px}
  .spec-circ{width:88px}
  .spec-circ-img{width:72px;height:72px}

  /* ПРОМО: одна колонка, картинка ровная */
  .promo-grid{grid-template-columns:1fr!important}
  .promo{padding:18px}
  .promo-img{height:180px}

  /* ОТЗЫВЫ-бейджи: в столбик, без горизонт. скролла */
  .rev-badges{flex-direction:column;align-items:stretch}
  .rev-badge{justify-content:center}
}
@media(max-width:420px){
  .spec-cards{grid-template-columns:repeat(2,1fr)!important}
}

/* ==== ШАПКА на мобиле: лого + поиск + бургер, остальное в меню ==== */
@media(max-width:768px){
  header{padding:10px 0}
  header .w{gap:10px}
  .hdr-row{display:flex;align-items:center;justify-content:space-between;width:100%}
  /* в шапке прячем кнопку записи и телефон — они в гамбургер-меню */
  .hdr-right .btn-sm,.hdr-right .btn-fill{display:none}
  .hdr-right{gap:8px;margin-left:auto}
  .hdr-search-btn{width:38px;height:38px}
  .burger{display:flex!important;width:30px;height:30px;margin-left:4px;flex-shrink:0}
  .burger span{background:var(--dark)}
  /* меню открывается под шапкой */
  .mmenu{top:58px}
}

/* ==== Footer-кнопка записи: крупная красивая ==== */
.f-form .btn.btn-fill{grid-column:1/-1;margin-top:8px;padding:17px 32px;font-size:16px;font-weight:700;border-radius:14px;letter-spacing:.02em;box-shadow:0 6px 24px rgba(37,99,235,.35)}
.f-form .btn.btn-fill:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(37,99,235,.45)}
@media(max-width:768px){
  .f-form-sec .w{grid-template-columns:1fr;gap:20px}
  .f-form{grid-template-columns:1fr 1fr}
  .f-form .btn.btn-fill{padding:18px;font-size:16px}
  /* Калуга hero: услуги+телефон в строку, компактно, не закрывают фон */
  .hg-actions-row{flex-direction:row!important;gap:8px}
  .hg-actions-row .hero-btn-ghost{flex:1;width:auto;padding:13px 12px;font-size:13px;justify-content:center;background:rgba(255,255,255,.12);backdrop-filter:blur(10px)}
}
@media(max-width:420px){
  .f-form{grid-template-columns:1fr}
}

/* ==== Бургер белый на hero + города в меню ==== */
@media(max-width:768px){
  /* бургер белый поверх тёмного hero, тёмный когда шапка прилипла/субстраница */
  .burger span{background:#fff!important}
  header.stuck .burger span,body.subpage .burger span{background:var(--dark)!important}
  /* выбор города в меню: иконка с отступом, активный — белый текст */
  .mm-city{gap:10px;padding:13px 14px}
  .mm-city svg{margin-right:2px}
  .mm-city,.mm-city *{color:var(--dark)}
  .mm-city-active,.mm-city-active *{color:#fff!important}
  .mm-city-active svg{color:#fff!important}
}

/* ==== BVI как на портале (торчащая синяя плашка слева) + hero-top выше ==== */
.bvi-hero-btn{display:inline-flex;align-items:center;gap:7px;cursor:pointer;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);border-radius:30px;padding:7px 14px;font-family:inherit;font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.85);transition:all .2s}
.bvi-hero-btn:hover{background:rgba(255,255,255,.2);color:#fff}
.bvi-hero-btn svg{width:16px;height:16px;flex-shrink:0}
@media(max-width:768px){
  /* поднять "Офтальмологический центр" + город выше */
  .hero-grid{padding-top:64px}
  .hg-top{padding-top:0;margin-bottom:24px}
  /* BVI — торчащая плашка слева как на портале */
  .bvi-hero-btn{position:fixed;left:0;top:50%;bottom:auto;transform:translateY(-50%);z-index:60;background:rgba(37,99,235,.92);border:1px solid rgba(255,255,255,.25);border-left:none;border-radius:0 10px 10px 0;padding:8px 9px;color:#fff;box-shadow:2px 2px 12px rgba(0,0,0,.3)}
  .bvi-hero-btn span{display:none}
  .bvi-hero-btn svg{width:18px;height:18px}
}

/* ==== Гамбургер 2.0: аккордеон, иконки, красивый телефон ==== */
.mm-nav{display:flex;flex-direction:column;margin-bottom:16px}
.mm-item,.mm-acc-head{display:flex;align-items:center;gap:12px;width:100%;padding:14px 6px;font-size:16px;font-weight:600;color:var(--dark);background:none;border:none;border-bottom:1px solid var(--line2,#f1f5f9);font-family:inherit;cursor:pointer;text-align:left}
.mm-item svg,.mm-acc-head .mm-ic{width:20px;height:20px;flex-shrink:0;color:var(--accent)}
.mm-item span,.mm-acc-head span{flex:1}
.mm-chev{width:18px;height:18px;color:var(--mute);transition:transform .25s ease;flex-shrink:0}
.mm-acc.open .mm-chev{transform:rotate(180deg)}
.mm-acc-body{display:grid;grid-template-rows:0fr;overflow:hidden;transition:grid-template-rows .28s ease}
.mm-acc.open .mm-acc-body{grid-template-rows:1fr}
.mm-acc-body>div,.mm-acc-body{min-height:0}
.mm-acc-body a{display:block;padding:11px 6px 11px 38px;font-size:14.5px;color:var(--mute);border-bottom:1px solid var(--line2,#f5f7fa)}
.mm-acc-body a:hover{color:var(--accent)}
.mm-acc-body{padding-left:0}
/* обёртка для анимации grid-rows */
.mm-acc-body{display:block;max-height:0;transition:max-height .3s ease}
.mm-acc.open .mm-acc-body{max-height:600px}
/* красивый телефон */
.mm-phone{display:flex!important;align-items:center;justify-content:center;gap:10px;padding:14px;margin-top:6px;background:var(--accent-bg,#eff6ff);border:1px solid var(--accent-soft,#dbeafe);border-radius:14px;font-size:18px;font-weight:700;color:var(--accent)!important;border-bottom:none!important}
.mm-phone svg{width:20px;height:20px;flex-shrink:0}
@media(max-width:768px){
  .mm-cities{gap:8px}
  .mm-city span{margin-left:2px}
}

/* ==== FINAL: города-отступ, footer-кнопка крупная ==== */
.mm-city{gap:12px!important;padding:13px 16px!important}
.mm-city svg{margin-right:4px}
.mm-city span{margin-left:0}
.f-form .btn.btn-fill.fw,.f-form button.btn-fill{grid-column:1/-1;padding:18px 32px!important;font-size:16px!important;font-weight:700!important;border-radius:14px!important;box-shadow:0 6px 24px rgba(37,99,235,.35)!important;letter-spacing:.02em}
@media(max-width:768px){
  .f-form .btn.btn-fill.fw,.f-form button.btn-fill{padding:18px!important;width:100%}
}

/* ==== FIX: размеры всех иконок в гамбургере ==== */
.mmenu svg{width:20px;height:20px;flex-shrink:0}
.mm-item svg,.mm-acc-head .mm-ic{width:20px!important;height:20px!important}
.mm-chev{width:18px!important;height:18px!important}
.mm-city svg{width:16px!important;height:16px!important}
.mm-search svg{width:18px!important;height:18px!important}
.mm-phone svg{width:20px!important;height:20px!important}
.mm-acc-body svg{width:16px!important;height:16px!important}

/* ==== Footer-кнопка: реально крупная и мощная ==== */
.f-form button[type=submit],.f-form .btn.fw{grid-column:1/-1!important;padding:20px 40px!important;font-size:18px!important;font-weight:700!important;border-radius:16px!important;background:var(--accent)!important;color:#fff!important;border:none!important;box-shadow:0 8px 28px rgba(37,99,235,.4)!important;letter-spacing:.03em;text-transform:uppercase;width:100%!important;margin-top:10px!important;cursor:pointer;transition:all .3s}
.f-form button[type=submit]:hover{transform:translateY(-3px)!important;box-shadow:0 12px 36px rgba(37,99,235,.5)!important}

/* ==== Ровные отступы значок<->текст в гамбургере ==== */
.mm-item,.mm-acc-head{gap:14px!important;padding:15px 8px!important}
.mm-item svg,.mm-acc-head .mm-ic{margin-right:0!important}
.mm-city{gap:0!important;padding:13px 14px!important}
.mm-city svg{margin-right:10px!important}
.mm-acc-body a{padding-left:42px!important}
.mm-phone{gap:12px!important}

/* ==== Чёткий крестик закрытия бургера ==== */
@media(max-width:768px){
  .burger{display:flex!important;flex-direction:column;justify-content:center;gap:6px;width:30px;height:30px;padding:0;position:relative}
  .burger span{display:block;height:2.5px;width:24px;margin:0 auto;background:#fff!important;border-radius:2px;transition:transform .3s ease,opacity .2s ease;transform-origin:center}
  header.stuck .burger span,body.subpage .burger span{background:var(--dark)!important}
  .burger.active span:nth-child(1){transform:translateY(8.5px) rotate(45deg)}
  .burger.active span:nth-child(2){opacity:0}
  .burger.active span:nth-child(3){transform:translateY(-8.5px) rotate(-45deg)}
}

/* ==== Модалка записи: прокрутка до кнопки на мобиле ==== */
@media(max-width:768px){
  .ov{align-items:flex-start;justify-content:center;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:16px 0}
  .ov.on{display:block}
  .modal{max-height:none;width:94%;margin:16px auto;padding:24px 20px;overflow-y:visible}
  .modal .mx{position:sticky;top:-4px}
}

/* крестик закрытия — белый, виден поверх меню */
@media(max-width:768px){
  .burger.active span{background:#fff!important}
  header.stuck .burger.active span,body.subpage .burger.active span{background:var(--dark)!important}
}

/* ==== Единое оформление всех пунктов гамбургера ==== */
@media(max-width:768px){
  .mm-item,.mm-acc-head{display:flex!important;align-items:center!important;gap:14px!important;width:100%;padding:15px 6px!important;font-size:16px!important;font-weight:600!important;color:var(--dark)!important;background:none;border:none;border-bottom:1px solid var(--line2,#f1f5f9);font-family:inherit;cursor:pointer;text-align:left;line-height:1.2}
  .mm-item svg,.mm-acc-head .mm-ic{width:21px!important;height:21px!important;flex-shrink:0;color:var(--accent)!important;stroke-width:1.8}
  .mm-item span,.mm-acc-head>span{flex:1;font-weight:600!important}
  .mm-chev{width:18px!important;height:18px!important;color:var(--mute)!important;flex-shrink:0}
  /* убрать двойной border у вложенного .mm-links если есть */
  .mm-links a{display:flex;align-items:center;gap:14px;padding:15px 6px;font-size:16px;font-weight:600;color:var(--dark)}
  .mm-links a svg{width:21px;height:21px;flex-shrink:0;color:var(--accent)}
}

/* ==== КРЕСТ закрытия ВСЕГДА белый (перебивает stuck/subpage) ==== */
@media(max-width:768px){
  body .burger.active span,
  body.subpage .burger.active span,
  header.stuck .burger.active span,
  body.subpage header.stuck .burger.active span{background:#ffffff!important}
}

/* ==== Кнопка отправки в модалке записи: крупная ==== */
.modal-submit{width:100%!important;padding:19px 32px!important;font-size:17px!important;font-weight:700!important;border-radius:14px!important;background:var(--accent)!important;color:#fff!important;border:none!important;box-shadow:0 6px 24px rgba(37,99,235,.4)!important;letter-spacing:.02em;text-transform:uppercase;margin-top:8px!important;cursor:pointer;transition:all .3s}
.modal-submit:hover{transform:translateY(-2px)!important;box-shadow:0 10px 32px rgba(37,99,235,.5)!important}

/* ==== Footer: тонкие разделители между секциями на мобилке ==== */
@media(max-width:768px){
  .fgrid{grid-template-columns:1fr;gap:0}
  .fgrid>.fb,.fgrid>.fcol{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.1)}
  .fgrid>.fcol:last-child{border-bottom:none}
  .fcol h4{margin-bottom:12px}
  .fcol a{padding:7px 0}
}

/* ==== Кнопка "Запись" в нижнем меню: красивая выпуклая ==== */
@media(max-width:768px){
  .mob-tab-cta{position:relative;margin-top:-22px}
  .mob-tabs .mob-tab-cta svg{width:54px!important;height:54px!important;stroke:#fff;background:linear-gradient(135deg,#2563eb,#1e40af);border-radius:50%;padding:15px;box-shadow:0 6px 20px rgba(37,99,235,.45);border:3px solid #fff}
  .mob-tab-cta span{color:var(--accent);font-weight:700;font-size:10px}
  .mob-tab-cta:active svg{transform:scale(.94)}
}

/* ==== Услуги: тонкий разделитель между карточками (мобилка) ==== */
@media(max-width:768px){
  .svc-pg-grid{display:flex;flex-direction:column;gap:0}
  .svc-pg-card{border-bottom:1px solid var(--line,#e1e1e1);border-radius:0;padding-bottom:18px;margin-bottom:18px}
  .svc-pg-card:last-child{border-bottom:none}
}
/* ==== Footer разделители (усилить, гарантированно) ==== */
@media(max-width:768px){
  footer .fgrid{display:flex!important;flex-direction:column;gap:0!important}
  footer .fgrid>.fb,footer .fgrid>.fcol{padding:18px 0!important;border-bottom:1px solid rgba(255,255,255,.12)!important}
  footer .fgrid>.fcol:last-child{border-bottom:none!important}
}
/* ==== Крест бургера: тёмный на светлых (sub)страницах, белый на hero ==== */
@media(max-width:768px){
  body.subpage .burger.active span,body.subpage header.stuck .burger.active span{background:var(--dark)!important}
}

/* ==== Карточка врача: убрать дубль должности на фото (мобилка) ==== */
@media(max-width:768px){
  .sc-overlay{display:none!important}
}

/* ==== Врачи: ПК 3 карточки, мобилка 2 (3-ю прячем) ==== */
@media(max-width:768px){
  .spec-cards{grid-template-columns:repeat(2,1fr)!important;gap:12px}
  .spec-cards .spec-card:nth-child(3){display:none!important}
}

/* ==== Модалка "Спасибо за заявку" ==== */
.ty-ov{display:none;position:fixed;inset:0;background:rgba(58,60,69,.55);backdrop-filter:blur(8px);z-index:3000;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .35s ease}
.ty-ov.on{display:flex;opacity:1}
.ty-modal{background:#fff;border-radius:24px;padding:44px 36px;max-width:420px;width:100%;text-align:center;box-shadow:0 30px 80px rgba(37,99,235,.25);transform:translateY(30px) scale(.92);opacity:0;transition:transform .45s cubic-bezier(.34,1.56,.64,1),opacity .35s ease}
.ty-ov.on .ty-modal{transform:translateY(0) scale(1);opacity:1}
.ty-check{width:88px;height:88px;margin:0 auto 22px}
.ty-check svg{width:88px;height:88px}
.ty-check-circle{stroke:#2563eb;stroke-width:2.5;stroke-dasharray:151;stroke-dashoffset:151;animation:tyCircle .6s cubic-bezier(.65,0,.45,1) .2s forwards}
.ty-check-mark{stroke:#2563eb;stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:tyMark .35s cubic-bezier(.65,0,.45,1) .75s forwards}
@keyframes tyCircle{to{stroke-dashoffset:0}}
@keyframes tyMark{to{stroke-dashoffset:0}}
.ty-modal h2{font-size:24px;font-weight:700;color:var(--dark,#3A3C45);margin-bottom:10px}
.ty-modal p{font-size:15px;color:var(--mute,#888B99);line-height:1.6;margin-bottom:26px}
.ty-btn{display:inline-block;padding:15px 48px;background:var(--accent,#2563eb);color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .3s;box-shadow:0 6px 24px rgba(37,99,235,.35)}
.ty-btn:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(37,99,235,.45)}
@media(max-width:480px){.ty-modal{padding:36px 24px}.ty-modal h2{font-size:21px}}
