/* ============================================================
   HEROES GAME — DESIGN SYSTEM
   Стиль: классические HoMM, деревянные рамки, металлические вставки
   ============================================================ */

/* --- CSS Variables --- */
:root {
  /* Background */
  --ds-bg-dark:       #1a1209;
  --ds-bg:            #2a1f10;
  --ds-bg-panel:      #1e160c;
  --ds-bg-inset:      #151008;

  /* Wood */
  --ds-wood-dark:     #3a2510;
  --ds-wood:          #5c3d1e;
  --ds-wood-light:    #7a5230;
  --ds-wood-highlight:#9a6b3a;

  /* Metal / Gold */
  --ds-gold:          #c9a84c;
  --ds-gold-light:    #e8c96d;
  --ds-gold-dark:     #8a6f2e;
  --ds-metal:         #8b7355;
  --ds-steel:         #6b6b6b;

  /* Parchment */
  --ds-parchment:     #d4c5a0;
  --ds-parchment-dark:#c4b48a;
  --ds-parchment-text:#3a2a15;

  /* Text */
  --ds-text:          #e0d8c0;
  --ds-text-dim:      #8a7a60;
  --ds-text-bright:   #f5ecd5;

  /* Accents */
  --ds-red:           #cc4444;
  --ds-red-light:     #ff6b6b;
  --ds-green:         #44aa66;
  --ds-green-light:   #66cc88;
  --ds-blue:          #4488cc;
  --ds-purple:        #8855cc;

  /* Rarity */
  --ds-rarity-common:    #8a8a8a;
  --ds-rarity-uncommon:  #44aa66;
  --ds-rarity-rare:      #4488cc;
  --ds-rarity-epic:      #8855cc;
  --ds-rarity-legendary: #c9a84c;

  /* Spacing */
  --ds-space-xs: 4px;
  --ds-space-sm: 8px;
  --ds-space-md: 16px;
  --ds-space-lg: 24px;
  --ds-space-xl: 32px;

  /* Radius */
  --ds-radius-sm: 4px;
  --ds-radius-md: 6px;
  --ds-radius-lg: 8px;

  /* Shadows */
  --ds-shadow-sm:    0 2px 4px rgba(0,0,0,0.4);
  --ds-shadow-md:    0 4px 12px rgba(0,0,0,0.5);
  --ds-shadow-lg:    0 8px 24px rgba(0,0,0,0.6);
  --ds-shadow-inset: inset 0 2px 4px rgba(0,0,0,0.5);
  --ds-shadow-glow-gold: 0 0 8px rgba(201,168,76,0.3);

  /* Fonts */
  --ds-font-heading: 'Cinzel', Georgia, serif;
  --ds-font-body:    'Crimson Text', Georgia, serif;
  --ds-font-mono:    Georgia, serif;
}


/* ============================================================
   PANEL — основной контейнер
   ============================================================ */

.panel {
  position: relative;
  background: var(--ds-bg-panel);
  border: none;
  padding: 32px;
  box-shadow: var(--ds-shadow-md);
  overflow: visible;
}

/* Убираем старый ::before для рамки — теперь border-image */
.panel::before {
  content: none;
}

/* Рамка поверх всего контента */
.panel::after {
  content: '';
  position: absolute;
  inset: -32px;
  border: 32px solid transparent;
  border-image: url('../images/ui/frame_ornate.png') 130 / 32px / 0 stretch;
  pointer-events: none;
  z-index: 10;
}

.panel__header {
  position: relative;
  z-index: 2;
  padding: 10px var(--ds-space-md);
  background:
    linear-gradient(180deg, rgba(122,82,48,0.55) 0%, rgba(92,61,30,0.65) 40%, rgba(58,37,16,0.75) 100%),
    url('../images/ui/tex_metal_strip.png') repeat center / 100px;
  border-bottom: 2px solid var(--ds-gold-dark);
  font-family: var(--ds-font-heading);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ds-gold-light);
  text-shadow: 0 1px 2px rgba(0,0,0,0.5);
  text-align: center;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  /* Металлическая полоса — блик сверху */
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.15),
    inset 0 -1px 0 rgba(0,0,0,0.3);
}

