/* ЛК (контрол-плейн) — единый стиль с деплоером (тёмная тема Google Sans + Material Symbols). */
:root{
  --bg-main:#131314;
  --bg-surface:#1e1f20;
  --bg-hover:#28292a;
  --bg-active:#333537;
  --text-primary:#e3e3e3;
  --text-secondary:#969696;
  --accent:#a8c7fa;
  --success:#6dd58c;
  --danger:#f28b82;
  --border:#252628;
  --sidebar-width:280px;
}
*{box-sizing:border-box;margin:0;padding:0}
/* Author display на .auth-form/.integration-form перебивает UA-стиль [hidden]; возвращаем. */
[hidden]{display:none !important}
body{background-color:var(--bg-main);color:var(--text-primary);
  font-family:'Google Sans','Roboto',sans-serif;height:100vh;overflow:hidden}
.material-symbols-outlined{font-variation-settings:'opsz' 20,'wght' 400,'GRAD' 0,'FILL' 0}

/* ===== Бренд ===== */
.brand{font-size:20px;font-weight:500;display:flex;align-items:center;gap:10px;color:var(--accent);margin-bottom:6px}
.brand .brand-dim{color:var(--text-secondary);font-weight:400}
.brand .material-symbols-outlined{font-size:24px}

/* ===== Экран входа ===== */
.auth-screen{width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.auth-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:28px;
  padding:32px;width:100%;max-width:420px;box-shadow:0 12px 48px rgba(0,0,0,.45)}
.auth-sub{color:var(--text-secondary);font-size:13px;margin:0 0 22px}
.auth-form{display:flex;flex-direction:column;gap:4px}
.auth-error{color:var(--danger);font-size:13px;min-height:0;margin:2px 0}
.auth-error:not(:empty){background:rgba(242,139,130,.1);padding:8px 12px;border-radius:12px;margin:6px 0}
.check{display:flex;flex-direction:row;align-items:flex-start;gap:8px;font-size:12px;
  color:var(--text-secondary);margin:8px 0 4px;cursor:pointer}
.check input{margin-top:2px}
.hint{color:var(--text-secondary);font-weight:400}
.auth-divider{display:flex;align-items:center;gap:12px;margin:22px 0 16px;color:var(--text-secondary);font-size:12px}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--border)}
.auth-alt{display:flex;flex-direction:column;gap:8px}
.soon{margin-left:auto;font-size:10px;text-transform:uppercase;letter-spacing:.5px;
  color:var(--text-secondary);border:1px solid var(--border);border-radius:100px;padding:2px 8px}

/* ===== Tabs (вход/регистрация) ===== */
.tabs{display:flex;gap:4px;background:var(--bg-main);padding:4px;border-radius:100px;margin-bottom:20px}
.tab{flex:1;border:none;background:transparent;padding:9px;border-radius:100px;cursor:pointer;
  font-size:13px;color:var(--text-secondary);font-family:inherit;transition:.2s}
.tab.active{background:var(--bg-active);color:var(--accent)}

/* ===== Кнопки (единая система с деплоером) ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 24px;border-radius:100px;cursor:pointer;font-family:'Google Sans','Roboto',sans-serif;
  font-weight:500;font-size:14px;border:1px solid transparent;line-height:1;transition:.2s}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn .material-symbols-outlined{font-size:18px}
.btn-block{width:100%}
.btn-primary{background-color:#3c4043;color:#e8eaed;border-color:#5f6368}
.btn-primary:hover:not(:disabled){background-color:#4d5154;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.btn-primary.deploy-action,.btn-accent{background-color:var(--accent);color:var(--bg-main);border-color:transparent}
.btn-primary.deploy-action:hover:not(:disabled),.btn-accent:hover:not(:disabled){background-color:#c0d6fb;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.btn-secondary{background:none;border-color:var(--border);color:var(--accent)}
.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}
.btn-danger{background:none;border-color:rgba(242,139,130,.5);color:var(--danger)}
.btn-danger:hover:not(:disabled){background:rgba(242,139,130,.1);border-color:var(--danger)}
.btn-icon-label{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:100px;
  font-size:13px;font-weight:500;background:none;border:1px solid var(--border);color:var(--text-primary);
  cursor:pointer;font-family:inherit;transition:.2s}
.btn-icon-label:hover:not(:disabled){background:var(--bg-hover);color:var(--accent)}
.btn-icon-label .material-symbols-outlined{font-size:18px}
.btn-icon-label.danger{border-color:rgba(242,139,130,.4);color:var(--danger)}
.btn-icon-label.danger:hover:not(:disabled){background:rgba(242,139,130,.1)}

/* ===== Формы ===== */
.form-group{margin-bottom:16px}
.form-group label{display:block;color:var(--text-secondary);margin-bottom:8px;font-size:14px}
.form-group input,.form-group select,.form-group textarea{width:100%;background:var(--bg-main);
  border:1px solid var(--border);color:var(--text-primary);padding:12px 16px;border-radius:12px;
  font-size:15px;font-family:'Google Sans','Roboto',sans-serif}
.form-group textarea{resize:vertical;min-height:90px}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent)}
.form-err{color:var(--danger);font-size:13px;margin-bottom:8px}
.form-err:not(:empty){background:rgba(242,139,130,.1);padding:8px 12px;border-radius:12px}
.form-ok{color:var(--success);font-size:13px;margin-bottom:8px}
.form-ok:not(:empty){background:rgba(109,213,140,.1);padding:8px 12px;border-radius:12px}

