/* Базовые */
:root{
    --bg:#ffffff;
    --text:#1f2a30;
    --muted:#6b7a85;
    --brand:#0DAFAE;
    --brand-2:#2c7a7b;         /* можно сменить под вкус */
    --card:#f6f9f9;
    --line:#e7eef0;
    --shadow:0 10px 30px rgba(0,0,0,.06);
    --radius:14px;
    --container:1120px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:16px/1.6 "Inter","Segoe UI",system-ui,-apple-system,Arial,sans-serif}
img{max-width:100%;display:block;height:auto}
a{color:var(--brand-2);text-decoration:none}
a:hover{opacity:.9}
.container{max-width:var(--container);margin:0 auto;padding:0 16px}
.container.narrow{max-width:800px}

/* Заголовки / отступы */
h1{font-size:44px;line-height:1.15;margin:0 0 12px}
h2{font-size:32px;margin:0 0 14px}
h3{font-size:20px;margin:0 0 8px}
.section{padding:56px 0}
.section.alt{background:#f7fbfb}
.bullets{padding-left:18px;margin:10px 0}
.bullets li{margin:6px 0}
.muted{color:var(--muted)}
.tiny{font-size:12px}

/* Шапка */
.site-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(1.5) blur(8px);z-index:1000;border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:72px}
.brand{display:flex;align-items:center;gap:12px}
.brand-logo{display:block;width:46px;height:46px;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.brand-logo img{width:100%;height:100%;object-fit:cover;display:block}
.brand-title{font-weight:800}
.brand-subtitle{font-size:12px;color:var(--muted);margin-top:-4px}

/* Навигация */
.nav-toggle{display:none;width:40px;height:40px;border:0;background:
        radial-gradient(currentColor 2px,transparent 3px) left 10px top 14px/8px 8px no-repeat,
        radial-gradient(currentColor 2px,transparent 3px) center top 14px/8px 8px no-repeat,
        radial-gradient(currentColor 2px,transparent 3px) right 10px top 14px/8px 8px no-repeat;
    color:#2d3748;border-radius:10px}
.nav-list{display:flex;gap:20px;list-style:none;margin:0;padding:0}
.nav-list a{display:block;padding:10px 8px;border-radius:10px;font-weight:700;color:#2d3748}
.nav-list a.active,.nav-list a:hover{color:var(--brand);}

/* Hero slider */
.hero{position:relative}
.slider{position:relative;height:min(86vh,760px);overflow:hidden;border-bottom:1px solid var(--line)}
.slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transform:scale(1.04);transition:opacity .8s ease,transform 1.6s ease}
.slide::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.45),rgba(0,0,0,.15) 40%,rgba(0,0,0,.05) 70%)}
.slide{background-image:var(--bg)}
.slide.current{opacity:1;transform:scale(1)}
.hero-caption{position:absolute;left:clamp(16px,10vw,80px);top:50%;transform:translateY(-50%);color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.35)}
.hero-caption h1{font-size:clamp(32px,5vw,56px);margin:0 0 8px}
.hero-sub{font-size:20px;opacity:.95;margin:0}

