
:root{
  --blue-900:#0a1628;
  --blue-800:#0f2042;
  --blue-700:#162d5a;
  --blue-600:#1a3a72;
  --blue-500:#2563eb;
  --blue-400:#3b82f6;
  --blue-300:#60a5fa;
  --blue-200:#93c5fd;
  --blue-100:#dbeafe;
  --blue-50:#eff6ff;
  --white:#ffffff;
  --gray-50:#f8fafc;
  --gray-100:#f1f5f9;
  --gray-200:#e2e8f0;
  --gray-300:#cbd5e1;
  --gray-400:#94a3b8;
  --gray-500:#64748b;
  --gray-600:#475569;
  --gray-700:#334155;
  --gray-800:#1e293b;
  --green-500:#22c55e;
  --red-500:#ef4444;
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);
  --shadow:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);
  --shadow-md:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);
  --shadow-lg:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);
  --shadow-xl:0 25px 50px -12px rgba(0,0,0,.25);
  --radius:12px;
  --radius-lg:16px;
  --radius-xl:24px;
  --transition:all .3s cubic-bezier(.4,0,.2,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--gray-800);background:var(--white);line-height:1.6;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}

/* ── SCROLLBAR ───────────────────────── */
::-webkit-scrollbar{width:8px;}
::-webkit-scrollbar-track{background:var(--gray-100);}
::-webkit-scrollbar-thumb{background:var(--blue-400);border-radius:4px;}

/* ── HEADER ─────────────────────────── */
header{background:var(--white);position:sticky;top:0;z-index:1000;border-bottom:1px solid var(--gray-200);backdrop-filter:blur(12px);background:rgba(255,255,255,.95);}
.header-top{display:flex;align-items:center;justify-content:space-between;padding:12px 5%;max-width:1400px;margin:0 auto;}
.logo{display:flex;align-items:center;gap:12px;text-decoration:none;}
.logo-img{height:58px;width:auto;display:block;transform:scale(1.6);transform-origin:left center;margin-left:6px;margin-right:24px;}
.footer-brand-text{display:flex;align-items:center;gap:12px;margin-bottom:10px;}
.fbt-dots{display:inline-flex;align-items:center;gap:4px;flex-shrink:0;}
.fbt-dots i{display:block;width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.fbt-dots i:nth-child(1){background:#e53935;}
.fbt-dots i:nth-child(2){background:#2e7d32;}
.fbt-dots i:nth-child(3){background:#1e88e5;}
.fbt-name{font-size:28px;font-weight:900;color:#fff;letter-spacing:1px;line-height:1;}
.footer-brand-sub{font-size:11px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1.5px;line-height:1.4;margin-bottom:18px;font-weight:600;}
.logo-badge{width:48px;height:48px;background:linear-gradient(135deg,var(--blue-500),var(--blue-700));border-radius:var(--radius);display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative;overflow:hidden;}
.logo-badge::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.2));border-radius:var(--radius);}
.logo-badge svg{width:28px;height:28px;position:relative;z-index:1;}
.logo-text .name{font-size:16px;font-weight:800;color:var(--blue-800);letter-spacing:-.3px;}
.logo-text .sub{font-size:10px;font-weight:500;color:var(--gray-500);text-transform:uppercase;letter-spacing:1.5px;}
.header-contacts{display:flex;align-items:center;gap:24px;}
.contact-item{color:var(--gray-600);font-size:12px;transition:var(--transition);}
.contact-item:hover{color:var(--blue-500);}
.contact-item strong{display:block;font-size:14px;color:var(--gray-800);font-weight:700;}
.btn-consult{background:var(--blue-500);color:var(--white);padding:10px 24px;border-radius:var(--radius);font-weight:700;font-size:13px;white-space:nowrap;transition:var(--transition);box-shadow:0 4px 12px rgba(37,99,235,.3);}
.btn-consult:hover{background:var(--blue-600);transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,99,235,.4);}

/* mobile CTA в бургер-меню — по умолчанию скрыты, видны только в media-query */
.nav-mobile-cta{display:none;}

/* burger */
.burger{display:none;background:none;border:none;cursor:pointer;padding:8px;}
.burger span{display:block;width:24px;height:2px;background:var(--blue-800);margin:5px 0;transition:var(--transition);border-radius:2px;}
.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);}

/* backdrop за мобильным меню */
#nav-backdrop{display:none;position:fixed;inset:0;top:60px;background:rgba(0,0,0,.55);z-index:998;backdrop-filter:blur(2px);}
#nav-backdrop.open{display:block;}

/* nav */
nav{background:var(--blue-800);position:relative;}
.nav-inner{display:flex;align-items:center;padding:0 5%;max-width:1400px;margin:0 auto;}
.nav-a11y-btn{margin-left:auto;display:inline-flex;align-items:center;gap:6px;background:transparent;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.25);padding:7px 14px;font-size:12px;font-weight:600;border-radius:8px;cursor:pointer;font-family:inherit;transition:var(--transition);white-space:nowrap;}
.nav-a11y-btn:hover{color:#fff;border-color:rgba(255,255,255,.5);background:rgba(255,255,255,.08);}
@media (max-width:1024px){.nav-a11y-btn{margin:10px 24px;width:calc(100% - 48px);justify-content:center;padding:12px;}}
.nav-inner>a,.nav-inner>.nav-dropdown>a{color:rgba(255,255,255,.75);padding:14px 16px;font-size:13px;font-weight:600;white-space:nowrap;border-bottom:3px solid transparent;transition:var(--transition);position:relative;display:inline-flex;align-items:center;line-height:1.2;box-sizing:border-box;}
.nav-inner>a:hover,.nav-inner>a.active,.nav-inner>.nav-dropdown>a:hover,.nav-inner>.nav-dropdown:hover>a{color:var(--white);border-bottom-color:var(--blue-400);}
.nav-dropdown{position:relative;display:inline-flex;align-items:stretch;}
.nav-dropdown>a::after{content:'';display:inline-block;width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid currentColor;margin-left:6px;transition:var(--transition);align-self:center;}
.nav-dropdown:hover>a::after{transform:rotate(180deg);}
.dropdown-menu{display:none;position:absolute;top:100%;left:0;background:var(--white);min-width:340px;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow-lg);z-index:999;overflow:hidden;border-top:3px solid var(--blue-500);}
.dropdown-menu a{display:block;color:var(--gray-700);padding:12px 20px;font-size:13px;font-weight:500;border-bottom:1px solid var(--gray-100);transition:var(--transition);}
.dropdown-menu a:hover{background:var(--blue-50);color:var(--blue-600);padding-left:26px;}
.nav-dropdown:hover .dropdown-menu{display:block;animation:fadeDown .25s ease;}

@keyframes fadeDown{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeIn{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-20px);}to{opacity:1;transform:translateX(0);}}
@keyframes scaleIn{from{opacity:0;transform:scale(.95);}to{opacity:1;transform:scale(1);}}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.6;}}
@keyframes float{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
@keyframes slideRight{from{width:0;}to{width:100%;}}

.animate-on-scroll{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease;}
.animate-on-scroll.visible{opacity:1;transform:translateY(0);}

/* ── PAGES (SPA) ─────────────────────── */
.page{display:none;}
.page.active{display:block;animation:fadeIn .4s ease;}

/* ── HERO ────────────────────────────── */
.hero{min-height:600px;background:linear-gradient(135deg,var(--blue-900) 0%,var(--blue-800) 40%,var(--blue-700) 100%);position:relative;overflow:hidden;display:flex;align-items:center;padding:80px 5%;}
.hero::before{content:'';position:absolute;inset:0;background:
  radial-gradient(circle at 80% 20%,rgba(37,99,235,.25) 0%,transparent 50%),
  radial-gradient(circle at 20% 80%,rgba(59,130,246,.15) 0%,transparent 40%);
}
.hero-grid{display:grid;grid-template-columns:1fr .8fr;gap:60px;align-items:center;max-width:1400px;margin:0 auto;position:relative;z-index:1;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:var(--blue-300);padding:6px 16px;border-radius:30px;font-size:12px;font-weight:600;letter-spacing:.5px;margin-bottom:24px;backdrop-filter:blur(4px);}
.hero-badge svg{width:16px;height:16px;}
.hero h1{font-size:clamp(28px,4vw,52px);color:var(--white);font-weight:900;line-height:1.1;margin-bottom:20px;letter-spacing:-.5px;}
.hero h1 span{background:linear-gradient(135deg,var(--blue-300),var(--blue-200));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.hero p{color:rgba(255,255,255,.65);font-size:17px;line-height:1.8;margin-bottom:36px;max-width:540px;}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.btn-primary{background:var(--blue-500);color:var(--white);padding:14px 32px;border-radius:var(--radius);font-weight:700;font-size:15px;transition:var(--transition);box-shadow:0 4px 15px rgba(37,99,235,.4);display:inline-flex;align-items:center;gap:8px;}
.btn-primary:hover{background:var(--blue-400);transform:translateY(-2px);box-shadow:0 8px 25px rgba(37,99,235,.5);}
.btn-primary svg{width:18px;height:18px;transition:var(--transition);}
.btn-primary:hover svg{transform:translateX(3px);}
.btn-outline{border:2px solid rgba(255,255,255,.25);color:var(--white);padding:14px 32px;border-radius:var(--radius);font-weight:600;font-size:15px;transition:var(--transition);backdrop-filter:blur(4px);}
.btn-outline:hover{border-color:var(--blue-400);color:var(--blue-300);background:rgba(59,130,246,.1);}
.hero-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:50px;}
.stat{background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius);padding:20px;text-align:center;transition:var(--transition);}
.stat:hover{background:rgba(255,255,255,.1);transform:translateY(-2px);}
.stat strong{display:block;font-size:clamp(22px,2.5vw,34px);font-weight:900;background:linear-gradient(135deg,var(--blue-300),var(--white));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap;}
.stat span{font-size:12px;color:rgba(255,255,255,.5);font-weight:500;}

.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;}
.hero-img-wrapper{width:100%;max-width:480px;aspect-ratio:4/3;border-radius:var(--radius-xl);overflow:hidden;position:relative;box-shadow:var(--shadow-xl);}
.hero-img-wrapper img{width:100%;height:100%;object-fit:cover;}
.hero-img-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--blue-700),var(--blue-600));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;color:rgba(255,255,255,.3);}
.hero-img-placeholder svg{width:80px;height:80px;}
.hero-floating-card{position:absolute;background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-radius:var(--radius);padding:16px 20px;box-shadow:var(--shadow-lg);animation:float 4s ease-in-out infinite;}
.hero-floating-card.card-1{bottom:20px;left:-20px;animation-delay:0s;}
.hero-floating-card.card-2{top:20px;right:-20px;animation-delay:1s;}
.hero-floating-card .fc-number{font-size:24px;font-weight:900;color:var(--blue-500);}
.hero-floating-card .fc-text{font-size:11px;color:var(--gray-500);font-weight:500;}

/* ── SECTIONS ────────────────────────── */
.section{padding:80px 5%;}
.section .container{max-width:1400px;margin:0 auto;}
.section.alt{background:var(--gray-50);position:relative;}
.section.alt.with-bg{background:linear-gradient(rgba(248,250,252,.92),rgba(248,250,252,.95)),url('../assets/images/svc-go.jpg') center/cover no-repeat fixed;}
.section-head{text-align:center;margin-bottom:60px;}
.section-head .label{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--blue-500);margin-bottom:12px;padding:6px 16px;background:var(--blue-50);border-radius:30px;}
.section-head h2{font-size:clamp(24px,3vw,40px);font-weight:900;color:var(--blue-900);line-height:1.2;letter-spacing:-.5px;}
.section-head p{font-size:16px;color:var(--gray-500);margin-top:14px;max-width:620px;margin-left:auto;margin-right:auto;line-height:1.7;}

