/* ============================================================================
   dn-ui.css — БАЗОВЫЕ КОМПОНЕНТЫ DragoNightly (UI-kit).
   Перенесено из docs/design3 максимально дословно (значения d3), токены — из
   dn-theme.css (:root). Документация и витрина — /uikit, docs/site/UIKIT.md.

   Состояния интерактивных контролов:
     normal · .is-selected (латунный inset) · .is-pressed (сдвиг+заливка)
     .is-active/.is-focus (void-blue рамка/glow) · :disabled/.is-disabled
   Грузится ПОСЛЕ dn-theme.css.
   ============================================================================ */

/* ---- Кнопки (полностью из d3: значения, анимации, подсветки) ------------- */
/* d3 .btn: шрифт наследуется (Manrope, обычный вес, размер body) — font: inherit. */
.dn-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px; flex: 0 0 auto;
  min-height: 40px; padding: 9px 15px;
  border: 1px solid rgba(214,180,95,0.42); border-radius: 8px;
  color: var(--fg); font: inherit; line-height: normal; cursor: pointer; text-decoration: none;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease, color 120ms ease, opacity 120ms ease;
}
.dn-btn-sm { min-height: 34px; padding: 7px 11px; font-size: 13px; }
.dn-btn-lg { min-height: 48px; padding: 13px 18px; }
.dn-btn-block { width: 100%; }
.dn-btn-primary { background: linear-gradient(180deg, rgba(243,212,122,0.24), rgba(214,180,95,0.12)); color: var(--brand-soft); }
.dn-btn-secondary { border-color: rgba(42,168,255,0.42); background: rgba(16,46,67,0.62); color: #d4eeff; }
.dn-btn-ghost { background: transparent; color: var(--fg-dim); }
.dn-btn-danger { border-color: rgba(212,71,91,0.50); background: linear-gradient(180deg, rgba(212,71,91,0.22), rgba(212,71,91,0.10)); color: #ffd6dd; }
.dn-btn:hover, .dn-iconbtn:hover, .dn-chip:hover { transform: translateY(-1px); border-color: var(--brand); }
.dn-btn-danger:hover { border-color: var(--red); box-shadow: 0 0 20px rgba(212,71,91,0.18); }
.dn-btn .ic { font-size: 16px; }
.dn-btn-trunc { max-width: 168px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; display: inline-block; }

.dn-iconbtn { display: grid; width: 40px; height: 40px; place-items: center; flex: 0 0 auto;
  border: 1px solid rgba(214,180,95,0.36); border-radius: 8px; background: rgba(31,30,38,0.72);
  color: var(--brand-soft); cursor: pointer; font: inherit; line-height: normal;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease, color 120ms ease; }

/* состояния (общие модификаторы, как в d3) */
.is-selected { box-shadow: inset 0 0 0 1px rgba(243,212,122,0.42), 0 0 18px rgba(214,180,95,0.12); }
.is-pressed { transform: translateY(1px); background: rgba(214,180,95,0.2); }
.is-active { border-color: var(--accent) !important; box-shadow: 0 0 18px rgba(42,168,255,0.26); }
.dn-btn:disabled, .dn-iconbtn:disabled, .dn-input:disabled, .dn-textarea:disabled, .dn-select:disabled, .is-disabled {
  opacity: 0.42; cursor: not-allowed; filter: grayscale(0.7); }
.dn-btn:disabled:hover, .dn-iconbtn:disabled:hover, .dn-chip.is-disabled:hover {
  transform: none;
}
.dn-check.is-disabled, .dn-check:has(input:disabled) {
  cursor: not-allowed;
}
.dn-check.is-disabled input, .dn-check input:disabled {
  cursor: not-allowed;
}

.dn-btn:focus-visible, .dn-iconbtn:focus-visible, .dn-chip:focus-visible,
.dn-input:focus-visible, .dn-textarea:focus-visible, .dn-select:focus-visible,
.dn-check:focus-within, .field-checkbox:focus-within,
.is-focus {
  outline: none;
  border-color: rgba(42,168,255,0.72) !important;
  box-shadow: 0 0 0 3px rgba(42,168,255,0.12), 0 0 18px rgba(42,168,255,0.20);
}

/* ---- Поля ввода: ДВА режима ----------------------------------------------
   Базовый — НАШ «простой» (плоский). Модификатор .dn-field-pro — «пользовательский»
   (как d3 .text-input: латунная рамка + полупрозрачный фон). Оба во всех статусах
   (фокус void-ring, .is-selected/.is-pressed/.is-active/:disabled). */
.dn-input, .dn-textarea, .dn-select {
  width: 100%; min-height: 40px; padding: 9px 12px; color: var(--fg); font: inherit;
  border: 1px solid var(--border-hi); border-radius: 8px; background: var(--bg-soft);
  transition: border-color 120ms ease, box-shadow 120ms ease, background 120ms ease; }
.dn-textarea { min-height: 96px; resize: vertical; }
.dn-input::placeholder, .dn-textarea::placeholder { color: var(--fg-faint); }
.dn-input:hover, .dn-textarea:hover, .dn-select:hover { border-color: rgba(214,180,95,0.38); background: rgba(31,30,38,0.78); }
.dn-input:focus, .dn-textarea:focus, .dn-select:focus { outline: none;
  border-color: rgba(42,168,255,0.7); box-shadow: 0 0 0 3px rgba(42,168,255,0.12); }
.dn-select { appearance: none; cursor: pointer;
  background-image: linear-gradient(45deg, transparent 50%, var(--fg-dim) 50%), linear-gradient(135deg, var(--fg-dim) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%; background-size: 5px 5px; background-repeat: no-repeat; }
/* «пользовательский» режим = d3 .text-input */
.dn-field-pro { border-color: rgba(214,180,95,0.24); background: rgba(17,16,20,0.76); }

.dn-field { display: grid; gap: 7px; }
.dn-field-label {
  display: block; margin: 0; color: var(--brand); font-family: var(--font-mono);
  font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
}
.dn-field-hint, .dn-field-note {
  color: var(--fg-faint); font-family: var(--font-sans); font-size: 13px;
  letter-spacing: 0; line-height: 1.45; text-transform: none;
}
.dn-field-error { color: #F3C4CC; font-size: 13px; line-height: 1.45; }
.dn-field.is-error .dn-input, .dn-field.is-error .dn-textarea, .dn-field.is-error .dn-select,
.dn-input.is-error, .dn-textarea.is-error, .dn-select.is-error {
  border-color: rgba(212,71,91,0.72);
  box-shadow: 0 0 0 3px rgba(212,71,91,0.10);
}
.dn-field.is-success .dn-input, .dn-field.is-success .dn-textarea, .dn-field.is-success .dn-select,
.dn-input.is-success, .dn-textarea.is-success, .dn-select.is-success {
  border-color: rgba(76,175,122,0.68);
  box-shadow: 0 0 0 3px rgba(76,175,122,0.10);
}
.dn-form-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap: 14px; }
.dn-form-stack { display: grid; gap: 14px; }
.dn-form-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: flex-end; }

/* ---- Чекбокс / радио (из d3 .check-row), единый вид для обоих ------------- */
.dn-check { display: flex; align-items: center; gap: 10px; padding: 10px 12px; cursor: pointer;
  border: 1px solid rgba(214,180,95,0.22); border-radius: 8px; color: var(--fg-dim); background: rgba(17,16,20,0.54);
  transition: border-color 120ms ease, background 120ms ease, box-shadow 120ms ease; }
.dn-check:hover { border-color: rgba(214,180,95,0.4); }
.dn-check input { accent-color: var(--brand); width: 17px; height: 17px; flex: 0 0 auto; cursor: pointer; }
.dn-check input[type="radio"] { border-radius: 50%; }

/* ---- Чип / таб (полностью из d3) ----------------------------------------- */
.dn-chip { display: inline-flex; align-items: center; gap: 7px; min-height: 34px; padding: 7px 12px;
  border: 1px solid rgba(214,180,95,0.26); border-radius: 999px; color: var(--fg-dim);
  background: rgba(17,16,20,0.62); cursor: pointer; font: inherit; line-height: normal;
  transition: transform 120ms ease, border-color 120ms ease, color 120ms ease, background 120ms ease; }
.dn-chip.is-current { color: var(--brand-soft); background: rgba(214,180,95,0.14); border-color: rgba(214,180,95,0.4); }

/* ---- Поверхности (d3 .surface-samples) ----------------------------------- */
.dn-surfs { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px,1fr)); gap: 10px; }
.dn-surf { min-height: 88px; padding: 12px; border: 1px solid rgba(214,180,95,0.2); border-radius: 8px;
  color: var(--fg-dim); font-family: var(--font-mono); font-size: 12px; }