.panel__body {
  position: relative;
  z-index: 2;
  padding: var(--ds-space-md);
  background:
    linear-gradient(135deg, rgba(180,165,130,0.93) 0%, rgba(160,145,110,0.95) 100%),
    url('../images/ui/tex_parchment.png') repeat center / 300px;
  color: var(--ds-parchment-text);
  font-family: var(--ds-font-body);
  font-size: 0.95rem;
  line-height: 1.5;
}

/* Вариант: тёмный фон внутри (для лога, чата и т.д.) */
.panel--dark .panel__body {
  background: var(--ds-bg-panel);
  color: var(--ds-text);
}

/* Вариант: компактная */
.panel--compact .panel__header {
  padding: 6px var(--ds-space-sm);
  font-size: 0.85rem;
}
.panel--compact .panel__body {
  padding: var(--ds-space-sm);
}

/* Вариант: без заголовка */
.panel--no-header {
  padding: var(--ds-space-md);
}
.panel--no-header .panel__body {
  padding: 0;
}


/* ============================================================
   BUTTONS — кнопки
   ============================================================ */

.btn-fantasy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 24px;
  min-width: 100px;
  border: 2px solid var(--ds-wood-light);
  border-radius: var(--ds-radius-sm);
  background:
    linear-gradient(180deg, rgba(122,82,48,0.75) 0%, rgba(92,61,30,0.85) 50%, rgba(58,37,16,0.95) 100%),
    url('../images/ui/tex_wood_dark.png') repeat center / 120px;
  color: var(--ds-gold-light);
  font-family: var(--ds-font-heading);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
  cursor: pointer;
  transition: all 0.15s ease;
  box-shadow:
    var(--ds-shadow-sm),
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -1px 0 rgba(0,0,0,0.2);
  text-decoration: none;
  white-space: nowrap;
}

.btn-fantasy:hover {
  border-color: var(--ds-gold);
  background:
    linear-gradient(180deg, rgba(154,107,58,0.8) 0%, rgba(122,82,48,0.85) 50%, rgba(92,61,30,0.9) 100%),
    url('../images/ui/tex_wood_dark.png') repeat center / 120px;
  color: var(--ds-gold-light);
  box-shadow:
    var(--ds-shadow-md),
    var(--ds-shadow-glow-gold),
    inset 0 1px 0 rgba(255,255,255,0.15);
  transform: translateY(-1px);
}

.btn-fantasy:active {
  transform: translateY(1px);
  box-shadow:
    0 1px 2px rgba(0,0,0,0.4),
    inset 0 2px 3px rgba(0,0,0,0.3);
  background: linear-gradient(
    180deg,
    var(--ds-wood-dark) 0%,
    var(--ds-wood) 100%
  );
}

/* Primary — яркая золотая рамка */
.btn-fantasy--primary {
  border-color: var(--ds-gold);
  box-shadow:
    var(--ds-shadow-sm),
    var(--ds-shadow-glow-gold),
    inset 0 1px 0 rgba(255,255,255,0.15);
}
.btn-fantasy--primary:hover {
  border-color: var(--ds-gold-light);
  box-shadow:
    var(--ds-shadow-md),
    0 0 12px rgba(201,168,76,0.4),
    inset 0 1px 0 rgba(255,255,255,0.2);
}

/* Danger — красное дерево */
.btn-fantasy--danger {
  background: linear-gradient(
    180deg,
    #6b2020 0%,
    #4a1515 50%,
    #3a1010 100%
  );
  border-color: var(--ds-red);
  color: var(--ds-red-light);
}
.btn-fantasy--danger:hover {
  border-color: var(--ds-red-light);
  background: linear-gradient(
    180deg,
    #7a2525 0%,
    #5a1a1a 50%,
    #4a1515 100%
  );
  box-shadow:
    var(--ds-shadow-md),
    0 0 8px rgba(204,68,68,0.3);
}

/* Ghost — прозрачная */
.btn-fantasy--ghost {
  background: transparent;
  border: 1px solid var(--ds-gold-dark);
  color: var(--ds-gold);
  box-shadow: none;
}
.btn-fantasy--ghost:hover {
  background: rgba(201,168,76,0.08);
  border-color: var(--ds-gold);
  box-shadow: var(--ds-shadow-glow-gold);
}

/* Small */
.btn-fantasy--sm {
  padding: 6px 14px;
  min-width: auto;
  font-size: 0.78rem;
}

/* Disabled */
.btn-fantasy:disabled,
.btn-fantasy[disabled] {
  opacity: 0.4;
  cursor: not-allowed;
  pointer-events: none;
}