.training-slider{max-width:1400px;margin:0 auto;}
.training-slider-window{position:relative;overflow:hidden;border-radius:28px;background:linear-gradient(135deg,#dbe7f6,#eef4fb);box-shadow:0 24px 60px rgba(15,23,42,.12);padding:14px;}
.training-slider-track{position:relative;height:clamp(420px,68vw,820px);}
.training-slide{position:absolute;inset:0;width:100%;height:100%;margin:0;border-radius:22px;overflow:hidden;background:#dfe9f5;opacity:0;pointer-events:none;transition:opacity .35s ease;display:flex;align-items:center;justify-content:center;}
.training-slide.active{opacity:1;pointer-events:auto;z-index:1;}
.training-slide img{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;}
.training-slide figcaption{position:absolute;left:18px;right:18px;bottom:18px;padding:14px 18px;border-radius:16px;background:rgba(10,22,40,.68);color:#fff;font-size:14px;font-weight:700;backdrop-filter:blur(10px);}
.training-slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:52px;height:52px;border:none;border-radius:50%;background:rgba(255,255,255,.92);color:var(--blue-900);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 12px 28px rgba(15,23,42,.18);transition:var(--transition);z-index:2;}
.training-slider-btn:hover{background:#fff;transform:translateY(-50%) scale(1.05);}
.training-slider-btn svg{width:22px;height:22px;}
.training-slider-prev{left:26px;}
.training-slider-next{right:26px;}
.training-slider-dots{display:flex;justify-content:center;gap:10px;margin-top:18px;flex-wrap:wrap;}
.training-slider-dot{width:12px;height:12px;border:none;border-radius:999px;background:#c7d5e8;cursor:pointer;transition:var(--transition);padding:0;}
.training-slider-dot.active{width:34px;background:var(--blue-500);}

/* ── SERVICE CARDS WITH IMAGES ────────── */
.services-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:28px;}
.service-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);position:relative;cursor:pointer;}
.service-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:var(--blue-300);}
.service-card-img{height:200px;position:relative;overflow:hidden;}
.service-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s cubic-bezier(.4,0,.2,1);}
.service-card:hover .service-card-img img{transform:scale(1.08);}
.service-card-img .img-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:var(--transition);}
.service-card-img .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,22,40,.7),transparent 60%);z-index:1;}
.service-card-img .card-icon{position:absolute;top:16px;right:16px;z-index:2;width:48px;height:48px;background:rgba(255,255,255,.95);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:var(--transition);}
.service-card:hover .card-icon{background:var(--blue-500);color:var(--white);}
.service-card:hover .card-icon svg{stroke:var(--white);}
.card-icon svg{width:24px;height:24px;stroke:var(--blue-600);stroke-width:2;fill:none;transition:var(--transition);}
.service-card-body{padding:24px;}
.service-card h3{font-size:18px;font-weight:800;color:var(--blue-900);margin-bottom:10px;transition:var(--transition);}
.service-card:hover h3{color:var(--blue-500);}
.service-card p{font-size:14px;color:var(--gray-500);line-height:1.7;}
.service-card .card-link{display:inline-flex;align-items:center;gap:6px;margin-top:16px;color:var(--blue-500);font-weight:700;font-size:13px;transition:var(--transition);}
.service-card .card-link svg{width:16px;height:16px;transition:var(--transition);}
.service-card:hover .card-link{gap:10px;}
.service-card:hover .card-link svg{transform:translateX(3px);}

/* service image bg colors */
.svc-bg-1{background:linear-gradient(135deg,#1e3a5f,#2563eb);}
.svc-bg-2{background:linear-gradient(135deg,#1e293b,#475569);}
.svc-bg-3{background:linear-gradient(135deg,#064e3b,#059669);}
.svc-bg-4{background:linear-gradient(135deg,#7c2d12,#ea580c);}
.svc-bg-5{background:linear-gradient(135deg,#7f1d1d,#dc2626);}
.svc-bg-6{background:linear-gradient(135deg,#312e81,#6366f1);}

/* ── ADVANTAGES ──────────────────────── */
.adv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:28px;}
.adv-item{text-align:center;padding:40px 24px;border-radius:var(--radius-lg);background:var(--white);border:1px solid var(--gray-200);transition:var(--transition);position:relative;overflow:hidden;}
.adv-item::after{content:'';position:absolute;bottom:0;left:0;width:0;height:3px;background:linear-gradient(90deg,var(--blue-500),var(--blue-300));transition:width .4s ease;}
.adv-item:hover::after{width:100%;}
.adv-item:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--blue-200);}
.adv-icon{width:72px;height:72px;background:var(--blue-50);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;transition:var(--transition);}
.adv-item:hover .adv-icon{background:var(--blue-500);transform:scale(1.05);}
.adv-icon svg{width:32px;height:32px;stroke:var(--blue-500);stroke-width:2;fill:none;transition:var(--transition);}
.adv-item:hover .adv-icon svg{stroke:var(--white);}
.adv-item h4{font-size:16px;font-weight:800;color:var(--blue-900);margin-bottom:10px;}
.adv-item p{font-size:14px;color:var(--gray-500);line-height:1.7;}

/* ── REVIEWS ─────────────────────────── */
.reviews-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:28px;}
.review-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:32px;position:relative;transition:var(--transition);overflow:hidden;}
.review-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--blue-500),var(--blue-300));transform:scaleX(0);transition:transform .4s ease;transform-origin:left;}
.review-card:hover::before{transform:scaleX(1);}
.review-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.review-stars{color:#f59e0b;font-size:14px;letter-spacing:2px;margin-bottom:16px;}
.review-card .quote{font-size:14px;color:var(--gray-600);line-height:1.8;font-style:italic;margin-bottom:20px;}
.review-author{display:flex;align-items:center;gap:14px;}
.review-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--blue-500),var(--blue-300));display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:800;font-size:18px;flex-shrink:0;overflow:hidden;}
.review-avatar img{width:100%;height:100%;object-fit:cover;}
.review-author strong{display:block;font-size:14px;font-weight:700;color:var(--blue-900);}
.review-author span{font-size:12px;color:var(--gray-400);}

/* ── CTA ─────────────────────────────── */
.cta{background:linear-gradient(135deg,var(--blue-900),var(--blue-700));padding:80px 5%;position:relative;overflow:hidden;}
.cta::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 50%,rgba(59,130,246,.2),transparent 60%);}
.cta .container{position:relative;z-index:1;max-width:700px;margin:0 auto;text-align:center;}
.cta h2{font-size:clamp(24px,3vw,40px);font-weight:900;color:var(--white);margin-bottom:14px;}
.cta p{color:rgba(255,255,255,.6);font-size:16px;margin-bottom:36px;line-height:1.7;}
.cta-form{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;}
.cta-form input{flex:1;min-width:200px;padding:14px 20px;border:2px solid rgba(255,255,255,.15);border-radius:var(--radius);font-size:14px;font-family:inherit;outline:none;background:rgba(255,255,255,.08);color:var(--white);backdrop-filter:blur(4px);transition:var(--transition);}
.cta-form input::placeholder{color:rgba(255,255,255,.4);}
.cta-form input:focus{border-color:var(--blue-400);background:rgba(255,255,255,.12);}
.cta-form button{background:var(--blue-500);color:var(--white);border:none;padding:14px 32px;border-radius:var(--radius);font-weight:700;font-size:14px;font-family:inherit;cursor:pointer;transition:var(--transition);box-shadow:0 4px 15px rgba(37,99,235,.4);}
.cta-form button:hover{background:var(--blue-400);transform:translateY(-1px);}

/* ── SVEDEN (Сведения) ──────────────── */
.sveden-page-header{background:linear-gradient(135deg,var(--blue-900),var(--blue-700));padding:50px 5%;color:var(--white);position:relative;overflow:hidden;}
.sveden-page-header::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(59,130,246,.2),transparent 50%);}
.sveden-page-header .container{position:relative;z-index:1;max-width:1400px;margin:0 auto;}
.sveden-page-header h1{font-size:clamp(22px,3vw,34px);font-weight:900;margin-bottom:10px;}
.sveden-page-header p{color:rgba(255,255,255,.6);font-size:15px;}
.sveden-page-header .law-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(59,130,246,.15);border:1px solid rgba(59,130,246,.3);color:var(--blue-300);padding:8px 18px;border-radius:30px;font-size:12px;font-weight:600;margin-top:16px;}

.sveden-wrapper{padding:0 5%;max-width:1400px;margin:0 auto;}
.sveden-layout{display:grid;grid-template-columns:280px minmax(0,1fr);gap:0;min-height:600px;border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;margin:-40px 0 60px;position:relative;z-index:2;background:var(--white);box-shadow:var(--shadow-lg);}
.sveden-content{min-width:0;}
.sveden-sidebar{background:var(--blue-800);padding:12px 0;}
.sveden-sidebar a{display:block;padding:12px 20px;color:rgba(255,255,255,.65);font-size:13px;font-weight:500;border-left:3px solid transparent;transition:var(--transition);line-height:1.4;}
.sveden-sidebar a:hover{background:rgba(255,255,255,.05);color:var(--white);padding-left:24px;}
.sveden-sidebar a.active{background:rgba(37,99,235,.2);color:var(--blue-300);border-left-color:var(--blue-400);}
.sveden-content{padding:40px;background:var(--white);}
.sveden-panel{display:none;animation:fadeIn .3s ease;}
.sveden-panel.active{display:block;}
.sveden-panel h3{font-size:22px;font-weight:900;color:var(--blue-900);margin-bottom:8px;}
.sveden-panel .breadcrumb{font-size:12px;color:var(--gray-400);margin-bottom:24px;}
.sveden-panel .breadcrumb span{color:var(--blue-500);font-weight:600;}

.info-table{width:100%;border-collapse:separate;border-spacing:0;margin-bottom:24px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);}
.info-table th{background:var(--blue-800);color:var(--white);padding:13px 16px;text-align:left;font-size:13px;font-weight:600;}
.info-table td{padding:13px 16px;border-bottom:1px solid var(--gray-100);font-size:14px;vertical-align:top;transition:var(--transition);}
.info-table tr:last-child td{border-bottom:none;}
.info-table tr:hover td{background:var(--blue-50);}
.info-table td:first-child{color:var(--gray-500);font-size:13px;width:240px;font-weight:600;background:var(--gray-50);}

.doc-link{display:inline-flex;align-items:center;gap:8px;color:var(--blue-700);font-weight:600;font-size:13px;background:var(--blue-50);padding:10px 16px;border-radius:var(--radius);border:1px solid var(--blue-100);margin:4px;transition:var(--transition);}
.doc-link:hover{background:var(--blue-500);color:var(--white);transform:translateY(-1px);box-shadow:var(--shadow);}
.doc-link svg{width:18px;height:18px;flex-shrink:0;}

.notice{background:var(--blue-50);border:1px solid var(--blue-200);border-radius:var(--radius);padding:16px 20px;font-size:13px;color:var(--gray-700);line-height:1.7;margin:16px 0;display:flex;gap:12px;align-items:flex-start;}
.notice svg{width:20px;height:20px;flex-shrink:0;stroke:var(--blue-500);margin-top:2px;}
.notice strong{color:var(--blue-700);}
.notice-content{flex:1;}