.dn-surf-normal { background: var(--bg-soft); }
.dn-surf-selected { background: rgba(214,180,95,0.13); }
.dn-surf-pressed { background: rgba(214,180,95,0.22); transform: translateY(1px); }
.dn-surf-active { background: rgba(42,168,255,0.13); border-color: var(--accent) !important; }
.dn-surf-disabled { background: rgba(31,30,38,0.42); opacity: 0.42; }
/* «игровой» фон-поверхность (аркан d3: void-glow + латунь) — под игровые блоки/uikit2 */
.dn-bg-arcane { background:
  radial-gradient(circle at 70% 10%, rgba(42,168,255,0.16), transparent 28rem),
  linear-gradient(135deg, rgba(214,180,95,0.07), transparent 38%),
  rgba(7,8,11,0.56); }

/* ---- Карточки: ТРИ тира — простая / пользовательская / игровая ----------- */
.dn-grid { display: grid; gap: 18px; grid-template-columns: repeat(auto-fit, minmax(260px,1fr)); }
.dn-card, .dn-card-simple, .dn-card-game {
  position: relative; padding: 24px 22px; border-radius: 14px; overflow: hidden;
  border: 1px solid var(--border); transition: border-color .2s, transform .12s, box-shadow .2s; }
.dn-card h3, .dn-card-simple h3, .dn-card-game h3 { font-family: var(--font-sans); font-weight: 700; font-size: 17px; margin: 0 0 8px; color: var(--fg); }
.dn-card p, .dn-card-simple p, .dn-card-game p { margin: 0; color: var(--fg-dim); font-size: 14.5px; line-height: 1.55; }
.dn-card .dn-card-ic, .dn-card-simple .dn-card-ic, .dn-card-game .dn-card-ic { display:block; margin-bottom: 12px; font-size: 22px; color: var(--brand-soft); }
/* простая */
.dn-card-simple { background: var(--bg-soft); }
.dn-card-simple:hover { border-color: var(--border-hi); transform: translateY(-2px); }
/* пользовательская (латунный уголок + ховер-glow) */
.dn-card { background: linear-gradient(180deg, var(--bg-card), var(--bg-soft)); }
.dn-card:hover { border-color: var(--brand-strong); transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,0.45), 0 0 0 1px var(--brand-glow); }
.dn-card::before { content:""; position:absolute; top:0; left:0; width:34px; height:34px;
  border-top: 1.5px solid var(--brand-strong); border-left: 1.5px solid var(--brand-strong);
  border-top-left-radius: 14px; opacity: .55; }
