/* ============================================================
   mobile.css — мобильная адаптация ttd-mo.ru
   Подключается после style.css
   ============================================================ */

/* === TOPBAR: скрываем на мобильном === */
@media(max-width:768px){
  .site-topbar{display:none!important}
}

/* === HEADER === */
@media(max-width:768px){
  .site-header__body{
    height:auto;
    flex-wrap:nowrap;
    padding:10px 14px;
    gap:0;
    align-items:center;
  }
  .site-header__mid,
  .site-header__actions{display:none!important}

  .site-logo{
    flex:1;min-width:0;padding:0;
    border-right:none;overflow:hidden;
  }
  .site-logo__accent{display:none}
  .site-logo__img-wrap{
    width:44px;height:44px;min-width:44px;
    margin-right:10px;flex-shrink:0;
  }
  .site-logo__img{width:40px;height:40px}
  .site-logo__text{min-width:0;overflow:hidden}
  .site-logo__badge{font-size:.55rem;padding:1px 5px}
  .site-logo__name{
    font-size:.82rem;max-width:none;
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  }
  .site-logo__sub{display:none}
  .burger{display:flex!important;flex-shrink:0;margin-left:10px}
}

/* === БУРГЕР АНИМАЦИЯ === */
.burger span{transition:.25s}
.burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0;transform:translateX(-8px)}
.burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* === МОБИЛЬНАЯ ПОЛОСА КНОПОК ПОД ШАПКОЙ === */
.mob-actions{display:none}
@media(max-width:768px){
  .mob-actions{
    display:flex;gap:8px;
    padding:8px 14px;
    background:#f4f7ff;
    border-bottom:1px solid #dde3f0;
  }
  .mob-actions a{
    flex:1;display:flex;align-items:center;
    justify-content:center;gap:5px;
    padding:9px 6px;border-radius:7px;
    font-size:.76rem;font-weight:700;
    text-decoration:none;transition:.15s;
    white-space:nowrap;
  }
  .mob-actions__contacts{
    background:#eff6ff;color:#006eba;
    border:1.5px solid #c7d8f8;
  }
  .mob-actions__question{
    background:#fff;color:#374151;
    border:1.5px solid #d1d5db;
  }
  .mob-actions__admission{
    flex:1.5;
    background:#c0392b;color:#fff;
    border:1.5px solid #c0392b;
  }
  .mob-actions__admission:hover{background:#a93226;color:#fff;text-decoration:none}
}

/* === НАВИГАЦИЯ МОБИЛЬНАЯ === */
@media(max-width:768px){
  .main-nav__inner{padding:0}
  .main-nav__list{
    display:none;flex-direction:column;
    width:100%;max-height:75vh;overflow-y:auto;
  }
  .main-nav__list.open{display:flex}
  .main-nav__link{
    height:auto;padding:13px 16px;
    font-size:.9rem;justify-content:space-between;
    border-bottom:1px solid rgba(255,255,255,.1);
  }
  /* Дропдауны в мобильном — аккордеон */
  .main-nav__item > .dropdown{
    position:static;box-shadow:none;border-radius:0;
    border:none;border-top:none;
    background:rgba(0,0,0,.2);min-width:unset;
    display:none;padding:0;
  }
  .main-nav__item > .dropdown.mob-open{display:block}
  .dropdown a{
    color:rgba(255,255,255,.88);
    padding:11px 16px 11px 30px;
    font-size:.86rem;white-space:normal;
    border-bottom:1px solid rgba(255,255,255,.07);
  }
  .dropdown a:hover{background:rgba(255,255,255,.12);color:#fff}
  .dropdown--sub{
    position:static;border-radius:0;
    box-shadow:none;background:rgba(0,0,0,.15);
    padding-left:12px;display:none;
  }
  .dropdown--sub.mob-open{display:block}
  .dropdown--sub a{padding-left:44px}
}

/* === ОБЩИЙ КОНТЕНТ === */
@media(max-width:768px){
  .wrap{padding:0 14px}
  h1{font-size:clamp(1.3rem,5vw,1.7rem)!important}
  h2{font-size:1.1rem}
  .card{padding:1rem;border-radius:10px}
  .breadcrumb{font-size:.78rem;overflow-x:auto;white-space:nowrap;padding-bottom:4px}
  input,textarea,select{font-size:1rem!important}
}

/* === ТАБЛИЦЫ — горизонтальный скролл === */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1rem}
@media(max-width:768px){
  .table-wrap table{min-width:500px}
  table th,table td{padding:8px 10px;font-size:.8rem}
}

/* === SVEDEN САЙДБАР === */
@media(max-width:768px){
  .sveden-layout{grid-template-columns:1fr!important;gap:16px}
  .sveden-sidebar{position:static!important;border-radius:10px;overflow:hidden}
  .sveden-sidebar__toggle{
    display:flex!important;
    align-items:center;justify-content:space-between;
    padding:13px 16px;cursor:pointer;
    font-weight:700;font-size:.9rem;
  }
  .sveden-sidebar__body{
    display:none;
    padding:0 16px 16px;
    border-top:1px solid rgba(255,255,255,.2);
  }
  .sveden-sidebar__body.open{display:block}
  .toggle-arrow{transition:.25s;flex-shrink:0}
  .sveden-sidebar.open .toggle-arrow{transform:rotate(180deg)}
  .sveden-content{width:100%!important}
  .sveden-page-content{overflow-x:auto}
  .sveden-page-content table{min-width:480px}
  .sveden-page-content th,
  .sveden-page-content td{padding:8px 10px;font-size:.8rem}

  /* Ссылки в сайдбаре — предотвращаем обрезание текста */
  .sveden-sidebar__link{
    white-space:normal;
    word-break:break-word;
    padding-right:12px;
  }
  .sveden-sidebar__list{overflow:visible}
}

/* === STAFF PAGE === */
@media(max-width:768px){
  /* Таблица руководства — скролл */
  .staff-table{min-width:520px}
  .staff-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1rem}

  /* Карточка преподавателя */
  .teacher-row__header{padding:12px 14px;gap:10px}
  .teacher-row__avatar{width:44px;height:44px}
  .teacher-row__name{font-size:.88rem}
  .teacher-row__pos{font-size:.78rem}

  /* Таблица полей преподавателя (п.12) — скрываем средний столбец */
  .pfield-table{display:block;overflow-x:hidden}
  .pf-label{display:none!important}
  .pf-lit{padding:7px 8px 7px 14px;width:2rem;font-size:.78rem}
  .pf-val{padding:7px 14px 7px 0;font-size:.82rem;word-break:break-word}

  /* Скрываем телефон/email в таблице руководства (4 колонки → 2) */
  .staff-table th:nth-child(3),
  .staff-table td:nth-child(3),
  .staff-table th:nth-child(4),
  .staff-table td:nth-child(4){display:none}

  /* Блок раздела */
  .section-heading{font-size:.9rem;padding:9px 12px}
  .law-note{font-size:.78rem;padding:7px 12px}
}