/* ============================================================
   INPUTS — поля ввода
   ============================================================ */

.input-fantasy {
  width: 100%;
  padding: 10px 14px;
  background: var(--ds-bg-inset);
  border: 2px solid var(--ds-wood-dark);
  border-radius: var(--ds-radius-md);
  color: var(--ds-text);
  font-family: var(--ds-font-body);
  font-size: 0.95rem;
  box-shadow: var(--ds-shadow-inset);
  transition: border-color 0.2s, box-shadow 0.2s;
  outline: none;
}

.input-fantasy::placeholder {
  color: var(--ds-text-dim);
  font-style: italic;
}

.input-fantasy:focus {
  border-color: var(--ds-gold-dark);
  box-shadow:
    var(--ds-shadow-inset),
    0 0 6px rgba(201,168,76,0.2);
}

/* Label для инпутов */
.label-fantasy {
  display: block;
  margin-bottom: 6px;
  font-family: var(--ds-font-heading);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ds-gold);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

/* Группа label + input */
.field-fantasy {
  margin-bottom: var(--ds-space-md);
}


/* ============================================================
   CARDS — карточки
   ============================================================ */

.card-fantasy {
  position: relative;
  background: var(--ds-bg-panel);
  border: 2px solid var(--ds-wood);
  border-radius: var(--ds-radius-md);
  padding: var(--ds-space-sm) var(--ds-space-md);
  box-shadow: var(--ds-shadow-sm);
  transition: all 0.15s ease;
  color: var(--ds-text);
  font-family: var(--ds-font-body);
}

.card-fantasy:hover {
  border-color: var(--ds-gold-dark);
  box-shadow:
    var(--ds-shadow-md),
    var(--ds-shadow-glow-gold);
  transform: translateY(-1px);
}

.card-fantasy__title {
  font-family: var(--ds-font-heading);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--ds-gold-light);
  margin-bottom: var(--ds-space-xs);
}

.card-fantasy__desc {
  font-size: 0.85rem;
  color: var(--ds-text-dim);
  line-height: 1.4;
}

.card-fantasy__icon {
  font-size: 1.8rem;
  margin-bottom: var(--ds-space-xs);
}

/* Карточка с фиксированной шириной */
.card-fantasy--fixed {
  width: 180px;
}

/* Горизонтальная карточка */
.card-fantasy--horizontal {
  display: flex;
  align-items: center;
  gap: var(--ds-space-sm);
}
.card-fantasy--horizontal .card-fantasy__icon {
  margin-bottom: 0;
  font-size: 2rem;
}


/* ============================================================
   DIVIDERS — разделители
   ============================================================ */

.divider-ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: var(--ds-space-md) 0;
  color: var(--ds-gold-dark);
  font-size: 0.7rem;
  background: url('../images/ui/divider_gold.png') no-repeat center / 80% auto;
  height: 40px;
  min-height: 40px;
}

/* Если нет текста внутри — чисто картинка */
.divider-ornament:empty {
  /* картинка и так отображается */
}

.divider-ornament::before,
.divider-ornament::after {
  content: none;
}