/* игровая (аркан-фон + латунно-void рамка + орнамент-уголок) */
.dn-card-game { border-color: rgba(214,180,95,0.34);
  background:
    radial-gradient(circle at 78% 8%, rgba(42,168,255,0.14), transparent 22rem),
    linear-gradient(135deg, rgba(214,180,95,0.08), transparent 42%),
    linear-gradient(180deg, var(--bg-card), #0c0b10);
  box-shadow: inset 0 0 0 1px rgba(214,180,95,0.06); }
.dn-card-game:hover { border-color: var(--accent); transform: translateY(-2px);
  box-shadow: 0 16px 44px rgba(0,0,0,0.5), 0 0 26px rgba(42,168,255,0.18); }
.dn-card-game::before { content:""; position:absolute; top:8px; left:8px; width:40px; height:40px; opacity:.8;
  background: url('/assets/img/ornaments/corner-tl.png') top left / contain no-repeat; }

/* ---- Eyebrow (надзаголовок) ---------------------------------------------- */
/* основной — ровный латунный mono-капс БЕЗ черты; размеры/разрядка — из токенов типографики */
.dn-eyebrow { margin: 0 0 12px; color: var(--brand);
  font-family: var(--ty-eyebrow-ff); font-size: var(--ty-eyebrow-fs);
  letter-spacing: var(--ty-eyebrow-ls); text-transform: var(--ty-eyebrow-tt); }
/* доп. вариант — с латунной чертой слева */
.dn-eyebrow-line { display: inline-flex; align-items: center; gap: 10px; }
.dn-eyebrow-line::before { content:""; flex: 0 0 auto; width: 26px; height: 1px;
  background: linear-gradient(90deg, var(--brand), transparent); }

/* ---- Отчёркивания (разделители) ----------------------------------------- */
.dn-rule { width: min(1180px, 92%); margin: 6px auto; height: 1px; border: 0; position: relative;
  background: linear-gradient(90deg, transparent 0%, var(--border) 10%, var(--brand-strong) 50%, var(--border) 90%, transparent 100%); }
.dn-rule::after { content:"✦"; position:absolute; left:50%; top:50%; transform: translate(-50%,-50%);
  color: var(--brand); background: var(--bg); padding: 0 14px; font-size: 12px; }
.dn-rule-wide { width: 100%;
  background: linear-gradient(90deg, transparent 0%, var(--border) 16%, var(--brand-strong) 50%, var(--border) 84%, transparent 100%); }

/* ---- Шрифт-хелперы ------------------------------------------------------- */
.dn-font-display { font-family: var(--font-display); }
.dn-font-sans { font-family: var(--font-sans); }
.dn-font-serif { font-family: var(--font-serif); }
.dn-font-mono { font-family: var(--font-mono); }

/* ===========================================================================
   Compatibility components for current gm_panel_site pages
   =========================================================================== */

.btn-primary:not(.dn-btn),
.btn-secondary:not(.dn-btn),
.btn-danger,
.btn-ghost:not(.dn-btn) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 9px 15px;
  border-radius: 8px;
  border: 1px solid rgba(214,180,95,0.42);
  font: inherit;
  line-height: normal;
  text-decoration: none;
  cursor: pointer;
  transition: transform 120ms ease, border-color 120ms ease, background 120ms ease, color 120ms ease, opacity 120ms ease;
}

