:root {
  --bg: #f6f9fc;
  --bg-soft: #eef4ff;
  --surface: rgba(255, 255, 255, 0.82);
  --surface-strong: #ffffff;
  --surface-muted: #f8fafc;
  --text: #0f172a;
  --muted: #64748b;
  --border: rgba(15, 23, 42, 0.08);
  --border-strong: rgba(15, 23, 42, 0.12);
  --primary: #2563eb;
  --primary-soft: rgba(37, 99, 235, 0.08);
  --shadow: 0 18px 50px rgba(15, 23, 42, 0.08);
  --shadow-soft: 0 10px 30px rgba(15, 23, 42, 0.06);
  --radius: 24px;
}

* {
  box-sizing: border-box;
}

html, body {
  height: 100%;
  margin: 0;
}

body {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at top left, rgba(191, 219, 254, 0.55), transparent 34%),
    radial-gradient(circle at top right, rgba(224, 231, 255, 0.8), transparent 28%),
    linear-gradient(180deg, #f8fbff 0%, #f6f9fc 48%, #edf3fb 100%);
  display: flex;
  flex-direction: column;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(120deg, rgba(255,255,255,0.35), transparent 35%),
    linear-gradient(300deg, rgba(255,255,255,0.18), transparent 28%);
  z-index: -1;
}


.header {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 32px;
  border-radius: var(--radius);
  background: var(--surface);
  border: 1px solid rgba(255,255,255,0.72);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
}

.logo, .preview-logo {
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: transform 0.24s ease, box-shadow 0.24s ease;
  background: linear-gradient(180deg, #fff, #f8fbff);
  margin-right:10px;
}

.logo:hover,
.preview-logo:hover {
  transform: translateY(-1px);
}

.logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.logo-fallback,
.preview-fallback {
  font-weight: 800;
  color: var(--muted);
  letter-spacing: 0.06em;
}

.brand h1 {
  margin: 0;
  font-size: clamp(1.5rem, 2vw, 1.9rem);
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.brand p {
  margin: 8px 0 0;
  font-size: 0.98rem;
  color: var(--muted);
}

/* ====== Header layout ====== */
.site-header {
  width: 100%;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(255,255,255,0.78);
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.10);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
  padding: 14px 18px;
}

.header-top {
  display: flex;
  align-items: center;
  gap: 18px;
  min-width: 0;
}

.header-brand {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.nav {
  position: relative;
  overflow: visible;
  display: flex;
  flex-wrap: wrap;
}

.nav-line-break {
  flex: 0 0 100%;
  width: 100%;
  height: 0;
}

.nav-left { margin-right: auto; }
.nav-right { margin-left: auto; }

.nav-item,
.has-submenu {
  position: relative;
  overflow: visible;
}

.header-top {
  display: flex;
  align-items: center;
}

.nav-top-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 12px;
}

.nav-link,
.submenu-link,
.admin-link,
.btn {
  text-decoration: none;
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    color 0.18s ease;
}

.btn-click {
  text-decoration: none;
  color:white;
  padding: 14px;
  border-radius: 45px;
  background:#03234C;
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    color 0.18s ease;
}

.btn-click:hover {
	transform: scale(1.02);
}

.nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 11px 15px;
  border-radius: 999px;
  color: var(--text);
  border: 1px solid transparent;
  background: transparent;
  font-size: 0.95rem;
  font-weight: 600;
  white-space: nowrap;
}

.has-submenu > .nav-link::after {
  content: "";
  width: 8px;
  height: 8px;
  border-right: 1.8px solid currentColor;
  border-bottom: 1.8px solid currentColor;
  transform: rotate(45deg) translateY(-1px);
  opacity: 0.55;
  margin-left: 2px;
}

.nav-link:hover,
.nav-link:focus-visible {
  background: rgba(255,255,255,0.72);
  border-color: rgba(15, 23, 42, 0.06);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
  transform: translateY(-1px);
  outline: none;
}

.submenu {
  position: absolute;
  top: calc(100% + 12px);
  left: 0;
  min-width: 240px;
  display: none;
  flex-direction: column;
  gap: 6px;
  padding: 10px;
  border-radius: 20px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,0.94);
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.14);
  backdrop-filter: blur(20px);
  z-index: 60;
}

.submenu::before {
  content: "";
  position: absolute;
  top: -7px;
  left: 26px;
  width: 14px;
  height: 14px;
  background: rgba(255,255,255,0.94);
  border-left: 1px solid rgba(15, 23, 42, 0.08);
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  transform: rotate(45deg);
}

.has-submenu::after {
  content: "";
  position: absolute;
  left: 0;
  top: 100%;
  width: 100%;
  height: 18px;
}

.submenu {
  display: flex;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(6px);
  transition:
    opacity 0.18s ease 0.5s,
    transform 0.18s ease 0.5s,
    visibility 0s linear 0.5s;
}

.has-submenu:hover .submenu,
.has-submenu:focus-within .submenu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition:
    opacity 0.18s ease,
    transform 0.18s ease,
    visibility 0s linear 0s;
}

.submenu-link {
  display: block;
  padding: 12px 14px;
  border-radius: 14px;
  color: var(--text);
  background: transparent;
  border: 1px solid transparent;
  font-weight: 500;
}

.submenu-link:hover,
.submenu-link:focus-visible {
  background: var(--primary-soft);
  color: var(--primary);
  border-color: rgba(37, 99, 235, 0.12);
  transform: translateX(2px);
  outline: none;
}

.site-header[data-placement="below"] .header-top {
  flex-wrap: wrap;
}

