@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Mulish:wght@300;400;500;600;700&display=swap');

:root {
  --blue:#003a6e; --blue-mid:#005299; --blue-light:#1976d2;
  --accent:#e8a020; --accent-light:#f5c04a;
  --white:#fff; --gray-bg:#f4f7fb; --gray-light:#e8eef6;
  --gray-text:#5a6a80; --dark:#1a2535; --green:#1a7a4a;
  --radius:10px; --shadow:0 4px 24px rgba(0,58,110,.10);
  --shadow-lg:0 8px 40px rgba(0,58,110,.18); --tr:.25s cubic-bezier(.4,0,.2,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Mulish',sans-serif;color:var(--dark);background:var(--white);line-height:1.6}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.25}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}
ul{list-style:none}
button{cursor:pointer;font-family:'Mulish',sans-serif}

.container{max-width:1240px;margin:0 auto;padding:0 20px}

/* TOPBAR */
.topbar{background:var(--blue);color:rgba(255,255,255,.85);font-size:13px;padding:7px 0;position:relative;z-index:200}
.topbar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.topbar a{color:rgba(255,255,255,.85);transition:color var(--tr)}
.topbar a:hover{color:var(--accent-light)}
.topbar-left{display:flex;gap:22px;flex-wrap:wrap;align-items:center}
.topbar-right{display:flex;gap:16px;align-items:center}
.topbar-phone{font-weight:700;font-size:15px;color:#fff!important}
.topbar-phone::before{content:"☎ "}
.lang-switch{display:flex;gap:5px}
.lang-btn{padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;border:1px solid rgba(255,255,255,.35);color:rgba(255,255,255,.8);background:transparent;transition:var(--tr);text-transform:uppercase;letter-spacing:.5px}
.lang-btn:hover,.lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* HEADER */
header{background:#fff;box-shadow:0 2px 14px rgba(0,58,110,.10);position:sticky;top:0;z-index:150}
.header-inner{display:flex;align-items:center;gap:16px;padding:12px 0}
.logo{display:flex;align-items:center;gap:14px;flex-shrink:0}
.logo-icon{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-light));display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff;flex-shrink:0}
.logo-name{font-family:'Playfair Display',serif;font-size:18px;font-weight:700;color:var(--blue);line-height:1.2}
.logo-sub{font-size:11px;color:var(--gray-text);text-transform:uppercase;letter-spacing:1px;margin-top:2px}

nav{margin-left:auto;display:flex;gap:2px;align-items:center;flex-wrap:wrap}
.nav-item{position:relative}
.nav-link{display:block;padding:9px 12px;font-size:13.5px;font-weight:600;color:var(--dark);border-radius:8px;transition:var(--tr);white-space:nowrap;cursor:pointer}
.nav-link:hover,.nav-link.active{color:var(--blue-light);background:var(--gray-bg)}
.has-dd>.nav-link::after{content:" ▾";font-size:9px;opacity:.6}

/* Dropdown — мост между кнопкой и меню через padding, чтобы зазор не разрывал hover */
.dropdown{
  position:absolute;
  top:100%;          /* вплотную к nav-link */
  left:0;
  padding-top:8px;   /* визуальный зазор — часть самого дропдауна */
  background:transparent;
  min-width:230px;
  z-index:300;
  opacity:0;pointer-events:none;
  transform:translateY(-4px);
  transition:var(--tr);
}
.dropdown-inner{
  background:#fff;
  border:1px solid var(--gray-light);
  border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  overflow:hidden;
}
.nav-item:hover .dropdown{opacity:1;pointer-events:all;transform:translateY(0)}
.dropdown a{display:block;padding:10px 18px;font-size:13px;color:var(--dark);border-bottom:1px solid var(--gray-bg);transition:var(--tr)}
.dropdown a:last-child{border-bottom:none}
.dropdown a:hover{background:var(--gray-bg);color:var(--blue-light);padding-left:24px}
.header-cta{margin-left:8px;flex-shrink:0}
.burger{display:none;background:none;border:none;padding:10px 8px;cursor:pointer;flex-direction:column;gap:5px;align-items:center;justify-content:center;border-radius:8px;transition:background 0.2s}
.burger:hover{background:rgba(26,86,164,0.08)}

/* Close button X icon */
.close-line{display:block;width:22px;height:2.5px;background:var(--blue);border-radius:2px;transition:all 0.2s}
.nav-close-btn .close-line:nth-child(1){transform:translateY(6px) rotate(45deg)}
.nav-close-btn .close-line:nth-child(2){transform:translateY(3.5px) rotate(-45deg)}
.burger-line{display:block;width:26px;height:3px;background:var(--blue);border-radius:2px;transition:all 0.3s}
nav.open ~ * .burger .burger-line:nth-child(1){transform:translateY(8px) rotate(45deg)}
nav.open ~ * .burger .burger-line:nth-child(2){opacity:0}
nav.open ~ * .burger .burger-line:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius);font-size:14px;font-weight:700;border:none;transition:var(--tr);line-height:1;cursor:pointer}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent-light);transform:translateY(-2px);box-shadow:0 6px 20px rgba(232,160,32,.4)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-mid);transform:translateY(-2px)}
.btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.5)}
.btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.12)}
.btn-white{background:#fff;color:var(--blue)}
.btn-white:hover{background:var(--gray-bg)}
.btn-full{width:100%}

/* HERO */
.hero{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--blue) 0%,var(--blue-mid) 55%,#004585 100%);min-height:480px;display:flex;align-items:center}
.hero-pattern{position:absolute;inset:0;pointer-events:none;background-image: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='%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/svg%3E")}
.slides-wrap{position:relative;z-index:1;width:100%}
.slide{display:none;animation:fadeIn .5s ease}
.slide.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.slide-inner{display:flex;align-items:center;gap:50px;max-width:1240px;margin:0 auto;padding:60px 20px}
.slide-text{flex:1;color:#fff}
.slide-badge{display:inline-block;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:1.2px;margin-bottom:16px}
.slide-text h2{font-size:clamp(26px,3.8vw,46px);font-weight:700;margin-bottom:14px}
.slide-text p{font-size:16px;opacity:.9;line-height:1.75;margin-bottom:26px;max-width:520px}
.slide-btns{display:flex;gap:14px;flex-wrap:wrap}
.slide-visual{flex:0 0 360px;height:270px;border-radius:18px;overflow:hidden;background:rgba(255,255,255,.10);border:2px dashed rgba(255,255,255,.25);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:rgba(255,255,255,.7);font-size:13px;text-align:center}
.slide-visual .vi{font-size:60px}
.slide-visual img{width:100%;height:100%;object-fit:cover}
.hero-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.15);border:none;color:#fff;width:44px;height:44px;border-radius:50%;font-size:20px;z-index:5;transition:var(--tr);line-height:1}
.hero-nav:hover{background:var(--accent)}
.hero-prev{left:16px}.hero-prev::before{content:"❮"}
.hero-next{right:16px}.hero-next::before{content:"❯"}
.hero-dots{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:5}
.hero-dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.4);border:none;padding:0;transition:var(--tr);cursor:pointer}
.hero-dot.active{background:var(--accent);transform:scale(1.3)}