.btn-primary:not(.dn-btn) {
  color: var(--brand-soft);
  background: linear-gradient(180deg, rgba(243,212,122,0.24), rgba(214,180,95,0.12));
}

.btn-secondary:not(.dn-btn) {
  color: #d4eeff;
  border-color: rgba(42,168,255,0.42);
  background: rgba(16,46,67,0.62);
}

.btn-ghost:not(.dn-btn) {
  color: var(--fg-dim);
  background: transparent;
}

.btn-danger {
  color: #ffd6dd;
  border-color: rgba(212,71,91,0.50);
  background: linear-gradient(180deg, rgba(212,71,91,0.22), rgba(212,71,91,0.10));
}

.btn-mini {
  min-height: 34px !important;
  padding: 7px 11px !important;
  font-size: 13px !important;
  line-height: normal !important;
}

.btn-primary:not(.dn-btn):hover,
.btn-secondary:not(.dn-btn):hover,
.btn-danger:hover,
.btn-ghost:not(.dn-btn):hover {
  transform: translateY(-1px);
  border-color: var(--brand);
  text-decoration: none;
}

.btn-danger:hover {
  border-color: var(--red);
  box-shadow: 0 0 20px rgba(212,71,91,0.18);
}

.btn-primary:not(.dn-btn):disabled,
.btn-secondary:not(.dn-btn):disabled,
.btn-danger:disabled,
.btn-ghost:not(.dn-btn):disabled {
  opacity: 0.42;
  cursor: not-allowed;
  filter: grayscale(0.7);
}

.btn-primary:not(.dn-btn):disabled:hover,
.btn-secondary:not(.dn-btn):disabled:hover,
.btn-danger:disabled:hover,
.btn-ghost:not(.dn-btn):disabled:hover {
  transform: none;
}

input[type="email"],
input[type="text"],
input[type="password"],
input[type="search"],
input[type="url"],
input[type="number"],
input[type="tel"],
input[type="file"],
textarea,
select {
  display: block;
  width: 100%;
  min-height: 40px;
  padding: 9px 12px;
  color: var(--fg);
  font: inherit;
  border: 1px solid rgba(214,180,95,0.24);
  border-radius: 8px;
  background: rgba(17,16,20,0.76);
  outline: none;
  transition: border-color 120ms ease, box-shadow 120ms ease, background 120ms ease;
}

input[type="file"] {
  padding: 8px 12px;
  color: var(--fg-dim);
}

input[type="file"]::file-selector-button {
  min-height: 30px;
  margin-right: 10px;
  padding: 6px 10px;
  border: 1px solid rgba(214,180,95,0.34);
  border-radius: 7px;
  color: var(--brand-soft);
  background: linear-gradient(180deg, rgba(243,212,122,0.18), rgba(214,180,95,0.08));
  font: inherit;
  cursor: pointer;
}

textarea {
  min-height: 112px;
  resize: vertical;
}

