:root {
  --design-w: 1280;
  --design-h: 720;
  --stage-scale: 1;
  --app-w: 100vw;
  --app-h: 100vh;
  --scene-bg-w: 1920px;
  --scene-bg-h: 1080px;
  --safe-top: env(safe-area-inset-top, 0px);
  --safe-right: env(safe-area-inset-right, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);
  --safe-left: env(safe-area-inset-left, 0px);
  --gold: #f3c66f;
  --gold-dark: #7e5622;
  --emerald: #79e9b5;
  --text: #fff2d9;
  --muted: #bea98a;
  --panel: rgba(11, 13, 18, .74);
  --panel-strong: rgba(8, 10, 14, .90);
  --line: rgba(243, 198, 111, .28);
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { width: 100%; height: 100%; margin: 0; padding: 0; overflow: hidden; }
body {
  background: #07090e;
  color: var(--text);
  font-family: Arial, Helvetica, sans-serif;
  touch-action: manipulation;
  user-select: none;
}
button, input { font: inherit; }
input, textarea, select { font-size: 18px; }
button { border: 0; }

.app {
  position: fixed;
  left: 0;
  top: 0;
  width: var(--app-w, 100vw);
  height: var(--app-h, 100vh);
  overflow: hidden;
  background: #07090e;
}

.scene-background {
  position: absolute;
  left: 50%;
  top: 50%;
  width: var(--scene-bg-w, 1920px);
  height: var(--scene-bg-h, 1080px);
  transform: translate(-50%, -50%) scale(var(--stage-scale));
  transform-origin: center center;
  background-color: #12141c;
  background-image:
    radial-gradient(circle at 50% 30%, rgba(243,198,111,.14), transparent 34%),
    linear-gradient(145deg, #101824, #24170d 55%, #07090e);
  background-position: center center;
  background-size: 100% 100%, 100% 100%, 100% 100%;
  background-repeat: no-repeat;
  transition: opacity .18s ease, filter .18s ease;
}

.scene-vignette {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse at center, rgba(255,255,255,.02) 0%, rgba(0,0,0,.04) 44%, rgba(0,0,0,.58) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.26), transparent 22%, rgba(0,0,0,.40));
}

.stage {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 1280px;
  height: 720px;
  transform: translate(-50%, -50%) scale(var(--stage-scale));
  transform-origin: center center;
  overflow: visible;
}

.screen {
  position: absolute;
  inset: 0;
  display: none;
}
.screen.is-active { display: block; }

.ui-button,
.text-input,
.field-label,
.race-description-panel,
.character-preview,
.location-title,
.resource-widget {
  position: absolute;
}

.ui-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1px;
  min-height: 1px;
  padding: 0 18px;
  border-radius: 6px;
  color: var(--text);
  font-weight: 800;
  letter-spacing: .02em;
  text-align: center;
  cursor: pointer;
  border: 1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(180deg, rgba(68, 49, 31, .92), rgba(26, 22, 21, .94));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.15),
    inset 0 -2px 0 rgba(0,0,0,.26),
    0 12px 28px rgba(0,0,0,.34);
  text-shadow: 0 2px 2px rgba(0,0,0,.55);
}
.ui-button:active { transform: translateY(2px); }
.ui-button:disabled {
  cursor: not-allowed;
  opacity: .58;
  filter: grayscale(.45);
}
.primary-button {
  color: #2a1705;
  font-size: 26px;
  background: linear-gradient(180deg, #ffe4a1, #d49237 58%, #9a5b1d);
  border-color: rgba(255,232,175,.65);
  text-shadow: 0 1px 0 rgba(255,255,255,.28);
}
.icon-button {
  z-index: 30;
  padding: 0;
  border-radius: 50%;
  font-size: 28px;
  background: rgba(9, 11, 16, .66);
  backdrop-filter: blur(4px);
}
.sex-button,
.nav-button,
.action-button { font-size: 18px; }
.sex-button.is-active {
  color: #2a1705;
  background: linear-gradient(180deg, #ffe4a1, #d49237 58%, #9a5b1d);
  border-color: rgba(255,232,175,.65);
  text-shadow: 0 1px 0 rgba(255,255,255,.28);
}
.nav-button {
  border-radius: 7px;
  background: linear-gradient(180deg, rgba(27, 39, 51, .93), rgba(11, 14, 20, .95));
}
.action-button {
  white-space: normal;
  line-height: 1.1;
}
.action-button small {
  display: block;
  width: 100%;
  margin-top: 4px;
  color: rgba(255,242,217,.70);
  font-size: 12px;
  font-weight: 700;
}

.game-logo {
  position: absolute;
  left: 50%;
  top: 92px;
  width: 700px;
  min-height: 220px;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-radius: 34px;
  background: radial-gradient(circle at 50% 10%, rgba(243,198,111,.17), rgba(6,8,12,.28) 70%);
}
.game-logo__mark {
  font-size: 78px;
  line-height: 1;
  color: var(--gold);
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.50));
}
.game-logo h1 {
  margin: 10px 0 0;
  font-size: 68px;
  line-height: .98;
  color: var(--gold);
  text-shadow: 0 5px 0 rgba(0,0,0,.36), 0 18px 38px rgba(0,0,0,.60);
}

.screen-title {
  position: absolute;
  left: 40px;
  top: 28px;
  margin: 0;
  color: var(--gold);
  font-size: 42px;
  line-height: 1;
  text-shadow: 0 4px 12px rgba(0,0,0,.55);
}

.character-preview {
  border-radius: 9px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 28%, rgba(243,198,111,.18), transparent 32%),
    linear-gradient(180deg, rgba(17,23,31,.68), rgba(5,6,8,.54));
  border: 1px solid rgba(243,198,111,.20);
  box-shadow: 0 18px 60px rgba(0,0,0,.38);
}
.character-preview__shadow {
  position: absolute;
  left: 50%;
  bottom: 36px;
  width: 210px;
  height: 34px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: rgba(0,0,0,.42);
  filter: blur(2px);
}
.character-preview__body {
  position: absolute;
  left: 50%;
  bottom: 70px;
  width: 138px;
  height: 170px;
  transform: translateX(-50%);
  border-radius: 54px 54px 26px 26px;
  background: linear-gradient(180deg, #76583a, #2e2730);
  box-shadow: inset 0 0 0 3px rgba(0,0,0,.16), 0 15px 28px rgba(0,0,0,.28);
  animation: previewIdle 1.6s ease-in-out infinite;
}
.character-preview__head {
  position: absolute;
  left: 50%;
  top: 82px;
  width: 92px;
  height: 92px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(circle at 38% 28%, #f3c89b, #bb7c55 65%, #573129);
  box-shadow: inset 0 -10px 0 rgba(0,0,0,.10), 0 14px 28px rgba(0,0,0,.28);
  animation: previewIdle 1.6s ease-in-out infinite;
}
.character-preview[data-gender="female"] .character-preview__body {
  width: 128px;
  border-radius: 68px 68px 30px 30px;
  background: linear-gradient(180deg, #6f3e4a, #2b202c);
}
.character-preview[data-gender="female"] .character-preview__head {
  background: radial-gradient(circle at 38% 28%, #f4ca9e, #c1845d 65%, #2d2028);
}
.character-preview__label {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 14px;
  color: rgba(255,242,217,.78);
  text-align: center;
  font-weight: 700;
  font-size: 16px;
}
@keyframes previewIdle {
  0%, 100% { margin-top: 0; }
  50% { margin-top: -6px; }
}

.field-label {
  display: flex;
  align-items: center;
  color: var(--gold);
  font-weight: 800;
  text-shadow: 0 2px 4px rgba(0,0,0,.60);
}
.text-input {
  padding: 0 16px;
  border-radius: 5px;
  border: 1px solid rgba(243,198,111,.34);
  color: var(--text);
  background: rgba(5,7,10,.72);
  outline: none;
  box-shadow: inset 0 2px 8px rgba(0,0,0,.32), 0 10px 28px rgba(0,0,0,.24);
}
.text-input:focus { border-color: rgba(255,226,160,.82); }

.race-description-panel {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 6px;
  padding: 12px 14px;
  overflow: hidden;
  border-radius: 6px;
  color: var(--text);
  background: rgba(8, 10, 14, .74);
  border: 1px solid rgba(243,198,111,.24);
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  backdrop-filter: blur(4px);
}
.race-description-panel__title {
  color: var(--gold);
  font-size: 18px;
  font-weight: 900;
  line-height: 1.1;
  text-shadow: 0 2px 4px rgba(0,0,0,.60);
}
.race-description-panel__text {
  color: rgba(255,242,217,.78);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.25;
}
.race-description-panel__stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3px;
  margin-top: 2px;
  color: rgba(255,226,160,.92);
  font-size: 13px;
  font-weight: 800;
  line-height: 1.15;
}
.race-description-panel__stats span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
}


.top-hud,
.bottom-nav,
.location-actions { position: absolute; inset: 0; pointer-events: none; }
.top-hud > *, .bottom-nav > *, .location-actions > * { pointer-events: auto; }
.location-title {
  display: flex;
  align-items: center;
  padding: 0 22px;
  border-radius: 6px;
  color: var(--gold);
  font-size: 28px;
  font-weight: 900;
  background: rgba(8, 10, 14, .72);
  border: 1px solid var(--line);
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  backdrop-filter: blur(4px);
  text-shadow: 0 3px 6px rgba(0,0,0,.52);
}
.resource-widget {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 6px;
  background: rgba(8, 10, 14, .72);
  border: 1px solid var(--line);
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  backdrop-filter: blur(4px);
}
.resource-widget__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  font-size: 20px;
}
.resource-widget--emerald .resource-widget__icon { color: var(--emerald); }
.resource-widget--gold .resource-widget__icon { color: var(--gold); }
.resource-widget--premium .resource-widget__icon { color: #ffe38f; }
.resource-widget__image {
  display: block;
  width: 38px;
  height: 38px;
  object-fit: contain;
  flex: 0 0 auto;
  pointer-events: none;
}
.resource-widget__image[hidden] { display: none; }
.resource-widget.is-inactive .resource-widget__value { color: rgba(255,242,217,.82); font-size: 18px; }
.resource-widget__value {
  color: #fff8e8;
  font-size: 22px;
  font-weight: 900;
  min-width: 74px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
.location-title.has-layout-image {
  padding: 0;
  border: 0;
  background-color: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
.location-title.has-layout-image.is-text-hidden {
  color: transparent;
  text-shadow: none;
}

.panel-overlay {
  position: absolute;
  inset: 0;
  z-index: 50;
  display: none;
  align-items: center;
  justify-content: center;
  padding: max(16px, var(--safe-top)) max(16px, var(--safe-right)) max(16px, var(--safe-bottom)) max(16px, var(--safe-left));
  background: rgba(0,0,0,.58);
  backdrop-filter: blur(4px);
}
.panel-overlay.is-open { display: flex; }
.panel-window {
  width: min(100%, 980px);
  max-height: min(92vh, 680px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  border-radius: 9px;
  background: var(--panel-strong);
  border: 1px solid rgba(243, 198, 111, .24);
  box-shadow: 0 28px 100px rgba(0,0,0,.62);
}
.panel-window__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 20px 22px;
  border-bottom: 1px solid rgba(243, 198, 111, .14);
}
.small-label {
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.panel-title {
  margin: 4px 0 0;
  color: var(--gold);
  font-size: 36px;
  line-height: 1;
}
.close-button {
  position: static;
  min-width: 120px;
  min-height: 48px;
  border-radius: 5px;
}
.panel-content {
  overflow: auto;
  padding: 24px;
}
.panel-content--stub { display: none; }
.panel-overlay[data-panel="inventory"] .panel-content--map,
.panel-overlay[data-panel="parameters"] .panel-content--map,
.panel-overlay[data-panel="talents"] .panel-content--map,
.panel-overlay[data-panel="quests"] .panel-content--map,
.panel-overlay[data-panel="premium_exchange"] .panel-content--map,
.panel-overlay[data-panel="groups"] .panel-content--map,
.panel-overlay[data-panel="clans"] .panel-content--map,
.panel-overlay[data-panel="shop_equipment"] .panel-content--map,
.panel-overlay[data-panel="shop_alchemy"] .panel-content--map,
.panel-overlay[data-panel="store"] .panel-content--map,
.panel-overlay[data-panel="chat"] .panel-content--map { display: none; }
.panel-overlay[data-panel="inventory"] .panel-content--stub,
.panel-overlay[data-panel="parameters"] .panel-content--stub,
.panel-overlay[data-panel="talents"] .panel-content--stub,
.panel-overlay[data-panel="quests"] .panel-content--stub,
.panel-overlay[data-panel="premium_exchange"] .panel-content--stub,
.panel-overlay[data-panel="groups"] .panel-content--stub,
.panel-overlay[data-panel="clans"] .panel-content--stub,
.panel-overlay[data-panel="shop_equipment"] .panel-content--stub,
.panel-overlay[data-panel="shop_alchemy"] .panel-content--stub,
.panel-overlay[data-panel="store"] .panel-content--stub,
.panel-overlay[data-panel="chat"] .panel-content--stub { display: block; }

.map-location-button.is-locked {
  opacity: 0.58;
  filter: grayscale(0.35);
  cursor: not-allowed;
}
.map-location-button.is-locked strong::after {
  content: ' 🔒';
}
.map-location-button.is-locked span {
  color: #f2d5a7;
}
.map-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.map-location-button {
  position: relative;
  min-height: 118px;
  padding: 16px;
  border-radius: 7px;
  text-align: left;
  color: var(--text);
  background: linear-gradient(180deg, rgba(45, 39, 34, .94), rgba(12, 13, 17, .96));
  border: 1px solid rgba(243,198,111,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10), 0 10px 24px rgba(0,0,0,.28);
}
.map-location-button strong {
  display: block;
  color: var(--gold);
  font-size: 21px;
  line-height: 1.1;
}
.map-location-button span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.3;
}
.map-location-button.has-layout-image {
  overflow: hidden;
  border: 1px solid rgba(243,198,111,.22);
  background-color: rgba(12, 13, 17, .72);
  background-repeat: no-repeat;
  background-position: center center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.10), 0 10px 24px rgba(0,0,0,.34);
}
.map-location-button.has-layout-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8, 10, 14, .24), rgba(8, 10, 14, .70));
  pointer-events: none;
}
.map-location-button.has-layout-image strong,
.map-location-button.has-layout-image span {
  position: relative;
  z-index: 1;
  text-shadow: 0 2px 4px rgba(0,0,0,.85);
}
.map-location-button.has-layout-image.is-text-hidden strong,
.map-location-button.has-layout-image.is-text-hidden span {
  opacity: 0;
}
.map-location-button.is-current,
.map-location-button:disabled {
  cursor: not-allowed;
  opacity: .62;
  filter: grayscale(.35);
}
.map-location-button.is-current::after {
  content: 'Вы здесь';
  position: absolute;
  right: 12px;
  bottom: 10px;
  color: var(--emerald);
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.panel-content--stub h3 {
  margin: 0 0 10px;
  color: var(--gold);
  font-size: 32px;
}
.panel-content--stub p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.5;
}

@media (max-width: 720px) {
  .panel-window { border-radius: 7px; }
  .panel-title { font-size: 28px; }
  .map-grid { grid-template-columns: 1fr; }
}

/* 0.1.6: картинки кнопок и персонаж в idle */
.ui-button.has-layout-image {
  overflow: hidden;
}
.ui-button.has-layout-image.is-text-hidden {
  color: transparent;
  text-shadow: none;
}
.ui-button.has-layout-image.is-text-hidden > * {
  opacity: 0;
}

.character-sprite {
  position: absolute;
  display: block;
  object-fit: contain;
  pointer-events: none;
  user-select: none;
}
.character-sprite[hidden] { display: none; }
.character-sprite--create {
  left: 50%;
  top: 50%;
  z-index: 3;
  width: 88%;
  height: 88%;
  transform: translate(-50%, -50%);
  object-fit: contain;
  filter: drop-shadow(0 18px 22px rgba(0,0,0,.42));
}
.character-preview.has-sprite .character-preview__body,
.character-preview.has-sprite .character-preview__head,
.character-preview.has-sprite .character-preview__shadow {
  display: none;
}
.character-preview.has-sprite {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}

.location-character {
  position: absolute;
  z-index: 4;
  pointer-events: none;
}
.location-character[hidden] { display: none; }
.location-character__placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 9px;
  color: rgba(255,242,217,.70);
  font-weight: 900;
  font-size: 22px;
  text-shadow: 0 3px 8px rgba(0,0,0,.65);
  background: radial-gradient(circle at 50% 35%, rgba(243,198,111,.16), rgba(4,5,8,.10) 70%);
  border: 1px dashed rgba(243,198,111,.22);
}
.location-character.has-sprite .location-character__placeholder { display: none; }
.character-sprite--location {
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 22px 24px rgba(0,0,0,.46));
}

/* 0.1.8: idle-персонаж собирается из split-rig структуры редактора */
.character-preview.has-rig .character-preview__body,
.character-preview.has-rig .character-preview__head,
.character-preview.has-rig .character-preview__shadow {
  display: none;
}
.character-preview.has-rig {
  background: transparent;
  border-color: transparent;
  box-shadow: none;
}
.location-character.has-rig .location-character__placeholder { display: none; }

.character-rig {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 4;
  transform: translate(-50%, -50%) scale(var(--character-rig-scale, 1));
  transform-origin: center center;
  pointer-events: none;
  user-select: none;
  filter: drop-shadow(0 22px 24px rgba(0,0,0,.46));
}
.character-rig[hidden] { display: none; }
.character-rig__part {
  position: absolute;
  overflow: hidden;
  pointer-events: none;
  user-select: none;
}
.character-rig__part:not(.is-loaded) { opacity: 0; }
.character-rig__strip {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  max-width: none;
  transform: translate3d(0, 0, 0);
  will-change: transform;
  pointer-events: none;
  user-select: none;
}
.character-preview .character-rig {
  filter: drop-shadow(0 18px 22px rgba(0,0,0,.42));
}
.character-preview__label { z-index: 8; }

/* 0.1.11: фон — большая картинка, масштабируется тем же scale от центра, что и stage. */
.scene-background {
  width: var(--scene-bg-w, 1920px);
  height: var(--scene-bg-h, 1080px);
  transform: translate(-50%, -50%) scale(var(--stage-scale));
  transform-origin: center center;
  background-size: 100% 100%, 100% 100%, 100% 100%;
}

/* 0.1.9: если кнопка сделана картинкой — не рисуем игровую рамку поверх */
.ui-button.has-layout-image {
  padding: 0;
  border: 0;
  border-radius: 0;
  background-color: transparent;
  box-shadow: none;
  text-shadow: none;
  overflow: hidden;
}
.ui-button.has-layout-image.is-text-hidden {
  color: transparent;
  text-shadow: none;
}
.ui-button.has-layout-image.is-text-hidden > * {
  opacity: 0;
}

/* 0.1.16: старт без текста, аккаунт и расы в создании персонажа */
.screen--start .game-logo { display: none !important; }
.create-account-emeralds,
.account-characters-panel,
.race-button {
  position: absolute;
}
.create-account-emeralds {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 18px;
  border-radius: 6px;
  background: rgba(8, 10, 14, .74);
  border: 1px solid rgba(121,233,181,.30);
  box-shadow: 0 12px 34px rgba(0,0,0,.34);
  color: var(--text);
  font-weight: 900;
}
.create-account-emeralds__label { color: rgba(255,242,217,.78); font-size: 15px; }
.create-account-emeralds__value { color: var(--emerald); font-size: 24px; }
.account-characters-panel {
  overflow: hidden;
  border-radius: 7px;
  background: rgba(8, 10, 14, .72);
  border: 1px solid rgba(243,198,111,.22);
  box-shadow: 0 14px 40px rgba(0,0,0,.38);
}
.account-characters-panel__title {
  padding: 12px 14px 8px;
  color: var(--gold);
  font-size: 18px;
  font-weight: 900;
  text-shadow: 0 2px 4px rgba(0,0,0,.58);
}
.account-characters-list {
  position: absolute;
  left: 10px;
  right: 10px;
  top: 46px;
  bottom: 10px;
  overflow: auto;
  padding-right: 4px;
}
.account-character-row {
  width: 100%;
  min-height: 50px;
  margin: 0 0 8px;
  padding: 8px 10px;
  border-radius: 5px;
  color: var(--text);
  text-align: left;
  background: rgba(16, 22, 31, .74);
  border: 1px solid rgba(255,255,255,.10);
  cursor: pointer;
}
.account-character-row.is-active {
  border-color: rgba(255,226,160,.72);
  background: rgba(98, 63, 29, .76);
}
.account-character-row strong {
  display: block;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 16px;
  line-height: 1.1;
}
.account-character-row span {
  display: block;
  margin-top: 4px;
  color: rgba(255,242,217,.72);
  font-size: 12px;
  line-height: 1.1;
}
.account-character-empty {
  padding: 12px;
  color: rgba(255,242,217,.68);
  font-size: 14px;
  line-height: 1.35;
}
.race-button {
  font-size: 16px;
  border-radius: 5px;
}
.race-button.is-active:not(:disabled) {
  color: #2a1705;
  background: linear-gradient(180deg, #ffe4a1, #d49237 58%, #9a5b1d);
  border-color: rgba(255,232,175,.65);
  text-shadow: 0 1px 0 rgba(255,255,255,.28);
}
.race-button:disabled::after {
  content: '🔒';
  position: absolute;
  right: 8px;
  top: 6px;
  font-size: 14px;
  color: rgba(255,255,255,.88);
  text-shadow: 0 2px 4px rgba(0,0,0,.7);
}
.character-preview[data-race="high_elf"] { filter: drop-shadow(0 0 18px rgba(160,210,255,.20)); }
.character-preview[data-race="orc"] { filter: drop-shadow(0 0 18px rgba(143,210,112,.18)); }
.character-preview[data-race="beastkin"] { filter: drop-shadow(0 0 18px rgba(255,197,128,.18)); }

/* 0.1.17: загрузка игры и общая подпись кнопок снизу */
.screen--loading {
  pointer-events: none;
}
.loading-box {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 440px;
  min-height: 132px;
  transform: translate(-50%, -50%);
  padding: 24px 28px 22px;
  border-radius: 26px;
  background: rgba(8, 10, 14, .78);
  border: 1px solid rgba(243,198,111,.34);
  box-shadow: 0 22px 70px rgba(0,0,0,.52), inset 0 1px 0 rgba(255,255,255,.08);
  text-align: center;
}
.loading-title {
  color: var(--gold);
  font-size: 26px;
  font-weight: 900;
  text-shadow: 0 3px 8px rgba(0,0,0,.62);
}
.loading-bar {
  position: relative;
  width: 100%;
  height: 18px;
  margin: 18px 0 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(0,0,0,.50);
  border: 1px solid rgba(255,255,255,.12);
}
.loading-bar__fill {
  width: 0%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #7ddfb0, #ffe4a1 55%, #d49237);
  box-shadow: 0 0 18px rgba(243,198,111,.50);
  transition: width .16s ease;
}
.loading-text {
  color: rgba(255,242,217,.78);
  font-size: 15px;
  font-weight: 700;
}
.loading-percent {
  position: absolute;
  right: 28px;
  bottom: 19px;
  color: rgba(255,242,217,.74);
  font-size: 14px;
  font-weight: 900;
}
.global-button-tooltip {
  position: absolute;
  left: 50%;
  bottom: 1px;
  min-width: 240px;
  max-width: 720px;
  height: 22px;
  transform: translateX(-50%);
  padding: 2px 18px 0;
  border-radius: 999px 999px 0 0;
  background: rgba(6, 8, 12, .72);
  border: 1px solid rgba(243,198,111,.20);
  border-bottom: 0;
  color: rgba(255,242,217,.92);
  font-size: 15px;
  font-weight: 900;
  line-height: 20px;
  text-align: center;
  text-shadow: 0 2px 4px rgba(0,0,0,.7);
  pointer-events: none;
  opacity: 0;
  z-index: 220;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: opacity .12s ease;
}
.global-button-tooltip.is-visible {
  opacity: 1;
}
.ui-button.is-locked {
  cursor: not-allowed;
  opacity: .58;
  filter: grayscale(.45);
}
.race-button.is-locked::after {
  content: '🔒';
  position: absolute;
  right: 8px;
  top: 6px;
  font-size: 14px;
  color: rgba(255,255,255,.88);
  text-shadow: 0 2px 4px rgba(0,0,0,.7);
}
.race-button:disabled::after { content: none; }

/* 0.4.0: разделы Параметры и Таланты */
.build-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
  color: var(--text);
}
.build-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 6px;
  background: linear-gradient(180deg, rgba(45, 39, 34, .92), rgba(12, 13, 17, .94));
  border: 1px solid rgba(243,198,111,.22);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.09), 0 10px 24px rgba(0,0,0,.20);
}
.build-summary__main strong {
  display: block;
  color: var(--gold);
  font-size: 24px;
  line-height: 1.1;
}
.build-summary__main span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 14px;
}
.build-status {
  min-width: 150px;
  text-align: right;
  color: var(--muted);
  font-size: 14px;
}
.build-status.is-error { color: #ffb4a8; }
.build-status.is-ok { color: #bff2b5; }
.derived-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.derived-cell {
  padding: 10px 12px;
  border-radius: 5px;
  background: rgba(9, 12, 17, .68);
  border: 1px solid rgba(255,255,255,.08);
}
.derived-cell span {
  display: block;
  color: var(--muted);
  font-size: 12px;
}
.derived-cell strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
  font-size: 18px;
}
.build-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.build-list--talents {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.build-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px;
  gap: 12px;
  align-items: center;
  padding: 12px;
  border-radius: 6px;
  background: rgba(20, 22, 28, .82);
  border: 1px solid rgba(243,198,111,.14);
}
.build-row__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.build-row__top strong {
  color: var(--gold);
  font-size: 19px;
}
.build-row__top span {
  color: var(--text);
  font-weight: 700;
}
.build-row__info p {
  margin: 4px 0 8px;
  min-height: 32px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.25;
}
.build-progress {
  overflow: hidden;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
}
.build-progress__fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(243,198,111,.75), rgba(255,238,166,.95));
}
.build-row__actions {
  display: flex;
  flex-direction: column;
  gap: 7px;
  align-items: stretch;
}
.build-cost {
  color: var(--muted);
  font-size: 12px;
  text-align: center;
}
.build-upgrade-button,
.build-reset-button {
  min-height: 42px;
  border-radius: 5px;
  font-size: 16px;
}
.build-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: 2px;
}
.build-reset-button {
  min-width: 210px;
}
.build-empty {
  margin: 0;
  padding: 22px;
  border-radius: 6px;
  color: var(--muted);
  background: rgba(9, 12, 17, .68);
}
@media (max-width: 900px) {
  .derived-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .build-list--talents { grid-template-columns: 1fr; }
  .build-row { grid-template-columns: 1fr; }
  .build-status { text-align: left; }
  .build-summary { align-items: flex-start; flex-direction: column; }
}