.site-header[data-placement="below"] .nav-desktop {
  width: 100%;
  margin-left: 0;
  margin-right: 0;
  justify-content: center;
  padding-top: 12px;
}

/* ====== Hamburger ====== */
.hamburger {
  display: none;
  margin-left: auto;
  width: 46px;
  height: 46px;
  border-radius: 15px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,0.8);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.07);
  cursor: pointer;
  align-items: center;
  justify-content: center;
  gap: 5px;
  flex-direction: column;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.hamburger:hover {
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.10);
}

.hamburger span {
  width: 18px;
  height: 2px;
  background: var(--text);
  display: block;
  opacity: 0.85;
  border-radius: 999px;
}

/* Mobile drawer */
.nav-mobile {
  display: none;
  margin-top: 14px;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
  padding-top: 14px;
  gap: 10px;
  flex-direction: column;
}

.nav-mobile.open {
  display: flex;
}

.mobile-menu-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.06);
  background: rgba(255,255,255,0.74);
}

.mobile-submenu {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-left: 12px;
  margin-left: 10px;
  border-left: 1px solid rgba(15, 23, 42, 0.10);
}

/* Admin */
.admin-link {
  color: var(--text);
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255,255,255,0.72);
  padding: 10px 14px;
  border-radius: 14px;
  box-shadow: var(--shadow-soft);
}

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

.notice {
  border: 1px solid rgba(15, 23, 42, 0.08);
  padding: 12px 14px;
  border-radius: 16px;
  font-size: 14px;
  box-shadow: var(--shadow-soft);
  background: rgba(255,255,255,0.72);
}

.notice.success { background: rgba(220, 252, 231, 0.88); }
.notice.error { background: rgba(254, 226, 226, 0.92); }

.card,
.content,
.article,
.preview {
  border: 1px solid rgba(255,255,255,0.72);
  background: rgba(255,255,255,0.72);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(18px);
}

.card {
  border-radius: var(--radius);
}

.field input[type="text"],
.field input[type="number"],
.field input[type="file"],
.field select,
.compact-select,
.compact-input {
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255,255,255,0.88);
  color: var(--text);
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.02);
}

.field input[type="text"]:focus,
.field input[type="number"]:focus,
.field input[type="file"]:focus,
.field select:focus,
.compact-select:focus,
.compact-input:focus {
  outline: none;
  border-color: rgba(37, 99, 235, 0.35);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.10);
}

.btn {
  appearance: none;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  color: var(--text);
  padding: 12px 14px;
  border-radius: 14px;
  cursor: pointer;
  font-weight: 700;
  box-shadow: var(--shadow-soft);
}

/* Responsive */
@media (max-width: 860px) {
  .nav-desktop { display: none; }
  .hamburger { display: flex; }
  .wrap,
  .wrap-top { padding-left: 18px; padding-right: 18px; }
  .site-header {
    padding: 14px;
    border-radius: 24px;
  }
  .header-top {
    gap: 12px;
  }
}

@media (max-width: 768px) {
  .header {
    flex-direction: column;
    text-align: center;
    padding: 26px;
  }

  .brand h1 {
    font-size: 22px;
  }
}


/* ====== Footer ====== */
@media (max-width: 860px) {
  .site-footer {
    padding: 18px;
    border-radius: 22px;
  }

  .site-footer-grid {
    grid-template-columns: 1fr;
  }
}


.field textarea {
  width: 100%;
  min-height: 120px;
  border-radius: 16px;
  padding: 14px 16px;
  resize: vertical;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255,255,255,0.88);
  color: var(--text);
  box-shadow: inset 0 1px 2px rgba(15, 23, 42, 0.02);
  font: inherit;
}

.field textarea:focus {
  outline: none;
  border-color: rgba(37, 99, 235, 0.35);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.10);
}

.site-footer {
  width: 100%;
  margin-top: 6px;
}

.site-footer-shell {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: 32px;
  background:
    radial-gradient(circle at top right, rgba(191, 219, 254, 0.34), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,0.92) 0%, rgba(248,250,252,0.96) 100%);
  border: 1px solid rgba(255,255,255,0.82);
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.10);
}

.site-footer-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,0.35), transparent 40%);
}

.site-footer-brand {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin-bottom: 26px;
}

.site-footer-eyebrow {
  display: inline-flex;
  align-items: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.08);
  color: var(--primary);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 14px;
}

.site-footer-brand h2 {
  margin: 0;
  font-size: clamp(1.6rem, 3vw, 2.3rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.site-footer-brand p {
  margin: 14px 0 0;
  color: var(--muted);
  line-height: 1.7;
  font-size: 1rem;
}

.site-footer-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.05fr 1fr 1fr 1fr;
  gap: 16px;
}

.site-footer-card {
  min-height: 100%;
  padding: 20px;
  border-radius: 22px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(15, 23, 42, 0.07);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.site-footer-card h3 {
  margin: 0 0 14px;
  font-size: 0.98rem;
  letter-spacing: -0.02em;
}

.site-footer-card p {
  margin: 0 0 8px;
  color: var(--muted);
  line-height: 1.65;
}

.site-footer-card p:last-child {
  margin-bottom: 0;
}

.site-footer-card a {
  color: inherit;
  text-decoration: none;
}

.site-footer-card a:hover {
  color: var(--primary);
}

.site-footer-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.site-footer-tags span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.05);
  border: 1px solid rgba(15, 23, 42, 0.07);
  font-weight: 600;
  color: var(--text);
}

.site-footer-bottom {
  position: relative;
  z-index: 1;
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  color: var(--muted);
  font-size: 0.92rem;
}