select {
  appearance: none;
  cursor: pointer;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--fg-dim) 50%),
    linear-gradient(135deg, var(--fg-dim) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%;
  background-size: 5px 5px;
  background-repeat: no-repeat;
}

input::placeholder,
textarea::placeholder {
  color: var(--fg-faint);
}

input[type="email"]:hover,
input[type="text"]:hover,
input[type="password"]:hover,
input[type="search"]:hover,
input[type="url"]:hover,
input[type="number"]:hover,
input[type="tel"]:hover,
input[type="file"]:hover,
textarea:hover,
select:hover {
  border-color: rgba(214,180,95,0.38);
  background: rgba(31,30,38,0.78);
}

input[type="email"]:focus,
input[type="text"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="url"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="file"]:focus,
textarea:focus,
select:focus {
  border-color: rgba(42,168,255,0.70);
  box-shadow: 0 0 0 3px rgba(42,168,255,0.12);
  background: rgba(17,16,20,0.86);
}

input[type="email"]:focus-visible,
input[type="text"]:focus-visible,
input[type="password"]:focus-visible,
input[type="search"]:focus-visible,
input[type="url"]:focus-visible,
input[type="number"]:focus-visible,
input[type="tel"]:focus-visible,
input[type="file"]:focus-visible,
textarea:focus-visible,
select:focus-visible,
.btn-primary:not(.dn-btn):focus-visible,
.btn-secondary:not(.dn-btn):focus-visible,
.btn-danger:focus-visible,
.btn-ghost:not(.dn-btn):focus-visible {
  outline: none;
  border-color: rgba(42,168,255,0.72) !important;
  box-shadow: 0 0 0 3px rgba(42,168,255,0.12), 0 0 18px rgba(42,168,255,0.20);
}

.field.is-error input,
.field.is-error textarea,
.field.is-error select,
input.is-error,
textarea.is-error,
select.is-error {
  border-color: rgba(212,71,91,0.72);
  box-shadow: 0 0 0 3px rgba(212,71,91,0.10);
}

.field.is-success input,
.field.is-success textarea,
.field.is-success select,
input.is-success,
textarea.is-success,
select.is-success {
  border-color: rgba(76,175,122,0.68);
  box-shadow: 0 0 0 3px rgba(76,175,122,0.10);
}

.field {
  display: grid;
  gap: 7px;
}

.field-label {
  display: block;
  margin: 0;
  color: var(--brand);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.field-hint {
  color: var(--fg-faint);
  font-family: var(--font-sans);
  font-size: 13px;
  line-height: 1.45;
  letter-spacing: 0;
  text-transform: none;
}

.field-error {
  color: #F3C4CC;
  font-size: 13px;
  line-height: 1.45;
}

.field-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(214,180,95,0.22);
  border-radius: 8px;
  color: var(--fg-dim);
  background: rgba(17,16,20,0.54);
  font-size: 13px;
  line-height: 1.5;
  cursor: pointer;
}

.field-checkbox:hover {
  border-color: rgba(214,180,95,0.40);
}

.field-checkbox input[type="checkbox"],
.field-checkbox input[type="radio"] {
  flex: 0 0 auto;
  width: 17px;
  height: 17px;
  margin-top: 2px;
  accent-color: var(--brand);
}

.field-checkbox a {
  color: var(--accent-hi);
  border-bottom: 1px dotted currentColor;
}

.field-checkbox a:hover {
  color: var(--brand-soft);
}

.dn-honeypot {
  position: absolute !important;
  left: -9999px !important;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.form-actions,
.profile-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
  align-items: center;
}

.form-link {
  color: var(--fg-dim);
  font-size: 14px;
  line-height: 1.45;
}

.form-link a {
  color: var(--accent-hi);
  border-bottom: 1px dotted currentColor;
}

.form-link:hover,
.form-link a:hover {
  color: var(--brand-soft);
}

.auth-page {
  position: relative;
  max-width: 500px;
  margin: 0 auto;
  padding: 30px;
  overflow: hidden;
  border: 1px solid rgba(214,180,95,0.24);
  border-radius: 8px;
  background:
    radial-gradient(circle at 100% 0%, rgba(42,168,255,0.15), transparent 18rem),
    linear-gradient(135deg, rgba(214,180,95,0.08), transparent 40%),
    rgba(31,30,38,0.82);
  box-shadow: 0 26px 80px rgba(0,0,0,0.42), inset 0 0 0 1px rgba(214,180,95,0.04);
}