.badge-ok{display:inline-flex;align-items:center;gap:4px;background:#dcfce7;color:#166534;padding:4px 12px;border-radius:30px;font-size:12px;font-weight:700;}
.badge-no{display:inline-flex;align-items:center;gap:4px;background:#fee2e2;color:#991b1b;padding:4px 12px;border-radius:30px;font-size:12px;font-weight:700;}

/* педсостав - карточки */
.staff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin:20px 0;}
.staff-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;transition:var(--transition);position:relative;overflow:hidden;}
.staff-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--blue-500),var(--blue-300));transform:scaleX(0);transition:transform .4s ease;transform-origin:left;}
.staff-card:hover::before{transform:scaleX(1);}
.staff-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.staff-card-header{display:flex;gap:16px;align-items:center;margin-bottom:16px;}
.staff-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--blue-500),var(--blue-300));display:flex;align-items:center;justify-content:center;color:var(--white);font-weight:800;font-size:20px;flex-shrink:0;overflow:hidden;}
.staff-avatar img{width:100%;height:100%;object-fit:cover;}
.staff-card-header .staff-name{font-size:16px;font-weight:800;color:var(--blue-900);}
.staff-card-header .staff-pos{font-size:12px;color:var(--gray-400);font-weight:500;}
.staff-card-body{display:flex;flex-direction:column;gap:8px;}
.staff-field{display:flex;gap:8px;font-size:13px;line-height:1.5;}
.staff-field-label{color:var(--gray-400);font-weight:600;min-width:110px;flex-shrink:0;font-size:12px;}
.staff-field-value{color:var(--gray-700);}
.staff-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px;}
.staff-tag{display:inline-block;background:var(--blue-50);color:var(--blue-600);padding:3px 10px;border-radius:6px;font-size:11px;font-weight:600;border:1px solid var(--blue-100);}
.staff-profile-link{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:8px 16px;background:var(--blue-50);color:var(--blue-600);border-radius:var(--radius);font-size:12px;font-weight:700;border:1px solid var(--blue-100);transition:var(--transition);}
.staff-profile-link:hover{background:var(--blue-500);color:var(--white);border-color:var(--blue-500);}
.staff-profile-link svg{width:14px;height:14px;}

/* staff table view */
.staff-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--gray-200);}
.staff-table th{background:var(--blue-800);color:var(--white);padding:12px 14px;text-align:left;font-size:12px;font-weight:600;white-space:nowrap;position:sticky;top:0;}
.staff-table td{padding:12px 14px;border-bottom:1px solid var(--gray-100);vertical-align:top;line-height:1.5;transition:var(--transition);}
.staff-table tr:hover td{background:var(--blue-50);}
.staff-name-cell{font-weight:700;color:var(--blue-900);font-size:13px;}

.filter-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:center;}
.filter-bar input,.filter-bar select{padding:10px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:13px;font-family:inherit;outline:none;color:var(--gray-800);transition:var(--transition);background:var(--white);}
.filter-bar input:focus,.filter-bar select:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px rgba(37,99,235,.1);}

.view-toggle{display:flex;gap:4px;margin-bottom:20px;background:var(--gray-100);padding:4px;border-radius:var(--radius);width:fit-content;}
.view-toggle button{padding:8px 16px;border:none;border-radius:8px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition);background:transparent;color:var(--gray-500);}
.view-toggle button.active{background:var(--white);color:var(--blue-600);box-shadow:var(--shadow-sm);}
.view-toggle button:hover:not(.active){color:var(--gray-700);}

.doc-download-btn{display:inline-flex;align-items:center;gap:8px;background:var(--blue-500);color:var(--white);padding:12px 20px;border-radius:var(--radius);font-size:13px;font-weight:700;margin-bottom:20px;transition:var(--transition);box-shadow:0 4px 12px rgba(37,99,235,.3);}
.doc-download-btn:hover{background:var(--blue-600);transform:translateY(-1px);box-shadow:0 6px 16px rgba(37,99,235,.4);}
.doc-download-btn svg{width:18px;height:18px;}

/* ── FOOTER ──────────────────────────── */
footer{background:var(--blue-900);color:rgba(255,255,255,.5);}
.footer-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding:60px 5% 50px;max-width:1400px;margin:0 auto;}
@media (max-width:1024px){.footer-main{grid-template-columns:1fr 1fr;gap:32px;}}
@media (max-width:600px){.footer-main{grid-template-columns:1fr;}}
.footer-col h5{color:var(--white);font-size:14px;font-weight:700;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-col a{display:block;color:rgba(255,255,255,.45);font-size:13px;margin-bottom:10px;transition:var(--transition);padding-left:0;}
.footer-col a:hover{color:var(--blue-300);padding-left:4px;}
.footer-col p{font-size:13px;line-height:1.7;color:rgba(255,255,255,.45);}
.footer-col p a{display:inline;margin:0;padding:0;color:var(--blue-300);}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding:20px 5%;display:flex;align-items:center;justify-content:space-between;font-size:12px;flex-wrap:wrap;gap:10px;max-width:1400px;margin:0 auto;}
.footer-bottom span{color:rgba(255,255,255,.3);}
.legalese{font-size:11px;color:rgba(255,255,255,.2);text-align:center;padding:14px 5%;border-top:1px solid rgba(255,255,255,.04);}

/* ── MODAL ───────────────────────────── */
.modal-overlay{position:fixed;inset:0;background:rgba(10,22,40,.6);backdrop-filter:blur(6px);z-index:9999;display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .3s ease;}
.modal-overlay.open{display:flex;opacity:1;}
.modal{background:var(--white);border-radius:var(--radius-xl);max-width:480px;width:100%;padding:40px;position:relative;box-shadow:var(--shadow-xl);transform:translateY(20px) scale(.97);transition:transform .3s ease;}
.modal-overlay.open .modal{transform:translateY(0) scale(1);}
.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;border:none;background:var(--gray-100);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);color:var(--gray-500);}
.modal-close:hover{background:var(--gray-200);color:var(--gray-800);}
.modal-close svg{width:18px;height:18px;}
.modal h2{font-size:22px;font-weight:900;color:var(--blue-900);margin-bottom:6px;}
.modal .modal-sub{font-size:14px;color:var(--gray-500);margin-bottom:24px;line-height:1.6;}
.modal-form{display:flex;flex-direction:column;gap:14px;}
.modal-form label{font-size:12px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;}
.modal-form input,.modal-form textarea{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:14px;font-family:inherit;outline:none;color:var(--gray-800);transition:var(--transition);background:var(--white);}
.modal-form input:focus,.modal-form textarea:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.modal-form textarea{resize:vertical;min-height:80px;}
.modal-form button{background:var(--blue-500);color:var(--white);border:none;padding:14px;border-radius:var(--radius);font-weight:700;font-size:15px;font-family:inherit;cursor:pointer;transition:var(--transition);box-shadow:0 4px 12px rgba(37,99,235,.3);margin-top:4px;}
.modal-form button:hover{background:var(--blue-600);transform:translateY(-1px);}
.modal-form .consent{font-size:11px;color:var(--gray-400);text-align:center;margin-top:4px;}
.modal-success{display:none;text-align:center;padding:20px 0;}
.modal-success svg{width:64px;height:64px;stroke:var(--green-500);margin-bottom:16px;}
.modal-success h3{font-size:20px;font-weight:800;color:var(--blue-900);margin-bottom:8px;}
.modal-success p{font-size:14px;color:var(--gray-500);}

/* ── SERVICE PAGES ───────────────────── */
.svc-hero{padding:60px 5%;background:linear-gradient(135deg,var(--blue-900),var(--blue-700));color:var(--white);position:relative;overflow:hidden;}
.svc-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(59,130,246,.2),transparent 50%);}
.svc-hero .container{position:relative;z-index:1;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.svc-hero-text .back-link{display:inline-flex;align-items:center;gap:6px;color:var(--blue-300);font-size:13px;font-weight:600;margin-bottom:20px;transition:var(--transition);}
.svc-hero-text .back-link:hover{color:var(--white);gap:8px;}
.svc-hero-text .back-link svg{width:16px;height:16px;}
.svc-hero-text h1{font-size:clamp(24px,3.5vw,42px);font-weight:900;margin-bottom:16px;line-height:1.15;}
.svc-hero-text p{color:rgba(255,255,255,.65);font-size:16px;line-height:1.8;margin-bottom:28px;}
.svc-hero-img{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl);max-height:360px;}
.svc-hero-img img{width:100%;height:100%;object-fit:cover;}
.svc-features{display:flex;gap:24px;flex-wrap:wrap;margin-top:8px;}
.svc-feature{display:flex;align-items:center;gap:8px;color:rgba(255,255,255,.8);font-size:13px;font-weight:600;}
.svc-feature svg{width:18px;height:18px;stroke:var(--blue-300);}

.svc-content{padding:60px 5%;}
.svc-content .container{max-width:1400px;margin:0 auto;}
.svc-content h2{font-size:clamp(20px,2.5vw,30px);font-weight:900;color:var(--blue-900);margin-bottom:24px;}

.programs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;margin-bottom:48px;}
.program-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;transition:var(--transition);position:relative;overflow:hidden;}
.program-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--blue-500),var(--blue-300));transform:scaleX(0);transition:transform .4s ease;transform-origin:left;}
.program-card:hover::before{transform:scaleX(1);}
.program-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.program-card h4{font-size:16px;font-weight:800;color:var(--blue-900);margin-bottom:8px;}
.program-card .hours{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--blue-500);background:var(--blue-50);padding:4px 10px;border-radius:6px;margin-bottom:10px;}
.program-card .hours svg{width:14px;height:14px;}
.program-card p{font-size:13px;color:var(--gray-500);line-height:1.7;}
.program-card .price{margin-top:12px;font-size:14px;font-weight:700;color:var(--blue-700);}

.svc-cta-row{background:var(--blue-50);border:1px solid var(--blue-200);border-radius:var(--radius-lg);padding:36px 40px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-top:40px;}
.svc-cta-row h3{font-size:20px;font-weight:800;color:var(--blue-900);}
.svc-cta-row p{font-size:14px;color:var(--gray-500);margin-top:4px;}
.svc-cta-row .btn-primary{flex-shrink:0;}

.svc-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin:32px 0;}
.svc-info-card{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius);padding:24px;text-align:center;}
.svc-info-card svg{width:32px;height:32px;stroke:var(--blue-500);margin-bottom:12px;}
.svc-info-card h4{font-size:15px;font-weight:800;color:var(--blue-900);margin-bottom:6px;}
.svc-info-card p{font-size:13px;color:var(--gray-500);line-height:1.6;}

@media(max-width:768px){
  .svc-hero .container{grid-template-columns:1fr;}
  .svc-hero-img{max-height:240px;}
  .svc-cta-row{flex-direction:column;text-align:center;}
}

/* ── PROGRAMS PAGE ───────────────────── */
.programs-hero{padding:50px 5%;background:linear-gradient(135deg,var(--blue-900),var(--blue-700));color:var(--white);position:relative;overflow:hidden;}
.programs-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 60% 40%,rgba(59,130,246,.2),transparent 50%);}
.programs-hero .container{position:relative;z-index:1;max-width:1400px;margin:0 auto;text-align:center;}
.programs-hero h1{font-size:clamp(24px,3vw,38px);font-weight:900;margin-bottom:10px;}
.programs-hero p{color:rgba(255,255,255,.6);font-size:15px;max-width:600px;margin:0 auto;}

.programs-filter-bar{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:32px 0 12px;padding:0 5%;}
.programs-filter-bar button{padding:8px 18px;border:2px solid var(--gray-200);border-radius:30px;background:var(--white);color:var(--gray-600);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:var(--transition);}
.programs-filter-bar button:hover{border-color:var(--blue-400);color:var(--blue-500);}
.programs-filter-bar button.active{background:var(--blue-500);border-color:var(--blue-500);color:var(--white);}

.prog-category{margin-bottom:40px;}
.prog-category h2{font-size:20px;font-weight:900;color:var(--blue-900);margin-bottom:16px;padding-bottom:10px;border-bottom:2px solid var(--blue-100);display:flex;align-items:center;gap:10px;}
.prog-category h2 svg{width:24px;height:24px;stroke:var(--blue-500);}
.prog-category .cat-count{font-size:12px;font-weight:700;color:var(--blue-500);background:var(--blue-50);padding:2px 10px;border-radius:20px;margin-left:auto;}