/* === НОВОСТИ === */
@media(max-width:600px){
  .news-card{flex-direction:column}
  .news-card__thumb{width:100%!important;min-width:unset!important;height:180px}
  .news-card__body{padding:14px 16px}
  .news-card__title{font-size:.95rem}
}

/* === НОВОСТЬ-ДЕТАЛЬ === */
@media(max-width:600px){
  .article__image{border-radius:8px;margin-bottom:1.5rem}
  .article__meta{gap:1rem;font-size:.8rem}
  .ng-thumb{width:56px;height:40px}
  .ng-arrow{width:34px;height:34px;font-size:.95rem}
  .ng-wrap{padding:1rem}
}

/* === ДИНАМИЧЕСКИЕ СТРАНИЦЫ (dynamic.php) === */
@media(max-width:768px){
  .sveden-page-content img,
  .wrap img{max-width:100%;height:auto}
  .wrap iframe{max-width:100%}
}

/* === СПЕЦИАЛЬНОСТИ === */
@media(max-width:600px){
  /* Карточки специальностей уже full-width, просто уменьшаем отступы */
  .spec-card{border-radius:10px}
  .spec-card__header{padding:14px 16px}
  .spec-card__body{padding:12px 16px}
  .spec-tag{font-size:.73rem;padding:4px 8px}
}

/* === ПРИЁМНАЯ КОМИССИЯ === */
@media(max-width:600px){
  .deadline-card{padding:16px 18px}
  .deadline-card__date{font-size:1.3rem}
  .deadline-card__label{font-size:.65rem;letter-spacing:.06em}
}

/* === QA ФОРМА (задать вопрос) === */
@media(max-width:600px){
  .qa-form{padding:20px 16px}
  .qa-form__row{flex-direction:column}
}

/* === ФУТЕР === */
@media(max-width:768px){
  .site-footer .wrap{padding:24px 14px 16px}
  .footer__top{
    flex-direction:column;gap:24px;
  }
  .footer__col{min-width:unset;width:100%}
  .footer__logo-name{font-size:.9rem}
  .footer__links a{font-size:.82rem}
}
@media(max-width:540px){
  .footer__bottom{flex-direction:column;align-items:center;text-align:center;gap:8px}
  .footer__gov{justify-content:center}
  .footer__copy{font-size:.75rem;text-align:center}
}

/* === ОТСТУП ПЕРЕД ФУТЕРОМ — уменьшаем на мобильном === */
@media(max-width:768px){
  .site-footer{margin-top:32px!important}
}


