/*─────────────────────────────────────────────────────────────────────────────
  Variables & Base
─────────────────────────────────────────────────────────────────────────────*/
:root{
  --bg:#07141c;
  --bg-2:#0d202c;
  --gold:#d4b25c;
  --gold-2:#f0d88a;
  --muted:#8aa1b1;
  --glass:rgba(9,25,35,.6);
  --card:rgba(255,255,255,.06);
  --shadow:0 24px 48px rgba(0,0,0,.5);
  --font:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Noto Sans",Ubuntu,Cantarell,"Helvetica Neue",Arial,sans-serif;
  --green:#22c55e;
  --red:#ef4444;
  --blue:#60a5fa;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

html,body{
  height:100%;
  font-family:var(--font);
  background:var(--bg);
  color:#e8eef2;
  overflow-x:hidden;
}

a{color:inherit;text-decoration:none}

/*─────────────────────────────────────────────────────────────────────────────
  Page container
─────────────────────────────────────────────────────────────────────────────*/
.container{
  width:92%;
  max-width:1280px;     /* вернул прежнюю ширину, чтобы другие страницы не «расползались» */
  margin:40px auto;
  padding:0 20px;
}

/*─────────────────────────────────────────────────────────────────────────────
  Topbar + Layout with Sidebar
─────────────────────────────────────────────────────────────────────────────*/
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-top:10px;
}
.brand{display:flex;align-items:center;gap:10px}
.brand img{width:28px;height:28px;object-fit:contain}
.brand span{font-weight:800;letter-spacing:.3px}

.menu-toggle{
  display:none;
  background:transparent;
  border:2px solid rgba(255,255,255,.25);
  color:#e8eef2;
  border-radius:12px;
  padding:8px 12px;
  cursor:pointer;
}
.logout-top{
  padding:10px 16px;
  border-radius:12px;
  border:2px solid var(--gold);
  color:var(--gold);
}
.logout-top:hover{background:var(--gold);color:var(--bg)}

/* ====== Надёжный layout без :has() ====== */
.layout{
  display:flex;                /* вместо grid */
  gap:28px;
  align-items:flex-start;
}
.sidebar{
  flex:0 0 280px;              /* фиксированная ширина меню слева */
  position:sticky;
  top:20px;
  align-self:start;
  background:var(--glass);
  border-radius:20px;
  padding:16px;
  box-shadow:var(--shadow);
  height:max-content;
}
.content{
  flex:1 1 auto;               /* контент занимает всё остальное */
  min-width:0;
}

/* чтобы карточки в контенте не «схлопывались» */
.layout .content > *{width:100%;max-width:none}