.prog-accordion{display:flex;flex-direction:column;gap:10px;}
.prog-item{border:1px solid var(--gray-200);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);background:var(--white);}
.prog-item:hover{border-color:var(--blue-300);}
.prog-item.open{border-color:var(--blue-400);box-shadow:var(--shadow-md);}
.prog-item-header{display:flex;align-items:center;gap:16px;padding:18px 24px;cursor:pointer;transition:var(--transition);user-select:none;}
.prog-item:hover .prog-item-header{background:var(--blue-50);}
.prog-item.open .prog-item-header{background:var(--blue-50);border-bottom:1px solid var(--blue-100);}
.prog-item-header .prog-title-wrap{flex:1;display:flex;flex-direction:column;gap:6px;min-width:0;}
.prog-item-header .prog-title{font-size:15px;font-weight:700;color:var(--blue-900);}
.prog-types{display:flex;flex-wrap:wrap;gap:6px;}
.prog-type-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.2px;white-space:nowrap;}
.prog-type-program{background:#dcfce7;color:#15803d;border:1px solid #86efac;}
.prog-type-qual{background:#fee2e2;color:#b91c1c;border:1px solid #fca5a5;}
.prog-type-retraining{background:#fef3c7;color:#a16207;border:1px solid #fcd34d;}
.prog-item-header .prog-hours{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:700;color:var(--blue-500);background:var(--blue-50);padding:4px 12px;border-radius:20px;white-space:nowrap;flex-shrink:0;}
.prog-item-header .prog-hours svg{width:14px;height:14px;}
.prog-item-header .prog-price{font-size:13px;font-weight:700;color:var(--blue-700);white-space:nowrap;flex-shrink:0;}
.prog-item-header .prog-chevron{width:20px;height:20px;stroke:var(--gray-400);flex-shrink:0;transition:transform .3s ease;}
.prog-item.open .prog-chevron{transform:rotate(180deg);stroke:var(--blue-500);}

.prog-item-body{max-height:0;overflow:hidden;transition:max-height .4s ease;}
.prog-item.open .prog-item-body{max-height:900px;}
.prog-item-content{padding:24px;display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.prog-detail{display:flex;gap:10px;font-size:13px;}
.prog-detail svg{width:18px;height:18px;stroke:var(--blue-500);flex-shrink:0;margin-top:1px;}
.prog-detail strong{display:block;font-size:11px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;}
.prog-detail span{color:var(--gray-700);line-height:1.6;}
.prog-desc{grid-column:1/-1;font-size:13px;color:var(--gray-600);line-height:1.7;border-top:1px solid var(--gray-100);padding-top:16px;margin-top:4px;}
.prog-actions{grid-column:1/-1;display:flex;gap:12px;flex-wrap:wrap;align-items:center;padding-top:8px;}
.prog-actions .btn-primary{padding:10px 24px;font-size:13px;}
/* PDF button */
.btn-pdf-link{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;font-size:13px;font-weight:600;color:var(--blue-600);border:1.5px solid var(--blue-200);border-radius:8px;text-decoration:none;transition:background .2s,border-color .2s;white-space:nowrap;}
.btn-pdf-link:hover{background:var(--blue-50);border-color:var(--blue-400);}
.btn-pdf-link svg{width:15px;height:15px;stroke:var(--blue-500);flex-shrink:0;}
/* Десктоп: ДЛЯ КОГО слева span 2 строки, ЦЕЛЬ+ФОРМА справа, ДОКУМЕНТ+ДЛИТЕЛЬНОСТЬ в 3й строке */
@media(min-width:769px){
  .prog-item-content .prog-detail:nth-child(1){grid-column:1;grid-row:1/span 2;align-self:start;}
  .prog-item-content .prog-detail:nth-child(2){grid-column:2;grid-row:1;}
  .prog-item-content .prog-detail:nth-child(3){grid-column:1;grid-row:3;}
  .prog-item-content .prog-detail:nth-child(4){grid-column:2;grid-row:2;}
  .prog-item-content .prog-detail:nth-child(5){grid-column:2;grid-row:3;}
}

@media(max-width:768px){
  .prog-item-content{grid-template-columns:1fr;}
  .prog-item-header{flex-wrap:wrap;gap:8px;padding:14px 16px;}
  .prog-item-header .prog-title{flex:none;width:100%;font-size:14px;}
  .prog-item-header .prog-hours{order:3;}
  .prog-item-header .prog-price{font-size:12px;}
  .prog-item-header .prog-chevron{margin-left:auto;}
}

/* ── STAFF PROFILE PAGE ─────────────── */
.staff-profile-hero{padding:60px 5% 40px;background:linear-gradient(135deg,var(--blue-900),var(--blue-700));color:var(--white);position:relative;overflow:hidden;}
.staff-profile-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 40%,rgba(59,130,246,.2),transparent 50%);}
.staff-profile-hero .container{position:relative;z-index:1;max-width:1100px;margin:0 auto;display:flex;gap:36px;align-items:center;}
.staff-profile-hero .sp-avatar{width:140px;height:140px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,.3);flex-shrink:0;}
.staff-profile-hero .sp-info h1{font-size:clamp(22px,3vw,34px);font-weight:900;margin-bottom:6px;}
.staff-profile-hero .sp-info .sp-pos{font-size:16px;opacity:.8;margin-bottom:10px;}
.staff-profile-hero .sp-tags{display:flex;gap:8px;flex-wrap:wrap;}
.staff-profile-hero .sp-tag{padding:4px 14px;background:rgba(255,255,255,.15);border-radius:20px;font-size:12px;font-weight:600;backdrop-filter:blur(6px);}
.sp-back{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.7);font-size:13px;font-weight:600;text-decoration:none;margin-bottom:18px;transition:var(--transition);}
.sp-back:hover{color:#fff;}
.sp-back svg{width:18px;height:18px;}
.sp-body{max-width:1100px;margin:0 auto;padding:40px 5%;}
.sp-section{margin-bottom:32px;}
.sp-section h2{font-size:18px;font-weight:800;color:var(--blue-900);margin-bottom:16px;display:flex;align-items:center;gap:10px;}
.sp-section h2 svg{width:22px;height:22px;stroke:var(--blue-500);}
.sp-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.sp-field{background:var(--gray-50);border-radius:12px;padding:16px 20px;}
.sp-field-label{font-size:11px;font-weight:700;color:var(--gray-400);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.sp-field-value{font-size:14px;color:var(--gray-800);line-height:1.6;}
.sp-disciplines{display:flex;flex-direction:column;gap:10px;}
.sp-disc-item{display:flex;align-items:flex-start;gap:10px;padding:12px 16px;background:var(--blue-50);border-radius:10px;border-left:3px solid var(--blue-400);}
.sp-disc-item svg{width:18px;height:18px;stroke:var(--blue-500);flex-shrink:0;margin-top:2px;}
.sp-disc-item span{font-size:14px;color:var(--gray-700);}
@media(max-width:768px){
  .staff-profile-hero .container{flex-direction:column;text-align:center;}
  .staff-profile-hero .sp-tags{justify-content:center;}
  .sp-grid{grid-template-columns:1fr;}
}

/* ── ABOUT PAGE ──────────────────────── */
.about-hero{padding:60px 5%;background:linear-gradient(135deg,var(--blue-900),var(--blue-700));color:var(--white);position:relative;overflow:hidden;}
.about-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 60%,rgba(59,130,246,.2),transparent 50%);}
.about-hero .container{position:relative;z-index:1;max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;}
.about-hero h1{font-size:clamp(26px,3.5vw,44px);font-weight:900;margin-bottom:16px;line-height:1.15;}
.about-hero p{color:rgba(255,255,255,.65);font-size:16px;line-height:1.8;}
.about-hero-img{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl);max-height:340px;}
.about-hero-img img{width:100%;height:100%;object-fit:cover;}

.about-mission{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:28px;margin:40px 0;}
.about-mission-card{background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:32px;transition:var(--transition);position:relative;overflow:hidden;}
.about-mission-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--blue-500),var(--blue-300));}
.about-mission-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px);}
.about-mission-card svg{width:36px;height:36px;stroke:var(--blue-500);margin-bottom:16px;}
.about-mission-card h4{font-size:17px;font-weight:800;color:var(--blue-900);margin-bottom:8px;}
.about-mission-card p{font-size:14px;color:var(--gray-500);line-height:1.7;}

.about-timeline{position:relative;padding-left:32px;margin:40px 0;}
.about-timeline::before{content:'';position:absolute;left:11px;top:0;bottom:0;width:2px;background:var(--blue-200);}
.timeline-item{position:relative;margin-bottom:28px;padding-left:24px;}
.timeline-item::before{content:'';position:absolute;left:-25px;top:4px;width:14px;height:14px;border-radius:50%;background:var(--blue-500);border:3px solid var(--blue-100);}
.timeline-item h4{font-size:15px;font-weight:800;color:var(--blue-900);margin-bottom:4px;}
.timeline-item .year{font-size:12px;font-weight:700;color:var(--blue-500);margin-bottom:4px;}
.timeline-item p{font-size:13px;color:var(--gray-500);line-height:1.6;}

.about-numbers{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin:40px 0;}
.about-num{text-align:center;padding:28px 16px;background:var(--blue-50);border-radius:var(--radius-lg);border:1px solid var(--blue-100);}
.about-num strong{display:block;font-size:36px;font-weight:900;color:var(--blue-500);margin-bottom:4px;}
.about-num span{font-size:13px;color:var(--gray-500);font-weight:500;}

.about-docs{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0;}

/* ── CONTACTS PAGE ───────────────────── */
.contacts-hero{padding:50px 5%;background:linear-gradient(135deg,var(--blue-900),var(--blue-700));color:var(--white);position:relative;overflow:hidden;}
.contacts-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(59,130,246,.2),transparent 50%);}
.contacts-hero .container{position:relative;z-index:1;max-width:1400px;margin:0 auto;text-align:center;}
.contacts-hero h1{font-size:clamp(24px,3vw,38px);font-weight:900;margin-bottom:10px;}
.contacts-hero p{color:rgba(255,255,255,.6);font-size:15px;}

.contacts-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin:40px 0;}
.contacts-info{display:flex;flex-direction:column;gap:20px;}
.contact-card{display:flex;gap:16px;align-items:flex-start;background:var(--white);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:24px;transition:var(--transition);}
.contact-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);}
.contact-card-icon{width:48px;height:48px;border-radius:var(--radius);background:var(--blue-50);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.contact-card-icon svg{width:22px;height:22px;stroke:var(--blue-500);}
.contact-card h4{font-size:14px;font-weight:800;color:var(--blue-900);margin-bottom:4px;}
.contact-card p{font-size:14px;color:var(--gray-500);line-height:1.6;}
.contact-card a{color:var(--blue-500);font-weight:600;transition:var(--transition);}
.contact-card a:hover{color:var(--blue-700);}

.contacts-map{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--gray-200);min-height:400px;box-shadow:var(--shadow);}
.contacts-map iframe{width:100%;height:100%;min-height:400px;border:none;}

.contacts-form-section{background:var(--gray-50);border:1px solid var(--gray-200);border-radius:var(--radius-lg);padding:36px;margin-top:40px;}
.contacts-form-section h3{font-size:20px;font-weight:900;color:var(--blue-900);margin-bottom:6px;}
.contacts-form-section>p{font-size:14px;color:var(--gray-500);margin-bottom:24px;}
.contacts-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.contacts-form-grid .full{grid-column:1/-1;}
.contacts-form-grid label{font-size:12px;font-weight:700;color:var(--gray-600);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:6px;}
.contacts-form-grid input,.contacts-form-grid textarea{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:var(--radius);font-size:14px;font-family:inherit;outline:none;color:var(--gray-800);transition:var(--transition);background:var(--white);}
.contacts-form-grid input:focus,.contacts-form-grid textarea:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.contacts-form-grid textarea{resize:vertical;min-height:100px;}
.contacts-form-grid button{background:var(--blue-500);color:var(--white);border:none;padding:14px 32px;border-radius:var(--radius);font-weight:700;font-size:15px;font-family:inherit;cursor:pointer;transition:var(--transition);box-shadow:0 4px 12px rgba(37,99,235,.3);}
.contacts-form-grid button:hover{background:var(--blue-600);transform:translateY(-1px);}

@media(max-width:768px){
  .about-hero .container{grid-template-columns:1fr;}
  .about-hero-img{max-height:240px;}
  .contacts-grid{grid-template-columns:1fr;}
  .contacts-form-grid{grid-template-columns:1fr;}
  .training-slider-window{padding:10px;border-radius:22px;}
  .training-slider-track{height:clamp(240px,62vw,420px);}
  .training-slide figcaption{left:12px;right:12px;bottom:12px;padding:12px 14px;font-size:13px;}
  .training-slider-btn{width:42px;height:42px;}
  .training-slider-prev{left:14px;}
  .training-slider-next{right:14px;}
}

