:root {
  --canvas: #100e0b;
  --canvas-soft: #17130e;
  --ink: #f5f0e7;
  --muted: #b9b0a1;
  --muted-strong: #d7cdbd;
  --line: rgba(227, 211, 182, .16);
  --line-strong: rgba(227, 211, 182, .28);
  --panel: rgba(29, 25, 19, .72);
  --panel-solid: #211d16;
  --pine: #526b4b;
  --pine-dark: #1f3128;
  --moss: #9ab47d;
  --gold: #b97932;
  --gold-bright: #e5b366;
  --cream: #fff5e4;
  --danger: #d46855;
  --shadow: 0 20px 70px rgba(0, 0, 0, .28);
  --shadow-deep: 0 35px 100px rgba(0, 0, 0, .46);
  --radius-lg: 24px;
  --radius-md: 16px;
  --radius-sm: 12px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  min-width: 320px;
  margin: 0;
  color: var(--ink);
  background:
    linear-gradient(rgba(13, 11, 8, .82), rgba(13, 11, 8, .92)),
    image-set(
      url("assets/wildlands-page-texture.webp") type("image/webp"),
      url("assets/wildlands-page-texture.png") type("image/png")
    ) center top / 620px auto repeat,
    var(--canvas);
  font-family: Inter, "Segoe UI", system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  overflow-x: hidden;
}
body::before {
  position: fixed;
  inset: 0;
  z-index: -1;
  content: "";
  pointer-events: none;
  opacity: .56;
  background: radial-gradient(900px 500px at 50% -10%, rgba(229, 179, 102, .1), transparent 62%);
}
body.modal-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input, select { font: inherit; }
button { cursor: pointer; }
button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible {
  outline: 2px solid var(--gold-bright);
  outline-offset: 3px;
}
code {
  padding: 2px 7px;
  border: 1px solid rgba(229, 179, 102, .22);
  border-radius: 7px;
  color: var(--cream);
  background: rgba(0, 0, 0, .22);
  font-weight: 800;
}

.page { display: none; }
.page.active { display: block; }

.topbar {
  position: fixed;
  z-index: 30;
  top: 16px;
  left: 50%;
  width: min(1220px, calc(100% - 32px));
  min-height: 72px;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 9px 10px 9px 16px;
  border: 1px solid rgba(255, 245, 228, .18);
  border-radius: 22px;
  background: rgba(22, 19, 14, .78);
  box-shadow: 0 16px 55px rgba(0, 0, 0, .26);
  backdrop-filter: blur(18px) saturate(120%);
}
.brand {
  display: inline-flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 10px;
  color: var(--cream);
  font-family: Unbounded, Inter, sans-serif;
  font-size: .96rem;
  font-weight: 800;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.brand img {
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 245, 228, .45);
  border-radius: 14px;
  box-shadow: 0 7px 16px rgba(0, 0, 0, .26);
}
.topbar nav {
  display: flex;
  flex: 1;
  align-items: center;
  justify-content: center;
  gap: 2px;
}
.topbar nav a {
  padding: 9px 12px;
  border-radius: 10px;
  color: rgba(245, 240, 231, .74);
  font-size: .9rem;
  font-weight: 800;
  transition: color .18s ease, background-color .18s ease;
}
.topbar nav a:hover,
.topbar nav a.active {
  color: var(--cream);
  background: rgba(255, 245, 228, .09);
}
.server-pill {
  display: grid;
  flex: 0 0 auto;
  gap: 0;
  min-width: 216px;
  padding: 9px 14px 8px;
  border: 1px solid rgba(229, 179, 102, .36);
  border-radius: 14px;
  color: var(--ink);
  background: rgba(229, 179, 102, .08);
  box-shadow: inset 0 1px rgba(255, 245, 228, .08);
  text-align: left;
}
.server-pill span { color: var(--muted); font-size: .69rem; font-weight: 800; }
.server-pill strong { color: var(--gold-bright); font-size: .94rem; font-weight: 900; }
.server-pill small { color: rgba(245, 240, 231, .68); font-size: .69rem; font-weight: 700; }

