/* EAsAPI - modern product UI for Bootstrap 5.3 */

:root,
[data-bs-theme="light"] {
  --app-bg: #f5f6ff;
  --app-bg-soft: #ffffff;
  --surface: #ffffff;
  --surface-strong: #f8f8fd;
  --surface-muted: #eeedf8;
  --surface-tint: #eef0ff;
  --border-soft: rgba(15, 10, 50, .08);
  --border-strong: rgba(15, 10, 50, .14);
  --text-strong: #0f0e1a;
  --text-muted: #6b6c86;
  --brand: #6366f1;
  --brand-dark: #4f46e5;
  --brand-soft: rgba(99, 102, 241, .10);
  --accent: #10b981;
  --accent-soft: rgba(16, 185, 129, .12);
  --success: #15803d;
  --warning: #b45309;
  --danger: #be123c;
  --success-soft: rgba(21, 128, 61, .11);
  --warning-soft: rgba(180, 83, 9, .13);
  --danger-soft: rgba(190, 18, 60, .10);
  --shadow-sm: 0 1px 2px rgba(10, 8, 40, .04), 0 10px 24px rgba(10, 8, 40, .06);
  --shadow-md: 0 16px 38px rgba(10, 8, 40, .10);
  --shadow-lg: 0 28px 72px rgba(4, 2, 20, .26);
  --navbar-bg: rgba(10, 9, 26, .94);
  --table-hover: rgba(99, 102, 241, .055);
  --input-focus-shadow: rgba(99, 102, 241, .18);
}

[data-bs-theme="dark"] {
  --app-bg: #0a0b1a;
  --app-bg-soft: #0f1028;
  --surface: #131429;
  --surface-strong: #191a35;
  --surface-muted: #1f2044;
  --surface-tint: #151635;
  --border-soft: rgba(220, 218, 255, .10);
  --border-strong: rgba(220, 218, 255, .16);
  --text-strong: #f0efff;
  --text-muted: #9d9db8;
  --brand: #a5b4fc;
  --brand-dark: #c4b5fd;
  --brand-soft: rgba(165, 180, 252, .14);
  --accent: #34d399;
  --accent-soft: rgba(52, 211, 153, .14);
  --success: #7ee787;
  --warning: #f7c46c;
  --danger: #ff8aa0;
  --success-soft: rgba(126, 231, 135, .12);
  --warning-soft: rgba(247, 196, 108, .13);
  --danger-soft: rgba(255, 138, 160, .12);
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, .22), 0 14px 32px rgba(0, 0, 0, .24);
  --shadow-md: 0 18px 48px rgba(0, 0, 0, .34);
  --shadow-lg: 0 28px 78px rgba(0, 0, 0, .54);
  --navbar-bg: rgba(6, 5, 18, .90);
  --table-hover: rgba(165, 180, 252, .085);
  --input-focus-shadow: rgba(165, 180, 252, .22);
}

* {
  min-width: 0;
}

html {
  background: var(--app-bg);
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  color: var(--text-strong);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .70), rgba(255, 255, 255, 0) 21rem),
    linear-gradient(135deg, rgba(99, 102, 241, .08) 0%, rgba(16, 185, 129, .06) 45%, rgba(245, 246, 255, 0) 72%),
    var(--app-bg);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  font-size: .95rem;
}

[data-bs-theme="dark"] body {
  background:
    linear-gradient(180deg, rgba(10, 9, 26, .76), rgba(10, 9, 26, 0) 22rem),
    linear-gradient(135deg, rgba(99, 102, 241, .12) 0%, rgba(52, 211, 153, .07) 48%, rgba(10, 11, 26, 0) 75%),
    var(--app-bg);
}

a {
  color: var(--brand);
  text-decoration: none;
  text-underline-offset: .2em;
}

a:hover {
  color: var(--brand-dark);
}

main.container-fluid {
  width: min(100%, 1440px);
  margin-inline: auto;
}

.text-muted {
  color: var(--text-muted) !important;
}

.text-primary {
  color: var(--brand) !important;
}

code {
  color: var(--brand);
  background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 82%);
  border-radius: .45rem;
  padding: .08rem .35rem;
}

/* Auth pages */
body.auth-page {
  align-items: center;
  justify-content: center;
  padding: 2rem 0;
  background:
    radial-gradient(circle at 72% 28%, rgba(139, 92, 246, .22), transparent 400px),
    radial-gradient(circle at 20% 72%, rgba(52, 211, 153, .13), transparent 360px),
    linear-gradient(145deg, #08081a 0%, #110f2e 50%, #0b1a16 100%);
}

.auth-page .container {
  max-width: 1160px;
}

.auth-card {
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, .24);
  border-radius: .7rem;
  background: rgba(255, 255, 255, .95);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(18px);
}

[data-bs-theme="dark"] .auth-card {
  background: rgba(20, 27, 43, .92);
}

.auth-logo {
  width: 4rem;
  height: 4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255, 255, 255, .28);
  border-radius: .8rem;
  color: #ffffff;
  font-size: 2.15rem;
  background: linear-gradient(135deg, #6366f1 0%, #10b981 100%);
  box-shadow: 0 18px 36px rgba(0, 0, 0, .24);
}

.auth-card hr {
  border-color: var(--border-soft);
  opacity: 1;
}

/* Navbar */
.navbar-easapi {
  background: var(--navbar-bg) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .12);
  box-shadow: 0 12px 30px rgba(2, 8, 23, .18);
  backdrop-filter: blur(18px);
  z-index: 1050;
}

.navbar-easapi .navbar-brand {
  letter-spacing: 0;
}

.navbar-easapi .navbar-brand .bi {
  color: #a5b4fc !important;
}

.navbar-easapi .nav-link {
  border-radius: .45rem;
  color: rgba(255, 255, 255, .74);
  font-weight: 650;
  padding-inline: .82rem;
}

.navbar-easapi .nav-link:hover,
.navbar-easapi .nav-link:focus {
  color: #ffffff;
  background: rgba(255, 255, 255, .10);
}

.navbar-easapi .nav-link.text-danger {
  color: #ffb4c2 !important;
}

.navbar-toggler {
  border-color: rgba(255, 255, 255, .18);
}

/* Layout blocks */
.card {
  border-color: var(--border-soft);
  border-radius: .7rem;
  background-color: var(--surface);
  box-shadow: var(--shadow-sm);
}

.card.border-0 {
  border: 1px solid var(--border-soft) !important;
}

.card-header {
  border-bottom: 1px solid var(--border-soft);
  background-color: var(--surface-strong) !important;
}

.shadow-sm,
.shadow {
  box-shadow: var(--shadow-sm) !important;
}

.license-status-card {
  position: relative;
  overflow: hidden;
  border-radius: .7rem;
  background:
    linear-gradient(135deg, var(--surface-tint), var(--surface) 58%);
}

.license-status-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: .26rem;
  background: linear-gradient(90deg, var(--brand), var(--accent), #f59e0b);
}

.list-group-item {
  color: var(--text-strong);
  background: transparent;
  border-color: var(--border-soft);
}

/* Stat cards */
.stat-card {
  overflow: hidden;
  border: 1px solid var(--border-soft) !important;
  border-radius: .7rem;
  box-shadow: var(--shadow-sm);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.stat-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong) !important;
  box-shadow: var(--shadow-md);
}

.stat-card .card-body {
  position: relative;
  z-index: 1;
}

.stat-card .small {
  opacity: .82;
  font-weight: 650;
}

.stat-card .stat-icon {
  font-size: 2rem;
  opacity: .62;
}

.stat-card .stat-num {
  font-size: clamp(1.6rem, 2vw, 2.1rem);
  font-weight: 850;
  line-height: 1;
}

