/* ═══════════════════════════════════════════════════════════════════════════
   dfcraft.css — Общая библиотека стилей для всех поддоменов dfcraft.online
   Используется поверх Bootstrap 5.
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── CSS переменные ──────────────────────────────────────────────────────────── */
:root {
  --df-bg:        #0b0e1a;
  --df-surface:   #111827;
  --df-surface2:  #1a2235;
  --df-border:    #1e2d45;
  --df-accent:    #00d4ff;
  --df-accent2:   #7c3aed;
  --df-green:     #22c55e;
  --df-red:       #ef4444;
  --df-gold:      #f59e0b;
  --df-text:      #e2e8f0;
  --df-muted:     #64748b;
  --df-radius:    12px;
  --df-radius-lg: 18px;
  --df-font-head: 'Rajdhani', 'Exo 2', sans-serif;
  --df-transition: .22s ease;
}

/* ── Базовые переопределения Bootstrap ───────────────────────────────────── */
html { scroll-behavior: smooth; }

body {
  background-color: var(--df-bg);
  color: var(--df-text);
  font-family: 'Inter', system-ui, sans-serif;
  min-height: 100vh;
  background-image:
    radial-gradient(ellipse at 15% 0%,   rgba(0,212,255,.055) 0%, transparent 52%),
    radial-gradient(ellipse at 85% 100%, rgba(124,58,237,.07)  0%, transparent 50%);
}

/* ── Скроллбар ───────────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--df-bg); }
::-webkit-scrollbar-thumb { background: var(--df-border); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: var(--df-accent); }

/* ══════════════════════════════════════════════════════════════════════════
   НАВИГАЦИЯ
   ══════════════════════════════════════════════════════════════════════════ */
.df-navbar {
  background: rgba(11,14,26,.92) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--df-border);
  padding: .6rem 0;
  position: sticky;
  top: 0;
  z-index: 1030;
}

.df-navbar .navbar-brand {
  font-family: var(--df-font-head);
  font-size: 1.55rem;
  font-weight: 700;
  letter-spacing: .5px;
  background: linear-gradient(135deg, var(--df-accent) 0%, var(--df-accent2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.df-navbar .nav-link {
  color: var(--df-muted) !important;
  font-size: .875rem;
  font-weight: 500;
  border-radius: 8px;
  padding: .4rem .85rem !important;
  transition: color var(--df-transition), background var(--df-transition);
}
.df-navbar .nav-link:hover,
.df-navbar .nav-link.active {
  color: var(--df-text) !important;
  background: var(--df-surface2);
}
.df-navbar .nav-link.active {
  color: var(--df-accent) !important;
}

/* Burger */
.df-navbar .navbar-toggler {
  border: 1px solid var(--df-border);
  color: var(--df-text);
  padding: .3rem .6rem;
}
.df-navbar .navbar-toggler-icon {
  filter: invert(1) brightness(.8);
}

/* Server status pill in navbar */
.df-nav-status {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .78rem;
  padding: .3rem .7rem;
  border-radius: 999px;
  border: 1px solid var(--df-border);
  color: var(--df-muted);
  white-space: nowrap;
}
.df-nav-status .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--df-muted);
}
.df-nav-status.online .dot  { background: var(--df-green); box-shadow: 0 0 6px var(--df-green); }
.df-nav-status.online       { border-color: rgba(34,197,94,.3); color: var(--df-green); }
.df-nav-status.offline .dot { background: var(--df-red); box-shadow: 0 0 6px var(--df-red); }
.df-nav-status.offline      { border-color: rgba(239,68,68,.3); color: var(--df-red); }

/* ══════════════════════════════════════════════════════════════════════════
   КНОПКИ
   ══════════════════════════════════════════════════════════════════════════ */
.btn-df {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .65rem 1.4rem;
  border-radius: 10px;
  font-weight: 600;
  font-size: .9rem;
  transition: all .22s;
  border: none;
  cursor: pointer;
  font-family: inherit;
  text-decoration: none;
  line-height: 1.2;
}
.btn-df:active { transform: scale(.96); }

.btn-df-primary {
  background: linear-gradient(135deg, var(--df-accent) 0%, #009fcc 100%);
  color: #000 !important;
  box-shadow: 0 4px 14px rgba(0,212,255,.35);
}
.btn-df-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 7px 22px rgba(0,212,255,.5);
  color: #000 !important;
}

.btn-df-secondary {
  background: var(--df-surface2);
  border: 1px solid var(--df-border);
  color: var(--df-text) !important;
}
.btn-df-secondary:hover {
  border-color: var(--df-accent);
  color: var(--df-accent) !important;
}

.btn-df-danger {
  background: linear-gradient(135deg, #dc2626, #b91c1c);
  color: #fff !important;
  box-shadow: 0 4px 14px rgba(239,68,68,.3);
}
.btn-df-danger:hover { transform: translateY(-2px); }

.btn-df-sm  { padding: .42rem .95rem; font-size: .82rem; }
.btn-df-lg  { padding: .85rem 2rem;   font-size: 1.05rem; }
.btn-df-xl  { padding: 1rem 2.4rem;   font-size: 1.1rem;  border-radius: 12px; }

/* ══════════════════════════════════════════════════════════════════════════
   КАРТОЧКИ
   ══════════════════════════════════════════════════════════════════════════ */
.df-card {
  background: var(--df-surface);
  border: 1px solid var(--df-border);
  border-radius: var(--df-radius-lg);
  transition: border-color var(--df-transition), box-shadow var(--df-transition), transform var(--df-transition);
}
.df-card:hover {
  transform: translateY(-4px);
}

/* ── Rank cards ── */
.rank-card {
  background: var(--df-surface);
  border: 1px solid var(--df-border);
  border-radius: var(--df-radius-lg);
  padding: 1.75rem 1.5rem 1.5rem;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  transition: transform .28s ease, box-shadow .28s ease, border-color .28s ease;
  height: 100%;
}
.rank-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% -15%, var(--rank-glow, rgba(0,212,255,.07)) 0%, transparent 60%);
  pointer-events: none;
  transition: opacity .3s;
}
.rank-card:hover {
  transform: translateY(-7px);
  border-color: var(--rank-color, var(--df-accent));
  box-shadow: 0 22px 45px var(--rank-shadow, rgba(0,212,255,.14));
}
.rank-card:hover::before { opacity: 1.5; }