/* ============================================================
   КОМПЛЕКСНЫЕ ИСПРАВЛЕНИЯ МОБИЛЬНОЙ АДАПТАЦИИ v2
   ============================================================ */

/* === ПРЕДОТВРАЩЕНИЕ ГОРИЗОНТАЛЬНОГО СКРОЛЛА === */
@media (max-width: 768px) {
  html, body {
    overflow-x: hidden;
    max-width: 100%;
  }

  /* Шапка — не выходить за экран */
  .site-header {
    overflow: hidden;
  }
  .site-header__body {
    max-width: 100%;
    padding: 10px 14px;
    box-sizing: border-box;
  }

  /* Лицензии и аккредитация — скрыть на мобильном */
  .hdr-licences,
  .hdr-divider,
  .hdr-actions,
  .hdr-spacer {
    display: none !important;
  }

  /* Навигационная полоса */
  .main-nav {
    overflow: hidden;
  }
  .main-nav__inner {
    max-width: 100%;
    overflow: hidden;
  }

  /* Мобильное меню — ограничить ширину */
  .main-nav__list {
    width: 100% !important;
    max-width: 100vw;
    box-sizing: border-box;
    overflow-x: hidden;
  }

  /* Кнопки действий в шапке */
  .mob-actions {
    overflow: hidden;
    box-sizing: border-box;
    width: 100%;
  }
  .mob-actions a {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* Основной контент */
  .wrap {
    padding: 0 14px;
    box-sizing: border-box;
    max-width: 100%;
    overflow-x: hidden;
  }

  /* Все блоки — не выходить за экран */
  div, section, article, aside, nav, main {
    max-width: 100%;
  }

  /* Изображения */
  img {
    max-width: 100%;
    height: auto;
  }

  /* Таблицы — горизонтальный скролл внутри контейнера */
  table {
    min-width: unset;
    width: 100%;
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  /* Иключение — таблицы внутри wrap уже имеют таблицу-обёртку */
  .table-wrap table,
  .table-responsive table {
    min-width: 480px;
  }
}

/* === ШАПКА — средние экраны === */
@media (max-width: 1024px) {
  .hdr-licences { gap: 14px; }
  .hdr-lic-val { font-size: .7rem; }
}
@media (max-width: 860px) {
  .hdr-licences { display: none !important; }
  .hdr-divider { display: none !important; }
}

/* === СЛАЙДЕР === */
@media (max-width: 768px) {
  .hero-slide__title {
    font-size: clamp(1.2rem, 5vw, 1.6rem) !important;
  }
  .hero-slide__text {
    font-size: .88rem !important;
  }
  .hero-slide__actions {
    flex-direction: column;
    gap: 8px;
  }
  .hero-slide__btn {
    width: 100%;
    text-align: center;
    justify-content: center;
  }
}

/* === ФОРМА ЗАЯВЛЕНИЯ === */
@media (max-width: 640px) {
  .app-form-section {
    padding: 16px 14px !important;
    border-radius: 8px !important;
  }
  .form-grid {
    grid-template-columns: 1fr !important;
  }
  /* Уведомление перед формой */
  .app-form-section > div[style*="display:flex"] {
    flex-direction: column;
    gap: 10px;
  }
}

/* === СТРАНИЦА СПЕЦИАЛЬНОСТЕЙ === */
@media (max-width: 600px) {
  .spec-card__header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .spec-card__code {
    font-size: .75rem;
  }
}

/* === СТРАНИЦА ПРИЁМНОЙ КОМИССИИ === */
@media (max-width: 640px) {
  /* Блок "подать заявление" */
  [class*="priem"] h2,
  .priemnaya h2 {
    font-size: 1.1rem !important;
  }
}

/* === КОНТАКТЫ === */
@media (max-width: 640px) {
  .contacts-grid {
    grid-template-columns: 1fr !important;
  }
  .contacts-map iframe {
    height: 220px !important;
  }
}

/* === РЕЙТИНГ (публичный) === */
@media (max-width: 640px) {
  .rating-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .rating-table-wrap table {
    min-width: 400px;
  }
}

/* === ФУТЕР — исправление === */
@media (max-width: 768px) {
  .footer__top {
    flex-direction: column !important;
    gap: 20px !important;
  }
  .footer__col {
    width: 100% !important;
    min-width: unset !important;
  }
  .site-footer .wrap {
    padding: 20px 14px !important;
    overflow: hidden;
  }
}

/* === ДИНАМИЧЕСКИЕ СТРАНИЦЫ === */
@media (max-width: 768px) {
  /* Контент из CMS */
  .wrap p,
  .wrap li {
    word-break: break-word;
    overflow-wrap: break-word;
  }
  .wrap iframe {
    max-width: 100% !important;
    width: 100% !important;
  }
  .wrap pre,
  .wrap code {
    overflow-x: auto;
    max-width: 100%;
    font-size: .82rem;
  }
}