.stat-card.bg-primary {
  background: linear-gradient(135deg, #0f6fff, #005fc2) !important;
}

.stat-card.bg-success {
  background: linear-gradient(135deg, #008f7a, #15803d) !important;
}

.stat-card.bg-danger {
  background: linear-gradient(135deg, #be123c, #8b1d5a) !important;
}

.stat-card.bg-secondary {
  background: linear-gradient(135deg, #475467, #202939) !important;
}

.stat-card.bg-warning {
  background: linear-gradient(135deg, #ffd166, #f59e0b) !important;
}

/* Tables */
.table-responsive {
  border-radius: .7rem;
}

.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--text-strong);
  --bs-table-border-color: var(--border-soft);
  margin-bottom: 0;
}

.table thead th {
  color: var(--text-muted);
  border-bottom: 1px solid var(--border-soft);
  font-size: .72rem;
  font-weight: 850;
  letter-spacing: .02em;
  text-transform: uppercase;
  white-space: nowrap;
  padding: .92rem 1rem;
}

.table tbody td {
  padding: .92rem 1rem;
  vertical-align: middle;
}

.table-hover tbody tr {
  transition: background-color .15s ease;
}

.table-hover tbody tr:hover {
  background-color: var(--table-hover);
}

.table-light {
  --bs-table-bg: var(--surface-strong);
  --bs-table-color: var(--text-strong);
  --bs-table-border-color: var(--border-soft);
}

/* Forms */
.form-label {
  color: var(--text-strong);
  font-size: .9rem;
}

.form-control,
.form-select,
.input-group-text {
  border-color: var(--border-soft);
  color: var(--text-strong);
  background-color: var(--surface);
  border-radius: .55rem;
}

.form-control,
.form-select {
  min-height: 2.55rem;
}

.form-control-sm,
.form-select-sm {
  min-height: 2.1rem;
}

.input-group .form-control,
.input-group .form-select {
  border-radius: 0 .55rem .55rem 0;
}

.input-group .form-control:not(:last-child),
.input-group .form-select:not(:last-child) {
  border-radius: 0;
}

.input-group .input-group-text {
  border-radius: .55rem 0 0 .55rem;
  color: var(--text-muted);
  background-color: var(--surface-strong);
}

.input-group .btn {
  border-radius: 0 .55rem .55rem 0;
}

.form-control::placeholder {
  color: color-mix(in srgb, var(--text-muted), transparent 22%);
}

.form-control:focus,
.form-select:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 .22rem var(--input-focus-shadow);
}

.form-text {
  color: var(--text-muted);
}

.form-check-input {
  border-color: color-mix(in srgb, var(--text-muted), transparent 44%);
}

.form-check-input:checked {
  background-color: var(--brand);
  border-color: var(--brand);
}

/* Buttons and badges */
.btn {
  border-radius: .52rem;
  font-weight: 750;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, border-color .15s ease;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  border-color: #0f6fff;
  background: linear-gradient(135deg, #0f6fff, #095bd9);
  box-shadow: 0 9px 20px rgba(15, 111, 255, .22);
}

.btn-primary:hover,
.btn-primary:focus {
  border-color: #095bd9;
  background: linear-gradient(135deg, #095bd9, #084aa8);
}

.btn-outline-primary {
  color: var(--brand);
  border-color: color-mix(in srgb, var(--brand), transparent 42%);
}

.btn-outline-primary:hover {
  border-color: var(--brand);
  background-color: var(--brand);
}

.btn-outline-secondary {
  color: var(--text-muted);
  border-color: var(--border-strong);
}

.btn-outline-secondary:hover {
  color: var(--text-strong);
  border-color: var(--border-strong);
  background: var(--surface-muted);
}

.btn-group-sm > .btn,
.btn-sm {
  border-radius: .45rem;
}

.badge {
  border-radius: 999px;
  font-weight: 800;
  letter-spacing: 0;
  padding: .42em .68em;
}

.badge.bg-success {
  color: var(--success) !important;
  background: var(--success-soft) !important;
}

.badge.bg-warning {
  color: var(--warning) !important;
  background: var(--warning-soft) !important;
}

.badge.bg-danger {
  color: var(--danger) !important;
  background: var(--danger-soft) !important;
}

.badge.bg-secondary {
  color: var(--text-strong) !important;
  background: var(--surface-muted) !important;
}

.badge.bg-info {
  color: var(--brand) !important;
  background: var(--brand-soft) !important;
}

/* Feedback and modal */
.alert {
  border: 1px solid transparent;
  border-radius: .62rem;
  box-shadow: none;
}

.alert-success {
  color: var(--success);
  background: var(--success-soft);
  border-color: color-mix(in srgb, var(--success), transparent 78%);
}

.alert-danger {
  color: var(--danger);
  background: var(--danger-soft);
  border-color: color-mix(in srgb, var(--danger), transparent 78%);
}

.alert-secondary {
  color: var(--text-strong);
  background: var(--surface-strong);
  border-color: var(--border-soft);
}

.modal-content {
  border: 1px solid var(--border-soft);
  border-radius: .7rem;
  background-color: var(--surface);
  box-shadow: var(--shadow-lg);
}

.modal-header,
.modal-footer {
  border-color: var(--border-soft);
}

/* Theme toggle */
#themeToggle {
  width: 2.25rem;
  height: 2.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 999px;
  color: rgba(255, 255, 255, .86);
  background: rgba(255, 255, 255, .08);
}

#themeToggle:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, .16);
}

/* License progress */
.progress {
  overflow: hidden;
  background-color: var(--surface-muted);
  border-radius: 999px;
}

.days-bar {
  height: .55rem;
}

.progress-bar {
  border-radius: 999px;
}

/* Admin accounts expand button */
.btn-ghost-accounts {
  background: var(--brand-soft);
  color: var(--brand);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 72%);
  border-radius: .45rem;
  font-size: .78rem;
  font-weight: 800;
  padding: .28rem .7rem;
  transition: background .15s, transform .15s;
}

.btn-ghost-accounts:hover {
  background: color-mix(in srgb, var(--brand-soft), var(--brand) 10%);
  color: var(--brand);
  transform: translateY(-1px);
}

.accounts-expand-row td {
  border-top: none !important;
}

/* User dashboard */
.user-avatar-wrap {
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  background: var(--brand-soft);
  color: var(--brand);
  border: 2px solid color-mix(in srgb, var(--brand), transparent 72%);
}

/* Footer and utilities */
footer {
  color: var(--text-muted) !important;
  border-color: var(--border-soft) !important;
  background: color-mix(in srgb, var(--surface), transparent 16%);
}

.text-truncate-150 {
  max-width: 150px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 767.98px) {
  main.container-fluid {
    padding-inline: 1rem !important;
  }

  .auth-card .card-body {
    padding: 2rem !important;
  }

  .d-flex.justify-content-between.align-items-center.mb-4 {
    align-items: flex-start !important;
    gap: .75rem;
  }

  .table thead th,
  .table tbody td {
    padding: .8rem .82rem;
  }

  .btn-group-sm > .btn {
    min-width: 2.15rem;
  }
}

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

/* ── Dropdown nav ────────────────────────────────────────────────────────── */

.navbar-easapi .dropdown-menu {
  background: rgba(16, 24, 40, .97);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: .6rem;
  box-shadow: var(--shadow-lg);
  margin-top: .4rem;
  z-index: 1051;
}

.navbar-easapi .dropdown-item {
  color: rgba(255, 255, 255, .78);
  font-weight: 650;
  font-size: .88rem;
  border-radius: .38rem;
  padding: .5rem .9rem;
  transition: background .15s;
}

.navbar-easapi .dropdown-item:hover {
  background: rgba(255, 255, 255, .10);
  color: #fff;
}

.navbar-easapi .dropdown-divider {
  border-color: rgba(255, 255, 255, .12);
}

/* ── Ad slots ────────────────────────────────────────────────────────────── */

.ad-slot-wrap {
  padding: .85rem 0;
  background: var(--app-bg);
}

.ad-slot-wrap-footer {
  border-top: 1px solid var(--border-soft);
  background: var(--app-bg-soft);
  padding: 1.1rem 0;
}

.ad-slot {
  display: flex;
  align-items: center;
  justify-content: center;
}

.ad-leaderboard { min-height: 90px; }
.ad-rectangle   { min-height: 280px; max-width: 336px; }

.ad-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .4rem;
  width: 100%;
  height: 100%;
  min-height: inherit;
  border: 1px dashed var(--border-strong);
  border-radius: .6rem;
  background: color-mix(in srgb, var(--surface-muted), transparent 30%);
  color: var(--text-muted);
  user-select: none;
}

.ad-label {
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .55;
}

.ad-size {
  font-size: .72rem;
  font-family: ui-monospace, monospace;
  opacity: .38;
}

@media (max-width: 767px) {
  .ad-leaderboard { min-height: 60px; }
  .ad-rectangle   { max-width: 100%; min-height: 200px; }
}

/* ── Admin subnav ─────────────────────────────────────────────────────────── */

.admin-subnav {
  background: rgba(10, 9, 26, .97);
  border-bottom: 1px solid rgba(165, 180, 252, .14);
  position: sticky;
  top: 60px;
  z-index: 1040;
  box-shadow: 0 4px 16px rgba(0, 0, 0, .18);
}

[data-bs-theme="light"] .admin-subnav {
  background: rgba(18, 14, 50, .96);
}

.admin-subnav-links {
  display: flex;
  align-items: center;
  gap: .15rem;
  overflow-x: auto;
  scrollbar-width: none;
  padding: .35rem 0;
  -ms-overflow-style: none;
}

.admin-subnav-links::-webkit-scrollbar { display: none; }