.rank-card .rank-icon-wrap {
  width: 54px; height: 54px;
  border-radius: 14px;
  display: grid; place-items: center;
  font-size: 1.35rem;
  flex-shrink: 0;
  background: color-mix(in srgb, var(--rank-color) 15%, transparent);
  color: var(--rank-color);
  box-shadow: 0 0 18px color-mix(in srgb, var(--rank-color) 30%, transparent);
  margin-bottom: 1rem;
}

.rank-card .rank-name {
  font-family: var(--df-font-head);
  font-size: 1.7rem;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--rank-color);
  line-height: 1;
  margin-bottom: .2rem;
}
.rank-card .rank-price {
  font-size: 1rem;
  font-weight: 600;
  color: var(--df-muted);
  margin-bottom: 1.1rem;
}
.rank-card .rank-price span {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--df-text);
}

.rank-card .perk-list {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column;
  gap: .55rem;
  flex: 1;
  margin-bottom: 1.3rem;
}
.rank-card .perk-list li {
  display: flex; align-items: center; gap: .65rem;
  font-size: .86rem;
  color: var(--df-text);
}
.rank-card .perk-list li i {
  width: 18px; text-align: center;
  color: var(--rank-color);
  opacity: .85;
  font-size: .85rem;
  flex-shrink: 0;
}

.rank-buy-btn {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  padding: .75rem 1rem;
  border-radius: 10px;
  font-weight: 700;
  font-size: .95rem;
  text-decoration: none;
  border: none; cursor: pointer;
  transition: transform .2s, box-shadow .2s;
  font-family: inherit;
  color: #000 !important;
  background: var(--rank-color);
  box-shadow: 0 5px 18px var(--rank-shadow, rgba(0,212,255,.3));
}
.rank-buy-btn:hover { transform: translateY(-2px); filter: brightness(1.08); }
.rank-buy-btn:active { transform: scale(.96); }

/* Badge on card */
.rank-badge {
  position: absolute; top: 1rem; right: 1rem;
  background: var(--rank-color);
  color: #000;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .5px;
  padding: .22rem .6rem;
  border-radius: 999px;
  text-transform: uppercase;
}

/* ══════════════════════════════════════════════════════════════════════════
   INPUTS
   ══════════════════════════════════════════════════════════════════════════ */
.df-input {
  background: var(--df-surface2) !important;
  border: 1px solid var(--df-border) !important;
  border-radius: 10px !important;
  color: var(--df-text) !important;
  font-size: 1rem;
  padding: .72rem 1rem !important;
  transition: border-color .2s, box-shadow .2s;
  font-family: inherit;
  width: 100%;
}
.df-input::placeholder { color: var(--df-muted) !important; }
.df-input:focus {
  border-color: var(--df-accent) !important;
  box-shadow: 0 0 0 3px rgba(0,212,255,.15) !important;
  outline: none;
}