/* 0.4.1: черновик талантов, +/-, sticky footer */
.build-row--draft.is-changed {
  border-color: rgba(144, 211, 255, .42);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 0 0 1px rgba(144,211,255,.08);
}
.talent-effect {
  margin: 0 0 8px;
  color: rgba(191, 242, 181, .92);
  font-size: 13px;
  line-height: 1.25;
}
.build-row__actions--stepper {
  display: grid;
  grid-template-columns: 42px minmax(32px, 1fr) 42px;
  align-items: center;
  gap: 6px;
}
.build-step-button {
  min-height: 42px;
  border-radius: 5px;
  font-size: 24px;
  line-height: 1;
  padding: 0;
}
.build-delta {
  min-height: 42px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  background: rgba(0,0,0,.24);
  border: 1px solid rgba(255,255,255,.08);
  font-weight: 800;
}
.build-footer--talents {
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 12px;
  border-radius: 6px;
  background: linear-gradient(180deg, rgba(26, 27, 34, .97), rgba(10, 12, 16, .98));
  border: 1px solid rgba(243,198,111,.22);
  box-shadow: 0 -8px 22px rgba(0,0,0,.25);
}
.build-footer--sticky {
  position: sticky;
  bottom: 0;
  z-index: 5;
}
.build-apply-summary strong,
.build-apply-summary span {
  display: block;
}
.build-apply-summary strong {
  color: var(--gold);
  font-size: 17px;
}
.build-apply-summary span {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
}
.build-footer__buttons {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.build-apply-button {
  min-height: 42px;
  min-width: 150px;
  border-radius: 5px;
  font-size: 16px;
}
@media (max-width: 900px) {
  .build-footer--talents { align-items: stretch; flex-direction: column; }
  .build-footer__buttons { justify-content: stretch; }
  .build-footer__buttons .ui-button { flex: 1 1 180px; }
}

/* 0.4.7: footer талантов прикреплён к рамке окна, а не плавает отдельно */
.panel-overlay[data-panel="talents"] .panel-content--stub {
  padding-bottom: 0;
}
.panel-overlay[data-panel="talents"] .build-panel {
  min-height: 100%;
}
.panel-overlay[data-panel="talents"] .build-footer--sticky {
  bottom: 0;
  margin: 2px -24px 0;
  padding: 12px 24px calc(12px + max(0px, var(--safe-bottom)));
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  border-radius: 0 0 24px 24px;
}
@media (max-width: 900px) {
  .panel-overlay[data-panel="talents"] .build-footer--sticky {
    margin-left: -24px;
    margin-right: -24px;
  }
}



/* 0.4.8: кнопки + / - внутри строк талантов привязаны к своим рамкам */
.build-panel .ui-button,
.build-panel .build-step-button,
.build-panel .build-upgrade-button,
.build-panel .build-reset-button,
.build-panel .build-apply-button {
  position: static;
}
.build-row,
.build-row__info,
.build-row__actions,
.build-row__actions--stepper {
  position: relative;
}
.build-row__actions--stepper {
  align-self: center;
  justify-self: stretch;
}
.build-step-button {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
}
.build-row--draft .build-row__actions--stepper {
  grid-template-columns: 42px minmax(32px, 1fr) 42px;
}

/* 0.4.9: отдельный сброс параметров */
.build-footer--params {
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 12px;
  border-radius: 6px;
  background: linear-gradient(180deg, rgba(26, 27, 34, .94), rgba(10, 12, 16, .96));
  border: 1px solid rgba(243,198,111,.18);
}
@media (max-width: 900px) {
  .build-footer--params { align-items: stretch; flex-direction: column; }
}

/* 0.5.0: параметры тоже работают через черновик и одну кнопку применения */
.panel-overlay[data-panel="parameters"] .panel-content--stub {
  padding-bottom: 0;
}
.panel-overlay[data-panel="parameters"] .build-panel {
  min-height: 100%;
}
.panel-overlay[data-panel="parameters"] .build-footer--sticky {
  bottom: 0;
  margin: 2px -24px 0;
  padding: 12px 24px calc(12px + max(0px, var(--safe-bottom)));
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  border-radius: 0 0 24px 24px;
}
.build-row--stat-draft .build-row__actions--stepper {
  grid-template-columns: 42px minmax(32px, 1fr) 42px;
}
@media (max-width: 900px) {
  .panel-overlay[data-panel="parameters"] .build-footer--sticky {
    margin-left: -24px;
    margin-right: -24px;
  }
}

/* 0.5.1: полноценный экран инвентаря */
.panel-overlay[data-panel="inventory"] .panel-content--stub {
  min-height: 0;
}
.inventory-panel {
  display: grid;
  grid-template-columns: 330px minmax(0, 1fr);
  gap: 18px;
  min-height: 540px;
  color: var(--text);
}
.inventory-panel .ui-button,
.inventory-category-button {
  position: static;
}
.inventory-left,
.inventory-right {
  min-height: 0;
  border-radius: 7px;
  background: linear-gradient(180deg, rgba(31, 32, 40, .92), rgba(10, 12, 16, .96));
  border: 1px solid rgba(243,198,111,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 34px rgba(0,0,0,.22);
}
.inventory-left {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px;
}
.inventory-right {
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.inventory-side-title {
  color: var(--gold);
  font-weight: 900;
  font-size: 19px;
  letter-spacing: .02em;
}
.inventory-categories {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.inventory-category-button {
  justify-content: flex-start;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 5px;
  font-size: 14px;
}
.inventory-category-button.is-active {
  color: #2a1705;
  border-color: rgba(255,234,163,.75);
  background: linear-gradient(180deg, #ffe6a5, #d69338);
}
.inventory-preview {
  flex: 1 1 auto;
  min-height: 240px;
  padding: 13px;
  border-radius: 6px;
  background: rgba(8, 10, 14, .58);
  border: 1px solid rgba(255,255,255,.08);
}
.inventory-preview h3 {
  margin: 0 0 10px;
  color: var(--gold);
  font-size: 20px;
  line-height: 1.12;
}
.inventory-preview__visual {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 132px;
  margin-bottom: 10px;
  border-radius: 6px;
  background:
    radial-gradient(circle at 50% 36%, rgba(255,225,145,.18), transparent 46%),
    linear-gradient(180deg, rgba(45,38,31,.9), rgba(11,13,18,.96));
  border: 1px solid rgba(243,198,111,.16);
}
.inventory-preview__visual span {
  display: block;
  color: rgba(255,226,150,.94);
  font-size: 56px;
  line-height: 1;
  text-shadow: 0 10px 22px rgba(0,0,0,.55);
}
.inventory-preview__meta,
.inventory-preview__empty {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}
.inventory-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  margin-top: 10px;
}
.inventory-stat {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  padding: 7px 9px;
  border-radius: 11px;
  background: rgba(255,255,255,.045);
}
.inventory-stat span {
  color: var(--muted);
  font-size: 12px;
}
.inventory-stat strong {
  color: var(--text);
  font-size: 13px;
  text-align: right;
}
.inventory-effect {
  margin-top: 10px;
  padding: 9px 10px;
  border-radius: 4px;
  background: rgba(66, 48, 28, .32);
  border: 1px solid rgba(243,198,111,.12);
}
.inventory-effect span {
  display: block;
  color: var(--gold);
  font-weight: 900;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.inventory-effect p {
  margin: 5px 0 0;
  color: var(--text);
  font-size: 13px;
  line-height: 1.3;
}
.inventory-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 15px 16px;
  border-bottom: 1px solid rgba(243,198,111,.14);
}
.inventory-list-header span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .1em;
}
.inventory-list-header strong {
  display: block;
  margin-top: 3px;
  color: var(--gold);
  font-size: 24px;
}
.inventory-status {
  color: var(--muted);
  font-size: 13px;
  white-space: nowrap;
}
.inventory-status.is-error { color: #ffb4a8; }
.inventory-list {
  overflow: auto;
  padding: 12px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}
.inventory-item-row {
  position: relative;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 72px;
  padding: 10px;
  border-radius: 5px;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  background: rgba(20, 22, 28, .82);
  border: 1px solid rgba(243,198,111,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.inventory-item-row:hover,
.inventory-item-row.is-selected {
  border-color: rgba(243,198,111,.45);
  background: rgba(47, 38, 28, .88);
}
.inventory-item-row.is-equipped::after {
  content: 'Надето';
  position: absolute;
  right: 9px;
  top: 8px;
  color: #bff2b5;
  font-size: 11px;
  font-weight: 900;
}
.inventory-item-row b {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 5px;
  color: rgba(255,226,150,.95);
  font-size: 24px;
  background: rgba(8,10,14,.72);
  border: 1px solid rgba(255,255,255,.08);
}
.inventory-item-row strong {
  display: block;
  overflow: hidden;
  color: var(--gold);
  font-size: 15px;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.inventory-item-row span {
  display: block;
  overflow: hidden;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.inventory-empty {
  grid-column: 1 / -1;
  padding: 22px;
  border-radius: 6px;
  color: var(--muted);
  background: rgba(9, 12, 17, .68);
  border: 1px solid rgba(255,255,255,.07);
}
@media (max-width: 900px) {
  .inventory-panel { grid-template-columns: 1fr; }
  .inventory-list { grid-template-columns: 1fr; }
}

/* 0.5.2 inventory accordion/action layout */
.inventory-panel--accordion {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 0;
}
.inventory-list-header--wide {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.inventory-accordion {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 0;
  overflow-y: auto;
  padding-right: 4px;
}
.inventory-section {
  border: 1px solid rgba(245, 216, 151, 0.28);
  border-radius: 5px;
  background: rgba(18, 15, 18, 0.62);
  overflow: hidden;
}
.inventory-section-toggle,
.inventory-panel--accordion .inventory-section-toggle.ui-button {
  position: static;
  width: 100%;
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 14px;
  border: 0;
  border-radius: 0;
  background: linear-gradient(180deg, rgba(83, 59, 41, 0.88), rgba(42, 30, 28, 0.88));
  color: #ffe4b6;
  text-align: left;
  transform: none;
}
.inventory-section-toggle strong {
  min-width: 34px;
  padding: 3px 9px;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
  text-align: center;
}
.inventory-section.is-open .inventory-section-toggle {
  background: linear-gradient(180deg, rgba(112, 77, 45, 0.95), rgba(56, 37, 29, 0.95));
}
.inventory-section-body {
  display: grid;
  grid-template-columns: minmax(220px, 0.95fr) minmax(260px, 1.25fr);
  gap: 12px;
  padding: 12px;
}
.inventory-inline-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 420px;
  overflow-y: auto;
  padding-right: 4px;
}
.inventory-preview--inline {
  margin: 0;
  min-height: 0;
}
.inventory-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 12px;
}
.inventory-panel .inventory-action-button,
.inventory-panel .inventory-action-button.ui-button {
  position: static;
  min-height: 40px;
  border-radius: 4px;
  transform: none;
  padding: 7px 8px;
}
.inventory-action-button.is-danger {
  background: linear-gradient(180deg, rgba(115, 45, 40, 0.95), rgba(64, 28, 28, 0.95));
  color: #ffd9d2;
}
.inventory-item-row,
.inventory-panel .inventory-item-row.ui-button {
  position: static;
}
@media (max-width: 760px) {
  .inventory-section-body { grid-template-columns: 1fr; }
  .inventory-actions { grid-template-columns: 1fr; }
  .inventory-inline-list { max-height: 280px; }
}

/* 0.5.4: consumables/potions in inventory dropdown */
.inventory-active-potion {
  margin-top: 9px;
  padding: 8px 10px;
  border-radius: 4px;
  color: #d7f5c6;
  background: rgba(60, 91, 48, .22);
  border: 1px solid rgba(183, 242, 149, .18);
  font-size: 12px;
  line-height: 1.32;
}
.inventory-active-potion--bar {
  margin: 10px 12px 0;
}
.inventory-actions--consumable {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* 0.5.3: inventory returns to left preview + right list; category is Dropdown */
.inventory-panel--dropdown {
  grid-template-columns: 330px minmax(0, 1fr);
  min-height: 540px;
}
.inventory-panel--dropdown .inventory-left,
.inventory-panel--dropdown .inventory-right {
  min-height: 0;
}
.inventory-left--dropdown {
  overflow: hidden;
}
.inventory-type-select-wrap {
  display: grid;
  gap: 7px;
}
.inventory-type-select-wrap span {
  color: var(--gold);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.inventory-type-select {
  width: 100%;
  min-height: 44px;
  border-radius: 5px;
  padding: 0 13px;
  color: var(--text);
  background: rgba(12, 14, 18, .9);
  border: 1px solid rgba(243,198,111,.28);
  outline: none;
  font-weight: 800;
}
.inventory-type-select:focus {
  border-color: rgba(255,226,150,.72);
  box-shadow: 0 0 0 2px rgba(243,198,111,.12);
}
.inventory-preview--left {
  display: flex;
  flex-direction: column;
  overflow: auto;
}
.inventory-preview--left .inventory-actions {
  margin-top: auto;
  padding-top: 12px;
}
.inventory-list--dropdown {
  flex: 1 1 auto;
  min-height: 0;
}
.inventory-right--dropdown {
  overflow: hidden;
}
.inventory-slot-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-top: 1px solid rgba(243,198,111,.14);
  background: rgba(8, 10, 14, .42);
}
.inventory-slot-count span,
.inventory-slot-buy span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}
.inventory-slot-count strong {
  display: block;
  color: var(--gold);
  font-size: 22px;
  line-height: 1.1;
}
.inventory-slot-buy {
  display: flex;
  align-items: center;
  gap: 10px;
  text-align: right;
}
.inventory-panel .inventory-slot-buy-button,
.inventory-panel .inventory-slot-buy-button.ui-button {
  position: static;
  min-height: 40px;
  padding: 7px 12px;
  border-radius: 4px;
  transform: none;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .inventory-panel--dropdown { grid-template-columns: 1fr; }
  .inventory-slot-footer { align-items: flex-start; flex-direction: column; }
  .inventory-slot-buy { width: 100%; justify-content: space-between; text-align: left; }
}

/* 0.5.5: задания гильдии и группы */
.quests-panel,
.groups-panel {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  color: #f6edd7;
}

.quest-panel-head,
.group-tabs,
.group-status-line,
.quest-status {
  border: 1px solid rgba(255, 230, 170, 0.22);
  background: rgba(31, 20, 18, 0.72);
  border-radius: 5px;
  padding: 10px 12px;
  box-shadow: inset 0 0 18px rgba(0, 0, 0, 0.22);
}

.quest-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.quest-panel-head strong,
.group-create-box h3,
.group-status-box h3 {
  display: block;
  font-size: 18px;
  letter-spacing: 0.02em;
  margin: 0 0 4px;
}

.quest-panel-head span,
.quest-card__desc,
.group-create-box p,
.group-search-hint,
.group-status-box p {
  display: block;
  color: rgba(246, 237, 215, 0.78);
  font-size: 13px;
  line-height: 1.35;
}

.quest-status,
.group-status-line {
  min-height: 34px;
  display: flex;
  align-items: center;
  color: rgba(246, 237, 215, 0.82);
}

.quest-status.is-error,
.group-status-line.is-error {
  color: #ffb5a9;
  border-color: rgba(255, 130, 110, 0.45);
}

.quest-list {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding-right: 4px;
}

.quest-card,
.quest-empty,
.group-empty,
.group-search-row,
.group-create-box,
.group-status-box,
.group-search-hint {
  border: 1px solid rgba(255, 230, 170, 0.22);
  background: rgba(22, 14, 16, 0.76);
  border-radius: 5px;
  padding: 12px;
}

.quest-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-height: 154px;
}

.quest-card.is-complete {
  border-color: rgba(148, 235, 145, 0.46);
}

.quest-card.is-claimed {
  opacity: 0.74;
}

.quest-card__top,
.quest-card__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.quest-card__top h3 {
  margin: 0;
  font-size: 16px;
}

.quest-card__badge {
  flex: 0 0 auto;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 213, 125, 0.12);
  border: 1px solid rgba(255, 230, 170, 0.20);
  font-size: 12px;
}

.quest-progress {
  height: 8px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(0, 0, 0, 0.34);
  border: 1px solid rgba(255, 230, 170, 0.14);
}

.quest-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #9f6b35, #f1c15e);
}

.quest-card__reward {
  color: rgba(246, 237, 215, 0.82);
  font-size: 12px;
}

.quest-claim-button,
.quest-refresh-button,
.group-create-button,
.group-apply-button,
.group-application-button,
.group-leave-button,
.group-tab {
  position: static;
  min-width: 120px;
  height: 34px;
  padding: 0 12px;
  white-space: nowrap;
}

.group-tabs {
  display: flex;
  gap: 8px;
  align-items: center;
}

.group-tab.is-active {
  filter: brightness(1.18);
  transform: translateY(-1px);
}

.group-grid {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.9fr);
  gap: 12px;
}

.group-left,
.group-right {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.group-search-list {
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-right: 4px;
}

.group-search-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.group-search-row__info {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.group-search-row__info strong {
  font-size: 15px;
}

.group-search-row__info span,
.group-meta-lines,
.group-members {
  color: rgba(246, 237, 215, 0.76);
  font-size: 12px;
}

.group-status-box {
  min-height: 180px;
}

.group-meta-lines {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0;
}

.group-meta-lines span {
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 213, 125, 0.10);
  border: 1px solid rgba(255, 230, 170, 0.16);
}

.group-members {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

@media (max-width: 760px) {
  .quest-list,
  .group-grid {
    grid-template-columns: 1fr;
  }
}

/* 0.5.6: группы — поиск/создание слева, состояние и заявки справа */
.group-grid--guild {
  grid-template-columns: minmax(220px, 0.72fr) minmax(0, 1.28fr);
}

.group-tabs--side {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 8px;
}

.group-tabs--side .group-tab {
  width: 100%;
}

.group-list-title {
  border: 1px solid rgba(255, 230, 170, 0.22);
  background: rgba(31, 20, 18, 0.72);
  border-radius: 5px;
  padding: 10px 12px;
  font-weight: 700;
  color: #f6edd7;
}

.group-status-box + .group-status-box,
.group-search-list + .group-status-box {
  margin-top: 10px;
}

.group-own-controls,
.group-application-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.group-leave-button,
.group-application-button {
  position: static;
  min-width: 112px;
  height: 34px;
  padding: 0 12px;
  white-space: nowrap;
}

.group-applications {
  margin-top: 12px;
  border-top: 1px solid rgba(255, 230, 170, 0.16);
  padding-top: 10px;
}

.group-applications h4 {
  margin: 0 0 8px;
  font-size: 15px;
  color: #f6edd7;
}

.group-application-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 0;
  border-top: 1px solid rgba(255, 230, 170, 0.09);
}

.group-application-row:first-of-type {
  border-top: 0;
}

.group-application-row__info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}

.group-application-row__info strong {
  color: #f6edd7;
  font-size: 14px;
}

.group-application-row__info span,
.group-empty--small {
  color: rgba(246, 237, 215, 0.76);
  font-size: 12px;
}

.group-empty--small {
  padding: 8px;
}

@media (max-width: 760px) {
  .group-grid--guild {
    grid-template-columns: 1fr;
  }
  .group-tabs--side {
    flex-direction: row;
  }
}

/* 0.6.0: торговая площадь — магазины по принципу инвентаря */
.shop-panel .shop-list-header strong {
  color: #f4d88a;
}
.shop-panel .shop-item-row strong {
  letter-spacing: .01em;
}
.shop-panel .shop-preview .inventory-preview__meta {
  color: #e8cf91;
}
.shop-actions {
  margin-top: 10px;
}
.shop-buy-button:disabled {
  opacity: .55;
  filter: grayscale(.35);
}
.shop-footer-note {
  max-width: 360px;
  justify-content: flex-end;
  text-align: right;
  color: rgba(255, 239, 196, .78);
  font-size: 13px;
}
.shop-type-select-wrap span:first-child::after {
  content: ' магазина';
  opacity: .75;
}

/* 0.6.2: лавка алхимика плоским списком, как задания */
.shop-flat-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 520px;
}
.shop-flat-header {
  align-items: flex-start;
}
.shop-flat-header strong {
  display: block;
  color: var(--gold);
  font-size: 22px;
}
.shop-flat-header span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.35;
}
.shop-flat-selected {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-radius: 6px;
  background: rgba(25, 21, 17, .78);
  border: 1px solid rgba(243,198,111,.18);
}
.shop-flat-selected b {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 5px;
  color: rgba(255,226,150,.95);
  font-size: 30px;
  background: rgba(8,10,14,.72);
  border: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
}
.shop-flat-selected b img {
  display: block;
  width: 50px;
  height: 50px;
  object-fit: contain;
  filter: drop-shadow(0 3px 7px rgba(255,214,119,.45));
}
.shop-flat-selected strong {
  display: block;
  color: var(--gold);
  font-size: 18px;
}
.shop-flat-selected span {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.35;
}
.shop-flat-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
  min-height: 0;
  overflow: auto;
}
.shop-flat-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(132px, auto) 112px;
  gap: 12px;
  align-items: center;
  cursor: pointer;
}
.shop-flat-row.is-selected {
  border-color: rgba(243,198,111,.52);
  background: rgba(50, 38, 27, .86);
}
.shop-flat-main strong {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--gold);
  font-size: 16px;
}
.shop-flat-item-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  color: rgba(255,226,150,.95);
  font-size: 18px;
}
.shop-flat-item-icon img {
  display: block;
  width: 28px;
  height: 28px;
  object-fit: contain;
  filter: drop-shadow(0 2px 5px rgba(255,214,119,.38));
}
.shop-flat-main span {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.32;
}
.shop-flat-meta {
  min-width: 132px;
  width: max-content;
  justify-self: end;
  text-align: right;
  padding-left: 10px;
  padding-right: 10px;
  white-space: nowrap;
}
.shop-flat-meta strong {
  display: block;
  min-width: 92px;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
.shop-flat-buy,
.shop-flat-panel .shop-flat-buy.ui-button {
  position: static;
  min-height: 40px;
  border-radius: 4px;
  transform: none;
}
.shop-flat-buy:disabled {
  opacity: .55;
  filter: grayscale(.35);
}
@media (max-width: 760px) {
  .shop-flat-row { grid-template-columns: 1fr; align-items: stretch; }
  .shop-flat-meta { text-align: left; }
}

/* 0.6.3: арена — недельный турнир */
.panel-overlay[data-panel="arena"] .panel-content--map,
.panel-overlay[data-panel="pve_zone"] .panel-content--map { display: none; }
.panel-overlay[data-panel="arena"] .panel-content--stub,
.panel-overlay[data-panel="pve_zone"] .panel-content--stub { display: block; }
.arena-panel {
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 12px;
  color: #f6edd7;
}
.arena-head,
.arena-status,
.arena-card,
.arena-rules {
  border: 1px solid rgba(255, 230, 170, 0.22);
  background: rgba(31, 20, 18, 0.72);
  border-radius: 5px;
  padding: 10px 12px;
  box-shadow: inset 0 0 18px rgba(0, 0, 0, 0.22);
}
.arena-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.arena-head strong,
.arena-card h3,
.arena-rules b {
  display: block;
  color: var(--gold);
  font-size: 18px;
  margin: 0 0 4px;
}
.arena-head span,
.arena-rules p,
.arena-entry-box span,
.arena-card p {
  display: block;
  color: rgba(246, 237, 215, 0.78);
  font-size: 13px;
  line-height: 1.35;
  margin: 4px 0;
}
.arena-small-button,
.arena-join-button,
.arena-head__buttons .ui-button {
  position: static;
  transform: none;
  min-height: 42px;
  min-width: 150px;
  padding: 8px 12px;
  white-space: normal;
}
.arena-status {
  min-height: 34px;
  display: flex;
  align-items: center;
  color: rgba(246, 237, 215, 0.82);
}
.arena-status.is-error { color: #ffb5a9; border-color: rgba(255, 130, 110, 0.45); }
.arena-grid {
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(320px, 1.25fr);
  gap: 12px;
  min-height: 0;
}
.arena-entry-box {
  border: 1px solid rgba(255, 230, 170, 0.16);
  background: rgba(15, 12, 14, 0.48);
  border-radius: 4px;
  padding: 10px;
  margin-top: 8px;
}
.arena-entry-box strong { display: block; color: #ffe2a3; margin-bottom: 4px; }
.arena-standings,
.arena-matches {
  display: grid;
  gap: 8px;
  max-height: 240px;
  overflow: auto;
  padding-right: 4px;
}
.arena-standing-row,
.arena-match-row,
.arena-empty {
  border: 1px solid rgba(255, 230, 170, 0.14);
  background: rgba(15, 12, 14, 0.52);
  border-radius: 11px;
  padding: 8px 10px;
}
.arena-standing-row {
  display: grid;
  grid-template-columns: 1.4fr 0.7fr 0.8fr;
  gap: 8px;
  align-items: center;
}
.arena-standing-row.is-current { border-color: rgba(255, 214, 123, 0.55); background: rgba(91, 59, 20, 0.42); }
.arena-standing-row b { color: #fff4cf; }
.arena-standing-row span,
.arena-match-row span { color: rgba(246, 237, 215, 0.78); font-size: 13px; }
.arena-match-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.arena-match-row b { color: #ffe2a3; font-size: 13px; }
.arena-matches-card { min-height: 0; }
@media (max-width: 900px) {
  .arena-grid { grid-template-columns: 1fr; }
  .arena-head { align-items: stretch; flex-direction: column; }
  .arena-standing-row { grid-template-columns: 1fr; }
  .arena-match-row { align-items: flex-start; flex-direction: column; }
}

/* 0.6.4: боёвка арены — всплывающие надписи без анимации защиты */
.arena-match-row__info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.arena-replay-button {
  min-width: 96px;
  min-height: 34px;
  padding: 6px 10px;
}
.arena-replay-card {
  min-height: 240px;
}
.arena-battle-scene {
  position: relative;
  display: grid;
  grid-template-columns: minmax(160px, 1fr) 64px minmax(160px, 1fr);
  gap: 10px;
  align-items: stretch;
  margin-top: 8px;
}
.arena-fighter {
  position: relative;
  min-height: 112px;
  border: 1px solid rgba(255, 230, 170, 0.16);
  background: radial-gradient(circle at center 35%, rgba(255, 218, 142, 0.12), rgba(12, 10, 14, 0.62));
  border-radius: 5px;
  padding: 12px;
  overflow: hidden;
}
.arena-fighter b {
  display: block;
  color: #fff4cf;
  font-size: 15px;
}
.arena-fighter span:not(.arena-float) {
  display: block;
  margin-top: 4px;
  color: rgba(246, 237, 215, 0.7);
  font-size: 12px;
}
.arena-hpbar {
  height: 9px;
  border: 1px solid rgba(255, 230, 170, 0.18);
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.32);
  overflow: hidden;
  margin-top: 9px;
}
.arena-hpbar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(205, 78, 54, .9), rgba(255, 188, 83, .9));
}
.arena-battle-vs {
  align-self: center;
  justify-self: center;
  color: var(--gold);
  font-weight: 900;
  letter-spacing: .08em;
}
.arena-fighter__float {
  pointer-events: none;
  position: absolute;
  inset: 0;
}
.arena-float {
  position: absolute;
  left: 50%;
  top: 58%;
  transform: translate(-50%, 0);
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(8, 6, 8, .58);
  border: 1px solid rgba(255, 255, 255, .14);
  font-weight: 800;
  font-size: 14px;
  white-space: nowrap;
  text-shadow: 0 1px 2px rgba(0,0,0,.9);
  animation: arenaFloatUp 1.15s ease-out forwards;
}
.arena-float--red { color: #ff8b77; }
.arena-float--orange { color: #ffd36a; }
.arena-float--yellow { color: #fff09b; }
.arena-float--green { color: #8ef0a0; }
.arena-float--violet { color: #d5a6ff; }
.arena-float--blue { color: #9bd4ff; }
.arena-float--gray { color: #c7c0b4; }
.arena-float--white { color: #f7f0df; }
@keyframes arenaFloatUp {
  0% { opacity: 0; transform: translate(-50%, 10px) scale(.92); }
  12% { opacity: 1; }
  78% { opacity: 1; }
  100% { opacity: 0; transform: translate(-50%, -54px) scale(1.04); }
}
.arena-replay-result {
  margin-top: 8px;
  color: rgba(246, 237, 215, .84);
  font-size: 13px;
}
.arena-battle-log {
  margin-top: 10px;
  max-height: 190px;
  overflow: auto;
  display: grid;
  gap: 6px;
  padding-right: 4px;
}
.arena-battle-log-row {
  display: grid;
  grid-template-columns: 52px minmax(130px, .8fr) minmax(160px, 1fr);
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(255, 230, 170, .10);
  background: rgba(15, 12, 14, .46);
  border-radius: 3px;
  padding: 6px 8px;
}
.arena-battle-log-row span {
  color: rgba(246, 237, 215, .62);
  font-size: 12px;
}
.arena-battle-log-row b {
  color: #ffe2a3;
  font-size: 13px;
}
.arena-battle-log-row em {
  color: rgba(246, 237, 215, .78);
  font-style: normal;
  font-size: 12px;
}
@media (max-width: 760px) {
  .arena-battle-scene { grid-template-columns: 1fr; }
  .arena-battle-vs { display: none; }
  .arena-battle-log-row { grid-template-columns: 1fr; }
}

/* 0.6.8: PvE test zone at main gate. */
.pve-zone-shell {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.pve-zone-desc {
  margin: 0;
  line-height: 1.45;
  opacity: 0.92;
}

.pve-battle-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.pve-battle-button {
  min-height: 82px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  text-align: center;
}

.pve-battle-button b,
.pve-battle-button span,
.pve-battle-button small {
  display: block;
  pointer-events: none;
}

.pve-battle-button small {
  opacity: 0.82;
  font-size: 12px;
}

.pve-reward-preview {
  padding: 10px 12px;
  border-radius: 4px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.pve-battle-controls {
  display: flex;
  justify-content: center;
  margin-top: 12px;
}

@media (max-width: 720px) {
  .pve-battle-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* 0.6.10: PvE battle scene uses real player rig/full-sprite animation and full HP on zone start. */
.pve-zone-shell--battle {
  gap: 10px;
}

.pve-battle-loading {
  min-height: 300px;
  border: 1px solid rgba(255, 230, 170, 0.16);
  border-radius: 6px;
  background:
    radial-gradient(circle at 50% 20%, rgba(255, 218, 142, 0.16), transparent 38%),
    linear-gradient(145deg, rgba(17, 22, 28, 0.88), rgba(38, 25, 15, 0.88));
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  text-align: center;
  color: rgba(246, 237, 215, 0.86);
}
.pve-battle-loading b {
  color: #fff4cf;
  font-size: 18px;
}
.pve-battle-loading span {
  max-width: 520px;
  opacity: 0.82;
}

.pve-battle-scene-card {
  border: 1px solid rgba(255, 230, 170, 0.16);
  border-radius: 6px;
  padding: 12px;
  background: rgba(13, 10, 12, 0.62);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.035), 0 12px 36px rgba(0,0,0,.28);
}

.pve-battle-topline,
.pve-battle-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.pve-battle-topline b {
  display: block;
  color: #fff4cf;
  font-size: 16px;
}
.pve-battle-topline span,
.pve-battle-buffs,
.pve-battle-result {
  color: rgba(246, 237, 215, 0.74);
  font-size: 12px;
}
.pve-battle-result {
  min-width: 160px;
  text-align: right;
  color: #ffe2a3;
  font-weight: 700;
}
.pve-battle-bottom {
  margin: 10px 0 0;
}
.pve-battle-buffs {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pve-combat-scene {
  position: relative;
  min-height: min(52vh, 430px);
  border-radius: 5px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 18%, rgba(255, 226, 163, 0.17), transparent 42%),
    linear-gradient(180deg, rgba(77, 98, 101, .46), rgba(28, 46, 31, .78) 55%, rgba(18, 16, 14, .9));
  border: 1px solid rgba(255, 230, 170, 0.14);
  box-shadow: inset 0 -65px 120px rgba(0,0,0,.38);
}
.pve-combat-vignette {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 50% 44%, transparent 45%, rgba(0,0,0,.48) 100%);
}
.pve-combat-ground {
  position: absolute;
  left: 5%;
  right: 5%;
  bottom: 0;
  height: 78%;
}
.pve-combat-ground::after {
  content: '';
  position: absolute;
  left: 5%;
  right: 5%;
  bottom: 22px;
  height: 72px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(30, 22, 12, .54), transparent 66%);
  filter: blur(2px);
}

.pve-combatant {
  position: absolute;
  bottom: 34px;
  width: min(30vw, 250px);
  height: min(34vh, 280px);
  min-width: 145px;
  min-height: 190px;
  transition: opacity .5s ease, filter .5s ease, transform .2s ease;
  z-index: 2;
}
.pve-combatant--player {
  left: 6%;
}
.pve-combatant--enemy {
  right: 6%;
}
.pve-combatant-name,
.pve-combatant-hptext {
  position: relative;
  z-index: 4;
  text-align: center;
  text-shadow: 0 2px 3px rgba(0,0,0,.88);
}
.pve-combatant-name {
  color: #fff4cf;
  font-weight: 800;
  margin-bottom: 4px;
}
.pve-combatant-hp {
  position: relative;
  z-index: 4;
  width: 78%;
  height: 10px;
  margin: 0 auto 4px;
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid rgba(255,230,170,.22);
  background: rgba(0,0,0,.46);
}
.pve-combatant-hp i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(198, 61, 48, .95), rgba(255, 185, 76, .95));
  transition: width .25s ease;
}
.pve-combatant-hptext {
  color: rgba(246, 237, 215, .78);
  font-size: 12px;
}
.pve-combatant-sprite {
  position: absolute;
  left: 50%;
  bottom: 18px;
  width: 78%;
  height: 74%;
  transform: translateX(-50%);
  transform-origin: 50% 100%;
  z-index: 3;
}
.pve-combatant-sprite-img {
  position: absolute;
  left: 50%;
  bottom: 0;
  max-width: 100%;
  max-height: 100%;
  transform: translateX(-50%);
  object-fit: contain;
  filter: drop-shadow(0 12px 10px rgba(0,0,0,.45));
}
.pve-combatant-sprite.is-flipped .pve-combatant-sprite-img {
  transform: translateX(-50%) scaleX(-1);
}
.pve-combatant-sprite-fallback {
  position: absolute;
  left: 50%;
  bottom: 0;
  width: 116px;
  height: 142px;
  transform: translateX(-50%);
  border-radius: 48% 48% 42% 42%;
  display: grid;
  place-items: center;
  color: rgba(255,244,207,.92);
  font-size: 58px;
  font-weight: 900;
  background:
    radial-gradient(circle at 48% 24%, rgba(255,255,255,.22), transparent 24%),
    linear-gradient(180deg, rgba(93, 139, 72, .96), rgba(44, 88, 58, .96));
  border: 2px solid rgba(255,230,170,.22);
  box-shadow: inset 0 -18px 28px rgba(0,0,0,.22), 0 16px 18px rgba(0,0,0,.34);
}
.pve-combatant--player .pve-combatant-sprite-fallback {
  border-radius: 42% 42% 16% 16%;
  background:
    radial-gradient(circle at 50% 22%, rgba(255,225,169,.84) 0 18%, transparent 19%),
    linear-gradient(180deg, rgba(92, 128, 173, .96), rgba(49, 67, 102, .96));
}
.pve-combatant-sprite.has-pve-visual .pve-combatant-sprite-fallback {
  display: none;
}
.pve-combatant-sprite--rig {
  width: min(92%, 292px);
  height: min(102%, 372px);
}
.pve-combatant-sprite--full {
  width: min(86%, 260px);
  height: min(82%, 292px);
}
.pve-full-sprite-viewport {
  position: absolute;
  left: 50%;
  bottom: 0;
  overflow: hidden;
  transform: translateX(-50%) scale(var(--pve-full-sprite-scale, 1));
  transform-origin: 50% 100%;
  filter: drop-shadow(0 12px 10px rgba(0,0,0,.45));
}
.pve-combatant-sprite.is-flipped .pve-full-sprite-viewport {
  transform: translateX(-50%) scaleX(-1) scale(var(--pve-full-sprite-scale, 1));
}
.pve-full-sprite-viewport .pve-combatant-sprite-img {
  position: absolute;
  left: 0;
  top: 0;
  bottom: auto;
  max-width: none;
  max-height: none;
  object-fit: unset;
  transform: translate3d(0, 0, 0);
  filter: none;
  will-change: transform;
}
.pve-combatant-sprite.is-flipped .pve-full-sprite-viewport .pve-combatant-sprite-img {
  transform: translate3d(0, 0, 0);
}
.pve-character-rig {
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%) scale(var(--pve-character-rig-scale, .62));
  transform-origin: 50% 100%;
  pointer-events: none;
  user-select: none;
  filter: drop-shadow(0 16px 14px rgba(0,0,0,.42));
}
.pve-combatant-sprite.is-flipped .pve-character-rig {
  transform: translateX(-50%) scaleX(-1) scale(var(--pve-character-rig-scale, .62));
}
.pve-character-rig__part {
  position: absolute;
  overflow: hidden;
  pointer-events: none;
  user-select: none;
}
.pve-character-rig__part:not(.is-loaded) { opacity: 0; }
.pve-character-rig__strip {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  max-width: none;
  transform: translate3d(0, 0, 0);
  will-change: transform;
  pointer-events: none;
  user-select: none;
}
.pve-combatant-shadow {
  position: absolute;
  left: 50%;
  bottom: 8px;
  width: 70%;
  height: 22px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: rgba(0,0,0,.35);
  filter: blur(2px);
  z-index: 1;
}
.pve-combatant-float {
  z-index: 7;
}
.pve-combatant.is-attacking.pve-combatant--player .pve-combatant-sprite,
.pve-combatant.is-attacking.pve-combatant--enemy .pve-combatant-sprite {
  animation: none;
}
.pve-combatant.is-hit .pve-combatant-sprite {
  animation: none;
  filter: brightness(1.55) saturate(1.18) drop-shadow(0 0 14px rgba(255,245,205,.48));
}
.pve-combatant.is-dodging.pve-combatant--player,
.pve-combatant.is-dodging.pve-combatant--enemy {
  animation: none;
}
.pve-combatant.is-dead .pve-combatant-sprite,
.pve-combatant.is-dead .pve-combatant-shadow {
  opacity: 0;
  filter: blur(4px);
  transform: translateX(-50%);
  transition: opacity .55s ease, filter .55s ease, transform .55s ease;
}
.pve-death-particles {
  pointer-events: none;
  position: absolute;
  left: 50%;
  bottom: 92px;
  width: 1px;
  height: 1px;
  z-index: 8;
}
.pve-death-particles i {
  position: absolute;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(189, 234, 145, .9);
  box-shadow: 0 0 12px rgba(255, 235, 160, .8);
  animation: pveDeathParticle .9s ease-out forwards;
}
.pve-battle-log-details {
  margin-top: 10px;
  color: rgba(246, 237, 215, .74);
}
.pve-battle-log-details summary {
  cursor: pointer;
  color: #ffe2a3;
  font-weight: 700;
}
.arena-float--damage { color: #ff8b77; }
.arena-float--crit { color: #ffd36a; font-size: 17px; }
.arena-float--debuff { color: #d5a6ff; }
.arena-float--heal { color: #8ef0a0; }
.arena-float--defense { color: #9bd4ff; }

@keyframes pvePlayerAttack {
  0%, 100% { transform: translateX(-50%); }
}
@keyframes pveEnemyAttack {
  0%, 100% { transform: translateX(-50%); }
}
@keyframes pveHitShake {
  0%, 100% { transform: translateX(-50%); }
  25% { transform: translateX(calc(-50% - 8px)); }
  55% { transform: translateX(calc(-50% + 6px)); }
}
@keyframes pveDodgeLeft {
  0%, 100% { transform: translateX(0); }
  45% { transform: translateX(-22px); }
}
@keyframes pveDodgeRight {
  0%, 100% { transform: translateX(0); }
  45% { transform: translateX(22px); }
}

@keyframes pveDeathParticle {
  0% { opacity: 0; transform: translate(0, 0) scale(.4); }
  20% { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--dx), var(--dy)) scale(1.05); }
}

@media (max-width: 760px) {
  .pve-battle-topline,
  .pve-battle-bottom {
    align-items: stretch;
    flex-direction: column;
  }
  .pve-battle-result { text-align: left; }
  .pve-battle-buffs { white-space: normal; }
  .pve-combat-scene { min-height: 360px; }
  .pve-combat-ground { left: 0; right: 0; }
  .pve-combatant { width: 42vw; min-width: 130px; }
  .pve-combatant--player { left: 1%; }
  .pve-combatant--enemy { right: 1%; }
}

/* 0.6.11: PvE-бой как отдельная игровая локация, без panel-overlay и логов. */
.app[data-location^="battle_"] .location-title,
.app[data-location^="battle_"] .resource-widget,
.app[data-location^="battle_"] .bottom-nav {
  display: none;
}

.pve-location-shell {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.pve-location-battle {
  position: absolute;
  inset: 0;
  overflow: visible;
  pointer-events: none;
}
.pve-location-hud {
  position: absolute;
  left: 42px;
  right: 42px;
  top: 20px;
  height: 76px;
  display: grid;
  grid-template-columns: minmax(260px, 1fr) 210px minmax(260px, 1fr);
  gap: 18px;
  align-items: center;
  z-index: 20;
  pointer-events: none;
}
.pve-location-hp {
  min-width: 0;
  padding: 10px 14px 12px;
  border-radius: 6px;
  border: 1px solid rgba(255,230,170,.28);
  background: rgba(6, 8, 12, .70);
  box-shadow: 0 14px 34px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(4px);
}
.pve-location-hp--enemy .pve-location-hp__label { flex-direction: row-reverse; }
.pve-location-hp__label {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 7px;
  color: #fff4cf;
  text-shadow: 0 2px 4px rgba(0,0,0,.70);
}
.pve-location-hp__label b {
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  font-size: 16px;
}
.pve-location-hp__label span {
  flex: 0 0 auto;
  color: rgba(255,242,217,.82);
  font-size: 13px;
  font-weight: 800;
}
.pve-location-hp__bar {
  height: 15px;
  overflow: hidden;
  border-radius: 999px;
  border: 1px solid rgba(255,230,170,.22);
  background: rgba(0,0,0,.55);
}
.pve-location-hp__bar i {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(195,50,45,.98), rgba(255,190,76,.98));
  transition: width .35s ease;
}
.pve-location-result {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 5px;
  color: #ffe2a3;
  font-weight: 900;
  text-align: center;
  text-shadow: 0 2px 4px rgba(0,0,0,.78);
  background: rgba(6, 8, 12, .58);
  border: 1px solid rgba(255,230,170,.20);
  box-shadow: 0 14px 34px rgba(0,0,0,.28);
}
.pve-location-result:empty {
  visibility: hidden;
}
.pve-location-combat-ground {
  position: absolute;
  inset: 0;
  z-index: 5;
}
.pve-location-combat-ground::after {
  content: '';
  position: absolute;
  left: 130px;
  right: 130px;
  bottom: 70px;
  height: 90px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center, rgba(24, 17, 10, .46), transparent 68%);
  filter: blur(2px);
  z-index: 1;
}
.pve-location-battle .pve-combatant {
  position: absolute;
  width: 300px;
  height: 350px;
  min-width: 0;
  min-height: 0;
  bottom: auto;
  left: auto;
  right: auto;
  z-index: 3;
}
.pve-location-battle .pve-combatant--player,
.pve-location-battle .pve-combatant--enemy {
  left: auto;
  right: auto;
}
.pve-location-battle .pve-combatant-name,
.pve-location-battle .pve-combatant-hp,
.pve-location-battle .pve-combatant-hptext {
  display: none;
}
.pve-location-battle .pve-combatant-sprite {
  width: 100%;
  height: 100%;
  bottom: 0;
}
.pve-location-battle .pve-combatant-sprite--rig {
  width: 100%;
  height: 100%;
}
.pve-location-battle .pve-combatant-sprite--full {
  width: 100%;
  height: 100%;
}
.pve-location-battle .pve-combatant-shadow {
  bottom: -4px;
  width: 68%;
  height: 25px;
}
.pve-location-battle .pve-combatant-float {
  left: 50%;
  top: 34%;
  transform: translateX(-50%);
}
.pve-location-buttons {
  position: absolute;
  left: 50%;
  bottom: 32px;
  display: flex;
  justify-content: center;
  gap: 14px;
  transform: translateX(-50%);
  z-index: 30;
  pointer-events: auto;
}
.pve-location-buttons .ui-button {
  position: relative;
  flex: 0 0 auto;
}
.pve-location-finish,
.pve-location-escape,
.pve-location-claim,
.pve-location-continue {
  width: 220px;
  height: 58px;
}
.pve-location-claim,
.pve-location-continue {
  border-color: rgba(255, 230, 170, .30);
}
.pve-location-escape {
  border-color: rgba(255, 154, 124, .42);
  background: linear-gradient(180deg, rgba(108, 45, 36, .92), rgba(68, 23, 20, .94));
}
.pve-location-finish:active,
.pve-location-escape:active,
.pve-location-claim:active,
.pve-location-continue:active { transform: translateY(2px); }
.pve-location-outcome {
  position: absolute;
  left: 50%;
  bottom: 102px;
  min-width: 300px;
  max-width: 620px;
  min-height: 54px;
  transform: translateX(-50%);
  z-index: 29;
  padding: 10px 18px;
  border-radius: 6px;
  color: #fff4cf;
  text-align: center;
  background: rgba(6, 8, 12, .70);
  border: 1px solid rgba(255,230,170,.24);
  box-shadow: 0 16px 40px rgba(0,0,0,.34);
  pointer-events: none;
}
.pve-location-outcome:empty {
  display: none;
}
.pve-location-outcome b {
  display: block;
  font-size: 24px;
  line-height: 1.05;
  letter-spacing: .02em;
}
.pve-location-outcome span {
  display: block;
  margin-top: 4px;
  color: rgba(255,242,217,.82);
  font-size: 14px;
  font-weight: 800;
}
.pve-location-status {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 430px;
  min-height: 150px;
  transform: translate(-50%, -50%);
  border-radius: 7px;
  border: 1px solid rgba(255,230,170,.24);
  background: rgba(6, 8, 12, .70);
  box-shadow: 0 24px 70px rgba(0,0,0,.44);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 24px;
  text-align: center;
  pointer-events: auto;
}
.pve-location-status b {
  color: #fff4cf;
  font-size: 22px;
}
.pve-location-status span {
  color: rgba(255,242,217,.80);
}
.pve-location-status--error b { color: #ffb0a3; }
.pve-location-reward {
  position: absolute;
  left: 50%;
  bottom: 98px;
  min-width: 320px;
  max-width: 620px;
  transform: translateX(-50%);
  z-index: 28;
  padding: 11px 16px;
  border-radius: 5px;
  color: #fff4cf;
  font-weight: 800;
  text-align: center;
  background: rgba(6, 8, 12, .68);
  border: 1px solid rgba(255,230,170,.22);
  pointer-events: none;
}

.pve-combatant.is-attacking.pve-combatant--player .pve-combatant-sprite,
.pve-combatant.is-attacking.pve-combatant--enemy .pve-combatant-sprite {
  animation: none;
}
.pve-combatant.is-hit .pve-combatant-sprite {
  animation: none;
}
.pve-combatant.is-dodging.pve-combatant--player,
.pve-combatant.is-dodging.pve-combatant--enemy {
  animation: none;
}

@media (max-width: 760px) {
  .pve-location-hud {
    left: 12px;
    right: 12px;
    top: 12px;
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "player enemy"
      "result result";
    height: auto;
    gap: 8px;
  }
  .pve-location-hp--player { grid-area: player; }
  .pve-location-hp--enemy { grid-area: enemy; }
  .pve-location-result { grid-area: result; min-height: 36px; }
  .pve-location-buttons { bottom: 18px; gap: 8px; flex-wrap: wrap; max-width: calc(100% - 24px); }
  .pve-location-finish,
  .pve-location-escape,
  .pve-location-claim,
  .pve-location-continue { width: 158px; height: 50px; }
  .pve-location-hp { padding: 8px; }
  .pve-location-hp__label { flex-direction: column; align-items: flex-start; gap: 2px; }
  .pve-location-hp--enemy .pve-location-hp__label { flex-direction: column; align-items: flex-end; }
}

/* 0.6.14: PvE replay is fully precomputed by the server; defense text floats without frame. */
.pve-location-battle .pve-combatant-float {
  left: 0;
  right: 0;
  top: 18%;
  bottom: auto;
  height: 120px;
  transform: none;
}
.pve-location-battle .arena-float--defense {
  top: 28%;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  font-size: 18px;
  letter-spacing: .03em;
  color: #bfe7ff;
  text-shadow: 0 2px 3px rgba(0,0,0,.95), 0 0 12px rgba(120,190,255,.62);
  animation: pveDodgeTextFloat 1.25s ease-out forwards;
}
@keyframes pveDodgeTextFloat {
  0% { opacity: 0; transform: translate(-50%, 18px) scale(.45); }
  14% { opacity: 1; transform: translate(-50%, 6px) scale(1.22); }
  52% { opacity: 1; transform: translate(-50%, -20px) scale(.94); }
  100% { opacity: 0; transform: translate(-50%, -76px) scale(.72); }
}

/* 0.6.20: характеристики персонажа, вес, опыт, репутация и ранг */
.derived-grid--expanded {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
.derived-cell.is-warning {
  border-color: rgba(255, 92, 92, .78);
  background: rgba(94, 19, 19, .50);
}
.derived-cell small {
  display: block;
  margin-top: 3px;
  color: rgba(246, 237, 215, .62);
  font-size: 11px;
  line-height: 1.15;
}
.derived-cell.is-warning span,
.derived-cell.is-warning strong,
.derived-cell.is-warning small {
  color: #ffb4a8;
}
.build-meter-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.build-meter {
  padding: 11px 12px;
  border-radius: 5px;
  background: rgba(9, 12, 17, .68);
  border: 1px solid rgba(255,255,255,.08);
}
.build-meter.is-warning {
  border-color: rgba(255, 92, 92, .78);
  background: rgba(94, 19, 19, .50);
}
.build-meter__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.build-meter__top strong {
  color: var(--gold);
  font-size: 13px;
}
.build-meter__top span {
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
  text-align: right;
}
.build-meter p {
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}
@media (max-width: 980px) {
  .derived-grid--expanded { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .build-meter-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .derived-grid--expanded { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* 0.6.24: Катакомбы как поход с 3 путями, накопленной добычей и событиями. */
.catacombs-location-shell {
  position: absolute;
  left: 70px;
  right: 70px;
  bottom: 76px;
  min-height: 220px;
  display: grid;
  grid-template-columns: 1fr;
  justify-items: center;
  gap: 12px;
  pointer-events: auto;
}
.catacombs-info-card,
.catacombs-event-card {
  width: min(680px, 100%);
  max-width: 680px;
  padding: 18px 24px;
  border: 1px solid rgba(255, 233, 178, .28);
  border-radius: 6px;
  background: rgba(28, 18, 16, .78);
  box-shadow: 0 12px 34px rgba(0,0,0,.38);
  color: #f8e8c2;
  text-shadow: 0 2px 3px rgba(0,0,0,.55);
}
.catacombs-info-card {
  text-align: center;
}
.catacombs-info-card b,
.catacombs-event-card b {
  display: block;
  font-size: 28px;
  margin-bottom: 10px;
  color: #ffe49a;
}
.catacombs-info-card span,
.catacombs-event-card span,
.catacombs-info-card em,
.catacombs-event-card em,
.catacombs-info-card strong {
  display: block;
  font-style: normal;
  font-size: 18px;
  line-height: 1.38;
  margin-top: 8px;
}
.catacombs-info-card em {
  color: #ffd37c;
  font-weight: 800;
}
.catacombs-info-card strong { color: #baffbd; font-weight: 800; }
.catacombs-event-card--error { color: #ffb0a3; }
.catacombs-path-buttons {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  width: 100%;
}
.catacombs-path-buttons .action-button {
  position: relative !important;
  left: auto !important;
  top: auto !important;
  width: 190px !important;
  height: 62px !important;
}
.catacombs-claim-button {
  position: fixed;
  left: 24px;
  bottom: 116px;
  z-index: 34;
  width: 240px;
  height: 58px;
}
@media (max-width: 760px) {
  .catacombs-location-shell { left: 18px; right: 18px; bottom: 36px; }
  .catacombs-claim-button { left: 14px; bottom: 104px; width: 210px; height: 54px; }
  .catacombs-path-buttons .action-button { width: 150px !important; height: 54px !important; }
  .catacombs-info-card, .catacombs-event-card { max-width: none; }
  .catacombs-info-card b, .catacombs-event-card b { font-size: 23px; }
  .catacombs-info-card span,
  .catacombs-event-card span,
  .catacombs-info-card em,
  .catacombs-event-card em,
  .catacombs-info-card strong { font-size: 15px; }
}


/* 0.6.25: базовая панель кланов */
.clans-panel { width: min(1040px, calc(100vw - 48px)); max-width: 100%; }
.clan-grid { gap: 18px; }
.clan-current-box,
.clan-create-box,
.clan-row {
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 5px;
  background: rgba(20,18,16,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.clan-current-box,
.clan-create-box { padding: 14px; margin-bottom: 12px; }
.clan-current-box h3,
.clan-create-box h3 { margin: 0 0 8px; font-size: 18px; }
.clan-current-meta,
.clan-row-meta,
.clan-bank-line,
.clan-row-motto,
.clan-current-motto { color: rgba(255,245,220,.78); font-size: 13px; line-height: 1.35; }
.clan-current-motto { margin: 8px 0; color: rgba(255,224,150,.9); }
.clan-input {
  width: 100%;
  box-sizing: border-box;
  margin: 6px 0;
  padding: 9px 10px;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.28);
  color: #fff3d2;
  outline: none;
}
.clan-deposit-line { display: flex; gap: 8px; align-items: center; margin: 10px 0; }
.clan-deposit-line .clan-input { margin: 0; }
.clan-search-list,
.clan-member-list { display: flex; flex-direction: column; gap: 8px; }
.clan-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px; }
.clan-row-title { font-weight: 700; color: #ffe5a6; margin-bottom: 3px; }
.clan-member-row { padding: 7px 9px; border-radius: 9px; background: rgba(255,255,255,.06); color: rgba(255,245,220,.88); font-size: 13px; }
.clan-list-title { margin: 12px 0 8px; color: #ffe5a6; font-weight: 700; }
.ui-button--danger { border-color: rgba(255,90,70,.45); color: #ffd0c8; }
@media (max-width: 760px) {
  .clan-row,
  .clan-deposit-line { flex-direction: column; align-items: stretch; }
}

.clan-fleet-box,
.clan-requests-box,
.clan-logs-box {
  margin-top: 12px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 4px;
  background: rgba(0,0,0,.18);
}

.clan-ship-card {
  margin: 8px 0;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 3px;
  background: rgba(255,255,255,.06);
}

.clan-crew-list {
  margin-top: 6px;
  max-height: 160px;
  overflow: auto;
}

.clan-build-ship-button,
.clan-battle-queue-button {
  margin-top: 8px;
  width: 100%;
}

/* 0.6.27: составной флаг клана */
.clan-title-line,
.clan-current-title {
  display: flex;
  align-items: center;
  gap: 9px;
}
.clan-flag-mini {
  --clan-flag-color: #7d1f1f;
  --clan-emblem-color: #f3d58a;
  width: 34px;
  height: 26px;
  flex: 0 0 auto;
  position: relative;
  border: 1px solid rgba(255,255,255,.28);
  background: var(--clan-flag-color);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.22), 0 2px 8px rgba(0,0,0,.28);
  overflow: hidden;
}
.clan-flag-mini--flag_01 { border-radius: 4px; }
.clan-flag-mini--flag_02 { border-radius: 50% 50% 6px 6px; }
.clan-flag-mini--flag_03 { clip-path: polygon(0 0, 100% 0, 100% 78%, 50% 100%, 0 78%); }
.clan-flag-mini--flag_04 { clip-path: polygon(0 0, 82% 0, 100% 50%, 82% 100%, 0 100%); }
.clan-flag-mini--flag_05 { border-radius: 4px; clip-path: polygon(0 0, 100% 0, 84% 50%, 100% 100%, 0 100%); }
.clan-flag-emblem {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 16px;
  height: 16px;
  transform: translate(-50%, -50%);
  display: grid;
  place-items: center;
  color: var(--clan-emblem-color);
  font-size: 9px;
  font-weight: 900;
  line-height: 1;
  text-shadow: 0 1px 2px rgba(0,0,0,.45);
}
.clan-flag-emblem--emblem_01 { border-radius: 50%; border: 3px solid var(--clan-emblem-color); color: transparent; }
.clan-flag-emblem--emblem_02 { clip-path: polygon(50% 0, 62% 36%, 100% 36%, 69% 58%, 82% 100%, 50% 74%, 18% 100%, 31% 58%, 0 36%, 38% 36%); background: var(--clan-emblem-color); color: transparent; }
.clan-flag-emblem--emblem_03 { clip-path: polygon(50% 0, 100% 50%, 50% 100%, 0 50%); background: var(--clan-emblem-color); color: transparent; }
.clan-flag-emblem--emblem_04::before,
.clan-flag-emblem--emblem_05::before,
.clan-flag-emblem--emblem_06::before,
.clan-flag-emblem--emblem_07::before,
.clan-flag-emblem--emblem_08::before { color: var(--clan-emblem-color); font-size: 16px; }
.clan-flag-emblem--emblem_04 { font-size: 0; }
.clan-flag-emblem--emblem_04::before { content: '✚'; }
.clan-flag-emblem--emblem_05 { font-size: 0; }
.clan-flag-emblem--emblem_05::before { content: '⚔'; }
.clan-flag-emblem--emblem_06 { font-size: 0; }
.clan-flag-emblem--emblem_06::before { content: '◆'; }
.clan-flag-emblem--emblem_07 { font-size: 0; }
.clan-flag-emblem--emblem_07::before { content: '☾'; }
.clan-flag-emblem--emblem_08 { font-size: 0; }
.clan-flag-emblem--emblem_08::before { content: '♛'; }
.clan-flag-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 78px 78px;
  gap: 8px;
  align-items: center;
}
.clan-color-input {
  min-height: 40px;
  padding: 4px;
}
.clan-locked-location {
  position: absolute;
  left: 70px;
  bottom: 118px;
  width: min(480px, calc(100% - 140px));
  padding: 18px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(20,18,16,.78);
  color: #fff3d2;
  box-shadow: 0 10px 26px rgba(0,0,0,.28);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.clan-locked-location b { color: #ffe5a6; font-size: 18px; }
.clan-locked-location span { color: rgba(255,245,220,.82); line-height: 1.35; }
@media (max-width: 760px) {
  .clan-flag-form-grid { grid-template-columns: 1fr 1fr; }
  .clan-locked-location { left: 18px; right: 18px; width: auto; bottom: 110px; }
}

/* 0.6.31: две кнопки оплаты при создании клана */
.clan-create-payments {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 10px 0 6px;
}
.clan-create-payments .clan-create-button {
  min-width: 190px;
  flex: 1 1 190px;
}
.clan-create-button--gold { border-color: rgba(245,190,80,.55); }
.clan-create-button--emerald { border-color: rgba(90,220,185,.55); }

/* 0.6.32: создание клана одной раскрывающейся кнопкой */
.clan-create-box--accordion {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.clan-create-toggle {
  width: 100%;
  min-height: 46px;
  justify-content: center;
  font-weight: 800;
}
.clan-create-box--accordion:not(.is-open) .clan-create-hint {
  margin-bottom: 0;
}

/* 0.6.33: новый поток окна кланов: список справа, действия слева */
.clan-grid--browse {
  grid-template-columns: minmax(260px, 340px) minmax(360px, 1fr);
}
.clan-left--join {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.clan-selected-box {
  padding: 14px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(20,18,16,.72);
  color: rgba(255,245,220,.86);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.clan-row--selectable {
  width: 100%;
  color: inherit;
  text-align: left;
  cursor: pointer;
  font: inherit;
}
.clan-row--selectable:hover,
.clan-row--selectable.is-selected {
  border-color: rgba(255,218,128,.55);
  background: rgba(90,65,25,.58);
}
.clan-row-select-mark {
  flex: 0 0 auto;
  padding: 5px 9px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  color: #ffe5a6;
  font-size: 12px;
}
.clan-join-selected-button,
.clan-create-toggle,
.clan-back-button {
  width: 100%;
  min-height: 46px;
  justify-content: center;
  font-weight: 800;
}
.clan-create-section-title {
  margin-top: 18px;
}
.clan-create-box--form {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
@media (max-width: 760px) {
  .clan-grid--browse { grid-template-columns: 1fr; }
  .clan-row-select-mark { align-self: flex-start; }
}

/* 0.6.34: фиксим поток кланов — глобальные .ui-button абсолютные, поэтому в форме они накладывались друг на друга */
.panel-overlay[data-panel="clans"] .panel-window {
  width: min(100%, 1120px);
  max-height: calc(100vh - 32px);
}
.panel-overlay[data-panel="clans"] .panel-content--stub {
  min-height: 0;
  overflow: auto;
}
.clans-panel {
  width: 100%;
}
.clans-panel .ui-button,
.clans-panel button.clan-row--selectable {
  position: static;
}
.clan-grid--browse {
  align-items: start;
}
.clan-left--join,
.clan-right--list,
.clan-create-box--form {
  min-width: 0;
}
.clan-left--join {
  padding: 12px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.14);
}
.clan-right--list {
  min-height: 0;
}
.clan-search-list {
  max-height: min(470px, calc(100vh - 245px));
  overflow: auto;
  padding-right: 4px;
}
.clan-create-box--form {
  box-sizing: border-box;
  max-width: 720px;
  width: 100%;
}
.clan-create-box--form .clan-input {
  flex: 0 0 auto;
}
.clan-create-payments {
  align-items: stretch;
}
.clan-create-payments .clan-create-button {
  min-height: 48px;
}
@media (max-width: 760px) {
  .panel-overlay[data-panel="clans"] .panel-window {
    width: calc(100vw - 20px);
    max-height: calc(100vh - 20px);
  }
  .panel-overlay[data-panel="clans"] .panel-content--stub {
    padding: 14px;
  }
  .panel-overlay[data-panel="clans"] .panel-title {
    font-size: 28px;
  }
  .clan-search-list {
    max-height: none;
  }
  .clan-create-payments .clan-create-button {
    flex-basis: 100%;
  }
}


/* 0.6.35: верфь клана как отдельная локация управления */
.app[data-location="clan_shipyard"] .bottom-nav {
  display: none;
}
.clan-shipyard-shell,
.clan-shipyard-shell .ui-button {
  position: static;
}
.clan-shipyard-shell {
  position: absolute;
  left: 50%;
  top: 72px;
  transform: translateX(-50%);
  width: min(1060px, calc(100% - 48px));
  max-height: calc(100% - 92px);
  overflow: auto;
  pointer-events: auto;
  display: grid;
  gap: 10px;
  padding: 14px;
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(10, 11, 15, .66);
  box-shadow: 0 18px 46px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(4px);
}
.clan-shipyard-top {
  display: grid;
  grid-template-columns: repeat(4, minmax(120px, 1fr));
  gap: 10px;
}
.clan-shipyard-tab {
  min-height: 44px;
  justify-content: center;
  font-weight: 800;
}
.clan-shipyard-tab.is-active {
  border-color: rgba(255,218,128,.65);
  background: rgba(92,65,24,.72);
}
.clan-shipyard-exit {
  border-color: rgba(160,220,255,.45);
}
.clan-shipyard-header,
.clan-shipyard-card {
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(20,18,16,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.clan-shipyard-header {
  padding: 12px 14px;
  display: grid;
  gap: 6px;
}
.clan-shipyard-clan-title {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #ffe5a6;
  font-size: 22px;
  font-weight: 900;
}
.clan-shipyard-meta,
.clan-shipyard-motto,
.clan-shipyard-ship-info span,
.clan-shipyard-member-info span,
.clan-member-note {
  color: rgba(255,245,220,.82);
  font-size: 13px;
  line-height: 1.35;
}
.clan-shipyard-motto { color: rgba(255,224,150,.92); }
.clan-shipyard-card {
  padding: 14px;
}
.clan-shipyard-card h3 {
  margin: 0 0 10px;
  color: #ffe5a6;
  font-size: 20px;
}
.clan-shipyard-ship-controls {
  display: grid;
  grid-template-columns: 76px minmax(260px, 1fr) 76px;
  gap: 12px;
  align-items: center;
}
.clan-ship-arrow {
  min-height: 150px;
  justify-content: center;
  font-size: 42px;
  line-height: 1;
}
.clan-shipyard-ship-center {
  min-height: 184px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.clan-ship-art {
  position: relative;
  width: min(420px, 64vw);
  height: 135px;
  border-radius: 50% 50% 38% 38% / 32% 32% 68% 68%;
  background: linear-gradient(180deg, rgba(172,118,58,.96), rgba(92,48,24,.96));
  box-shadow: inset 0 -18px 28px rgba(0,0,0,.25), 0 18px 32px rgba(0,0,0,.26);
}
.clan-ship-art::before {
  content: '';
  position: absolute;
  left: 48%;
  bottom: 58px;
  width: 10px;
  height: 110px;
  transform: translateX(-50%);
  background: rgba(80,45,24,.95);
  border-radius: 8px;
  box-shadow: 48px 24px 0 -2px rgba(80,45,24,.85), -54px 30px 0 -3px rgba(80,45,24,.72);
}
.clan-ship-art::after {
  content: '';
  position: absolute;
  left: 50%;
  bottom: 102px;
  width: 118px;
  height: 78px;
  transform: translateX(-50%) skewX(-8deg);
  clip-path: polygon(0 0, 100% 14%, 82% 100%, 7% 86%);
  background: rgba(238,218,166,.92);
  box-shadow: 68px 30px 0 -14px rgba(220,196,142,.86), -74px 32px 0 -18px rgba(220,196,142,.78);
}
.clan-ship-number {
  color: #ffe5a6;
  font-size: 20px;
  font-weight: 900;
  text-shadow: 0 2px 5px rgba(0,0,0,.55);
}
.clan-shipyard-ship-info {
  display: grid;
  gap: 5px;
  margin: 10px 0;
  color: rgba(255,245,220,.88);
}
.clan-shipyard-ship-info b { color: #ffe5a6; font-size: 18px; }
.clan-ship-slot-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 8px;
  max-height: 164px;
  overflow: auto;
  padding: 2px;
}
.clan-ship-slot-row {
  padding: 8px 10px;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.055);
  color: rgba(255,245,220,.8);
  font-size: 13px;
}
.clan-ship-slot-row.is-filled {
  border-color: rgba(255,218,128,.28);
  color: #fff2cc;
}
.clan-ship-slot-list.is-locked .clan-ship-slot-row {
  opacity: .78;
}

.clan-ship-slot-button {
  width: 100%;
  text-align: left;
  cursor: pointer;
}
.clan-ship-slot-button:hover {
  border-color: rgba(255,218,128,.48);
  background: rgba(255,218,128,.10);
}
.clan-ship-slot-picker {
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.20);
  background: rgba(0,0,0,.22);
}
.clan-ship-slot-picker-title {
  color: #ffe5a6;
  font-weight: 900;
  font-size: 15px;
}
.clan-ship-slot-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
  max-height: 210px;
  overflow: auto;
}
.clan-slot-choice {
  min-height: 38px;
  justify-content: flex-start;
  text-align: left;
  font-size: 13px;
}
.clan-slot-choice--clear {
  border-color: rgba(255,130,120,.38);
}
.clan-slot-cancel {
  justify-self: start;
}

.clan-shipyard-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 12px;
}
.clan-shipyard-main-button,
.clan-settings-save-button {
  width: 100%;
  min-height: 48px;
  justify-content: center;
  font-weight: 900;
}
.clan-shipyard-member-list {
  display: grid;
  gap: 8px;
  max-height: 420px;
  overflow: auto;
}
.clan-shipyard-member-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 4px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.055);
}
.clan-shipyard-member-info {
  display: grid;
  gap: 4px;
}
.clan-shipyard-member-info b { color: #ffe5a6; }
.clan-shipyard-member-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.clan-mini-button {
  min-height: 36px;
  padding: 0 12px;
  font-size: 13px;
}
.clan-member-note {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
}
.clan-shipyard-settings {
  max-width: 720px;
  width: 100%;
  justify-self: center;
  display: grid;
  gap: 8px;
}
@media (max-width: 760px) {
  .clan-shipyard-shell {
    top: 64px;
    width: calc(100% - 20px);
    max-height: calc(100% - 74px);
    padding: 10px;
  }
  .clan-shipyard-top {
    grid-template-columns: 1fr 1fr;
  }
  .clan-shipyard-ship-controls {
    grid-template-columns: 54px minmax(160px, 1fr) 54px;
    gap: 8px;
  }
  .clan-ship-arrow { min-height: 110px; font-size: 34px; }
  .clan-ship-art { width: min(300px, 58vw); height: 104px; }
  .clan-shipyard-action-row,
  .clan-shipyard-member-row {
    grid-template-columns: 1fr;
  }
  .clan-shipyard-member-actions {
    justify-content: stretch;
  }
  .clan-shipyard-member-actions .ui-button {
    flex: 1 1 150px;
  }
}

/* 0.6.41: отдельная сцена ручного кланового боя */
.clan-shipyard-top {
  grid-template-columns: repeat(5, minmax(110px, 1fr));
}
.clan-shipyard-shell--battle {
  background: radial-gradient(circle at 50% 20%, rgba(67, 94, 125, .68), rgba(9, 12, 18, .78) 62%), rgba(10, 11, 15, .70);
}
.clan-battle-scene,
.clan-battle-scene .ui-button,
.clan-battle-ship-card {
  position: static;
}
.clan-battle-scene {
  padding: 14px;
  border-radius: 6px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(180deg, rgba(18, 28, 42, .82), rgba(12, 11, 13, .78));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 36px rgba(0,0,0,.26);
}
.clan-battle-scene h3 {
  margin: 0 0 10px;
  color: #ffe5a6;
  font-size: 22px;
}
.clan-battle-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 12px;
  align-items: stretch;
}
.clan-battle-arena {
  min-height: 440px;
  padding: 12px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(54,91,118,.45), rgba(22,39,58,.42) 42%, rgba(36,25,18,.55));
  overflow: hidden;
}
.clan-battle-meta,
.clan-battle-next-shot {
  display: grid;
  gap: 4px;
  color: rgba(255,245,220,.88);
  font-size: 13px;
}
.clan-battle-meta b {
  color: #ffe5a6;
  font-size: 18px;
}
.clan-battle-next-shot {
  margin: 8px 0 10px;
  padding: 8px 10px;
  border-radius: 4px;
  background: rgba(0,0,0,.22);
}
.clan-battle-fleets {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: start;
}
.clan-battle-fleet {
  display: grid;
  gap: 8px;
}
.clan-battle-ship-card {
  width: 100%;
  display: grid;
  gap: 5px;
  min-height: 118px;
  padding: 10px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.07);
  color: rgba(255,245,220,.9);
  text-align: left;
  cursor: default;
}
button.clan-battle-ship-card--enemy {
  cursor: pointer;
}
button.clan-battle-ship-card--enemy:hover,
.clan-battle-ship-card.is-selected {
  border-color: rgba(255,218,128,.66);
  background: rgba(255,218,128,.13);
}
.clan-battle-ship-card.is-destroyed {
  opacity: .58;
  filter: grayscale(.5);
}
.clan-battle-ship-card b {
  color: #ffe5a6;
}
.clan-battle-ship-card span,
.clan-battle-ship-card small {
  font-size: 12px;
  color: rgba(255,245,220,.78);
}
.clan-battle-ship-art {
  width: 100%;
  height: 42px;
  border-radius: 50% 50% 38% 38% / 32% 32% 68% 68%;
  background: linear-gradient(180deg, rgba(172,118,58,.96), rgba(92,48,24,.96));
  box-shadow: inset 0 -10px 14px rgba(0,0,0,.25);
}
.clan-battle-shot-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 10px;
  margin-top: 12px;
}
.clan-battle-shot-button,
.clan-battle-refresh-button {
  min-height: 48px;
  justify-content: center;
  font-weight: 900;
}
.clan-battle-log {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 8px;
  min-height: 440px;
  padding: 12px;
  border-radius: 5px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.28);
}
.clan-battle-log h4 {
  margin: 0;
  color: #ffe5a6;
  font-size: 16px;
}
.clan-battle-log-list {
  display: grid;
  gap: 6px;
  align-content: start;
  overflow: auto;
  max-height: 420px;
}
.clan-battle-log-row {
  padding: 8px 9px;
  border-radius: 3px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.055);
  color: rgba(255,245,220,.86);
  font-size: 12px;
  line-height: 1.35;
}
.clan-battle-log-row.is-hit {
  border-color: rgba(255,210,120,.22);
}
.clan-battle-log-row.is-miss {
  color: rgba(210,225,255,.82);
}
.clan-battle-log-row.is-enemy {
  background: rgba(110,32,32,.16);
}
@media (max-width: 900px) {
  .clan-battle-layout,
  .clan-battle-fleets,
  .clan-battle-shot-row {
    grid-template-columns: 1fr;
  }
  .clan-battle-log,
  .clan-battle-arena {
    min-height: 0;
  }
}
@media (max-width: 760px) {
  .clan-shipyard-top {
    grid-template-columns: 1fr 1fr;
  }
}

/* 0.6.44: воздушная сцена кланового боя — палуба, пушка, парящие корабли */
.clan-battle-arena {
  min-height: 520px;
  padding: 0;
  border: 1px solid rgba(255,255,255,.14);
  background: #254a86;
  box-shadow: inset 0 0 42px rgba(0,0,0,.32), 0 16px 34px rgba(0,0,0,.22);
}
.clan-battle-sky-stage {
  position: relative;
  min-height: 520px;
  overflow: hidden;
  border-radius: 5px;
  background: linear-gradient(180deg, #315ca0 0%, #6ca0d4 54%, #b7d9eb 100%);
  isolation: isolate;
}
.clan-battle-sky-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: url('../resources/backgrounds/bg_clan_battle_sky.jpg'), radial-gradient(circle at 35% 14%, rgba(255,255,255,.68), rgba(255,255,255,0) 23%), linear-gradient(180deg, #315ca0 0%, #7eb1df 62%, #d3ebf4 100%);
  background-repeat: repeat-x, no-repeat, no-repeat;
  background-size: auto 100%, cover, cover;
  background-position: 0 0, center, center;
  animation: clanBattleCloudDrift 52s linear infinite;
}
.clan-battle-sky-stage::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 5;
  height: 34%;
  background-image: url('../resources/backgrounds/bg_clan_battle_deck.png'), linear-gradient(10deg, rgba(72,39,18,.96), rgba(116,73,32,.96) 42%, rgba(37,23,15,.96));
  background-repeat: no-repeat, no-repeat;
  background-position: left bottom, left bottom;
  background-size: cover, cover;
  pointer-events: none;
}
@keyframes clanBattleCloudDrift {
  from { background-position: 0 0, center, center; }
  to { background-position: -1400px 0, center, center; }
}
.clan-battle-sky-stage .clan-battle-meta,
.clan-battle-sky-stage .clan-battle-next-shot,
.clan-battle-sky-stage .clan-battle-shot-row,
.clan-battle-own-status {
  position: relative;
  z-index: 8;
}
.clan-battle-sky-stage .clan-battle-meta {
  position: absolute;
  left: 14px;
  top: 12px;
  min-width: min(360px, 54%);
  padding: 9px 12px;
  border-radius: 13px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(9,22,44,.46);
  backdrop-filter: blur(2px);
  text-shadow: 0 1px 2px rgba(0,0,0,.5);
}
.clan-battle-sky-stage .clan-battle-next-shot {
  position: absolute;
  left: 14px;
  top: 78px;
  width: min(430px, 58%);
  margin: 0;
  background: rgba(9,22,44,.42);
  border: 1px solid rgba(255,255,255,.13);
  backdrop-filter: blur(2px);
}
.clan-battle-targets-layer {
  position: absolute;
  inset: 0;
  z-index: 3;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy {
  position: absolute;
  width: 245px;
  min-height: 130px;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  text-align: center;
  filter: drop-shadow(0 11px 12px rgba(0,0,0,.36));
  animation: clanBattleShipHover 4.8s ease-in-out infinite;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy b {
  display: inline-block;
  max-width: 210px;
  padding: 2px 8px;
  border-radius: 8px;
  background: rgba(35, 13, 17, .38);
  color: #7b1118;
  font-size: 18px;
  font-weight: 900;
  text-shadow: 0 1px 1px rgba(255,255,255,.32), 0 1px 4px rgba(0,0,0,.45);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars {
  display: grid;
  gap: 3px;
  justify-items: center;
  margin: 1px auto 0;
  width: 180px;
  padding: 3px 6px;
  border-radius: 8px;
  background: rgba(20, 20, 38, .35);
  color: rgba(255,245,225,.92);
  text-shadow: 0 1px 2px rgba(0,0,0,.7);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars::before,
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars::after {
  content: "";
  display: block;
  width: 150px;
  height: 5px;
  border-radius: 999px;
  box-shadow: 0 1px 2px rgba(0,0,0,.48);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars::before {
  background: linear-gradient(90deg, #8e0f14, #e43636);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars::after {
  background: linear-gradient(90deg, #611d9e, #d242db);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars span {
  font-size: 11px;
  color: rgba(255,245,220,.9);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-state {
  color: #ffe9ac;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-art {
  width: 230px;
  height: 96px;
  margin: -4px auto 0;
  border-radius: 0;
  background-image: url('../resources/sprites/clan_airship_enemy.png'), linear-gradient(180deg, rgba(40,35,38,.1), rgba(40,20,14,.1));
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  box-shadow: none;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy small {
  display: inline-block;
  margin-top: -2px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(0,0,0,.36);
  color: #ffe9ac;
  font-weight: 700;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.is-selected {
  transform: translateY(-4px) scale(1.03);
  filter: drop-shadow(0 0 12px rgba(255,226,91,.95)) drop-shadow(0 13px 12px rgba(0,0,0,.36));
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.is-selected::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -20px;
  width: 22px;
  height: 22px;
  margin-left: -11px;
  border: 4px solid rgba(255,49,49,.86);
  border-radius: 50%;
  box-shadow: 0 0 9px rgba(255,49,49,.78);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.is-destroyed {
  opacity: .46;
  filter: grayscale(.75) drop-shadow(0 9px 8px rgba(0,0,0,.32));
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.damage-light .clan-battle-ship-art { filter: sepia(.05) brightness(.95); }
.clan-battle-ship-card.clan-battle-ship-card--enemy.damage-mid .clan-battle-ship-art { filter: sepia(.18) brightness(.88); }
.clan-battle-ship-card.clan-battle-ship-card--enemy.damage-heavy .clan-battle-ship-art,
.clan-battle-ship-card.clan-battle-ship-card--enemy.damage-critical .clan-battle-ship-art { filter: sepia(.35) brightness(.72); }
.clan-battle-ship-card.clan-battle-ship-card--enemy.damage-heavy::after,
.clan-battle-ship-card.clan-battle-ship-card--enemy.damage-critical::after {
  content: "";
  position: absolute;
  left: 54%;
  top: 66px;
  width: 42px;
  height: 64px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(40,40,40,.5), rgba(40,40,40,0) 64%);
  opacity: .8;
  animation: clanBattleSmoke 2.8s ease-in-out infinite;
}
.clan-battle-target-pos-1 { left: 39%; top: 17%; }
.clan-battle-target-pos-2 { right: 8%; top: 10%; transform: scale(.78); }
.clan-battle-target-pos-3 { right: 7%; top: 44%; transform: scale(.82); }
.clan-battle-target-pos-4 { left: 18%; top: 38%; transform: scale(.72); }
.clan-battle-target-pos-5 { left: 58%; top: 33%; transform: scale(.68); }
.clan-battle-target-pos-6 { left: 4%; top: 18%; transform: scale(.64); }
@keyframes clanBattleShipHover {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -8px; }
}
@keyframes clanBattleSmoke {
  0%, 100% { transform: translateY(0) scale(.9); opacity: .35; }
  50% { transform: translateY(-18px) scale(1.25); opacity: .75; }
}
.clan-battle-own-status {
  position: absolute;
  left: 20px;
  bottom: 132px;
  display: grid;
  gap: 2px;
  padding: 8px 12px;
  border-radius: 4px;
  border: 1px solid rgba(255,235,170,.28);
  background: rgba(44, 24, 12, .55);
  color: rgba(255,245,220,.92);
  text-shadow: 0 1px 2px rgba(0,0,0,.7);
}
.clan-battle-own-status b { color: #ffe5a6; }
.clan-battle-cannon {
  position: absolute;
  left: -34px;
  bottom: 56px;
  z-index: 7;
  width: min(350px, 40%);
  height: 88px;
  transform: rotate(-12deg);
  transform-origin: left center;
  border-radius: 999px 36px 36px 999px;
  background-image: url('../resources/sprites/clan_cannon.png'), linear-gradient(180deg, #333a3d 0%, #0d1113 48%, #454b4a 100%);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  box-shadow: inset -12px 0 18px rgba(0,0,0,.62), inset 0 7px 9px rgba(255,255,255,.12), 10px 20px 24px rgba(0,0,0,.38);
  pointer-events: none;
}
.clan-battle-cannon::after {
  content: "";
  position: absolute;
  right: -18px;
  top: 15px;
  width: 42px;
  height: 58px;
  border-radius: 50%;
  background: linear-gradient(180deg, #9c6c32, #2d1b12);
  box-shadow: inset 0 0 9px rgba(0,0,0,.5);
}
.clan-battle-sky-stage .clan-battle-shot-row {
  position: absolute;
  left: 50%;
  bottom: 36px;
  width: min(520px, 56%);
  transform: translateX(-50%);
  grid-template-columns: minmax(0, 1fr) 150px;
  margin: 0;
}
.clan-battle-sky-stage .clan-battle-shot-button {
  min-height: 56px;
  font-size: 20px;
  color: #ffea6f;
  text-shadow: 0 2px 2px rgba(0,0,0,.74);
  box-shadow: 0 0 0 2px rgba(255,240,120,.18), 0 10px 16px rgba(0,0,0,.34);
}
.clan-battle-sky-stage .clan-battle-refresh-button {
  min-height: 48px;
  align-self: center;
}
.clan-battle-no-targets {
  position: absolute;
  right: 28px;
  top: 110px;
  z-index: 6;
  max-width: 220px;
}
@media (max-width: 900px) {
  .clan-battle-sky-stage,
  .clan-battle-arena { min-height: 500px; }
  .clan-battle-sky-stage .clan-battle-meta,
  .clan-battle-sky-stage .clan-battle-next-shot {
    width: auto;
    min-width: 0;
    max-width: calc(100% - 28px);
    right: 14px;
  }
  .clan-battle-sky-stage .clan-battle-next-shot { top: 76px; }
  .clan-battle-ship-card.clan-battle-ship-card--enemy { width: 190px; }
  .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-art { width: 180px; height: 76px; }
  .clan-battle-target-pos-1 { left: 36%; top: 25%; }
  .clan-battle-target-pos-2 { right: 2%; top: 20%; }
  .clan-battle-target-pos-3 { right: 4%; top: 48%; }
  .clan-battle-sky-stage .clan-battle-shot-row {
    width: calc(100% - 24px);
    grid-template-columns: 1fr;
    bottom: 14px;
  }
  .clan-battle-cannon {
    width: 240px;
    height: 62px;
    bottom: 86px;
  }
  .clan-battle-own-status { bottom: 146px; }
}

/* Cemetery clearance */
.cemetery-location-shell {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) minmax(260px, 360px);
  gap: 18px;
  width: min(920px, calc(100% - 28px));
  margin: 18px auto 0;
  align-items: stretch;
  color: #f7e7c7;
}
.cemetery-location-shell .ui-button {
  position: static;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  transform: none;
}
.cemetery-status-card,
.cemetery-actions-card,
.cemetery-heal-card,
.cemetery-note {
  border: 1px solid rgba(222, 181, 105, .46);
  border-radius: 5px;
  background: rgba(24, 16, 18, .78);
  box-shadow: 0 12px 28px rgba(0,0,0,.32), inset 0 0 22px rgba(97, 44, 41, .24);
  backdrop-filter: blur(2px);
}
.cemetery-status-card {
  grid-column: 1 / 2;
  padding: 18px;
}
.cemetery-status-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  font-size: 22px;
  font-weight: 800;
  color: #ffdca2;
  text-shadow: 0 2px 2px rgba(0,0,0,.7);
}
.cemetery-status-title span {
  font-size: 14px;
  font-weight: 700;
  color: #ffb56e;
  border: 1px solid rgba(255, 181, 110, .42);
  border-radius: 999px;
  padding: 4px 10px;
  background: rgba(0,0,0,.24);
  white-space: nowrap;
}
.cemetery-loading {
  margin-top: 18px;
  color: #f3d29a;
  opacity: .9;
}
.cemetery-hp-box {
  margin-top: 16px;
}
.cemetery-hp-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
  margin-bottom: 8px;
  font-size: 15px;
}
.cemetery-hp-head span {
  color: #b9ffb2;
  font-weight: 700;
  white-space: nowrap;
}
.cemetery-hp-bar {
  height: 18px;
  overflow: hidden;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(20, 7, 11, .82);
  box-shadow: inset 0 2px 8px rgba(0,0,0,.55);
}
.cemetery-hp-bar i {
  display: block;
  height: 100%;
  min-width: 2px;
  border-radius: inherit;
  background: linear-gradient(90deg, #7bd45d, #e8d46a, #d95545);
  box-shadow: 0 0 12px rgba(165, 239, 93, .35);
}
.cemetery-progress-line {
  margin-top: 14px;
  font-size: 15px;
  line-height: 1.45;
  color: #f7e0b7;
}
.cemetery-progress-line b {
  color: #ffdca2;
}
.cemetery-actions-card {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  align-self: start;
}
.cemetery-start-button,
.cemetery-refresh-button,
.cemetery-crypt-button,
.cemetery-heal-button {
  width: 100%;
  min-height: 44px;
  font-weight: 800;
  letter-spacing: .02em;
}
.cemetery-start-button {
  min-height: 58px;
  font-size: 18px;
}
.cemetery-refresh-button {
  opacity: .92;
}
.cemetery-crypt-button {
  min-height: 52px;
  font-size: 18px;
  background: linear-gradient(180deg, rgba(79, 55, 105, .96), rgba(31, 22, 44, .96));
}
.cemetery-heal-card {
  grid-column: 1 / 3;
  padding: 16px;
}
.cemetery-heal-card h3 {
  margin: 0 0 12px;
  color: #ffdca2;
  font-size: 18px;
}
.cemetery-heal-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.cemetery-heal-button {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 10px 12px;
  white-space: normal;
  text-align: center;
}
.cemetery-heal-button small {
  display: block;
  font-size: 12px;
  opacity: .86;
  font-weight: 700;
}
.cemetery-note {
  grid-column: 1 / 3;
  padding: 12px 16px;
  color: #ecd0aa;
  line-height: 1.45;
  font-size: 14px;
}
.cemetery-note b {
  color: #ffdca2;
}
@media (max-width: 760px) {
  .cemetery-location-shell {
    grid-template-columns: 1fr;
    width: calc(100% - 20px);
    margin-top: 12px;
  }
  .cemetery-status-card,
  .cemetery-actions-card,
  .cemetery-heal-card,
  .cemetery-note {
    grid-column: 1 / 2;
  }
  .cemetery-heal-list {
    grid-template-columns: 1fr;
  }
  .cemetery-status-title {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* 0.6.46: лечение между этапами через клик по герою на Кладбище */
.location-character.location-character--stage-heal {
  pointer-events: auto;
  cursor: pointer;
}
.location-character.location-character--stage-heal::after {
  content: 'Лечение';
  position: absolute;
  left: 50%;
  bottom: -8px;
  transform: translateX(-50%);
  padding: 4px 9px;
  border-radius: 999px;
  border: 1px solid rgba(126, 235, 116, .42);
  background: rgba(17, 35, 18, .72);
  color: #caffb9;
  font-size: 12px;
  font-weight: 900;
  text-shadow: 0 2px 3px rgba(0,0,0,.75);
  box-shadow: 0 6px 16px rgba(0,0,0,.32);
  pointer-events: none;
}
.cemetery-heal-card h4 {
  margin: 0 0 12px;
  color: #ffdca2;
  font-size: 18px;
}
.cemetery-heal-intro {
  margin: 0 0 12px;
  color: #ecd0aa;
  line-height: 1.45;
  font-size: 14px;
}
.cemetery-heal-toggle-button {
  width: 100%;
  min-height: 44px;
  margin-bottom: 12px;
  font-weight: 900;
}
.cemetery-heal-list--inventory .group-empty {
  grid-column: 1 / -1;
}
.cemetery-heal-button--inventory span {
  font-size: 15px;
}

/* 0.6.47: Склеп */
.crypt-location-shell {
  position: relative;
  display: grid;
  gap: 10px;
  width: min(760px, calc(100vw - 24px));
  margin: 58px auto 0;
  padding: 10px;
  border-radius: 5px;
  background: rgba(18, 12, 24, 0.78);
  border: 1px solid rgba(214, 185, 121, 0.45);
  box-shadow: 0 10px 28px rgba(0,0,0,.35);
  color: #f7e7c6;
}
.crypt-status-card,
.crypt-actions-card,
.crypt-heal-picker,
.crypt-battle-result {
  border-radius: 4px;
  background: rgba(35, 24, 34, 0.82);
  border: 1px solid rgba(240, 205, 139, 0.35);
  padding: 10px;
}
.crypt-status-title {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: flex-start;
  font-size: 18px;
  text-shadow: 0 1px 2px #000;
}
.crypt-status-title span,
.crypt-meta-line,
.crypt-note {
  font-size: 13px;
  color: #dbc699;
}
.crypt-rank-buttons,
.crypt-actions-card {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.crypt-rank-button {
  min-width: 46px;
  min-height: 32px;
  padding: 4px 9px;
}
.crypt-rank-button.is-active {
  filter: brightness(1.2);
  outline: 2px solid rgba(255, 220, 120, .75);
}
.crypt-party-line {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.crypt-member-card {
  position: relative;
  display: grid;
  gap: 4px;
  min-height: 118px;
  padding: 10px;
  border-radius: 4px;
  color: #f7e7c6;
  text-align: left;
  background: linear-gradient(180deg, rgba(75,57,57,.92), rgba(39,29,35,.92));
  border: 1px solid rgba(240, 205, 139, 0.45);
  cursor: pointer;
}
.crypt-member-card b { font-size: 16px; color: #ffe5a3; }
.crypt-member-card span,
.crypt-member-card em { font-size: 12px; font-style: normal; color: #dac696; }
.crypt-member-card.is-selected { outline: 2px solid rgba(255, 220, 120, .85); }
.crypt-member-card.is-dead { filter: grayscale(.65); background: linear-gradient(180deg, rgba(69,38,38,.92), rgba(25,22,26,.92)); }
.crypt-member-card.is-empty { opacity: .75; cursor: default; }
.crypt-hp {
  display: block;
  overflow: hidden;
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: rgba(0,0,0,.45);
  border: 1px solid rgba(255,255,255,.18);
}
.crypt-hp u {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #8d1f1f, #e8bd5e);
}
.crypt-heal-picker h4,
.crypt-battle-result h4 {
  margin: 0 0 8px;
  color: #ffe5a3;
}
.crypt-heal-button {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 150px;
  margin: 4px;
  padding: 7px 10px;
}
.crypt-heal-button--icon {
  position: relative;
  width: 92px;
  min-width: 92px;
  min-height: 104px;
  gap: 5px;
  padding: 8px 7px;
}
.crypt-heal-button--icon img {
  width: 42px;
  height: 42px;
  object-fit: contain;
  image-rendering: auto;
  filter: drop-shadow(0 2px 3px rgba(0,0,0,.55));
}
.crypt-heal-button small { font-size: 11px; opacity: .86; }
.crypt-heal-button--icon small {
  max-width: 78px;
  white-space: normal;
  line-height: 1.1;
}
.crypt-heal-count {
  position: absolute;
  right: 8px;
  top: 7px;
  min-width: 20px;
  padding: 1px 4px;
  border-radius: 999px;
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.18);
  color: #ffe5a3;
  font-size: 11px;
  text-align: center;
}
.crypt-no-elixirs { text-align: center; }
.crypt-fight-button { min-width: 160px; min-height: 42px; font-size: 18px; }
.crypt-battle-log {
  display: grid;
  gap: 4px;
  max-height: 150px;
  overflow: auto;
  padding-right: 4px;
}
.crypt-battle-log-row {
  padding: 5px 7px;
  border-radius: 8px;
  background: rgba(0,0,0,.23);
  font-size: 12px;
}
.crypt-reward-line { margin-bottom: 7px; color: #f5d790; }
@media (max-width: 680px) {
  .crypt-party-line { grid-template-columns: 1fr; }
  .crypt-status-title { display: block; }
}

/* 0.6.51: актуализация создания персонажа и редактора раскладки */
.ui-button.has-layout-image.is-text-hidden,
.ui-button.has-layout-image.is-text-hidden:hover,
.ui-button.has-layout-image.is-text-hidden:focus,
.ui-button.has-layout-image.is-text-hidden.is-active {
  color: transparent !important;
  text-shadow: none !important;
  font-size: 0 !important;
}
.ui-button.has-layout-image.is-text-hidden::first-letter {
  color: transparent !important;
}
.account-characters-panel__title {
  font-size: 21px;
  line-height: 1.1;
}
.account-character-row {
  min-height: 58px;
  padding: 10px 12px;
  margin-bottom: 9px;
  border-radius: 5px;
}
.account-character-row strong {
  font-size: 18px;
  line-height: 1.12;
}
.account-character-row span {
  font-size: 13px;
  line-height: 1.16;
}
.race-description-panel__stats span.race-description-panel__cost,
.race-description-panel__stats span.race-description-panel__cost b,
.race-description-panel__stats span.race-description-panel__cost em {
  color: #7f1410;
  text-shadow: 0 1px 2px rgba(255, 220, 180, .12);
}


/* 0.6.52: создание персонажа — описание рас, изумруды и скрытая подпись превью */
.character-preview__label {
  display: none !important;
}
.create-account-emeralds {
  justify-content: center;
  gap: 10px;
}
.create-account-emeralds__label {
  display: none;
}
.create-account-emeralds__fallback-icon,
.create-account-emeralds__icon {
  flex: 0 0 auto;
  width: 30px;
  height: 30px;
}
.create-account-emeralds__icon {
  object-fit: contain;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.45));
}
.create-account-emeralds__fallback-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--emerald);
  font-size: 26px;
  line-height: 1;
  text-shadow: 0 2px 4px rgba(0,0,0,.45);
}
.create-account-emeralds__value {
  color: var(--emerald);
  font-size: 28px;
  line-height: 1;
}
.race-description-panel {
  gap: 10px;
  padding: 16px 18px;
}
.race-description-panel__title {
  font-size: 25px;
}
.race-description-panel__text {
  color: rgba(255,242,217,.88);
  font-size: 17px;
  line-height: 1.28;
}
.race-description-panel__subtitle {
  margin-top: 4px;
  color: var(--gold);
  font-size: 18px;
  font-weight: 900;
  line-height: 1.15;
  text-shadow: 0 2px 4px rgba(0,0,0,.55);
}
.race-description-panel__stats {
  gap: 7px;
  font-size: 17px;
  line-height: 1.2;
}
.race-description-panel__cost-value {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}
.race-description-panel__cost-icon {
  width: 21px;
  height: 21px;
  object-fit: contain;
  filter: drop-shadow(0 1px 2px rgba(0,0,0,.45));
}

/* 0.6.57: боевая сцена арены из кнопки «Бой» */
.arena-location-shell {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.arena-location-battle {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.arena-location-stage {
  position: absolute;
  left: 50%;
  top: 46%;
  width: min(820px, calc(100% - 120px));
  min-height: 190px;
  transform: translate(-50%, -50%);
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 76px minmax(220px, 1fr);
  gap: 16px;
  align-items: center;
  z-index: 15;
  pointer-events: none;
}
.arena-location-stage .arena-fighter {
  min-height: 170px;
  background: rgba(12, 10, 14, .76);
  box-shadow: 0 18px 48px rgba(0,0,0,.36), inset 0 0 28px rgba(255, 214, 130, .08);
}
.arena-location-result {
  position: absolute;
  left: 50%;
  bottom: 104px;
  min-width: 320px;
  max-width: 640px;
  min-height: 52px;
  transform: translateX(-50%);
  z-index: 24;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border-radius: 6px;
  color: #fff4cf;
  font-weight: 900;
  text-align: center;
  background: rgba(6, 8, 12, .70);
  border: 1px solid rgba(255,230,170,.24);
  box-shadow: 0 16px 40px rgba(0,0,0,.34);
  pointer-events: none;
}
.arena-location-result:empty { display: none; }
.arena-location-buttons {
  position: absolute;
  left: 50%;
  bottom: 32px;
  display: flex;
  justify-content: center;
  gap: 14px;
  transform: translateX(-50%);
  z-index: 30;
  pointer-events: auto;
}
.arena-location-buttons .ui-button {
  position: relative;
  width: 220px;
  height: 58px;
}
.arena-location-escape {
  border-color: rgba(255, 154, 124, .42);
  background: linear-gradient(180deg, rgba(108, 45, 36, .92), rgba(68, 23, 20, .94));
}
@media (max-width: 760px) {
  .arena-location-stage {
    width: calc(100% - 32px);
    grid-template-columns: 1fr;
    top: 44%;
  }
  .arena-location-stage .arena-battle-vs { display: none; }
  .arena-location-buttons { bottom: 18px; }
  .arena-location-buttons .ui-button { width: 158px; height: 50px; }
}


.game-dialog-overlay {
  position: fixed;
  inset: 0;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 22px;
  z-index: 1000;
  background: rgba(3, 5, 9, .68);
  backdrop-filter: blur(3px);
}
.game-dialog-overlay.is-open { display: flex; }
.game-dialog {
  width: min(520px, calc(100vw - 36px));
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 16px;
  padding: 22px;
  border-radius: 8px;
  border: 1px solid rgba(255, 224, 158, .38);
  background: linear-gradient(180deg, rgba(34, 25, 18, .96), rgba(12, 11, 13, .96));
  box-shadow: 0 28px 78px rgba(0,0,0,.62), inset 0 0 34px rgba(255, 208, 128, .08);
  color: #fff1cf;
}
.game-dialog__icon {
  width: 62px;
  height: 62px;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  line-height: 1;
  font-weight: 1000;
  color: #351612;
  background: radial-gradient(circle at 38% 28%, #fff5bb, #e9a542 58%, #8d411d 100%);
  border: 2px solid rgba(255, 235, 170, .72);
  box-shadow: 0 12px 28px rgba(0,0,0,.32), 0 0 22px rgba(247, 169, 72, .24);
}
.game-dialog__title {
  margin-bottom: 8px;
  font-size: 25px;
  font-weight: 1000;
  color: #ffe7ad;
  text-shadow: 0 2px 0 rgba(0,0,0,.45);
}
.game-dialog__text {
  min-height: 46px;
  font-size: 18px;
  line-height: 1.35;
  color: #f6e8ca;
  white-space: pre-line;
}
.game-dialog__actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
  margin-top: 18px;
}
.game-dialog__button,
.game-dialog__button.ui-button {
  position: relative;
  min-width: 132px;
  min-height: 48px;
  padding: 0 18px;
  font-size: 17px;
}
.game-dialog__button--accept,
.game-dialog__button--accept.ui-button {
  border-color: rgba(255, 219, 142, .58);
  background: linear-gradient(180deg, rgba(129, 79, 33, .96), rgba(78, 38, 22, .98));
}
.game-dialog__button--cancel,
.game-dialog__button--cancel.ui-button {
  border-color: rgba(210, 201, 183, .28);
  background: linear-gradient(180deg, rgba(55, 59, 67, .92), rgba(24, 27, 32, .96));
}
.game-dialog-overlay--message .game-dialog__actions {
  justify-content: center;
}
@media (max-width: 560px) {
  .game-dialog {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .game-dialog__icon {
    margin: 0 auto;
  }
  .game-dialog__actions {
    flex-direction: column;
  }
  .game-dialog__button,
  .game-dialog__button.ui-button {
    width: 100%;
  }
}


/* 0.6.66: основа 0.6.61, без толстых золотых рамок; уменьшено только скругление углов */

/* 0.6.67: верфь клана как локация поверх фона, без общей рамки */
.app[data-location="clan_shipyard"] #locationTitle,
.app[data-location="clan_shipyard"] #emeraldWidget,
.app[data-location="clan_shipyard"] #goldWidget {
  display: none;
}
.app[data-location="clan_shipyard"] #premiumWidget {
  display: flex;
}
.app[data-location="clan_shipyard"] .bottom-nav {
  display: none;
}

.clan-shipyard-shell,
.clan-shipyard-shell .ui-button {
  position: static;
}
.clan-shipyard-shell {
  position: absolute;
  inset: 0;
  width: auto;
  max-height: none;
  overflow: visible;
  transform: none;
  left: 0;
  top: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  pointer-events: none;
  display: block;
}
.clan-shipyard-shell > * {
  pointer-events: auto;
}

.clan-shipyard-top {
  position: absolute;
  left: 14px;
  top: 118px;
  width: 170px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  z-index: 5;
}
.clan-shipyard-tab,
.clan-shipyard-main-button,
.clan-ship-open-button,
.clan-shipyard-bank__button {
  min-height: 56px;
  border: 0;
  border-radius: 6px;
  color: #fff4d4;
  font-size: 18px;
  font-weight: 1000;
  text-shadow: 0 2px 4px rgba(0,0,0,.75);
  background:
    linear-gradient(180deg, rgba(0,0,0,.08), rgba(0,0,0,.16)),
    url('../resources/ui/buttons/btn_creat.png') center center / 100% 100% no-repeat,
    linear-gradient(180deg, rgba(96,58,25,.96), rgba(38,24,16,.96));
  box-shadow: 0 12px 26px rgba(0,0,0,.32);
}
.clan-shipyard-tab.is-active,
.clan-ship-open-button:hover,
.clan-shipyard-main-button:hover {
  filter: brightness(1.1);
}
.clan-shipyard-tab--alert {
  box-shadow: 0 0 22px rgba(255, 90, 42, .34), 0 12px 26px rgba(0,0,0,.32);
}

.clan-shipyard-timers {
  position: absolute;
  top: 10px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  z-index: 6;
}
.clan-shipyard-timer {
  min-width: 190px;
  padding: 9px 14px;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.28);
  background: rgba(8, 10, 14, .68);
  box-shadow: 0 10px 26px rgba(0,0,0,.28);
  text-align: center;
}
.clan-shipyard-timer b,
.clan-shipyard-bank__value b {
  display: block;
  color: rgba(255,224,150,.90);
  font-size: 12px;
  line-height: 1.2;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.clan-shipyard-timer span,
.clan-shipyard-bank__value span {
  display: block;
  margin-top: 2px;
  color: #fff4d4;
  font-size: 20px;
  font-weight: 1000;
  line-height: 1.05;
  text-shadow: 0 2px 4px rgba(0,0,0,.6);
}

.clan-shipyard-bank {
  position: absolute;
  left: 12px;
  top: 8px;
  z-index: 7;
  display: grid;
  grid-template-columns: auto 92px 92px;
  gap: 8px;
  align-items: center;
  padding: 8px;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.24);
  background: rgba(8, 10, 14, .70);
  box-shadow: 0 10px 28px rgba(0,0,0,.28);
}
.clan-shipyard-bank__input {
  position: static;
  width: 92px;
  height: 42px;
  min-height: 42px;
  padding: 0 8px;
  border-radius: 4px;
  font-size: 15px;
}
.clan-shipyard-bank__button {
  width: 92px;
  min-height: 42px;
  font-size: 15px;
}

.clan-shipyard-quick-nav {
  position: absolute;
  left: 12px;
  bottom: 10px;
  display: flex;
  gap: 10px;
  z-index: 5;
}
.clan-shipyard-quick-nav__button {
  width: 72px;
  height: 72px;
  min-height: 72px;
  padding: 0;
  border: 0;
  border-radius: 6px;
  overflow: hidden;
  color: transparent;
  text-shadow: none;
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}
.clan-shipyard-quick-nav__button--map {
  background-image: url('../resources/ui/buttons/nav_map.png');
}
.clan-shipyard-quick-nav__button--chat {
  background-image: url('../resources/ui/buttons/nav_chat.png');
}

.clan-shipyard-status {
  position: absolute;
  left: 50%;
  top: 72px;
  transform: translateX(-50%);
  z-index: 8;
  max-width: 560px;
  padding: 8px 14px;
  border-radius: 5px;
  background: rgba(8, 10, 14, .72);
  box-shadow: 0 10px 24px rgba(0,0,0,.25);
}

.clan-shipyard-ship {
  position: absolute;
  left: 50%;
  top: 128px;
  transform: translateX(-50%);
  width: min(760px, calc(100% - 250px));
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  z-index: 3;
}
.clan-shipyard-ship-controls {
  display: grid;
  grid-template-columns: 72px minmax(260px, 1fr) 72px;
  gap: 14px;
  align-items: center;
}
.clan-ship-arrow {
  min-height: 170px;
  border: 0;
  border-radius: 6px;
  background: rgba(8, 10, 14, .36);
  color: rgba(255,235,175,.9);
  font-size: 56px;
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
}
.clan-shipyard-ship-center {
  min-height: 278px;
  gap: 8px;
}
.clan-ship-art {
  width: min(520px, 58vw);
  height: 210px;
  border-radius: 0;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
}
.clan-ship-art.has-layout-image {
  background-color: transparent;
  box-shadow: none;
}
.clan-ship-art.has-layout-image::before,
.clan-ship-art.has-layout-image::after {
  display: none;
}
.clan-ship-number {
  font-size: 24px;
}
.clan-ship-open-button {
  width: 210px;
  min-height: 54px;
}
.clan-shipyard-ship-details {
  margin: 10px auto 0;
  width: min(640px, 100%);
  padding: 12px;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.18);
  background: rgba(8, 10, 14, .66);
  box-shadow: 0 18px 42px rgba(0,0,0,.32);
}
.clan-shipyard-ship-details .clan-shipyard-action-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.clan-shipyard-ship-details .clan-shipyard-main-button {
  min-height: 46px;
  font-size: 15px;
}

.clan-shipyard-members,
.clan-shipyard-settings,
.clan-battle-scene {
  position: absolute;
  left: 220px;
  top: 96px;
  right: 24px;
  max-height: calc(100% - 126px);
  overflow: auto;
  z-index: 4;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.18);
  background: rgba(8, 10, 14, .72);
  box-shadow: 0 18px 44px rgba(0,0,0,.32);
}
.clan-shipyard-settings {
  width: auto;
  max-width: none;
  justify-self: auto;
}

@media (max-width: 760px) {
  .clan-shipyard-timers {
    top: 72px;
    width: calc(100% - 24px);
    flex-direction: column;
    gap: 6px;
  }
  .clan-shipyard-timer {
    min-width: 0;
    padding: 6px 10px;
  }
  .clan-shipyard-timer span { font-size: 16px; }
  .clan-shipyard-battle-stats {
    min-width: 0;
    width: 100%;
    padding: 8px 10px;
    font-size: 15px;
    gap: 6px 12px;
  }
  .clan-shipyard-battle-stats b { font-size: 17px; }
  .clan-shipyard-bank {
    grid-template-columns: 1fr 74px;
    width: calc(100% - 120px);
  }
  .clan-shipyard-bank__input { display: none; }
  .clan-shipyard-bank__button { width: 74px; }
  .clan-shipyard-top {
    top: auto;
    left: 8px;
    bottom: 92px;
    width: calc(100% - 16px);
    grid-template-columns: repeat(4, 1fr);
  }
  .clan-shipyard-tab { min-height: 48px; font-size: 13px; }
  .clan-shipyard-ship {
    top: 150px;
    width: calc(100% - 24px);
  }
  .clan-shipyard-ship-controls {
    grid-template-columns: 48px minmax(160px, 1fr) 48px;
    gap: 6px;
  }
  .clan-ship-arrow { min-height: 110px; font-size: 36px; }
  .clan-ship-art { width: min(300px, 64vw); height: 124px; }
  .clan-ship-open-button { width: 160px; min-height: 46px; }
  .clan-shipyard-ship-details .clan-shipyard-action-row {
    grid-template-columns: 1fr;
  }
  .clan-shipyard-members,
  .clan-shipyard-settings,
  .clan-battle-scene {
    left: 10px;
    right: 10px;
    top: 142px;
    max-height: calc(100% - 238px);
  }
  .clan-shipyard-quick-nav__button {
    width: 60px;
    height: 60px;
    min-height: 60px;
  }
}


/* 0.6.68: правки верфи — крупнее корабль, флаг, overlay деталей */
.clan-shipyard-top {
  grid-template-columns: 1fr;
}
.clan-shipyard-flag-stand {
  position: absolute;
  left: 12px;
  top: 76px;
  z-index: 7;
  width: 116px;
  display: grid;
  justify-items: center;
  gap: 6px;
  padding: 8px 6px 10px;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.24);
  background: rgba(8, 10, 14, .68);
  box-shadow: 0 10px 28px rgba(0,0,0,.28);
}
.clan-shipyard-flag-stand__flag {
  width: 78px;
  height: 56px;
  border-radius: 6px;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem {
  transform: scale(1.45);
}
.clan-shipyard-flag-stand__name {
  max-width: 100%;
  color: rgba(255,236,190,.95);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.15;
  text-align: center;
  text-shadow: 0 2px 4px rgba(0,0,0,.6);
}
.clan-shipyard-top {
  top: 152px;
}
.clan-shipyard-bank {
  grid-template-columns: auto 92px 92px;
}
.clan-shipyard-ship {
  top: 84px;
  width: min(1160px, calc(100% - 240px));
}
.clan-shipyard-ship-controls {
  grid-template-columns: 84px minmax(300px, 1fr) 84px;
}
.clan-ship-arrow {
  min-height: 240px;
  font-size: 64px;
}
.clan-shipyard-ship-center {
  min-height: 520px;
}
.clan-ship-art {
  width: min(980px, 82vw);
  height: 420px;
  animation: clanShipRock 5.6s ease-in-out infinite;
  transform-origin: 50% 60%;
  will-change: transform;
}
@keyframes clanShipRock {
  0% { transform: translateY(0px) scale(1); }
  25% { transform: translateY(-3px) scale(1.014) rotate(-0.4deg); }
  50% { transform: translateY(1px) scale(0.998) rotate(0deg); }
  75% { transform: translateY(-2px) scale(1.012) rotate(0.4deg); }
  100% { transform: translateY(0px) scale(1); }
}
.clan-ship-number {
  font-size: 28px;
}
.clan-ship-open-button {
  width: 240px;
  min-height: 58px;
}
.clan-shipyard-ship.is-details-open {
  z-index: 20;
}
.clan-shipyard-ship-details {
  position: fixed;
  inset: 0;
  margin: 0;
  width: auto;
  padding: 22px;
  border: 0;
  background: rgba(3, 5, 9, .74);
  box-shadow: none;
  backdrop-filter: blur(3px);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 120;
}
.clan-shipyard-ship-details__panel {
  width: min(920px, calc(100vw - 40px));
  max-height: calc(100vh - 44px);
  overflow: auto;
  padding: 18px;
  border-radius: 8px;
  border: 1px solid rgba(255,218,128,.18);
  background: rgba(8, 10, 14, .92);
  box-shadow: 0 20px 48px rgba(0,0,0,.40);
}
.clan-shipyard-ship-details__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.clan-shipyard-ship-details__title {
  color: #ffe5a6;
  font-size: 26px;
  font-weight: 1000;
  line-height: 1.1;
}
.clan-shipyard-ship-details__back {
  min-width: 160px;
}
.clan-shipyard-ship-details .clan-shipyard-ship-info {
  font-size: 17px;
}
.clan-shipyard-ship-details .clan-shipyard-ship-info b {
  font-size: 24px;
}
.clan-shipyard-ship-details .clan-ship-slot-row {
  min-height: 52px;
  font-size: 17px;
}
.clan-shipyard-ship-details .clan-shipyard-main-button {
  min-height: 56px;
  font-size: 18px;
}
.clan-shipyard-ship-details .clan-create-hint,
.clan-shipyard-ship-details .group-empty,
.clan-shipyard-ship-details .clan-ship-slot-picker-title {
  font-size: 17px;
}
@media (max-width: 760px) {
  .clan-shipyard-flag-stand {
    top: 60px;
    width: 94px;
    padding: 6px 4px 8px;
  }
  .clan-shipyard-flag-stand__flag {
    width: 64px;
    height: 46px;
  }
  .clan-shipyard-bank {
    width: calc(100% - 120px);
  }
  .clan-shipyard-top {
    grid-template-columns: repeat(4, 1fr);
  }
  .clan-shipyard-ship {
    top: 144px;
    width: calc(100% - 20px);
  }
  .clan-shipyard-ship-controls {
    grid-template-columns: 48px minmax(180px, 1fr) 48px;
  }
  .clan-ship-arrow {
    min-height: 148px;
    font-size: 36px;
  }
  .clan-shipyard-ship-center {
    min-height: 290px;
  }
  .clan-ship-art {
    width: min(92vw, 560px);
    height: 220px;
  }
  .clan-shipyard-ship-details {
    padding: 12px;
  }
  .clan-shipyard-ship-details__panel {
    width: calc(100vw - 16px);
    max-height: calc(100vh - 16px);
    padding: 12px;
  }
  .clan-shipyard-ship-details__head {
    flex-direction: column;
    align-items: stretch;
  }
  .clan-shipyard-ship-details__back {
    width: 100%;
  }
}


/* 0.6.69: правки верфи */
.clan-shipyard-ship-controls > .clan-ship-arrow:first-child {
  transform: translateX(168px);
  z-index: 4;
}
.clan-flag-mini.has-layout-image {
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  border-color: transparent;
  box-shadow: none;
}
.clan-flag-emblem.has-layout-image {
  background-color: transparent;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  color: transparent;
  border: 0;
  clip-path: none;
}
.clan-flag-emblem.has-layout-image::before,
.clan-flag-emblem.has-layout-image::after {
  content: none;
}
.clan-shipyard-ship-details {
  align-items: stretch;
  justify-content: stretch;
  padding: 14px;
}
.clan-shipyard-ship-details__panel {
  width: 100%;
  max-width: none;
  max-height: none;
  height: 100%;
  padding: 26px;
  border-radius: 6px;
}
.clan-shipyard-ship-details__head {
  display: grid;
  grid-template-columns: 1fr 190px 190px;
  gap: 14px;
}
.clan-shipyard-ship-details__title {
  font-size: 34px;
}
.clan-shipyard-ship-details__back,
.clan-shipyard-ship-details__close {
  min-width: 0;
  width: 100%;
}
.clan-shipyard-ship-details .clan-shipyard-ship-info {
  gap: 9px;
}
.clan-shipyard-ship-details .clan-shipyard-ship-info b {
  font-size: 32px;
}
.clan-shipyard-ship-details .clan-shipyard-ship-info span {
  font-size: 22px;
  line-height: 1.25;
}
.clan-shipyard-ship-details .clan-ship-slot-list {
  gap: 10px;
}
.clan-shipyard-ship-details .clan-ship-slot-row {
  min-height: 64px;
  padding: 14px 18px;
  font-size: 22px;
}
.clan-shipyard-ship-details .clan-shipyard-action-row {
  gap: 14px;
  margin-top: 16px;
}
.clan-shipyard-ship-details .clan-shipyard-main-button {
  min-height: 68px;
  font-size: 22px;
}
.clan-ship-upgrade-hint {
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 5px;
  border: 1px solid rgba(255,218,128,.18);
  background: rgba(255,218,128,.08);
  color: rgba(255,238,198,.94);
  font-size: 20px;
  font-weight: 800;
  line-height: 1.25;
}
.clan-shipyard-ship-details .clan-create-hint,
.clan-shipyard-ship-details .group-empty,
.clan-shipyard-ship-details .clan-ship-slot-picker-title {
  font-size: 21px;
}
@media (max-width: 760px) {
  .clan-shipyard-ship-controls > .clan-ship-arrow:first-child {
    transform: translateX(96px);
  }
  .clan-shipyard-ship-details {
    padding: 8px;
  }
  .clan-shipyard-ship-details__panel {
    width: 100%;
    height: 100%;
    max-height: none;
    padding: 12px;
  }
  .clan-shipyard-ship-details__head {
    grid-template-columns: 1fr 1fr;
  }
  .clan-shipyard-ship-details__title {
    grid-column: 1 / -1;
    font-size: 26px;
  }
  .clan-shipyard-ship-details .clan-shipyard-ship-info b {
    font-size: 24px;
  }
  .clan-shipyard-ship-details .clan-shipyard-ship-info span {
    font-size: 18px;
  }
  .clan-shipyard-ship-details .clan-ship-slot-row {
    min-height: 54px;
    font-size: 18px;
  }
  .clan-shipyard-ship-details .clan-shipyard-action-row {
    grid-template-columns: 1fr;
  }
  .clan-shipyard-ship-details .clan-shipyard-main-button {
    min-height: 56px;
    font-size: 18px;
  }
  .clan-ship-upgrade-hint {
    font-size: 17px;
  }
}


/* 0.6.70: настройка корабля на полный экран, крупный флаг, кнопки ниже */
.clan-shipyard-flag-stand {
  top: 76px;
  width: 278px;
  min-height: 210px;
  padding: 14px 12px 16px;
  gap: 10px;
}
.clan-shipyard-flag-stand__flag {
  width: 234px;
  height: 168px;
  border-radius: 8px;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem {
  transform: scale(2.4);
}
.clan-shipyard-flag-stand__name {
  font-size: 17px;
}
.clan-shipyard-top {
  top: 318px;
}
.clan-shipyard-ship-details {
  position: fixed;
  inset: 0;
  width: 100vw;
  height: 100vh;
  height: 100dvh;
  padding: 0;
  box-sizing: border-box;
  align-items: stretch;
  justify-content: stretch;
  z-index: 300;
}
.clan-shipyard-ship-details__panel {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  border-radius: 0;
  padding: 30px;
  box-sizing: border-box;
}
.clan-shipyard-ship-details__head {
  grid-template-columns: 1fr 190px;
}
.clan-shipyard-ship-details__back {
  display: none !important;
}
.clan-ship-upgrade-hint {
  text-align: center;
}
@media (max-width: 760px) {
  .clan-shipyard-flag-stand {
    top: 58px;
    width: 148px;
    min-height: 118px;
    padding: 8px 6px 10px;
  }
  .clan-shipyard-flag-stand__flag {
    width: 126px;
    height: 90px;
  }
  .clan-shipyard-flag-stand__name {
    font-size: 12px;
  }
  .clan-shipyard-top {
    bottom: 92px;
    top: auto;
  }
  .clan-shipyard-ship-details__panel {
    padding: 12px;
  }
  .clan-shipyard-ship-details__head {
    grid-template-columns: 1fr;
  }
}


/* 0.6.71: флаг клана без тёмной подложки, цветной mask PNG, крупная эмблема */
.clan-flag-mini.has-mask-image {
  background: var(--clan-flag-color);
}
.clan-flag-emblem.has-mask-image {
  background: var(--clan-emblem-color);
  color: transparent;
  border: 0;
  clip-path: none;
  text-shadow: none;
}
.clan-flag-emblem.has-mask-image::before,
.clan-flag-emblem.has-mask-image::after {
  content: none;
}
.clan-shipyard-flag-stand {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  padding: 0 !important;
  min-height: 0 !important;
}
.clan-shipyard-flag-stand__flag {
  background-color: var(--clan-flag-color) !important;
  box-shadow: 0 8px 18px rgba(0,0,0,.28) !important;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem {
  width: 112px;
  height: 112px;
  transform: translate(-50%, -50%);
  font-size: 70px;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem::before {
  font-size: 70px;
}
.clan-shipyard-flag-stand__name {
  text-shadow: 0 2px 5px rgba(0,0,0,.7);
}
@media (max-width: 760px) {
  .clan-shipyard-flag-stand__flag .clan-flag-emblem {
    width: 78px;
    height: 78px;
    font-size: 50px;
  }
  .clan-shipyard-flag-stand__flag .clan-flag-emblem::before {
    font-size: 50px;
  }
}


/* 0.6.72: флаг клана рисуется кодом, без PNG/mask-текстур; настройка корабля — настоящий fullscreen */
.clan-flag-mini {
  isolation: isolate;
  background:
    linear-gradient(135deg, rgba(255,255,255,.22), rgba(255,255,255,0) 34%, rgba(0,0,0,.14) 72%, rgba(0,0,0,.22)),
    var(--clan-flag-color) !important;
}
.clan-flag-mini::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.16), transparent 18%, transparent 82%, rgba(0,0,0,.18)),
    repeating-linear-gradient(180deg, rgba(255,255,255,.055) 0 2px, rgba(0,0,0,.035) 2px 4px);
  pointer-events: none;
}
.clan-flag-mini::after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  width: 16%;
  height: 100%;
  z-index: 1;
  background: rgba(0,0,0,.20);
  box-shadow: inset -1px 0 rgba(255,255,255,.18);
  pointer-events: none;
}
.clan-flag-mini--flag_01 { border-radius: 4px; clip-path: none; }
.clan-flag-mini--flag_02 { border-radius: 50% 50% 6px 6px; clip-path: none; }
.clan-flag-mini--flag_03 { clip-path: polygon(0 0, 100% 0, 100% 78%, 50% 100%, 0 78%); }
.clan-flag-mini--flag_04 { clip-path: polygon(0 0, 82% 0, 100% 50%, 82% 100%, 0 100%); }
.clan-flag-mini--flag_05 { border-radius: 4px; clip-path: polygon(0 0, 100% 0, 84% 50%, 100% 100%, 0 100%); }
.clan-flag-mini--flag_06 { border-radius: 4px; clip-path: polygon(0 0, 100% 0, 82% 50%, 100% 100%, 0 100%); }
.clan-flag-mini--flag_07 { clip-path: polygon(0 0, 100% 50%, 0 100%); }
.clan-flag-mini--flag_08 { clip-path: polygon(0 0, 100% 12%, 92% 100%, 0 88%); }
.clan-flag-emblem {
  z-index: 2;
  text-shadow: 0 2px 4px rgba(0,0,0,.62);
}
.clan-flag-emblem--emblem_01,
.clan-flag-emblem--emblem_02,
.clan-flag-emblem--emblem_03 {
  box-shadow: 0 2px 4px rgba(0,0,0,.28);
}
.clan-flag-emblem--emblem_04::before { content: '✚'; }
.clan-flag-emblem--emblem_05::before { content: '⚔'; }
.clan-flag-emblem--emblem_06::before { content: '◆'; }
.clan-flag-emblem--emblem_07::before { content: '☾'; }
.clan-flag-emblem--emblem_08::before { content: '♛'; }
.clan-flag-mini.has-layout-image,
.clan-flag-mini.has-mask-image,
.clan-flag-emblem.has-layout-image,
.clan-flag-emblem.has-mask-image {
  -webkit-mask-image: none !important;
  mask-image: none !important;
  background-image: none !important;
}
.clan-shipyard-flag-stand__flag {
  border: 0 !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.30), inset 0 2px 0 rgba(255,255,255,.18) !important;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem {
  left: 50%;
  top: 50%;
  width: 132px;
  height: 132px;
  transform: translate(-50%, -50%);
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem::before {
  font-size: 86px;
  line-height: 1;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem--emblem_01 {
  border-width: 16px;
}

.clan-shipyard-ship.is-details-open {
  position: fixed !important;
  inset: 0 !important;
  left: 0 !important;
  top: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  transform: none !important;
  z-index: 900 !important;
  pointer-events: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}
.clan-shipyard-ship.is-details-open > .clan-shipyard-ship-controls {
  display: none !important;
}
.clan-shipyard-ship.is-details-open .clan-shipyard-ship-details {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: rgba(0, 0, 0, .76) !important;
  box-shadow: none !important;
  backdrop-filter: blur(3px);
  display: flex !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  z-index: 901 !important;
}
.clan-shipyard-ship.is-details-open .clan-shipyard-ship-details__panel {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  overflow: auto !important;
  border-radius: 0 !important;
  border: 0 !important;
  background: rgba(8, 10, 14, .94) !important;
  box-shadow: inset 0 0 0 1px rgba(255,218,128,.12) !important;
}
@media (max-width: 760px) {
  .clan-shipyard-flag-stand__flag .clan-flag-emblem {
    width: 88px;
    height: 88px;
  }
  .clan-shipyard-flag-stand__flag .clan-flag-emblem::before {
    font-size: 58px;
  }
  .clan-shipyard-flag-stand__flag .clan-flag-emblem--emblem_01 {
    border-width: 11px;
  }
}


/* 0.6.73: флаги/эмблемы снова берутся из PNG-масок и красятся цветом; корабль — отдельный fullscreen-слой; анимация медленнее в 5 раз */
.clan-flag-mini.has-mask-image {
  clip-path: none !important;
  border-radius: 0 !important;
  background: var(--clan-flag-color) !important;
  background-image: none !important;
  overflow: visible !important;
}
.clan-flag-mini.has-mask-image::before,
.clan-flag-mini.has-mask-image::after {
  content: none !important;
  display: none !important;
}
.clan-flag-emblem.has-mask-image {
  clip-path: none !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: var(--clan-emblem-color) !important;
  background-image: none !important;
  color: transparent !important;
  text-shadow: none !important;
}
.clan-flag-emblem.has-mask-image::before,
.clan-flag-emblem.has-mask-image::after {
  content: none !important;
  display: none !important;
}
.clan-shipyard-flag-stand__flag.has-mask-image {
  box-shadow: none !important;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.32));
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem.has-mask-image {
  left: 50%;
  top: 50%;
  width: 46%;
  height: 46%;
  transform: translate(-50%, -50%) scale(3);
  transform-origin: center center;
}
.clan-ship-details-portal {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  z-index: 10000 !important;
  pointer-events: auto !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: rgba(0, 0, 0, .78) !important;
  box-shadow: none !important;
  backdrop-filter: blur(3px);
  display: flex !important;
  align-items: stretch !important;
  justify-content: stretch !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__panel {
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  overflow: auto !important;
  border-radius: 0 !important;
  border: 0 !important;
  background: rgba(8, 10, 14, .94) !important;
  box-shadow: inset 0 0 0 1px rgba(255,218,128,.12) !important;
  box-sizing: border-box !important;
}
body.clan-ship-details-open {
  overflow: hidden;
}
.clan-ship-art {
  animation-duration: 28s !important;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy {
  animation-duration: 24s !important;
}
@media (max-width: 760px) {
  .clan-shipyard-flag-stand__flag .clan-flag-emblem.has-mask-image {
    width: 46%;
    height: 46%;
    transform: translate(-50%, -50%) scale(3);
  }
}

/* 0.6.74: флаг как Unity Image.color — обычная PNG-текстура с tint-цветом; корабль — fullscreen-слой без растягивания содержимого */
.clan-flag-mini.has-tint-image,
.clan-flag-emblem.has-tint-image {
  clip-path: none !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  background-image: linear-gradient(var(--clan-tint-color), var(--clan-tint-color)), var(--clan-image-url) !important;
  background-repeat: no-repeat, no-repeat !important;
  background-position: center center, center center !important;
  background-size: contain, contain !important;
  background-blend-mode: multiply, normal !important;
  color: transparent !important;
  text-shadow: none !important;
}
.clan-flag-mini.has-tint-image::before,
.clan-flag-mini.has-tint-image::after,
.clan-flag-emblem.has-tint-image::before,
.clan-flag-emblem.has-tint-image::after {
  content: none !important;
  display: none !important;
}
.clan-flag-emblem.has-tint-image {
  border: 0 !important;
  box-shadow: none !important;
}
.clan-shipyard-flag-stand__flag.has-tint-image {
  border: 0 !important;
  box-shadow: none !important;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.32));
  overflow: visible !important;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem.has-tint-image {
  left: 50%;
  top: 50%;
  width: 46%;
  height: 46%;
  transform: translate(-50%, -50%) scale(3);
  transform-origin: center center;
}

.clan-shipyard-ship.is-details-open {
  position: absolute !important;
  left: 50% !important;
  top: 84px !important;
  right: auto !important;
  bottom: auto !important;
  inset: auto auto auto 50% !important;
  width: min(1160px, calc(100% - 240px)) !important;
  height: auto !important;
  min-height: 0 !important;
  transform: translateX(-50%) !important;
  z-index: 3 !important;
  pointer-events: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}
.clan-shipyard-ship.is-details-open > .clan-shipyard-ship-controls {
  display: grid !important;
}
.clan-ship-details-portal {
  position: fixed !important;
  inset: 0 !important;
  width: 100vw !important;
  height: 100vh !important;
  height: 100dvh !important;
  z-index: 10000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: max(16px, var(--safe-top)) max(16px, var(--safe-right)) max(16px, var(--safe-bottom)) max(16px, var(--safe-left)) !important;
  box-sizing: border-box !important;
  pointer-events: auto !important;
  background: rgba(0, 0, 0, .62) !important;
  backdrop-filter: blur(4px);
}
.clan-ship-details-portal .clan-shipyard-ship-details {
  position: relative !important;
  inset: auto !important;
  width: min(1040px, calc(100vw - 32px)) !important;
  height: auto !important;
  max-width: none !important;
  max-height: calc(100vh - 32px) !important;
  max-height: calc(100dvh - 32px) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 9px !important;
  background: transparent !important;
  box-shadow: 0 28px 100px rgba(0,0,0,.62) !important;
  backdrop-filter: none !important;
  display: block !important;
  align-items: initial !important;
  justify-content: initial !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__panel {
  width: 100% !important;
  height: auto !important;
  max-width: none !important;
  max-height: calc(100vh - 32px) !important;
  max-height: calc(100dvh - 32px) !important;
  overflow: auto !important;
  border-radius: 9px !important;
  border: 1px solid rgba(243,198,111,.24) !important;
  background: rgba(8, 10, 14, .96) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
  box-sizing: border-box !important;
  padding: 22px !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__close {
  min-width: 160px !important;
}
body.clan-ship-details-open {
  overflow: hidden !important;
}
.clan-ship-art {
  animation-duration: 28s !important;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy {
  animation-duration: 24s !important;
}
@media (max-width: 760px) {
  .clan-shipyard-ship.is-details-open {
    top: 144px !important;
    width: calc(100% - 20px) !important;
  }
  .clan-shipyard-ship.is-details-open > .clan-shipyard-ship-controls {
    grid-template-columns: 48px minmax(180px, 1fr) 48px !important;
  }
  .clan-ship-details-portal {
    padding: max(8px, var(--safe-top)) max(8px, var(--safe-right)) max(8px, var(--safe-bottom)) max(8px, var(--safe-left)) !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details {
    width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__panel {
    max-height: calc(100vh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
    padding: 12px !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__head {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__close {
    width: 100% !important;
  }
  .clan-shipyard-flag-stand__flag .clan-flag-emblem.has-tint-image {
    width: 46%;
    height: 46%;
    transform: translate(-50%, -50%) scale(3);
  }
}


/* 0.6.75: нормальный размер кнопок в fullscreen-настройке корабля + эмблема флага меньше в 2 раза */
.clan-ship-details-portal .clan-shipyard-action-row {
  gap: 10px !important;
}
.clan-ship-details-portal .clan-shipyard-main-button,
.clan-ship-details-portal .clan-shipyard-ship-details__close,
.clan-ship-details-portal .clan-ship-slot-picker .clan-shipyard-main-button {
  min-height: 56px !important;
  height: 56px !important;
  padding: 0 18px !important;
  font-size: 18px !important;
  line-height: 1.05 !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__close {
  min-width: 160px !important;
  width: auto !important;
}
.clan-shipyard-flag-stand__flag .clan-flag-emblem,
.clan-shipyard-flag-stand__flag .clan-flag-emblem.has-tint-image,
.clan-shipyard-flag-stand__flag .clan-flag-emblem.has-mask-image {
  transform: translate(-50%, -50%) scale(1.5) !important;
  transform-origin: center center !important;
}
@media (max-width: 760px) {
  .clan-ship-details-portal .clan-shipyard-action-row {
    gap: 8px !important;
  }
  .clan-ship-details-portal .clan-shipyard-main-button,
  .clan-ship-details-portal .clan-shipyard-ship-details__close,
  .clan-ship-details-portal .clan-ship-slot-picker .clan-shipyard-main-button {
    min-height: 48px !important;
    height: 48px !important;
    padding: 0 12px !important;
    font-size: 16px !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__close {
    width: 100% !important;
    min-width: 0 !important;
  }
  .clan-shipyard-flag-stand__flag .clan-flag-emblem,
  .clan-shipyard-flag-stand__flag .clan-flag-emblem.has-tint-image,
  .clan-shipyard-flag-stand__flag .clan-flag-emblem.has-mask-image {
    transform: translate(-50%, -50%) scale(1.5) !important;
  }
}


/* 0.6.76: кнопки Закрыть и Улучшить в настройке корабля перенесены вправо */
.clan-ship-details-portal .clan-shipyard-ship-details__head {
  justify-content: space-between !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__close {
  width: 160px !important;
  min-width: 160px !important;
  max-width: 160px !important;
  margin-left: auto !important;
  justify-self: end !important;
}
.clan-ship-details-portal .clan-shipyard-action-row {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 160px !important;
  justify-content: stretch !important;
  align-items: center !important;
}
.clan-ship-details-portal .clan-shipyard-action-row [data-clan-action="upgrade_ship"] {
  width: 160px !important;
  min-width: 160px !important;
  max-width: 160px !important;
  justify-self: end !important;
}
@media (max-width: 760px) {
  .clan-ship-details-portal .clan-shipyard-ship-details__head {
    align-items: stretch !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__close {
    width: 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    margin-left: auto !important;
  }
  .clan-ship-details-portal .clan-shipyard-action-row {
    grid-template-columns: 1fr !important;
  }
  .clan-ship-details-portal .clan-shipyard-action-row [data-clan-action="upgrade_ship"] {
    width: 160px !important;
    min-width: 160px !important;
    max-width: 160px !important;
    justify-self: end !important;
  }
}


/* 0.6.77: настройка корабля — все кнопки в одной строке, закрыть справа, без плавающей кнопки на телефоне */
.clan-ship-details-portal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: max(16px, var(--safe-top)) max(16px, var(--safe-right)) max(16px, var(--safe-bottom)) max(16px, var(--safe-left)) !important;
  box-sizing: border-box !important;
  background: rgba(0, 0, 0, .62) !important;
  backdrop-filter: blur(4px);
}
.clan-ship-details-portal .clan-shipyard-ship-details {
  position: relative !important;
  inset: auto !important;
  width: min(1040px, calc(100vw - 32px)) !important;
  height: auto !important;
  max-height: calc(100vh - 32px) !important;
  max-height: calc(100dvh - 32px) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 9px !important;
  background: transparent !important;
  box-shadow: 0 28px 100px rgba(0,0,0,.62) !important;
  display: block !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__panel {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  max-height: calc(100vh - 32px) !important;
  max-height: calc(100dvh - 32px) !important;
  overflow: auto !important;
  border-radius: 9px !important;
  border: 1px solid rgba(243,198,111,.24) !important;
  background: rgba(8, 10, 14, .96) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08) !important;
  box-sizing: border-box !important;
  padding: 22px !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__head {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  margin-bottom: 12px !important;
}
.clan-ship-details-portal .clan-shipyard-action-row {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  margin-top: 14px !important;
}
.clan-ship-details-portal .clan-shipyard-action-row--single {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
}
.clan-ship-details-portal .clan-shipyard-main-button,
.clan-ship-details-portal .clan-shipyard-ship-details__close,
.clan-ship-details-portal .clan-ship-slot-picker .clan-shipyard-main-button,
.clan-ship-details-portal .clan-shipyard-action-row [data-clan-action="upgrade_ship"] {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 54px !important;
  height: 54px !important;
  padding: 0 14px !important;
  font-size: 17px !important;
  line-height: 1.05 !important;
  justify-self: stretch !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details__close {
  margin-left: 0 !important;
}
body.clan-ship-details-open {
  overflow: hidden !important;
}
@media (max-width: 760px) {
  .clan-ship-details-portal {
    padding: max(8px, var(--safe-top)) max(8px, var(--safe-right)) max(8px, var(--safe-bottom)) max(8px, var(--safe-left)) !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details {
    width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__panel {
    max-height: calc(100vh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
    padding: 12px !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details__head {
    flex-direction: row !important;
    align-items: center !important;
  }
  .clan-ship-details-portal .clan-shipyard-action-row {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }
  .clan-ship-details-portal .clan-shipyard-action-row--single {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .clan-ship-details-portal .clan-shipyard-main-button,
  .clan-ship-details-portal .clan-shipyard-ship-details__close,
  .clan-ship-details-portal .clan-ship-slot-picker .clan-shipyard-main-button,
  .clan-ship-details-portal .clan-shipyard-action-row [data-clan-action="upgrade_ship"] {
    min-height: 44px !important;
    height: 44px !important;
    padding: 0 6px !important;
    font-size: 12px !important;
    line-height: 1.05 !important;
    white-space: normal !important;
  }
}

/* 0.6.78: настройка корабля пересобрана с нуля по принципу окна инвентаря/магазина */
.clan-ship-details-portal.clan-ship-setup-portal {
  position: fixed !important;
  inset: 0 !important;
  z-index: 10000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: max(16px, var(--safe-top)) max(16px, var(--safe-right)) max(16px, var(--safe-bottom)) max(16px, var(--safe-left)) !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  background: rgba(0,0,0,.58) !important;
  backdrop-filter: blur(4px) !important;
}
.clan-ship-details-portal .clan-shipyard-ship-details.clan-ship-setup-overlay {
  position: relative !important;
  inset: auto !important;
  display: block !important;
  width: min(100%, 980px) !important;
  height: auto !important;
  max-height: min(92vh, 680px) !important;
  max-height: min(92dvh, 680px) !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 9px !important;
  background: transparent !important;
  box-shadow: 0 28px 100px rgba(0,0,0,.62) !important;
  overflow: hidden !important;
}
.clan-ship-details-portal .clan-ship-setup-window {
  display: flex !important;
  flex-direction: column !important;
  width: 100% !important;
  max-width: none !important;
  height: auto !important;
  max-height: min(92vh, 680px) !important;
  max-height: min(92dvh, 680px) !important;
  padding: 0 !important;
  overflow: hidden !important;
  border-radius: 9px !important;
  background: var(--panel-strong) !important;
  border: 1px solid rgba(243,198,111,.24) !important;
  box-shadow: none !important;
  box-sizing: border-box !important;
}
.clan-ship-details-portal .clan-ship-setup-header {
  flex: 0 0 auto !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  gap: 16px !important;
  margin: 0 !important;
  padding: 20px 22px !important;
  border-bottom: 1px solid rgba(243,198,111,.14) !important;
}
.clan-ship-details-portal .clan-ship-setup-title {
  margin: 4px 0 0 !important;
  color: var(--gold) !important;
  font-size: 36px !important;
  line-height: 1 !important;
}
.clan-ship-details-portal .clan-ship-setup-content {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow: auto !important;
  padding: 24px !important;
  box-sizing: border-box !important;
}
.clan-ship-details-portal .clan-ship-setup-info {
  display: flex !important;
  flex-direction: column !important;
  gap: 7px !important;
  margin-bottom: 14px !important;
  padding: 14px !important;
  border-radius: 8px !important;
  border: 1px solid rgba(255,230,170,.12) !important;
  background: rgba(0,0,0,.18) !important;
}
.clan-ship-details-portal .clan-ship-setup-info b {
  color: #ffe5a6 !important;
  font-size: 22px !important;
  line-height: 1.12 !important;
}
.clan-ship-details-portal .clan-ship-setup-info span {
  color: rgba(246,237,215,.82) !important;
  font-size: 15px !important;
  line-height: 1.32 !important;
}
.clan-ship-details-portal .clan-ship-setup-slots {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin: 0 0 14px !important;
}
.clan-ship-details-portal .clan-ship-setup-slots .clan-ship-slot-row,
.clan-ship-details-portal .clan-ship-setup-slots .clan-ship-slot-button {
  width: 100% !important;
  min-height: 48px !important;
  height: auto !important;
  padding: 10px 12px !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  text-align: left !important;
  box-sizing: border-box !important;
}
.clan-ship-details-portal .clan-ship-setup-actions {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 10px !important;
  align-items: stretch !important;
  justify-content: stretch !important;
  margin: 14px 0 10px !important;
  padding: 0 !important;
}
.clan-ship-details-portal .clan-ship-setup-actions--empty {
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  max-width: 460px !important;
  margin-left: auto !important;
}
.clan-ship-details-portal .clan-ship-setup-button,
.clan-ship-details-portal .clan-shipyard-main-button.clan-ship-setup-button,
.clan-ship-details-portal .clan-shipyard-ship-details__close.clan-ship-setup-button,
.clan-ship-details-portal .clan-ship-setup-actions [data-clan-action="upgrade_ship"] {
  position: static !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  min-height: 50px !important;
  height: 50px !important;
  margin: 0 !important;
  padding: 0 12px !important;
  border-radius: 5px !important;
  font-size: 15px !important;
  line-height: 1.05 !important;
  white-space: normal !important;
  text-align: center !important;
  justify-self: stretch !important;
  box-sizing: border-box !important;
  transform: none !important;
}
.clan-ship-details-portal .clan-ship-setup-button--close {
  order: 10 !important;
}
.clan-ship-details-portal .clan-ship-setup-upgrade-hint {
  margin: 6px 0 0 !important;
  color: #ffe5a6 !important;
  font-size: 15px !important;
  text-align: right !important;
}
body.clan-ship-details-open {
  overflow: hidden !important;
}
@media (max-width: 760px) {
  .clan-ship-details-portal.clan-ship-setup-portal {
    padding: max(8px, var(--safe-top)) max(8px, var(--safe-right)) max(8px, var(--safe-bottom)) max(8px, var(--safe-left)) !important;
  }
  .clan-ship-details-portal .clan-shipyard-ship-details.clan-ship-setup-overlay,
  .clan-ship-details-portal .clan-ship-setup-window {
    width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 16px) !important;
    max-height: calc(100dvh - 16px) !important;
  }
  .clan-ship-details-portal .clan-ship-setup-header {
    padding: 14px 14px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-title {
    font-size: 28px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-content {
    padding: 14px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-info {
    padding: 12px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-info b {
    font-size: 19px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-info span {
    font-size: 13px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-slots {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-slots .clan-ship-slot-row,
  .clan-ship-details-portal .clan-ship-setup-slots .clan-ship-slot-button {
    min-height: 42px !important;
    padding: 8px 10px !important;
    font-size: 13px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-actions {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
    margin-top: 12px !important;
  }
  .clan-ship-details-portal .clan-ship-setup-actions--empty {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    max-width: none !important;
  }
  .clan-ship-details-portal .clan-ship-setup-button,
  .clan-ship-details-portal .clan-shipyard-main-button.clan-ship-setup-button,
  .clan-ship-details-portal .clan-shipyard-ship-details__close.clan-ship-setup-button,
  .clan-ship-details-portal .clan-ship-setup-actions [data-clan-action="upgrade_ship"] {
    min-height: 44px !important;
    height: 44px !important;
    padding: 0 5px !important;
    font-size: 12px !important;
    letter-spacing: 0 !important;
  }
  .clan-ship-details-portal .clan-ship-setup-upgrade-hint {
    font-size: 13px !important;
    text-align: left !important;
  }
}

/* 0.6.79: клановый бой по серверному событию + палуба-спрайт снизу + реальные HP/щит над кораблями */
.clan-shipyard-tab--locked,
.clan-shipyard-tab--locked:disabled {
  opacity: .56 !important;
  filter: grayscale(.22) brightness(.86) !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
}
.clan-battle-empty {
  display: grid;
  gap: 6px;
  padding: 18px;
}
.clan-battle-empty b {
  color: #ffe5a6;
  font-size: 20px;
}
.clan-battle-empty span {
  color: rgba(255,245,220,.82);
  line-height: 1.35;
}
.clan-battle-wait-row {
  max-width: 280px;
  margin-top: 12px;
}
.clan-battle-sky-stage::after {
  background-image: linear-gradient(10deg, rgba(72,39,18,.78), rgba(116,73,32,.70) 42%, rgba(37,23,15,.78)) !important;
  height: 23% !important;
}
.clan-battle-deck-sprite {
  position: absolute;
  left: 50%;
  bottom: -8%;
  z-index: 6;
  width: min(1180px, 120%);
  height: 42%;
  transform: translateX(-50%);
  background-image: url('../resources/sprites/clan_battle_deck_cannon.png'), url('../resources/backgrounds/bg_clan_battle_deck.png'), linear-gradient(10deg, rgba(72,39,18,.98), rgba(116,73,32,.98) 42%, rgba(37,23,15,.98));
  background-repeat: no-repeat, no-repeat, no-repeat;
  background-position: center bottom, center bottom, center bottom;
  background-size: contain, cover, cover;
  pointer-events: none;
  filter: drop-shadow(0 -12px 18px rgba(0,0,0,.28));
}
.clan-battle-cannon {
  bottom: 72px !important;
  z-index: 7 !important;
  opacity: .96;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy {
  z-index: 4;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars {
  width: 186px !important;
  padding: 4px 7px !important;
  gap: 2px !important;
  background: rgba(11, 15, 29, .52) !important;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars::before,
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars::after {
  content: none !important;
  display: none !important;
}
.clan-battle-ship-bar-label {
  width: 100%;
  font-size: 10px !important;
  text-align: left;
}
.clan-battle-meter {
  width: 100%;
  height: 7px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(0,0,0,.46);
  box-shadow: inset 0 1px 2px rgba(0,0,0,.62), 0 1px 2px rgba(255,255,255,.12);
}
.clan-battle-meter > i {
  display: block;
  width: var(--value, 0%);
  height: 100%;
  border-radius: inherit;
}
.clan-battle-meter--hp > i {
  background: linear-gradient(90deg, #7e1218, #e13a35, #ff7865);
}
.clan-battle-meter--shield > i {
  background: linear-gradient(90deg, #3722a0, #8e3ee2, #e06dff);
}
.clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-art {
  background-repeat: no-repeat !important;
  background-position: center !important;
  background-size: contain !important;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-1 .clan-battle-ship-art {
  width: 210px;
  height: 86px;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-2 .clan-battle-ship-art {
  width: 232px;
  height: 98px;
}
.clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-3 .clan-battle-ship-art {
  width: 252px;
  height: 108px;
}
.clan-battle-target-pos-1 { left: 40%; top: 15%; }
.clan-battle-target-pos-2 { right: 7%; top: 11%; transform: scale(.80); }
.clan-battle-target-pos-3 { right: 7%; top: 43%; transform: scale(.84); }
@media (max-width: 900px) {
  .clan-battle-deck-sprite {
    bottom: -5%;
    width: 138%;
    height: 34%;
  }
  .clan-battle-cannon {
    bottom: 92px !important;
  }
  .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars {
    width: 156px !important;
  }
  .clan-battle-target-pos-1 { left: 34%; top: 23%; }
  .clan-battle-target-pos-2 { right: 1%; top: 21%; }
  .clan-battle-target-pos-3 { right: 3%; top: 47%; }
}

/* 0.6.81: клановый бой как отдельная fullscreen-сцена, без окна и без кодовой пушки */
.app[data-location="clan_battle"] #locationTitle,
.app[data-location="clan_battle"] .resource-widget,
.app[data-location="clan_battle"] .bottom-nav,
.app[data-location="clan_battle"] #locationCharacter {
  display: none !important;
}
.app[data-location="clan_battle"] .scene-vignette {
  background: linear-gradient(to bottom, rgba(0,0,0,.08), transparent 38%, rgba(0,0,0,.34));
}
.clan-battle-full-shell,
.clan-battle-full-shell .ui-button {
  position: static;
}
.clan-battle-full-shell {
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: auto;
  isolation: isolate;
}
.clan-battle-full-stage {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background: linear-gradient(180deg, #3265a7 0%, #83bae1 61%, #d9f0f7 100%);
}
.clan-battle-full-stage::before {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: 0;
  background-image: url('../resources/backgrounds/bg_clan_battle_sky.jpg'), radial-gradient(circle at 32% 13%, rgba(255,255,255,.70), rgba(255,255,255,0) 22%), linear-gradient(180deg, #315fa0 0%, #83bae1 62%, #d9f0f7 100%);
  background-repeat: repeat-x, no-repeat, no-repeat;
  background-size: auto 100%, cover, cover;
  background-position: 0 0, center, center;
  animation: clanBattleCloudDriftReverse 58s linear infinite;
}
@keyframes clanBattleCloudDriftReverse {
  from { background-position: -1400px 0, center, center; }
  to { background-position: 0 0, center, center; }
}
.clan-battle-full-stage::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 4;
  height: 18%;
  background: linear-gradient(180deg, rgba(70,39,18,0), rgba(70,39,18,.42));
  pointer-events: none;
}
.clan-battle-full-meta,
.clan-battle-full-next-shot,
.clan-battle-full-card,
.clan-battle-full-own-status,
.clan-battle-full-controls,
.clan-battle-full-log {
  position: absolute;
  z-index: 10;
}
.clan-battle-full-meta {
  left: 24px;
  top: 22px;
  display: grid;
  gap: 4px;
  min-width: 320px;
  max-width: 470px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(7,18,39,.46);
  backdrop-filter: blur(3px);
  text-shadow: 0 2px 3px rgba(0,0,0,.56);
}
.clan-battle-full-meta b { color: #ffe5a6; font-size: 19px; }
.clan-battle-full-meta span { color: rgba(255,245,220,.9); font-size: 14px; }
.clan-battle-full-next-shot {
  left: 24px;
  top: 96px;
  max-width: 500px;
  padding: 8px 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(7,18,39,.40);
  color: rgba(255,245,220,.92);
  font-weight: 800;
  text-shadow: 0 2px 3px rgba(0,0,0,.56);
}
.clan-battle-full-card--empty {
  left: 50%;
  top: 42%;
  transform: translate(-50%, -50%);
  display: grid;
  gap: 8px;
  min-width: 360px;
  padding: 22px 26px;
  border-radius: 13px;
  border: 1px solid rgba(243,198,111,.28);
  background: rgba(8,10,14,.76);
  backdrop-filter: blur(4px);
  text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,.48);
}
.clan-battle-full-card--empty b { color: #ffe5a6; font-size: 24px; }
.clan-battle-full-card--empty span { color: rgba(255,245,220,.88); }
.clan-battle-full-targets {
  position: absolute;
  inset: 0;
  z-index: 5;
}
.clan-battle-full-own-status {
  left: 24px;
  bottom: 152px;
  z-index: 12;
}
.clan-battle-full-deck {
  bottom: -13% !important;
  z-index: 8 !important;
  width: 126% !important;
  height: 46% !important;
  background-image: url('../resources/sprites/clan_battle_deck_cannon.png'), url('../resources/backgrounds/bg_clan_battle_deck.png'), linear-gradient(10deg, rgba(72,39,18,.98), rgba(116,73,32,.98) 42%, rgba(37,23,15,.98)) !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center bottom, center bottom, center bottom !important;
  background-size: contain, cover, cover !important;
}
.clan-battle-full-controls {
  right: 24px;
  bottom: 24px;
  z-index: 18;
  display: grid;
  grid-template-columns: repeat(2, 124px);
  gap: 10px;
  pointer-events: auto;
}
.clan-battle-full-control.ui-button {
  width: 124px;
  height: 50px;
  min-width: 124px;
  min-height: 50px;
  padding: 0 12px;
  border-radius: 8px;
  font-size: 17px;
  line-height: 1;
}
.clan-battle-full-control--shoot.ui-button {
  grid-column: 1 / -1;
  width: 258px;
  min-width: 258px;
  height: 58px;
  min-height: 58px;
  color: #ffea6f;
  font-size: 22px;
  text-shadow: 0 2px 2px rgba(0,0,0,.74);
  box-shadow: 0 0 0 2px rgba(255,240,120,.18), 0 10px 16px rgba(0,0,0,.34);
}
.clan-battle-full-log {
  right: 24px;
  top: 24px;
  bottom: 152px;
  width: 360px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid rgba(243,198,111,.26);
  background: rgba(7,10,16,.78);
  backdrop-filter: blur(4px);
  box-shadow: 0 18px 54px rgba(0,0,0,.44);
}
.clan-battle-full-log-head {
  display: grid;
  gap: 2px;
  padding: 12px 14px;
  border-bottom: 1px solid rgba(243,198,111,.18);
}
.clan-battle-full-log-head b { color: #ffe5a6; font-size: 20px; }
.clan-battle-full-log-head span { color: rgba(255,245,220,.72); font-size: 12px; }
.clan-battle-full-log-list {
  min-height: 0;
  overflow: auto;
  padding: 10px;
  display: grid;
  gap: 8px;
}
.clan-battle-full-empty-log {
  position: static;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy {
  z-index: 6;
}
.clan-battle-full-stage .clan-battle-target-pos-1 { left: 38%; top: 14%; }
.clan-battle-full-stage .clan-battle-target-pos-2 { right: 8%; top: 13%; transform: scale(.80); }
.clan-battle-full-stage .clan-battle-target-pos-3 { right: 9%; top: 42%; transform: scale(.84); }
.clan-battle-full-stage .clan-battle-target-pos-4 { left: 14%; top: 34%; transform: scale(.72); }
.clan-battle-full-stage .clan-battle-target-pos-5 { left: 57%; top: 34%; transform: scale(.68); }
.clan-battle-full-stage .clan-battle-target-pos-6 { left: 4%; top: 16%; transform: scale(.64); }
@media (max-width: 900px) {
  .clan-battle-full-meta {
    left: 12px;
    top: 12px;
    min-width: 0;
    max-width: calc(100% - 24px);
    padding: 8px 10px;
  }
  .clan-battle-full-next-shot {
    left: 12px;
    top: 82px;
    right: 12px;
    max-width: none;
    font-size: 12px;
  }
  .clan-battle-full-deck {
    bottom: -8% !important;
    width: 150% !important;
    height: 36% !important;
  }
  .clan-battle-full-own-status {
    left: 12px;
    bottom: 116px;
    max-width: 220px;
  }
  .clan-battle-full-controls {
    right: 10px;
    bottom: 10px;
    grid-template-columns: repeat(2, 96px);
    gap: 7px;
  }
  .clan-battle-full-control.ui-button {
    width: 96px;
    min-width: 96px;
    height: 42px;
    min-height: 42px;
    font-size: 14px;
  }
  .clan-battle-full-control--shoot.ui-button {
    width: 199px;
    min-width: 199px;
    height: 50px;
    min-height: 50px;
    font-size: 18px;
  }
  .clan-battle-full-log {
    left: 10px;
    right: 10px;
    top: 10px;
    bottom: 112px;
    width: auto;
  }
  .clan-battle-full-stage .clan-battle-target-pos-1 { left: 31%; top: 24%; }
  .clan-battle-full-stage .clan-battle-target-pos-2 { right: 1%; top: 22%; }
  .clan-battle-full-stage .clan-battle-target-pos-3 { right: 1%; top: 48%; }
  .clan-battle-full-stage .clan-battle-target-pos-4 { left: 0; top: 45%; }
}

/* 0.6.82: клановый бой — правильные слои, небо с запасом, скрытые цифры HP/щита, лёгкое покачивание и навигация слева */
.app[data-location="clan_battle"] .location-actions,
.app[data-location="clan_battle"] #locationActions {
  overflow: hidden !important;
}
.clan-battle-full-stage {
  isolation: isolate;
  background: linear-gradient(180deg, #3265a7 0%, #83bae1 61%, #d9f0f7 100%) !important;
}
.clan-battle-full-stage::before {
  inset: -9vh -14vw !important;
  z-index: 0 !important;
  background-repeat: repeat-x, no-repeat, no-repeat !important;
  background-size: auto 118%, cover, cover !important;
  background-position: 0 50%, center center, center center !important;
  animation: clanBattleSkyWideReverse 66s linear infinite !important;
  will-change: background-position;
}
@keyframes clanBattleSkyWideReverse {
  from { background-position: 1600px 50%, center center, center center; }
  to { background-position: 0 50%, center center, center center; }
}
.clan-battle-full-targets {
  z-index: 3 !important;
}
.clan-battle-full-deck {
  z-index: 8 !important;
  bottom: -14% !important;
  width: 132% !important;
  height: 48% !important;
  animation: clanBattleDeckSoftFloat 7.5s ease-in-out infinite !important;
  will-change: transform;
}
@keyframes clanBattleDeckSoftFloat {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(-3px); }
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy {
  z-index: 4 !important;
  width: 282px !important;
  min-height: 152px !important;
  --ship-scale: 1;
  animation: clanBattleEnemySoftFloat 6.8s ease-in-out infinite !important;
  will-change: transform;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy:nth-child(2n) {
  animation-delay: -1.4s !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy:nth-child(3n) {
  animation-delay: -2.6s !important;
}
@keyframes clanBattleEnemySoftFloat {
  0%, 100% { transform: translateY(0) scale(var(--ship-scale, 1)); }
  50% { transform: translateY(-4px) scale(var(--ship-scale, 1)); }
}
.clan-battle-full-stage .clan-battle-target-pos-1 { left: 37%; top: 14%; --ship-scale: 1.08; }
.clan-battle-full-stage .clan-battle-target-pos-2 { right: 6%; top: 12%; --ship-scale: .92; }
.clan-battle-full-stage .clan-battle-target-pos-3 { right: 7%; top: 41%; --ship-scale: .96; }
.clan-battle-full-stage .clan-battle-target-pos-4 { left: 12%; top: 33%; --ship-scale: .84; }
.clan-battle-full-stage .clan-battle-target-pos-5 { left: 56%; top: 32%; --ship-scale: .80; }
.clan-battle-full-stage .clan-battle-target-pos-6 { left: 3%; top: 15%; --ship-scale: .76; }
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.is-selected {
  filter: drop-shadow(0 0 14px rgba(255,226,91,.98)) drop-shadow(0 13px 12px rgba(0,0,0,.36)) !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-art {
  width: 258px !important;
  height: 108px !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-1 .clan-battle-ship-art {
  width: 238px !important;
  height: 98px !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-2 .clan-battle-ship-art {
  width: 264px !important;
  height: 112px !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-3 .clan-battle-ship-art {
  width: 286px !important;
  height: 122px !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars {
  width: 214px !important;
  gap: 3px !important;
  padding: 4px 8px !important;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bar-label {
  font-size: 10px !important;
  letter-spacing: .02em;
  opacity: .9;
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-meter {
  height: 8px !important;
}
.clan-battle-full-nav-controls,
.clan-battle-full-controls {
  position: absolute;
  z-index: 18;
  pointer-events: auto;
}
.clan-battle-full-nav-controls {
  left: 24px;
  bottom: 24px;
  display: grid;
  grid-template-columns: repeat(2, 124px);
  gap: 10px;
}
.clan-battle-full-controls {
  right: 24px;
  bottom: 24px;
}
.clan-battle-full-control--map.ui-button,
.clan-battle-full-control--chat.ui-button {
  width: 124px;
  min-width: 124px;
  height: 50px;
  min-height: 50px;
}
@media (max-width: 900px) {
  .clan-battle-full-stage::before {
    inset: -8vh -22vw !important;
    background-size: auto 120%, cover, cover !important;
  }
  .clan-battle-full-deck {
    bottom: -9% !important;
    width: 158% !important;
    height: 38% !important;
  }
  .clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy {
    width: 214px !important;
    min-height: 126px !important;
  }
  .clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-art,
  .clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-1 .clan-battle-ship-art,
  .clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-2 .clan-battle-ship-art,
  .clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.clan-battle-ship-rank-3 .clan-battle-ship-art {
    width: 198px !important;
    height: 84px !important;
  }
  .clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy .clan-battle-ship-bars {
    width: 166px !important;
  }
  .clan-battle-full-stage .clan-battle-target-pos-1 { left: 29%; top: 23%; --ship-scale: 1.02; }
  .clan-battle-full-stage .clan-battle-target-pos-2 { right: -2%; top: 21%; --ship-scale: .86; }
  .clan-battle-full-stage .clan-battle-target-pos-3 { right: -1%; top: 47%; --ship-scale: .88; }
  .clan-battle-full-stage .clan-battle-target-pos-4 { left: -2%; top: 44%; --ship-scale: .78; }
  .clan-battle-full-nav-controls {
    left: 10px;
    bottom: 10px;
    grid-template-columns: repeat(2, 96px);
    gap: 7px;
  }
  .clan-battle-full-control--map.ui-button,
  .clan-battle-full-control--chat.ui-button {
    width: 96px;
    min-width: 96px;
    height: 42px;
    min-height: 42px;
    font-size: 14px;
  }
}

/* 0.6.83: клановый бой — чистые слои: небо за сценой, палуба поверх, навигация как нижняя панель */
.app[data-location="clan_battle"] .scene-vignette {
  background: none !important;
}
.app[data-location="clan_battle"] .location-actions,
.app[data-location="clan_battle"] #locationActions {
  overflow: hidden !important;
}
.clan-battle-full-stage {
  overflow: hidden !important;
  background: #7fb6d9 !important;
}
.clan-battle-full-stage::before {
  inset: -4vh -8vw !important;
  z-index: 0 !important;
  background-image: url('../resources/backgrounds/bg_clan_battle_sky.jpg'), linear-gradient(180deg, #6da8d4 0%, #a9d2e8 62%, #d8eef7 100%) !important;
  background-repeat: no-repeat, no-repeat !important;
  background-size: cover, cover !important;
  background-position: center center, center center !important;
  filter: none !important;
  transform: translateX(0);
  animation: clanBattleSkyFullDrift 72s ease-in-out infinite !important;
  will-change: transform;
}
@keyframes clanBattleSkyFullDrift {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(-5vw); }
}
.clan-battle-full-stage::after {
  content: none !important;
  display: none !important;
}
.clan-battle-full-targets,
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy {
  z-index: 4 !important;
}
.clan-battle-full-deck,
.clan-battle-deck-sprite.clan-battle-full-deck {
  left: 50% !important;
  bottom: -13% !important;
  z-index: 9 !important;
  width: min(1360px, 138%) !important;
  height: 48% !important;
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center bottom, center bottom, center bottom !important;
  background-size: contain, cover, cover !important;
  pointer-events: none !important;
  transform: translateX(-50%) translateY(0);
  animation: clanBattleDeckSoftFloat083 8s ease-in-out infinite !important;
  will-change: transform;
}
@keyframes clanBattleDeckSoftFloat083 {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50% { transform: translateX(-50%) translateY(-3px); }
}
.clan-battle-full-own-status {
  z-index: 12 !important;
}
.clan-battle-full-nav-controls {
  left: 10px !important;
  bottom: 10px !important;
  display: grid !important;
  grid-template-columns: repeat(2, 90px) !important;
  gap: 6px !important;
  z-index: 20 !important;
}
.clan-battle-full-control--map.ui-button,
.clan-battle-full-control--chat.ui-button {
  width: 90px !important;
  min-width: 90px !important;
  height: 90px !important;
  min-height: 90px !important;
  padding: 0 !important;
  border-radius: 7px !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
  font-size: 0 !important;
  color: transparent !important;
  text-shadow: none !important;
}
.clan-battle-full-control--map.ui-button.is-text-hidden,
.clan-battle-full-control--chat.ui-button.is-text-hidden {
  font-size: 0 !important;
  color: transparent !important;
}
.clan-battle-full-controls {
  z-index: 20 !important;
}
@media (max-width: 900px) {
  .clan-battle-full-stage::before {
    inset: -3vh -12vw !important;
  }
  @keyframes clanBattleSkyFullDrift {
    0%, 100% { transform: translateX(0); }
    50% { transform: translateX(-7vw); }
  }
  .clan-battle-full-deck,
  .clan-battle-deck-sprite.clan-battle-full-deck {
    bottom: -8% !important;
    width: 154% !important;
    height: 38% !important;
  }
  .clan-battle-full-nav-controls {
    left: 8px !important;
    bottom: 8px !important;
    grid-template-columns: repeat(2, 72px) !important;
    gap: 5px !important;
  }
  .clan-battle-full-control--map.ui-button,
  .clan-battle-full-control--chat.ui-button {
    width: 72px !important;
    min-width: 72px !important;
    height: 72px !important;
    min-height: 72px !important;
  }
}

/* 0.6.84: клановый бой подключён к редактору раскладки */
.clan-battle-full-stage .has-battle-layout {
  position: absolute !important;
  right: auto !important;
  bottom: auto !important;
}
.clan-battle-full-deck.has-battle-layout,
.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  background-repeat: no-repeat, no-repeat, no-repeat !important;
  background-position: center bottom, center bottom, center bottom !important;
  background-size: contain, cover, cover !important;
  pointer-events: none !important;
  transform: translateY(0) !important;
  animation: clanBattleDeckSoftFloatLayout084 8s ease-in-out infinite !important;
  will-change: transform;
}
@keyframes clanBattleDeckSoftFloatLayout084 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.has-battle-layout {
  transform: none !important;
  --ship-scale: 1 !important;
  animation: clanBattleEnemySoftFloatLayout084 6.8s ease-in-out infinite !important;
}
@keyframes clanBattleEnemySoftFloatLayout084 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}
.clan-battle-full-stage .clan-battle-ship-card.clan-battle-ship-card--enemy.has-battle-layout .clan-battle-ship-art {
  width: min(92%, 286px) !important;
  height: min(70%, 122px) !important;
}
.clan-battle-full-nav-controls.is-battle-editor-layout,
.clan-battle-full-controls.is-battle-editor-layout {
  left: 0 !important;
  top: 0 !important;
  right: auto !important;
  bottom: auto !important;
  width: 1280px !important;
  height: 720px !important;
  display: block !important;
  grid-template-columns: none !important;
  gap: 0 !important;
  pointer-events: none !important;
}
.clan-battle-full-control.has-battle-layout-control.ui-button {
  position: absolute !important;
  right: auto !important;
  bottom: auto !important;
  min-width: 1px !important;
  min-height: 1px !important;
  pointer-events: auto !important;
}
.clan-battle-full-control--shoot.has-battle-layout-control.ui-button {
  grid-column: auto !important;
}
.clan-battle-full-control--map.has-battle-layout-control.ui-button,
.clan-battle-full-control--chat.has-battle-layout-control.ui-button {
  padding: 0 !important;
  font-size: 0 !important;
  color: transparent !important;
  text-shadow: none !important;
}


/* 0.6.87 — clan battle black screen/layers safe fix */
.app[data-location="clan_battle"] .scene-background {
  background-image: none !important;
}
.app[data-location="clan_battle"] #stage,
.app[data-location="clan_battle"] #locationActions,
.app[data-location="clan_battle"] .location-actions {
  background: transparent !important;
}
.clan-battle-full-shell,
.clan-battle-full-stage {
  border-top: 0 !important;
  box-shadow: none !important;
}
.clan-battle-full-stage {
  background-color: #9fc6df !important;
  background-image: none !important;
}
.clan-battle-full-stage::before,
.clan-battle-full-stage::after {
  content: none !important;
  display: none !important;
}
.clan-battle-full-sky-bg {
  animation: clanBattleSkyLayerDrift087 72s ease-in-out infinite;
  will-change: transform;
}
@keyframes clanBattleSkyLayerDrift087 {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(-5vw); }
}
.clan-battle-full-stage > *:not(.clan-battle-full-sky-bg) {
  position: relative;
  z-index: 2;
}
.clan-battle-full-targets,
.clan-battle-targets-layer {
  z-index: 4 !important;
}
.clan-battle-ship-wrap {
  pointer-events: none;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-ship-wrap .clan-battle-ship-card {
  pointer-events: auto;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-ship-wrap .clan-battle-ship-name,
.clan-battle-ship-wrap .clan-battle-ship-bars {
  pointer-events: none;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-ship-wrap .clan-battle-ship-art {
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.28));
}
.clan-battle-ship-wrap.is-destroyed .clan-battle-ship-name {
  color: #8c2b2b !important;
  opacity: .9;
}
.clan-battle-ship-wrap .clan-battle-meter {
  background: transparent !important;
  box-shadow: none !important;
}
.clan-battle-deck-sprite.clan-battle-full-deck {
  z-index: 9 !important;
  background-color: transparent !important;
}
.clan-battle-full-nav-controls,
.clan-battle-full-controls,
.clan-battle-full-meta,
.clan-battle-full-next-shot,
.clan-battle-full-own-status,
.clan-battle-full-log {
  z-index: 20 !important;
}


/* 0.6.88 — клановый бой: чистые слои сцены */
.app[data-location="clan_battle"] .scene-background,
.app[data-location="clan_battle"] .scene-vignette {
  background-image: none !important;
  background: transparent !important;
  opacity: 0 !important;
  pointer-events: none !important;
}
.app[data-location="clan_battle"] #stage,
.app[data-location="clan_battle"] #locationActions,
.app[data-location="clan_battle"] .location-actions {
  background: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}
.clan-battle-full-shell,
.clan-battle-full-stage {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-full-stage {
  position: relative !important;
  overflow: hidden !important;
  isolation: isolate !important;
  background-color: #9fc6df !important;
  background-image: none !important;
}
.clan-battle-full-stage::before,
.clan-battle-full-stage::after {
  content: none !important;
  display: none !important;
}
.clan-battle-layer {
  position: absolute !important;
  inset: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
}
.clan-battle-layer--sky {
  z-index: 0 !important;
  overflow: hidden !important;
  background-color: #9fc6df !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: cover !important;
  animation: none !important;
  transform: none !important;
}
.clan-battle-layer--ships { z-index: 3 !important; }
.clan-battle-layer--ship-ui { z-index: 5 !important; }
.clan-battle-layer--deck { z-index: 8 !important; overflow: hidden !important; }
.clan-battle-full-stage > *:not(.clan-battle-layer) {
  position: relative;
  z-index: 20;
}
.clan-battle-scene-ship {
  display: block !important;
  pointer-events: auto !important;
  background-color: transparent !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: contain !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: visible !important;
  color: transparent !important;
  text-shadow: none !important;
  cursor: pointer;
  filter: drop-shadow(0 8px 16px rgba(0,0,0,.28));
  animation: clanBattleEnemySceneFloat088 7s ease-in-out infinite !important;
}
.clan-battle-scene-ship:nth-child(2n) { animation-duration: 8.2s !important; }
.clan-battle-scene-ship:nth-child(3n) { animation-duration: 7.6s !important; animation-delay: -.8s !important; }
@keyframes clanBattleEnemySceneFloat088 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}
.clan-battle-scene-ship[disabled] {
  cursor: default;
  opacity: .92;
}
.clan-battle-scene-ship.is-destroyed {
  opacity: .58;
  filter: grayscale(.5) brightness(.72) drop-shadow(0 6px 12px rgba(0,0,0,.2));
}
.clan-battle-scene-ship-name {
  display: flex !important;
  align-items: center;
  justify-content: center;
  pointer-events: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #b01717 !important;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
  text-shadow: 0 1px 0 rgba(255,225,150,.75), 0 2px 5px rgba(0,0,0,.45);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.clan-battle-scene-ship-name.is-destroyed {
  color: #702020 !important;
  opacity: .85;
}
.clan-battle-scene-ship-bars {
  display: grid !important;
  grid-template-columns: 30px 1fr;
  grid-template-rows: 14px 14px;
  gap: 3px 6px;
  align-items: center;
  pointer-events: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
.clan-battle-scene-bar-label {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  color: #ffe7b6;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
  text-shadow: 0 1px 3px rgba(0,0,0,.85);
}
.clan-battle-scene-meter {
  position: relative;
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: transparent !important;
  border: 1px solid rgba(30,19,8,.62);
  box-shadow: none !important;
}
.clan-battle-scene-meter > i {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  border-radius: 999px;
}
.clan-battle-scene-meter--hp > i {
  background: linear-gradient(180deg, #ff9386, #d92d22);
}
.clan-battle-scene-meter--shield > i {
  background: linear-gradient(180deg, #9deaff, #3a84ff);
}
.clan-battle-scene-target-marker {
  pointer-events: none !important;
  background-image: url('../resources/ui/icons/target_marker.png');
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.45));
  animation: clanBattleTargetMarkerPulse088 1.2s ease-in-out infinite;
}
@keyframes clanBattleTargetMarkerPulse088 {
  0%, 100% { transform: scale(1); opacity: .95; }
  50% { transform: scale(1.08); opacity: 1; }
}
.clan-battle-deck-sprite.clan-battle-full-deck {
  background-color: transparent !important;
  background-repeat: no-repeat !important;
  background-position: center bottom !important;
  background-size: contain !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
  z-index: 1 !important;
  animation: clanBattleDeckSceneFloat088 8s ease-in-out infinite !important;
}
@keyframes clanBattleDeckSceneFloat088 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}
.clan-battle-full-card--empty,
.clan-battle-scene-no-targets,
.clan-battle-full-meta,
.clan-battle-full-next-shot,
.clan-battle-full-own-status,
.clan-battle-full-nav-controls,
.clan-battle-full-controls,
.clan-battle-full-log {
  z-index: 20 !important;
}


/* 0.6.89 clan battle static code sky */
.app[data-location="clan_battle"] .scene-background {
  background-image: none !important;
  background: transparent !important;
}
.clan-battle-full-stage {
  background: transparent !important;
  background-image: none !important;
}
.clan-battle-full-stage::before,
.clan-battle-full-stage::after {
  content: none !important;
  display: none !important;
}
.clan-battle-layer--sky,
.clan-battle-full-sky-bg {
  inset: 0 !important;
  background: linear-gradient(180deg, #6fa9d1 0%, #a4c7dd 100%) !important;
  background-image: linear-gradient(180deg, #6fa9d1 0%, #a4c7dd 100%) !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: 100% 100% !important;
  animation: none !important;
  transform: none !important;
  filter: none !important;
}


/* 0.6.90 clan battle deck transparency fix */
.clan-battle-layer--deck {
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
}
.clan-battle-deck-sprite.clan-battle-full-deck,
.clan-battle-full-deck.has-battle-layout,
.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  background: transparent url('../resources/sprites/clan_battle_deck_cannon.png') center bottom / contain no-repeat !important;
  background-color: transparent !important;
  background-image: url('../resources/sprites/clan_battle_deck_cannon.png') !important;
  background-repeat: no-repeat !important;
  background-position: center bottom !important;
  background-size: contain !important;
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-full-stage {
  background: linear-gradient(180deg, #6fa9d1 0%, #a4c7dd 100%) !important;
  background-image: linear-gradient(180deg, #6fa9d1 0%, #a4c7dd 100%) !important;
}
.clan-battle-full-sky-bg {
  background: linear-gradient(180deg, #6fa9d1 0%, #a4c7dd 100%) !important;
}


/* 0.6.91: палуба рисуется как отдельная картинка, как корабль, без фоновой заливки */
.clan-battle-layer--deck {
  background: transparent !important;
  background-image: none !important;
  overflow: visible !important;
  pointer-events: none !important;
}
.clan-battle-deck-image.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  display: block !important;
  object-fit: contain !important;
  object-position: center bottom !important;
  background: transparent !important;
  background-image: none !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
  z-index: 1 !important;
  animation: clanBattleDeckImageFloat091 8s ease-in-out infinite !important;
  user-select: none !important;
  -webkit-user-drag: none !important;
}
@keyframes clanBattleDeckImageFloat091 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-3px); }
}


/* 0.6.92: палуба с запасом за края экрана */
.clan-battle-layer--deck {
  inset: 0 !important;
  overflow: visible !important;
  background: transparent !important;
  pointer-events: none !important;
}
.clan-battle-deck-image.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  object-fit: contain !important;
  object-position: center bottom !important;
  max-width: none !important;
  max-height: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
  background: transparent !important;
}


/* 0.6.93: палуба увеличивается с сохранением пропорций */
.clan-battle-deck-image.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  object-fit: contain !important;
  object-position: center bottom !important;
  max-width: none !important;
  max-height: none !important;
  min-width: 0 !important;
  min-height: 0 !important;
  background: transparent !important;
  background-image: none !important;
}


/* 0.6.95: клановый бой — пользовательская раскладка, кнопки поверх спрайтов */
.app[data-location="clan_battle"] .scene-background {
  background: transparent !important;
  background-image: none !important;
}
.clan-battle-full-stage {
  background: transparent !important;
  background-image: none !important;
  isolation: isolate !important;
}
.clan-battle-layer--sky,
.clan-battle-full-sky-bg {
  z-index: 0 !important;
  pointer-events: none !important;
}
.clan-battle-layer--ships {
  z-index: 10 !important;
  pointer-events: auto !important;
}
.clan-battle-layer--ship-ui {
  z-index: 30 !important;
  pointer-events: none !important;
}
.clan-battle-layer--deck {
  z-index: 40 !important;
  pointer-events: none !important;
  background: transparent !important;
  background-image: none !important;
  overflow: visible !important;
}
.clan-battle-deck-image.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  z-index: 1 !important;
  pointer-events: none !important;
  background: transparent !important;
  background-image: none !important;
  object-fit: contain !important;
  object-position: center bottom !important;
}
.clan-battle-full-nav-controls,
.clan-battle-full-controls {
  z-index: 200 !important;
  pointer-events: none !important;
}
.clan-battle-full-control.has-battle-layout-control.ui-button,
.clan-battle-full-control--map.ui-button,
.clan-battle-full-control--chat.ui-button,
.clan-battle-full-control--log.ui-button,
.clan-battle-full-control--shoot.ui-button {
  z-index: 201 !important;
  pointer-events: auto !important;
}
.clan-battle-full-log {
  z-index: 210 !important;
}


/* 0.6.97: safe clan battle clouds, no scene render dependency */
.clan-battle-cloud-layer {
  position: absolute !important;
  inset: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-cloud-layer--far { z-index: 2 !important; }
.clan-battle-cloud-layer--near { z-index: 4 !important; }
.clan-battle-cloud-sprite {
  position: absolute !important;
  left: 0 !important;
  top: var(--cloud-y, 120px) !important;
  width: var(--cloud-w, 512px) !important;
  height: var(--cloud-h, 256px) !important;
  background-image: var(--cloud-img) !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: contain !important;
  opacity: var(--cloud-opacity, .5) !important;
  pointer-events: none !important;
  user-select: none !important;
  transform: translateX(var(--cloud-start-x, -700px)) scale(var(--cloud-scale, 1));
  animation: clanBattleCloudDrift097 var(--cloud-duration, 64s) linear infinite !important;
  animation-delay: var(--cloud-delay, 0s) !important;
  will-change: transform;
}
.clan-battle-cloud-sprite--far { filter: blur(.25px) drop-shadow(0 5px 9px rgba(55, 93, 124, .08)); }
.clan-battle-cloud-sprite--near { filter: drop-shadow(0 8px 13px rgba(55, 93, 124, .12)); }
@keyframes clanBattleCloudDrift097 {
  0% { transform: translateX(var(--cloud-start-x, -700px)) scale(var(--cloud-scale, 1)); }
  100% { transform: translateX(var(--cloud-end-x, 1540px)) scale(var(--cloud-scale, 1)); }
}
.clan-battle-layer--ships { z-index: 3 !important; }
.clan-battle-layer--ship-ui { z-index: 6 !important; }
.clan-battle-layer--deck { z-index: 8 !important; pointer-events: none !important; }
.clan-battle-full-nav-controls,
.clan-battle-full-controls { z-index: 1000 !important; pointer-events: none !important; }
.clan-battle-full-control.has-battle-layout-control.ui-button,
.clan-battle-full-control--map.ui-button,
.clan-battle-full-control--chat.ui-button,
.clan-battle-full-control--log.ui-button,
.clan-battle-full-control--shoot.ui-button { z-index: 1001 !important; pointer-events: auto !important; }
.clan-battle-full-log { z-index: 1010 !important; }


/* 0.6.98: visible sprite clouds */
.clan-battle-cloud-layer {
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
  display: block !important;
  visibility: visible !important;
}
.clan-battle-cloud-layer--far { z-index: 2 !important; }
.clan-battle-cloud-layer--near { z-index: 4 !important; }
img.clan-battle-cloud-sprite,
.clan-battle-cloud-sprite {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  max-width: none !important;
  max-height: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
}
.clan-battle-cloud-sprite--far { filter: blur(.15px) drop-shadow(0 5px 8px rgba(55,93,124,.10)); }
.clan-battle-cloud-sprite--near { filter: drop-shadow(0 8px 12px rgba(55,93,124,.14)); }
@keyframes clanBattleCloudDrift098 {
  0% { transform: translateX(var(--cloud-start-x, -700px)) scale(var(--cloud-scale, 1)); }
  100% { transform: translateX(var(--cloud-end-x, 1540px)) scale(var(--cloud-scale, 1)); }
}


/* 0.6.99: равномерный поток облаков в клановом бою */
.clan-battle-cloud-layer {
  overflow: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
}
.clan-battle-cloud-layer--far { z-index: 2 !important; }
.clan-battle-cloud-layer--near { z-index: 4 !important; }
img.clan-battle-cloud-sprite,
.clan-battle-cloud-sprite {
  display: block !important;
  visibility: visible !important;
  position: absolute !important;
  max-width: none !important;
  max-height: none !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  pointer-events: none !important;
  animation-fill-mode: both !important;
}
.clan-battle-cloud-sprite--far {
  filter: blur(.18px) drop-shadow(0 4px 7px rgba(55,93,124,.08));
}
.clan-battle-cloud-sprite--near {
  filter: drop-shadow(0 7px 11px rgba(55,93,124,.12));
}
@keyframes clanBattleCloudDrift099 {
  0% { transform: translateX(var(--cloud-start-x, -700px)) scale(var(--cloud-scale, 1)); }
  100% { transform: translateX(var(--cloud-end-x, 1700px)) scale(var(--cloud-scale, 1)); }
}


/* 0.7.00: particle-like cloud emitter, no prefilled cloud bunch */
.clan-battle-cloud-layer {
  overflow: hidden !important;
  pointer-events: none !important;
  background: transparent !important;
}
img.clan-battle-cloud-sprite {
  display: block !important;
  visibility: visible !important;
  background: transparent !important;
  border: 0 !important;
  max-width: none !important;
  max-height: none !important;
  pointer-events: none !important;
}
.clan-battle-cloud-sprite--far {
  filter: blur(.18px) drop-shadow(0 5px 8px rgba(55,93,124,.10));
}
.clan-battle-cloud-sprite--near {
  filter: drop-shadow(0 8px 12px rgba(55,93,124,.14));
}
@keyframes clanBattleCloudParticleDrift {
  0% { transform: translateX(var(--cloud-start-x, -700px)) scale(var(--cloud-scale, 1)); }
  100% { transform: translateX(var(--cloud-end-x, 1700px)) scale(var(--cloud-scale, 1)); }
}


/* 0.7.01: start cloud particles already spread across the sky */
.clan-battle-cloud-sprite.is-initial-cloud { animation-fill-mode: both !important; }


/* 0.7.02: clouds start at their own x/y positions, deck gently floats */
img.clan-battle-cloud-sprite.is-initial-cloud {
  animation-delay: 0s !important;
}
.clan-battle-deck-image.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck,
img.clan-battle-deck-sprite.clan-battle-full-deck.has-battle-layout {
  animation: clanBattleDeckGentleFloat0702 7.5s ease-in-out infinite !important;
  will-change: transform;
}
@keyframes clanBattleDeckGentleFloat0702 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-4px); }
}

/* 0.7.09 — clan battle rebuilt scene, isolated from old battle CSS */
.app[data-location="clan_battle"] .scene-background,
.app[data-location="clan_battle"] .scene-vignette {
  background: transparent !important;
  background-image: none !important;
  opacity: 0 !important;
}
.clan-battle-rebuild-shell,
.clan-battle-rebuild-stage {
  border: 0 !important;
  box-shadow: none !important;
}
.clan-battle-rebuild-stage * {
  box-sizing: border-box;
}
.cb9-meta,
.cb9-next-shot,
.cb9-own-status,
.cb9-log {
  border-radius: 12px;
  border: 1px solid rgba(72, 45, 18, .45);
  background: rgba(34, 28, 24, .58);
  color: #ffe8bc;
  box-shadow: 0 8px 22px rgba(0,0,0,.16);
  text-shadow: 0 1px 2px rgba(0,0,0,.45);
  padding: 8px 10px;
  overflow: hidden;
  pointer-events: none;
}
.cb9-meta b,
.cb9-own-status b { display: block; font-size: 16px; color: #ffe5a6; }
.cb9-meta span,
.cb9-own-status span { display: block; font-size: 12px; color: rgba(255,245,220,.88); }
.cb9-next-shot { font-size: 13px; line-height: 1.25; }
.cb9-log { pointer-events: auto; }
.cb9-log-head { display: flex; justify-content: space-between; gap: 10px; margin-bottom: 8px; }
.cb9-log-head b { color: #ffe5a6; }
.cb9-log-head span { color: rgba(255,245,220,.72); font-size: 12px; }
.cb9-ship { filter: drop-shadow(0 10px 16px rgba(0,0,0,.25)); }
.cb9-ship.is-destroyed { filter: grayscale(.75) brightness(.62) drop-shadow(0 10px 16px rgba(0,0,0,.24)); opacity: .7; }
.cb9-cloud { pointer-events: none !important; user-select: none; -webkit-user-drag: none; }
.cb9-control.ui-button { position: absolute !important; pointer-events: auto !important; z-index: 1 !important; }
.cb9-control--mapButton.ui-button,
.cb9-control--chatButton.ui-button { padding: 0 !important; }
.cb9-deck { filter: drop-shadow(0 -3px 14px rgba(0,0,0,.18)); }
@keyframes cb9DeckFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-7px); }
}
@keyframes cb9CloudDrift {
  0% { transform: translateX(-220px); }
  100% { transform: translateX(1480px); }
}


/* 0.7.10 — cloud phase is preserved between UI rerenders; buttons stay above deck */
.cb9-controls-layer { z-index: 60 !important; pointer-events: none !important; }
.cb9-controls-layer .cb9-control.ui-button { z-index: 2 !important; pointer-events: auto !important; }
.cb9-cloud { will-change: transform; }

/* 0.7.11 cloud spawn: only Y randomized, X fixed offscreen */
.cb9-cloud { left: auto; }


/* 0.7.12 inventory equipment visual pass */
.character-preview,
.location-character,
.character-preview.has-rig,
.location-character.has-rig {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.location-character__placeholder,
.character-preview__shadow {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}
.character-rig { filter: drop-shadow(0 18px 22px rgba(0,0,0,.38)); }
.character-equipment-layer,
.character-equipment-part,
.character-equipment-img {
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}
.character-equipment-img {
  display: block;
  max-width: none;
  will-change: transform;
}
.inventory-panel--dropdown {
  grid-template-columns: minmax(300px, 340px) minmax(210px, 260px) !important;
  grid-template-rows: minmax(0, 1fr) auto;
  min-height: 540px;
}
.inventory-panel--dropdown .inventory-right {
  min-width: 0;
}
.inventory-list--dropdown {
  grid-template-columns: repeat(2, 82px) !important;
  align-content: start;
  justify-content: center;
  gap: 10px !important;
  padding: 12px !important;
}
.inventory-list--dropdown .inventory-item-row,
.inventory-panel .inventory-list--dropdown .inventory-item-row.ui-button {
  width: 82px;
  height: 82px;
  min-height: 82px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6px;
  border-radius: 8px;
  text-align: center;
  position: relative;
}
.inventory-list--dropdown .inventory-item-row > div {
  display: none;
}
.inventory-list--dropdown .inventory-item-row b {
  width: 58px;
  height: 58px;
  border-radius: 7px;
  font-size: 24px;
  position: relative;
  overflow: hidden;
}
.inventory-list--dropdown .inventory-item-row b img,
.inventory-equipped-cell b img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.inventory-list--dropdown .inventory-item-row b span,
.inventory-equipped-cell b i {
  font-style: normal;
  color: rgba(255,226,150,.95);
  font-size: 24px;
  line-height: 1;
}
.inventory-list--dropdown .inventory-item-row.is-equipped::after {
  content: '';
  right: 6px;
  top: 6px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #90f08a;
  box-shadow: 0 0 8px rgba(144,240,138,.75);
}
.inventory-preview__visual--image {
  height: 132px;
  position: relative;
}
.inventory-preview__image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 12px 16px rgba(0,0,0,.38));
}
.inventory-equipped-bar {
  grid-column: 1 / -1;
  min-height: 124px;
  padding: 10px 12px 12px;
  border-radius: 7px;
  background: linear-gradient(180deg, rgba(31, 32, 40, .92), rgba(10, 12, 16, .96));
  border: 1px solid rgba(243,198,111,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 34px rgba(0,0,0,.22);
}
.inventory-equipped-bar__title {
  color: var(--gold);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 8px;
}
.inventory-equipped-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(62px, 1fr));
  gap: 7px;
}
.inventory-equipped-cell {
  min-width: 0;
  min-height: 82px;
  border-radius: 7px;
  background: rgba(8,10,14,.58);
  border: 1px solid rgba(255,255,255,.08);
  display: grid;
  grid-template-rows: 14px 44px 14px;
  gap: 3px;
  align-items: center;
  justify-items: center;
  padding: 5px;
  overflow: hidden;
}
.inventory-equipped-cell.has-item {
  border-color: rgba(243,198,111,.34);
  background: rgba(47,38,28,.62);
}
.inventory-equipped-cell span {
  color: var(--muted);
  font-size: 9px;
  line-height: 1;
  white-space: nowrap;
}
.inventory-equipped-cell b {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  background: rgba(6,8,12,.62);
  overflow: hidden;
}
.inventory-equipped-cell strong {
  display: block;
  max-width: 100%;
  overflow: hidden;
  color: rgba(255,226,150,.92);
  font-size: 9px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 900px) {
  .inventory-panel--dropdown {
    grid-template-columns: 1fr !important;
  }
  .inventory-list--dropdown {
    grid-template-columns: repeat(2, 82px) !important;
    justify-content: start;
  }
  .inventory-equipped-grid {
    grid-template-columns: repeat(4, minmax(62px, 1fr));
  }
}


/* 0.7.13 — экипировка по эталонным JSON-слотам редактора */
.character-preview,
.location-character,
#locationCharacter,
.character-slot,
.character-preview.has-rig,
.location-character.has-rig {
  background: transparent !important;
  box-shadow: none !important;
  border-color: transparent !important;
  outline: 0 !important;
}
.character-preview::before,
.character-preview::after,
.location-character::before,
.location-character::after,
#locationCharacter::before,
#locationCharacter::after {
  content: none !important;
  display: none !important;
}
.character-rig {
  filter: none !important;
}
.character-equipment-layer {
  z-index: 200;
}
.character-equipment-part {
  transform-origin: center center;
}
.character-equipment-img {
  display: block;
  max-width: none;
  user-select: none;
  -webkit-user-drag: none;
}

/* 0.7.14 — equipment JSON coordinates are applied from the same character origin as body parts */


/* 0.7.15 — equipment uses real PNG size like editor, no frameSize shrink/crop */
.character-equipment-part { overflow: visible !important; }
.character-equipment-img { max-width: none !important; object-fit: fill !important; }


/* 0.7.16 — порядок слоёв экипировки как в tools/editor */
.character-equipment-layer { z-index: auto !important; }
.character-equipment-part,
.pve-character-equipment-part { position: absolute; overflow: visible; pointer-events: none; user-select: none; -webkit-user-drag: none; }
.character-equipment-img,
.pve-character-equipment-img { display: block; max-width: none; pointer-events: none; user-select: none; -webkit-user-drag: none; }

/* 0.7.17 — нижняя экипировка: только игровые слоты */
.inventory-equipped-grid--slots {
  grid-template-columns: repeat(7, minmax(72px, 1fr)) !important;
}
.inventory-equipped-grid--slots .inventory-equipped-cell {
  grid-template-rows: 18px 52px !important;
  min-height: 82px;
}
.inventory-equipped-grid--slots .inventory-equipped-cell strong {
  display: none !important;
}
.inventory-equipped-cell.is-locked {
  border-color: rgba(255,74,74,.68) !important;
  background: linear-gradient(180deg, rgba(116,28,28,.78), rgba(40,8,8,.86)) !important;
}
.inventory-equipped-cell.is-locked span {
  color: #ffd1d1 !important;
}
.inventory-equipped-cell.is-locked b {
  color: #ffb3b3 !important;
  font-size: 32px !important;
  text-shadow: 0 0 10px rgba(255,50,50,.75);
}


/* 0.7.18 — магазин экипировки не использует маленькую сетку инвентаря 2x82 */
.shop-panel.inventory-panel--dropdown {
  grid-template-columns: 330px minmax(0, 1fr) !important;
  grid-template-rows: minmax(0, 1fr) !important;
}
.shop-panel.inventory-panel--dropdown .shop-right.inventory-right--dropdown,
.shop-panel.inventory-panel--dropdown .inventory-right.shop-right {
  min-width: 0 !important;
  width: auto !important;
}
.shop-panel .shop-list.inventory-list--dropdown,
.shop-panel .shop-list.inventory-list {
  grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)) !important;
  justify-content: stretch !important;
  align-content: start !important;
  gap: 10px !important;
  padding: 12px !important;
}
.shop-panel .shop-list.inventory-list--dropdown .inventory-item-row,
.shop-panel .shop-list .inventory-item-row,
.shop-panel .shop-list.inventory-list--dropdown .inventory-item-row.ui-button,
.shop-panel.inventory-panel .shop-list.inventory-list--dropdown .inventory-item-row.ui-button {
  width: auto !important;
  height: auto !important;
  min-height: 72px !important;
  display: grid !important;
  grid-template-columns: 48px minmax(0, 1fr) !important;
  gap: 10px !important;
  align-items: center !important;
  justify-content: initial !important;
  padding: 10px !important;
  border-radius: 5px !important;
  text-align: left !important;
}
.shop-panel .shop-list.inventory-list--dropdown .inventory-item-row > div,
.shop-panel .shop-list .inventory-item-row > div {
  display: block !important;
  min-width: 0 !important;
}
.shop-panel .shop-list.inventory-list--dropdown .inventory-item-row b,
.shop-panel .shop-list .inventory-item-row b {
  width: 48px !important;
  height: 48px !important;
  border-radius: 5px !important;
  font-size: 24px !important;
  overflow: hidden !important;
}
.shop-panel .shop-list.inventory-list--dropdown .inventory-item-row strong,
.shop-panel .shop-list .inventory-item-row strong,
.shop-panel .shop-list.inventory-list--dropdown .inventory-item-row span,
.shop-panel .shop-list .inventory-item-row span {
  display: block !important;
}


/* 0.7.19 — magic weapon attack visual, weapon-specific rig animation mapping */
.pve-magic-cast-effect {
  background-image: url('resources/effects/magic_staff_effect_000.png');
  background-repeat: no-repeat;
  background-size: 1200% 100%;
  background-position: 0% 0%;
  filter: drop-shadow(0 0 16px rgba(116, 196, 255, .88));
  mix-blend-mode: screen;
  image-rendering: auto;
}
@keyframes pveMagicCastPulse {
  from { transform: scale(.76) rotate(0deg); opacity: .62; }
  to { transform: scale(1.08) rotate(18deg); opacity: .98; }
}

/* 0.7.20 — character switch clears old equipment cache; arena visuals use frozen build */

/* 0.7.21 — main gate uses rig character slot so equipped items are visible */

/* 0.7.22 — PvE battle uses rig equipment; main_gate location has no character slot */


/* 0.7.23 — named main-gate battle zones and active debuffs */
.action-button--battle-zone,
.action-button.is-locked {
  align-items: flex-end;
  justify-content: center;
  padding: 0 22px 20px;
  border-radius: 14px;
  overflow: hidden;
  font-size: 18px;
  text-align: center;
  text-shadow: 0 2px 5px rgba(0,0,0,.95), 0 0 9px rgba(0,0,0,.7);
}
.action-button--battle-zone span,
.action-button.is-locked span {
  display: block;
  width: 100%;
  max-width: 118px;
  margin: 0 auto;
  font-size: 18px;
  line-height: .98;
  letter-spacing: -.02em;
  overflow-wrap: anywhere;
}
.action-button--battle-zone small,
.action-button.is-locked small {
  display: block;
  width: 100%;
  max-width: 116px;
  margin: 5px auto 0;
  color: rgba(255,244,210,.9);
  font-size: 10px;
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.action-button.is-locked {
  filter: grayscale(.55) brightness(.75);
  opacity: .72;
}
.action-button.is-locked::after {
  content: none;
  display: none;
}
.battle-active-debuffs {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  gap: 4px;
  margin-top: 3px;
  pointer-events: auto;
}
.battle-debuff-icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.28);
  background: rgba(20,18,22,.74);
  box-shadow: 0 2px 8px rgba(0,0,0,.35), inset 0 1px 0 rgba(255,255,255,.18);
  font-size: 13px;
  color: #fff0c8;
}
.battle-debuff-icon img {
  display: block;
  width: 18px;
  height: 18px;
  object-fit: contain;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.6));
}
.battle-debuff-icon img[hidden] { display: none; }
.battle-debuff-icon b { line-height: 1; }
.battle-debuff-icon i {
  position: absolute;
  right: -4px;
  bottom: -4px;
  min-width: 13px;
  height: 13px;
  padding: 0 2px;
  border-radius: 999px;
  background: #2a160c;
  color: #ffe2a3;
  font-size: 9px;
  font-style: normal;
  font-weight: 900;
  line-height: 13px;
}
.battle-debuff-icon--armor { background: rgba(94,72,52,.86); }
.battle-debuff-icon--bleed { background: rgba(142,20,24,.86); }
.battle-debuff-icon--poison { background: rgba(31,111,45,.86); }
.battle-debuff-icon--slow { background: rgba(62,77,132,.86); }
.battle-debuff-icon--disease { background: rgba(85,115,24,.86); }
.battle-debuff-icon--weakness { background: rgba(105,69,136,.86); }
.battle-debuff-icon--dark-curse { background: rgba(41,25,72,.88); }
.battle-debuff-icon--other { background: rgba(50,45,58,.86); }

/* 0.7.24 — battle actors lowered closer to bottom control buttons */
.pve-location-combat-ground::after { bottom: 28px !important; }
.pve-location-battle .pve-combatant-shadow { bottom: -8px !important; }

/* 0.7.31 — HUD resources/effects fixed without decorative frames. */
.resource-widget--emerald,
.resource-widget--gold {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.resource-widget--emerald .resource-widget__icon,
.resource-widget--gold .resource-widget__icon {
  background: transparent !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
#hudPotionBuffBar,
#hudWeaknessDebuffBar {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
#hudPotionBuffFallbackIcon,
#hudWeaknessDebuffFallbackIcon,
.battle-debuff-icon b[hidden],
.battle-debuff-icon b:empty {
  display: none !important;
}
.pve-location-hud { right: 120px !important; }
@media (max-width: 760px) { .pve-location-hud { right: 12px !important; } }
.pve-location-battle .pve-combatant-float { top: 2% !important; height: 132px !important; }
.pve-location-battle .arena-float { top: 40% !important; }
.pve-location-battle .arena-float--defense { top: 18% !important; }
.battle-active-debuffs { min-height: 48px !important; gap: 8px !important; margin-top: 10px !important; }
.battle-debuff-icon { width: 44px !important; min-width: 44px !important; height: 44px !important; border: 0 !important; border-radius: 0 !important; background: transparent !important; box-shadow: none !important; font-size: 0 !important; }
.battle-debuff-icon img { width: 44px !important; height: 44px !important; filter: drop-shadow(0 3px 6px rgba(0,0,0,.62)) !important; }
.battle-debuff-icon i { right: -2px !important; bottom: -2px !important; min-width: 18px !important; height: 18px !important; padding: 0 4px !important; font-size: 11px !important; line-height: 18px !important; border: 1px solid rgba(255,230,170,.35) !important; }


/* 0.7.33 — potion buffs in PvE battle effect rows. */
.battle-buff-icon--potion { background: transparent !important; }
.battle-buff-icon--potion img { filter: drop-shadow(0 3px 7px rgba(255,214,119,.52)) drop-shadow(0 0 10px rgba(255,171,64,.28)) !important; }


/* 0.7.34 — alchemy icons/prices and stable top currency digits. */
.resource-widget--emerald,
.resource-widget--gold { min-width: 132px !important; justify-content: flex-end !important; }
.resource-widget--emerald .resource-widget__value,
.resource-widget--gold .resource-widget__value { min-width: 78px !important; text-align: right !important; font-variant-numeric: tabular-nums !important; font-feature-settings: "tnum" 1 !important; }
.shop-flat-meta { min-width: 132px !important; width: max-content !important; white-space: nowrap !important; }

/* 0.7.35 — stable PNG HUD widgets for emerald and premium. */
.resource-widget--emerald,
.resource-widget--premium {
  min-width: 148px !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  contain: layout paint !important;
}
.resource-widget--premium { min-width: 172px !important; }
.resource-widget--emerald .resource-widget__image,
.resource-widget--premium .resource-widget__image,
.resource-widget--emerald .resource-widget__icon,
.resource-widget--premium .resource-widget__icon {
  width: 38px !important;
  min-width: 38px !important;
  height: 38px !important;
  flex: 0 0 38px !important;
  line-height: 38px !important;
}
.resource-widget--emerald .resource-widget__image[hidden],
.resource-widget--premium .resource-widget__image[hidden] {
  display: block !important;
  visibility: hidden !important;
}
.resource-widget--emerald .resource-widget__value,
.resource-widget--premium .resource-widget__value {
  min-width: 86px !important;
  text-align: right !important;
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
}
.resource-widget--premium .resource-widget__value {
  min-width: 112px !important;
  font-size: 18px !important;
}



/* 0.7.36 — HUD currency alignment and PNG-only icons. */
.resource-widget--emerald,
.resource-widget--gold,
.resource-widget--premium {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  overflow: visible !important;
}
.resource-widget--emerald,
.resource-widget--gold {
  min-width: 150px !important;
}
.resource-widget--premium {
  min-width: 300px !important;
  padding: 0 10px !important;
}
.resource-widget--emerald .resource-widget__fallback-icon,
.resource-widget--gold .resource-widget__fallback-icon,
.resource-widget--premium .resource-widget__fallback-icon {
  display: none !important;
}
.resource-widget--emerald .resource-widget__image,
.resource-widget--gold .resource-widget__image,
.resource-widget--premium .resource-widget__image {
  display: block !important;
  width: 38px !important;
  min-width: 38px !important;
  height: 38px !important;
  flex: 0 0 38px !important;
  object-fit: contain !important;
}
.resource-widget--emerald .resource-widget__image[hidden],
.resource-widget--gold .resource-widget__image[hidden],
.resource-widget--premium .resource-widget__image[hidden] {
  display: block !important;
  visibility: hidden !important;
}
.resource-widget--gold .resource-widget__value {
  min-width: 86px !important;
  text-align: right !important;
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
}
.resource-widget--premium .resource-widget__value {
  min-width: 220px !important;
  max-width: 220px !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}


/* 0.7.37 — HUD premium shifted left and bottom title centered. */
.location-title {
  justify-content: center !important;
  text-align: center !important;
}
.location-title:not(.has-layout-image) {
  width: auto;
}
.location-title.has-layout-image {
  justify-content: center !important;
  text-align: center !important;
}
.resource-widget--premium {
  justify-content: flex-start !important;
  min-width: 330px !important;
  padding: 0 8px !important;
}
.resource-widget--premium .resource-widget__value {
  min-width: 250px !important;
  max-width: 250px !important;
  text-align: left !important;
}

/* 0.7.12: компактная нижняя панель талантов/параметров и прокачка характеристик сверху */
.panel-overlay[data-panel="talents"] .build-footer--sticky,
.panel-overlay[data-panel="parameters"] .build-footer--sticky {
  justify-content: center !important;
  align-items: center !important;
  width: max-content !important;
  max-width: calc(100% - 48px) !important;
  margin: 8px auto 0 !important;
  padding: 10px 12px calc(10px + max(0px, var(--safe-bottom))) !important;
  border: 1px solid rgba(243,198,111,.20) !important;
  border-radius: 12px !important;
  background: rgba(10, 12, 16, .88) !important;
  box-shadow: 0 -8px 22px rgba(0,0,0,.22) !important;
}
.panel-overlay[data-panel="talents"] .build-apply-summary,
.panel-overlay[data-panel="parameters"] .build-apply-summary {
  display: none !important;
}
.panel-overlay[data-panel="talents"] .build-footer__buttons,
.panel-overlay[data-panel="parameters"] .build-footer__buttons {
  flex-wrap: nowrap !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 10px !important;
}
.panel-overlay[data-panel="talents"] .build-footer__buttons .ui-button,
.panel-overlay[data-panel="parameters"] .build-footer__buttons .ui-button {
  flex: 0 0 auto !important;
  white-space: nowrap !important;
}
.panel-overlay[data-panel="parameters"] .build-list--params-primary {
  order: -1;
}
@media (max-width: 900px) {
  .panel-overlay[data-panel="talents"] .build-footer--sticky,
  .panel-overlay[data-panel="parameters"] .build-footer--sticky {
    max-width: calc(100% - 24px) !important;
  }
  .panel-overlay[data-panel="talents"] .build-reset-button,
  .panel-overlay[data-panel="parameters"] .build-reset-button {
    min-width: 0 !important;
  }
}


/* 0.7.25 — inventory full-width list, real item icons and material wallet */
.inventory-panel--dropdown {
  grid-template-columns: minmax(300px, 340px) minmax(360px, 1fr) !important;
}
.inventory-panel--dropdown .inventory-right,
.inventory-right--dropdown {
  min-width: 0;
  width: 100%;
}
.inventory-list--dropdown {
  grid-template-columns: repeat(auto-fill, minmax(82px, 82px)) !important;
  justify-content: start !important;
  width: 100%;
}
.inventory-list--dropdown .inventory-item-row b span,
.inventory-equipped-cell b i,
.inventory-preview__visual span {
  display: none !important;
}
.inventory-list--dropdown .inventory-item-row b img,
.shop-list .inventory-item-row b img,
.inventory-equipped-cell b img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.inventory-bottom-row {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(210px, 260px);
  gap: 10px;
  align-items: stretch;
}
.inventory-bottom-row .inventory-equipped-bar {
  grid-column: auto;
}
.inventory-materials-bar {
  min-height: 124px;
  padding: 10px 12px 12px;
  border-radius: 7px;
  background: linear-gradient(180deg, rgba(31, 32, 40, .92), rgba(10, 12, 16, .96));
  border: 1px solid rgba(243,198,111,.18);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08), 0 16px 34px rgba(0,0,0,.22);
}
.inventory-materials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 7px;
}
.inventory-material-cell {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 46px;
  padding: 5px 7px;
  border-radius: 7px;
  background: rgba(8,10,14,.58);
  border: 1px solid rgba(255,255,255,.08);
}
.inventory-material-cell img {
  width: 36px;
  height: 36px;
  object-fit: contain;
  display: block;
}
.inventory-material-cell span {
  display: block;
  color: var(--muted);
  font-size: 10px;
  line-height: 1;
}
.inventory-material-cell strong {
  display: block;
  margin-top: 4px;
  color: var(--gold);
  font-size: 17px;
  font-weight: 900;
}
@media (max-width: 900px) {
  .inventory-bottom-row {
    grid-template-columns: 1fr;
  }
  .inventory-materials-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* 0.7.16: выбор персонажа через отдельную кнопку и полное превью без верхней обрезки */
.account-characters-list {
  bottom: 76px !important;
}
.account-character-select-button {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 14px;
  width: auto;
  height: 48px;
  min-height: 48px;
  border-radius: 6px;
  font-size: 18px;
  font-weight: 900;
}
.account-character-select-button.is-disabled,
.account-character-select-button:disabled {
  opacity: .48;
  cursor: default;
  filter: grayscale(.45);
}
.screen--create .character-preview {
  overflow: visible !important;
  clip-path: none !important;
  contain: none !important;
}
.screen--create .character-preview.has-rig,
.screen--create .character-preview.has-sprite {
  overflow: visible !important;
}
.screen--create .character-preview .character-rig {
  transform-origin: center bottom !important;
}
.screen--create .character-sprite--create {
  height: 104% !important;
  top: 54% !important;
}

/* Скрыто только визуально: логика battleWindow продолжает работать в JS. */
.clan-battle-window-line--hidden {
  display: none !important;
}

/* Полностью скрываем только визуальную строку окна боёв, логика JS не затронута. */
.clan-shipyard-timer--end,
.clan-battle-window-line--hidden {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}


/* Cemetery visual layout patch: centered rectangular clearance card, crypt button on the right */
.cemetery-location-shell {
  position: relative;
  display: grid;
  grid-template-columns: 1fr minmax(280px, 620px) 1fr;
  gap: 16px;
  width: min(980px, calc(100% - 28px));
  margin: 18px auto 0;
  align-items: center;
}
.cemetery-status-card {
  grid-column: 2 / 3;
  width: 100%;
  min-height: 260px;
  border-radius: 4px;
  padding: 18px;
}
.cemetery-actions-card {
  grid-column: 3 / 4;
  grid-row: 1 / 2;
  align-self: center;
  justify-self: start;
  width: min(180px, 100%);
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
}
.cemetery-main-controls {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 18px;
}
.cemetery-main-controls .ui-button,
.cemetery-heal-toggle-button {
  width: 100%;
  min-height: 44px;
  margin: 0;
  font-weight: 900;
  white-space: normal;
}
.cemetery-main-controls .cemetery-start-button {
  min-height: 50px;
  font-size: 17px;
}
.cemetery-crypt-button {
  width: 100%;
  min-height: 54px;
}
.cemetery-heal-list--inventory {
  margin-top: 14px;
}
.cemetery-heal-card,
.cemetery-note,
.cemetery-heal-intro,
.cemetery-heal-card h4,
.cemetery-heal-card h3 {
  display: none !important;
}
@media (max-width: 760px) {
  .cemetery-location-shell {
    grid-template-columns: 1fr;
    width: calc(100% - 20px);
  }
  .cemetery-status-card,
  .cemetery-actions-card {
    grid-column: 1 / 2;
  }
  .cemetery-actions-card {
    justify-self: stretch;
    width: 100%;
  }
  .cemetery-main-controls {
    grid-template-columns: 1fr;
  }
}

/* Cemetery top-panel overlap fix: move clearance section below currency bar */
.cemetery-location-shell {
  margin-top: 76px !important;
}
@media (max-width: 760px) {
  .cemetery-location-shell {
    margin-top: 82px !important;
  }
}

/* 0.7.35: Crypt layout fix - keep rank/action buttons inside the crypt frame and enlarge text */
.crypt-location-shell {
  margin-top: 78px;
  gap: 14px;
  font-size: 17px;
}
.crypt-location-shell .ui-button {
  position: static;
  left: auto;
  top: auto;
  right: auto;
  bottom: auto;
  transform: none;
}
.crypt-status-card {
  display: grid;
  gap: 12px;
}
.crypt-status-title {
  flex-direction: column;
  gap: 5px;
  font-size: 22px;
}
.crypt-status-title span,
.crypt-meta-line,
.crypt-note {
  font-size: 16px;
  line-height: 1.35;
}
.crypt-rank-buttons {
  display: grid;
  grid-template-columns: repeat(8, minmax(42px, 1fr));
  gap: 8px;
  width: 100%;
  margin-top: 4px;
}
.crypt-rank-button {
  width: 100%;
  min-height: 42px;
  padding: 6px 8px;
  font-size: 18px;
}
.crypt-party-line {
  margin-top: 0;
}
.crypt-member-card {
  min-height: 134px;
  gap: 6px;
  padding: 12px;
}
.crypt-member-card b { font-size: 19px; }
.crypt-member-card span,
.crypt-member-card em { font-size: 15px; line-height: 1.25; }
.crypt-actions-card {
  justify-content: center;
  gap: 10px;
}
.crypt-fight-button,
.crypt-refresh-button,
.crypt-heal-close {
  min-height: 44px;
  font-size: 18px;
}
.crypt-heal-picker h4,
.crypt-battle-result h4 {
  font-size: 19px;
}
.crypt-heal-button--icon {
  width: 112px;
  min-width: 112px;
  min-height: 122px;
  font-size: 15px;
}
.crypt-heal-button--icon img {
  width: 50px;
  height: 50px;
}
.crypt-heal-button small,
.crypt-heal-button--icon small {
  font-size: 13px;
  max-width: 98px;
}
.crypt-heal-count {
  font-size: 13px;
}
.crypt-battle-log-row {
  font-size: 15px;
  line-height: 1.3;
}
@media (max-width: 680px) {
  .crypt-rank-buttons { grid-template-columns: repeat(4, minmax(46px, 1fr)); }
}

/* Crypt visual battle replay */
.crypt-battle-scene {
  position: relative;
  overflow: hidden;
  padding: 10px;
}
.crypt-battle-stage {
  position: relative;
  min-height: 360px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: radial-gradient(circle at 50% 30%, rgba(110,80,150,.25), rgba(12,10,18,.96) 62%);
}
.crypt-battle-bg {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(28,20,42,.92), rgba(8,7,12,.96));
  opacity: .95;
}
.crypt-battle-party {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 10px;
}
.crypt-battle-hero {
  position: relative;
  min-height: 82px;
  padding: 8px;
  border-radius: 14px;
  background: rgba(0,0,0,.44);
  border: 1px solid rgba(255,255,255,.13);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}
.crypt-battle-hero b,
.crypt-battle-boss strong {
  display: block;
  font-size: 13px;
  line-height: 1.15;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,.9);
}
.crypt-battle-field {
  position: relative;
  z-index: 2;
  min-height: 210px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 8px 16px 52px;
}
.crypt-battle-boss {
  position: relative;
  width: min(250px, 68%);
  padding: 10px;
  border-radius: 18px;
  text-align: center;
  background: rgba(0,0,0,.34);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .18s ease, filter .18s ease, box-shadow .18s ease;
}
.crypt-boss-body {
  height: 118px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 72px;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,.85));
}
.crypt-battle-hp {
  margin-top: 6px;
}
.crypt-battle-hp i {
  display: block;
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(0,0,0,.25);
}
.crypt-battle-hp u {
  display: block;
  height: 100%;
  width: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #7ee071, #f0c85d);
  transition: width .28s ease;
}
.crypt-battle-hp span {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  color: rgba(255,255,255,.78);
}
.crypt-battle-effects {
  display: flex;
  gap: 4px;
  margin-top: 5px;
}
.crypt-battle-effects span {
  flex: 1;
  min-height: 17px;
  border-radius: 8px;
  font-size: 9px;
  line-height: 17px;
  text-align: center;
  color: rgba(255,255,255,.48);
  background: rgba(255,255,255,.07);
}
.crypt-battle-action {
  position: absolute;
  z-index: 3;
  left: 10px;
  right: 10px;
  bottom: 10px;
  min-height: 34px;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(0,0,0,.56);
  color: rgba(255,255,255,.9);
  text-align: center;
  font-size: 13px;
}
.crypt-battle-float {
  position: absolute;
  left: 50%;
  top: 30%;
  z-index: 10;
  transform: translateX(-50%);
  pointer-events: none;
  font-weight: 900;
  color: #ffdf7e;
  text-shadow: 0 2px 7px rgba(0,0,0,.9);
  animation: cryptBattleFloat .85s ease-out forwards;
}
.crypt-battle-float.is-good {
  color: #8cff9d;
}
.crypt-battle-hero.is-attacking {
  transform: translateY(10px) scale(1.03);
  box-shadow: 0 0 22px rgba(255,222,126,.32);
}
.crypt-battle-boss.is-attacking {
  transform: translateY(-8px) scale(1.04);
  filter: brightness(1.2);
}
.crypt-battle-hero.is-targeted,
.crypt-battle-boss.is-targeted {
  box-shadow: 0 0 0 2px rgba(255,90,90,.7), 0 0 26px rgba(255,80,80,.25);
}
.crypt-battle-hero.is-dead,
.crypt-battle-hp.is-dead {
  opacity: .55;
  filter: grayscale(.85);
}
.crypt-battle-final {
  margin-top: 10px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.12);
}
@keyframes cryptBattleFloat {
  0% { opacity: 0; transform: translate(-50%, 10px) scale(.9); }
  20% { opacity: 1; }
  100% { opacity: 0; transform: translate(-50%, -44px) scale(1.18); }
}


/* 0.7.48: preview флага при создании и изменении клана */
.clan-flag-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  margin: 8px 0 10px;
  border: 1px solid rgba(222, 188, 118, .22);
  border-radius: 12px;
  background: rgba(12, 10, 8, .38);
}
.clan-flag-preview__title {
  min-width: 130px;
  color: #e8d3a0;
  font-size: 13px;
  line-height: 1.25;
}
.clan-flag-preview__flag {
  width: 74px;
  height: 74px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.clan-flag-preview__flag .clan-flag-mini {
  width: 64px;
  height: 64px;
}
@media (max-width: 760px) {
  .clan-flag-preview { align-items: flex-start; flex-direction: column; }
  .clan-flag-preview__title { min-width: 0; }
}


/* 0.7.49: предпросмотр флага редактируется как черновик; слой тиснения не перекрывает цвет и поля ввода */
.clan-flag-form-grid {
  position: relative;
  z-index: 3;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 64px 64px;
}
.clan-color-input,
.clan-flag-form-grid input[type="color"] {
  width: 64px;
  min-width: 64px;
  height: 44px;
  min-height: 44px;
  cursor: pointer;
  pointer-events: auto;
  position: relative;
  z-index: 4;
}
.clan-flag-preview {
  position: relative;
  z-index: 1;
  pointer-events: none;
}
.clan-flag-preview__flag,
.clan-flag-preview__flag .clan-flag-mini,
.clan-flag-preview__flag .clan-flag-emblem {
  pointer-events: none;
}
.clan-flag-mini.has-tint-image {
  background-color: var(--clan-flag-color) !important;
  background-image: var(--clan-image-url) !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: contain !important;
  background-blend-mode: normal !important;
}
.clan-flag-mini.has-tint-image::after {
  content: '' !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 1 !important;
  background-image: var(--clan-flag-emboss-url) !important;
  background-repeat: no-repeat !important;
  background-position: center center !important;
  background-size: contain !important;
  opacity: .62 !important;
  mix-blend-mode: overlay !important;
  pointer-events: none !important;
}
.clan-flag-mini.has-tint-image .clan-flag-emblem {
  z-index: 2;
}
@media (max-width: 760px) {
  .clan-flag-form-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
  .clan-color-input,
  .clan-flag-form-grid input[type="color"] {
    width: 100%;
    min-width: 0;
  }
}

/* 0.7.49 — Crypt lesser lich casts from idle sprite with magic effect overlay */
.pve-combatant-sprite--full.is-magic-caster {
  overflow: visible;
}
.pve-full-magic-cast-effect {
  position: absolute;
  left: 50%;
  top: 16%;
  width: 192px;
  height: 192px;
  transform: translate(-50%, -50%) scale(1.1);
  z-index: 9;
  pointer-events: none;
  opacity: 0;
  background-repeat: no-repeat;
  background-size: 1200% 100%;
  background-position: 0% 0%;
  filter: drop-shadow(0 0 18px rgba(116,196,255,.9));
  mix-blend-mode: screen;
}
.pve-combatant-sprite--full.is-magic-casting .pve-full-magic-cast-effect {
  opacity: 1;
  animation: pveFullMagicCastSheet .52s steps(12) 1, pveFullMagicCastPulse .52s ease-out 1;
}
@keyframes pveFullMagicCastSheet {
  from { background-position: 0% 0%; }
  to { background-position: 100% 0%; }
}
@keyframes pveFullMagicCastPulse {
  from { transform: translate(-50%, -50%) scale(.72); opacity: .35; }
  45% { opacity: 1; }
  to { transform: translate(-50%, -50%) scale(1.28); opacity: .04; }
}


/* 0.7.53 — alchemist shop price block: do not inherit quest-progress 8px bar styles. */
.shop-flat-meta.shop-price-meta,
.shop-alchemy-flat-panel .shop-flat-meta.shop-price-meta {
  height: auto !important;
  min-height: 42px !important;
  overflow: visible !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-end !important;
  justify-content: center !important;
  gap: 2px !important;
  padding: 6px 12px !important;
  border-radius: 5px !important;
  background: rgba(0, 0, 0, 0.24) !important;
  border: 1px solid rgba(255, 230, 170, 0.14) !important;
  line-height: 1.15 !important;
}
.shop-flat-meta.shop-price-meta span,
.shop-alchemy-flat-panel .shop-flat-meta.shop-price-meta span {
  display: block !important;
  font-size: 11px !important;
  line-height: 1.1 !important;
  color: rgba(246, 237, 215, 0.68) !important;
}
.shop-flat-meta.shop-price-meta strong,
.shop-alchemy-flat-panel .shop-flat-meta.shop-price-meta strong {
  display: block !important;
  min-width: 92px !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  color: var(--gold) !important;
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
  font-feature-settings: "tnum" 1 !important;
}

/* Vote shop — products for VK votes. */
.vote-shop-panel {
  gap: 10px;
}

.vote-shop-header span {
  max-width: 640px;
}

.vote-shop-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.vote-shop-row {
  width: 100%;
  min-height: 72px;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border: 1px solid rgba(82, 53, 20, .38);
  border-radius: 14px;
  background: rgba(255, 244, 212, .78);
  color: #34220d;
  text-align: left;
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.42), 0 2px 7px rgba(44, 26, 6, .12);
}

.vote-shop-row.is-selected,
.vote-shop-row:hover {
  background: rgba(255, 234, 166, .92);
  border-color: rgba(132, 82, 20, .7);
}

.vote-shop-row__icon,
.vote-shop-selected__icon {
  width: 46px;
  height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: rgba(69, 42, 13, .12);
  overflow: hidden;
  font-size: 26px;
}

.vote-shop-row__icon img,
.vote-shop-selected__icon img {
  max-width: 82%;
  max-height: 82%;
  object-fit: contain;
  image-rendering: auto;
}

.vote-shop-row__info {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.vote-shop-row__info strong {
  font-size: 15px;
  line-height: 1.12;
}

.vote-shop-row__info span {
  font-size: 12px;
  color: #3f7f2a;
  font-weight: 800;
}

.vote-shop-row__price {
  min-width: 78px;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
  white-space: nowrap;
}

.vote-shop-row__price span {
  font-size: 10px;
  opacity: .72;
  font-weight: 800;
  text-transform: uppercase;
}

.vote-shop-row__price strong {
  font-size: 13px;
}

.vote-shop-selected {
  grid-template-columns: 58px minmax(0, 1fr) auto;
}

.vote-shop-buy {
  min-width: 142px;
}

@media (max-width: 760px) {
  .vote-shop-list {
    grid-template-columns: 1fr;
  }
  .vote-shop-selected {
    grid-template-columns: 54px minmax(0, 1fr);
  }
  .vote-shop-buy {
    grid-column: 1 / -1;
    width: 100%;
  }
}

/* Chat panel */
.chat-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: min(840px, 100%);
  margin: 0 auto;
}

.chat-header {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: flex-start;
  padding: 12px 14px;
  border: 1px solid rgba(243, 198, 111, .18);
  border-radius: 16px;
  background: rgba(15, 12, 9, .56);
}

.chat-header strong {
  display: block;
  color: #ffe2a3;
  font-size: 16px;
}

.chat-header span {
  display: block;
  margin-top: 4px;
  color: rgba(244, 239, 225, .74);
  font-size: 13px;
}

.chat-list {
  min-height: 260px;
  max-height: min(52vh, 460px);
  overflow-y: auto;
  padding: 10px;
  border: 1px solid rgba(243, 198, 111, .16);
  border-radius: 16px;
  background: rgba(4, 4, 5, .42);
}

.chat-line {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255, 255, 255, .06);
  color: #f4efe1;
}

.chat-line:last-child { border-bottom: 0; }

.chat-line--global { color: #f4efe1; }
.chat-line--party { color: #6bb7ff; }
.chat-line--clan { color: #71e388; }
.chat-line--system {
  color: #ffd45a;
  background: rgba(255, 212, 90, .08);
  border-left: 3px solid rgba(255, 212, 90, .65);
  padding-left: 9px;
}

.chat-line__head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 3px;
  font-size: 12px;
  opacity: .92;
}

.chat-line__badge {
  min-width: 54px;
  padding: 2px 6px;
  border-radius: 999px;
  text-align: center;
  background: rgba(255, 255, 255, .08);
  color: currentColor;
}

.chat-line__head strong {
  color: currentColor;
  font-weight: 700;
}

.chat-line__head em {
  margin-left: auto;
  color: rgba(244, 239, 225, .45);
  font-style: normal;
}

.chat-line__body {
  color: currentColor;
  font-size: 14px;
  line-height: 1.35;
  word-break: break-word;
}

.chat-form {
  display: grid;
  grid-template-columns: 128px 1fr auto;
  gap: 8px;
  align-items: center;
}

.chat-channel-select,
.chat-input {
  height: 42px;
  border: 1px solid rgba(243, 198, 111, .24);
  border-radius: 12px;
  background: rgba(12, 9, 7, .74);
  color: #f4efe1;
  padding: 0 12px;
  outline: none;
}

.chat-input:focus,
.chat-channel-select:focus {
  border-color: rgba(243, 198, 111, .56);
}

.chat-send-button {
  min-height: 42px;
  padding-left: 18px;
  padding-right: 18px;
}

@media (max-width: 720px) {
  .chat-header,
  .chat-form { grid-template-columns: 1fr; }
  .chat-header { flex-direction: column; }
  .chat-send-button { width: 100%; }
}

/* Chat UI fix: global .ui-button is absolute in this engine, so chat controls must be normal flow */
.chat-panel .ui-button,
.chat-panel button,
.chat-panel select,
.chat-panel input {
  position: static;
  box-sizing: border-box;
}

.chat-form {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr) 132px;
  gap: 10px;
  align-items: stretch;
  width: 100%;
  padding: 0 2px 2px;
}

.chat-channel-select,
.chat-input,
.chat-send-button.ui-button {
  width: 100%;
  height: 44px;
  min-height: 44px;
}

.chat-send-button.ui-button {
  white-space: nowrap;
  padding-left: 12px;
  padding-right: 12px;
}

@media (max-width: 720px) {
  .chat-form {
    grid-template-columns: 1fr;
  }
}


/* 0.7.41 — казначей гильдии как спрайт-кнопка */
.action-button--npc,
.action-button--premium_merchant {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  overflow: visible;
  color: #ffe7ad;
  text-shadow: none;
}
.action-button--npc:hover { filter: brightness(1.08); }
.action-button--npc span {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.npc-merchant-figure,
.premium-shop-hero__npc i {
  position: absolute;
  left: 50%;
  bottom: 0;
  display: block;
  width: 512px;
  height: 512px;
  transform: translateX(-50%) scale(var(--premium-merchant-scale, .28));
  transform-origin: center bottom;
  border-radius: 0;
  background-image: url("../resources/sprites/premium_merchant_12x512.png");
  background-repeat: no-repeat;
  background-size: 6144px 512px;
  background-position: 0 0;
  box-shadow: none;
  animation: premiumMerchantSprite 1.2s steps(12) infinite;
  pointer-events: none;
}
.npc-merchant-figure::before,
.npc-merchant-figure::after,
.premium-shop-hero__npc i::before,
.premium-shop-hero__npc i::after {
  display: none;
  content: none;
}
.action-button--premium_merchant .npc-merchant-figure {
  bottom: -8px;
  filter: drop-shadow(0 18px 14px rgba(0,0,0,.44));
}
@keyframes premiumMerchantSprite {
  from { background-position: 0 0; }
  to { background-position: -6144px 0; }
}
.premium-shop-panel {
  display: flex;
  flex-direction: column;
  gap: 14px;
  color: #ffe7bd;
}
.premium-shop-status {
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(14, 18, 29, .72);
  border: 1px solid rgba(255, 219, 135, .22);
  font-weight: 800;
}
.premium-shop-status.is-error { color: #ffb4a8; border-color: rgba(255, 120, 98, .55); }
.premium-shop-hero {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 14px;
  align-items: center;
  min-height: 126px;
  padding: 12px 14px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(39, 34, 55, .82), rgba(18, 21, 33, .82));
  border: 1px solid rgba(255, 219, 135, .28);
}
.premium-shop-hero__npc { position: relative; height: 112px; overflow: visible; }
.premium-shop-hero__npc i { bottom: -6px; transform: translateX(-50%) scale(.20); transform-origin: center bottom; }
.premium-shop-hero strong { display: block; font-size: 22px; color: #fff0bc; }
.premium-shop-hero span { display: block; margin-top: 4px; color: rgba(255,239,203,.82); }
.premium-shop-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.premium-shop-box {
  padding: 14px;
  border-radius: 16px;
  background: rgba(10, 13, 22, .7);
  border: 1px solid rgba(255, 219, 135, .22);
}
.premium-shop-box h3 { margin: 0 0 6px; font-size: 20px; color: #fff0bc; }
.premium-shop-box p { margin: 0 0 12px; color: rgba(255,239,203,.78); }
.premium-shop-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.premium-shop-row strong,
.premium-shop-row span,
.premium-shop-row em { display: block; }
.premium-shop-row span { color: rgba(255,239,203,.76); font-size: 13px; }
.premium-shop-row em { color: #8ff0ff; font-style: normal; font-size: 13px; font-weight: 800; }
.premium-shop-buy-button { min-width: 118px; height: 42px; font-size: 14px; }

/* Premium shop: buttons are normal flow elements inside the scrollable exchange panel. */
.premium-shop-panel .ui-button,
.premium-shop-panel button,
.premium-shop-buy-button {
  position: static;
}

@media (max-width: 820px) {
  .premium-shop-grid { grid-template-columns: 1fr; }
}

/* 0.7.62 — main gate zone cards: layout stays from ui_layout, only text is overlay on hover. */
.action-button--battle-zone {
  position: absolute;
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  overflow: hidden;
}
.action-button--battle-zone span {
  position: absolute;
  left: 50%;
  top: 50%;
  right: auto;
  bottom: auto;
  transform: translate(-50%, -50%);
  display: block;
  width: auto;
  max-width: calc(100% - 24px);
  margin: 0;
  font-size: 42px;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  pointer-events: none;
}
.action-button--battle-zone small {
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 12px;
  display: block;
  width: auto;
  max-width: none;
  margin: 0;
  color: #ffe7a4;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.08;
  text-align: center;
  white-space: normal;
  overflow-wrap: break-word;
  opacity: 0;
  transform: translateY(5px);
  transition: opacity .14s ease, transform .14s ease;
  text-shadow: 0 2px 5px rgba(0,0,0,.95), 0 0 9px rgba(0,0,0,.85);
  pointer-events: none;
}
.action-button--battle-zone:hover small,
.action-button--battle-zone:focus-visible small {
  opacity: 1;
  transform: translateY(0);
}
.action-button--battle-zone.is-locked::after {
  content: none;
  display: none;
}
.action-button--battle-zone.is-locked span {
  font-size: 22px;
  opacity: .9;
}
.action-button--battle-zone.is-locked small {
  font-size: 13px;
}


/* 0.7.64: награда за последнего босса Главных ворот */
.pve-final-reward-card {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 430px;
  max-width: calc(100% - 32px);
  transform: translate(-50%, -50%);
  z-index: 31;
  padding: 18px 20px 20px;
  border-radius: 8px;
  border: 1px solid rgba(255,230,170,.34);
  background: rgba(8, 9, 14, .82);
  box-shadow: 0 26px 80px rgba(0,0,0,.55), inset 0 1px 0 rgba(255,255,255,.08);
  color: #fff4cf;
  text-align: center;
  pointer-events: none;
}
.pve-final-reward-title {
  font-size: 28px;
  line-height: 1.05;
  font-weight: 900;
  color: #ffe2a3;
  text-shadow: 0 2px 6px rgba(0,0,0,.82);
}
.pve-final-reward-subtitle {
  margin-top: 5px;
  margin-bottom: 12px;
  font-size: 14px;
  font-weight: 800;
  color: rgba(255,242,217,.78);
}
.pve-final-reward-item {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 10px auto 12px;
  padding: 10px 12px;
  border-radius: 7px;
  border: 1px solid rgba(255,230,170,.24);
  background: rgba(255,230,170,.08);
  text-align: left;
}
.pve-final-reward-item img,
.pve-final-reward-item__empty {
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  object-fit: contain;
  border-radius: 6px;
  background: rgba(0,0,0,.30);
}
.pve-final-reward-item__empty {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 900;
}
.pve-final-reward-item b {
  display: block;
  font-size: 16px;
  line-height: 1.15;
  color: #fff4cf;
}
.pve-final-reward-item span,
.pve-final-reward-pending {
  display: block;
  margin-top: 4px;
  font-size: 13px;
  font-weight: 800;
  color: rgba(255,242,217,.72);
}
.pve-final-reward-pending {
  margin: 10px auto 12px;
}
.pve-final-reward-list {
  display: grid;
  gap: 6px;
}
.pve-final-reward-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 7px 10px;
  border-radius: 5px;
  background: rgba(0,0,0,.22);
  font-size: 15px;
  font-weight: 900;
}
.pve-final-reward-row span { color: #ffe2a3; }


/* 0.7.66: статистика клана крупнее и ниже, под отсчетом клановых боев */
.clan-shipyard-battle-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 8px 18px;
  margin-top: 0;
  min-width: 430px;
  padding: 10px 18px;
  border-radius: 12px;
  background: rgba(18, 24, 34, .70);
  border: 1px solid rgba(239, 206, 142, .30);
  color: #f7dfb5;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.18;
  text-shadow: 0 2px 3px rgba(0,0,0,.68);
  box-shadow: 0 12px 30px rgba(0,0,0,.28);
}
.clan-shipyard-battle-stats span {
  white-space: nowrap;
}
.clan-shipyard-battle-stats b {
  color: #fff1c8;
  font-weight: 1000;
  font-size: 19px;
}

/* 0.7.68: локальное обучение */
.loa-tutorial {
  position: fixed;
  inset: 0;
  z-index: 99990;
  display: none;
  pointer-events: none;
  font-family: inherit;
}
.loa-tutorial.is-active {
  display: block;
  pointer-events: auto;
}
.loa-tutorial__shade {
  position: absolute;
  inset: 0;
  background: rgba(4, 8, 14, .58);
  backdrop-filter: blur(1px);
}
.loa-tutorial__highlight {
  position: fixed;
  z-index: 99991;
  box-sizing: border-box;
  border: 3px solid rgba(255, 222, 126, .98);
  border-radius: 18px;
  box-shadow: 0 0 0 9999px rgba(4, 8, 14, .34), 0 0 28px rgba(255, 204, 86, .8), inset 0 0 16px rgba(255, 233, 166, .35);
  pointer-events: none;
  transition: left .16s ease, top .16s ease, width .16s ease, height .16s ease;
}
.loa-tutorial__card {
  position: fixed;
  z-index: 99992;
  width: 380px;
  max-width: calc(100vw - 20px);
  box-sizing: border-box;
  padding: 16px 17px 15px;
  border: 2px solid rgba(255, 222, 150, .88);
  border-radius: 18px;
  color: #fff2c8;
  background: linear-gradient(180deg, rgba(42, 25, 13, .96), rgba(18, 13, 10, .97));
  box-shadow: 0 16px 40px rgba(0,0,0,.58), inset 0 0 22px rgba(255, 195, 85, .09);
  text-shadow: 0 2px 4px rgba(0,0,0,.72);
}
.loa-tutorial__counter {
  margin-bottom: 6px;
  color: rgba(255, 226, 170, .78);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.loa-tutorial__title {
  margin-bottom: 8px;
  color: #ffe39a;
  font-size: 23px;
  line-height: 1.08;
  font-weight: 900;
}
.loa-tutorial__text {
  color: rgba(255, 244, 218, .94);
  font-size: 16px;
  line-height: 1.36;
  font-weight: 700;
}
.loa-tutorial__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 14px;
}
.loa-tutorial__button {
  position: static;
  min-width: 86px;
  height: 40px;
  padding: 0 14px;
  font-size: 14px;
  line-height: 1;
}
.loa-tutorial__button--skip {
  margin-right: auto;
  opacity: .86;
}
.loa-tutorial__button--next {
  min-width: 102px;
}
.loa-tutorial__button:disabled {
  opacity: .45;
  cursor: default;
}
@media (max-width: 760px) {
  .loa-tutorial__card {
    width: 340px;
    padding: 14px 14px 13px;
  }
  .loa-tutorial__title { font-size: 20px; }
  .loa-tutorial__text { font-size: 14px; }
  .loa-tutorial__button { min-width: 74px; height: 36px; padding: 0 10px; font-size: 12px; }
}

/* 0.7.69: отображение премиум-бонуса в награде PvE */
.pve-final-reward-row--premium {
  background: rgba(255, 202, 92, .16);
  border: 1px solid rgba(255, 222, 143, .28);
  color: #fff0c4;
}
.pve-final-reward-row--premium span {
  color: #fff1a8;
}


/* 0.7.75 — визуальная память персонажа без заглушек и скачков */
.location-character__placeholder {
  display: none !important;
}
.character-preview.is-rig-preparing .character-preview__shadow,
.character-preview.is-rig-preparing .character-preview__body,
.character-preview.is-rig-preparing .character-preview__head,
.character-preview.has-rig .character-preview__shadow,
.character-preview.has-rig .character-preview__body,
.character-preview.has-rig .character-preview__head,
.character-preview.has-sprite .character-preview__shadow,
.character-preview.has-sprite .character-preview__body,
.character-preview.has-sprite .character-preview__head {
  display: none !important;
}
.location-character.is-rig-preparing,
.character-preview.is-rig-preparing {
  background: transparent !important;
  border-color: transparent !important;
  box-shadow: none !important;
}
.character-rig[hidden],
.character-equipment-part[hidden] {
  display: none !important;
}


/* 0.7.77 — в боевой сцене HUD-эффекты валюты скрыты; бутылки/слабость выводятся в верхнем ряду бафов боя. */
/* 0.7.76 — без мгновенных муляжей, слабость рядом с валютой, щит маны */
.has-layout-image.is-layout-image-loading {
  background-image: none !important;
}
.action-button--battle-zone.is-layout-image-loading,
.action-button.is-locked.is-layout-image-loading {
  opacity: 0 !important;
}
.action-button--battle-zone.is-layout-image-loading span,
.action-button--battle-zone.is-layout-image-loading small,
.action-button.is-locked.is-layout-image-loading span,
.action-button.is-locked.is-layout-image-loading small {
  visibility: hidden !important;
}
.hud-effect-bar {
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: visible;
  pointer-events: auto;
  z-index: 34;
}
.hud-effect-bar[hidden] {
  display: none !important;
}
.hud-effect-bar__image,
.hud-effect-bar__fallback-icon {
  width: 44px;
  height: 44px;
  min-width: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  object-fit: contain;
  border-radius: 50%;
  filter: drop-shadow(0 3px 7px rgba(0,0,0,.62));
  pointer-events: none;
}
.hud-effect-bar__image[hidden],
.hud-effect-bar__fallback-icon[hidden] {
  display: none !important;
}
.hud-effect-bar--debuff .hud-effect-bar__fallback-icon {
  color: #f0d7ff;
  font-size: 26px;
  font-weight: 900;
  background: radial-gradient(circle at 34% 25%, #f0d7ff, #8e61b8 48%, #311448 100%);
  text-shadow: 0 2px 4px rgba(0,0,0,.62);
}
.hud-effect-bar__value {
  display: none !important;
}
.npc-merchant-figure,
.premium-shop-hero__npc i {
  animation-duration: 2.4s !important;
}
.arena-float--mana {
  color: #8fe4ff;
  text-shadow: 0 2px 5px rgba(0,0,0,.85), 0 0 11px rgba(80,190,255,.62);
}

/* 0.7.80: в боевой сцене больше не показываем зелёные fallback-куклы врагов/игрока.
   Актёр появляется только когда реальный PNG/риг готов, без муляжа на время загрузки. */
.pve-combatant-sprite-fallback {
  display: none !important;
}
.pve-combatant-sprite--full:not(.has-pve-visual) .pve-full-sprite-viewport,
.pve-combatant-sprite--rig:not(.has-pve-visual) .pve-character-rig {
  visibility: hidden;
}


/* 0.7.82 — battle effect icons are square PNG frames, no round clipping; hide slots until image is loaded. */
.battle-debuff-icon,
.battle-debuff-icon img,
.hud-effect-bar__image,
.hud-effect-bar__fallback-icon {
  border-radius: 0 !important;
  overflow: visible !important;
}
.battle-debuff-icon.is-image-loading,
.battle-debuff-icon.is-image-missing {
  display: none !important;
}


/* 0.7.83 — эффектное появление дебаффов в центре боя и полёт к панели эффектов. */
.pve-battle-scene-card { position: relative; overflow: visible; }
.pve-battle-effect-fly {
  position: absolute;
  left: 50%;
  top: 46%;
  z-index: 44;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 54px;
  padding: 8px 16px 9px 12px;
  pointer-events: none;
  color: #fff1c7;
  font-size: 25px;
  font-weight: 1000;
  line-height: 1;
  letter-spacing: .02em;
  white-space: nowrap;
  text-shadow: 0 3px 6px rgba(0,0,0,.92), 0 0 14px rgba(255,213,120,.38);
  border-radius: 0;
  border: 1px solid rgba(255,226,158,.34);
  background: linear-gradient(180deg, rgba(54,42,31,.82), rgba(16,12,14,.70));
  box-shadow: 0 18px 42px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.12);
  transform: translate(-50%, -50%) scale(.58);
  opacity: 0;
  animation: pveBattleEffectFlyToPanel 1.28s cubic-bezier(.18,.82,.22,1) forwards;
  will-change: transform, opacity, filter;
}
.pve-battle-effect-fly img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: 0 !important;
  overflow: visible !important;
  filter: drop-shadow(0 4px 9px rgba(0,0,0,.65));
}
.pve-battle-effect-fly--debuff {
  color: #f2d1ff;
  border-color: rgba(217,160,255,.36);
  background: linear-gradient(180deg, rgba(62,34,78,.84), rgba(17,10,20,.72));
  text-shadow: 0 3px 6px rgba(0,0,0,.92), 0 0 16px rgba(181,94,255,.42);
}
.pve-battle-effect-fly--buff {
  color: #ffe2a3;
  border-color: rgba(255,213,122,.36);
  background: linear-gradient(180deg, rgba(74,48,22,.84), rgba(18,12,8,.72));
  text-shadow: 0 3px 6px rgba(0,0,0,.92), 0 0 16px rgba(255,178,68,.42);
}
.pve-battle-effect-fly--armor_crack {
  color: #ffd8a1;
  border-color: rgba(255,190,105,.44);
  background: linear-gradient(180deg, rgba(82,58,38,.88), rgba(23,16,13,.76));
}
@keyframes pveBattleEffectFlyToPanel {
  0% {
    opacity: 0;
    filter: brightness(1.6) blur(1px);
    transform: translate(-50%, -50%) scale(.45);
  }
  14% {
    opacity: 1;
    filter: brightness(1.35) blur(0);
    transform: translate(-50%, -50%) scale(1.18);
  }
  42% {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
  }
  100% {
    opacity: 0;
    filter: brightness(1);
    transform: translate(calc(-50% + var(--fly-x, 0px)), calc(-50% + var(--fly-y, -160px))) scale(.28);
  }
}

/* 0.7.83 — более крупные тексты урона/эффектов в боевой сцене. */
.pve-location-battle .arena-float,
.pve-battle-scene-card .arena-float {
  padding: 6px 13px !important;
  border-radius: 0 !important;
  font-size: 28px !important;
  line-height: 1.05 !important;
  font-weight: 1000 !important;
  letter-spacing: .025em !important;
  text-shadow: 0 4px 8px rgba(0,0,0,.92), 0 0 13px rgba(255,231,170,.26) !important;
  border-color: rgba(255,230,170,.24) !important;
  background: rgba(8,6,8,.42) !important;
}
.pve-location-battle .arena-float--damage,
.pve-battle-scene-card .arena-float--damage {
  font-size: 31px !important;
  color: #ff806b !important;
}
.pve-location-battle .arena-float--crit,
.pve-battle-scene-card .arena-float--crit {
  font-size: 38px !important;
  color: #ffd36a !important;
  text-shadow: 0 4px 9px rgba(0,0,0,.94), 0 0 18px rgba(255,190,76,.56) !important;
}
.pve-location-battle .arena-float--debuff,
.pve-battle-scene-card .arena-float--debuff {
  font-size: 28px !important;
  color: #e0adff !important;
  text-shadow: 0 4px 8px rgba(0,0,0,.94), 0 0 16px rgba(177,93,255,.44) !important;
}
.pve-location-battle .arena-float--heal,
.pve-battle-scene-card .arena-float--heal {
  font-size: 31px !important;
  color: #9dffad !important;
}
.pve-location-battle .arena-float--mana,
.pve-battle-scene-card .arena-float--mana {
  font-size: 29px !important;
  color: #8fe4ff !important;
  text-shadow: 0 4px 8px rgba(0,0,0,.94), 0 0 18px rgba(80,190,255,.58) !important;
}


/* 0.7.84 — бой: цифры/надписи без рамок и плашек, центральный эффект только PNG. */
.pve-location-battle .arena-float,
.pve-battle-scene-card .arena-float {
  padding: 0 !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
}
.pve-location-battle .arena-float::before,
.pve-location-battle .arena-float::after,
.pve-battle-scene-card .arena-float::before,
.pve-battle-scene-card .arena-float::after {
  display: none !important;
  content: none !important;
}
.pve-battle-effect-fly {
  gap: 0 !important;
  min-width: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  text-shadow: none !important;
}
.pve-battle-effect-fly span {
  display: none !important;
}
.pve-battle-effect-fly img {
  width: 74px !important;
  height: 74px !important;
  border: 0 !important;
  outline: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  filter: drop-shadow(0 8px 14px rgba(0,0,0,.72)) drop-shadow(0 0 18px rgba(255,221,143,.22)) !important;
}