/* QUICK LINKS */
.quick-links{background:#fff;padding:26px 0;box-shadow:0 4px 14px rgba(0,0,0,.05)}
.quick-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.quick-card{display:flex;align-items:center;gap:14px;padding:16px 18px;border-radius:var(--radius);background:var(--gray-bg);transition:var(--tr);cursor:pointer;border:1px solid transparent;text-decoration:none;color:var(--dark)}
.quick-card:hover{background:var(--blue);color:#fff;transform:translateY(-3px);box-shadow:var(--shadow)}
.quick-card .vi{font-size:28px;flex-shrink:0}
.quick-label{font-size:13px;font-weight:600;line-height:1.35}

/* SECTIONS */
.section{padding:60px 0}.section-alt{background:var(--gray-bg)}
.section-header{text-align:center;margin-bottom:44px}
.section-tag{display:inline-block;background:var(--blue);color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:20px;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px}
.section-header h2{font-size:clamp(22px,3vw,34px);color:var(--blue);margin-bottom:10px}
.section-header p{color:var(--gray-text);font-size:16px;max-width:600px;margin:0 auto}
.section-line{width:58px;height:3px;background:var(--accent);margin:14px auto 0;border-radius:2px}
.center{text-align:center}.mt-8{margin-top:32px}.mt-6{margin-top:24px}.mt-4{margin-top:16px}

/* SPLIT / ABOUT */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.img-ph{border-radius:var(--radius);overflow:hidden;min-height:340px;background:var(--gray-light)}
.img-ph img{width:100%;height:100%;object-fit:cover;display:block}
.img-ph .vi{font-size:60px}
.img-ph small{font-size:11px;opacity:.7}
.about-text h2{font-size:clamp(20px,2.8vw,30px);color:var(--blue);margin-bottom:14px}
.about-text p{font-size:15px;color:var(--gray-text);line-height:1.8;margin-bottom:12px}
.check-list{display:flex;flex-direction:column;gap:10px;margin:18px 0}
.check-list li{display:flex;align-items:center;gap:10px;font-size:15px}
.check-list li::before{content:"✔";color:var(--green);font-weight:700;flex-shrink:0}

/* STATS */
.stats-bar{background:linear-gradient(135deg,var(--blue),var(--blue-mid));padding:48px 0;color:#fff}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat-num{font-family:'Playfair Display',serif;font-size:48px;font-weight:700;color:var(--accent-light);line-height:1}
.stat-label{font-size:15px;opacity:.9;margin-top:8px}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.service-card{background:#fff;border-radius:var(--radius);padding:28px 22px;text-align:center;box-shadow:var(--shadow);transition:var(--tr);border-top:4px solid transparent;cursor:pointer;display:block;color:var(--dark)}
.service-card:hover{border-top-color:var(--accent);transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.service-card .vi{font-size:44px;margin-bottom:14px}
.service-card h3{font-size:16px;color:var(--blue);margin-bottom:10px}
.service-card p{font-size:14px;color:var(--gray-text);line-height:1.6}
.link-more{display:inline-flex;align-items:center;gap:5px;margin-top:14px;font-size:13px;font-weight:700;color:var(--blue-light)}

/* DOCTORS */
.doctors-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.doctor-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:var(--tr);display:block;color:var(--dark)}
.doctor-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.doctor-photo{height:200px;background:var(--gray-light);display:flex;align-items:center;justify-content:center;font-size:68px;overflow:hidden}
.doctor-photo img{width:100%;height:100%;object-fit:cover}
.doctor-body{padding:16px;text-align:center}
.doctor-name{font-size:14px;font-weight:700;margin-bottom:5px}
.doctor-spec{font-size:12px;color:var(--blue-light);font-weight:600}
.doctor-cat{font-size:11px;color:var(--gray-text);margin-top:3px}

/* NEWS */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.news-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:var(--tr);display:flex;flex-direction:column;color:var(--dark)}
.news-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.news-img{height:180px;background:var(--gray-light);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.news-img img{width:100%;height:100%;object-fit:cover}
.news-ph{display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--gray-text);font-size:13px}
.news-ph span{font-size:38px}
.news-cat{position:absolute;top:12px;left:12px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px}
.news-body{padding:18px;flex:1;display:flex;flex-direction:column}
.news-date{font-size:12px;color:var(--gray-text);margin-bottom:8px}
.news-title{font-size:15px;font-weight:700;margin-bottom:10px;line-height:1.4}
.news-excerpt{font-size:13px;color:var(--gray-text);line-height:1.65;flex:1}
.news-more{display:inline-flex;align-items:center;gap:5px;margin-top:12px;font-size:13px;font-weight:700;color:var(--blue-light)}

/* REVIEWS */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.review-card{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.review-stars{color:var(--accent);font-size:18px;margin-bottom:12px;letter-spacing:2px}
.review-stars::before{content:"★★★★★"}
.review-text{font-size:14px;color:var(--gray-text);line-height:1.75;margin-bottom:14px;font-style:italic}
.review-author{font-weight:700;font-size:14px}
.review-date{font-size:12px;color:var(--gray-text)}

/* PAGE HEADER */
.page-header{background:linear-gradient(135deg,var(--blue),var(--blue-mid));color:#fff;padding:46px 0}
.page-header h1{font-size:clamp(26px,4vw,42px);margin-bottom:10px}
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:14px;opacity:.85;flex-wrap:wrap}
.breadcrumb a{color:var(--accent-light)}
.breadcrumb a:hover{text-decoration:underline}

/* TABLES */
.price-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:22px}
.price-tab{padding:9px 18px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;border:2px solid var(--gray-light);background:#fff;color:var(--gray-text);transition:var(--tr)}
.price-tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.price-tab:hover:not(.active){border-color:var(--blue-light);color:var(--blue-light)}
.price-panel{display:none}.price-panel.active{display:block}
.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.data-table th{background:var(--blue);color:#fff;padding:13px 16px;text-align:left;font-size:14px;font-weight:600}
.data-table td{padding:12px 16px;font-size:14px;border-bottom:1px solid var(--gray-light);vertical-align:top}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:nth-child(even) td{background:var(--gray-bg)}
.data-table tr:hover td{background:#dfeaf8}
.price-val{font-weight:700;color:var(--blue);white-space:nowrap}
.notice{margin-top:16px;padding:13px 16px;background:#fff8e1;border-left:4px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;font-size:14px;color:var(--gray-text)}

/* CONTACTS */
.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px}
.contact-list{display:flex;flex-direction:column;gap:20px}
.contact-item{display:flex;gap:16px;align-items:flex-start}
.contact-ico{width:46px;height:46px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.contact-ico::before{content:"✦";font-size:16px}
.contact-label{font-size:11px;color:var(--gray-text);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.contact-value{font-size:15px;font-weight:600;line-height:1.5}
.map-box{background:var(--gray-light);border-radius:var(--radius);min-height:320px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:14px;color:var(--gray-text);font-size:15px;border:2px dashed #b0bec5;overflow:hidden;text-align:center;padding:30px}
.map-box iframe{width:100%;height:100%;min-height:320px;border:none;display:block}

/* SEARCH */
.search-bar{display:flex;gap:10px;margin-bottom:26px}
.search-input{flex:1;padding:11px 16px;border:1.5px solid var(--gray-light);border-radius:var(--radius);font-size:14px;font-family:'Mulish',sans-serif;outline:none;transition:var(--tr)}
.search-input:focus{border-color:var(--blue-light)}

/* TREATMENT */
.treat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.treat-card{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);display:flex;gap:16px;align-items:flex-start;transition:var(--tr)}
.treat-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.treat-card .vi{font-size:38px;flex-shrink:0}
.treat-card h3{font-size:16px;color:var(--blue);margin-bottom:8px}
.treat-card p{font-size:14px;color:var(--gray-text);line-height:1.65}

/* DIAGN CARDS */
.diagn-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.diagn-card{background:#fff;border-radius:var(--radius);padding:26px 22px;box-shadow:var(--shadow);border-left:4px solid var(--blue-light);transition:var(--tr);display:block;color:var(--dark)}
.diagn-card:hover{transform:translateX(4px);box-shadow:var(--shadow-lg);border-left-color:var(--accent)}
.diagn-card .vi{font-size:34px;margin-bottom:12px}
.diagn-card h3{font-size:15px;color:var(--blue);margin-bottom:8px}
.diagn-card p{font-size:13px;color:var(--gray-text);line-height:1.6}

/* FOREIGN */
.fserv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:28px}
.fserv-card{background:var(--gray-bg);border-radius:var(--radius);padding:22px 18px;text-align:center}
.fserv-card .vi{font-size:34px;margin-bottom:10px}
.fserv-card h4{font-size:15px;margin-bottom:6px;color:var(--blue)}
.fserv-card p{font-size:13px;color:var(--gray-text)}

/* SCHEDULE */
.sched-wrap{max-width:680px}

/* TOUR */
.tour-box{background:var(--gray-light);border-radius:var(--radius);min-height:460px;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;color:var(--gray-text);border:2px dashed #b0bec5;padding:40px;text-align:center;overflow:hidden}
.tour-box iframe{width:100%;min-height:460px;border:none;display:block}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:var(--tr);padding:20px}
.modal-overlay.open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:16px;padding:36px;max-width:480px;width:100%;position:relative;transform:translateY(20px);transition:var(--tr);max-height:90vh;overflow-y:auto}
.modal-overlay.open .modal{transform:translateY(0)}
.modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:26px;color:var(--gray-text);cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background 0.2s}
.modal-close:hover{background:var(--gray-light)}
.modal-close::before{content:"×";font-size:28px;line-height:1;color:var(--gray-text)}
.modal h3{font-size:21px;color:var(--blue);margin-bottom:20px}
.form-group{margin-bottom:15px}
.form-group label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{width:100%;padding:11px 13px;border:1.5px solid var(--gray-light);border-radius:8px;font-size:14px;font-family:'Mulish',sans-serif;outline:none;transition:var(--tr);color:var(--dark);background:#fff}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--blue-light)}
.form-group textarea{height:88px;resize:vertical}

/* FOOTER */
footer{background:var(--dark);color:rgba(255,255,255,.8);padding:50px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px}
.footer-brand p{font-size:14px;opacity:.7;line-height:1.75;margin-top:12px}
.footer-col h4{font-family:'Playfair Display',serif;color:#fff;font-size:16px;margin-bottom:16px}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col ul li a{font-size:14px;opacity:.75;transition:var(--tr);cursor:pointer}
.footer-col ul li a:hover{opacity:1;color:var(--accent-light)}
.social-links{display:flex;gap:10px;margin-top:16px}
.social-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.10);display:flex;align-items:center;justify-content:center;font-size:16px;transition:var(--tr)}
.social-btn:hover{background:var(--accent);transform:translateY(-2px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.10);padding:16px 0;display:flex;justify-content:space-between;font-size:13px;opacity:.6;flex-wrap:wrap;gap:8px}

/* SCROLL TOP */
#scrollTop{position:fixed;bottom:26px;right:26px;z-index:500;background:var(--blue);color:#fff;width:46px;height:46px;border-radius:50%;border:none;font-size:22px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:var(--tr)}
#scrollTop.show{opacity:1;pointer-events:all}
#scrollTop:hover{background:var(--blue-mid);transform:translateY(-3px)}

/* MOBILE NAV */
.nav-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:148}
.nav-overlay.show{display:block}

/* ── PREVENT HORIZONTAL SCROLL ON ALL SCREENS ── */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}
* { min-width: 0; }

/* ── TABLET ── */
@media(max-width:1100px){
  .services-grid,.news-grid{grid-template-columns:repeat(2,1fr)}
  .doctors-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  nav{display:none}
  nav.open{
    display:flex;flex-direction:column;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:#fff;z-index:149;
    padding:70px 20px 30px;overflow-y:auto;gap:0;
    width:100%;
  }
  nav.open .nav-link{font-size:17px;padding:13px 10px;border-bottom:1px solid var(--gray-light)}
  nav.open .dropdown{
    position:static;opacity:1;pointer-events:all;
    transform:none;box-shadow:none;border:none;padding-top:0;
    background:transparent;
  }
  nav.open .dropdown-inner{
    background:var(--gray-bg);border-radius:var(--radius);
    border:none;box-shadow:none;margin:4px 0 8px;
  }
  nav.open .dropdown a{padding-left:24px;font-size:15px}
  .burger{display:flex}
  .nav-close-btn{
    display:flex!important;align-items:center;justify-content:center;
    width:44px;height:44px;background:#f0f4fa;border-radius:50%;border:none;
    margin:16px 16px 8px auto;cursor:pointer;flex-direction:column;gap:0;
    box-shadow:0 2px 8px rgba(0,0,0,0.08)
  }
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .fserv-grid{grid-template-columns:1fr 1fr}
  .header-inner{gap:8px;flex-wrap:nowrap;width:100%;box-sizing:border-box}
  .logo{flex:1 1 auto;min-width:0;overflow:hidden}
  .logo-name{font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .logo-sub{display:none}
  .logo-icon{width:42px;height:42px;font-size:18px;flex-shrink:0}
  .header-cta{flex-shrink:0;margin-left:0}
  .header-cta .btn{padding:9px 14px;font-size:13px;white-space:nowrap}
  .burger{flex-shrink:0}
}

/* ── MOBILE ── */
@media(max-width:768px){
  .container{padding:0 16px}
  .split,.contacts-grid{grid-template-columns:1fr}
  .services-grid,.news-grid,.reviews-grid{grid-template-columns:1fr}
  .treat-grid,.diagn-grid{grid-template-columns:1fr}
  .slide-visual{display:none}
  .slide-inner{padding:36px 16px;gap:0}
  .slide-text h2{font-size:24px}
  .slide-text p{font-size:14px;margin-bottom:20px}
  .slide-badge{font-size:10px;margin-bottom:12px}
  .hero{min-height:340px}
  .footer-grid{grid-template-columns:1fr}
  .fserv-grid{grid-template-columns:1fr}
  .section{padding:44px 0}
  .section-header{margin-bottom:30px}
  .section-header h2{font-size:22px}
  .stats-bar{padding:36px 0}
  .stat-num{font-size:36px}
  .page-header{padding:32px 0}
  .page-header h1{font-size:24px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .quick-grid{grid-template-columns:repeat(2,1fr);gap:10px}
  .quick-card{padding:14px}
  .doctors-grid{grid-template-columns:repeat(2,1fr)}
  .data-table{font-size:13px}
  .data-table th,.data-table td{padding:10px 12px}
  .price-tabs{gap:6px}
  .price-tab{padding:8px 12px;font-size:13px}
  .contacts-grid{gap:28px}
  .map-box{min-height:240px}
  .footer-bottom{flex-direction:column;gap:4px;text-align:center}
  .slide-btns{gap:10px}
  .btn{padding:11px 18px;font-size:13px}
}

/* ── SMALL PHONES ── */
@media(max-width:420px){
  .doctors-grid{grid-template-columns:1fr}
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .stat-num{font-size:30px}
  .stat-label{font-size:13px}
  .logo-name{font-size:13px}
  .logo-icon{width:36px;height:36px;font-size:16px}
  .price-tab{padding:7px 10px;font-size:12px}
  .data-table th,.data-table td{padding:8px 10px;font-size:12px}
  .topbar{display:none}
  .slide-text h2{font-size:20px}
  .header-cta{display:none} /* на совсем маленьких прячем кнопку — она есть в меню */
}

/* Table horizontal scroll on mobile */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--radius)}
.table-wrap .data-table{min-width:480px}

/* Mobile nav CTA button */
.nav-cta-mobile{display:none;padding:16px 0 8px}
@media(max-width:1100px){
  nav.open .nav-cta-mobile{display:block}
}