.admin-subnav-item {
  display: inline-flex;
  align-items: center;
  gap: .42rem;
  padding: .42rem .9rem;
  border-radius: .55rem;
  font-size: .82rem;
  font-weight: 700;
  color: rgba(200, 195, 255, .62);
  text-decoration: none;
  white-space: nowrap;
  transition: background .14s, color .14s;
  border: 1px solid transparent;
}

.admin-subnav-item i {
  font-size: .9rem;
}

.admin-subnav-item:hover {
  color: #fff;
  background: rgba(165, 180, 252, .12);
}

.admin-subnav-item.active {
  color: #fff;
  background: rgba(99, 102, 241, .22);
  border-color: rgba(165, 180, 252, .22);
}

/* ── Landing page ─────────────────────────────────────────────────────────── */

.landing-page {
  background: var(--app-bg);
}

.navbar-landing {
  background: rgba(7, 12, 22, .96) !important;
  backdrop-filter: blur(20px);
}

/* Hero */
.hero-section {
  background:
    linear-gradient(180deg, rgba(7, 12, 22, .98) 0%, rgba(8, 14, 28, .95) 100%);
  padding: 6rem 0 5rem;
  position: relative;
  overflow: hidden;
}

.hero-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 70% 40%, rgba(139, 92, 246, .16), transparent 65%),
    radial-gradient(ellipse 55% 50% at 20% 60%, rgba(52, 211, 153, .10), transparent 60%);
  pointer-events: none;
}

.hero-badge {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--brand);
  background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 72%);
  border-radius: 999px;
  padding: .4em 1em;
}

.hero-title {
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 900;
  line-height: 1.12;
  color: #eef4ff;
  margin: 1rem 0 1.25rem;
}

.hero-gradient {
  background: linear-gradient(90deg, #a5b4fc, #34d399);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.hero-subtitle {
  font-size: 1.05rem;
  color: rgba(200, 215, 240, .75);
  line-height: 1.65;
  max-width: 520px;
  margin-bottom: 2rem;
}

.btn-hero {
  padding: .72rem 1.6rem;
  font-size: 1rem;
  font-weight: 750;
  border-radius: .6rem;
}

.btn-hero-outline {
  padding: .72rem 1.6rem;
  font-size: 1rem;
  font-weight: 750;
  border-radius: .6rem;
  color: rgba(200, 215, 240, .85);
  border: 1px solid rgba(255, 255, 255, .22);
  background: rgba(255, 255, 255, .06);
  transition: all .18s ease;
}

.btn-hero-outline:hover {
  color: #fff;
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .38);
}

/* Hero code block */
.hero-code-block {
  background: rgba(13, 20, 38, .88);
  border: 1px solid rgba(102, 163, 255, .18);
  border-radius: .9rem;
  overflow: hidden;
  width: 100%;
  max-width: 400px;
  box-shadow: 0 28px 64px rgba(0, 0, 0, .48), 0 0 0 1px rgba(255, 255, 255, .04);
}

.hero-code-header {
  display: flex;
  align-items: center;
  gap: .4rem;
  padding: .75rem 1rem;
  background: rgba(255, 255, 255, .04);
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.hero-code-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
}

.hero-code-body {
  margin: 0;
  padding: 1.25rem 1.4rem;
  font-size: .8rem;
  line-height: 1.65;
  color: #c9d3e8;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  background: transparent;
  border: none;
  overflow: auto;
}

.hero-code-body .c-kw   { color: #66a3ff; font-weight: 700; }
.hero-code-body .c-fn   { color: #7dd3fc; }
.hero-code-body .c-str  { color: #7ee787; }
.hero-code-body .c-comment { color: #5a6a82; font-style: italic; }

/* Features */
.features-section {
  padding: 5rem 0;
  background: var(--app-bg);
}

.section-title {
  font-size: clamp(1.6rem, 3vw, 2rem);
  font-weight: 850;
  color: var(--text-strong);
}

.section-subtitle {
  font-size: 1rem;
  color: var(--text-muted);
  max-width: 500px;
  margin-inline: auto;
}

.feature-card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: .85rem;
  padding: 1.75rem;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.feature-card:hover {
  transform: translateY(-3px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}

.feature-icon {
  width: 3rem;
  height: 3rem;
  border-radius: .65rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  background: color-mix(in srgb, var(--fi-color), transparent 88%);
  color: var(--fi-color);
  margin-bottom: 1.1rem;
}

.feature-title {
  font-weight: 800;
  margin-bottom: .5rem;
  color: var(--text-strong);
}

.feature-desc {
  font-size: .9rem;
  color: var(--text-muted);
  line-height: 1.6;
  margin-bottom: 0;
}

/* Blog section */
.blog-section {
  padding: 4rem 0 5rem;
  background: var(--app-bg-soft);
  border-top: 1px solid var(--border-soft);
}

[data-bs-theme="dark"] .blog-section {
  background: var(--surface-strong);
}

/* Post card */
.post-card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: .85rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.post-card:hover {
  transform: translateY(-3px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}

.post-card-top {
  padding: 1.4rem 1.4rem .75rem;
  flex: 1;
}

.post-lang-badge {
  display: inline-block;
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .04em;
  color: var(--brand);
  background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 72%);
  border-radius: 999px;
  padding: .28em .75em;
}

.post-video-badge {
  display: inline-flex;
  align-items: center;
  font-size: .68rem;
  font-weight: 700;
  color: #e53e3e;
  background: rgba(229, 62, 62, .1);
  border-radius: 999px;
  padding: .25em .65em;
}

.post-date {
  font-size: .72rem;
  color: var(--text-muted);
}

.post-title {
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.4;
  color: var(--text-strong);
  margin-bottom: .4rem;
}

.post-excerpt {
  font-size: .85rem;
  color: var(--text-muted);
  line-height: 1.55;
  margin-bottom: 0;
}

/* ── Language toggle button ───────────────────────────────────────── */
.lang-toggle-btn {
  background: transparent;
  border: 1px solid rgba(255, 255, 255, .22);
  color: rgba(255, 255, 255, .78);
  border-radius: .4rem;
  padding: .28rem .58rem;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .06em;
  cursor: pointer;
  line-height: 1;
  transition: background .15s, border-color .15s, color .15s;
}

.lang-toggle-btn:hover,
.lang-toggle-btn:focus {
  background: rgba(255, 255, 255, .11);
  border-color: rgba(255, 255, 255, .38);
  color: #fff;
  outline: none;
}

.post-code-preview {
  background: var(--surface-strong);
  border-top: 1px solid var(--border-soft);
  padding: .7rem 1rem;
  font-size: .72rem;
  max-height: 100px;
  overflow: hidden;
  position: relative;
}

.post-code-preview::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2.5rem;
  background: linear-gradient(transparent, var(--surface-strong));
}

.post-code-preview pre {
  margin: 0;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  color: var(--text-muted);
  white-space: pre-wrap;
  word-break: break-all;
  background: transparent;
  border: none;
  padding: 0;
}

.post-code-preview code {
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  font-size: inherit;
  color: inherit;
}

.post-card-footer {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.4rem;
  border-top: 1px solid var(--border-soft);
  background: var(--surface-strong);
}

.btn-post-read {
  font-size: .8rem;
  font-weight: 750;
  color: var(--brand);
  background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 72%);
  border-radius: .45rem;
  padding: .38rem .85rem;
  transition: all .15s ease;
}

.btn-post-read:hover {
  background: var(--brand);
  color: #fff;
  border-color: var(--brand);
}

/* Landing footer */
.landing-footer {
  background: rgba(7, 12, 22, .96);
  color: rgba(200, 215, 240, .6);
  padding: 1.5rem 0;
  border-top: 1px solid rgba(255, 255, 255, .08);
}

.landing-footer .text-primary {
  color: #66a3ff !important;
}

.landing-footer .fw-bold {
  color: rgba(200, 215, 240, .9);
}

/* ── Post page ─────────────────────────────────────────────────────────────── */

.post-page {
  padding: 2rem 0 4rem;
  min-height: calc(100vh - 120px);
}

.post-page-title {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 900;
  line-height: 1.25;
  color: var(--text-strong);
}

.post-header {
  border-bottom: 1px solid var(--border-soft);
  padding-bottom: 1.25rem;
}

.post-content {
  font-size: .97rem;
  line-height: 1.8;
  color: var(--text-strong);
}

.post-video-wrap {
  border-radius: .7rem;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.post-code-block {
  border: 1px solid var(--border-soft);
  border-radius: .7rem;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.post-code-block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .65rem 1.1rem;
  background: var(--surface-strong);
  border-bottom: 1px solid var(--border-soft);
  font-size: .78rem;
  font-weight: 700;
  color: var(--text-muted);
}

.post-code-block-body {
  margin: 0;
  padding: 1.25rem 1.4rem;
  font-size: .82rem;
  line-height: 1.7;
  color: var(--text-strong);
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  background: var(--surface);
  border: none;
  overflow-x: auto;
  white-space: pre;
}

.post-code-block-body code {
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  font-size: inherit;
  color: inherit;
}

.btn-copy-code {
  font-size: .72rem;
  font-weight: 700;
  color: var(--text-muted);
  background: transparent;
  border: 1px solid var(--border-soft);
  border-radius: .38rem;
  padding: .25rem .65rem;
  cursor: pointer;
  transition: all .15s ease;
  display: inline-flex;
  align-items: center;
  gap: .3rem;
}

.btn-copy-code:hover {
  color: var(--brand);
  border-color: var(--brand);
  background: var(--brand-soft);
}

/* Breadcrumb */
.breadcrumb {
  font-size: .82rem;
}

.breadcrumb-item + .breadcrumb-item::before {
  color: var(--text-muted);
}

/* ── Compact hero ─────────────────────────────────────────────────────────── */

.hero-compact {
  background: linear-gradient(180deg, rgba(7,12,22,.98) 0%, rgba(8,14,28,.95) 100%);
  padding: 3.5rem 0 3rem;
  position: relative;
  overflow: hidden;
}

.hero-compact::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 80% at 80% 50%, rgba(139,92,246,.16), transparent 65%),
    radial-gradient(ellipse 50% 60% at 10% 60%, rgba(52,211,153,.10), transparent 60%);
  pointer-events: none;
}

.hero-compact-inner {
  position: relative;
  z-index: 1;
  max-width: 600px;
}

/* Feature strip */
.feature-strip {
  background: rgba(10,17,32,.96);
  border-top: 1px solid rgba(255,255,255,.07);
  border-bottom: 1px solid rgba(255,255,255,.07);
  padding: .75rem 0;
}

.feature-strip-item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  font-size: .8rem;
  font-weight: 700;
  color: rgba(200,215,240,.65);
  padding: .5rem 0;
  border-right: 1px solid rgba(255,255,255,.07);
}

.feature-strip-item:last-child { border-right: none; }
.feature-strip-item i { font-size: 1rem; color: #a5b4fc; opacity: .90; }

/* EA preview section (landing page) */
.ea-preview-section {
  padding: 3rem 0 2.5rem;
  background: var(--app-bg-soft);
  border-bottom: 1px solid var(--border-soft);
}

.ea-preview-hint {
  text-align: center;
  font-size: .83rem;
  color: var(--text-muted);
  padding: .5rem 1rem;
  border-radius: .5rem;
  background: var(--surface-tint);
  border: 1px solid var(--border-soft);
  display: inline-block;
  width: 100%;
}

.ea-preview-hint a { color: var(--brand); font-weight: 600; }

/* Blog photo grid */
.blog-grid-section {
  padding: 2.5rem 0 4rem;
  background: var(--app-bg);
}

.blog-grid-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  gap: .75rem;
}

.post-photo-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}