.df-label {
  font-size: .8rem;
  font-weight: 500;
  color: var(--df-muted);
  display: block;
  margin-bottom: .4rem;
  letter-spacing: .3px;
}

/* ══════════════════════════════════════════════════════════════════════════
   BADGES / STATUS
   ══════════════════════════════════════════════════════════════════════════ */
.df-badge {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .25rem .65rem;
  border-radius: 999px;
  font-size: .74rem;
  font-weight: 700;
}
.df-badge-pending  { background: rgba(245,158,11,.14); color: var(--df-gold);  border: 1px solid rgba(245,158,11,.3); }
.df-badge-approved { background: rgba(34,197,94,.14);  color: var(--df-green); border: 1px solid rgba(34,197,94,.3); }
.df-badge-rejected { background: rgba(239,68,68,.14);  color: var(--df-red);   border: 1px solid rgba(239,68,68,.3); }
.df-badge-info     { background: rgba(0,212,255,.1);   color: var(--df-accent);border: 1px solid rgba(0,212,255,.25); }

/* ══════════════════════════════════════════════════════════════════════════
   ALERTS
   ══════════════════════════════════════════════════════════════════════════ */
.df-alert {
  display: flex; align-items: flex-start; gap: .8rem;
  border-radius: 10px;
  padding: .9rem 1.1rem;
  font-size: .88rem;
  line-height: 1.5;
}
.df-alert i { margin-top: .1rem; flex-shrink: 0; }
.df-alert-success { background: rgba(34,197,94,.1);  border: 1px solid rgba(34,197,94,.25);  color: #4ade80; }
.df-alert-error   { background: rgba(239,68,68,.1);  border: 1px solid rgba(239,68,68,.25);  color: #f87171; }
.df-alert-info    { background: rgba(0,212,255,.08); border: 1px solid rgba(0,212,255,.22);  color: var(--df-accent); }
.df-alert-warning { background: rgba(245,158,11,.1); border: 1px solid rgba(245,158,11,.25); color: var(--df-gold); }

/* ══════════════════════════════════════════════════════════════════════════
   TOAST
   ══════════════════════════════════════════════════════════════════════════ */
#df-toast-container {
  position: fixed; bottom: 1.5rem; right: 1.5rem;
  z-index: 9999;
  display: flex; flex-direction: column; gap: .55rem;
  pointer-events: none;
}
.df-toast {
  background: var(--df-surface);
  border: 1px solid var(--df-border);
  border-radius: 11px;
  padding: .72rem 1.2rem;
  font-size: .84rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.45);
  animation: dfFadeUp .3s ease both;
  display: flex; align-items: center; gap: .6rem;
  min-width: 220px; max-width: 320px;
  pointer-events: all;
}
.df-toast-success { border-left: 3px solid var(--df-green); }
.df-toast-error   { border-left: 3px solid var(--df-red);   }
.df-toast-info    { border-left: 3px solid var(--df-accent); }

/* ══════════════════════════════════════════════════════════════════════════
   СЕКЦИИ / ТАЙТЛЫ
   ══════════════════════════════════════════════════════════════════════════ */
.df-section-title {
  font-family: var(--df-font-head);
  font-size: clamp(1.7rem, 4vw, 2.6rem);
  font-weight: 700;
  background: linear-gradient(135deg, #fff 30%, var(--df-accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1.15;
}
.df-section-sub {
  color: var(--df-muted);
  font-size: .95rem;
  margin-top: .4rem;
}

.df-divider {
  border: none;
  border-top: 1px solid var(--df-border);
  margin: 2.5rem 0;
}

/* How-it-works steps */
.how-step-num {
  width: 54px; height: 54px;
  background: linear-gradient(135deg, var(--df-accent), var(--df-accent2));
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--df-font-head);
  font-size: 1.4rem; font-weight: 700;
  color: #000;
  box-shadow: 0 4px 18px rgba(0,212,255,.4);
  margin: 0 auto .9rem;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════════════════════ */
.df-footer {
  background: var(--df-surface);
  border-top: 1px solid var(--df-border);
  padding: 2.5rem 0 1.5rem;
  margin-top: 4rem;
  color: var(--df-muted);
  font-size: .83rem;
}
.df-footer a { color: var(--df-accent); text-decoration: none; }
.df-footer a:hover { text-decoration: underline; }
.df-footer-brand {
  font-family: var(--df-font-head);
  font-size: 1.35rem; font-weight: 700;
  background: linear-gradient(135deg, var(--df-accent), var(--df-accent2));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline-block; margin-bottom: .4rem;
}

/* ══════════════════════════════════════════════════════════════════════════
   АНИМАЦИИ
   ══════════════════════════════════════════════════════════════════════════ */
@keyframes dfFadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: none; }
}
@keyframes dfPulse { 0%,100%{opacity:1} 50%{opacity:.4} }
@keyframes dfSpin  { to{transform:rotate(360deg)} }