.hero {
  position: relative;
  isolation: isolate;
  display: flex;
  align-items: end;
  min-height: min(820px, 100svh);
  padding: 190px max(24px, calc((100vw - 1180px) / 2)) 90px;
}
.hero::after {
  position: absolute;
  inset: auto 0 0;
  z-index: -1;
  height: 210px;
  content: "";
  background: linear-gradient(transparent, var(--canvas));
}
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(14, 12, 9, .72) 0%, rgba(14, 12, 9, .34) 52%, rgba(14, 12, 9, .48) 100%),
    linear-gradient(180deg, rgba(14, 12, 9, .28), transparent 38%, rgba(14, 12, 9, .44) 100%),
    image-set(
      url("assets/wildlands-bg.webp") type("image/webp"),
      url("assets/wildlands-bg.png") type("image/png")
    ) center / cover no-repeat;
}
.hero-copy { width: min(820px, 100%); }
.eyebrow {
  margin: 0 0 15px;
  color: var(--moss);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.hero h1,
.section h2,
.account-hero h1,
.legal-modal h2 {
  font-family: Unbounded, Inter, sans-serif;
  letter-spacing: 0;
  text-transform: uppercase;
}
.hero h1 {
  max-width: 860px;
  margin: 0;
  color: var(--cream);
  font-size: clamp(4rem, 9vw, 8.2rem);
  line-height: .88;
  text-shadow: 0 8px 0 rgba(37, 29, 20, .6), 0 24px 70px rgba(0, 0, 0, .32);
}
.hero h1 span { color: var(--gold-bright); }
.lead {
  max-width: 670px;
  margin: 28px 0 0;
  color: rgba(255, 248, 234, .88);
  font-size: 1.08rem;
  line-height: 1.7;
}
.hero-actions,
.form-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.hero-actions { margin-top: 30px; }
.hero-runtime {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px 22px;
  margin-top: 31px;
}
.status-card {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 230px;
  padding: 10px 13px;
  border: 1px solid rgba(154, 180, 125, .35);
  border-radius: 13px;
  background: rgba(18, 30, 23, .69);
  box-shadow: 0 10px 34px rgba(0, 0, 0, .16);
  backdrop-filter: blur(10px);
}
.status-card strong { display: block; color: var(--cream); font-size: .9rem; }
.status-card small { display: block; color: var(--muted); font-size: .74rem; }
.status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--danger);
  box-shadow: 0 0 0 4px rgba(212, 104, 85, .12), 0 0 18px rgba(212, 104, 85, .55);
}
.status-card.online .status-dot {
  background: var(--moss);
  box-shadow: 0 0 0 4px rgba(154, 180, 125, .12), 0 0 18px rgba(154, 180, 125, .55);
}
.hero-facts { display: flex; flex-wrap: wrap; gap: 8px; }
.hero-facts span {
  padding: 7px 10px;
  border: 1px solid rgba(255, 245, 228, .17);
  border-radius: 999px;
  color: rgba(255, 248, 234, .84);
  background: rgba(20, 17, 12, .35);
  font-size: .76rem;
  font-weight: 800;
  backdrop-filter: blur(8px);
}