@media (max-width: 1199px) { .post-photo-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .post-photo-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 479px)  { .post-photo-grid { grid-template-columns: 1fr; } }

.post-photo-card {
  display: flex;
  flex-direction: column;
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: .7rem;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.post-photo-card:hover {
  transform: translateY(-3px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
  color: inherit;
}

.post-photo-bar {
  height: 4px;
  flex-shrink: 0;
}

.post-photo-body {
  padding: .85rem;
  flex: 1;
}

.post-photo-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .4rem;
}

.post-photo-lang {
  font-size: .65rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.post-photo-video-icon {
  color: #e53e3e;
  font-size: .8rem;
}

.post-photo-title {
  font-size: .88rem;
  font-weight: 800;
  line-height: 1.35;
  color: var(--text-strong);
  margin-bottom: .3rem;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.post-photo-date {
  font-size: .68rem;
  color: var(--text-muted);
}

.post-photo-code {
  background: var(--surface-strong);
  border-top: 1px solid var(--border-soft);
  padding: .5rem .75rem;
  font-size: .68rem;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  color: var(--text-muted);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.post-photo-code pre {
  margin: 0;
  font-family: inherit;
  color: inherit;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  background: transparent;
  border: none;
  padding: 0;
}

.post-photo-edit {
  position: absolute;
  top: .5rem;
  right: .5rem;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: .38rem;
  background: rgba(0,0,0,.55);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .72rem;
  opacity: 0;
  transition: opacity .15s;
}

.post-photo-card:hover .post-photo-edit { opacity: 1; }

/* ── Store (EA marketplace) ───────────────────────────────────────────────── */

.store-ea-card {
  background: var(--surface);
  border: 1px solid var(--border-soft);
  border-radius: .85rem;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.store-ea-card:hover {
  transform: translateY(-3px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}

.store-ea-photo {
  width: 100%;
  height: 110px;
  overflow: hidden;
  flex-shrink: 0;
  position: relative;
}

.store-ea-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.store-ea-photo-placeholder {
  background: var(--brand-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2rem;
  color: var(--brand);
  opacity: .6;
  height: 100%;
}

.store-ea-photo-badges {
  position: absolute;
  top: .45rem;
  left: .45rem;
  display: flex;
  gap: .3rem;
  flex-wrap: wrap;
}

.store-ea-body {
  padding: .65rem 1rem .5rem;
  flex: 1;
}

.store-ea-name {
  font-weight: 800;
  font-size: .92rem;
  margin-bottom: .15rem;
  color: var(--text-strong);
  line-height: 1.3;
}

.store-ea-owner {
  font-size: .73rem;
  color: var(--text-muted);
}

.store-ea-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .6rem 1rem;
  border-top: 1px solid var(--border-soft);
  background: var(--surface-strong);
}

.store-ea-price {
  font-size: 1rem;
  font-weight: 900;
  color: var(--brand);
  line-height: 1;
}

.store-ea-period {
  font-size: .68rem;
  font-weight: 600;
  color: var(--text-muted);
}

.store-ea-typetag {
  font-size: .68rem;
  font-weight: 600;
  margin-top: .3rem;
  display: flex;
  align-items: center;
  gap: .25rem;
  opacity: .85;
}

/* ── EA cards (admin) ─────────────────────────────────────────────────────── */

.ea-card {
  transition: transform .18s ease, box-shadow .18s ease;
}

.ea-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.ea-icon-wrap {
  width: 2.6rem;
  height: 2.6rem;
  border-radius: .6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.25rem;
  background: var(--brand-soft);
  color: var(--brand);
  flex-shrink: 0;
}

.ea-auth-key-block {
  background: var(--surface-strong);
  border: 1px solid var(--border-soft);
  border-radius: .55rem;
  padding: .75rem 1rem;
}

.ea-auth-key-label {
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: .45rem;
}

.ea-auth-key-row {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.ea-auth-key {
  font-size: .72rem;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  word-break: break-all;
  flex: 1;
  background: transparent;
  border: none;
  color: var(--brand);
  padding: 0;
}

.btn-copy-key {
  flex-shrink: 0;
  width: 1.8rem;
  height: 1.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--brand-soft);
  color: var(--brand);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 72%);
  border-radius: .38rem;
  cursor: pointer;
  font-size: .82rem;
  transition: all .15s ease;
}

.btn-copy-key:hover {
  background: var(--brand);
  color: #fff;
}

/* Visual refresh - clean SaaS look */
:root,
[data-bs-theme="light"] {
  --app-bg: #f5f6ff;
  --app-bg-soft: #ffffff;
  --surface: #ffffff;
  --surface-strong: #f8f8fd;
  --surface-muted: #eeedf8;
  --surface-tint: #eef0ff;
  --border-soft: rgba(15, 10, 50, .08);
  --border-strong: rgba(15, 10, 50, .14);
  --text-strong: #0f0e1a;
  --text-muted: #6b6c86;
  --brand: #6366f1;
  --brand-dark: #4f46e5;
  --brand-soft: rgba(99, 102, 241, .10);
  --accent: #10b981;
  --accent-soft: rgba(16, 185, 129, .10);
  --success: #16803c;
  --warning: #b7791f;
  --danger: #c0263f;
  --shadow-sm: 0 1px 2px rgba(10, 8, 40, .04), 0 10px 24px rgba(10, 8, 40, .06);
  --shadow-md: 0 18px 42px rgba(10, 8, 40, .10);
  --shadow-lg: 0 34px 90px rgba(4, 2, 20, .28);
  --navbar-bg: rgba(10, 9, 26, .95);
  --table-hover: rgba(99, 102, 241, .045);
  --input-focus-shadow: rgba(99, 102, 241, .18);
}

[data-bs-theme="dark"] {
  --app-bg: #0a0b1a;
  --app-bg-soft: #0f1028;
  --surface: #131429;
  --surface-strong: #191a35;
  --surface-muted: #1f2044;
  --surface-tint: #151635;
  --border-soft: rgba(220, 218, 255, .10);
  --border-strong: rgba(220, 218, 255, .18);
  --text-strong: #f0efff;
  --text-muted: #9d9db8;
  --brand: #a5b4fc;
  --brand-dark: #c4b5fd;
  --brand-soft: rgba(165, 180, 252, .14);
  --accent: #34d399;
  --accent-soft: rgba(52, 211, 153, .13);
  --navbar-bg: rgba(6, 5, 18, .95);
  --input-focus-shadow: rgba(165, 180, 252, .22);
}

body {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(255, 255, 255, 0) 280px),
    radial-gradient(circle at 12% 0%, rgba(99, 102, 241, .10), transparent 280px),
    radial-gradient(circle at 90% 3%, rgba(16, 185, 129, .07), transparent 280px),
    var(--app-bg);
  font-family: "Segoe UI", Inter, Roboto, Arial, sans-serif;
  color: var(--text-strong);
}

[data-bs-theme="dark"] body {
  background:
    radial-gradient(circle at 18% 0%, rgba(99, 102, 241, .16), transparent 320px),
    radial-gradient(circle at 90% 5%, rgba(52, 211, 153, .09), transparent 320px),
    linear-gradient(180deg, rgba(10, 9, 26, .72), rgba(10, 9, 26, 0) 320px),
    var(--app-bg);
}

main.container-fluid {
  padding-top: 1.75rem !important;
  padding-bottom: 2.5rem !important;
}

/* Quando a subnav admin está presente, o main é o direto abaixo dela */
.admin-subnav + main.container-fluid {
  padding-top: 1.5rem !important;
}

.navbar-easapi {
  background: var(--navbar-bg) !important;
  border-bottom: 1px solid rgba(255, 255, 255, .10);
  box-shadow: 0 16px 40px rgba(2, 6, 23, .20);
}

.navbar-easapi .navbar-brand {
  font-weight: 850 !important;
}

.navbar-easapi .nav-link {
  border-radius: .6rem;
  color: rgba(255, 255, 255, .76);
  font-size: .92rem;
  font-weight: 700;
  padding: .58rem .82rem;
}

.navbar-easapi .nav-link:hover,
.navbar-easapi .nav-link:focus,
.navbar-easapi .nav-link.show {
  color: #ffffff;
  background: rgba(255, 255, 255, .105);
}

.navbar-easapi .dropdown-menu {
  padding: .45rem;
  background: rgba(13, 23, 42, .98);
  border-radius: .8rem;
}

.navbar-easapi .dropdown-item {
  border-radius: .55rem;
}

#themeToggle {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: .7rem;
  color: rgba(255, 255, 255, .88);
  background: rgba(255, 255, 255, .09);
}

.card,
.feature-card,
.post-card,
.post-photo-card,
.store-ea-card {
  border: 1px solid var(--border-soft);
  border-radius: .9rem;
  background: color-mix(in srgb, var(--surface), transparent 0%);
  box-shadow: var(--shadow-sm);
}

.card-header,
.card-footer,
.post-card-footer,
.store-ea-footer {
  background: var(--surface-strong) !important;
  border-color: var(--border-soft);
}

.card-body {
  color: var(--text-strong);
}

.card:hover,
.feature-card:hover,
.post-card:hover,
.post-photo-card:hover,
.store-ea-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-md);
}

.license-status-card {
  border: 1px solid color-mix(in srgb, var(--brand), transparent 76%) !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--brand-soft), var(--surface) 20%), var(--surface) 62%);
}