.cms-footer-preview-modern {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.cms-footer-preview-eyebrow {
  color: var(--primary);
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.cms-footer-preview-brand {
  font-size: 1.45rem;
  font-weight: 800;
  letter-spacing: -0.03em;
}

.cms-footer-preview-text {
  color: var(--muted);
  line-height: 1.6;
}

.cms-footer-preview-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

@media (max-width: 960px) {
  .site-footer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 860px) {
  .site-footer-shell {
    padding: 22px;
    border-radius: 24px;
  }

  .site-footer-grid,
  .cms-footer-preview-columns {
    grid-template-columns: 1fr;
  }
}
.site-header {
  position: relative;
  z-index: 200;
  overflow: visible;
}

.header-top {
  position: relative;
  z-index: 201;
  overflow: visible;
}

.nav,
.nav-item,
.has-submenu {
  position: relative;
  overflow: visible;
}

.submenu {
  z-index: 9999;
}

.content,
.article {
  position: relative;
  z-index: 1;
}

/*BOUTON MENU*/
.nav-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #03234C;
  color: #fff;
  font-size: 15px;
  font-weight: 500;
  letter-spacing: -0.01em;
  padding: 12px 24px;
  border-radius: 980px;
  border: none;
  text-decoration: none;
  transition: background 0.18s ease, transform 0.12s ease;

}
.nav-button:hover {
  background: #041f42;
  transform: scale(1.02);
}
.nav-button:active {
  transform: scale(0.97);
}

/* ====== Blocs articles avancés ====== */
/* ===== BLOCK ===== */

.cms-feature-block {
    display: flex;
    align-items: center;
    gap: 40px;
    flex-wrap: nowrap;
    width: 100%;
}

/* Image à gauche */
.cms-feature-block.image-left {
    flex-direction: row;
}

/* Image à droite */
.cms-feature-block.image-right {
    flex-direction: row-reverse;
}

/* ===== IMAGE ===== */

.cms-feature-media {
    flex: 0 0 40%;
    max-height: 420px;
    overflow: hidden;
    border-radius: 20px;
}

.cms-feature-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* ===== CONTENT ===== */

.cms-feature-content {
    flex: 1;
    min-width: 0;
}

/* ===== TAGS ===== */

.cms-block-tags {
    margin-bottom: 14px;
}

.cms-block-tags span {
    display: inline-block;
    background: #b54830;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 6px 12px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 1px;
}

/* ===== TITLE ===== */

.cms-feature-title {
    margin: 0 0 20px;
    font-size: 46px;
    font-weight: 300;
    letter-spacing: 3px;
    line-height: 1.1;
}

/* ===== TEXT ===== */

.cms-feature-text {
    font-size: 16px;
    line-height: 1.8;
    color: #374151;
}

.cms-feature-text p {
    margin-top: 0;
}

/* ===== TABLE ===== */

.cms-table-wrap {
    margin-top: 25px;
}

.cms-feature-table {
    width: 100%;
    border-collapse: collapse;
}

.cms-feature-table td {
    padding: 12px 0;
    border-bottom: 1px solid #e5e7eb;
    font-size: 14px;
}

.cms-feature-table td:last-child {
    text-align: right;
    font-weight: 700;
}

/* ===== BUTTON ===== */

.cms-download-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 30px;
    background: #b54830;
    color: white;
    text-decoration: none;
    padding: 16px 28px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 1px;
    transition: 0.25s;
}

.cms-download-btn:hover {
    background: #983b27;
    transform: translateY(-1px);
}

/* ===== RESPONSIVE ===== */

@media (max-width: 900px) {

    .cms-feature-block,
    .cms-feature-block.image-left,
    .cms-feature-block.image-right {
        flex-direction: column;
    }

    .cms-feature-media,
    .cms-feature-content {
        width: 100%;
    }

    .cms-feature-title {
        font-size: 32px;
    }
	
	.content{
		width:100%;
	}
}
/* ====== Fichiers multiples dans les articles ====== */
.cms-downloads {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 28px;
}

.cms-downloads .cms-download-btn {
    margin-top: 0;
}

.tags-bottom {
    margin-top: 22px;
    margin-bottom: 0;
}

.header-home-link{
    text-decoration: none;
    color: inherit;
    display: flex;
    align-items: center;
}

/* ===== Sous-header / Hero sous le menu ===== */
.hero-subheader {
  padding: 58px 20px 46px;
  text-align: center;
  position: relative;
}

.hero-subheader-inner {
  max-width: 1100px;
  margin: 0 auto;
}

.hero-subheader-title {
  margin: 0;
  font-size: clamp(34px, 4.2vw, 64px);
  font-weight: 300;
  letter-spacing: 6px;
  line-height: 1.1;
  text-transform: uppercase;
  color: #d9b98c;
}

.hero-subheader-subtitle {
  margin: 18px 0 0;
  font-size: clamp(16px, 1.7vw, 25px);
  letter-spacing: 2px;
  line-height: 1.35;
  text-transform: uppercase;
  color: #d9b98c;
  opacity: 0.92;
}

.hero-subheader::after {
  content: "";
  display: block;
  width: min(420px, 70%);
  height: 1px;
  margin: 34px auto 0;
  background: rgba(217, 185, 140, 0.35);
}

@media (max-width: 768px) {
  .hero-subheader {
    padding: 38px 16px 28px;
  }

  .hero-subheader-title {
    letter-spacing: 3px;
  }

  .hero-subheader-subtitle {
    letter-spacing: 1px;
  }
  
  .row-actions{
      gap:8px;
      align-items:center;
      justify-content:flex-end;
      flex-wrap:nowrap;
    }
}