.auth-page::before,
.profile-card::before,
.legal-head::before,
.dn-form-surface::before {
  content: "";
  position: absolute;
  inset: 0 auto auto 0;
  width: 36px;
  height: 36px;
  background: none;
  border-top: 1.5px solid var(--brand-strong);
  border-left: 1.5px solid var(--brand-strong);
  border-top-left-radius: 8px;
  opacity: .68;
}

.auth-page h1 {
  margin: 0 0 8px;
  font-family: var(--font-display);
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 520;
  line-height: 1.12;
}

.auth-sub,
.auth-hint {
  color: var(--fg-dim);
  margin: 0 0 24px;
  line-height: 1.58;
}

.auth-form,
.profile-form {
  display: grid;
  gap: 16px;
}

.auth-form .form-actions {
  flex-direction: column;
  align-items: stretch;
  justify-content: stretch;
}

.auth-form .form-actions .btn-primary {
  width: 100%;
}

.auth-form .form-actions .dn-btn-primary {
  width: 100%;
}

.captcha-field {
  gap: 8px;
}

.captcha-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 2px;
}

.captcha-img {
  border-radius: 8px;
  border: 1px solid rgba(214,180,95,0.24);
  background: var(--bg-soft);
  box-shadow: inset 0 0 0 1px rgba(214,180,95,0.04);
}

.captcha-refresh {
  min-height: 56px;
  min-width: 48px;
  padding-inline: 12px !important;
}

.verify-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border: 1px solid rgba(224,169,60,0.34);
  border-radius: 8px;
  padding: 14px 16px;
  color: #F6DCA1;
  background:
    linear-gradient(135deg, rgba(224,169,60,0.10), transparent 46%),
    rgba(31,30,38,0.76);
}

.verify-banner strong {
  color: var(--brand-soft);
}

.verify-banner form {
  margin: 0;
  flex: 0 0 auto;
}

.profile-page {
  max-width: 840px;
  margin: 0 auto;
  display: grid;
  gap: 18px;
}

.profile-card,
.legal-head,
.legal-table-wrap {
  position: relative;
  border: 1px solid rgba(214,180,95,0.22);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(214,180,95,0.07), transparent 36%),
    rgba(31,30,38,0.78);
  box-shadow: 0 18px 52px rgba(0,0,0,0.30);
}

.profile-card {
  padding: 22px;
  overflow: hidden;
}

.profile-card h2,
.legal-section h2 {
  margin: 0 0 10px;
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: 18px;
  font-weight: 760;
}

.profile-info {
  display: grid;
  grid-template-columns: minmax(96px, max-content) 1fr;
  gap: 8px 18px;
  margin: 0;
}

.profile-info dt {
  color: var(--brand);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
}

.profile-info dd {
  margin: 0;
  color: var(--fg);
}

.profile-info .mono,
.mono {
  font-family: var(--font-mono);
}

.muted {
  color: var(--fg-faint);
}

.profile-hint {
  color: var(--fg-dim);
  font-size: 14px;
  line-height: 1.58;
}

.profile-card > .profile-hint {
  margin: 0 0 16px;
}

.profile-policy-note {
  margin-top: 16px !important;
  margin-bottom: 0;
  font-size: 12px;
}

.profile-hint a {
  color: var(--accent-hi);
  border-bottom: 1px dotted currentColor;
}

.profile-hint a:hover {
  color: var(--brand-soft);
}

.profile-hint code,
.legal-section code,
.legal-meta code {
  color: var(--accent-hi);
  background: rgba(42,168,255,0.08);
  border: 1px solid rgba(42,168,255,0.22);
  border-radius: 4px;
  padding: 1px 5px;
}

.profile-danger {
  border-color: rgba(212,71,91,0.42);
}

.profile-danger::before {
  border-color: var(--red);
}

.profile-card.profile-danger::before {
  background: none;
}

.profile-danger h2,
.profile-danger strong {
  color: #F09BA8;
}

.legal-page {
  max-width: 900px;
  margin: 0 auto;
}

.legal-head {
  padding: 28px;
  margin-bottom: 28px;
  overflow: hidden;
}

.legal-head h1 {
  margin: 0 0 12px;
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 520;
  line-height: 1.1;
}

.legal-meta {
  color: var(--fg-dim);
  margin: 0;
  line-height: 1.6;
}

.legal-section {
  margin: 0 0 32px;
}