/* ── RESPONSIVE ──────────────────────── */
@media(max-width:1024px){
  .hero-grid{grid-template-columns:1fr;text-align:center;}
  .hero p{margin-left:auto;margin-right:auto;}
  .hero-btns{justify-content:center;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero-visual{display:none;}
}
@media(max-width:900px){
  .sveden-layout{grid-template-columns:1fr;}
  .sveden-sidebar{display:flex;overflow-x:auto;padding:6px;gap:4px;-ms-overflow-style:none;scrollbar-width:none;}
  .sveden-sidebar::-webkit-scrollbar{display:none;}
  .sveden-sidebar a{white-space:nowrap;border-left:none;border-bottom:3px solid transparent;padding:10px 14px;border-radius:8px 8px 0 0;font-size:12px;}
  .sveden-sidebar a.active{border-left:none;border-bottom-color:var(--blue-400);}
  .sveden-content{padding:24px 20px;}
  .footer-main{grid-template-columns:1fr;}
  .services-grid{grid-template-columns:1fr;}
}
@media(max-width:1024px){
  .header-contacts{display:none;}
  .burger{display:block;}
  nav{position:fixed;top:60px;left:0;right:0;background:var(--blue-800);transform:translateY(-120%);transition:var(--transition);z-index:999;box-shadow:var(--shadow-lg);max-height:calc(100vh - 60px);overflow-y:auto;}
  nav.open{transform:translateY(0);}
  .nav-inner{flex-direction:column;padding:10px 0;}
  .nav-inner>a,.nav-inner>.nav-dropdown>a{padding:14px 24px;width:100%;border-bottom:1px solid rgba(255,255,255,.06);border-left:3px solid transparent;border-bottom-width:0;display:block;box-sizing:border-box;}
  .nav-inner>a:hover,.nav-inner>a.active,.nav-inner>.nav-dropdown>a:hover{border-bottom-color:transparent;border-left-color:var(--blue-400);}
  .nav-dropdown{display:block;width:100%;position:relative;}
  .nav-dropdown>a{position:relative;}
  .nav-dropdown>a::after{position:absolute;right:24px;top:50%;transform:translateY(-50%);transition:transform .2s ease;}
  .nav-dropdown.open>a::after{transform:translateY(-50%) rotate(180deg);}
  .dropdown-menu{
    display:none;position:static;min-width:100%;box-shadow:none;border-radius:0;
    border-top:1px solid rgba(255,255,255,.06);
    background:rgba(0,0,0,.25);
    max-height:none;overflow-y:visible;
  }
  .dropdown-menu a{
    padding:12px 20px 12px 48px;border-radius:0;
    color:rgba(255,255,255,.8);font-size:13px;
    border-bottom:1px solid rgba(255,255,255,.04);
    display:block;
  }
  .dropdown-menu a:hover{background:rgba(255,255,255,.08);color:#fff;padding-left:54px;}
  .nav-dropdown:hover .dropdown-menu{animation:none;}

  /* Mobile CTA buttons in burger menu */
  .nav-mobile-cta{display:flex;flex-direction:column;gap:10px;padding:16px 20px;border-top:1px solid rgba(255,255,255,.1);margin-top:8px;}
  .nav-cta-btn{display:flex !important;align-items:center;justify-content:center;gap:8px;padding:14px 20px !important;border-radius:10px !important;font-size:14px !important;font-weight:700 !important;border:none !important;border-left:none !important;width:100% !important;box-sizing:border-box;text-align:center;transition:transform .15s ease, box-shadow .15s ease;}
  .nav-cta-btn:hover{border-left:none !important;transform:translateY(-1px);}
  .nav-cta-primary{background:#16a34a !important;color:#fff !important;box-shadow:0 4px 12px rgba(22,163,74,.3);}
  .nav-cta-primary:hover{background:#15803d !important;box-shadow:0 6px 16px rgba(22,163,74,.4);}
  .nav-cta-secondary{background:var(--blue-500) !important;color:#fff !important;box-shadow:0 4px 12px rgba(59,130,246,.3);}
  .nav-cta-secondary:hover{background:var(--blue-600) !important;box-shadow:0 6px 16px rgba(59,130,246,.4);}
  .nav-cta-btn svg{flex-shrink:0;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .staff-grid{grid-template-columns:1fr;}
  .svc-hero .container{grid-template-columns:1fr;gap:24px;}
  .svc-hero{padding:40px 5%;}
  .svc-hero-img{max-height:200px;}
  .svc-content{padding:40px 5%;}
  .svc-cta-row{flex-direction:column;text-align:center;padding:28px 20px;}
  .svc-cta-row .btn-primary{width:100%;justify-content:center;}
  .programs-filter-bar{overflow-x:auto;-ms-overflow-style:none;scrollbar-width:none;flex-wrap:nowrap;justify-content:flex-start;padding:0 4%;}
  .programs-filter-bar::-webkit-scrollbar{display:none;}
  .programs-filter-bar button{flex-shrink:0;}
  .footer-bottom{flex-direction:column;text-align:center;gap:4px;}
  .footer-main{gap:24px;}
  .modal-box{margin:10px;max-width:calc(100vw - 20px);}
  .header-top{padding:10px 4%;gap:8px;}
  .logo{font-size:14px;min-width:0;flex:1;}
  .logo img,.logo svg{height:36px;transform:scale(1.4);transform-origin:left center;margin-left:4px;margin-right:14px;}
  .logo-badge{width:38px;height:38px;flex-shrink:0;}
  .logo-badge svg{width:22px;height:22px;}
  .logo-text{min-width:0;}
  .logo-text .name{font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
  .logo-text .sub{display:none;}
  .burger{flex-shrink:0;}
}
@media(max-width:480px){
  .section{padding:50px 4%;}
  .hero{padding:50px 4%;}
  .hero h1{font-size:26px;}
  .hero-stats{grid-template-columns:1fr 1fr;gap:10px;}
  .stat{padding:14px;}
  .info-table td:first-child{width:120px;font-size:12px;}
  .prog-item-header{padding:14px 16px;}
  .prog-title{font-size:13px;}
  .prog-hours,.prog-price{font-size:11px;}
  .svc-hero{padding:30px 4%;}
  .svc-hero-text h1{font-size:22px;}
  .sp-body{padding:24px 4%;}
}

/* ── MOBILE IMPROVEMENTS ──────────────────────────────────────────────── */
/* Эти стили дополнительно улучшают отображение на мобильных устройствах  */

/* Модальное окно на малых экранах */
@media(max-width:520px){
  .modal{padding:24px 20px;border-radius:var(--radius-lg);margin:10px;}
  .modal h2{font-size:18px;}
  .modal-form button{font-size:14px;padding:13px;}
}

/* CTA форма на мобильных */
@media(max-width:600px){
  .cta-form{flex-direction:column;}
  .cta-form input,.cta-form button{width:100%;}
  .cta{padding:50px 4%;}
}

/* Контакты — форма на мобильных */
@media(max-width:600px){
  .contacts-form-grid{grid-template-columns:1fr;}
  .contacts-form-grid .full{grid-column:1;}
  .contacts-grid{grid-template-columns:1fr;}
}

/* Таблица сведений — горизонтальная прокрутка */
@media(max-width:600px){
  .info-table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;}
  .info-table td:first-child{min-width:100px;}
}

/* Статистика на главной */
@media(max-width:400px){
  .hero-stats{grid-template-columns:1fr 1fr;}
  .stat strong{font-size:22px;}
  .stat span{font-size:10px;}
}

/* Аккордион программ — кнопка подачи заявки */
@media(max-width:480px){
  .prog-actions .btn-primary{width:100%;justify-content:center;font-size:13px;padding:10px 16px;}
  .prog-item.open .prog-item-body{max-height:none;}
}

/* Педсостав — профиль на мобильных */
@media(max-width:480px){
  .staff-profile-hero{padding:32px 4% 24px;}
  .staff-profile-hero .sp-avatar{width:100px;height:100px;}
}

/* Footer на мобильных */
@media(max-width:480px){
  .footer-main{padding:40px 4% 32px;gap:20px;}
  .footer-col h5{font-size:13px;}
  .legalese{font-size:10px;padding:10px 4%;}
}

/* Баннер услуг — более компактный на мобильных */
@media(max-width:480px){
  .svc-features{gap:12px;}
  .svc-feature{font-size:12px;}
  .section-head h2{font-size:22px;}
  .section-head p{font-size:14px;}
}

/* Шапка — лого на маленьких экранах */
@media(max-width:360px){
  .logo-text .name{font-size:13px;}
  .logo-text .sub{font-size:9px;}
  .logo-badge{width:40px;height:40px;}
}

/* Программы — фильтр-бар */
@media(max-width:480px){
  .programs-filter-bar button{padding:7px 14px;font-size:12px;}
  .prog-category h2{font-size:17px;}
}

/* О нас — страница */
@media(max-width:768px){
  .about-hero .container{grid-template-columns:1fr;gap:24px;}
  .about-hero-img{max-height:200px;}
  .about-timeline{padding-left:20px;}
}

/* Свежие заявки: уведомление успеха */
@media(max-width:480px){
  .modal-success h3{font-size:17px;}
}

/* ══════════════════════════════════════════════════════════════════
   ВЕРСИЯ ДЛЯ СЛАБОВИДЯЩИХ (п.14 Приказа Рособрнадзора №1493)
   ══════════════════════════════════════════════════════════════════ */

/* Тонкая верхняя полоса с кнопкой "Для слабовидящих" */
.topline{background:var(--gray-100,#f3f4f6);border-bottom:1px solid var(--gray-200,#e5e7eb);}
.topline-inner{max-width:1400px;margin:0 auto;padding:0 5%;display:flex;justify-content:flex-end;align-items:center;min-height:32px;}
.a11y-toggle{display:inline-flex;align-items:center;gap:6px;background:transparent;color:var(--gray-600,#4b5563);border:none;padding:6px 10px;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;letter-spacing:.2px;transition:color .15s;}
.a11y-toggle:hover{color:var(--blue-600,#2563eb);}
.a11y-toggle svg{flex-shrink:0;opacity:.75;}
.a11y-toggle:hover svg{opacity:1;}
@media(max-width:600px){
  .topline-inner{padding:0 4%;min-height:28px;}
  .a11y-toggle{font-size:11px;padding:4px 6px;}
}

/* Панель управления — скрыта по умолчанию, показывается при a11y-on */
.a11y-bar{display:none;background:#0b2242;color:#fff;padding:8px 16px;border-bottom:3px solid #ffcc00;position:relative;z-index:1001;}
body.a11y-on .a11y-bar{display:block;}
.a11y-bar-inner{max-width:1400px;margin:0 auto;display:flex;flex-wrap:wrap;gap:8px 16px;align-items:center;}
.a11y-group{display:flex;align-items:center;gap:4px;flex-wrap:wrap;}
.a11y-lbl{font-size:12px;font-weight:700;margin-right:2px;opacity:.9;}
.a11y-bar button{background:#fff;color:#0b2242;border:2px solid transparent;padding:4px 10px;border-radius:5px;cursor:pointer;font-weight:700;font-size:12px;font-family:inherit;transition:border-color .2s;min-width:30px;line-height:1.2;}
.a11y-bar button:hover{border-color:#ffcc00;}
.a11y-bar button.active{border-color:#ffcc00;outline:2px solid #ffcc00;}
.a11y-off-btn{margin-left:auto;background:#ffcc00 !important;color:#0b2242 !important;font-weight:800 !important;padding:6px 14px !important;font-size:13px !important;}

/* Скрываем обычный toggle-кнопку когда a11y включена (уже в панели есть выход) */
body.a11y-on .a11y-toggle{display:none;}

/* ── Базовые перезаписи режима для слабовидящих ── */
body.a11y-on{line-height:1.8;}
body.a11y-on *{animation:none !important;transition:none !important;text-shadow:none !important;box-shadow:none !important;letter-spacing:normal;}
body.a11y-on .hero::before,
body.a11y-on .hero-floating-card,
body.a11y-on .hero-badge,
body.a11y-on .service-card-img .overlay,
body.a11y-on .service-card-img .card-icon,
body.a11y-on .staff-profile-hero::before,
body.a11y-on .sveden-page-header::before{display:none !important;}

/* Размер шрифта */
body.a11y-size-s{font-size:16px;}
body.a11y-size-m{font-size:20px;}
body.a11y-size-l{font-size:24px;}
body.a11y-on h1{font-size:1.8em !important;line-height:1.2 !important;letter-spacing:normal !important;}
body.a11y-on h2{font-size:1.5em !important;line-height:1.3 !important;}
body.a11y-on h3{font-size:1.3em !important;}
body.a11y-on h4,body.a11y-on h5{font-size:1.1em !important;}
body.a11y-on p,body.a11y-on li,body.a11y-on td,body.a11y-on a,body.a11y-on span,body.a11y-on div{font-size:1em;}

/* Шрифт */
body.a11y-font-sans,body.a11y-font-sans *{font-family:Arial,Helvetica,sans-serif !important;}
body.a11y-font-serif,body.a11y-font-serif *{font-family:Georgia,'Times New Roman',serif !important;}

/* Межбуквенный интервал */
body.a11y-spacing-n{letter-spacing:normal;}
body.a11y-spacing-m,body.a11y-spacing-m *{letter-spacing:.08em !important;}
body.a11y-spacing-l,body.a11y-spacing-l *{letter-spacing:.15em !important;word-spacing:.2em !important;}

/* Цветовые схемы */
body.a11y-theme-bw,body.a11y-theme-bw header,body.a11y-theme-bw nav,body.a11y-theme-bw footer,body.a11y-theme-bw .hero,body.a11y-theme-bw .section,body.a11y-theme-bw .cta,body.a11y-theme-bw .page,body.a11y-theme-bw .modal-box,body.a11y-theme-bw .service-card,body.a11y-theme-bw .sveden-layout,body.a11y-theme-bw .sveden-sidebar,body.a11y-theme-bw .sveden-content,body.a11y-theme-bw .sveden-page-header,body.a11y-theme-bw .staff-profile-hero,body.a11y-theme-bw .svc-hero,body.a11y-theme-bw .about-hero,body.a11y-theme-bw .contacts-hero{background:#fff !important;color:#000 !important;}
body.a11y-theme-bw *{background-color:transparent !important;color:#000 !important;border-color:#000 !important;}
body.a11y-theme-bw a{color:#000 !important;text-decoration:underline !important;}
body.a11y-theme-bw button,body.a11y-theme-bw .btn-primary,body.a11y-theme-bw .btn-outline,body.a11y-theme-bw .btn-consult{background:#fff !important;color:#000 !important;border:2px solid #000 !important;}

body.a11y-theme-wb,body.a11y-theme-wb header,body.a11y-theme-wb nav,body.a11y-theme-wb footer,body.a11y-theme-wb .hero,body.a11y-theme-wb .section,body.a11y-theme-wb .cta,body.a11y-theme-wb .page,body.a11y-theme-wb .modal-box,body.a11y-theme-wb .service-card,body.a11y-theme-wb .sveden-layout,body.a11y-theme-wb .sveden-sidebar,body.a11y-theme-wb .sveden-content,body.a11y-theme-wb .sveden-page-header,body.a11y-theme-wb .staff-profile-hero,body.a11y-theme-wb .svc-hero,body.a11y-theme-wb .about-hero,body.a11y-theme-wb .contacts-hero{background:#000 !important;color:#fff !important;}
body.a11y-theme-wb *{background-color:transparent !important;color:#fff !important;border-color:#fff !important;}
body.a11y-theme-wb a{color:#ffcc00 !important;text-decoration:underline !important;}
body.a11y-theme-wb button,body.a11y-theme-wb .btn-primary,body.a11y-theme-wb .btn-outline,body.a11y-theme-wb .btn-consult{background:#000 !important;color:#fff !important;border:2px solid #fff !important;}

body.a11y-theme-bb,body.a11y-theme-bb header,body.a11y-theme-bb nav,body.a11y-theme-bb footer,body.a11y-theme-bb .hero,body.a11y-theme-bb .section,body.a11y-theme-bb .cta,body.a11y-theme-bb .page,body.a11y-theme-bb .modal-box,body.a11y-theme-bb .service-card,body.a11y-theme-bb .sveden-layout,body.a11y-theme-bb .sveden-sidebar,body.a11y-theme-bb .sveden-content,body.a11y-theme-bb .sveden-page-header,body.a11y-theme-bb .staff-profile-hero,body.a11y-theme-bb .svc-hero,body.a11y-theme-bb .about-hero,body.a11y-theme-bb .contacts-hero{background:#9dd1ff !important;color:#063462 !important;}
body.a11y-theme-bb *{background-color:transparent !important;color:#063462 !important;border-color:#063462 !important;}
body.a11y-theme-bb a{color:#063462 !important;text-decoration:underline !important;font-weight:700 !important;}
body.a11y-theme-bb button,body.a11y-theme-bb .btn-primary,body.a11y-theme-bb .btn-outline,body.a11y-theme-bb .btn-consult{background:#9dd1ff !important;color:#063462 !important;border:2px solid #063462 !important;}

body.a11y-theme-bg,body.a11y-theme-bg header,body.a11y-theme-bg nav,body.a11y-theme-bg footer,body.a11y-theme-bg .hero,body.a11y-theme-bg .section,body.a11y-theme-bg .cta,body.a11y-theme-bg .page,body.a11y-theme-bg .modal-box,body.a11y-theme-bg .service-card,body.a11y-theme-bg .sveden-layout,body.a11y-theme-bg .sveden-sidebar,body.a11y-theme-bg .sveden-content,body.a11y-theme-bg .sveden-page-header,body.a11y-theme-bg .staff-profile-hero,body.a11y-theme-bg .svc-hero,body.a11y-theme-bg .about-hero,body.a11y-theme-bg .contacts-hero{background:#3b2f2f !important;color:#a8d08d !important;}
body.a11y-theme-bg *{background-color:transparent !important;color:#a8d08d !important;border-color:#a8d08d !important;}
body.a11y-theme-bg a{color:#ffd966 !important;text-decoration:underline !important;}
body.a11y-theme-bg button,body.a11y-theme-bg .btn-primary,body.a11y-theme-bg .btn-outline,body.a11y-theme-bg .btn-consult{background:#3b2f2f !important;color:#a8d08d !important;border:2px solid #a8d08d !important;}

/* Панель A11Y в режиме должна сохранять свой контраст */
body.a11y-on .a11y-bar,body.a11y-on .a11y-bar *{background:#0b2242 !important;color:#fff !important;border-color:#ffcc00 !important;}
body.a11y-on .a11y-bar button{background:#fff !important;color:#0b2242 !important;}
body.a11y-on .a11y-bar button.active{border-color:#ffcc00 !important;outline:2px solid #ffcc00 !important;}
body.a11y-on .a11y-off-btn{background:#ffcc00 !important;color:#0b2242 !important;}

/* Скрытие изображений */
body.a11y-img-off img,body.a11y-img-off svg:not(.a11y-keep),body.a11y-img-off .hero-img-wrapper,body.a11y-img-off .service-card-img,body.a11y-img-off .svc-hero-img,body.a11y-img-off .about-hero-img,body.a11y-img-off .contacts-map,body.a11y-img-off .hero-visual{display:none !important;}
body.a11y-img-off .logo-badge{display:none !important;}

/* Фокус для клавиатурной навигации */
body.a11y-on a:focus,body.a11y-on button:focus,body.a11y-on input:focus,body.a11y-on textarea:focus,body.a11y-on select:focus{outline:3px solid #ffcc00 !important;outline-offset:2px;}

/* ── Фиксы для шапки и меню в режиме слабовидящих ── */
/* Дроп-меню: непрозрачный фон, плотный z-index, чтобы не сливалось с контентом */
body.a11y-on .dropdown-menu{position:absolute !important;z-index:9999 !important;min-width:340px !important;padding:6px 0 !important;}
body.a11y-theme-bw .dropdown-menu,body.a11y-theme-bw .dropdown-menu *{background:#fff !important;color:#000 !important;}
body.a11y-theme-wb .dropdown-menu,body.a11y-theme-wb .dropdown-menu *{background:#000 !important;color:#fff !important;}
body.a11y-theme-bb .dropdown-menu,body.a11y-theme-bb .dropdown-menu *{background:#9dd1ff !important;color:#063462 !important;}
body.a11y-theme-bg .dropdown-menu,body.a11y-theme-bg .dropdown-menu *{background:#3b2f2f !important;color:#a8d08d !important;}
body.a11y-on .dropdown-menu a{display:block !important;padding:10px 18px !important;border-bottom:1px solid currentColor !important;text-decoration:none !important;}
body.a11y-on .dropdown-menu a:last-child{border-bottom:none !important;}
body.a11y-on .dropdown-menu a:hover{text-decoration:underline !important;}

/* Шапка/навигация: убираем подчёркивание у пунктов меню верхнего уровня (визуально каша) */
body.a11y-on .nav-inner>a,body.a11y-on .nav-inner>.nav-dropdown>a,
body.a11y-on .header-contacts a,body.a11y-on .logo,body.a11y-on .btn-consult{text-decoration:none !important;}
body.a11y-on .nav-inner>a:hover,body.a11y-on .nav-inner>.nav-dropdown>a:hover,body.a11y-on .nav-inner>a.active{text-decoration:underline !important;}

/* Чтобы фон шапки оставался видимым, не сливался */
body.a11y-theme-bw header,body.a11y-theme-bw nav{background:#fff !important;border-bottom:2px solid #000 !important;}
body.a11y-theme-wb header,body.a11y-theme-wb nav{background:#000 !important;border-bottom:2px solid #fff !important;}
body.a11y-theme-bb header,body.a11y-theme-bb nav{background:#9dd1ff !important;border-bottom:2px solid #063462 !important;}
body.a11y-theme-bg header,body.a11y-theme-bg nav{background:#3b2f2f !important;border-bottom:2px solid #a8d08d !important;}

/* ── Полная перестройка шапки и hero в режиме для слабовидящих ── */
/* Шапка: всё вертикально, никаких поплывших телефонов */
body.a11y-on header{padding:8px 16px !important;}
body.a11y-on .header-top{display:flex !important;flex-direction:column !important;align-items:flex-start !important;gap:14px !important;max-width:none !important;padding:0 !important;}
body.a11y-on .logo{margin:0 !important;}
body.a11y-on .logo-img{max-width:280px !important;width:auto !important;height:auto !important;}
body.a11y-on .header-contacts{display:flex !important;flex-direction:column !important;align-items:stretch !important;gap:12px !important;width:100% !important;margin:0 !important;}
body.a11y-on .contact-item{padding:8px 0 !important;text-align:left !important;border-bottom:1px solid currentColor !important;}
body.a11y-on .contact-item strong{display:block !important;font-size:1.1em !important;font-weight:800 !important;margin-bottom:2px !important;}
body.a11y-on .contact-item span{display:block !important;font-size:.85em !important;opacity:.85 !important;}
body.a11y-on .btn-consult{width:100% !important;display:block !important;text-align:center !important;padding:14px 16px !important;font-size:1em !important;font-weight:700 !important;border-radius:8px !important;line-height:1.3 !important;white-space:normal !important;}
/* Бургер не нужен — меню всегда развёрнуто */
body.a11y-on .burger{display:none !important;}

/* Основная навигация: вертикальная, подменю работает по клику (как и в обычном режиме) */
body.a11y-on #main-nav{position:static !important;transform:none !important;display:block !important;width:100% !important;background:transparent !important;padding:0 !important;height:auto !important;box-shadow:none !important;}
body.a11y-on .nav-inner{display:flex !important;flex-direction:column !important;align-items:stretch !important;justify-content:flex-start !important;gap:0 !important;width:100% !important;padding:0 !important;}
body.a11y-on .nav-inner > *{align-self:stretch !important;flex-shrink:0 !important;}
body.a11y-on .nav-inner > a,
body.a11y-on .nav-inner > .nav-dropdown > a{display:block !important;padding:12px 16px !important;border-bottom:1px solid currentColor !important;font-size:1em !important;font-weight:700 !important;text-align:left !important;width:100% !important;box-sizing:border-box !important;}
body.a11y-on .nav-dropdown{position:static !important;width:100% !important;display:block !important;}
/* Подменю по умолчанию свёрнуто; раскрывается по клику (.open) или hover */
body.a11y-on .dropdown-menu{position:static !important;display:none !important;box-shadow:none !important;background:transparent !important;border:none !important;width:100% !important;min-width:0 !important;padding:0 0 8px 24px !important;}
body.a11y-on .nav-dropdown.open .dropdown-menu,
body.a11y-on .nav-dropdown:hover .dropdown-menu{display:block !important;}
body.a11y-on .dropdown-menu a{padding:10px 12px !important;font-size:.95em !important;border-bottom:1px solid currentColor !important;text-align:left !important;}

/* Скрываем плавающую/боковую кнопку «Версия для слабовидящих» в самом меню (когда a11y уже активен) */
body.a11y-on .nav-a11y-btn,
body.a11y-on .nav-cta-btn{display:none !important;}

/* Активный пункт меню — фон, а не центрирование */
body.a11y-on .nav-inner > a.active,
body.a11y-on .nav-inner > .nav-dropdown > a.active{background:rgba(0,0,0,.06) !important;text-decoration:underline !important;}
body.a11y-theme-wb .nav-inner > a.active{background:rgba(255,255,255,.12) !important;}

/* Гарантия скролла страницы в a11y режиме (на случай если что-то заблокировало) */
body.a11y-on,html{overflow-y:auto !important;overflow-x:hidden !important;height:auto !important;}

/* Hero: одна колонка, без декора */
body.a11y-on .hero{padding:24px 16px !important;background:transparent !important;}
/* Убираем градиент-заливку текста (-webkit-text-fill-color делает h1 синим/невидимым в a11y) */
body.a11y-on h1,
body.a11y-on h1 *,
body.a11y-on h2,
body.a11y-on h2 *,
body.a11y-on h3,
body.a11y-on h3 *,
body.a11y-on .hero p,
body.a11y-on .hero p *{
  -webkit-text-fill-color:currentColor !important;
  background-image:none !important;
  background:transparent !important;
  -webkit-background-clip:initial !important;
  background-clip:initial !important;
}
body.a11y-on .hero-inner{display:flex !important;flex-direction:column !important;gap:20px !important;max-width:none !important;padding:0 !important;}
body.a11y-on .hero-content{max-width:none !important;text-align:left !important;}
body.a11y-on .hero-visual,body.a11y-on .hero-img-wrapper{margin-top:16px !important;width:100% !important;}
body.a11y-on .hero-visual img,body.a11y-on .hero-img-wrapper img{width:100% !important;height:auto !important;max-height:300px !important;object-fit:cover !important;border-radius:0 !important;}
body.a11y-on .hero-btns,body.a11y-on .hero-cta{display:flex !important;flex-direction:column !important;gap:12px !important;align-items:stretch !important;}
body.a11y-on .hero-btns a,body.a11y-on .hero-btns button,
body.a11y-on .hero-cta a,body.a11y-on .hero-cta button{width:100% !important;display:block !important;text-align:center !important;padding:14px 16px !important;font-size:1em !important;white-space:normal !important;}
body.a11y-on .hero-stats,body.a11y-on .stats-grid,body.a11y-on .service-hero-stats{display:grid !important;grid-template-columns:1fr 1fr !important;gap:10px !important;}
body.a11y-on .hero-stats > *,body.a11y-on .stats-grid > *,body.a11y-on .service-hero-stats > *{padding:12px !important;text-align:center !important;border:2px solid currentColor !important;border-radius:6px !important;}

/* Контент: все блоки в одну колонку */
body.a11y-on .container{max-width:none !important;padding:0 16px !important;}
body.a11y-on .services-grid,
body.a11y-on .directions-grid,
body.a11y-on .adv-grid,
body.a11y-on .values-grid,
body.a11y-on .timeline,
body.a11y-on .staff-grid,
body.a11y-on .feature-grid{display:flex !important;flex-direction:column !important;gap:16px !important;}

/* Кнопки везде растягиваем для удобства */
body.a11y-on .btn-primary,
body.a11y-on .btn-outline{display:block !important;width:100% !important;text-align:center !important;padding:14px 18px !important;white-space:normal !important;line-height:1.3 !important;}

/* Скрываем декор который только усложняет */
body.a11y-on .hero-floating-card,
body.a11y-on .hero-badge,
body.a11y-on .card-icon,
body.a11y-on .direction-icon,
body.a11y-on .adv-icon,
body.a11y-on .service-card-img .overlay{display:none !important;}

/* Скрываем кнопку «Версия для слабовидящих» когда режим уже включён */
body.a11y-on .a11y-toggle{display:none !important;}

/* Картинки сервисов делаем компактнее */
body.a11y-on .service-card-img,
body.a11y-on .direction-card .service-card-img{max-height:200px !important;overflow:hidden !important;}

/* На десктопе расширяем хедер чтобы не было совсем уж узко (читать удобнее) */
@media (min-width:768px){
  body.a11y-on .header-top,
  body.a11y-on .nav-inner,
  body.a11y-on .container{max-width:900px !important;margin:0 auto !important;}
}

/* ─── 4 НАПРАВЛЕНИЯ (home) ─────────────────────────── */
.section-light{background:var(--gray-50);}
.directions-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-top:32px;}
.edu-consult-btn{display:inline-flex;align-items:center;gap:6px;color:var(--blue-600);font-weight:700;font-size:13px;text-decoration:none;white-space:nowrap;transition:color .2s;}
.edu-consult-btn:hover{color:var(--blue-700);text-decoration:underline;}

/* ─── Кнопка «Наверх» — фикс. позиция, появляется при прокрутке ─── */
#back-to-top{position:fixed;right:20px;bottom:20px;width:48px;height:48px;border-radius:50%;border:none;background:var(--blue-600,#2563eb);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 6px 20px -4px rgba(37,99,235,.45),0 2px 6px rgba(15,23,42,.15);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .25s ease,transform .25s ease,background .2s,visibility .25s;z-index:998;}
#back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0);}
#back-to-top:hover{background:var(--blue-700,#1d4ed8);}
#back-to-top:active{transform:translateY(0) scale(.95);}
#back-to-top svg{width:22px;height:22px;}
@media (max-width:600px){#back-to-top{right:14px;bottom:14px;width:44px;height:44px;}#back-to-top svg{width:20px;height:20px;}}
/* В a11y режиме делаем побольше и контрастнее */
body.a11y-on #back-to-top{width:56px;height:56px;border:3px solid currentColor;}
body.a11y-theme-bw #back-to-top{background:#fff !important;color:#000 !important;border-color:#000 !important;}
body.a11y-theme-wb #back-to-top{background:#000 !important;color:#fff !important;border-color:#fff !important;}
body.a11y-theme-bb #back-to-top{background:#9dd1ff !important;color:#063462 !important;border-color:#063462 !important;}
body.a11y-theme-bg #back-to-top{background:#3b2f2f !important;color:#a8d08d !important;border-color:#a8d08d !important;}

/* ─── Кастомный селект (для модалки заявки) ─── */
.custom-select{position:relative;width:100%;}
/* Используем повышенную специфичность чтобы перебить .modal-form button */
.modal-form .cs-trigger,
.cs-trigger{width:100%;padding:12px 40px 12px 14px;border:2px solid var(--gray-200);border-radius:10px;font-size:14px;font-family:inherit;background:#fff !important;color:#1e293b !important;cursor:pointer;text-align:left;display:flex;align-items:center;justify-content:space-between;gap:10px;transition:border-color .2s;box-shadow:none !important;margin-top:0 !important;font-weight:normal !important;}
.modal-form .cs-trigger:hover,
.cs-trigger:hover{border-color:var(--blue-300);}
.modal-form .cs-trigger:focus,
.cs-trigger:focus{outline:none;border-color:var(--blue-500);box-shadow:0 0 0 3px rgba(37,99,235,.1) !important;}
.cs-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#1e293b;}
.cs-text.cs-placeholder{color:#94a3b8;}
.cs-arrow{width:18px;height:18px;flex-shrink:0;color:#64748b;transition:transform .2s;}
.custom-select.open .cs-arrow{transform:rotate(180deg);}
.cs-panel{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#fff;border:1px solid var(--gray-200);border-radius:10px;box-shadow:0 12px 32px -8px rgba(15,32,66,.18);max-height:360px;display:none;flex-direction:column;z-index:100;overflow:hidden;}
.custom-select.open .cs-panel{display:flex;}
.cs-search{padding:10px;border-bottom:1px solid var(--gray-100);display:flex;align-items:center;gap:8px;}
.cs-search svg{width:16px;height:16px;color:#94a3b8;flex-shrink:0;margin-left:6px;}
.cs-search-input{flex:1;border:none;outline:none;font-size:14px;font-family:inherit;color:#1e293b;background:transparent;padding:4px 0;}
.cs-search-input::placeholder{color:#94a3b8;}
.cs-list{flex:1;overflow-y:auto;padding:6px;}
.cs-group{font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--blue-600);padding:10px 12px 6px;}
.cs-option{padding:9px 12px;border-radius:6px;cursor:pointer;font-size:14px;line-height:1.4;color:#334155;transition:background .15s;word-break:break-word;}
.cs-option:hover{background:var(--blue-50);color:var(--blue-700);}
.cs-option.selected{background:var(--blue-100);color:var(--blue-700);font-weight:600;}
.cs-empty{padding:20px;text-align:center;color:#94a3b8;font-size:13px;}
.cs-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:24px;color:#64748b;font-size:13px;}
.cs-spinner{width:16px;height:16px;border:2px solid #e2e8f0;border-top-color:var(--blue-500);border-radius:50%;animation:cs-spin .8s linear infinite;}
@keyframes cs-spin{to{transform:rotate(360deg);}}
.info-table.edu-table th,
.info-table.edu-table td{text-align:center;vertical-align:middle;}
.info-table.edu-table td:first-child{text-align:center;}
.direction-card{background:#fff;border:1px solid var(--gray-200);border-radius:16px;padding:28px 24px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:14px;transition:all .25s ease;position:relative;overflow:hidden;}
.direction-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--blue-500);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;}
.direction-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px -20px rgba(37,99,235,.25);border-color:var(--blue-300);}
.direction-card:hover::before{transform:scaleX(1);}
.direction-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;}
.direction-icon svg{width:28px;height:28px;}
.direction-icon-blue{background:#dbeafe;color:#1d4ed8;}
.direction-icon-green{background:#d1fae5;color:#047857;}
.direction-icon-orange{background:#fed7aa;color:#c2410c;}
.direction-icon-purple{background:#ede9fe;color:#6d28d9;}
.direction-tag{display:inline-block;padding:4px 10px;background:var(--gray-100);color:var(--gray-700);font-size:12px;font-weight:700;border-radius:999px;width:fit-content;}
.direction-card h3{font-size:19px;font-weight:800;color:var(--blue-800);line-height:1.3;margin:0;}
.direction-card > p{font-size:14px;color:var(--gray-600);line-height:1.55;margin:0;}
.direction-bullets{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--gray-600);margin-top:auto;}
.direction-link{margin-top:10px;color:var(--blue-500);font-weight:700;font-size:14px;}
@media (max-width:1024px){.directions-grid,.directions-grid[style]{grid-template-columns:repeat(2,1fr) !important;}}
@media (max-width:600px){.directions-grid,.directions-grid[style]{grid-template-columns:1fr !important;}}

/* ─── СТРАНИЦЫ УСЛУГ: тарифы ─────────────────────────── */
.tariff-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin:32px 0;}
.tariff-card{background:#fff;border:2px solid var(--gray-200);border-radius:16px;padding:28px 24px;display:flex;flex-direction:column;gap:14px;transition:all .25s;}
.tariff-card:hover{border-color:var(--blue-400);box-shadow:0 16px 32px -16px rgba(37,99,235,.2);}
.tariff-card.featured{border-color:var(--blue-500);position:relative;}
.tariff-card.featured::before{content:'Популярный';position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--blue-500);color:#fff;font-size:11px;font-weight:700;padding:4px 12px;border-radius:999px;letter-spacing:.5px;}
.tariff-head{display:flex;flex-direction:column;gap:4px;padding-bottom:16px;border-bottom:1px solid var(--gray-200);}
.tariff-name{font-size:14px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:1px;}
.tariff-title{font-size:22px;font-weight:800;color:var(--blue-800);}
.tariff-price{display:flex;align-items:baseline;gap:6px;}
.tariff-price strong{font-size:30px;font-weight:800;color:var(--blue-600);}
.tariff-price span{font-size:13px;color:var(--gray-500);}
.tariff-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px;font-size:14px;color:var(--gray-700);flex:1;}
.tariff-list li{display:flex;gap:10px;align-items:flex-start;line-height:1.45;}
.tariff-list li::before{content:'';width:18px;height:18px;flex-shrink:0;background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%232563eb' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/contain no-repeat;margin-top:2px;}
.tariff-btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;background:var(--blue-500);color:#fff;font-weight:700;border-radius:10px;text-decoration:none;transition:background .2s;cursor:pointer;border:none;font-size:14px;}
.tariff-btn:hover{background:var(--blue-600);}
.tariff-btn-outline{background:transparent;color:var(--blue-500);border:2px solid var(--blue-200);}
.tariff-btn-outline:hover{background:var(--blue-50);border-color:var(--blue-500);color:var(--blue-500);}

/* ─── FAQ ─────────────────────────── */
.faq-list{max-width:820px;margin:32px auto 0;display:flex;flex-direction:column;gap:12px;}
.faq-item{background:#fff;border:1px solid var(--gray-200);border-radius:12px;overflow:hidden;}
.faq-question{padding:18px 22px;font-weight:700;color:var(--blue-800);cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:16px;}
.faq-question::after{content:'+';font-size:22px;color:var(--blue-500);font-weight:400;transition:transform .2s;}
.faq-item.open .faq-question::after{transform:rotate(45deg);}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .3s ease,padding .3s ease;padding:0 22px;color:var(--gray-600);line-height:1.6;font-size:15px;}
.faq-item.open .faq-answer{max-height:600px;padding:0 22px 20px;}

/* ─── Service page hero ─────────────────────────── */
.service-hero{background:linear-gradient(135deg,var(--blue-50),#fff);padding:56px 0 40px;border-bottom:1px solid var(--gray-200);}
.service-hero .btn-outline{border-color:var(--blue-400);color:var(--blue-600);background:rgba(255,255,255,.7);}
.service-hero .btn-outline:hover{border-color:var(--blue-600);color:var(--white);background:var(--blue-500);}
.service-hero .container{max-width:1400px;margin:0 auto;padding:0 5%;display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center;}
.service-hero h1{font-size:38px;font-weight:800;color:var(--blue-800);line-height:1.15;margin:16px 0;}
.service-hero .lead{font-size:17px;color:var(--gray-600);line-height:1.6;margin-bottom:24px;}
.service-hero-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 14px;background:var(--blue-100);color:var(--blue-700);font-size:13px;font-weight:700;border-radius:999px;width:fit-content;}
.service-hero-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;background:#fff;padding:24px;border-radius:16px;box-shadow:0 20px 40px -20px rgba(0,0,0,.1);border:1px solid var(--gray-200);}
.service-hero-stats .sh-stat{text-align:center;}
.service-hero-stats .sh-stat strong{display:block;font-size:26px;font-weight:800;color:var(--blue-600);white-space:nowrap;}
.service-hero-stats .sh-stat span{font-size:12px;color:var(--gray-500);}
@media (max-width:1024px){.service-hero .container{grid-template-columns:1fr;}.service-hero h1{font-size:28px;}.service-hero-stats{grid-template-columns:repeat(2,1fr);}}
@media (max-width:600px){.service-hero-stats .sh-stat strong{font-size:20px;white-space:normal;}.service-hero-stats{padding:16px;gap:10px;}.service-hero-stats .sh-stat span{font-size:11px;}}

/* ── Таблица сравнения на моб. ── */
@media (max-width:600px){.compare-table{font-size:12px !important;}.compare-table th,.compare-table td{padding:8px !important;}}

/* ── info-table на моб. более читаема ── */
@media (max-width:600px){.info-table td:first-child{width:auto !important;font-size:12px !important;padding:10px 12px !important;}.info-table td{padding:10px 12px !important;font-size:13px;line-height:1.45;}}

/* ── nav-inner: убрать «прыгающие» бордюры между пунктами на моб. ── */
@media (max-width:1024px){
  .nav-inner a{border-left:3px solid transparent;}
  .nav-inner>a.active{border-left-color:var(--blue-400);background:rgba(255,255,255,.05);}
  .nav-inner>.nav-dropdown>.dropdown-trigger::after{margin-left:auto;}
  .nav-inner>.nav-dropdown>.dropdown-trigger{display:flex;align-items:center;}
}

/* ── Подсказки в сравнительной таблице ──────────────────── */
.tt-info{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#dbeafe;color:#1e40af;font-size:11px;font-weight:800;cursor:pointer;margin-left:6px;flex-shrink:0;border:none;font-family:inherit;transition:.15s;vertical-align:middle;}
.tt-info:hover{background:#1e40af;color:#fff;}
.tt-info-green{background:#d1fae5;color:#15803d;}
.tt-info-green:hover{background:#15803d;color:#fff;}
.tt-modal-bg{display:none;position:fixed;inset:0;background:rgba(15,23,42,.6);z-index:9998;align-items:center;justify-content:center;padding:20px;}
.tt-modal-bg.open{display:flex;animation:fadeIn .2s;}
.tt-modal{background:#fff;border-radius:14px;max-width:640px;width:100%;max-height:80vh;overflow-y:auto;padding:28px 32px;position:relative;box-shadow:0 25px 60px rgba(0,0,0,.4);}
.tt-modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;background:#f1f5f9;border:none;font-size:18px;cursor:pointer;color:#64748b;}
.tt-modal-close:hover{background:#e2e8f0;color:#0f172a;}
.tt-modal h3{font-size:18px;font-weight:800;color:#1e40af;margin:0 0 14px;padding-right:30px;}
.tt-modal p{font-size:14px;line-height:1.6;color:#334155;margin:0 0 12px;}
.tt-modal p:last-child{margin-bottom:0;}

/* ── Форма «Заявка на дистанционное обучение» (4 шага) ─────────── */
.contract-page{padding:40px 0 80px;background:var(--gray-50);min-height:60vh;}
.contract-page .container{max-width:980px;margin:0 auto;padding:0 20px;width:100%;box-sizing:border-box;}
.contract-back{display:inline-flex;align-items:center;gap:8px;color:var(--gray-500);text-decoration:none;font-size:14px;margin-bottom:14px;cursor:pointer;}
.contract-back:hover{color:var(--blue-500);}
.contract-title{text-align:center;font-size:26px;font-weight:800;margin:8px 0 32px;color:var(--gray-900);}
.contract-step{background:#fff;border-radius:14px;border:1px solid var(--gray-200);padding:28px 32px;margin-bottom:20px;box-shadow:0 1px 3px rgba(0,0,0,.04);}
.contract-step .step-num{font-size:14px;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.contract-step .step-title{font-size:20px;font-weight:800;color:var(--blue-500);margin-bottom:10px;}
.contract-step .step-sub{font-size:13px;color:var(--gray-500);margin-bottom:20px;line-height:1.5;}
.contract-step .step-warn{font-size:13px;color:#854d0e;background:#fef9c3;border:1px solid #fde047;padding:8px 12px;border-radius:8px;margin-bottom:14px;display:flex;gap:8px;align-items:flex-start;}
.contract-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.contract-grid.cols-2{grid-template-columns:repeat(2,1fr);}
.contract-grid.cols-1{grid-template-columns:1fr;}
.cf-field{position:relative;}
.cf-field input,.cf-field select,.cf-field textarea{width:100%;padding:14px 14px 6px;border:1px solid var(--gray-300);border-radius:6px;font-size:14px;font-family:inherit;outline:none;background:#fff;transition:border-color .15s;color:var(--gray-900);}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-color:var(--blue-500);}
.cf-field label{position:absolute;left:14px;top:14px;font-size:12px;color:var(--gray-500);background:#fff;padding:0 4px;pointer-events:none;transition:.15s;}
.cf-field input:focus + label,.cf-field input:not(:placeholder-shown) + label,
.cf-field textarea:focus + label,.cf-field textarea:not(:placeholder-shown) + label,
.cf-field select.has-value + label{top:-8px;font-size:11px;color:var(--blue-500);}
.cf-field.req label::after{content:' *';color:#dc2626;}
.cf-note{font-size:12px;color:var(--gray-500);margin-top:6px;}

.contract-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:24px;}
.contract-tab{padding:14px 16px;text-align:center;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.4px;color:var(--gray-500);background:#fff;border:none;cursor:pointer;font-family:inherit;border-bottom:3px solid transparent;margin-bottom:-2px;transition:.15s;}
.contract-tab.active{color:var(--blue-500);border-bottom-color:var(--blue-500);background:var(--blue-50);}
.contract-tab:hover{color:var(--blue-600);}

.contract-delivery-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:2px solid var(--gray-200);margin-bottom:24px;}
.contract-delivery-tabs .contract-tab{font-size:12px;}

.student-card{background:var(--blue-50);border:1px solid var(--blue-100);border-radius:12px;padding:20px;margin-bottom:14px;}
.student-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;}
.student-card-title{font-size:15px;font-weight:800;color:var(--gray-900);}
.student-card .add-student-link{color:var(--blue-500);text-decoration:none;font-size:14px;font-weight:600;cursor:pointer;}
.student-card .add-student-link:hover{text-decoration:underline;}
.student-card .remove-student{color:#dc2626;background:transparent;border:none;cursor:pointer;font-size:13px;font-weight:600;}
.contract-prog-block{margin-top:18px;padding-top:14px;border-top:1px dashed var(--blue-200);}
.contract-prog-block .pb-title{font-size:14px;font-weight:800;color:var(--gray-900);margin-bottom:10px;}

.contract-add-btn{display:inline-flex;align-items:center;gap:8px;color:var(--blue-500);background:#fff;border:1px dashed var(--blue-500);padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;}
.contract-add-btn:hover{background:var(--blue-50);}

.contract-section-title{font-size:14px;font-weight:800;color:var(--gray-900);margin:14px 0 10px;}
.contract-checkbox-row{display:flex;align-items:flex-start;gap:10px;margin:10px 0;font-size:13px;color:var(--gray-700);cursor:pointer;}
.contract-checkbox-row input{margin-top:3px;width:18px;height:18px;cursor:pointer;}

.contract-submit{width:100%;padding:14px;background:var(--blue-500);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:800;cursor:pointer;font-family:inherit;letter-spacing:.5px;text-transform:uppercase;transition:.15s;}
.contract-submit:hover{background:var(--blue-600);}
.contract-submit:disabled{background:var(--gray-300);cursor:not-allowed;}

.contract-success{background:#dcfce7;border:1px solid #86efac;color:#166534;padding:24px;border-radius:12px;text-align:center;font-size:15px;font-weight:600;}

@media (max-width:768px){
  .contract-grid,.contract-grid.cols-2{grid-template-columns:1fr;}
  .contract-tabs{grid-template-columns:1fr;}
  .contract-step{padding:18px;}
}