/* ===== Module Tarifs ===== */
.tarifs-page{
  position:relative;
  display:flex;
  flex-direction:column;
  gap:24px;
  padding-top:28px;
  overflow:hidden;
}
.tarifs-page:before{
  content:"";
  position:absolute;
  inset:0 -40px auto -40px;
  height:420px;
  background:
    radial-gradient(circle at 96% 18%, rgba(37,99,235,.10), transparent 32%),
    radial-gradient(circle at 7% 80%, rgba(214,236,86,.22), transparent 18%),
    linear-gradient(180deg, rgba(248,251,255,.96), rgba(255,255,255,0));
  pointer-events:none;
  z-index:0;
}
.tarifs-page>*{position:relative;z-index:1}
.tarifs-hero{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:12px 0 8px;
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
}
.tarifs-hero:before{display:none}
.tarifs-hero-title{display:flex;align-items:center;gap:18px;min-width:0}
.tarifs-hero-icon{
  width:66px;height:66px;border-radius:22px;
  display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
  background:rgba(255,255,255,.86);
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 14px 32px rgba(3,35,76,.10);
  font-size:28px;color:#03234C;
}
.tarifs-kicker{display:none}
.tarifs-hero h1{margin:0;font-size:clamp(1.9rem,3vw,2.8rem);line-height:1.04;letter-spacing:-.045em;color:#03234C}
.tarifs-hero p{max-width:720px;margin:6px 0 0;color:#334155;font-size:1.03rem;line-height:1.45}
.tarifs-pdf{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:10px;justify-content:center;
  padding:15px 22px;border-radius:16px;background:rgba(255,255,255,.82);
  color:#03234C;text-decoration:none;font-weight:900;border:1px solid rgba(15,23,42,.10);
  box-shadow:0 12px 28px rgba(3,35,76,.08);
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease;
}
.tarifs-pdf:hover{transform:translateY(-2px);box-shadow:0 18px 42px rgba(3,35,76,.14);background:#fff}
.tarifs-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:22px;align-items:stretch;grid-auto-rows:auto}
.tarif-card{
  position:relative;overflow:hidden;background:rgba(255,255,255,.90);
  border:1px solid rgba(15,23,42,.08);border-radius:24px;padding:0;
  box-shadow:0 18px 42px rgba(3,35,76,.10);display:flex;flex-direction:column;min-width:0;height:100%;
}
.tarif-card header{
  min-height:136px;padding:28px 20px;border-radius:0;background:linear-gradient(135deg,#f8fbff,#eef5ff);
  border:0;border-bottom:1px solid rgba(15,23,42,.06);text-align:left;display:grid;grid-template-columns:74px 1fr;gap:18px;align-items:center;box-sizing:border-box;
}
.tarif-card-icon{
  width:66px;height:66px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#1d75d8,#0a56bd);box-shadow:0 14px 28px rgba(29,117,216,.28);color:#fff;font-size:31px;
}
.tarif-card:nth-child(1) .tarif-card-icon:before{content:"🎾"}.tarif-card:nth-child(2) .tarif-card-icon:before{content:"▱";font-size:42px;transform:rotate(30deg)}.tarif-card:nth-child(3) .tarif-card-icon:before{content:"🏆"}.tarif-card:nth-child(4) .tarif-card-icon:before{content:"🎁"}.tarif-card:nth-child(5) .tarif-card-icon:before{content:"★"}
.tarif-accent-orange header{background:linear-gradient(135deg,#fff8ec,#fff0dc)}
.tarif-accent-orange .tarif-card-icon{background:linear-gradient(135deg,#ff9f18,#f07800);box-shadow:0 14px 28px rgba(240,120,0,.25)}
.tarif-accent-teal header,.tarif-accent-green header{background:linear-gradient(135deg,#effdfb,#e9f7f6)}
.tarif-accent-teal .tarif-card-icon,.tarif-accent-green .tarif-card-icon{background:linear-gradient(135deg,#11b6b5,#008c95);box-shadow:0 14px 28px rgba(0,140,149,.25)}
.tarif-accent-purple header{background:linear-gradient(135deg,#fbf7ff,#f1e8ff)}
.tarif-accent-purple .tarif-card-icon{background:linear-gradient(135deg,#9b5ad6,#7441b7);box-shadow:0 14px 28px rgba(116,65,183,.25)}
.tarif-card h2{margin:0;color:#03234C;text-transform:uppercase;letter-spacing:.01em;font-size:1.18rem;line-height:1.12;font-weight:950}
.tarif-card header span:not(.tarif-card-icon){display:inline-flex;margin-top:9px;padding:8px 13px;border-radius:999px;background:#126fd1;color:#fff;font-size:.76rem;font-weight:900;box-shadow:0 8px 18px rgba(18,111,209,.18)}
.tarif-accent-orange header span:not(.tarif-card-icon){background:#f18400}.tarif-accent-teal header span:not(.tarif-card-icon),.tarif-accent-green header span:not(.tarif-card-icon){background:#11a6aa}.tarif-accent-purple header span:not(.tarif-card-icon){background:#8551c8}
.tarif-card h3{margin:20px 18px 8px;color:#03234C;text-transform:uppercase;font-size:.78rem;letter-spacing:.06em;font-weight:950}.tarif-accent-orange h3{color:#f07800}.tarif-accent-teal h3,.tarif-accent-green h3{color:#008c95}.tarif-accent-purple h3{color:#7441b7}
.tarif-list{display:flex;flex-direction:column;gap:0;padding:14px 18px 0}.tarif-section-list{padding-top:0}.tarif-main-list+.tarif-card h3{margin-top:16px}
.tarif-row{display:grid;grid-template-columns:max-content minmax(0,1fr) repeat(3,max-content);gap:9px;align-items:center;padding:10px 0;border-bottom:1px solid rgba(15,23,42,.09)}
.tarif-row-cells-1{grid-template-columns:minmax(0,1fr)}.tarif-row-cells-2{grid-template-columns:max-content minmax(0,1fr)}.tarif-row-cells-3{grid-template-columns:max-content minmax(0,1fr) max-content}.tarif-row-cells-4{grid-template-columns:max-content minmax(0,1fr) max-content max-content}.tarif-row-cells-5{grid-template-columns:max-content minmax(0,1fr) max-content max-content max-content}
.tarif-cell{min-width:0;color:#334155;font-size:.86rem;line-height:1.35;display:flex;align-items:center}.tarif-cell-1{color:#03234C;font-weight:950}.tarif-cell-2{overflow-wrap:normal;word-break:normal}.tarif-cell-3,.tarif-cell-4{white-space:nowrap}.tarif-cell-5{color:#03234C;font-weight:950;white-space:nowrap;text-align:right;justify-content:flex-end}
.tarif-notes{margin:16px 18px 20px;padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,#f8fbff,#f0f6ff);color:#475569;font-size:.84rem;line-height:1.55}.tarif-accent-orange .tarif-notes{background:linear-gradient(135deg,#fffaf2,#fff2de)}.tarif-accent-teal .tarif-notes,.tarif-accent-green .tarif-notes{background:linear-gradient(135deg,#f0fffd,#eaf8f7)}.tarif-accent-purple .tarif-notes{background:linear-gradient(135deg,#fbf7ff,#f3ecff)}
.tarif-notes ul{margin:0;padding-left:0;list-style:none}.tarif-notes li{position:relative;margin:6px 0;padding-left:22px}.tarif-notes li:before{content:"✓";position:absolute;left:0;top:0;width:15px;height:15px;border-radius:50%;background:#2774d8;color:#fff;font-size:10px;display:inline-flex;align-items:center;justify-content:center}.tarif-notes p{margin:6px 0}
.tarifs-bonus{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;align-items:start}.tarifs-bonus-card,.tarifs-contact{background:rgba(255,255,255,.86);border:1px solid rgba(15,23,42,.08);border-radius:22px;padding:18px;box-shadow:0 14px 32px rgba(3,35,76,.08);text-align:center}.tarifs-bonus-card h3,.tarifs-contact h2{margin:0 0 10px;color:#03234C}.tarifs-bonus-card p,.tarifs-contact p{margin:5px 0;color:#475569;font-weight:700}.tarifs-bonus-richtext{color:#475569;font-weight:700;line-height:1.55}.tarifs-bonus-richtext p{margin:5px 0}.tarifs-bonus-richtext ul,.tarifs-bonus-richtext ol{text-align:left;margin:8px auto;display:inline-block}.tarifs-contact{text-align:center;color:#667085;background:transparent;box-shadow:none;border:0}.tarifs-contact h2{font-size:1.05rem}
@media(max-width:1280px){.tarifs-grid,.tarifs-bonus{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:980px){.tarifs-grid,.tarifs-bonus{grid-template-columns:repeat(2,minmax(0,1fr))}.tarif-row{grid-template-columns:.8fr 1.5fr 1fr 1fr 1fr}}
@media(max-width:720px){.tarifs-page{padding-top:12px}.tarifs-hero{flex-direction:column;align-items:stretch;padding:8px 0}.tarifs-hero-title{align-items:flex-start}.tarifs-hero-icon{width:54px;height:54px;border-radius:18px;font-size:24px}.tarifs-grid,.tarifs-bonus{grid-template-columns:1fr}.tarif-card{border-radius:22px}.tarif-card header{grid-template-columns:58px 1fr;gap:14px;min-height:112px;padding:22px 16px}.tarif-card-icon{width:54px;height:54px;font-size:25px}.tarif-list{padding-left:16px;padding-right:16px}.tarif-row{gap:8px;padding:10px 0}.tarif-cell{font-size:.92rem}.tarif-cell-2{overflow-wrap:normal;word-break:normal}.tarif-cell-3,.tarif-cell-4,.tarif-cell-5{white-space:nowrap}.tarif-cell-5{text-align:right;justify-content:flex-end}.tarifs-pdf{width:100%;border-radius:16px}.tarif-notes{margin-left:16px;margin-right:16px}}

/* Colonnes modulaires dans les articles */
.cms-pricing-columns{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:18px;
  margin:22px 0;
}
.cms-pricing-column{
  background:rgba(255,255,255,.78);
  border:1px solid rgba(10,48,91,.10);
  border-radius:28px;
  padding:24px;
  box-shadow:0 18px 42px rgba(10,48,91,.08);
  overflow:hidden;
}
.cms-pricing-column h3{
  margin:0 0 14px;
  color:#002f68;
  font-size:1.35rem;
  line-height:1.15;
  letter-spacing:.02em;
  text-transform:uppercase;
}
.cms-pricing-column-content{color:#183a5a;line-height:1.65;}
.cms-pricing-column-content p{margin:0 0 10px;}
.cms-pricing-column-content ul,.cms-pricing-column-content ol{padding-left:20px;margin:10px 0;}
.cms-pricing-column-content strong{color:#002f68;}
@media(max-width:700px){.cms-pricing-columns{grid-template-columns:1fr}.cms-pricing-column{border-radius:22px;padding:18px}}

/* ====== Footer premium modernisé ====== */
.site-footer{
  margin-top: 34px;
  padding-bottom: 22px;
}

.site-footer-shell{
  position: relative;
  isolation: isolate;
  overflow: hidden;
  border-radius: 38px;
  padding: clamp(26px, 3vw, 46px);
  background:
    radial-gradient(circle at 8% 0%, rgba(37, 99, 235, .18), transparent 28%),
    radial-gradient(circle at 94% 10%, rgba(56, 189, 248, .20), transparent 30%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(248,251,255,.90) 48%, rgba(238,246,255,.88));
  border: 1px solid rgba(255,255,255,.88);
  box-shadow: 0 34px 90px rgba(3, 35, 76, .14), inset 0 1px 0 rgba(255,255,255,.95);
}

.site-footer-shell::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(3,35,76,.05) 1px, transparent 1px),
    linear-gradient(180deg, rgba(3,35,76,.045) 1px, transparent 1px);
  background-size: 54px 54px;
  mask-image: linear-gradient(120deg, transparent 0%, black 18%, black 70%, transparent 100%);
  opacity:.42;
}

.site-footer-shell::after{
  content:"";
  position:absolute;
  right:-90px;
  bottom:-110px;
  width:260px;
  height:260px;
  border-radius:999px;
  background: radial-gradient(circle, rgba(187, 222, 251, .65), rgba(187, 222, 251, 0) 68%);
  z-index:-1;
  pointer-events:none;
}

.site-footer-brand{
  max-width: 860px;
  margin-bottom: 30px;
}

.site-footer-eyebrow{
  gap: 8px;
  padding: 9px 14px;
  background: linear-gradient(135deg, rgba(37,99,235,.12), rgba(14,165,233,.10));
  color: #1d4ed8;
  box-shadow: inset 0 0 0 1px rgba(37,99,235,.08), 0 10px 26px rgba(37,99,235,.10);
}

.site-footer-eyebrow::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  background: #2563eb;
  box-shadow: 0 0 0 5px rgba(37,99,235,.13);
}

.site-footer-brand h2{
  color:#061b3a;
  font-size: clamp(2rem, 4vw, 3.25rem);
  letter-spacing:-.055em;
}

.site-footer-brand .site-footer-richtext{
  max-width: 720px;
  margin-top: 12px;
  color:#64748b;
  font-size:1.05rem;
}

.site-footer-grid{
  grid-template-columns: minmax(260px, 1.2fr) repeat(3, minmax(220px, 1fr));
  gap: 18px;
  align-items: stretch;
}

.site-footer-card{
  position: relative;
  overflow: hidden;
  padding: 24px;
  border-radius: 28px;
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(18px);
  border: 1px solid rgba(255,255,255,.82);
  box-shadow: 0 18px 44px rgba(15, 23, 42, .075), inset 0 1px 0 rgba(255,255,255,.92);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.site-footer-card:hover{
  transform: translateY(-3px);
  border-color: rgba(37,99,235,.16);
  box-shadow: 0 26px 60px rgba(3,35,76,.12), inset 0 1px 0 rgba(255,255,255,.95);
}

.site-footer-card::before{
  content:"";
  display:flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  margin-bottom:16px;
  border-radius:16px;
  background: linear-gradient(135deg, #03234C, #1d4ed8);
  color:#fff;
  box-shadow: 0 16px 30px rgba(37,99,235,.22);
  font-size:20px;
  line-height:1;
}

.site-footer-card-legal::before{ content:"ℹ"; }
.site-footer-card:nth-child(2)::before{ content:"⌖"; }
.site-footer-card:nth-child(3)::before{ content:"✉"; }
.site-footer-card:nth-child(4)::before{ content:"◷"; }

.site-footer-card h3{
  margin-bottom: 14px;
  color:#061b3a;
  font-size:1.05rem;
  letter-spacing:-.035em;
}

.site-footer-card .site-footer-richtext{
  color:#64748b;
  font-weight: 500;
  line-height:1.8;
}

.site-footer-card .site-footer-richtext strong,
.site-footer-card .site-footer-richtext b{
  color:#23395f;
  font-weight:800;
}

.site-footer-card a{
  display:inline-flex;
  align-items:center;
  width:fit-content;
  color:#23395f;
  text-decoration:none;
  font-weight:700;
}

.site-footer-card a:hover{
  color:#1d4ed8;
}

.site-footer-tags{
  gap: 9px;
  padding-left: 0 !important;
}

.site-footer-tags p{
  display: contents;
}

.site-footer-tags a,
.site-footer-tags span{
  display:inline-flex;
  align-items:center;
  min-height:38px;
  padding:9px 13px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(37,99,235,.08), rgba(14,165,233,.06));
  border:1px solid rgba(37,99,235,.10);
  color:#1e3a8a;
  font-weight:800;
  text-decoration:none;
}

.site-footer-bottom{
  margin-top: 22px;
  padding: 18px 20px;
  border-top: 0;
  border-radius: 22px;
  background: rgba(255,255,255,.58);
  border: 1px solid rgba(255,255,255,.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.9);
  color:#64748b;
  text-align:center;
}

.cms-footer-preview-modern{
  padding: 22px;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(37,99,235,.15), transparent 35%),
    linear-gradient(135deg, rgba(255,255,255,.95), rgba(239,246,255,.80));
  border: 1px solid rgba(255,255,255,.78);
  box-shadow: 0 20px 50px rgba(15,23,42,.08);
}

.cms-footer-preview-columns{
  gap: 14px;
}

.cms-footer-preview-block{
  padding: 16px;
  border-radius: 20px;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(15,23,42,.06);
}

@media (max-width: 1180px){
  .site-footer-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 680px){
  .site-footer{ margin-top: 20px; }
  .site-footer-shell{ border-radius: 28px; padding: 22px; }
  .site-footer-grid{ grid-template-columns: 1fr; gap: 14px; }
  .site-footer-card{ padding: 20px; border-radius: 24px; }
  .site-footer-brand{ margin-bottom: 20px; }
  .site-footer-brand h2{ font-size: 2rem; }
  .site-footer-bottom{ text-align:left; }
}

/* ====== Thème public blanc + header/footer épurés ====== */
body{
  background:#fff !important;
}
body::before{
  display:none !important;
}

.site-header{
  background:#fff !important;
  border:0 !important;
  border-bottom:1px solid rgba(3,35,76,.10) !important;
  box-shadow:0 8px 24px rgba(3,35,76,.055) !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
}
.site-header[data-sticky="1"]{
  box-shadow:0 8px 24px rgba(3,35,76,.06) !important;
}

.tarifs-page{
  background:#fff !important;
}
.tarifs-page::before{
  display:none !important;
}
.tarifs-hero{
  background:#fff !important;
  border-bottom:0 !important;
}

.site-footer{
  margin-top:56px !important;
  padding:0 0 28px !important;
  background:#fff !important;
  border-top:1px solid rgba(3,35,76,.08);
}
.site-footer-shell{
  max-width:calc(100% - 64px);
  margin:0 auto;
  border-radius:0 !important;
  padding:38px 0 0 !important;
  background:#fff !important;
  border:0 !important;
  box-shadow:none !important;
}
.site-footer-shell::before,
.site-footer-shell::after{
  display:none !important;
}
.site-footer-brand{
  max-width:760px;
  margin-bottom:24px !important;
}
.site-footer-eyebrow{
  width:fit-content;
  background:#eef4ff !important;
  color:#2563eb !important;
  border:0 !important;
  box-shadow:none !important;
  letter-spacing:.04em;
}
.site-footer-brand h2{
  color:#061b3a !important;
  font-size:clamp(1.8rem,3vw,2.55rem) !important;
  letter-spacing:-.045em !important;
}
.site-footer-brand .site-footer-richtext{
  color:#64748b !important;
}
.site-footer-grid{
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
  gap:16px !important;
  align-items:stretch !important;
}
.site-footer-card{
  padding:22px 24px !important;
  border-radius:24px !important;
  background:#fff !important;
  border:1px solid rgba(3,35,76,.08) !important;
  box-shadow:0 18px 42px rgba(3,35,76,.055) !important;
  backdrop-filter:none !important;
}
.site-footer-card:hover{
  transform:translateY(-2px) !important;
  box-shadow:0 24px 54px rgba(3,35,76,.08) !important;
}
.site-footer-card::before{
  display:none !important;
}
.site-footer-card h3{
  color:#061b3a !important;
  margin:0 0 14px !important;
}
.site-footer-card .site-footer-richtext{
  color:#64748b !important;
  line-height:1.75 !important;
}
.site-footer-tags a,
.site-footer-tags span{
  background:#f6f9ff !important;
  border:1px solid rgba(3,35,76,.08) !important;
  color:#23395f !important;
}
.site-footer-bottom{
  margin-top:18px !important;
  padding:18px 0 0 !important;
  border-radius:0 !important;
  background:transparent !important;
  border:0 !important;
  border-top:1px solid rgba(3,35,76,.08) !important;
  box-shadow:none !important;
  color:#64748b !important;
}

@media(max-width:1180px){
  .site-footer-grid{grid-template-columns:repeat(2,minmax(0,1fr)) !important;}
}
@media(max-width:720px){
  .site-footer-shell{max-width:calc(100% - 32px);padding-top:28px !important;}
  .site-footer-grid{grid-template-columns:1fr !important;}
  .site-footer-card{border-radius:20px !important;}
}

/* =========================
   Accueil MMORPG / Eilati
========================= */
.mmo-hero{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,1.05fr);gap:28px;align-items:stretch;min-height:460px;padding:56px 42px;border-radius:34px;background:linear-gradient(90deg,#fff 0%,rgba(255,255,255,.96) 38%,rgba(239,248,255,.65) 100%);box-shadow:0 24px 70px rgba(15,23,42,.08);overflow:hidden;position:relative;margin-bottom:28px;border:1px solid rgba(15,23,42,.06)}
.mmo-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(75,164,255,.20),transparent 34%),radial-gradient(circle at 40% 100%,rgba(118,199,255,.16),transparent 36%);pointer-events:none}.mmo-hero-copy{position:relative;z-index:1;align-self:center}.mmo-hero h1{font-family:Georgia,'Times New Roman',serif;font-size:clamp(38px,5vw,66px);line-height:1.05;margin:0 0 22px;color:#0f1a38;letter-spacing:-.045em}.mmo-hero p{font-size:18px;line-height:1.75;color:#475569;margin:0 0 28px;max-width:560px}.mmo-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:34px}.mmo-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 22px;border-radius:999px;background:rgba(255,255,255,.86);border:1px solid rgba(15,23,42,.08);color:#101a33;text-decoration:none;font-weight:850;box-shadow:0 14px 34px rgba(15,23,42,.10);transition:transform .18s ease,box-shadow .18s ease}.mmo-btn:hover{transform:translateY(-2px);box-shadow:0 18px 44px rgba(15,23,42,.14)}.mmo-btn.primary{background:linear-gradient(135deg,#3157a7,#18366f);color:#fff;border-color:rgba(255,255,255,.2)}.mmo-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;border-top:1px solid rgba(15,23,42,.08);padding-top:24px}.mmo-stats div{display:flex;flex-direction:column;gap:4px}.mmo-stats strong{font-size:18px;color:#0f1a38}.mmo-stats span{font-size:13px;color:#64748b}.mmo-hero-art{position:relative;z-index:1;border-radius:30px;min-height:360px;background-image:linear-gradient(180deg,rgba(179,226,255,.55),rgba(255,255,255,.15)),url('../../uploads/articles/img_20260509_113549_c209e242.png');background-size:cover;background-position:center;box-shadow:inset 0 0 90px rgba(255,255,255,.32)}.mmo-section{margin:26px 0}.mmo-section-head{display:flex;align-items:center;justify-content:space-between;margin:0 10px 16px}.mmo-section-head h2{font-family:Georgia,'Times New Roman',serif;font-size:30px;margin:0;color:#0f1a38}.mmo-section-head a{font-weight:800;text-decoration:none;color:#2654a8}.mmo-news-grid,.mmo-class-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.mmo-news-card,.mmo-class-card{background:#fff;border:1px solid rgba(15,23,42,.07);border-radius:20px;box-shadow:0 18px 45px rgba(15,23,42,.07);overflow:hidden;text-decoration:none;color:#101a33;transition:transform .18s ease,box-shadow .18s ease}.mmo-news-card:hover,.mmo-class-card:hover{transform:translateY(-3px);box-shadow:0 22px 55px rgba(15,23,42,.11)}.mmo-news-card img{width:100%;height:130px;object-fit:cover;display:block}.mmo-news-card div{padding:14px 16px 18px}.mmo-news-card small{display:block;color:#8190a5;font-weight:750;margin-bottom:8px}.mmo-news-card h3,.mmo-class-card h3{margin:0 0 8px;font-size:17px;color:#0f1a38}.mmo-news-card p,.mmo-class-card p,.mmo-visual-block p,.mmo-road-item p{margin:0;color:#526174;line-height:1.55}.mmo-class-card{display:flex;gap:16px;align-items:center;padding:22px;min-height:150px}.mmo-class-card img{width:70px;height:70px;object-fit:contain}.mmo-class-icon{flex:0 0 54px;width:54px;height:54px;border-radius:18px;display:flex;align-items:center;justify-content:center;font-size:27px;background:#f1f5f9}.mmo-class-card.red .mmo-class-icon{background:#fff1f2;color:#dc2626}.mmo-class-card.blue .mmo-class-icon{background:#eff6ff;color:#2563eb}.mmo-class-card.green .mmo-class-icon{background:#f0fdf4;color:#16a34a}.mmo-class-card.purple .mmo-class-icon{background:#f5f3ff;color:#7c3aed}.mmo-block-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin:26px 0}.mmo-visual-block{min-height:245px;padding:34px;border-radius:24px;border:1px solid rgba(15,23,42,.06);box-shadow:0 18px 50px rgba(15,23,42,.08);background:linear-gradient(100deg,rgba(255,255,255,.96) 0%,rgba(255,255,255,.72) 52%,rgba(255,255,255,.2) 100%),linear-gradient(135deg,#eaf6ff,#f8fbff);background-size:cover;background-position:center;display:flex;flex-direction:column;align-items:flex-start;justify-content:center;overflow:hidden}.mmo-visual-block h2{font-family:Georgia,'Times New Roman',serif;font-size:30px;margin:0 0 12px;color:#0f1a38}.mmo-visual-block p{max-width:460px;margin-bottom:20px}.mmo-roadmap{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:0;position:relative;padding-top:22px}.mmo-roadmap:before{content:"";position:absolute;left:4%;right:4%;top:36px;height:2px;background:linear-gradient(90deg,#50b36f,#4b6fb6,#d6dce8)}.mmo-road-item{position:relative;padding:46px 18px 10px;border-right:1px solid rgba(15,23,42,.07)}.mmo-road-item:last-child{border-right:0}.mmo-road-item span{position:absolute;top:3px;left:18px;width:28px;height:28px;border-radius:50%;background:#e2e8f0;border:5px solid #fff;box-shadow:0 0 0 1px rgba(15,23,42,.08);z-index:1}.mmo-road-item.done span{background:#52b46b}.mmo-road-item.current span{background:#4169b6}.mmo-road-item.locked span:after{content:"🔒";position:absolute;font-size:12px;inset:0;display:flex;align-items:center;justify-content:center}.mmo-road-item h3{margin:0 0 8px;font-size:16px;color:#0f1a38}.mmo-road-item small{display:block;margin-bottom:12px;color:#94a3b8;font-weight:800}.mmo-road-item p{font-size:13px;font-weight:650;color:#334155}
@media(max-width:1050px){.mmo-news-grid,.mmo-class-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.mmo-roadmap{grid-template-columns:1fr}.mmo-roadmap:before{display:none}.mmo-road-item{border-right:0;border-left:2px solid #e2e8f0;padding-top:14px;padding-left:52px}.mmo-road-item span{left:10px;top:14px}.mmo-hero{grid-template-columns:1fr}.mmo-hero-art{min-height:280px}}
@media(max-width:680px){.mmo-hero{padding:32px 20px;border-radius:24px}.mmo-stats{grid-template-columns:1fr}.mmo-actions{flex-direction:column}.mmo-btn{width:100%}.mmo-news-grid,.mmo-class-grid,.mmo-block-grid{grid-template-columns:1fr}.mmo-section-head{align-items:flex-start;gap:8px;flex-direction:column}.mmo-class-card{min-height:auto}.mmo-visual-block{padding:26px}}