.legal-section h2 {
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(214,180,95,0.22);
}

.legal-section p,
.legal-section li {
  color: var(--fg-dim);
  line-height: 1.68;
}

.legal-section ul {
  margin: 10px 0 0 20px;
}

.legal-section strong {
  color: var(--fg);
}

.legal-section a {
  color: var(--accent-hi);
  border-bottom: 1px dotted currentColor;
}

.legal-table-wrap {
  overflow-x: auto;
  margin: 16px 0;
}

.legal-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 14px;
}

.legal-table th,
.legal-table td {
  padding: 12px 14px;
  vertical-align: top;
  border-bottom: 1px solid rgba(214,180,95,0.16);
}

.legal-table th {
  color: var(--brand-soft);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-align: left;
  text-transform: uppercase;
  background: rgba(17,16,20,0.52);
}

.legal-table td {
  color: var(--fg-dim);
}

.legal-table tr:last-child td {
  border-bottom: 0;
}

.feedback-fieldset {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px,1fr));
  gap: 8px;
  margin: 0;
  padding: 0;
  border: 0;
}

.feedback-fieldset .field-label {
  grid-column: 1 / -1;
}

.feedback-images {
  display: grid;
  gap: 8px;
}

.feedback-page .feedback-form {
  max-width: 860px;
  margin: 0 auto;
}

.feedback-block {
  display: grid;
  gap: 14px;
}

.feedback-noshow {
  margin: 0;
}

.device-list {
  display: grid;
  gap: 10px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

.device-item {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto;
  gap: 14px;
  align-items: start;
  padding: 14px 16px;
  border: 1px solid rgba(214,180,95,0.20);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(214,180,95,0.06), transparent 38%),
    rgba(17,16,20,0.58);
}

.device-name {
  display: inline-block;
  margin-right: 8px;
  color: var(--fg);
}

.device-meta {
  color: var(--fg-faint);
  font-size: 12px;
}

.device-dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 4px 12px;
  margin: 10px 0 0;
  font-size: 12px;
}

.device-dl dt {
  color: var(--brand);
  font-family: var(--font-mono);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.device-dl dd {
  margin: 0;
  color: var(--fg-dim);
}

.device-revoke {
  margin: 0;
}

.profile-empty,
.dn-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 96px;
  margin: 16px 0 0;
  padding: 18px;
  border: 1px dashed rgba(214,180,95,0.28);
  border-radius: 8px;
  color: var(--fg-dim);
  background:
    radial-gradient(circle at 100% 0%, rgba(42,168,255,0.08), transparent 14rem),
    rgba(17,16,20,0.42);
  text-align: center;
}

.profile-empty span,
.dn-empty span {
  color: var(--brand-soft);
  font-family: var(--font-mono);
  font-size: 20px;
}

.dn-note-center {
  text-align: center;
}

.dn-lore-spaced {
  margin-top: 32px;
}

.dn-cta-center {
  justify-content: center;
}

.dn-section-tail {
  margin-top: 40px;
  margin-bottom: 0;
}

.dn-card h3 {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.dn-card-badge {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 3px 7px;
  border: 1px solid rgba(214,180,95,0.32);
  border-radius: 999px;
  color: var(--brand-soft);
  background: rgba(214,180,95,0.12);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .10em;
  line-height: 1;
  text-transform: uppercase;
}

.dn-card .dn-cta-row,
.dn-card-simple .dn-cta-row,
.dn-card-game .dn-cta-row {
  margin-top: 18px;
}

.dn-download-guest-actions {
  justify-content: center;
  margin-top: 24px;
}

.dn-docs-placeholder {
  min-height: 190px;
}

/* ---- Homepage/product sections from docs/design3 ------------------------ */
.dn-problem-grid {
  display: grid;
  grid-template-columns: minmax(260px, .78fr) 1.22fr;
  gap: 36px;
  align-items: start;
}

.dn-problem-intro {
  display: grid;
  gap: 12px;
}

.dn-problem-intro .dn-problem-kicker {
  color: var(--brand-soft);
  text-shadow: 0 0 20px rgba(214,180,95,0.16);
}

.dn-problem-intro h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 520;
  line-height: 1.12;
}

.dn-problem-intro p {
  color: var(--fg-dim);
  margin: 0;
}

.dn-anchor-target {
  scroll-margin-top: 96px;
}

.dn-screen-section .dn-section-head {
  margin-bottom: 28px;
}