/* Разделитель с текстом — картинка фоном + текст поверх */
.divider-ornament--text {
  font-family: var(--ds-font-heading);
  font-size: 0.75rem;
  color: var(--ds-gold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-shadow: 0 1px 3px rgba(0,0,0,0.8);
}

/* Простая линия */
.divider-simple {
  height: 1px;
  background: linear-gradient(
    90deg,
    transparent 0%,
    var(--ds-wood) 20%,
    var(--ds-wood-light) 50%,
    var(--ds-wood) 80%,
    transparent 100%
  );
  margin: var(--ds-space-sm) 0;
  border: none;
}


/* ============================================================
   BADGES — бейджи / метки
   ============================================================ */

.badge-fantasy {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 3px;
  font-family: var(--ds-font-heading);
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border: 1px solid;
}

/* Варианты */
.badge-fantasy--gold {
  background: rgba(201,168,76,0.15);
  border-color: var(--ds-gold-dark);
  color: var(--ds-gold-light);
}
.badge-fantasy--red {
  background: rgba(204,68,68,0.15);
  border-color: var(--ds-red);
  color: var(--ds-red-light);
}
.badge-fantasy--green {
  background: rgba(68,170,102,0.15);
  border-color: var(--ds-green);
  color: var(--ds-green-light);
}
.badge-fantasy--blue {
  background: rgba(68,136,204,0.15);
  border-color: var(--ds-blue);
  color: #6ab0f0;
}
.badge-fantasy--purple {
  background: rgba(136,85,204,0.15);
  border-color: var(--ds-purple);
  color: #aa77ee;
}
.badge-fantasy--steel {
  background: rgba(107,107,107,0.15);
  border-color: var(--ds-steel);
  color: #aaa;
}


/* ============================================================
   TOOLTIP — тултипы
   ============================================================ */

.tooltip-fantasy {
  position: absolute;
  z-index: 1000;
  min-width: 200px;
  max-width: 320px;
  background: var(--ds-bg-panel);
  border: 2px solid var(--ds-wood);
  border-radius: var(--ds-radius-md);
  box-shadow: var(--ds-shadow-lg);
  padding: var(--ds-space-sm) var(--ds-space-md);
  color: var(--ds-text);
  font-family: var(--ds-font-body);
  font-size: 0.85rem;
  pointer-events: none;
}

.tooltip-fantasy__title {
  font-family: var(--ds-font-heading);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--ds-gold-light);
  margin-bottom: var(--ds-space-xs);
}

.tooltip-fantasy__stat {
  display: flex;
  justify-content: space-between;
  padding: 2px 0;
  font-size: 0.82rem;
}

.tooltip-fantasy__stat-label {
  color: var(--ds-text-dim);
}

.tooltip-fantasy__stat-value {
  color: var(--ds-text-bright);
  font-weight: 600;
}


/* ============================================================
   MODAL — модальные окна
   ============================================================ */

.modal-fantasy-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.75);
  z-index: 500;
  align-items: center;
  justify-content: center;
  animation: ds-fadeIn 0.2s ease;
}
.modal-fantasy-overlay.open {
  display: flex;
}

.modal-fantasy {
  position: relative;
  width: 420px;
  max-width: 90vw;
  max-height: 80vh;
  overflow-y: auto;
}

@keyframes ds-fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}


/* ============================================================
   SCROLLBAR — кастомный скроллбар
   ============================================================ */

.ds-scroll::-webkit-scrollbar {
  width: 10px;
}
.ds-scroll::-webkit-scrollbar-track {
  background: var(--ds-bg-dark);
  border-left: 1px solid var(--ds-wood-dark);
}
.ds-scroll::-webkit-scrollbar-thumb {
  background: linear-gradient(
    180deg,
    var(--ds-wood-light) 0%,
    var(--ds-wood) 50%,
    var(--ds-wood-dark) 100%
  );
  border-radius: 4px;
  border: 1px solid var(--ds-wood-dark);
}
.ds-scroll::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(
    180deg,
    var(--ds-wood-highlight) 0%,
    var(--ds-wood-light) 50%,
    var(--ds-wood) 100%
  );
}


/* ============================================================
   TABLE — таблицы
   ============================================================ */

.table-fantasy {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--ds-font-body);
  font-size: 0.9rem;
}

.table-fantasy th {
  padding: 8px 12px;
  background: linear-gradient(180deg, var(--ds-wood) 0%, var(--ds-wood-dark) 100%);
  border-bottom: 2px solid var(--ds-gold-dark);
  font-family: var(--ds-font-heading);
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--ds-gold-light);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  text-align: left;
}

.table-fantasy td {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(90,61,30,0.3);
  color: var(--ds-text);
}

.table-fantasy tr:hover td {
  background: rgba(201,168,76,0.05);
}

.table-fantasy tr:nth-child(even) td {
  background: rgba(0,0,0,0.1);
}
.table-fantasy tr:nth-child(even):hover td {
  background: rgba(201,168,76,0.08);
}


/* ============================================================
   TABS — вкладки
   ============================================================ */

.tabs-fantasy {
  display: flex;
  border-bottom: 2px solid var(--ds-wood);
  gap: 2px;
}

.tab-fantasy {
  padding: 8px 20px;
  background: linear-gradient(180deg, var(--ds-wood-dark) 0%, var(--ds-bg-panel) 100%);
  border: 1px solid var(--ds-wood-dark);
  border-bottom: none;
  border-radius: var(--ds-radius-sm) var(--ds-radius-sm) 0 0;
  font-family: var(--ds-font-heading);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ds-text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all 0.15s ease;
}