.sidebar-section+.sidebar-section{
  margin-top:12px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
}
.sidebar-title{
  font-weight:700;
  color:var(--gold);
  margin-bottom:10px;
}
.side-link{
  display:block;
  padding:11px 12px;
  border-radius:12px;
  color:#cfe3f0;
  transition:background .2s,transform .2s;
}
.side-link:hover{background:rgba(255,255,255,.08);transform:translateX(2px)}
.side-link.active{background:rgba(212,178,92,.18);color:#fff}

/*─────────────────────────────────────────────────────────────────────────────
  Flash banners
─────────────────────────────────────────────────────────────────────────────*/
.flash{margin-bottom:18px;list-style:none;padding-left:0}
.flash li{
  padding:12px 14px;border-radius:12px;margin-bottom:10px;
  background:rgba(255,255,255,.06);box-shadow:var(--shadow);border-left:4px solid var(--blue)
}
.flash li.success{border-left-color:var(--green)}
.flash li.error,.flash li.danger{border-left-color:var(--red)}

/*─────────────────────────────────────────────────────────────────────────────
  Buttons
─────────────────────────────────────────────────────────────────────────────*/
.btn-primary,.btn-secondary,.btn-ghost{
  display:inline-flex;align-items:center;justify-content:center;
  text-align:center;cursor:pointer;border-radius:16px;font-weight:600;
  transition:transform .2s,background .2s,color .2s,box-shadow .2s;
}
.btn-primary{
  padding:16px 32px;font-size:1.15rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:#0b1013;border:none;box-shadow:0 24px 48px rgba(212,178,92,.35);
}
.btn-primary:hover{transform:translateY(-2px) scale(1.03)}
.btn-secondary{
  padding:14px 28px;font-size:1.05rem;background:transparent;
  border:2px solid rgba(255,255,255,.22);color:#cfe3f0;
}
.btn-secondary:hover{background:rgba(255,255,255,.1);color:var(--gold);transform:translateY(-1px) scale(1.02)}
.btn-ghost{
  padding:12px 24px;font-size:1.05rem;background:transparent;border:2px solid var(--gold);color:var(--gold);
}
.btn-ghost:hover{background:var(--gold);color:var(--bg);transform:translateY(-1px) scale(1.02)}

/*─────────────────────────────────────────────────────────────────────────────
  Glass cards
─────────────────────────────────────────────────────────────────────────────*/
.glass-card{
  background:var(--glass);
  border-radius:24px;
  padding:40px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
  margin-bottom:40px;
}

/*─────────────────────────────────────────────────────────────────────────────
  Auth / Forms / Register modal + 2FA inputs
─────────────────────────────────────────────────────────────────────────────*/
.auth-form{
  width:100%;max-width:520px;margin:60px auto;
  padding:32px 26px;background:var(--glass);border-radius:24px;
  backdrop-filter:blur(10px);box-shadow:var(--shadow);text-align:center;
}
.auth-form h2{font-size:1.9rem;margin-bottom:18px}
.auth-form label{display:block;text-align:left;font-size:1rem;color:#d9e9f4;margin-bottom:6px}
.auth-form input,.auth-form textarea{
  width:100%;padding:14px;margin:6px 0 16px;border:none;border-radius:16px;
  background:rgba(255,255,255,.05);
  box-shadow:inset 0 6px 16px rgba(255,255,255,.18),0 12px 24px rgba(0,0,0,.4);
  color:#eaf2f9;font-size:1.02rem;transition:background .2s,box-shadow .2s;resize:vertical
}
.auth-form input:focus,.auth-form textarea:focus{
  background:rgba(255,255,255,.12);
  box-shadow:inset 0 8px 20px rgba(255,255,255,.28),0 14px 30px rgba(0,0,0,.5);
  outline:none
}
.auth-form .btn-primary,.auth-form .btn-secondary,.auth-form .btn-ghost{
  width:100%;padding:15px 0;margin-top:10px;font-size:1.05rem
}

/* 2FA inputs */
.two-fa-inputs{display:flex;justify-content:center;gap:10px;margin:12px 0 10px}
.two-fa-inputs input{
  width:52px;aspect-ratio:1/1;text-align:center;font-size:1.35rem;border-radius:12px;border:none;
  background:rgba(255,255,255,.08);color:#fff;outline:none;
  box-shadow:inset 0 4px 10px rgba(255,255,255,.18),0 10px 20px rgba(0,0,0,.35);
}

/* Register modal */
.hide{display:none!important}
#register-modal{
  position:fixed;inset:0;background:rgba(7,20,28,.86);
  display:flex;align-items:center;justify-content:center;z-index:100
}
.modal-content{
  background:rgba(14,31,43,.95);
  border-radius:20px;
  padding:28px 22px;
  max-width:360px;text-align:center;
  box-shadow:var(--shadow);
  border:1px solid rgba(255,255,255,.1)
}
.modal-content h3{font-size:1.4rem;margin-bottom:12px;color:#eaf2f9}
.modal-content p{font-size:1rem;color:#cfe3f0;margin-bottom:16px;line-height:1.45}
.modal-content a{display:inline-block;font-weight:700}
.modal-content .btn-primary{
  background:linear-gradient(135deg,#f5de9a,#e9c76a);
  color:#0b1013;
  box-shadow:0 10px 24px rgba(233,199,106,.35);
}

/*─────────────────────────────────────────────────────────────────────────────
  Dashboard / Pilot Panel
─────────────────────────────────────────────────────────────────────────────*/
.profile-card{
  position:relative;
  display:grid;
  grid-template-columns:120px auto;
  gap:28px;
  align-items:center;
}
.profile-card .avatar img{width:120px;height:120px;border-radius:50%;object-fit:cover}
.profile-card .avatar-placeholder{
  width:120px;height:120px;background:var(--muted);color:var(--bg);
  border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:3rem
}
.profile-card .info h2{font-size:2rem;margin-bottom:10px}
.profile-card .info p{margin:6px 0;font-size:1.05rem;line-height:1.4}
.profile-card .info .action-buttons{margin-top:18px;display:flex;gap:12px}
.profile-card .info .action-buttons .btn-secondary,
.profile-card .info .action-buttons .btn-primary{min-width:140px}

/* Акцентный бокс под описание */
.info-box{
  background:var(--bg-2);
  border-radius:14px;
  padding:14px 16px;
  margin:12px 0;
  border-left:4px solid var(--gold);
  box-shadow:var(--shadow);
}
.info-box-title{font-weight:700;color:var(--gold);margin-bottom:6px}
.info-box-body{line-height:1.55}

/* Company Stats */
.company-stats{
  background:var(--glass);
  border-radius:24px;
  padding:32px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
  margin-bottom:36px;
  text-align:center;
}
.company-stats h3{font-size:1.4rem;margin-bottom:16px}
.company-stats .company-info{display:flex;align-items:center;gap:20px;justify-content:center}
.company-stats .company-avatar img{width:110px;height:110px;border-radius:50%;object-fit:cover}
.company-stats .company-details{text-align:left}
.company-stats .company-details p{margin:6px 0;font-size:1.05rem}
.company-stats .company-details .btn-secondary{margin-top:12px}

/* Company Actions */
.company-actions{text-align:center;margin-bottom:36px}
.company-actions h3{font-size:1.4rem;margin-bottom:16px}
.company-actions .btn-secondary,.company-actions .btn-primary{margin:8px;min-width:200px}

/* Flights list */
.flights-section{background:var(--glass);border-radius:24px;padding:32px;box-shadow:var(--shadow);backdrop-filter:blur(10px)}
.flights-section h2{font-size:1.6rem;margin-bottom:18px}
.flights-list{list-style:none;margin:0 0 24px;padding:0}
.flights-list li{background:var(--card);padding:18px 20px;border-radius:16px;margin-bottom:14px;box-shadow:var(--shadow)}
.flights-list li a{display:flex;justify-content:space-between;color:#e8eef2;font-size:1.05rem}
.flights-list li a:hover{background:rgba(255,255,255,.05)}
.pagination{display:flex;gap:12px;justify-content:center;margin:14px 0 6px}
.pagination .page-link{
  padding:10px 14px;background:var(--glass);color:var(--gold);
  text-decoration:none;box-shadow:var(--shadow);border-radius:12px;font-size:1.05rem;transition:background .2s
}
.pagination .page-link:hover{background:rgba(255,255,255,.1)}
.pagination .page-link.active{background:rgba(212,178,92,.3);color:#0b1013}

/*─────────────────────────────────────────────────────────────────────────────
  Company List
─────────────────────────────────────────────────────────────────────────────*/
.company-list ul{
  list-style:none;
  margin:0; padding:0;
  display:grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); /* ровная сетка */
  gap:20px;
  align-items: stretch; /* карточки одной высоты по строке */
}

.company-list li{
  margin:0; padding:0;
  /* убрали flex-basis/max-width, чтобы не ломать сетку */
}

.company-list li > a{
  display:flex; align-items:center; gap:16px;
  background:var(--card);
  border-radius:16px;
  padding:16px;
  box-shadow:var(--shadow);
  transition:transform .2s, box-shadow .2s;
  width:100%;             /* занимает всю ячейку */
  height:100%;            /* тянется по высоте */
}

.company-list li > a:hover{
  transform:translateY(-2px) scale(1.02);
  box-shadow:0 28px 56px rgba(0,0,0,.6);
}

.company-list .company-avatar{flex:0 0 auto}
.company-list .company-avatar img,
.company-list .company-avatar .avatar-placeholder{
  width:64px; height:64px; border-radius:50%; object-fit:cover;
  background:var(--muted); color:var(--bg);
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem;
}
.company-list .company-info h3{
  font-size:1.2rem; margin:0 0 6px; color:#eaf2f2;
  display:flex; align-items:center; gap:6px;
}
/* два строки текста — визуально ровные карточки по высоте */
.company-list .company-info p{
  font-size:.95rem; margin:0; color:#cfe3f0; line-height:1.4;
  display:-webkit-box; -webkit-box-orient:vertical; -webkit-line-clamp:2;
  overflow:hidden;
}

/* пагинация без изменений */
.company-list .pagination{
  display:flex; gap:12px; justify-content:center; margin-top:22px;
}
.company-list .pagination .page-link{
  padding:10px 14px; background:var(--glass); color:var(--gold);
  border-radius:12px; text-decoration:none; box-shadow:var(--shadow);
}
.company-list .pagination .page-link:hover,
.company-list .pagination .page-link.active{
  background:rgba(212,178,92,.3); color:#0b1013;
}

/* Мобилка: карточка на всю ширину контейнера */
@media (max-width: 640px){
  .company-list ul{ grid-template-columns: 1fr; gap:12px; }
}

/*─────────────────────────────────────────────────────────────────────────────
  Company Profile (rating badge fix + инфобоксы)
─────────────────────────────────────────────────────────────────────────────*/
.company-profile .glass-card{display:grid;grid-template-columns:120px auto;gap:24px;align-items:center;margin-bottom:28px}
.company-profile>img{width:120px;height:120px;border-radius:12px;object-fit:cover}
.company-title{display:inline-flex;align-items:center;gap:6px}
.rating-badge{width:18px;height:18px;display:inline-block;vertical-align:middle;object-fit:contain;cursor:help}
.company-profile .rating-badge{width:18px!important;height:18px!important;border-radius:0!important}

/* Pilot list */
.pilot-list{margin-bottom:28px}
.pilot-list h3{margin-bottom:12px}
.pilot-list ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.pilot-list li{
  display:flex;align-items:center;gap:12px;padding:12px 16px;max-width:420px;background:var(--card);
  border-radius:12px;box-shadow:var(--shadow);margin:0
}
.pilot-list li>a{display:flex;align-items:center;gap:12px;width:100%}
.pilot-list .pilot-avatar img{width:64px;height:64px;border-radius:50%;object-fit:cover}
.pilot-list .pilot-avatar .avatar-placeholder{
  width:64px;height:64px;background:var(--muted);color:var(--bg);
  border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem
}
.pilot-list .pilot-info{flex:1;display:flex;flex-direction:column;justify-content:center}
.pilot-list .pilot-info h4{font-size:1rem;margin:0;color:#eaf2f2}
.pilot-list .pilot-info p{font-size:.92rem;margin:2px 0;color:#cfe3f0;line-height:1.3}
.badge-leader{display:inline-block;margin-left:8px;padding:2px 8px;font-size:.8rem;background:var(--green);color:#052e16;border-radius:999px;font-weight:700}

/*─────────────────────────────────────────────────────────────────────────────
  Company Settings (страница настроек + поля)
─────────────────────────────────────────────────────────────────────────────*/
.company-settings-page{
  background:var(--glass);
  border-radius:24px;
  padding:32px;
  box-shadow:var(--shadow);
  backdrop-filter:blur(10px);
  margin-bottom:36px;

  width:100%;          /* контент идёт на всю доступную ширину колонки */
  max-width:none;
  min-width:0;
}

.company-settings-page .settings-content{
  background:var(--bg-2);
  border-radius:16px;
  padding:30px;
  box-shadow:var(--shadow);
  width:100%;
  max-width:none;
  min-width:0;
}

/* внутренний грид настроек (если вдруг нужен) */
.settings-layout{
  display:grid;
  grid-template-columns:300px minmax(0,1fr);
  gap:32px;
  align-items:start;
}
.settings-layout > *{min-width:0}
@media (max-width:992px){
  .settings-layout{grid-template-columns:1fr;gap:16px}
}

/* Поля «Общие настройки» */
.settings-content .edit-info-form label{display:block;margin-bottom:6px;color:#d9e9f4}
.settings-content .edit-info-form{
  display:grid;
  grid-template-columns:1fr;
  gap:16px;
  max-width:720px;     /* аккуратная читаемая ширина формы */
}

.company-settings-page input[type="text"],
.company-settings-page textarea,
.company-settings-page select{
  display:block;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  padding:12px 14px;
  border:none;
  border-radius:12px;
  background:rgba(255,255,255,0.06);
  color:#eaf2f9;
  font-size:1rem;
  outline:none;
}

.company-settings-page textarea{
  min-height:140px;
  resize:vertical;
}
.settings-content .edit-info-form textarea{min-height:140px}
.settings-content .edit-info-form .btn-primary{margin-top:6px}

/* Заявки */
.settings-content .join-requests-list .request-card{margin-bottom:16px}
.settings-content .join-requests-list .request-card h4{font-size:1.15rem;margin-bottom:6px}
.settings-content .join-requests-list .request-card p{color:#cfe3f0;margin-bottom:10px}
.settings-content .join-requests-list .request-card .buttons{display:flex;gap:12px}

/* Блок удаления */
.settings-content .delete-company{margin-top:28px;text-align:center}
.settings-content .delete-company p{color:#ff6b6b;font-size:1rem;margin-bottom:12px}
.settings-content .delete-company input[type="text"]{
  width:100%;max-width:460px;padding:12px;margin-bottom:12px;border:none;border-radius:12px;
  background:rgba(255,255,255,.05);color:#eaf2f9;font-size:1rem
}
.settings-content .delete-company .btn-ghost{margin-top:8px}

/* Рейтинг */
.rating-request{background:var(--bg-2);padding:20px;border-radius:16px;line-height:1.55}
.rating-request p,.rating-request ul{margin-bottom:12px;color:#cfe3f0}
.rating-request ul{padding-left:18px}
.rating-request ul li{list-style:inside disc}
.rating-request a{color:var(--gold);text-decoration:underline}

/*─────────────────────────────────────────────────────────────────────────────
  Responsive
─────────────────────────────────────────────────────────────────────────────*/
@media (max-width:992px){
  .layout{display:block;}        /* отключаем flex-поток, чтобы сайдбар стал выезжающим */
  .menu-toggle{display:inline-block}
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;width:260px;z-index:120;
    transform:translateX(-110%);transition:transform .25s ease;
    border-right:1px solid rgba(255,255,255,.08)
  }
  .sidebar.open{transform:translateX(0)}
}

@media (max-width:768px){
  .container{width:95%;margin:30px auto;padding:0 12px}
  .glass-card,.flights-section,.company-stats,.pilot-list,.company-settings-page{padding:22px;margin-bottom:26px}
  .btn-primary{padding:14px 22px;font-size:1.05rem}
  .btn-secondary,.btn-ghost{padding:12px 18px;font-size:1rem}
  .auth-form{margin:30px auto;padding:26px 18px}
  .auth-form h2{font-size:1.6rem;margin-bottom:14px}
  .auth-form input,.auth-form textarea{padding:12px;font-size:.98rem}
  .two-fa-inputs input{width:48px}

  .profile-card{grid-template-columns:1fr;text-align:center}
  .profile-card .avatar img,.profile-card .avatar-placeholder{width:100px;height:100px;font-size:2.5rem;margin:0 auto}
  .company-profile .glass-card{grid-template-columns:90px auto}
  .company-profile>img{width:90px;height:90px}
}

@media (max-width:480px){
  .container{margin:18px auto}
  .btn-primary{padding:12px 18px;font-size:1rem}
  .btn-secondary,.btn-ghost{padding:10px 14px;font-size:.95rem}
  .auth-form{margin:20px auto;padding:20px 14px}
  .auth-form h2{font-size:1.45rem;margin-bottom:12px}
  .auth-form input,.auth-form textarea{padding:11px;font-size:.95rem}
  .two-fa-inputs{gap:8px}
  .two-fa-inputs input{width:44px;font-size:1.25rem}

  .profile-card .avatar img,.profile-card .avatar-placeholder{width:84px;height:84px;font-size:2rem}
  .company-stats .company-avatar img,.company-profile>img{width:80px;height:80px}
  .flights-section h2{font-size:1.2rem}
  .pilot-list .pilot-info h4{font-size:1rem}
  .pilot-list .pilot-info p{font-size:.9rem}
}

/* ─────────────────────────────────────────────
   Admin Reports — форма / бейджи / сайдбар
   ───────────────────────────────────────────── */

.admin-form { display: flex; flex-direction: column; gap: 14px; }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.form-field { display: flex; flex-direction: column; gap: 6px; }

.form-label {
  font-size: 12px;
  color: #9ca3af; /* muted */
}

.form-input {
  width: 100%;
  padding: 10px 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px;
  color: inherit;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.form-input:focus {
  border-color: rgba(59,130,246,.65);
  box-shadow: 0 0 0 3px rgba(59,130,246,.25);
  background: rgba(255,255,255,.08);
}

.form-input[type=number]::-webkit-outer-spin-button,
.form-input[type=number]::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.form-input[type=number] { -moz-appearance: textfield; }

.form-actions {
  display: flex;
  gap: 12px;
  margin-top: 4px;
}

/* Бейджи статуса */
.badge {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 12px;
}
.badge-ai  { background: #f59e0b; color: #111827; }
.badge-mod { background: #16a34a; color: #fff; }

/* Сайдбар — визуально синхронизируем стиль пунктов */
.sidebar .side-link {
  display: block;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid transparent;
  transition: background .15s ease, border-color .15s ease, color .15s ease;
}
.sidebar .side-link:hover {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
}
.sidebar .side-link.active {
  background: rgba(59,130,246,.15);
  border-color: rgba(59,130,246,.35);
  color: #e5f0ff;
}

/* Адаптив формы */
@media (max-width: 980px) {
  .form-grid { grid-template-columns: 1fr; }
}

/* --- Tickets --- */
.table.responsive { display:grid; gap:8px; }
.table .thead, .table .trow { display:grid; grid-template-columns: 72px 160px 1fr 180px 140px 110px; gap:8px; align-items:center; }
.table .thead { font-weight:600; color:#6b7280; }
.table .trow {
  padding:10px 12px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  overflow: hidden; /* ← фикс вылезания кнопки за карточку */
}
.ellipsis { white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

.badge { display:inline-block; padding:2px 8px; border-radius:999px; font-size:12px; line-height:18px; border:1px solid transparent; }
.badge-muted { color:#9ca3af; border-color:#374151; background:transparent; }
.badge-prio-low { background:#0ea5e90d; color:#38bdf8; border-color:#0ea5e933; }
.badge-prio-medium { background:#eab30814; color:#facc15; border-color:#eab30844; }
.badge-prio-high { background:#ef44441a; color:#f87171; border-color:#ef444455; }

.ticket-status-pending { background:#64748b1a; color:#cbd5e1; border-color:#475569; }
.ticket-status-confirmed { background:#22c55e1a; color:#86efac; border-color:#16a34a; }
.ticket-status-fixed { background:#22c55e1a; color:#86efac; border-color:#16a34a; }
.ticket-status-not_repro { background:#ef44441a; color:#fca5a5; border-color:#ef4444; }
.ticket-status-roadmap { background:#38bdf81a; color:#7dd3fc; border-color:#0ea5e9; }
.ticket-status-rejected { background:#ef44441a; color:#fca5a5; border-color:#ef4444; }
.ticket-status-implemented { background:#22c55e1a; color:#86efac; border-color:#16a34a; }
.ticket-status-answered { background:#a78bfa1a; color:#c4b5fd; border-color:#8b5cf6; }

.kv { display:grid; grid-template-columns: 220px 1fr; gap:10px 16px; margin-top:8px; }
.pre { white-space:pre-wrap; word-wrap:break-word; background:rgba(255,255,255,.03); padding:8px 10px; border-radius:10px; border:1px solid rgba(255,255,255,.08); }
.img-preview-clickable { max-width:360px; width:100%; height:auto; border-radius:12px; cursor:zoom-in; box-shadow:0 6px 20px rgba(0,0,0,.18); }

/* forms reuse */
.admin-form .form-grid { display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.form-field { display:flex; flex-direction:column; gap:6px; }
.form-label { font-size:13px; color:#9ca3af; }
.form-input { width:100%; border-radius:10px; border:1px solid rgba(255,255,255,.12); background:rgba(255,255,255,.04); padding:10px 12px; color:#e5e7eb; }
.form-actions { display:flex; gap:12px; margin-top:12px; }

/* mobile */
@media (max-width: 900px) {
  .table .thead, .table .trow { grid-template-columns: 64px 120px 1fr 160px 120px 96px; }
  .kv { grid-template-columns: 1fr; }
  .admin-form .form-grid { grid-template-columns: 1fr; }
  .img-preview-clickable { max-width:100%; }
}

/* --- Tickets table: fix button clipping & layout --- */
.table .trow {
  /* отменяем прежний overflow:hidden, чтобы не обрезать кнопку */
  overflow: visible !important;
  display: grid;
  grid-template-columns: 72px 150px 1fr 180px 190px auto; /* ID | Тип | Название | Статус | Дата | Кнопка */
  align-items: center;
  gap: 8px 14px;
}

/* чтобы кнопка не вылезала за скругления карточки даже без overflow */
.table .trow .btn,
.table .trow .btn-secondary,
.table .trow .btn-primary {
  /* вместо внешнего свечения — “внутренняя” рамка */
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.18);
  outline: none;
}

/* чувствительный текст в ячейках не ломает сетку */
.table .trow .cell {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* последняя колонка с кнопкой прижимается вправо */
.table .trow .cell:last-child {
  justify-self: end;
}

/* ---------- MOBILE (<= 720px) ---------- */
@media (max-width: 720px) {
  /* прячем шапку таблицы: слишком тесно на мобилке */
  .table .thead { display: none; }

  .table .trow {
    grid-template-columns: 1fr auto;     /* контент | кнопка */
    grid-template-rows: auto auto auto;  /* заголовок, мета1, мета2 */
    gap: 8px 10px;
    padding: 12px;
  }

  /* если в вёрстке есть семантические классы — используем их */
  .table .trow .cell-title   { grid-column: 1 / 2; grid-row: 1; font-weight: 600; }
  .table .trow .cell-status  { grid-column: 1 / 2; grid-row: 2; }
  .table .trow .cell-created { grid-column: 1 / 2; grid-row: 3; opacity: .8; }

  /* ID и тип переносим в “метаданные” в одну строку помельче */
  .table .trow .cell-id,
  .table .trow .cell-type {
    grid-column: 1 / 2;
    grid-row: 2;
    display: inline-flex;
    gap: 10px;
    font-size: 12px;
    opacity: .85;
  }

  /* fallback, если в разметке нет этих классов — раскладываем по nth-child */
  .table .trow .cell:nth-child(3) { grid-column: 1 / 2; grid-row: 1; } /* Название */
  .table .trow .cell:nth-child(4) { grid-column: 1 / 2; grid-row: 2; } /* Статус  */
  .table .trow .cell:nth-child(5) { grid-column: 1 / 2; grid-row: 3; } /* Дата    */

  .table .trow .cell:nth-child(1),  /* ID  */
  .table .trow .cell:nth-child(2) { /* Тип */
    grid-column: 1 / 2;
    grid-row: 2;
    display: inline-flex;
    gap: 10px;
    font-size: 12px;
    opacity: .85;
  }

  /* кнопка — во второй колонке, по центру по вертикали */
  .table .trow .cell:last-child {
    grid-column: 2 / 3;
    grid-row: 1 / 4;
    align-self: center;
    justify-self: end;
  }

  /* кнопка компактнее на телефоне */
  .table .trow .btn,
  .table .trow .btn-secondary,
  .table .trow .btn-primary {
    padding: 10px 14px;
    font-size: 14px;
  }
}

/* --- Select dropdown: readable text in popup list --- */
select,
select.form-input,
.form-select {
  color: #e5e7eb;                  /* текст в самом поле select */
  background-color: #0f1a22;
}

/* Цвета элементов выпадающего списка (Chrome/Edge/Firefox) */
select option,
select optgroup {
  background-color: #0f1a22 !important;
  color: #e5e7eb !important;
}

/* Ослабляем disabled-пункты */
select option:disabled {
  color: rgba(229, 231, 235, .45) !important;
}

/* -------- Badges / counters -------- */
.badge-counter{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 6px;margin-left:8px;
  border-radius:999px;background:#1f2d3a;color:#e5e7eb;font-size:12px;
  border:1px solid rgba(255,255,255,.08)
}

/* -------- Lists with split rows -------- */
.list{display:flex;flex-direction:column;gap:10px}
.list-divided .list-row{display:flex;gap:12px;align-items:center;justify-content:space-between;
  padding:12px;border:1px solid rgba(255,255,255,.06);border-radius:12px;background:rgba(255,255,255,.02)}
.row-left .title{font-weight:600}
.row-left .sub{opacity:.75;font-size:.92rem;margin-top:2px}

/* -------- Stars -------- */
.stars{display:inline-flex;gap:4px;align-items:center}
.stars input{position:absolute;opacity:0;pointer-events:none}
.stars label{font-size:20px;cursor:pointer;opacity:.6;transition:opacity .15s, transform .15s}
.stars-large label{font-size:26px}
.stars input:checked ~ label{opacity:.6}
.stars label:hover, .stars input:focus + label, .stars label:has(~ input:checked){opacity:1;transform:scale(1.05)}
/* упрощённая подсветка при выборе */
.stars input:checked + label, .stars label:has(+ input:checked){opacity:1}

/* -------- Forms in rows -------- */
.rating-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.rating-form .form-input{min-height:36px}

/* -------- Modal -------- */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;align-items:center;justify-content:center;z-index:9999;padding:16px}
.modal.open{display:flex}
.modal-card{width:min(720px,100%);background:#0e1720;border:1px solid rgba(255,255,255,.08);border-radius:16px;box-shadow:0 20px 60px rgba(0,0,0,.35);overflow:hidden}
.modal-head{padding:16px 18px;font-weight:600;border-bottom:1px solid rgba(255,255,255,.06)}
.modal-body{padding:16px 18px;display:flex;flex-direction:column;gap:12px}
.modal-actions{display:flex;gap:10px;justify-content:flex-end}

/* -------- Workbook cards -------- */
.workbook .wb-item{padding:12px;border:1px solid rgba(255,255,255,.06);border-radius:12px;background:rgba(255,255,255,.02);margin-bottom:10px}
.wb-row{display:flex;justify-content:space-between;gap:12px;align-items:center}
.wb-title{font-weight:600}
.wb-sub{opacity:.7}
.wb-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:8px}
.wb-grid span{opacity:.7;margin-right:6px}
.chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;background:rgba(255,255,255,.08);font-size:.85rem}

/* Responsive: convert list rows to column layout on small screens */
@media (max-width: 640px){
  .list-divided .list-row{flex-direction:column;align-items:flex-start}
  .rating-form{width:100%}
  .rating-form .form-input{flex:1;min-width:0}
  .wb-grid{grid-template-columns:1fr}
}

/* danger buttons */
.btn-danger,
.btn-danger-outline {
  display:inline-flex;align-items:center;justify-content:center;
  text-align:center;cursor:pointer;border-radius:16px;font-weight:600;
  transition:transform .2s,background .2s,color .2s,box-shadow .2s;
  padding:14px 28px;font-size:1.05rem;background:transparent;
  border:2px solid rgba(255,255,255,.22);
}

/* заливка */
.btn-danger { background: #dc2626; color: #fff; border: 1px solid transparent; }
.btn-danger:hover { background: #b91c1c; }

/* outline */
.btn-danger-outline {
  background: transparent;
  color: #dc2626;
  border: 1px solid #dc2626;
}
.btn-danger-outline:hover {
  background: #fee2e2;
}

/* маленькие бейджи/статусы */
.badge {
  display:inline-flex; align-items:center;
  font-size:12px; font-weight:600;
  border-radius:999px; padding:4px 8px;
}
.badge-ok { background:#e9fbe7; color:#166534; }
.badge-warn { background:#fff7ed; color:#9a3412; }
.badge-ai { background:#eef2ff; color:#3730a3; }

/* ─── Fix: крупный логотип в шапке и скрыть текст рядом ─── */
nav.topbar .brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

nav.topbar .brand > img.brand {
  height: 80px !important;
  max-height: 80px !important;
  width: auto !important;
  vertical-align: middle;
  display: inline-block;
}

@media (max-width: 480px) {
  nav.topbar .brand > img.brand {
    height: 64px !important;
    max-height: 64px !important;
  }
}

/* Убираем подпись "Aeronation" рядом с логотипом */
nav.topbar .brand > span {
  display: none !important;
}

/* --- Gap fix: между топбаром и контентом --- */
nav.topbar {
  padding-block: 2px !important;        /* меньше вертикальный паддинг у шапки */
  margin-bottom: 2px !important;        /* ниже шапки — небольшой отступ */
}

/* основной контент сразу за шапкой — без лишнего верха */
.topbar + main.container {
  margin-top: 0 !important;
  padding-top: 2px !important;          /* небольшой «воздух» */
}

/* внутри main не даём дополнительного сдвига макета вверх */
main.container > .layout {
  margin-top: 0 !important;
}

.topbar .brand-link { display: inline-flex; align-items: center; line-height: 0; }
.topbar .brand .brand-logo { height: 80px; width: auto; display: block; flex-shrink: 0; }
@media (max-width: 640px) {
  .topbar .brand .brand-logo { height: 64px; }
}

.btn-vk{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:10px;
  background:#07f; color:#fff; font-weight:600;
  text-decoration:none; box-shadow:0 6px 20px rgba(7,127,255,.35);
  transition:transform .08s ease, box-shadow .2s ease, opacity .2s ease;
}
.btn-vk:hover{ transform:translateY(-1px); box-shadow:0 8px 24px rgba(7,127,255,.45); }
.btn-vk:active{ transform:translateY(0); opacity:.9; }
.btn-vk .vk-ico{ width:20px; height:20px; fill:#fff; }

/* ─── Admin Reports: responsive layout for mobile ─── */
.report-check-grid{
  display:grid;
  grid-template-columns: minmax(320px, 520px) 1fr;
  gap:16px;
  align-items:start;
}
.report-img{
  width:100%; height:auto;
  border-radius:12px;
  cursor:zoom-in;
  box-shadow:0 6px 20px rgba(0,0,0,.18);
}

/* мобильная адаптация */
@media (max-width: 980px){
  .report-check-grid{ grid-template-columns: 1fr; }

  /* превью не выше 60% экрана — удобно смотреть и скроллить к форме */
  .report-img{ max-height:60vh; object-fit:contain; }

  /* кнопки всегда под рукой */
  .report-actions{
    position: sticky;
    bottom: 0;
    padding-top: 8px;
    background: linear-gradient(180deg, rgba(7,20,28,0), rgba(7,20,28,.88));
    backdrop-filter: blur(2px);
    gap: 10px;
    z-index: 5;
    display: flex;
    flex-wrap: wrap;
  }
  .report-actions .btn-primary,
  .report-actions .btn-secondary{ width:100%; }
}

/* чуть крупнее кнопка закрытия на маленьких экранах */
@media (max-width: 480px){
  #imgModalClose{ padding:10px 12px; font-size:14px; }
}

/* === Notifications UI === */
.top-actions{display:flex; align-items:center; gap:12px;}
.notif-wrap{position:relative;}
.notif-bell{
  position:relative;
  background:transparent;
  border:2px solid rgba(255,255,255,.25);
  color:#e8eef2;
  border-radius:12px;
  padding:8px 12px;
  cursor:pointer;
  line-height:1;
}
.notif-badge{
  position:absolute;
  top:-6px; right:-6px;
  min-width:18px; height:18px;
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--red);
  color:#fff; font-size:12px; border-radius:999px;
  padding:0 6px; box-shadow:0 0 0 2px rgba(7,20,28,.9);
}
.notif-dropdown{
  position:absolute;
  top:calc(100% + 10px);
  right:0;
  width:min(92vw, 380px);
  max-height:70vh;
  overflow:auto;
  background:var(--bg-2);
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  box-shadow:0 16px 40px rgba(0,0,0,.45);
  z-index:500;
}
.notif-head{
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.08);
  font-weight:700; color:#eaf2f9;
}
.notif-list{display:flex; flex-direction:column;}
.notif-empty{padding:14px; color:#cfe3f0; opacity:.85}
.notif-item{
  position:relative;
  display:block;
  padding:10px 12px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.notif-item:last-child{border-bottom:none}
.notif-item:hover{background:rgba(255,255,255,.04)}
.notif-msg{line-height:1.35; color:#e8eef2}

/* компактная "крошка" компании (лого+название) */
.notif-co{
  display:flex; align-items:center; gap:8px;
  font-size:.88rem; color:#cfe3f0; opacity:.85; margin-bottom:6px;
}
.notif-co img{
  width:16px; height:16px; border-radius:50%; object-fit:cover;
  display:block;
}

/* красная точка «непрочитано», справа по центру */
.unread-dot{
  position:absolute;
  right:10px; top:50%;
  transform:translateY(-50%);
  width:8px; height:8px; border-radius:50%;
  background:var(--red);
  box-shadow:0 0 0 2px rgba(7,20,28,.9);
}

/* на очень узких экранах — растягиваем по ширине */
@media (max-width: 420px){
  .notif-dropdown{ width:min(96vw, 360px); }
}

/* Мобилки: дропдаун привязываем к вьюпорту, чтобы не вылезал влево/вправо */
@media (max-width: 640px){
  .notif-dropdown{
    position: fixed;           /* вместо absolute — к вьюпорту */
    top: calc(env(safe-area-inset-top) + 64px); /* ниже шапки, с учётом вырезов */
    left: 12px;
    right: 12px;
    width: auto;               /* ширина = ширине экрана минус отступы */
    max-width: none;           /* снимаем прежний max-width */
    max-height: calc(100vh - 96px);
  }
}

/* --- OAuth секция --- */
.oauth-sep {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 16px 0 12px;
  color: #6b7280;               /* нейтральный серый */
  font-size: 14px;
}
.oauth-sep::before,
.oauth-sep::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #e5e7eb;          /* тонкая линия */
}

.oauth-providers {
  display: flex;
  justify-content: center;      /* центрируем кнопку */
  gap: 12px;
}

/* --- VK ID icon button --- */
.vkid-icon-btn {
  width: 40px;                  /* small size из гайдов: 32–40px */
  height: 40px;
  border-radius: 50%;
  background: #0077FF;          /* Azure/A100 — фирменный */
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  text-decoration: none;
  box-shadow: 0 1px 2px rgba(0,0,0,.06), 0 1px 1px rgba(0,0,0,.08);
  transition: transform .08s ease, opacity .08s ease;
}
.vkid-icon-btn:hover { opacity: .9; }
.vkid-icon-btn:active { transform: scale(.97); }
.vkid-icon-btn:focus-visible {
  outline: 2px solid rgba(0,119,255,.35);
  outline-offset: 3px;
}
.vkid-icon-btn svg { display: block; }

.footer .footer-inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:16px; border-top:1px solid rgba(255,255,255,.08);
}
.footer .lang-switcher select{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12);
  color:#e8eef2; padding:8px 10px; border-radius:10px; outline:none;
}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}

/* ===================== Company Cover (VK-like) ===================== */
.company-cover{
  position: relative;
  width: 100%;
  max-width: 1100px;      /* не тянем на всю ширину — меньше заметны пиксели */
  height: clamp(140px, 22vw, 220px);
  margin: 0 auto 18px;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: var(--shadow);
  background: var(--bg-2);
}
.company-cover-img{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit: cover; object-position: center;
  image-rendering: auto;           /* не «вырвиглаз» */
  transform: translateZ(0);        /* сгладить на некоторых GPU */
}
.company-cover-ph{ position:absolute; inset:0; background:linear-gradient(135deg,#162934,#0e1f2b); }

/* мягкая виньетка, как у ВК */
.company-cover-overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,0) 35%, rgba(0,0,0,.18) 100%);
  pointer-events:none;
}

/* лёгкий «паттерн», чтобы скрыть лесенку на однотонных зонах */
.company-cover-noise{
  position:absolute; inset:0; pointer-events:none; opacity:.18;
  background-image:
    radial-gradient(rgba(255,255,255,.25) 1px, transparent 1px),
    radial-gradient(rgba(255,255,255,.12) 1px, transparent 1px);
  background-size: 12px 12px, 24px 24px;
  background-position: 0 0, 6px 6px;
  mix-blend-mode: soft-light;
}

/* хедер поверх шапки */
.company-head{
  position:absolute; left:18px; bottom:12px;
  display:flex; align-items:center; gap:14px;
}
.company-head-avatar{
  width:72px; height:72px; border-radius:12px; overflow:hidden;
  box-shadow:0 10px 24px rgba(0,0,0,.45);
  background:#11222d; display:flex; align-items:center; justify-content:center; font-weight:800; font-size:28px; color:#fff;
}
.company-head-avatar img{ width:100%; height:100%; object-fit:cover; }
.company-head-avatar .ph{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; }

.company-head-text .company-name{
  font-size:1.35rem; font-weight:800; letter-spacing:.2px; text-shadow:0 2px 6px rgba(0,0,0,.35);
}
.company-head-text .company-sub{
  margin-top:2px; font-size:.95rem; text-shadow:0 1px 3px rgba(0,0,0,.35);
}

/* на мобилках чуть компактнее */
@media (max-width: 520px){
  .company-head-avatar{ width:60px; height:60px; }
  .company-head-text .company-name{ font-size:1.15rem; }
}

/* отступ под аватар, чтобы было куда наезжать */
.company-cover{ margin-bottom: 44px; }

/* поднимаем аватар поверх шапки */
.company-head{
  margin-top: -44px;     /* величина наезда */
  position: relative;
  z-index: 5;            /* выше шапки */
}
@media (max-width:520px){
  .company-head{ margin-top:-38px; }
}

/* базовая чёткость всегда */
.company-cover-img{
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  transform: none !important;            /* убираем translateZ/scale и т.п. */
  backface-visibility: hidden;
  transition: none !important;           /* чтобы hover не перерисовывал */
  filter: none !important;
}

/* на :hover ничем не отличаемся от обычного состояния */
.company-cover:hover .company-cover-img{
  transform: none !important;
  filter: none !important;
}

/* Поднимаем именно аватар поверх шапки */
.company-head{ position: relative; z-index: 2; }

.company-head .avatar,
.company-head .company-avatar,
.company-head .company-logo{
  margin-top: -56px;        /* величина наезда — при необходимости подправь */
  z-index: 3;
}
@media (max-width:520px){
  .company-head .avatar,
  .company-head .company-avatar,
  .company-head .company-logo{ margin-top: -56px; }
}

/* --- FIX: аватар наезжает на шапку + чёткость всегда --- */

/* даём место под наезд */
.company-cover{
  transform: none !important;       /* чтобы не было ресемплинга при hover */
}

/* поднимаем блок с аватаром поверх шапки */
.company-logo{
  position: relative !important;    /* переопределяем раннее absolute */
  left: 0px;                        /* как и было визуально */
  bottom: auto !important;           /* сбросить старое bottom */
  margin-top: -150px !important;      /* тот же размер, что и margin-bottom у cover */
  z-index: 5;
}

/* гарантируем, что именно наш аватар выше шапки */
.company-head-avatar{ position: relative; z-index: 6; }

/* картинка шапки — без каких-либо «наводок» */
.company-cover, .company-cover:hover{ transform:none !important; }
.company-cover-img{
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  transform: none !important;
  transition: none !important;
  filter: none !important;
}

/* ——— Компания: история полётов ——— */
.table-responsive{overflow-x:auto;-webkit-overflow-scrolling:touch}
.company-flights table{table-layout:fixed;width:100%}
.company-flights th,.company-flights td{vertical-align:middle}
.company-flights td .truncate{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* фикс ширины столбцов (десктоп/планшет) */
.company-flights th:nth-child(1), .company-flights td:nth-child(1){width:110px;white-space:nowrap}
.company-flights th:nth-child(2), .company-flights td:nth-child(2){width:140px;white-space:nowrap}
.company-flights th:nth-child(3), .company-flights td:nth-child(3){width:230px}
.company-flights th:nth-child(4), .company-flights td:nth-child(4){width:160px;white-space:nowrap}
.company-flights th:nth-child(5), .company-flights td:nth-child(5){width:140px;white-space:nowrap}
.company-flights th:nth-child(6), .company-flights td:nth-child(6){width:120px}

/* мобильная карточная раскладка */
@media (max-width: 720px){
  .company-flights table,
  .company-flights thead,
  .company-flights tbody,
  .company-flights th,
  .company-flights td,
  .company-flights tr{display:block}
  .company-flights thead{display:none}
  .company-flights tbody{display:block}
  .company-flights tr{
    border:1px solid rgba(255,255,255,.08);
    border-radius:12px;padding:10px;margin-bottom:10px;background:rgba(0,0,0,.06)
  }
  .company-flights td{
    display:flex;justify-content:space-between;gap:12px;padding:6px 0
  }
  .company-flights td::before{
    content:attr(data-label);font-weight:600;opacity:.7;margin-right:12px
  }
  .company-flights td:last-child{justify-content:flex-end;padding-top:10px}
}

.auth-overlay{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
    backdrop-filter:blur(6px);background:rgba(0,0,0,.55)}
  .auth-modal{width:min(520px,92vw);border-radius:18px;padding:22px;background:#0f172a;color:#e5e7eb;
    box-shadow:0 20px 60px rgba(0,0,0,.6);text-align:center}
  .auth-modal h3{margin:6px 0 8px;font-size:20px;font-weight:800}
  .auth-modal p{opacity:.85;font-size:14px;margin:0 0 16px}
  .auth-badge{width:44px;height:44px;border-radius:999px;margin:0 auto 8px;background:rgba(255,255,255,.06);
    display:flex;align-items:center;justify-content:center;font-size:20px}
  .auth-actions{display:flex;gap:10px;justify-content:center}
  .btn-auth{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:12px;
    font-weight:700;text-decoration:none}
  .btn-auth-primary{background:#10b981;color:#06251f}
  .btn-auth-secondary{background:#111827;border:1px solid rgba(255,255,255,.14);color:#e5e7eb}

  /* Premium CTA */
.btn-premium{
  display:inline-flex;align-items:center;justify-content:center;
  padding:16px 32px;border:none;border-radius:18px;cursor:pointer;
  background:linear-gradient(135deg,var(--gold-2),var(--gold));
  color:#0b1013;font-weight:800;font-size:1.1rem;
  box-shadow:0 18px 36px rgba(212,178,92,.35);
  transition:transform .2s,box-shadow .2s;
}
.btn-premium:hover{ transform:translateY(-2px) scale(1.03); box-shadow:0 24px 48px rgba(212,178,92,.45); }

/* Premium callout */
.premium-callout{ margin:14px 0 18px; background:var(--glass); border-radius:20px; padding:18px; box-shadow:var(--shadow); }
.premium-callout__title{ font-weight:800; font-size:1.2rem; margin-bottom:6px; }
.premium-callout__text{ color:#cfe3f0; margin-bottom:12px; }
.premium-tiers{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:12px; }
.tier{ display:block; }
.tier input{ display:none; }
.tier-box{
  background:rgba(255,255,255,.06); border:2px solid rgba(255,255,255,.12);
  border-radius:14px; padding:12px; transition:transform .15s,border-color .15s,background .15s;
}
.tier input:checked + .tier-box{ border-color:var(--gold); background:rgba(212,178,92,.12); }
.tier-name{ font-weight:700; margin-bottom:4px; }
.tier-price{ font-weight:800; }
.tier-note{ color:#cfe3f0; font-size:.95rem; }

/* Заглушки и блюр */
.premium-stubs{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:12px; }
@media (max-width: 900px){ .premium-stubs{ grid-template-columns:1fr; } }

.stub-card{
  position:relative; background:var(--glass); border-radius:18px; padding:16px; min-height:140px; overflow:hidden;
}
.stub-title{ font-weight:800; margin-bottom:6px; }
.stub-body{ color:#dfe9f3; min-height:90px; }

.stub-card.is-locked .stub-body{ filter: blur(2px); pointer-events:none; user-select:none; }
.lock-overlay{
  position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(180deg, rgba(7,20,28,.2), rgba(7,20,28,.6));
}
.lock-title{ font-weight:800; font-size:1.05rem; text-align:center; margin-bottom:6px; }
.lock-text{ color:#cfe3f0; text-align:center; margin-bottom:10px; }

/* ===================== HARD FIX: убираем второй скролл ===================== */

/* 1) Любые вложенные .layout НЕ считаем макетом страницы */
.layout .layout {
  display: block !important;
  gap: 0 !important;
  align-items: initial !important;
  overflow: visible !important; /* критично */
}

/* 2) И у их "внутреннего" сайдбара не даём sticky/фикс */
.layout .layout > .sidebar {
  position: static !important;
  top: auto !important;
  height: auto !important;
  align-self: initial !important;
  flex: initial !important;
  overflow: visible !important;
}

/* 3) Внутренний .content — обычный блок без собственного скролла */
.layout .layout > .content {
  flex: initial !important;
  min-width: 0 !important;
  overflow: visible !important;
}

/* 4) На всякий случай гасим любые явные вертикальные скроллы у крупных блоков,
      кроме белого списка (дропдауны/модалки и т.п.) */
:where(.glass-card, .table.responsive, .company-settings-page, .flights-section){
  overflow: visible !important;
}

/* 5) Шапки/табличные строки — без скрытия содержимого (причина исчезновений при перетаскивании ползунка) */
.table .trow,
.support-table .trow {
  overflow: visible !important;
}

/* Company search */
.company-search { margin: 0 0 14px; }
.company-search__wrap{
  position: relative;
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 14px;
  padding: 10px 12px 10px 40px;
  box-shadow: var(--shadow);
}
.company-search__wrap svg{
  position: absolute; left: 12px; width: 18px; height: 18px; opacity:.8; stroke:#cfe3f0; fill:none; stroke-width:2;
}
.company-search__wrap input{
  width: 100%; background: transparent; border: 0; outline: 0;
  color: #e8eef2; font-size: 1rem;
}
.company-search__wrap .clear{
  display:inline-flex; align-items:center; justify-content:center;
  width: 26px; height: 26px; border-radius: 999px;
  background: rgba(255,255,255,.08); text-decoration:none;
  font-weight:800; line-height:1; color:#cfe3f0;
}
.company-search__wrap .clear:hover{ background: rgba(255,255,255,.14); }
.page-ellipsis{ display:inline-flex; align-items:center; padding:0 4px; opacity:.7; }

/* Контейнер вокруг аватарки — без изменений */
.avatar-wrap {
  position: relative;
  display: inline-block;
  line-height: 0;
  overflow: visible;              /* важно! чтобы не обрезало */
  padding-right: 20px;            /* карман под вылет бейджа */
  margin-right: -20px;            /* вернули общий поток на место */
}
.avatar-wrap .avatar {
  display: block;
  border-radius: 50%;
  max-width: 100%;
  height: auto;
}

/* ОБНОВЛЁННЫЙ бейдж стаффа */
.avatar-wrap .staff-badge {
  position: absolute;
  top: -17%;
  right: 2%;                    /* может быть -12..-16% по вкусу */
  width: clamp(58px, 50%, 110px);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  z-index: 2;
}

.avatar-wrap .staff-badge img,
.avatar-wrap .staff-badge svg {
  max-width: 86%;
  max-height: 86%;
}

/* Мобильная мелкая аватарка */
@media (max-width: 420px) {
  .avatar-wrap .staff-badge {
    width: clamp(36px, 36%, 64px);
  }
}

/* ======================= Codeshare UI (isolated, responsive) ======================= */
.cs-h3{font-size:1.15rem;margin:10px 0;color:#eaf2f9;font-weight:800}

/* ---- Tabs ------------------------------------------------------------- */
.cs-tabs__bar{
  display:flex; align-items:center; gap:8px;
  margin:8px 0 14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  padding:6px; border-radius:14px; box-shadow:var(--shadow);
  overflow:visible;               /* desktop */
}
.cs-tabs__btn{
  appearance:none; border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  color:#e8eef2; padding:10px 14px; border-radius:10px; font-weight:800;
  cursor:pointer; transition:background .15s, border-color .15s, transform .15s;
  white-space:nowrap; flex:0 0 auto;      /* чтобы не сжимались подписи */
}
.cs-tabs__btn:hover{ background:rgba(255,255,255,.08); transform:translateY(-1px); }
.cs-tabs__btn.is-active{
  background:rgba(212,178,92,.16);
  border-color:rgba(212,178,92,.45);
  color:#fff;
}

.cs-tabs__panel{ display:none; }
.cs-tabs__panel.is-active{ display:block; }

/* ---- Grids / lists ---------------------------------------------------- */
.cs-grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; align-items:start; }
@media (max-width: 900px){ .cs-grid-2{ grid-template-columns:1fr; } }

.cs-list{ list-style:none; margin:10px 0; padding:0; display:flex; flex-direction:column; gap:10px; }
.cs-row{
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px; padding:12px;
}
.cs-row__left{ display:flex; align-items:center; gap:12px; min-width:0; }
.cs-row__right{ display:flex; gap:10px; flex-wrap:wrap; }
.cs-row__text .title{ font-weight:700; line-height:1.25; word-break:break-word; }
.cs-row__text .sub{ opacity:.8; font-size:.95rem; margin-top:2px; }

.cs-avatar{ width:42px; height:42px; border-radius:50%; overflow:hidden; flex:0 0 auto; background:#193241; display:flex; align-items:center; justify-content:center; }
.cs-avatar img{ width:100%; height:100%; object-fit:cover; display:block; }

.cs-stats{ display:flex; flex-wrap:wrap; gap:8px 12px; align-items:center; margin:0 0 12px; }

.cs-cards{
  list-style:none; margin:0; padding:0;
  display:grid; grid-template-columns:repeat(auto-fill, minmax(260px, 1fr)); gap:14px;
}
.cs-card{
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:14px; padding:12px; box-shadow:var(--shadow);
  display:flex; flex-direction:column; gap:10px;
}
.cs-card__img{ width:100%; height:auto; border-radius:12px; display:block; }
.cs-card__body{ display:flex; flex-direction:column; gap:6px; }
.cs-card__title{ font-weight:800; }
.cs-card__sub{ opacity:.85; font-size:.95rem; }
.cs-card__actions{ display:flex; gap:10px; flex-wrap:wrap; }

/* Пустые состояния */
.cs-empty{
  padding:12px; border:1px dashed rgba(255,255,255,.2);
  border-radius:12px; text-align:center; opacity:.85; background:rgba(255,255,255,.02);
}

/* ======================= MOBILE ADAPTIVE ======================= */
/* — Tabs: горизонтальный скролл, удобные тап-зоны — */
@media (max-width: 720px){
  .cs-tabs__bar{
    overflow-x:auto; overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scroll-snap-type:x proximity;
    padding:6px 6px;
    gap:6px;
  }
  .cs-tabs__bar::-webkit-scrollbar{height:0}
  .cs-tabs__btn{ padding:9px 12px; font-size:.95rem; scroll-snap-align:start; }
}

/* — Ряды списков: в колонку, кнопки на всю ширину — */
@media (max-width: 720px){
  .cs-row{
    flex-direction:column; align-items:stretch; gap:10px;
  }
  .cs-row__right{
    width:100%;
    display:grid; grid-template-columns:1fr 1fr; gap:8px;
  }
  .cs-row__right .btn-primary,
  .cs-row__right .btn-secondary{ width:100%; min-width:0; }
  .cs-avatar{ width:36px; height:36px; }
}

/* — На очень узких экранах кнопки в один столбец — */
@media (max-width: 420px){
  .cs-row__right{ grid-template-columns:1fr; }
}

/* — Карточки входящих отчётов: одна колонка — */
@media (max-width: 780px){
  .cs-cards{ grid-template-columns:1fr; }
  .cs-card__actions .btn-primary,
  .cs-card__actions .btn-secondary{ width:100%; }
}

/* — «Статистика»/счётчики: уплотнить и переносить — */
@media (max-width: 540px){
  .cs-stats{ gap:6px; }
}

/* — Поисковая строка: компактнее на телефоне — */
@media (max-width: 540px){
  .company-search__wrap{ padding:9px 10px 9px 38px; }
  .company-search__wrap svg{ left:10px; width:16px; height:16px; }
}

/* Codeshare inbox image — не кликается, без модалки */
.cs-card__imgwrap{ cursor: default; }
.cs-card__imgwrap img{ pointer-events: none; user-select: none; }

/* Codeshare: превью без переходов и чужих модалок */
#cs-inbox .img-preview-clickable { cursor: zoom-in; }
#cs-inbox .img-preview-clickable a { pointer-events:none; }
#cs-inbox .img-preview-clickable img { user-select:none; }

/* ==== Admin layout (fix: side menu stays left on desktop) ==== */
.admin-layout{
  display:flex;
  gap:28px;
  align-items:flex-start;
}
.admin-layout .sidebar{
  flex:0 0 280px;
  position:sticky;
  top:20px;
  align-self:start;
  background:var(--glass);
  border-radius:20px;
  padding:16px;
  box-shadow:var(--shadow);
  height:max-content;
}
.admin-layout .content{
  flex:1 1 auto;
  min-width:0;
}
/* чтобы карточки в контенте не «схлопывались» */
.admin-layout .content > *{width:100%;max-width:none}

/* ── Responsive зеркалим правила .layout ───────────────────── */
@media (max-width:992px){
  .admin-layout{display:block;}        /* отключаем flex-поток */
  .admin-layout .sidebar{
    position:fixed;top:0;left:0;bottom:0;width:260px;z-index:120;
    transform:translateX(-110%);transition:transform .25s ease;
    border-right:1px solid rgba(255,255,255,.08)
  }
  .admin-layout .sidebar.open{transform:translateX(0)}
}