.dn-screen-section .dn-shot {
  max-width: none;
  margin: 0;
  padding: 10px;
  border: 1px solid rgba(214,180,95,0.28);
  border-radius: 8px;
  background: rgba(31,30,38,0.72);
  box-shadow: 0 26px 80px rgba(0,0,0,0.42);
}

.dn-screen-section .dn-shot img {
  border: 1px solid rgba(214,180,95,0.18);
  border-radius: 6px;
  box-shadow: none;
}

.dn-screen-section .dn-shot figcaption {
  margin-top: 0;
  padding: 14px 6px 4px;
  color: var(--fg-faint);
  font-size: 13px;
}

.dn-problem-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}

.dn-glass-card,
.dn-feature-strip article {
  position: relative;
  padding: 20px;
  border: 1px solid rgba(214,180,95,0.20);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(214,180,95,0.07), transparent 34%),
    rgba(31,30,38,0.80);
  box-shadow: 0 26px 80px rgba(0,0,0,0.42);
}

.dn-card-icon {
  display: grid;
  width: 42px;
  height: 42px;
  place-items: center;
  margin-bottom: 14px;
  border: 1px solid rgba(214,180,95,0.36);
  border-radius: 8px;
  color: var(--brand-soft);
  background: rgba(17,16,20,0.72);
}

.dn-glass-card h3,
.dn-feature-strip h3 {
  margin: 0 0 8px;
  color: var(--fg);
  font-size: 18px;
}

.dn-glass-card p,
.dn-feature-strip p {
  margin: 0;
  color: var(--fg-dim);
  line-height: 1.62;
}

.dn-feature-strip {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 16px;
}

.dn-feature-strip span {
  color: var(--accent);
  font-family: var(--font-mono);
}

.dn-roadmap-grid {
  display: grid;
  grid-template-columns: minmax(260px, .78fr) 1.22fr;
  gap: 36px;
  align-items: start;
}

.dn-roadmap-intro {
  display: grid;
  gap: 12px;
}

.dn-roadmap-intro .dn-roadmap-kicker {
  color: var(--brand-soft);
  text-shadow: 0 0 20px rgba(214,180,95,0.16);
}

.dn-roadmap-intro h2 {
  margin: 0;
  color: var(--text-strong);
  font-family: var(--font-display);
  font-size: clamp(30px, 4vw, 48px);
  font-weight: 520;
  line-height: 1.12;
}

.dn-roadmap-intro p {
  color: var(--fg-dim);
  margin: 0;
}

.dn-roadmap-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 16px;
}

.dn-arcane-panel {
  border: 1px solid rgba(214,180,95,0.24);
  border-radius: 8px;
  overflow: hidden;
  background:
    radial-gradient(circle at 70% 10%, rgba(42,168,255,0.16), transparent 28rem),
    linear-gradient(135deg, rgba(214,180,95,0.07), transparent 38%),
    url('/assets/img/arcane-focus-background.png') center / cover no-repeat,
    rgba(7,8,11,0.56);
  box-shadow: 0 26px 80px rgba(0,0,0,0.42);
}

@media (max-width: 1100px) {
  .dn-problem-grid,
  .dn-roadmap-grid,
  .dn-feature-strip {
    grid-template-columns: 1fr;
  }

  .dn-roadmap-cards {
    grid-template-columns: repeat(2, minmax(0,1fr));
  }
}

@media (max-width: 680px) {
  .auth-page,
  .legal-head,
  .profile-card {
    padding: 20px;
  }

  .verify-banner,
  .form-actions,
  .profile-actions {
    align-items: stretch;
    flex-direction: column;
  }

  .profile-info {
    grid-template-columns: 1fr;
  }

  .device-item {
    grid-template-columns: 1fr;
  }

  .device-dl {
    grid-template-columns: 1fr;
  }

  .device-revoke .btn-danger,
  .device-revoke .dn-btn-danger {
    width: 100%;
  }

  .dn-card .dn-cta-row .dn-btn,
  .dn-card-simple .dn-cta-row .dn-btn,
  .dn-card-game .dn-cta-row .dn-btn {
    width: 100%;
  }

  .captcha-row {
    align-items: stretch;
  }

  .captcha-img {
    width: min(180px, calc(100% - 58px));
    height: auto;
  }

  .dn-problem-cards,
  .dn-roadmap-cards {
    grid-template-columns: 1fr;
  }
}