.df-fade-up  { animation: dfFadeUp .45s ease both; }
.df-delay-1  { animation-delay: .07s; }
.df-delay-2  { animation-delay: .14s; }
.df-delay-3  { animation-delay: .21s; }
.df-delay-4  { animation-delay: .28s; }
.df-delay-5  { animation-delay: .35s; }

.df-skeleton {
  background: linear-gradient(90deg, var(--df-surface2) 25%, var(--df-border) 50%, var(--df-surface2) 75%);
  background-size: 200% 100%;
  animation: dfSkeleton 1.4s infinite;
  border-radius: 6px;
}
@keyframes dfSkeleton {
  from { background-position: 200% 0; }
  to   { background-position: -200% 0; }
}

/* ══════════════════════════════════════════════════════════════════════════
   RESPONSIVE HELPERS
   ══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 576px) {
  .rank-card { padding: 1.4rem 1.2rem 1.2rem; }
  .btn-df-xl { padding: .8rem 1.6rem; font-size: 1rem; }
  .df-section-title { font-size: 1.6rem; }
}

/* ── Markdown в сообщениях тикетов ──────────────────────────────────── */
.df-md b{font-weight:700}
.df-md i{font-style:italic}
.df-md a{color:var(--df-accent);text-decoration:none}
.df-md a:hover{text-decoration:underline}
.df-md .df-md-list{margin:.4rem 0 .4rem 1.2rem;padding:0;list-style:disc}
.df-md .df-md-list li{margin:.15rem 0}
.df-md .df-quote{margin:.4rem 0;padding:.4rem .7rem;border-left:3px solid var(--df-accent);background:rgba(255,255,255,.04);color:var(--df-muted);border-radius:0 7px 7px 0;font-size:.92em;white-space:pre-wrap}
.df-md .df-code{background:rgba(255,255,255,.07);border:1px solid var(--df-border);border-radius:5px;padding:.05em .35em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em}

/* ── Превью картинок и файл-чипы в сообщениях ──────────────────────── */
.df-file-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.45rem}
.df-file-img{display:block;border:1px solid var(--df-border);border-radius:8px;overflow:hidden;background:var(--df-surface2);width:120px;height:90px;flex:0 0 auto}
.df-file-img img{width:100%;height:100%;object-fit:cover;display:block}
.df-file-img:hover{border-color:var(--df-accent)}
.df-file-chip{display:inline-flex;gap:.4rem;align-items:center;background:var(--df-surface2);border:1px solid var(--df-border);border-radius:7px;padding:.3rem .6rem;font-size:.85rem;color:var(--df-text);text-decoration:none}
.df-file-chip:hover{border-color:var(--df-accent);color:var(--df-accent)}
.df-quote-btn{display:inline-flex;align-items:center;gap:.4rem;background:linear-gradient(180deg,rgba(34,211,238,.10),rgba(34,211,238,.04));border:1px solid rgba(34,211,238,.35);color:var(--df-accent);font-size:.78rem;font-weight:500;cursor:pointer;padding:.32rem .7rem;border-radius:8px;line-height:1;font-family:inherit;transition:all .15s ease;white-space:nowrap}
.df-quote-btn:hover{background:linear-gradient(180deg,rgba(34,211,238,.20),rgba(34,211,238,.10));border-color:var(--df-accent);box-shadow:0 0 0 3px rgba(34,211,238,.10);transform:translateY(-1px)}
.df-quote-btn:active{transform:translateY(0)}
.df-quote-btn i{font-size:.78em;opacity:.95}

/* ── Бейджи приоритета тикета ───────────────────────────────────────── */
.priority-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;padding:.15rem .5rem;border-radius:6px;border:1px solid;font-weight:700;text-transform:uppercase;letter-spacing:.04em;line-height:1.2;white-space:nowrap}
.pr-low{color:#94a3b8;border-color:#94a3b855}
.pr-normal{color:#3b82f6;border-color:#3b82f655}
.pr-high{color:#f59e0b;border-color:#f59e0b80;background:rgba(245,158,11,.06)}
.pr-urgent{color:#ef4444;border-color:#ef444480;background:rgba(239,68,68,.10);box-shadow:0 0 0 0 rgba(239,68,68,.4);animation:pr-urgent-pulse 2.4s ease-out infinite}
@keyframes pr-urgent-pulse{0%{box-shadow:0 0 0 0 rgba(239,68,68,.45)}70%{box-shadow:0 0 0 6px rgba(239,68,68,0)}100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}}