.license-status-card::before {
  height: .22rem;
  background: linear-gradient(90deg, var(--brand), var(--accent));
}

.stat-card {
  border-radius: .9rem;
  box-shadow: var(--shadow-sm);
}

.stat-card.bg-primary,
.btn-primary {
  background: linear-gradient(135deg, #6366f1, #4f46e5) !important;
}

.stat-card.bg-success {
  background: linear-gradient(135deg, #0f766e, #16803c) !important;
}

.stat-card.bg-danger {
  background: linear-gradient(135deg, #c0263f, #8f1d46) !important;
}

.stat-card.bg-secondary {
  background: linear-gradient(135deg, #475569, #1f2937) !important;
}

.stat-card.bg-warning {
  background: linear-gradient(135deg, #f8c55b, #d98917) !important;
}

.btn {
  border-radius: .68rem;
  font-weight: 750;
}

.btn-primary {
  border-color: #6366f1 !important;
  box-shadow: 0 10px 22px rgba(99, 102, 241, .22);
}

.btn-primary:hover,
.btn-primary:focus {
  border-color: #4f46e5 !important;
  box-shadow: 0 14px 28px rgba(99, 102, 241, .30);
}

.btn-outline-secondary {
  background: var(--surface);
}

.form-control,
.form-select,
.input-group-text {
  border-radius: .7rem;
  border-color: var(--border-soft);
}

.form-control,
.form-select {
  min-height: 2.7rem;
}

.form-control:focus,
.form-select:focus {
  border-color: color-mix(in srgb, var(--brand), transparent 25%);
  box-shadow: 0 0 0 .24rem var(--input-focus-shadow);
}

.table-responsive {
  border-radius: .9rem;
}

.table thead th {
  background: var(--surface-strong);
  color: var(--text-muted);
  font-size: .7rem;
  letter-spacing: .035em;
}

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

.badge {
  padding: .46em .76em;
  font-weight: 850;
}

.user-avatar-wrap,
.ea-icon-wrap,
.feature-icon {
  border-radius: .8rem;
  background: var(--brand-soft);
  border: 1px solid color-mix(in srgb, var(--brand), transparent 78%);
}

.user-avatar-wrap {
  border-radius: 1rem;
}

.auth-card {
  border-radius: 1rem;
  box-shadow: var(--shadow-lg);
}

.auth-logo {
  border-radius: 1rem;
  background: linear-gradient(135deg, #6366f1, #4f46e5);
}

.hero-section,
.hero-compact {
  background:
    radial-gradient(circle at 78% 22%, rgba(139, 92, 246, .20), transparent 380px),
    radial-gradient(circle at 15% 70%, rgba(52, 211, 153, .13), transparent 320px),
    linear-gradient(180deg, #08081a 0%, #100e2a 100%);
}

.hero-section {
  padding: 5.4rem 0 5rem;
}

.hero-badge {
  color: #c4b5fd;
  background: rgba(139, 92, 246, .14);
  border-color: rgba(139, 92, 246, .28);
}

.hero-title {
  max-width: 720px;
  font-weight: 900;
}

.hero-subtitle {
  color: rgba(226, 232, 240, .76);
}

.hero-code-block {
  border-radius: 1rem;
  border-color: rgba(148, 163, 184, .18);
  background: rgba(8, 15, 29, .88);
  box-shadow: 0 34px 90px rgba(0, 0, 0, .42);
}

.features-section,
.blog-grid-section {
  background: transparent;
}

.blog-section,
.ea-preview-section {
  background: color-mix(in srgb, var(--surface), var(--app-bg) 34%);
}

.section-title {
  letter-spacing: 0;
}

.store-ea-photo {
  height: 110px;
}

@media (max-width: 767.98px) {
  main.container-fluid {
    padding-inline: 1rem !important;
  }

  .navbar-easapi .container-fluid {
    padding-inline: 1rem !important;
  }

  .hero-section {
    padding: 4rem 0 3.75rem;
  }

  .card-body.p-4,
  .card-body.p-5 {
    padding: 1.25rem !important;
  }
}

/* Mobile responsiveness */
img,
video,
iframe {
  max-width: 100%;
}

.table-responsive {
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 991.98px) {
  body {
    font-size: .93rem;
  }

  .navbar-easapi .navbar-collapse {
    padding-top: .75rem;
  }

  .navbar-easapi .navbar-nav {
    gap: .25rem !important;
  }

  .navbar-easapi .nav-link,
  .navbar-easapi .dropdown-item {
    padding: .72rem .85rem;
  }

  .navbar-easapi .dropdown-menu {
    margin-top: .2rem;
    box-shadow: none;
  }

  #themeToggle {
    width: 100%;
    justify-content: flex-start;
    gap: .5rem;
    padding: .72rem .85rem;
    border-radius: .6rem;
  }

  .admin-subnav {
    top: 56px;
  }

  .admin-subnav .container-fluid {
    padding-inline: 1rem !important;
  }

  .hero-section,
  .hero-compact {
    padding: 3.5rem 0 3rem;
  }

  .hero-title,
  .section-title,
  .post-page-title {
    overflow-wrap: anywhere;
  }

  .store-ea-footer,
  .post-card-footer,
  .card-header.d-flex,
  .card-footer.d-flex {
    flex-wrap: wrap;
    gap: .75rem;
  }
}

@media (max-width: 767.98px) {
  .container,
  .container-fluid {
    --bs-gutter-x: 1.5rem;
  }

  main.container-fluid,
  .admin-subnav + main.container-fluid {
    padding-top: 1rem !important;
    padding-bottom: 1.5rem !important;
  }

  main[style*="padding"] {
    padding-top: 1.5rem !important;
    padding-bottom: 2.5rem !important;
  }

  .d-flex.align-items-center.justify-content-between,
  .d-flex.align-items-center.justify-content-between.mb-4 {
    align-items: stretch !important;
  }

  .d-flex.align-items-center.justify-content-between > .btn,
  .d-flex.align-items-center.justify-content-between > a.btn {
    width: 100%;
  }

  .card,
  .auth-card,
  .feature-card,
  .post-card,
  .post-photo-card,
  .store-ea-card {
    border-radius: .75rem;
  }

  .card-header,
  .card-footer,
  .store-ea-footer,
  .post-card-footer {
    padding-inline: 1rem !important;
  }

  .table-responsive {
    border-radius: .75rem;
    margin-inline: -1px;
  }

  .table-responsive > .table {
    min-width: 720px;
  }

  .table thead th,
  .table tbody td {
    padding: .72rem .75rem;
    font-size: .84rem;
  }

  .table .btn-sm,
  .table .form-control-sm,
  .table .form-select-sm {
    min-height: 2.05rem;
  }

  .btn,
  .form-control,
  .form-select,
  .input-group-text {
    font-size: .92rem;
  }

  .btn:not(.btn-sm) {
    min-height: 2.55rem;
  }

  .input-group {
    flex-wrap: nowrap;
  }

  .auth-page {
    padding: 1rem 0;
  }

  .auth-logo {
    width: 3.4rem;
    height: 3.4rem;
    font-size: 1.8rem;
  }

  .user-avatar-wrap {
    width: 52px;
    height: 52px;
    font-size: 1.55rem;
  }

  .stat-card .stat-num {
    font-size: 1.55rem;
  }

  .hero-section,
  .hero-compact {
    padding: 2.75rem 0 2.5rem;
  }

  .hero-badge {
    max-width: 100%;
    white-space: normal;
  }

  .hero-subtitle {
    font-size: 1rem;
  }

  .hero-code-block,
  .post-code-block {
    border-radius: .75rem;
  }

  .hero-code-block pre,
  .post-code-block-body {
    font-size: .76rem;
  }

  .features-section,
  .blog-section,
  .ea-preview-section,
  .blog-grid-section {
    padding-block: 2rem;
  }

  .feature-strip-item {
    justify-content: flex-start;
    border-right: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .07);
  }

  .feature-strip .row > [class*="col-"]:last-child .feature-strip-item {
    border-bottom: 0;
  }

  .blog-grid-header {
    align-items: stretch;
  }

  .post-photo-grid {
    gap: .85rem;
  }

  .store-ea-photo {
    height: 110px;
  }

  .store-ea-footer {
    flex-wrap: wrap;
    gap: .4rem;
  }

  footer,
  .landing-footer {
    text-align: center;
  }

  footer .d-flex,
  .landing-footer .d-flex {
    justify-content: center !important;
  }
}

@media (max-width: 575.98px) {
  body {
    font-size: .91rem;
  }

  .navbar-easapi .navbar-brand {
    max-width: calc(100vw - 5.5rem);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .admin-subnav-item {
    padding: .48rem .7rem;
    font-size: .78rem;
  }

  .card-body,
  .auth-card .card-body {
    padding: 1rem !important;
  }

  .row.g-4 {
    --bs-gutter-y: 1rem;
  }

  .row.g-3 {
    --bs-gutter-y: .85rem;
  }

  .btn,
  .btn-sm {
    white-space: normal;
  }

  .btn-sm {
    min-height: 2.05rem;
  }

  .badge {
    white-space: normal;
    text-align: center;
  }

  .section-title,
  .hero-title {
    font-size: clamp(1.65rem, 10vw, 2.35rem);
    line-height: 1.1;
  }

  .post-page-title {
    font-size: 1.45rem;
  }

  .store-ea-price {
    font-size: 1.05rem;
  }

  .store-ea-footer .btn {
    flex: 1 1 2.55rem;
  }
}

@media (max-width: 380px) {
  main.container-fluid,
  .navbar-easapi .container-fluid,
  .admin-subnav .container-fluid {
    padding-inline: .75rem !important;
  }

  .card-body,
  .auth-card .card-body {
    padding: .85rem !important;
  }

  .store-ea-photo {
    height: 110px;
  }

  .table-responsive > .table {
    min-width: 660px;
  }
}

/* ── Redesign 2026: tipografia, hero, blog grid, EA cards ──────────────────── */

:root, [data-bs-theme="light"] {
  --grid-line: rgba(17, 12, 54, .05);
  --brand-strong: #4f46e5;
  --text-soft: #3d3c54;
}
[data-bs-theme="dark"] {
  --grid-line: rgba(184, 188, 255, .045);
  --brand-strong: #a5b4fc;
  --text-soft: #bdc0e0;
}

h1, h2, h3, h4, h5, .font-display {
  font-family: "Space Grotesk", Inter, sans-serif;
}
.mono { font-family: "JetBrains Mono", ui-monospace, monospace; }
.eyebrow {
  font-size: .72rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase;
  color: var(--brand-strong);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  display: block; margin-bottom: .25rem;
}

/* Brand mark */
.brand-mark {
  width: 30px; height: 30px; border-radius: 9px;
  display: inline-grid; place-items: center; flex-shrink: 0;
  color: #fff; font-size: .95rem;
  background: linear-gradient(135deg, var(--brand), var(--brand-strong));
  box-shadow: 0 6px 16px color-mix(in srgb, var(--brand) 40%, transparent);
}

/* Hero new */
.hero-new {
  position: relative; overflow: hidden; padding: 5.5rem 0 4rem;
}
.hero-new::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 46px 46px;
  mask-image: radial-gradient(120% 80% at 50% 0%, #000 35%, transparent 78%);
  -webkit-mask-image: radial-gradient(120% 80% at 50% 0%, #000 35%, transparent 78%);
}
.hero-new .container { position: relative; z-index: 1; }

/* Trust badges */
.hero-trust { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.hero-trust-item { display: flex; align-items: center; gap: .5rem; font-size: .86rem; color: var(--text-muted); }
.hero-trust-item i { color: var(--accent); font-size: 1rem; }

/* Terminal card */
.term {
  border-radius: 18px; overflow: hidden;
  background: var(--surface); border: 1px solid var(--border-strong);
  box-shadow: var(--shadow-lg);
}
.term-head {
  display: flex; align-items: center; gap: .5rem;
  padding: .7rem 1rem; border-bottom: 1px solid var(--border-soft);
  background: var(--surface-strong);
}
.term-dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.term-file {
  margin-left: .5rem; font-family: "JetBrains Mono", monospace;
  font-size: .74rem; color: var(--text-muted);
}
.term-tag {
  margin-left: auto; font-size: .66rem; font-weight: 700; letter-spacing: .05em;
  color: var(--accent); background: var(--accent-soft); padding: .2rem .55rem;
  border-radius: 6px; font-family: "JetBrains Mono", monospace;
}
.term-body {
  margin: 0; padding: 1.1rem 1.2rem;
  font-family: "JetBrains Mono", monospace; font-size: .78rem; line-height: 1.75;
  color: var(--text-soft); overflow: auto;
}
.term-body .ln {
  color: color-mix(in srgb, var(--text-muted) 60%, transparent);
  user-select: none; margin-right: 1rem;
}
.term-body .c-kw  { color: var(--brand-strong); }
.term-body .c-fn  { color: var(--accent); }
.term-body .c-str { color: #e0a458; }
.term-body .c-cm  { color: var(--text-muted); font-style: italic; }
[data-bs-theme="dark"] .term-body .c-str { color: #f5c777; }

/* License chip */
.lic-chip {
  display: flex; align-items: center; gap: .8rem;
  margin: -14px 1.1rem 0; position: relative; z-index: 2;
  padding: .75rem 1rem; border-radius: 13px;
  background: var(--surface); border: 1px solid var(--border-strong);
  box-shadow: var(--shadow-md);
}
.lic-chip .ico {
  width: 34px; height: 34px; border-radius: 9px;
  display: grid; place-items: center; flex-shrink: 0;
  background: var(--accent-soft); color: var(--accent); font-size: 1.05rem;
}
.lic-chip .meta { font-size: .7rem; color: var(--text-muted); line-height: 1.2; }
.lic-chip .val {
  font-family: "JetBrains Mono", monospace; font-size: .82rem;
  font-weight: 600; color: var(--text-strong);
}
.lic-chip .pulse {
  margin-left: auto; display: inline-flex; align-items: center; gap: .4rem;
  font-size: .72rem; font-weight: 600; color: var(--accent);
}
.lic-chip .pulse::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: var(--accent); animation: licpulse 2s infinite;
}
@keyframes licpulse {
  0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 55%, transparent); }
  70%  { box-shadow: 0 0 0 8px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}

/* Feature strip new */
.strip-new {
  border-block: 1px solid var(--border-soft);
  background: color-mix(in srgb, var(--surface) 55%, transparent);
}
.strip-new .container {
  display: grid; grid-template-columns: repeat(3, 1fr);
}
.strip-new-item {
  display: flex; align-items: center; gap: .85rem; padding: 1.15rem 0;
}
.strip-new-item + .strip-new-item {
  border-left: 1px solid var(--border-soft); padding-left: 2rem;
}
.strip-new-item .ico {
  width: 40px; height: 40px; border-radius: 11px;
  display: grid; place-items: center; flex-shrink: 0;
  background: var(--brand-soft); color: var(--brand-strong); font-size: 1.15rem;
}
.strip-new-item .ttl { font-weight: 600; font-size: .92rem; color: var(--text-strong); line-height: 1.2; }
.strip-new-item .sub { font-size: .78rem; color: var(--text-muted); }

/* Section headers */
.sec-head-new {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 1rem; margin-bottom: 2rem; flex-wrap: wrap;
}
.sec-title-new {
  font-size: clamp(1.7rem, 2.6vw, 2.15rem); font-weight: 700;
  letter-spacing: -.02em; margin: .4rem 0 0;
}
.sec-desc-new { font-size: .96rem; color: var(--text-muted); margin: .4rem 0 0; max-width: 34rem; }
.link-all {
  display: inline-flex; align-items: center; gap: .4rem;
  font-weight: 600; font-size: .9rem; color: var(--brand-strong);
  white-space: nowrap;
}
.link-all:hover { gap: .6rem; }

/* Blog grid new */
.blog-grid-new {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.1rem;
}
@media (max-width: 1199px) { .blog-grid-new { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .blog-grid-new { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 479px)  { .blog-grid-new { grid-template-columns: 1fr; } }

.post-new {
  position: relative; display: flex; flex-direction: column;
  background: var(--surface); border: 1px solid var(--border-soft);
  border-radius: 16px; overflow: hidden; text-decoration: none; color: inherit;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.post-new:hover {
  transform: translateY(-4px); border-color: var(--border-strong);
  box-shadow: var(--shadow-md); color: inherit;
}
.post-new .lang-rail { height: 3px; width: 100%; flex-shrink: 0; }
.post-new .post-body  { padding: 1.05rem 1.1rem .9rem; flex: 1; display: flex; flex-direction: column; }
.post-new .lang-tag {
  display: inline-flex; align-items: center; gap: .4rem;
  font-family: "JetBrains Mono", monospace; font-size: .66rem; font-weight: 600;
}
.post-new .lang-sq { width: 8px; height: 8px; border-radius: 3px; flex-shrink: 0; }
.post-new .post-ttl {
  font-size: 1rem; font-weight: 600; line-height: 1.32; color: var(--text-strong);
  margin: .6rem 0 auto;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.post-new .post-date {
  font-size: .72rem; color: var(--text-muted); margin-top: .8rem;
  font-family: "JetBrains Mono", monospace;
}
.post-new .code-preview {
  margin-top: .75rem; padding: .55rem .7rem; border-radius: 9px;
  background: var(--surface-tint); border: 1px solid var(--border-soft);
  font-family: "JetBrains Mono", monospace; font-size: .7rem; color: var(--text-muted);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* EA grid new (landing preview) */
.ea-grid-new {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem;
}
@media (max-width: 1199px) { .ea-grid-new { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 767px)  { .ea-grid-new { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 479px)  { .ea-grid-new { grid-template-columns: 1fr; } }

.ea-new {
  display: flex; flex-direction: column;
  background: var(--surface); border: 1px solid var(--border-soft);
  border-radius: .9rem; overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.ea-new:hover { transform: translateY(-3px); border-color: var(--border-strong); box-shadow: var(--shadow-md); }

.ea-new-photo {
  position: relative; height: 110px; overflow: hidden;
  background:
    radial-gradient(120% 120% at 80% 0%, color-mix(in srgb, var(--brand) 32%, transparent), transparent 60%),
    linear-gradient(160deg, var(--surface-strong), var(--surface-muted));
}
.ea-new-photo img { width: 100%; height: 100%; object-fit: cover; }
.ea-new-photo .ver-badge {
  position: absolute; top: .45rem; left: .45rem;
  font-family: "JetBrains Mono", monospace; font-size: .64rem; font-weight: 600;
  color: #fff; background: rgba(0,0,0,.42); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.16); border-radius: 6px; padding: .15rem .4rem;
}
.ea-new-photo .file-badge {
  position: absolute; top: .45rem; right: .45rem;
  font-family: "JetBrains Mono", monospace; font-size: .62rem; font-weight: 600;
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 18%, rgba(0,0,0,.45));
  border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  border-radius: 6px; padding: .15rem .38rem;
  display: inline-flex; align-items: center; gap: .25rem;
}
.ea-new-body { padding: .65rem 1rem .4rem; flex: 1; }
.ea-new-name {
  font-size: .92rem; font-weight: 700; color: var(--text-strong);
  margin: 0 0 .15rem; letter-spacing: -.01em; line-height: 1.3;
}
.ea-new-owner {
  display: flex; align-items: center; gap: .35rem;
  font-size: .72rem; color: var(--text-muted);
}
.ea-new-desc { font-size: .82rem; line-height: 1.5; color: var(--text-muted); margin: .3rem 0 0; }
.ea-new-foot {
  display: flex; align-items: center; justify-content: space-between;
  padding: .6rem 1rem;
  border-top: 1px solid var(--border-soft); background: var(--surface-strong);
}
.ea-new-price .cur { font-size: .75rem; font-weight: 600; color: var(--text-muted); margin-right: .05rem; }
.ea-new-price .num {
  font-family: "JetBrains Mono", monospace; font-size: 1.05rem;
  font-weight: 700; color: var(--text-strong); letter-spacing: -.02em;
}
.ea-new-price .per { font-size: .68rem; color: var(--text-muted); }

/* EA category sections (landing) */
.ea-category-section {
  margin-bottom: 2.5rem;
}

.ea-category-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: .85rem;
  padding-bottom: .6rem;
  border-bottom: 1px solid var(--border-soft);
}

.ea-category-label {
  font-size: .85rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: .4rem;
  letter-spacing: .01em;
}

.ea-category-more {
  font-size: .78rem;
  font-weight: 600;
  color: var(--text-muted);
  display: flex;
  align-items: center;
  gap: .3rem;
  transition: color .15s;
}
.ea-category-more:hover { color: var(--brand); }

/* EA hint strip */
.ea-hint-new {
  margin-top: 1.6rem; display: flex; align-items: center; justify-content: center; gap: .5rem;
  font-size: .88rem; color: var(--text-muted); text-align: center;
  padding: .85rem 1.2rem; border-radius: 12px;
  background: var(--brand-soft); border: 1px solid color-mix(in srgb, var(--brand) 22%, transparent);
}
.ea-hint-new a { font-weight: 650; }

@media (max-width: 991px) {
  .hero-new { padding: 3.5rem 0 3rem; }
  .strip-new .container { grid-template-columns: 1fr; }
  .strip-new-item + .strip-new-item { border-left: none; border-top: 1px solid var(--border-soft); padding-left: 0; }
}
@media (max-width: 767px) {
  .hero-new { padding: 2.5rem 0 2rem; }
  .lic-chip { margin-top: .5rem; }
}

/* ── Block Editor (admin/post-form) ─────────────────────────────────────── */
.block-item {
  border: 1px solid var(--bs-border-color);
  border-radius: 10px;
  margin-bottom: 10px;
  background: var(--bs-body-bg);
  transition: box-shadow .15s;
}
.block-item:focus-within {
  box-shadow: 0 0 0 3px rgba(99,102,241,.18);
  border-color: var(--brand, #6366f1);
}
.block-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .5rem .9rem;
  border-bottom: 1px solid var(--bs-border-color);
  background: var(--bs-tertiary-bg);
  border-radius: 9px 9px 0 0;
  user-select: none;
}
.block-type-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--bs-secondary-color);
}
.block-actions { display: flex; gap: 3px; }
.block-btn {
  border: none;
  background: transparent;
  padding: 3px 7px;
  border-radius: 5px;
  cursor: pointer;
  color: var(--bs-secondary-color);
  font-size: .85rem;
  line-height: 1;
  transition: background .12s, color .12s;
}
.block-btn:hover { background: var(--bs-secondary-bg); color: var(--bs-body-color); }
.block-btn.text-danger:hover { background: rgba(220,53,69,.12); color: #dc3545; }
.block-body { padding: .9rem; }
.block-img-preview img { max-height: 200px; object-fit: contain; }
.blocks-empty {
  border: 2px dashed var(--bs-border-color);
  border-radius: 10px;
  padding: 2.5rem;
  text-align: center;
  color: var(--bs-secondary-color);
  font-size: .9rem;
}
.add-block-bar {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  padding: .75rem;
  background: var(--bs-tertiary-bg);
  border-radius: 10px;
  border: 1px solid var(--bs-border-color);
}
.add-block-btn {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .35rem .8rem;
  border-radius: 6px;
  border: 1px solid var(--bs-border-color);
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .12s, border-color .12s;
}
.add-block-btn:hover {
  background: var(--brand, #6366f1);
  border-color: var(--brand, #6366f1);
  color: #fff;
}

/* ── Post blocks (public view) ───────────────────────────────────────────── */
.post-block-heading {
  margin-top: 2rem;
  margin-bottom: 1rem;
  font-weight: 700;
  color: var(--bs-heading-color, var(--bs-body-color));
}
.post-image-block img {
  display: block;
  max-width: 100%;
  border-radius: 10px;
  box-shadow: 0 4px 18px rgba(0,0,0,.12);
}
.post-img-caption {
  margin-top: .5rem;
  font-size: .82rem;
  color: var(--bs-secondary-color);
  text-align: center;
  font-style: italic;
}

/* ── MT5 Panel Component ─────────────────────────────────────────────────── */
.mt5-panel {
  border-radius: 18px;
  overflow: hidden;
  background: #080d18;
  border: 1px solid rgba(99,102,241,.28);
  box-shadow:
    0 32px 80px rgba(0,0,0,.55),
    0 0 0 1px rgba(99,102,241,.08),
    inset 0 1px 0 rgba(255,255,255,.06);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  font-size: .8rem;
  color: #c8d4f0;
}

/* Titlebar */
.mt5-tb {
  display: flex;
  align-items: center;
  padding: .6rem 1rem;
  background: #050912;
  border-bottom: 1px solid rgba(255,255,255,.07);
  gap: .75rem;
}
.mt5-dots { display: flex; gap: 6px; flex-shrink: 0; }
.mt5-dots span { width: 11px; height: 11px; border-radius: 50%; }
.mt5-tb-center {
  flex: 1;
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .73rem;
  color: rgba(200,212,240,.55);
  justify-content: center;
}
.mt5-tb-pair {
  padding: .15rem .5rem;
  background: rgba(99,102,241,.2);
  border-radius: 5px;
  color: #a5b4fc;
  font-size: .67rem;
  font-weight: 700;
  letter-spacing: .04em;
}
.mt5-lic-pill {
  font-size: .64rem;
  font-weight: 700;
  letter-spacing: .1em;
  padding: .2rem .55rem;
  border-radius: 6px;
  background: rgba(52,211,153,.14);
  color: #34d399;
  border: 1px solid rgba(52,211,153,.22);
  flex-shrink: 0;
}

/* Auth banner */
.mt5-auth-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  background: rgba(99,102,241,.09);
  border-bottom: 1px solid rgba(99,102,241,.16);
}
.mt5-shield {
  width: 32px; height: 32px;
  border-radius: 9px;
  display: grid; place-items: center;
  background: rgba(99,102,241,.22);
  color: #a5b4fc;
  font-size: 1rem;
  flex-shrink: 0;
}
.mt5-auth-label {
  font-size: .78rem;
  font-weight: 600;
  color: #a5b4fc;
  font-family: "Space Grotesk", Inter, sans-serif;
  letter-spacing: -.01em;
}
.mt5-auth-sub {
  font-size: .66rem;
  color: rgba(200,212,240,.45);
  margin-top: .1rem;
}
.mt5-auth-exp {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .72rem;
  font-weight: 600;
  color: #34d399;
  flex-shrink: 0;
}
.mt5-exp-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #34d399;
  animation: licpulse 2s infinite;
}

/* Content grid */
.mt5-content {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.mt5-col { padding: .85rem 1rem; }
.mt5-col + .mt5-col { border-left: 1px solid rgba(255,255,255,.07); }
.mt5-col-title {
  font-size: .63rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(200,212,240,.35);
  margin-bottom: .55rem;
  font-family: "Space Grotesk", sans-serif;
}

/* Parameters */
.mt5-p {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: .24rem 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: .73rem;
  color: rgba(200,212,240,.5);
}
.mt5-p:last-child { border-bottom: none; }
.mt5-pv { color: #c8d4f0; font-weight: 600; }

/* Stats */
.mt5-stats { display: flex; flex-direction: column; gap: .42rem; padding-top: .1rem; }
.mt5-stat { display: flex; align-items: baseline; gap: .45rem; }
.mt5-stat-n {
  font-size: 1.12rem;
  font-weight: 700;
  color: #c8d4f0;
  letter-spacing: -.03em;
  line-height: 1;
}
.mt5-stat-green { color: #34d399; }
.mt5-stat-l { font-size: .65rem; color: rgba(200,212,240,.38); }

/* Inline code */
.mt5-code {
  padding: .7rem 1rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
  background: rgba(0,0,0,.22);
}
.mt5-code pre {
  margin: 0;
  font-family: "JetBrains Mono", monospace;
  font-size: .73rem;
  line-height: 1.7;
  color: #9ba8c8;
}
.mt5-code .c-kw  { color: #a5b4fc; }
.mt5-code .c-fn  { color: #34d399; }
.mt5-code .c-str { color: #f5c06a; }
.mt5-code .c-cm  { color: rgba(155,168,200,.45); font-style: italic; }

/* Log */
.mt5-log { padding: .6rem 1rem; background: rgba(0,0,0,.3); }
.mt5-log-e {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .18rem 0;
  font-size: .7rem;
  color: rgba(200,212,240,.5);
  line-height: 1.4;
}
.mt5-lt { color: rgba(200,212,240,.28); flex-shrink: 0; font-size: .65rem; }
.mt5-lok { color: #34d399; flex-shrink: 0; font-size: .8rem; }
.mt5-log-live { color: #a5b4fc; }
.mt5-ldot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #a5b4fc;
  flex-shrink: 0;
  animation: licpulse 1.5s infinite;
}

/* ── Landing page section padding ───────────────────────────────────────── */
.section-blog { padding: 4rem 0 3rem; }
.section-eas  { padding: 1rem 0 4.5rem; }

@media (max-width: 991.98px) {
  .section-blog, .section-eas { padding: 3rem 0 2.5rem; }
  .strip-new-item { padding: .9rem 0; }
  .strip-new-item + .strip-new-item { padding-left: 0; }
}

@media (max-width: 767.98px) {
  .section-blog, .section-eas { padding: 2.25rem 0 2rem; }
  .hero-new { padding: 2.5rem 0 2.5rem; }
  .hero-title { font-size: clamp(1.9rem, 8vw, 2.6rem) !important; }
  .sec-head-new { text-align: center; justify-content: center; flex-direction: column; align-items: center; }
  .sec-head-new > div { text-align: center; }
  .eyebrow { display: block; text-align: center; }
  .hero-trust { gap: .9rem; }
  .hero-trust-item { font-size: .8rem; }
  .btn-hero, .btn-hero-outline {
    width: 100%;
    justify-content: center;
  }
  .strip-new-item .ico { width: 34px; height: 34px; font-size: 1rem; }
}

@media (max-width: 479.98px) {
  .blog-grid-new { grid-template-columns: 1fr; }
  .ea-grid-new   { grid-template-columns: 1fr; }
}

/* ── Hero: modo claro ─────────────────────────────────────────────────────── */
[data-bs-theme="light"] .hero-title {
  color: #0f0e1a;
}
[data-bs-theme="light"] .hero-subtitle {
  color: rgba(40, 35, 70, .62);
}
[data-bs-theme="light"] .hero-badge {
  color: #4338ca;
  background: rgba(99, 102, 241, .10);
  border-color: rgba(99, 102, 241, .25);
}
[data-bs-theme="light"] .hero-gradient {
  background: linear-gradient(90deg, #4338ca, #059669);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
[data-bs-theme="light"] .hero-trust-item {
  color: #374151;
}
[data-bs-theme="light"] .btn-hero-outline {
  color: #4338ca;
  border-color: rgba(67, 56, 202, .35);
  background: rgba(99, 102, 241, .06);
}
[data-bs-theme="light"] .btn-hero-outline:hover {
  color: #fff;
  background: #4338ca;
  border-color: #4338ca;
}