.tab-fantasy:hover {
  color: var(--ds-gold);
  background: linear-gradient(180deg, var(--ds-wood) 0%, var(--ds-bg-panel) 100%);
}

.tab-fantasy.active {
  color: var(--ds-gold-light);
  background: linear-gradient(180deg, var(--ds-wood-light) 0%, var(--ds-bg-panel) 100%);
  border-color: var(--ds-wood);
  border-bottom: 2px solid var(--ds-bg-panel);
  margin-bottom: -2px;
}


/* ============================================================
   PROGRESS BAR — прогресс-бар
   ============================================================ */

.progress-fantasy {
  width: 100%;
  height: 16px;
  background: var(--ds-bg-inset);
  border: 1px solid var(--ds-wood-dark);
  border-radius: 3px;
  box-shadow: var(--ds-shadow-inset);
  overflow: hidden;
}

.progress-fantasy__fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.4s ease;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.2);
}

.progress-fantasy__fill--gold {
  background: linear-gradient(180deg, var(--ds-gold-light) 0%, var(--ds-gold-dark) 100%);
}
.progress-fantasy__fill--green {
  background: linear-gradient(180deg, var(--ds-green-light) 0%, #2a7744 100%);
}
.progress-fantasy__fill--red {
  background: linear-gradient(180deg, var(--ds-red-light) 0%, #8a2222 100%);
}
.progress-fantasy__fill--blue {
  background: linear-gradient(180deg, #6ab0f0 0%, #2a5588 100%);
}
.progress-fantasy__fill--xp {
  background: linear-gradient(180deg, #b8a0f0 0%, #5a3a8a 100%);
}


/* ============================================================
   TOAST — уведомления
   ============================================================ */

.toast-fantasy {
  padding: 10px 18px;
  background: var(--ds-bg-panel);
  border: 2px solid var(--ds-wood);
  border-left: 4px solid var(--ds-gold);
  border-radius: var(--ds-radius-sm);
  box-shadow: var(--ds-shadow-lg);
  font-family: var(--ds-font-body);
  font-size: 0.9rem;
  color: var(--ds-text);
  animation: ds-slideIn 0.3s ease;
}

.toast-fantasy--success {
  border-left-color: var(--ds-green);
}
.toast-fantasy--error {
  border-left-color: var(--ds-red);
}
.toast-fantasy--info {
  border-left-color: var(--ds-blue);
}

@keyframes ds-slideIn {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}


/* ============================================================
   NAV BAR — навигация (стиль для HUD)
   ============================================================ */

.nav-fantasy {
  display: flex;
  gap: 2px;
  padding: 0;
}

.nav-fantasy__item {
  padding: 8px 16px;
  background: transparent;
  border: none;
  font-family: var(--ds-font-heading);
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--ds-text-dim);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: all 0.15s ease;
  border-bottom: 2px solid transparent;
}

.nav-fantasy__item:hover {
  color: var(--ds-gold);
  background: rgba(201,168,76,0.05);
}

.nav-fantasy__item.active {
  color: var(--ds-gold-light);
  border-bottom-color: var(--ds-gold);
  background: rgba(201,168,76,0.08);
}


/* ============================================================
   UTILITY CLASSES
   ============================================================ */

/* Текст */
.ds-text-gold    { color: var(--ds-gold-light); }
.ds-text-dim     { color: var(--ds-text-dim); }
.ds-text-bright  { color: var(--ds-text-bright); }
.ds-text-red     { color: var(--ds-red-light); }
.ds-text-green   { color: var(--ds-green-light); }
.ds-text-blue    { color: #6ab0f0; }

/* Заголовки */
.ds-heading {
  font-family: var(--ds-font-heading);
  color: var(--ds-gold-light);
  text-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.ds-heading-lg { font-size: 1.6rem; font-weight: 700; }
.ds-heading-md { font-size: 1.2rem; font-weight: 600; }
.ds-heading-sm { font-size: 0.95rem; font-weight: 600; }

/* Фон body/экрана */
.ds-bg-leather {
  background-color: var(--ds-bg-dark);
  background-image:
    radial-gradient(ellipse at 50% 0%, rgba(60,40,20,0.3) 0%, transparent 60%),
    url('../images/ui/tex_leather.png');
  background-repeat: repeat;
  background-size: 300px;
}
