/* ============================================================
   DOTA МОНОПОЛИЯ — стили (часть 3: поле 2.5D, тайлы, карты)
   ============================================================ */

/* ---------- BOARD 2.5D ---------- */
.board-stage { --tilt: 42deg; position: relative; perspective: 2200px; perspective-origin: 50% 40%; width: 860px; height: 860px; transition: transform .5s cubic-bezier(.4,0,.2,1); }
.board-stage.is-2d { transform: scale(.60); }
.board-tilt { width: 100%; height: 100%; transform: rotateX(var(--tilt)); transform-style: preserve-3d; transition: transform .6s cubic-bezier(.4,0,.2,1); }
.board-grid {
  width: 100%; height: 100%; display: grid;
  grid-template-columns: 1.42fr repeat(9, 1fr) 1.42fr;
  grid-template-rows: 1.42fr repeat(9, 1fr) 1.42fr;
  gap: 2px; padding: 8px;
  background:
    linear-gradient(135deg, #0e1420, #0a0d14);
  border: 2px solid var(--gold-deep);
  border-radius: 8px;
  box-shadow: 0 40px 80px rgba(0,0,0,.7), inset 0 0 60px rgba(0,0,0,.6), 0 0 40px rgba(200,168,75,.12);
  transform-style: preserve-3d;
}
.cell { position: relative; background: #0d111a; border: 1px solid #1c2333; overflow: visible; cursor: pointer; transition: filter .15s; border-radius: 2px; }
.cell:hover { filter: brightness(1.25); z-index: 5; }
.cell.active { box-shadow: 0 0 0 2px var(--gold); z-index: 4; }

/* анимация клика по свободному месту доски (привязана к курсору) */
.click-fx { position: absolute; width: 0; height: 0; pointer-events: none; z-index: 20; }
.click-fx-ring {
  position: absolute; left: 0; top: 0;
  border: 2px solid var(--gold); border-radius: 50%;
  box-shadow: 0 0 14px 3px rgba(232,194,74,.65);
  transform: translate(-50%, -50%); animation: clickRing 0.55s cubic-bezier(.2,.7,.3,1) forwards;
}
.click-fx-flash {
  position: absolute; left: 0; top: 0; width: 90px; height: 90px;
  background: radial-gradient(circle, rgba(232,194,74,.55) 0%, transparent 65%);
  transform: translate(-50%, -50%); mix-blend-mode: screen; animation: clickFlash 0.45s ease-out forwards;
}
@keyframes clickRing {
  0%   { width: 8px; height: 8px; opacity: .95; }
  100% { width: 92px; height: 92px; opacity: 0; }
}
@keyframes clickFlash { 0% { opacity: 1; transform: translate(-50%,-50%) scale(.5); } 100% { opacity: 0; transform: translate(-50%,-50%) scale(1.1); } }

/* hero tile */
.tile-hero { --gc: #888; position: absolute; inset: 0; overflow: hidden; border-radius: 2px; }
.th-bar { position: absolute; background: var(--gc); z-index: 3; }
.side-bottom .th-bar { top: 0; left: 0; right: 0; height: 3px; }
.side-top .th-bar { bottom: 0; left: 0; right: 0; height: 3px; }
.side-left .th-bar { right: 0; top: 0; bottom: 0; width: 3px; }
.side-right .th-bar { left: 0; top: 0; bottom: 0; width: 3px; }
.th-art { position: absolute; inset: 0; }
.th-art img { width: 100%; height: 100%; object-fit: cover; object-position: center 22%; }
.th-fade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(7,9,15,.97) 6%, rgba(7,9,15,.5) 40%, transparent 66%); }
.th-name { position: absolute; bottom: 18px; left: 2px; right: 2px; text-align: center; font-family: var(--font-h); font-size: 11px; font-weight: 500; letter-spacing: -.015em; line-height: 1.05; color: #fff; z-index: 2; text-shadow: 0 1px 3px rgba(0,0,0,.9); overflow-wrap: anywhere; }
.th-price { position: absolute; bottom: 4px; left: 0; right: 0; text-align: center; font-size: 12px; font-weight: 500; color: var(--gold); z-index: 2; text-shadow: 0 1px 2px rgba(0,0,0,.8); }
.th-owner { position: absolute; top: 4px; right: 4px; width: 10px; height: 10px; border-radius: 50%; border: 1px solid rgba(0,0,0,.6); z-index: 4; }
.tile-upg { position: absolute; top: 7px; left: 0; right: 0; display: flex; justify-content: center; align-items: flex-end; gap: 0; z-index: 5; pointer-events: none; }
.tile-upg::before { content: ''; position: absolute; left: 50%; top: 55%; transform: translate(-50%,-50%); width: 78%; height: 30px; border-radius: 50%; background: radial-gradient(ellipse at center, rgba(110,200,255,.45) 0%, rgba(70,140,220,.18) 45%, transparent 72%); filter: blur(1px); z-index: -1; }
.tile-upg.throne { top: 0; }
.tile-upg.throne::before { width: 88%; height: 40px; background: radial-gradient(ellipse at center, rgba(255,210,110,.55) 0%, rgba(120,200,255,.3) 48%, transparent 74%); animation: thronePulse 2.4s ease-in-out infinite; }
@keyframes thronePulse { 0%,100% { opacity:.75; transform: translate(-50%,-50%) scale(1); } 50% { opacity:1; transform: translate(-50%,-50%) scale(1.12); } }
.upg-img { display: inline-block; vertical-align: middle; object-fit: contain; image-rendering: auto; filter: drop-shadow(0 1px 1px rgba(0,0,0,.9)) drop-shadow(0 0 4px rgba(120,205,255,.7)); }
.upg-img-tower { margin: 0 -2px; }
.upg-img-throne { filter: drop-shadow(0 2px 3px rgba(0,0,0,.95)) drop-shadow(0 0 7px rgba(255,205,110,.8)) drop-shadow(0 0 12px rgba(120,210,255,.6)); }

/* image tile (camp/obs/tax) */
.tile-img { position: absolute; inset: 0; overflow: hidden; border-radius: 2px; }
.tile-img img { width: 100%; height: 100%; object-fit: cover; }

/* ---- анимация покупки/улучшения кемпа ---- */
.tile-img.camp-up img,
.tile-hero.camp-up .th-art img { animation: campImgPop 0.95s cubic-bezier(.2,.9,.25,1); }
@keyframes campImgPop {
  0%   { transform: scale(.62); filter: brightness(2.4) saturate(1.4); }
  35%  { transform: scale(1.14); filter: brightness(1.7); }
  60%  { transform: scale(.97); }
  100% { transform: scale(1); filter: brightness(1); }
}
.camp-fx { position: absolute; inset: 0; pointer-events: none; z-index: 6; overflow: visible; }
.camp-fx-flash {
  position: absolute; inset: -20%;
  background: radial-gradient(circle, rgba(232,194,74,.95) 0%, rgba(232,194,74,.35) 40%, transparent 70%);
  mix-blend-mode: screen; animation: campFlash 0.7s ease-out forwards;
}
@keyframes campFlash { 0% { opacity: 0; } 18% { opacity: 1; } 100% { opacity: 0; } }
.camp-fx-ring {
  position: absolute; left: 50%; top: 50%; width: 14%; height: 14%;
  border: 2px solid #f1d36b; border-radius: 50%;
  box-shadow: 0 0 10px 2px rgba(232,194,74,.7);
  transform: translate(-50%, -50%); animation: campRing 0.95s ease-out forwards;
}
.camp-fx-ring2 { animation-delay: 0.18s; border-color: #fff0c0; }
@keyframes campRing {
  0%   { width: 10%; height: 10%; opacity: .95; }
  100% { width: 175%; height: 175%; opacity: 0; }
}
.camp-fx-up {
  position: absolute; left: 50%; top: 58%; transform: translateX(-50%);
  color: #f1d36b; font-weight: 900; font-size: 1.5em; letter-spacing: 1px;
  text-shadow: 0 0 8px #000, 0 0 14px rgba(232,194,74,.9);
  animation: campUp 1.1s ease-out forwards;
}
@keyframes campUp {
  0%   { opacity: 0; top: 62%; }
  25%  { opacity: 1; }
  100% { opacity: 0; top: 14%; }
}
.ti-fade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(7,9,15,.95) 10%, transparent 60%); }
.ti-label { position: absolute; bottom: 15px; left: 3px; right: 3px; text-align: center; font-family: var(--font-h); font-size: 12.5px; font-weight: 500; line-height: 1.08; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,.9); }
.ti-sub { position: absolute; bottom: 3px; left: 0; right: 0; text-align: center; font-size: 12px; font-weight: 500; color: var(--gold); text-shadow: 0 1px 2px rgba(0,0,0,.8); }
.ti-sub.tax { color: #e0564f; }
.tile-tax img { object-position: center 35%; }

/* event tile */
.tile-event { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 4px; border-radius: 2px; }
.tile-event.is-chance { background: radial-gradient(circle at 50% 35%, rgba(120,90,200,.25), #0d111a); }
.tile-event.is-chest { background: radial-gradient(circle at 50% 35%, rgba(200,168,75,.22), #0d111a); }
.te-mark { font-family: var(--font-h); font-size: 38px; font-weight: 700; line-height: 1; }
.is-chance .te-mark { color: #b08fe0; }
.is-chest .te-mark { color: var(--gold-bright); }
.te-label { font-family: var(--font-h); font-size: 12px; font-weight: 500; letter-spacing: .04em; color: var(--txt-dim); }

/* corner tile */
.tile-corner { position: absolute; inset: 0; overflow: hidden; border-radius: 3px; }
.tile-corner img { width: 100%; height: 100%; object-fit: cover; }
.tc-fade { position: absolute; inset: 0; background: linear-gradient(to top, rgba(7,9,15,.94) 12%, transparent 55%); }
.tc-label { position: absolute; bottom: 19px; left: 4px; right: 4px; text-align: center; font-family: var(--font-h); font-weight: 600; font-size: 13px; line-height: 1.06; letter-spacing: -.005em; color: #fff; text-shadow: 0 1px 3px rgba(0,0,0,.9); }
.tc-sub { position: absolute; bottom: 6px; left: 0; right: 0; text-align: center; font-size: 12px; font-weight: 500; color: var(--gold); letter-spacing: .02em; text-shadow: 0 1px 2px rgba(0,0,0,.8); }
.cell-corner { z-index: 2; }

/* center — 2.5D карта Доты */
.board-center { position: relative; display: flex; align-items: center; justify-content: center; transform-style: preserve-3d; overflow: visible; padding: 3%; }
.bc-frame { position: relative; width: 100%; height: 100%; border-radius: 10px; overflow: hidden;
  border: 2px solid var(--gold-deep);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.65), inset 0 0 46px rgba(0,0,0,.6), 0 0 0 1px rgba(0,0,0,.5), 0 24px 50px rgba(0,0,0,.55); }
.dota-map { width: 100%; height: 100%; display: block; object-fit: cover; border-radius: 0;
  filter: brightness(.82) contrast(1.08) saturate(.74) sepia(.1) hue-rotate(-4deg); }
/* цветокоррекция под палитру игры (тёплый край → холодный центр) */
.bc-grade { position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(circle at 50% 46%, transparent 26%, rgba(7,11,18,.5) 92%),
    linear-gradient(150deg, rgba(26,20,8,.34), rgba(8,14,20,.42)); }
/* мягкое золотое свечение в центре (под руну) */
.bc-glow { position: absolute; inset: 0; pointer-events: none; mix-blend-mode: screen;
  background: radial-gradient(circle at 50% 48%, rgba(232,200,90,.22), rgba(232,200,90,.06) 30%, transparent 46%);
  animation: bcGlow 5.5s ease-in-out infinite; }
@keyframes bcGlow { 0%,100% { opacity: .65; } 50% { opacity: 1; } }
.bc-vignette { position: absolute; inset: 0; background: radial-gradient(circle at 50% 50%, transparent 52%, rgba(0,0,0,.6) 100%); pointer-events: none; z-index: 2; }
/* внутренний золотой кант */
.bc-rim { position: absolute; inset: 5px; border-radius: 6px; pointer-events: none; z-index: 3;
  border: 1px solid rgba(200,168,75,.28); box-shadow: inset 0 0 22px rgba(0,0,0,.5); }
/* угловые орнаменты */
.bc-corner { position: absolute; width: 26px; height: 26px; z-index: 4; pointer-events: none; opacity: .8; }
.bc-corner.tl { top: -2px; left: -2px; border-top: 2px solid var(--gold); border-left: 2px solid var(--gold); border-top-left-radius: 8px; }
.bc-corner.tr { top: -2px; right: -2px; border-top: 2px solid var(--gold); border-right: 2px solid var(--gold); border-top-right-radius: 8px; }
.bc-corner.bl { bottom: -2px; left: -2px; border-bottom: 2px solid var(--gold); border-left: 2px solid var(--gold); border-bottom-left-radius: 8px; }
.bc-corner.br { bottom: -2px; right: -2px; border-bottom: 2px solid var(--gold); border-right: 2px solid var(--gold); border-bottom-right-radius: 8px; }
.map-label { font-family: var(--font-h); font-size: 4px; letter-spacing: .35em; font-weight: 700; opacity: .55; }

/* ---------- ШАНС / КАЗНА колоды в центре (как в классической Монополии) ---------- */
.bc-decks { position: absolute; inset: 0; z-index: 7; pointer-events: none; transform-style: preserve-3d; }
.bc-deck { position: absolute; transform-style: preserve-3d; }
.bc-deck img {
  display: block; width: 100%; height: auto;
  transform-origin: 50% 100%;
  transform: rotateX(calc(-1 * var(--tilt)));
  opacity: .82;
  filter: drop-shadow(0 5px 7px rgba(0,0,0,.5)) brightness(.9) saturate(.86);
}
/* мягкое контактное пятно тени, лежит на земле (без контр-наклона) */
.deck-shadow {
  position: absolute; left: 10%; right: 10%; bottom: -2%; height: 20%;
  border-radius: 50%; filter: blur(4px);
  background: radial-gradient(ellipse at 50% 50%, rgba(0,0,0,.5), rgba(0,0,0,.22) 55%, transparent 74%);
}
/* цветной свет, отбрасываемый колодой на карту */
.deck-glow {
  position: absolute; left: -14%; right: -14%; bottom: -10%; height: 46%;
  border-radius: 50%; filter: blur(10px); z-index: -1; mix-blend-mode: screen;
}
.deck-chest  { top: 13%;  left: 12%;  width: 17%; }
.deck-chance { bottom: 11%; right: 11%; width: 18.5%; }
.deck-chest  .deck-glow { background: radial-gradient(ellipse at 50% 50%, rgba(224,180,60,.22), transparent 66%); }
.deck-chance .deck-glow { background: radial-gradient(ellipse at 50% 50%, rgba(150,112,224,.24), transparent 66%); }
/* печатное «место» под колоду — стоит вместе с картой как подложка */
.deck-slot {
  position: absolute; left: -14%; right: -14%; top: -8%; bottom: -6%;
  border-radius: 8px; z-index: -2;
  transform-origin: 50% 100%;
  transform: rotateX(calc(-1 * var(--tilt)));
  background: linear-gradient(180deg, rgba(8,11,17,.5), rgba(6,9,14,.66));
  border: 1.5px dashed rgba(200,168,75,.4);
  box-shadow: inset 0 2px 8px rgba(0,0,0,.6), inset 0 0 0 3px rgba(0,0,0,.25);
  display: flex; align-items: flex-end; justify-content: center; padding-bottom: 5%;
}
.deck-slot-label {
  font-family: var(--font-h); font-weight: 700; font-size: 9px; letter-spacing: .28em;
  color: rgba(200,168,75,.55); text-shadow: 0 1px 2px rgba(0,0,0,.8);
}
.deck-chance .deck-slot { border-color: rgba(150,112,224,.4); }
.deck-chance .deck-slot-label { color: rgba(176,143,224,.6); }

.bc-deck img { animation: deckFloat 6s ease-in-out infinite; }
.deck-chance img { animation-delay: -3s; }
@keyframes deckFloat {
  0%,100% { transform: rotateX(calc(-1 * var(--tilt))) translateY(0); }
  50%     { transform: rotateX(calc(-1 * var(--tilt))) translateY(-1.4%); }
}

.river-shine { animation: riverFlow 5s ease-in-out infinite; }
@keyframes riverFlow { 0%,100% { opacity: .25; } 50% { opacity: .6; } }
.lane-line { animation: laneGlow 3.5s ease-in-out infinite; }
@keyframes laneGlow { 0%,100% { opacity: .4; } 50% { opacity: .7; } }

.map-twr .twr-aura { opacity: .4; transform-box: fill-box; transform-origin: center; animation: twrPulse 2.6s ease-in-out infinite; animation-delay: var(--d); }
@keyframes twrPulse { 0%,100% { opacity: .28; transform: scale(.8); } 50% { opacity: .7; transform: scale(1.18); } }
.twr-core { transform-box: fill-box; transform-origin: center; animation: twrCore 2.6s ease-in-out infinite; animation-delay: var(--d); }
@keyframes twrCore { 0%,100% { opacity: .65; } 50% { opacity: 1; } }

.anc-aura { transform-box: fill-box; transform-origin: center; animation: ancPulse 3.4s ease-in-out infinite; }
@keyframes ancPulse { 0%,100% { opacity: .45; transform: scale(.88); } 50% { opacity: .85; transform: scale(1.12); } }
.anc-core { transform-box: fill-box; transform-origin: center; animation: ancCore 3.4s ease-in-out infinite; }
@keyframes ancCore { 0%,100% { opacity: .6; } 50% { opacity: 1; } }

.rosh-aura { transform-box: fill-box; transform-origin: center; animation: roshAura 4s ease-in-out infinite; }
@keyframes roshAura { 0%,100% { opacity: .2; transform: scale(.9); } 50% { opacity: .5; transform: scale(1.1); } }
.rosh-eye { animation: roshEye 3s ease-in-out infinite; }
@keyframes roshEye { 0%,90%,100% { opacity: 1; } 94% { opacity: .2; } }
.rosh-glow { animation: roshGlow 4s ease-in-out infinite; transform-box: fill-box; transform-origin: center; }
@keyframes roshGlow { 0%,100% { opacity: 0; } 50% { opacity: .35; } }

/* token layer on tiles */
.tok-layer { position: absolute; inset: 0; transform-origin: bottom center; transform-style: preserve-3d; pointer-events: none; z-index: 8; }
.tok-slot { position: absolute; bottom: 14%; transform: translateX(-50%);
  filter: drop-shadow(0 3px 4px rgba(0,0,0,.85)) drop-shadow(0 0 2px rgba(255,255,255,.55)) drop-shadow(0 0 6px var(--pc, #fff)); }
/* мягкий ореол позади всей фишки в цвете игрока */
.tok-slot::before { content: ''; position: absolute; left: 50%; top: 38%; width: 40px; height: 46px;
  transform: translate(-50%, -50%); border-radius: 50%; z-index: -2;
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--pc, #fff) 60%, transparent) 0%, transparent 65%);
  filter: blur(4px); opacity: .55; animation: tokHalo 2s ease-in-out infinite; }
/* яркое наземное кольцо-подсветка */
.tok-slot::after { content: ''; position: absolute; left: 50%; bottom: -2px; width: 30px; height: 12px;
  transform: translateX(-50%); border-radius: 50%; z-index: -1;
  border: 2.5px solid var(--pc, #fff);
  background: radial-gradient(ellipse at center, color-mix(in srgb, var(--pc, #fff) 70%, transparent) 0%, transparent 70%);
  box-shadow: 0 0 8px var(--pc, #fff), inset 0 0 4px var(--pc, #fff); }
@keyframes tokHalo { 0%,100% { opacity: .4; } 50% { opacity: .7; } }
.tok-slot.afk { opacity: .4; }

/* ============================================================
   КАРТЫ ГЕРОЕВ (3 варианта)
   ============================================================ */
.deed { width: 370px; height: 540px; position: relative; border-radius: 6px; overflow: hidden; user-select: none; transform-origin: center; }

/* variant 1 — classic */
.deed-classic { --gc: #888; background: linear-gradient(180deg, #12161f, #0a0d14); border: 1px solid var(--line); box-shadow: 0 30px 70px rgba(0,0,0,.7); display: flex; flex-direction: column; }
.deed-bar { height: 8px; background: var(--gc); box-shadow: 0 0 14px var(--gc); }
.deed-art { position: relative; height: 265px; }
.deed-art img { width: 100%; height: 100%; object-fit: cover; object-position: center 18%; }
.deed-art-fade { position: absolute; inset: 0; background: linear-gradient(to top, #0a0d14 4%, transparent 40%); }
.deed-title { position: absolute; bottom: 10px; left: 16px; right: 16px; }
.deed-group { font-size: 11px; letter-spacing: .2em; font-weight: 700; }
.deed-title h3 { font-family: var(--font-h); font-weight: 600; font-size: 31px; color: #f7f0db; line-height: 1.02; letter-spacing: .005em; text-shadow: 0 2px 6px #000; }
.deed-price { display: flex; align-items: baseline; justify-content: space-between; padding: 9px 16px; border-bottom: 1px solid var(--line); }
.deed-price-label { font-size: 10px; letter-spacing: .18em; text-transform: uppercase; color: var(--txt-dim); }
.deed-price-val { font-family: var(--font-h); font-weight: 700; font-size: 22px; color: var(--gold-bright); }
.deed-price-val em { font-style: normal; font-size: 11px; color: var(--txt-dim); }
.deed-rents { flex: 1; padding: 9px 16px; display: flex; flex-direction: column; gap: 1px; }
.rent-row { display: flex; justify-content: space-between; align-items: center; font-size: 13.5px; padding: 3px 0; color: #d2cab8; }
.rent-row span { display: flex; align-items: center; gap: 3px; }
.rent-row .dot { width: 6px; height: 8px; background: var(--gc); display: inline-block; clip-path: polygon(50% 0, 100% 35%, 100% 100%, 0 100%, 0 35%); }
.rent-v { font-family: var(--font-h); font-weight: 600; font-size: 15px; color: #f4ecd6; }
.throne-row { border-top: 1px solid var(--line); margin-top: 3px; padding-top: 5px; }
.throne-row .rent-v { color: var(--gold-bright); }
.deed-foot { display: flex; justify-content: space-between; padding: 9px 16px; background: rgba(0,0,0,.3); border-top: 1px solid var(--line); font-size: 12px; color: #a89f8c; }
.deed-foot b { color: var(--gold); font-family: var(--font-h); }

/* variant 2 — immersive */
.deed-imm { --gc: #888; border: 1px solid var(--gc); box-shadow: 0 30px 70px rgba(0,0,0,.7); }
.deed-imm-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.deed-imm-veil { position: absolute; inset: 0; background: linear-gradient(to top, #07090f 18%, rgba(7,9,15,.4) 50%, rgba(7,9,15,.55) 100%); }
.deed-imm-top { position: absolute; top: 0; left: 0; right: 0; display: flex; justify-content: space-between; align-items: flex-start; padding: 14px; }
.deed-imm-group { font-size: 10px; letter-spacing: .18em; font-weight: 700; color: #0a0a0a; padding: 5px 10px; border-radius: 3px; }
.deed-imm-price { font-family: var(--font-h); font-weight: 700; font-size: 30px; color: var(--gold-bright); text-shadow: 0 2px 8px #000; line-height: 1; }
.deed-imm-body { position: absolute; bottom: 0; left: 0; right: 0; padding: 16px; }
.deed-imm-body h3 { font-family: var(--font-h); font-weight: 600; font-size: 34px; color: #f7f0db; line-height: 1.0; letter-spacing: .005em; text-shadow: 0 2px 8px #000; margin-bottom: 12px; }
.deed-imm-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 4px; overflow: hidden; }
.deed-imm-grid > div { background: rgba(10,13,20,.9); padding: 8px 4px; text-align: center; }
.deed-imm-grid label { display: block; font-size: 10px; letter-spacing: .08em; text-transform: uppercase; color: #9a917e; margin-bottom: 1px; }
.deed-imm-grid b { font-family: var(--font-h); font-weight: 600; font-size: 18px; color: #f4ecd6; }
.deed-imm-throne { display: flex; justify-content: space-between; align-items: center; margin-top: 8px; padding: 8px 12px; background: linear-gradient(90deg, rgba(200,168,75,.2), rgba(200,168,75,.05)); border: 1px solid var(--gold-deep); border-radius: 4px; }
.deed-imm-throne span { display: flex; align-items: center; gap: 6px; font-size: 12px; color: var(--gold-bright); letter-spacing: .06em; }
.deed-imm-throne b { font-family: var(--font-h); font-size: 18px; color: var(--gold-bright); }
.deed-imm-foot { display: flex; justify-content: space-between; margin-top: 9px; font-size: 12px; color: #a89f8c; letter-spacing: .02em; }

/* variant 3 — ornate */
.deed-orn { --gc: #888; background: radial-gradient(circle at 50% 20%, #16110a, #07090f); border: 1px solid var(--gold-deep); box-shadow: 0 30px 70px rgba(0,0,0,.7); padding: 10px; }
.orn-frame { position: relative; height: 100%; border: 1px solid var(--gold-deep); border-radius: 4px; padding: 18px 16px 14px; display: flex; flex-direction: column; align-items: center; }
.orn-corner { position: absolute; width: 14px; height: 14px; border: 2px solid var(--gold); }
.orn-corner.tl { top: -1px; left: -1px; border-right: none; border-bottom: none; }
.orn-corner.tr { top: -1px; right: -1px; border-left: none; border-bottom: none; }
.orn-corner.bl { bottom: -1px; left: -1px; border-right: none; border-top: none; }
.orn-corner.br { bottom: -1px; right: -1px; border-left: none; border-top: none; }
.orn-group { font-size: 10px; letter-spacing: .22em; font-weight: 700; padding: 3px 12px; border: 1px solid; border-radius: 20px; margin-bottom: 10px; }
.orn-art { width: 100%; height: 200px; border: 1px solid var(--gold-deep); border-radius: 3px; overflow: hidden; }
.orn-art img { width: 100%; height: 100%; object-fit: cover; object-position: center 16%; }
.orn-name { font-family: var(--font-h); font-weight: 600; font-size: 29px; color: #f7f0db; margin: 8px 0 2px; text-align: center; line-height: 1.02; letter-spacing: .01em; }
.orn-price { display: flex; align-items: baseline; gap: 6px; }
.orn-price span { font-family: var(--font-h); font-weight: 700; font-size: 26px; color: var(--gold-bright); }
.orn-price em { font-style: normal; font-size: 11px; color: var(--txt-dim); letter-spacing: .1em; }
.orn-rents { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 5px; width: 100%; margin: 12px 0 8px; }
.orn-rent { display: flex; flex-direction: column; align-items: center; gap: 2px; padding: 7px 2px; background: rgba(0,0,0,.35); border: 1px solid var(--line); border-radius: 3px; }
.orn-rent span { font-size: 10px; letter-spacing: .06em; text-transform: uppercase; color: #9a917e; }
.orn-rent b { font-family: var(--font-h); font-weight: 600; font-size: 17px; color: #f4ecd6; }
.orn-throne { display: flex; align-items: center; gap: 8px; width: 100%; justify-content: center; padding: 7px; border-top: 1px solid var(--gold-deep); border-bottom: 1px solid var(--gold-deep); }
.orn-throne span { font-size: 12px; color: var(--gold-bright); letter-spacing: .08em; }
.orn-throne b { font-family: var(--font-h); font-size: 17px; color: var(--gold-bright); }
.orn-foot { margin-top: auto; display: flex; align-items: center; gap: 10px; font-size: 12px; color: #a89f8c; padding-top: 8px; }
.orn-foot .div { color: var(--gold-deep); }

/* ---------- MODAL / EVENT CARD ---------- */
.modal-wrap { position: fixed; inset: 0; z-index: 60; background: rgba(4,5,9,.78); display: flex; align-items: center; justify-content: center; animation: fadeIn .2s ease-out; }
.modal-card { position: relative; display: flex; flex-direction: column; align-items: stretch; gap: 10px; animation: cardPop .3s cubic-bezier(.2,.8,.3,1.1); }
@keyframes cardPop { from { opacity: 0; transform: scale(.85) translateY(20px); } to { opacity: 1; transform: none; } }
.modal-x { position: absolute; top: -14px; right: -14px; width: 34px; height: 34px; border-radius: 50%; background: var(--panel2); border: 1px solid var(--gold); color: var(--gold); font-size: 20px; line-height: 1; }
.modal-x:hover { background: var(--gold); color: #0a0a0a; }

/* ---------- OWNER STRIP (владелец + улучшения) ---------- */
.owner-strip {
  --oc: #888;
  display: grid; grid-template-columns: 1.3fr 1.4fr auto; align-items: center; gap: 12px;
  padding: 11px 14px;
  background: linear-gradient(180deg, rgba(18,22,31,.94), rgba(10,13,20,.96));
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  border: 1px solid var(--gold-deep); border-left: 3px solid var(--oc);
  border-radius: 6px; box-shadow: 0 18px 44px rgba(0,0,0,.6);
  animation: cardPop .34s cubic-bezier(.2,.8,.3,1.1) .04s both;
}
.owner-strip.is-free { display: flex; justify-content: center; border-left-color: var(--gold-deep); }
.os-free { font-family: var(--font-h); letter-spacing: .14em; text-transform: uppercase; color: var(--txt-dim); font-size: 13px; }
.os-owner { display: flex; align-items: center; gap: 10px; min-width: 0; }
.os-ava { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: radial-gradient(circle at 50% 40%, color-mix(in srgb, var(--oc) 32%, transparent), transparent 70%);
  border: 1px solid color-mix(in srgb, var(--oc) 55%, transparent); flex: 0 0 auto; }
.os-id { min-width: 0; }
.os-label, .os-upg-lab, .os-rent-lab { font-size: 9.5px; letter-spacing: .2em; text-transform: uppercase; color: var(--txt-dim); font-weight: 600; }
.os-name { font-family: var(--font-h); font-weight: 600; font-size: 17px; color: var(--oc); line-height: 1.15; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.os-name em { color: var(--txt-dim); font-style: normal; font-size: 12px; }
.os-upg { display: flex; flex-direction: column; gap: 3px; border-left: 1px solid var(--line); padding-left: 12px; min-width: 0; }
.os-upg-row { display: flex; align-items: center; gap: 7px; }
.os-towers { display: flex; align-items: flex-end; gap: 1px; }
.os-upg-txt { font-family: var(--font-h); font-size: 14px; color: #efe7d2; line-height: 1.1; }
.os-rent { display: flex; flex-direction: column; align-items: flex-end; gap: 2px; padding-left: 4px; }
.os-rent-v { font-family: var(--font-h); font-weight: 700; font-size: 24px; color: var(--gold-bright); line-height: .9; text-shadow: 0 0 14px rgba(232,200,74,.35); }

.info-card { width: 356px; background: linear-gradient(180deg, rgba(18,22,31,.86), rgba(10,13,20,.9)); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); border: 1px solid var(--gold-deep); border-radius: 6px; overflow: hidden; box-shadow: 0 30px 70px rgba(0,0,0,.7); }
.info-art { position: relative; height: 200px; }
.info-art img { width: 100%; height: 100%; object-fit: cover; }
.info-fade { position: absolute; inset: 0; background: linear-gradient(to top, #0a0d14, transparent 60%); }
.info-card h3 { font-family: var(--font-h); font-weight: 600; font-size: 25px; letter-spacing: .01em; color: var(--gold-bright); padding: 0 18px; margin-top: -6px; position: relative; }
.info-card p { padding: 8px 18px 20px; color: #cabfa8; font-size: 14.5px; line-height: 1.5; }

.event-card { width: 340px; height: 440px; perspective: 1200px; cursor: pointer; }
.event-inner { position: relative; width: 100%; height: 100%; transform-style: preserve-3d; transition: transform .6s cubic-bezier(.4,0,.2,1); }
.event-card.flipped .event-inner { transform: rotateY(180deg); }
.event-back, .event-front { position: absolute; inset: 0; backface-visibility: hidden; border-radius: 8px; overflow: hidden; border: 1px solid var(--gold-deep); box-shadow: 0 30px 70px rgba(0,0,0,.7); }
.event-back { background: radial-gradient(circle at 50% 40%, #1a1408, #07090f); display: flex; align-items: center; justify-content: center; }
.event-back-mark { font-family: var(--font-h); font-size: 90px; color: var(--gold); opacity: .7; text-shadow: 0 0 30px rgba(200,168,75,.6); }
.event-front { transform: rotateY(180deg); background: #0a0d14; }
.event-bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: .5; }
.event-veil { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(7,9,15,.7), rgba(7,9,15,.95)); }
.event-front h4 { position: relative; font-family: var(--font-h); font-weight: 600; letter-spacing: .1em; color: var(--gold-bright); font-size: 20px; text-align: center; padding: 26px 16px 0; text-shadow: 0 0 16px rgba(200,168,75,.5); }
.event-front p { position: relative; padding: 22px 26px; color: #efe7d2; font-size: 17px; line-height: 1.5; text-align: center; }
.event-hint { text-align: center; color: var(--txt-dim); font-size: 12px; margin-top: 14px; letter-spacing: .08em; }