.btn,
.coin-form button,
.admin-actions button,
.quick-amounts button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 17px;
  border: 1px solid transparent;
  border-radius: 12px;
  font-weight: 900;
  transition: transform .18s ease, border-color .18s ease, background-color .18s ease, color .18s ease, box-shadow .18s ease;
}
.btn:hover,
.coin-form button:hover,
.admin-actions button:hover,
.quick-amounts button:hover { transform: translateY(-2px); }
.btn.primary,
.coin-form .btn.primary {
  color: #21170e;
  border-color: rgba(255, 237, 193, .55);
  background: var(--gold-bright);
  box-shadow: 0 10px 26px rgba(185, 121, 50, .24), inset 0 -2px rgba(100, 59, 20, .22);
}
.btn.primary:hover,
.coin-form .btn.primary:hover { background: #f0c47c; box-shadow: 0 14px 32px rgba(185, 121, 50, .32); }
.btn.secondary,
.quick-amounts button,
.admin-actions button {
  border-color: var(--line-strong);
  color: var(--cream);
  background: rgba(255, 255, 255, .07);
}
.btn.secondary:hover,
.quick-amounts button:hover,
.admin-actions button:hover { border-color: rgba(229, 179, 102, .48); background: rgba(255, 255, 255, .11); }
.btn.ghost { border-color: rgba(255, 245, 228, .23); color: var(--cream); background: rgba(16, 14, 10, .26); backdrop-filter: blur(8px); }
.btn.ghost:hover { background: rgba(255, 245, 228, .11); }
.btn.small { min-height: 38px; padding: 0 13px; font-size: .84rem; }

.section {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
  padding: 100px 0;
}
.split {
  display: grid;
  grid-template-columns: minmax(250px, .72fr) minmax(0, 1.28fr);
  align-items: center;
  gap: 52px;
}
.section h2 { margin: 0; color: var(--cream); font-size: clamp(2.25rem, 4.5vw, 4rem); line-height: 1.03; }
.section p { color: var(--muted); }
.section-copy { max-width: 360px; margin: 18px 0 0; font-size: 1rem; }
.section-head { max-width: 730px; margin-bottom: 32px; }
.section-head > p:not(.eyebrow) { max-width: 580px; margin: 14px 0 0; }

.steps,
.features,
.profile-grid,
.admin-grid { display: grid; gap: 14px; }
.steps { grid-template-columns: repeat(3, 1fr); }
.steps article,
.features article,
.profile-grid article,
.server-card,
.coin-card,
.login-panel,
.cabinet,
.chronicle-card {
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  background: var(--panel);
  box-shadow: var(--shadow);
}
.steps article {
  position: relative;
  min-height: 168px;
  padding: 21px;
  overflow: hidden;
}
.steps article::after {
  position: absolute;
  right: 18px;
  bottom: 16px;
  color: rgba(255, 245, 228, .08);
  content: "→";
  font-size: 2.6rem;
  font-weight: 900;
}
.steps b {
  display: grid;
  width: 34px;
  height: 34px;
  place-items: center;
  border: 1px solid rgba(229, 179, 102, .35);
  border-radius: 10px;
  color: var(--gold-bright);
  background: rgba(229, 179, 102, .08);
  font-size: .76rem;
}
.steps span,
.profile-grid span,
.card-head span { display: block; color: var(--muted); font-size: .82rem; }
.steps span { margin-top: 28px; }
.steps strong,
.profile-grid strong,
.card-head strong { display: block; margin-top: 6px; color: var(--cream); }

.shop-section { padding-top: 32px; }
.coin-card {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .72fr);
  gap: 42px;
  padding: 32px;
  background:
    linear-gradient(110deg, rgba(229, 179, 102, .12), transparent 42%),
    rgba(31, 26, 19, .78);
}
.coin-info { align-self: center; }
.coin-info span { color: var(--gold-bright); font-size: .76rem; font-weight: 900; letter-spacing: .09em; text-transform: uppercase; }
.coin-info strong { display: block; margin: 12px 0; color: var(--cream); font-family: Unbounded, Inter, sans-serif; font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1; }
.coin-info p { max-width: 460px; margin: 0; }
.coin-form { display: grid; gap: 11px; margin: 0; }
.coin-form label { display: grid; gap: 7px; color: var(--muted-strong); font-size: .88rem; font-weight: 800; }
.coin-form input,
.login-panel input,
.settings-form input,
.settings-form select,
.admin-mini-form input,
.admin-mini-form select,
.chronicle-toolbar select {
  width: 100%;
  min-height: 50px;
  padding: 0 14px;
  border: 1px solid rgba(255, 245, 228, .18);
  border-radius: 12px;
  color: var(--cream);
  background: rgba(255, 255, 255, .07);
  outline: 0;
  transition: border-color .18s ease, background-color .18s ease, box-shadow .18s ease;
}
select option { color: #17130e; background: #f5f0e7; }
.coin-form input:focus,
.login-panel input:focus,
.settings-form input:focus,
.settings-form select:focus,
.admin-mini-form input:focus,
.admin-mini-form select:focus,
.chronicle-toolbar select:focus {
  border-color: rgba(229, 179, 102, .76);
  background: rgba(255, 255, 255, .1);
  box-shadow: 0 0 0 4px rgba(229, 179, 102, .1);
}
.quick-amounts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.quick-amounts button { min-height: 42px; color: var(--muted-strong); font-size: .9rem; }

.features { grid-template-columns: repeat(3, 1fr); }
.features article {
  position: relative;
  min-height: 174px;
  padding: 22px;
  overflow: hidden;
  transition: transform .2s ease, border-color .2s ease, background-color .2s ease;
}
.features article::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 3px;
  height: 100%;
  content: "";
  background: transparent;
  transition: background-color .2s ease;
}
.features article:hover { transform: translateY(-4px); border-color: rgba(229, 179, 102, .34); background: rgba(38, 32, 23, .88); }
.features article:hover::before { background: var(--gold-bright); }
.features h3 { margin: 0 0 10px; color: var(--cream); font-size: 1.08rem; }
.features p { margin: 0; font-size: .92rem; }