/* ===== Каркас ЛК: сайдбар + контент ===== */
#app-container{width:100%;height:100vh;display:flex}
aside{width:var(--sidebar-width);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:12px}
.logo{padding:12px 16px;font-size:20px;font-weight:500;display:flex;align-items:center;gap:12px;margin-bottom:20px;color:var(--accent)}
nav{display:flex;flex-direction:column}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;color:var(--text-primary);
  border-radius:100px;margin-bottom:4px;cursor:pointer;transition:.2s;font-size:14px}
.nav-item:hover{background-color:var(--bg-hover)}
.nav-item.active{background-color:var(--bg-active);color:var(--accent)}
.nav-item.danger{color:var(--danger)}
.nav-item.danger:hover{background:rgba(242,139,130,.1)}
.nav-group-label{padding:16px 16px 6px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}
.sidebar-foot{margin-top:auto;border-top:1px solid var(--border);padding-top:8px}
.account-chip{display:flex;align-items:center;gap:10px;padding:8px 16px;color:var(--text-secondary);font-size:13px}
.account-chip .material-symbols-outlined{font-size:20px}
.account-email{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

main#main-content{flex-grow:1;display:flex;flex-direction:column;overflow:hidden}
.page{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.page.active{display:flex}
main header{padding:24px 32px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);flex-shrink:0}
main header h1{font-size:24px;font-weight:400}
.page-content{padding:32px;overflow-y:auto;flex:1}

/* ===== Карточки / настройки ===== */
.settings-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:20px;padding:24px;margin-bottom:16px}
.settings-card h3{font-weight:400;font-size:18px;margin-bottom:8px;display:flex;align-items:center;gap:10px}
.settings-card h3 .material-symbols-outlined{font-size:22px;color:var(--text-secondary)}
.card-hint{color:var(--text-secondary);font-size:13px;margin-bottom:16px;line-height:1.5}
.card-hint.warn{color:#f0b86e;display:flex;align-items:center;gap:6px}
.card-hint.warn .material-symbols-outlined{font-size:16px}
.muted{color:var(--text-secondary)}

/* ===== Пустое состояние ===== */
.empty-state{background:var(--bg-surface);border:1px dashed var(--border);border-radius:20px;
  padding:56px 24px;text-align:center;color:var(--text-secondary)}
.empty-state .empty-icon{font-size:48px;color:var(--text-secondary);margin-bottom:12px}
.empty-state h2{font-size:18px;margin:0 0 8px;color:var(--text-primary);font-weight:500}
.empty-state p{font-size:13px;margin:0;line-height:1.6}

/* ===== Интеграции ===== */
.integration-head{display:flex;align-items:center;justify-content:space-between;gap:12px}
.integration-title{display:flex;align-items:center;gap:14px}
.integration-title>.material-symbols-outlined{font-size:28px;color:var(--accent)}
.integration-title strong{font-size:16px}
.integration-status{font-size:12px;margin-top:3px}
.integration-status .ok{color:var(--success);display:inline-flex;align-items:center;gap:4px}
.integration-status .muted{color:var(--text-secondary)}
.integration-actions{display:flex;gap:8px;flex-shrink:0}
.integration-form{display:flex;flex-direction:column;margin-top:18px;padding-top:18px;border-top:1px solid var(--border)}

/* ===== Серверы / провиженинг ===== */
.action-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.server-card .integration-status{font-size:13px;color:var(--text-secondary)}
.status-dot{width:11px;height:11px;border-radius:50%;background:var(--success);flex-shrink:0}
.status-dot.provisioning{background:var(--accent);animation:pulse 1.6s infinite}
.status-dot.error{background:var(--danger)}
.status-dot.ready{background:var(--success);box-shadow:0 0 10px rgba(109,213,140,.3)}
.status-dot.destroying{background:var(--danger);animation:pulse 1.6s infinite}
@keyframes pulse{0%{opacity:1}50%{opacity:.35}100%{opacity:1}}
.ticket-status.ready{background:rgba(109,213,140,.14);color:var(--success)}
.ticket-status.error{background:rgba(242,139,130,.14);color:var(--danger)}
.ticket-status.provisioning{background:rgba(168,199,250,.14);color:var(--accent)}
.ticket-status.destroying{background:rgba(242,139,130,.14);color:var(--danger)}
.server-creds code{background:rgba(255,255,255,.06);padding:1px 6px;border-radius:5px;font-size:12px}

/* ===== Поддержка ===== */
.support-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:8px}
.support-chan{display:flex;align-items:center;gap:14px;text-decoration:none;color:var(--text-primary);transition:.2s;margin-bottom:0}
.support-chan:hover{background:var(--bg-hover);border-color:var(--accent)}
.support-chan>.material-symbols-outlined{font-size:28px;color:var(--accent)}
.ticket-item{border:1px solid var(--border);border-radius:12px;padding:12px 14px;margin-bottom:10px}
.ticket-item:last-child{margin-bottom:0}
.ticket-head{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.ticket-head strong{font-size:14px}
.ticket-status{font-size:11px;text-transform:uppercase;letter-spacing:.5px;border-radius:100px;padding:2px 10px;
  background:rgba(168,199,250,.12);color:var(--accent)}
.ticket-status.closed{background:rgba(150,150,150,.15);color:var(--text-secondary)}
.ticket-meta{font-size:12px;color:var(--text-secondary)}
.ticket-msg{font-size:13px;color:var(--text-primary);margin-top:6px;white-space:pre-wrap;word-break:break-word}

@media(max-width:760px){
  aside{width:72px}
  .logo span:last-child,.nav-item span:not(.material-symbols-outlined),.nav-group-label,
  .account-chip,.sidebar-foot .nav-item span:not(.material-symbols-outlined){display:none}
  .page-content{padding:20px}
}