.slider-btn{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border:0;border-radius:50%;background:rgba(255,255,255,.9);box-shadow:var(--shadow);font-size:28px;line-height:44px;color:#1a202c;cursor:pointer}
.slider-btn:hover{background:#fff}
.slider-btn.prev{left:16px}
.slider-btn.next{right:16px}
.slider-dots{position:absolute;left:50%;bottom:18px;transform:translateX(-50%);display:flex;gap:10px}
.slider-dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.7);cursor:pointer}
.slider-dots button.active{background:#fff;box-shadow:0 0 0 3px rgba(255,255,255,.35)}

/* Сетки/карточки */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.portrait{width:100%;height:auto;border-radius:var(--radius)}

/* Аккордеон (details/summary) */
.accordion{display:grid;gap:12px}
.acc{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden}
.acc-summary{padding:16px 56px 16px 16px;font-weight:700;cursor:pointer;list-style:none;position:relative}
.acc-summary::-webkit-details-marker{display:none}
.acc-arrow{position:absolute;right:14px;top:50%;transform:translateY(-50%) rotate(0);transition:transform .25s}
.acc-arrow::before{content:"▾";font-size:18px;color:var(--muted)}
.acc[open] .acc-arrow{transform:translateY(-50%) rotate(180deg)}
.acc-panel{padding:0 16px 16px 16px;border-top:1px dashed var(--line)}
.acc p{margin:12px 0}
.muted{color:var(--muted)}

/* Галерея-рельса */
.rail{overflow:hidden;border-radius:12px;border:1px solid var(--line);background:#fff}
.rail-track{display:flex;gap:12px;padding:12px;will-change:transform}
.rail img{width:360px;height:220px;object-fit:cover;border-radius:10px;box-shadow:var(--shadow)}

/* Форма */
.form label{display:grid;gap:6px;margin-bottom:12px;font-weight:600}
.form input,.form textarea{padding:12px 14px;border:1px solid var(--line);border-radius:10px;background:#fff;outline:none}
.form input:focus,.form textarea:focus{border-color:#cfe6e6;box-shadow:0 0 0 4px #e9f6f6}
.btn{padding:12px 18px;border:0;border-radius:999px;background:var(--brand);color:#fff;font-weight:800;cursor:pointer}
.btn:hover{filter:brightness(1.03)}
.contact-actions{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 10px}
.contact-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:999px;font-weight:700;color:#fff;border:0;box-shadow:var(--shadow);transition:transform .15s ease,filter .15s}
.contact-btn:focus-visible{outline:3px solid rgba(255,255,255,.6);outline-offset:2px}
.contact-btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.contact-btn--telegram{background:#27a5e7}
.contact-btn--vk{background:#0077ff}
.contact-btn--whatsapp{background:#25d366;color:#053d1c}
.contact-btn--max{background:#ff004d}
.contact-btn svg{width:18px;height:18px;fill:currentColor}
.seo-card{background:linear-gradient(135deg,#f7fbfb,#ffffff);padding:32px;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}
.seo-card h2{margin-bottom:12px}
.seo-text{font-size:18px;line-height:1.7;margin:0}
.seo-text strong{color:var(--brand-2)}

/* Футер */
.site-footer{border-top:1px solid var(--line);background:#fff}
.footer-inner{min-height:72px;display:flex;align-items:center;justify-content:space-between}

/* Плавающие кнопки */
.sticky-cta{position:fixed;left:50%;transform:translateX(-50%);bottom:12px;display:flex;gap:8px;z-index:999}
.pill{font-weight:700;font-size:14px;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow)}
.pill:hover{border-color:#dfe8ea}
@media (max-width:520px){
    .sticky-cta{gap:6px}
    .pill{font-size:13px;padding:8px 12px}
}

/* Страница политики */
body.privacy .section{padding:36px 0}
.policy-block{border:1px solid var(--line);border-radius:12px;margin:12px 0;background:#fff;overflow:hidden}
.policy-block>summary{cursor:pointer;font-weight:800;padding:16px 48px 16px 16px;list-style:none;position:relative}
.policy-block>summary::-webkit-details-marker{display:none}
.policy-block>summary::after{content:"▾";position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted)}
.policy-block[open]>summary::after{transform:translateY(-50%) rotate(180deg)}
.policy-block>div{padding:0 16px 16px;border-top:1px dashed var(--line)}

/* Мобильный адаптив и фиксы от скролла по ширине */
html,body{max-width:100%;overflow-x:hidden}
@media (max-width:960px){
    .grid-3{grid-template-columns:1fr 1fr}
}
@media (max-width:760px){
    .grid-2{grid-template-columns:1fr}
    .grid-3{grid-template-columns:1fr}
    .header-inner{min-height:64px}
    .site-header{background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.05);backdrop-filter:none}
    .nav-toggle{display:block}
    .nav-list{position:fixed;inset:auto 0 0 0;top:64px;background:#fff;border-top:1px solid var(--line);
        padding:12px 16px;flex-direction:column;gap:8px;transform:translateY(8px);opacity:0;pointer-events:none;transition:.2s;
        box-shadow:0 -6px 28px rgba(0,0,0,.12)}
    .nav-list.open{transform:translateY(0);opacity:1;pointer-events:auto}
    .slider-btn{display:none}
    .hero .slider{height:72vh}
}

/* === PATCH: Mobile drawer for existing .header / .menu === */
@media (max-width: 960px){
    .menu-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
        border:1px solid #e7eef0;border-radius:10px;background:#fff}
    .menu{display:none}
    .menu--drawer{position:fixed;inset:0 0 0 auto;width:min(86vw,360px);background:#fff;border-left:1px solid #e7eef0;
        transform:translateX(100%);transition:transform .25s ease;z-index:1000;padding:16px;overflow:auto}
    .menu--drawer.open{transform:translateX(0)}
    .menu--drawer .menu__list{list-style:none;margin:0;padding:0;display:grid;gap:8px}
    .menu--drawer a{display:block;padding:12px;border-radius:10px;text-decoration:none;color:#1f2a30;font-weight:600}
    .menu--drawer a:active{background:#f4fbfb}
    .drawer-mask{position:fixed;inset:0;background:rgba(0,0,0,.35);opacity:0;pointer-events:none;transition:.2s;z-index:999}
    .drawer-mask.drawer-mask--show{opacity:1;pointer-events:auto}
}

/* === PATCH: Fullscreen hero slider & adaptive text (uses .hero .slider/.slide/.current) === */
.hero .slider{position:relative;height:calc(100svh - 64px);min-height:480px;overflow:hidden}
.hero .slide{position:absolute;inset:0;opacity:0;transform:scale(1.04);transition:opacity .6s ease,transform 1.2s ease}
.hero .slide.current{opacity:1;transform:scale(1)}
.hero .slide[style*="background"], .hero .slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero .slide::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.45),rgba(0,0,0,.1) 45%,rgba(0,0,0,.04) 75%)}
.hero .hero-caption{position:absolute;left:clamp(16px,6vw,80px);top:50%;transform:translateY(-50%);color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.35);max-width:min(92vw,720px);padding-right:16px}
.hero .hero-caption h1{font-size:clamp(28px,5.2vw,56px);margin:0 0 10px}
.hero .hero-caption .hero-sub{font-size:clamp(16px,2.2vw,22px);margin:0}

/* точки/стрелки — не конфликтуют с твоими */
.slider-dots{position:absolute;left:50%;bottom:max(12px,calc(12px + env(safe-area-inset-bottom)));transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.slider-dots button{width:10px;height:10px;border-radius:50%;border:0;background:rgba(255,255,255,.75);cursor:pointer}
.slider-dots button.active{background:#fff;width:28px;border-radius:8px}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:40px;height:40px;border:1px solid #e7eef0;border-radius:50%;background:#fff;box-shadow:0 10px 30px rgba(0,0,0,.06);cursor:pointer}
.slider-btn.prev{left:16px}
.slider-btn.next{right:16px}

/* === Обновлённые стили для дипломов (горизонтальные, компактные) === */
.rail {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding: 8px;
    border-radius: 12px;
    border: 1px solid #e7eef0;
    background: #fff;
    scrollbar-width: thin;
    scrollbar-color: #ccc transparent;
}
.rail::-webkit-scrollbar {height: 6px;}
.rail::-webkit-scrollbar-thumb {background:#ccc;border-radius:4px;}

.rail > a {
    flex: 0 0 auto;
    width: 220px;              /* меньше */
    aspect-ratio: 4 / 3;       /* горизонтальные */
    border-radius: 10px;
    overflow: hidden;
    scroll-snap-align: center;
    border: 1px solid #e7eef0;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.rail > a:hover {
    transform: scale(1.03);
    box-shadow: 0 4px 14px rgba(0,0,0,0.1);
}
.rail img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: inherit;
}

/* === Обновлённый лайтбокс с кликом по фону и свайпом вниз === */
.lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.92);
    display: none;
    z-index: 2000;
}
.lightbox.open {display: block;}
.lightbox figure {
    position: absolute;
    inset: 0;
    margin: 0;
    display: grid;
    place-items: center;
    cursor: zoom-out;
}
.lightbox img {
    max-width: 96vw;
    max-height: 88vh;
    border-radius: 8px;
    box-shadow: 0 0 20px rgba(0,0,0,0.3);
    transition: transform 0.3s ease;
}
.lightbox .lb-close,
.lightbox .lb-prev,
.lightbox .lb-next {
    position: absolute;
    z-index: 3;
    width: 42px;
    height: 42px;
    border-radius: 50%;
    border: 0;
    background: #fff;
    box-shadow: 0 10px 30px rgba(0,0,0,.06);
    cursor: pointer;
    font-size: 22px;
    font-weight: bold;
}
.lightbox .lb-close {top: 16px; right: 16px;}
.lightbox .lb-prev {top: 50%; left: 16px; transform: translateY(-50%);}
.lightbox .lb-next {top: 50%; right: 16px; transform: translateY(-50%);}

/* меньше плитки дипломов на главной ТОЛЬКО на десктопе */
@media (min-width: 1024px){
    .rail--home > a { width: 160px; } /* сейчас 220px; можно 160–200 */
}

@media (min-width: 1024px){
    main .rail:first-of-type > a { width: 160px; }
}

/* Выровнять текст по ширине в основном контенте */
.section p,
.content p,
.page p,
.article p {
    text-align: justify;
    text-justify: inter-word;
}

.cta-buttons{
    margin-top:32px;
    text-align:center;
    display:flex;
    justify-content:center;
    gap:12px;
    flex-wrap:wrap; /* если вдруг не влезет */
}

@media (max-width: 520px){
    .cta-buttons{
        flex-direction:column;
        align-items:stretch;
        gap:10px;
        padding:0 16px; /* чтобы не липло к краям */
    }
    .cta-buttons .btn{
        width:100%;
        display:inline-flex;
        justify-content:center;
    }
}