.account-page,
.chronicle-page {
  width: min(1220px, calc(100% - 40px));
  min-height: 100svh;
  margin: 0 auto;
  padding: 152px 0 90px;
}
.account-hero {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 30px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--line);
}
.account-hero h1 { margin: 0; color: var(--cream); font-size: clamp(2.3rem, 4.6vw, 4.3rem); line-height: 1; }
.account-hero p { max-width: 650px; margin: 14px 0 0; color: var(--muted); }
.account-status {
  min-width: 260px;
  padding: 14px 16px;
  border: 1px solid rgba(154, 180, 125, .22);
  border-radius: 14px;
  color: var(--muted-strong);
  background: rgba(31, 49, 40, .38);
}
.account-layout { display: grid; grid-template-columns: 320px minmax(0, 1fr); gap: 18px; margin-top: 24px; align-items: start; }
.login-panel,
.cabinet { padding: 22px; }
.login-panel[hidden] + .cabinet { grid-column: 1 / -1; }
.login-panel h2 { margin: 0 0 15px; color: var(--cream); }
form { display: grid; gap: 11px; }
.muted { color: var(--muted); }
.cabinet-head { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding-bottom: 17px; border-bottom: 1px solid var(--line); }
.cabinet-head span { color: var(--muted); font-size: .82rem; }
.cabinet-head strong { display: block; color: var(--cream); font-size: 1.45rem; }
.tabs { display: flex; flex-wrap: wrap; align-items: center; gap: 7px; margin: 19px 0; }
.tabs button,
.admin-actions button {
  min-height: 40px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--muted-strong);
  background: rgba(255, 255, 255, .045);
  font-weight: 800;
}
.tabs button.active { color: #21170e; border-color: rgba(255, 237, 193, .5); background: var(--gold-bright); }
.tab-map-link { margin-left: auto; }
.tab-pane { display: none; }
.tab-pane.active { display: block; }
.profile-grid { grid-template-columns: repeat(3, 1fr); }
.profile-grid article { padding: 17px; box-shadow: none; }
.cabinet-shop { display: grid; grid-template-columns: minmax(0, 1fr) minmax(270px, .7fr); gap: 20px; align-items: center; margin-top: 16px; padding: 20px; border: 1px solid rgba(229, 179, 102, .2); border-radius: 16px; background: rgba(229, 179, 102, .06); }
.cabinet-shop h3 { margin: 0 0 5px; color: var(--cream); }
.cabinet-shop p { margin: 0; color: var(--muted); }
.coin-form.compact { grid-template-columns: minmax(110px, 1fr) auto; align-items: center; }
.orders { display: grid; gap: 9px; color: var(--muted); }
.order { padding: 14px; border: 1px solid var(--line); border-radius: 13px; background: rgba(255, 255, 255, .045); }
.order strong { color: var(--cream); }
.order a { color: var(--gold-bright); font-weight: 900; }

.admin-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.server-card { padding: 18px; box-shadow: none; }
.server-card.wide { grid-column: 1 / -1; }
.card-head { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.admin-actions { display: flex; flex-wrap: wrap; gap: 8px; }
pre { min-height: 104px; margin: 14px 0 0; padding: 13px; overflow: auto; border: 1px solid var(--line); border-radius: 12px; color: var(--muted); background: rgba(0, 0, 0, .22); white-space: pre-wrap; }
.settings-form { grid-template-columns: 1fr 1fr; }
.settings-form label { display: grid; gap: 6px; color: var(--muted); font-size: .85rem; }
.check-row { grid-template-columns: auto 1fr; align-items: center; min-height: 50px; padding: 0 13px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255, 255, 255, .04); }
.check-row input { width: auto; min-height: auto; }
.settings-form button { grid-column: 1 / -1; justify-self: start; }
.ratings-help { display: grid; gap: 8px; margin-top: 12px; color: var(--muted); font-size: .88rem; }
.ratings-help span { padding: 10px 11px; border: 1px solid var(--line); border-radius: 10px; background: rgba(255, 255, 255, .04); }
.admin-mini-form { display: grid; grid-template-columns: 1fr 1fr auto; gap: 9px; margin-top: 10px; }
.npc-form { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.npc-form button,
.rcon-form button { grid-column: auto; }
.rcon-form { grid-template-columns: minmax(0, 1fr) auto; }

.admin-map {
  position: relative;
  min-height: 390px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #201a12;
}
.map-ring { position: absolute; inset: 10%; border: 1px dashed rgba(229, 179, 102, .5); border-radius: 50%; }
.map-ring.protect { inset: 35%; border-color: rgba(154, 180, 125, .8); background: rgba(154, 180, 125, .08); }
.map-point { position: absolute; left: var(--x); top: var(--y); transform: translate(-50%, -50%); padding: 7px 10px; border: 1px solid rgba(255, 245, 228, .27); border-radius: 999px; color: #25180e; background: var(--cream); box-shadow: 0 8px 24px rgba(0, 0, 0, .22); font-size: .78rem; font-weight: 900; white-space: nowrap; }

.chronicle-card { padding: 22px; }
.chronicle-toolbar { display: flex; align-items: end; justify-content: space-between; gap: 16px; padding-bottom: 16px; border-bottom: 1px solid var(--line); }
.chronicle-toolbar span { display: block; margin-bottom: 6px; color: var(--muted); font-size: .82rem; font-weight: 800; }
.chronicle-toolbar select { min-width: 220px; min-height: 42px; }
.chronicle-list { display: grid; gap: 10px; max-height: 560px; overflow: auto; padding-top: 16px; }
.chronicle-item { padding: 14px 16px; border: 1px solid var(--line); border-radius: 13px; background: rgba(255, 255, 255, .045); }
.chronicle-item time { display: block; margin-bottom: 4px; color: var(--gold-bright); font-weight: 900; }
.chronicle-item p { margin: 0; color: var(--muted-strong); }

.footer {
  width: min(1180px, calc(100% - 40px));
  margin: 10px auto 26px;
  display: grid;
  grid-template-columns: minmax(260px, 1fr) auto minmax(180px, auto);
  align-items: center;
  gap: 20px;
  padding: 19px 20px;
  border-top: 1px solid var(--line);
}
.seller-card { display: grid; gap: 3px; }
.seller-card strong { color: var(--cream); font-family: Unbounded, Inter, sans-serif; font-size: .78rem; letter-spacing: .04em; text-transform: uppercase; }
.seller-card span { color: var(--muted); font-size: .82rem; }
.legal-links { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 4px 14px; }
.legal-links button { min-height: auto; padding: 4px 0; border: 0; color: rgba(245, 240, 231, .78); background: transparent; font-size: .82rem; font-weight: 800; }
.legal-links button:hover { color: var(--gold-bright); }
.payment-card { justify-self: end; display: flex; align-items: center; gap: 10px; padding: 9px 11px; border: 1px solid rgba(255, 221, 45, .32); border-radius: 13px; color: var(--muted-strong); background: rgba(255, 221, 45, .06); }
.tbank-mark,
.tbank-mark svg { display: block; width: 32px; height: 32px; }
.payment-card b { color: var(--cream); }

.legal-modal[hidden] { display: none; }
.legal-modal { position: fixed; inset: 0; z-index: 80; display: grid; place-items: center; padding: 18px; }
.legal-modal__overlay { position: absolute; inset: 0; background: rgba(9, 8, 6, .76); backdrop-filter: blur(9px); }
.legal-modal__dialog { position: relative; width: min(720px, 100%); max-height: min(760px, calc(100svh - 36px)); overflow: auto; padding: 26px; border: 1px solid var(--line-strong); border-radius: 20px; background: #1e1912; box-shadow: var(--shadow-deep); }
.legal-modal__close { position: absolute; top: 12px; right: 12px; display: grid; width: 38px; height: 38px; place-items: center; border: 1px solid var(--line-strong); border-radius: 10px; color: var(--cream); background: rgba(255,255,255,.05); font-size: 1.5rem; line-height: 1; }
.legal-modal h2 { margin: 0 48px 16px 0; color: var(--cream); font-size: 1.35rem; }
.legal-modal__content { display: grid; gap: 12px; color: var(--muted-strong); }
.legal-modal__content a { color: var(--gold-bright); font-weight: 900; }
.legal-modal__content p,
.legal-modal__content ul,
.legal-modal__content dl { margin: 0; }
.legal-modal__content ul { padding-left: 20px; }
.legal-modal__content dl { display: grid; gap: 8px; }
.legal-modal__content dt { color: var(--muted); font-size: .76rem; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.legal-modal__content dd { margin: 2px 0 0; }

.toast { position: fixed; right: 18px; bottom: 18px; z-index: 60; max-width: min(420px, calc(100% - 36px)); padding: 13px 15px; border: 1px solid rgba(255, 237, 193, .5); border-radius: 13px; color: #21170e; background: var(--gold-bright); box-shadow: 0 16px 40px rgba(0, 0, 0, .34); font-weight: 900; opacity: 0; transform: translateY(14px); pointer-events: none; transition: opacity .18s ease, transform .18s ease; }
.toast.show { opacity: 1; transform: translateY(0); }

@media (max-width: 1040px) {
  .hero { min-height: 760px; }
  .split,
  .coin-card,
  .account-layout,
  .admin-grid,
  .cabinet-shop { grid-template-columns: 1fr; }
  .account-hero { align-items: start; flex-direction: column; }
  .footer { grid-template-columns: 1fr; }
  .legal-links { justify-content: flex-start; }
  .payment-card { justify-self: start; }
  .admin-mini-form,
  .npc-form,
  .rcon-form { grid-template-columns: 1fr; }
}

@media (max-width: 820px) {
  .topbar { top: 10px; width: calc(100% - 20px); min-height: 62px; flex-wrap: wrap; padding: 8px 10px; border-radius: 17px; }
  .brand { font-size: .8rem; }
  .brand img { width: 36px; height: 36px; border-radius: 11px; }
  .server-pill { min-width: 150px; padding: 6px 9px; border-radius: 11px; }
  .server-pill span,
  .server-pill small { display: none; }
  .server-pill strong { font-size: .77rem; }
  .topbar nav { order: 3; width: 100%; justify-content: flex-start; overflow-x: auto; padding: 2px 0 0; }
  .topbar nav a { flex: 0 0 auto; padding: 7px 9px; font-size: .77rem; }
  .hero { min-height: 780px; padding: 178px 22px 66px; align-items: end; }
  .hero h1 { font-size: clamp(3rem, 15vw, 5rem); }
  .lead { margin-top: 21px; font-size: .98rem; line-height: 1.62; }
  .hero-runtime { align-items: stretch; }
  .status-card { width: 100%; }
  .section,
  .account-page,
  .chronicle-page,
  .footer { width: min(100% - 28px, 1180px); }
  .section { padding: 70px 0; }
  .steps,
  .features,
  .profile-grid,
  .settings-form,
  .quick-amounts,
  .coin-form.compact { grid-template-columns: 1fr; }
  .coin-card { gap: 26px; padding: 22px; }
  .features article { min-height: 150px; }
  .account-page,
  .chronicle-page { padding-top: 126px; padding-bottom: 55px; }
  .account-status { min-width: 0; width: 100%; }
  .login-panel,
  .cabinet,
  .chronicle-card { padding: 17px; border-radius: 18px; }
  .tabs { gap: 6px; }
  .tabs button { flex: 1 1 auto; }
  .tab-map-link { width: 100%; margin-left: 0; }
  .chronicle-toolbar { align-items: stretch; flex-direction: column; }
  .chronicle-toolbar select { width: 100%; }
  .footer { gap: 14px; padding: 18px 0; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; transition-duration: .01ms !important; animation-duration: .01ms !important; }
}

/* =========================================================
   CINEMATIC UPGRADE LAYER (2026-06-24) — тёмный кинематограф
   Переопределения в конце файла: визуал без ломки разметки/JS.
   ========================================================= */
:root {
  --canvas: #0b0a08;
  --canvas-soft: #131009;
  --gold: #c98a3c;
  --gold-bright: #f3c578;
  --grad-gold: linear-gradient(135deg, #ffe6b0 0%, #f3c578 38%, #c98a3c 100%);
  --glow-gold: 0 0 34px rgba(243, 197, 120, .35);
  --glow-moss: 0 0 30px rgba(154, 180, 125, .35);
  --panel: rgba(24, 20, 14, .62);
  --shadow: 0 24px 80px rgba(0, 0, 0, .45);
  --shadow-deep: 0 40px 120px rgba(0, 0, 0, .6);
}

/* Амбиентное живое свечение + виньетка поверх фона */
body::before {
  opacity: 1;
  background:
    radial-gradient(820px 460px at 18% -8%, rgba(243, 197, 120, .14), transparent 60%),
    radial-gradient(760px 520px at 88% 4%, rgba(110, 150, 95, .12), transparent 62%),
    radial-gradient(1200px 800px at 50% 120%, rgba(243, 197, 120, .06), transparent 60%);
  animation: wlAmbient 18s ease-in-out infinite alternate;
}
body::after {
  position: fixed; inset: 0; z-index: -1; content: ""; pointer-events: none;
  background: radial-gradient(130% 120% at 50% 42%, transparent 58%, rgba(0,0,0,.55) 100%);
}
@keyframes wlAmbient {
  0%   { transform: translate3d(0,0,0) scale(1); }
  100% { transform: translate3d(-2%, 1.5%, 0) scale(1.08); }
}

/* Топбар — глубже стекло */
.topbar {
  background: linear-gradient(180deg, rgba(30, 25, 17, .82), rgba(18, 15, 10, .7));
  border-color: rgba(243, 197, 120, .16);
  box-shadow: 0 18px 60px rgba(0,0,0,.4), inset 0 1px rgba(255,245,228,.06);
}
.topbar nav a.active, .topbar nav a:hover { background: rgba(243, 197, 120, .12); }
.server-pill { background: linear-gradient(180deg, rgba(243,197,120,.12), rgba(243,197,120,.04)); }

/* ГЕРОЙ — кинематограф */
.hero-bg { animation: wlKenBurns 26s ease-in-out infinite alternate; transform-origin: 60% 40%; }
@keyframes wlKenBurns {
  0%   { transform: scale(1.02); filter: saturate(1.02) contrast(1.02); }
  100% { transform: scale(1.12) translateY(-1.5%); filter: saturate(1.12) contrast(1.06); }
}
.hero::before {
  position: absolute; inset: 0; z-index: -1; content: ""; pointer-events: none;
  background: linear-gradient(75deg, rgba(11,10,8,.78) 0%, rgba(11,10,8,.25) 46%, transparent 70%);
}
.hero-copy { animation: wlRise .9s cubic-bezier(.2,.7,.2,1) both; }
.eyebrow { color: var(--moss); text-shadow: 0 0 18px rgba(154,180,125,.4); }
.hero h1 {
  background: linear-gradient(180deg, #fff7ea 0%, #f3c578 72%, #c98a3c 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
  text-shadow: none;
  filter: drop-shadow(0 12px 40px rgba(0,0,0,.5));
}
.hero h1 span {
  color: transparent;
  background: linear-gradient(180deg, #fff2d6, #f3c578);
  -webkit-background-clip: text; background-clip: text;
}

/* Кнопки — золото с бликом и свечением */
.btn.primary, .coin-form .btn.primary {
  position: relative; overflow: hidden;
  background: var(--grad-gold);
  border-color: rgba(255, 240, 205, .6);
  box-shadow: 0 14px 34px rgba(201,138,60,.35), var(--glow-gold), inset 0 1px rgba(255,255,255,.4);
}
.btn.primary::after {
  position: absolute; top: 0; left: -120%; width: 60%; height: 100%; content: "";
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.55), transparent);
  transform: skewX(-18deg); transition: left .6s ease;
}
.btn.primary:hover::after { left: 130%; }
.btn.primary:hover, .coin-form .btn.primary:hover {
  background: linear-gradient(135deg,#fff0cf,#f3c578 45%,#c98a3c);
  box-shadow: 0 18px 44px rgba(201,138,60,.45), 0 0 44px rgba(243,197,120,.5);
}

/* Карточки/панели — стекло, верхний акцент, hover-свечение */
.steps article, .features article, .profile-grid article,
.server-card, .coin-card, .login-panel, .cabinet, .chronicle-card, .account-status {
  background:
    linear-gradient(180deg, rgba(255,245,228,.05), rgba(255,245,228,.01)),
    rgba(20, 17, 12, .6);
  border-color: rgba(243, 197, 120, .14);
  box-shadow: var(--shadow), inset 0 1px rgba(255,245,228,.05);
  backdrop-filter: blur(14px) saturate(115%);
  -webkit-backdrop-filter: blur(14px) saturate(115%);
}
.steps article:hover, .features article:hover {
  border-color: rgba(243,197,120,.42);
  box-shadow: 0 26px 70px rgba(0,0,0,.5), 0 0 40px rgba(243,197,120,.16);
}
.coin-card {
  background:
    radial-gradient(120% 140% at 100% 0%, rgba(243,197,120,.16), transparent 48%),
    linear-gradient(180deg, rgba(255,245,228,.05), rgba(255,245,228,.01)),
    rgba(22, 18, 12, .72);
  border-color: rgba(243,197,120,.26);
  box-shadow: var(--shadow), var(--glow-gold);
}
.coin-info strong {
  background: var(--grad-gold); -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* Заголовки секций — лёгкий золотой акцент на первой строке */
.section-head .eyebrow, .account-hero .eyebrow { color: var(--gold-bright); text-shadow: var(--glow-gold); }

/* Статус-дот живее */
.status-card.online .status-dot { animation: wlPulse 1.8s ease-in-out infinite; }
@keyframes wlPulse {
  0%,100% { box-shadow: 0 0 0 4px rgba(154,180,125,.14), 0 0 18px rgba(154,180,125,.6); }
  50%     { box-shadow: 0 0 0 7px rgba(154,180,125,.05), 0 0 26px rgba(154,180,125,.9); }
}

/* Появление секций на главной */
.page.active .section, .page.active .hero-copy { animation: wlRise .8s cubic-bezier(.2,.7,.2,1) both; }
.page.active .section:nth-of-type(2) { animation-delay: .05s; }
.page.active .section:nth-of-type(3) { animation-delay: .1s; }
.page.active .section:nth-of-type(4) { animation-delay: .15s; }
@keyframes wlRise { from { opacity: 0; transform: translateY(26px); } to { opacity: 1; transform: translateY(0); } }

/* Вкладки/кнопки активные — золото */
.tabs button.active { background: var(--grad-gold); box-shadow: var(--glow-gold); }

/* Тосты — золото с бликом */
.toast { background: var(--grad-gold); box-shadow: 0 18px 46px rgba(0,0,0,.5), var(--glow-gold); }

@media (prefers-reduced-motion: reduce) {
  .hero-bg, body::before, .status-card.online .status-dot,
  .page.active .section, .page.active .hero-copy, .hero-copy { animation: none !important; }
}

/* === Правки по фидбеку: заголовок целиком + убрать hero-runtime === */
.hero-runtime { display: none !important; }
.hero h1 {
  font-size: clamp(2.6rem, 8.2vw, 6rem);
  line-height: .92;
  max-width: 100%;
  overflow-wrap: normal;
}
@media (max-width: 820px) {
  .hero h1 { font-size: clamp(2.4rem, 13vw, 4.4rem); }
}

/* Убрать зелёную надпись над заголовком героя */
.hero .eyebrow { display: none !important; }

/* === Соцсети (над футером) и иконки оплаты === */
.socials { width: min(1180px, calc(100% - 40px)); margin: 30px auto 0; display: flex; justify-content: center; gap: 14px; }
.social-btn { display: grid; place-items: center; width: 50px; height: 50px; border-radius: 15px; border: 1px solid rgba(243,197,120,.18); background: rgba(20,17,12,.6); box-shadow: var(--shadow); backdrop-filter: blur(10px); transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.social-btn svg { width: 30px; height: 30px; display: block; }
.social-btn:hover { transform: translateY(-3px); border-color: rgba(243,197,120,.5); box-shadow: 0 18px 40px rgba(0,0,0,.5), 0 0 26px rgba(243,197,120,.22); }
.payment-card { justify-self: end; display: flex; align-items: center; gap: 10px; padding: 8px 10px; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.04); }
.pay-icon { display: grid; place-items: center; height: 30px; }
.pay-icon svg { height: 30px; width: auto; display: block; }

/* === Соцсети + голосование + ровные иконки оплаты (финальная доводка) === */
.socials { width: min(1180px, calc(100% - 40px)); margin: 36px auto 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 18px 30px; }
.socials-block { display: flex; flex-direction: column; align-items: center; gap: 11px; }
.socials-title { color: var(--muted-strong); font-size: .8rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.socials-row { display: flex; gap: 14px; }
.vote-btn { display: inline-flex; align-items: center; gap: 9px; min-height: 50px; padding: 0 22px; border-radius: 15px; border: 1px solid rgba(243,197,120,.55); color: #21170e; background: var(--grad-gold); font-weight: 900; font-size: .98rem; box-shadow: 0 14px 34px rgba(201,138,60,.35), var(--glow-gold); transition: transform .18s ease, box-shadow .18s ease; }
.vote-btn svg { width: 20px; height: 20px; }
.vote-btn:hover { transform: translateY(-3px); box-shadow: 0 18px 46px rgba(201,138,60,.45), 0 0 44px rgba(243,197,120,.55); }
.payment-card { justify-self: end; display: flex; align-items: center; gap: 9px; padding: 7px 9px; border: 1px solid var(--line); border-radius: 14px; background: rgba(255,255,255,.04); }
.pay-icon { display: grid; place-items: center; height: 34px; }
.pay-icon svg { height: 34px; width: auto; display: block; border-radius: 7px; box-shadow: 0 3px 8px rgba(0,0,0,.28); }
.vote-list { list-style: none; padding: 0; margin: 8px 0 0; display: grid; gap: 8px; }
.vote-list li { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 11px 14px; border: 1px solid var(--line); border-radius: 12px; background: rgba(255,255,255,.04); }
.vote-list a { color: var(--gold-bright); font-weight: 900; }
.vote-list span { color: var(--muted); font-size: .8rem; }
@media (max-width: 820px) { .socials { gap: 16px; } .vote-list li { flex-direction: column; align-items: flex-start; gap: 4px; } }

/* === Голосовалки (сетка с иконками) === */
.vote-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 10px; margin-top: 6px; }
.vote-tile { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 13px; background: rgba(255,255,255,.04); color: var(--cream); font-weight: 800; transition: transform .16s ease, border-color .16s ease, background-color .16s ease; }
.vote-tile img { width: 26px; height: 26px; border-radius: 6px; flex: 0 0 auto; background: rgba(255,255,255,.06); }
.vote-tile span { font-size: .92rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vote-tile:hover { transform: translateY(-2px); border-color: rgba(243,197,120,.5); background: rgba(243,197,120,.08); }

/* === Золотая разделительная полоса === */
.gold-divider { width: min(1180px, calc(100% - 40px)); height: 2px; margin: 44px auto 0; border-radius: 2px; background: linear-gradient(90deg, transparent, rgba(243,197,120,.65), rgba(243,197,120,.95), rgba(243,197,120,.65), transparent); box-shadow: 0 0 18px rgba(243,197,120,.4); }

/* === Низ: голосование слева, соцсети справа === */
.socials { width: min(1180px, calc(100% - 40px)); margin: 26px auto 0; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.socials-block { display: flex; flex-direction: column; align-items: flex-end; gap: 11px; }
.socials-title { text-align: right; color: var(--muted-strong); font-size: .8rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }

/* === 4 шага «Как начать» === */
.steps-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1040px) { .steps-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .vote-grid { grid-template-columns: 1fr; } .steps-4 { grid-template-columns: 1fr; } .socials { flex-direction: column-reverse; gap: 18px; } .socials-block { align-items: center; } .socials-title { text-align: center; } }
