/*
=======================================================================
 NOVTINIS / SEVACAM — PAGE ABONNEMENT PREMIUM
 Fichier : css/subscription.css
 Page : /abonnement/
 Compatible : page-abonnement.php
=======================================================================
*/

/* ======================================================
   00. TOKENS NOVTINIS
====================================================== */

:root {
  --nt-bg: #071120;
  --nt-bg-2: #0b1728;
  --nt-dark: #0b132b;
  --nt-dark-2: #111827;
  --nt-card: #ffffff;
  --nt-soft: #f4f6f8;
  --nt-soft-2: #eef5ff;
  --nt-line: #e6ebf1;
  --nt-muted: #667085;
  --nt-muted-2: #94a3b8;
  --nt-blue: #2878ff;
  --nt-blue-2: #1d4ed8;
  --nt-cyan: #0f8cab;
  --nt-orange: #ff7a00;
  --nt-pink: #ff2d55;
  --nt-green: #16a34a;
  --nt-green-soft: #dcfce7;
  --nt-warning: #9a3412;
  --nt-warning-soft: #fff7ed;
  --nt-radius-xl: 34px;
  --nt-radius-lg: 28px;
  --nt-radius-md: 22px;
  --nt-shadow-soft: 0 18px 45px rgba(15, 23, 42, 0.16);
  --nt-shadow-card: 0 16px 38px rgba(7, 17, 32, 0.18);
  --nt-shadow-blue: 0 20px 48px rgba(40, 120, 255, 0.24);
  --nt-shadow-orange: 0 18px 46px rgba(255, 122, 0, 0.22);
}

/* ======================================================
   01. RESET LOCAL ASTRA / PAGE
====================================================== */

html,
body {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

body.page-template-page-abonnement,
body.page-template-page-abonnement-php,
body.page-id-abonnement {
  background: var(--nt-bg) !important;
  color: var(--nt-dark);
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}

body.page-template-page-abonnement header:not(.seva-subscription-hero),
body.page-template-page-abonnement footer,
body.page-template-page-abonnement .site-header,
body.page-template-page-abonnement .site-footer,
body.page-template-page-abonnement .entry-header,
body.page-template-page-abonnement .ast-primary-header-bar,
body.page-template-page-abonnement .ast-builder-grid-row-container,
body.page-template-page-abonnement .ast-mobile-header-wrap,
body.page-template-page-abonnement .main-header-bar-wrap,
body.page-template-page-abonnement-php header:not(.seva-subscription-hero),
body.page-template-page-abonnement-php footer,
body.page-template-page-abonnement-php .site-header,
body.page-template-page-abonnement-php .site-footer,
body.page-template-page-abonnement-php .entry-header,
body.page-template-page-abonnement-php .ast-primary-header-bar,
body.page-template-page-abonnement-php .ast-builder-grid-row-container,
body.page-template-page-abonnement-php .ast-mobile-header-wrap,
body.page-template-page-abonnement-php .main-header-bar-wrap {
  display: none !important;
}

body.page-template-page-abonnement .site,
body.page-template-page-abonnement .site-content,
body.page-template-page-abonnement #content,
body.page-template-page-abonnement .content-area,
body.page-template-page-abonnement .ast-container,
body.page-template-page-abonnement .site-main,
body.page-template-page-abonnement article,
body.page-template-page-abonnement .entry-content,
body.page-template-page-abonnement-php .site,
body.page-template-page-abonnement-php .site-content,
body.page-template-page-abonnement-php #content,
body.page-template-page-abonnement-php .content-area,
body.page-template-page-abonnement-php .ast-container,
body.page-template-page-abonnement-php .site-main,
body.page-template-page-abonnement-php article,
body.page-template-page-abonnement-php .entry-content {
  width: 100% !important;
  max-width: 100% !important;
  min-height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  background: transparent !important;
}

body.page-template-page-abonnement #wpadminbar ~ .site .seva-subscription-page,
body.page-template-page-abonnement-php #wpadminbar ~ .site .seva-subscription-page {
  min-height: calc(100vh - 32px);
}

/* ======================================================
   02. PAGE WRAPPER
====================================================== */

.seva-subscription-page {
  min-height: 100vh;
  padding: 24px 16px 110px;
  background:
    radial-gradient(circle at 12% 0%, rgba(40, 120, 255, 0.34), transparent 34%),
    radial-gradient(circle at 88% 8%, rgba(255, 122, 0, 0.18), transparent 31%),
    linear-gradient(180deg, #071120 0%, #08172a 42%, #06101f 100%);
  color: var(--nt-dark);
  font-family: -apple-system, BlinkMacSystemFont, "Inter", "Noto Sans Khmer", "Segoe UI", sans-serif;
  box-sizing: border-box;
}

.seva-subscription-page *,
.seva-subscription-page *::before,
.seva-subscription-page *::after {
  box-sizing: border-box;
}

.seva-subscription-shell {
  width: min(100%, 1080px);
  margin: 0 auto;
}

/* ======================================================
   03. HERO / HEADER PAGE
====================================================== */

.seva-subscription-hero {
  position: relative;
  min-height: 250px;
  margin-bottom: 18px;
  padding: 30px;
  border-radius: 34px;
  overflow: hidden;
  background:
    radial-gradient(circle at 86% 44%, rgba(40, 120, 255, 0.42), transparent 24%),
    radial-gradient(circle at 24% 0%, rgba(15, 140, 171, 0.18), transparent 30%),
    linear-gradient(135deg, rgba(16, 33, 58, 0.98), rgba(7, 17, 32, 0.98));
  border: 1px solid rgba(96, 165, 250, 0.28);
  color: #fff;
  display: flex;
  gap: 18px;
  align-items: flex-start;
  box-shadow: var(--nt-shadow-blue);
}

.seva-subscription-hero::before {
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: 33px;
  pointer-events: none;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.16), transparent 30%, rgba(40,120,255,0.14));
  opacity: 0.65;
}

.seva-subscription-hero::after {
  content: "♛";
  position: absolute;
  right: 46px;
  bottom: 34px;
  width: 96px;
  height: 96px;
  border-radius: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(142, 197, 255, 0.96);
  font-size: 54px;
  line-height: 1;
  background: rgba(40, 120, 255, 0.10);
  border: 1px solid rgba(96, 165, 250, 0.38);
  box-shadow: 0 0 34px rgba(40, 120, 255, 0.38);
  text-shadow: 0 0 18px rgba(96, 165, 250, 0.88);
  transform: rotate(-4deg);
}

.seva-subscription-back {
  position: relative;
  z-index: 2;
  width: 54px;
  height: 54px;
  flex: 0 0 54px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: #fff !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none !important;
  font-size: 28px;
  font-weight: 950;
  backdrop-filter: blur(12px);
  transition: transform 0.18s ease, background 0.18s ease;
}

.seva-subscription-back:hover {
  transform: translateX(-2px);
  background: rgba(255, 255, 255, 0.18);
}

.seva-subscription-hero > div {
  position: relative;
  z-index: 2;
  max-width: 720px;
}

.seva-subscription-kicker,
.seva-card-kicker {
  display: inline-flex;
  width: max-content;
  max-width: 100%;
  min-height: 34px;
  padding: 0 16px;
  margin-bottom: 13px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  color: var(--nt-blue);
  background: var(--nt-soft-2);
  font-size: 13px;
  font-weight: 950;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  line-height: 1;
}

.seva-subscription-hero .seva-subscription-kicker {
  color: #dbeafe;
  background: rgba(40, 120, 255, 0.20);
  border: 1px solid rgba(142, 197, 255, 0.28);
}

.seva-subscription-hero h1,
.seva-subscription-card h2,
.seva-pack-card h2 {
  margin: 0;
  color: inherit;
  font-weight: 950;
  letter-spacing: -0.055em;
}

.seva-subscription-hero h1 {
  font-size: clamp(44px, 7vw, 72px);
  line-height: 0.96;
}

.seva-subscription-hero p {
  margin: 16px 0 0;
  color: rgba(255, 255, 255, 0.82);
  font-size: 19px;
  line-height: 1.44;
  font-weight: 760;
}

/* ======================================================
   04. ALERTES
====================================================== */

.seva-subscription-alert {
  margin-bottom: 16px;
  padding: 15px 17px;
  border-radius: 20px;
  font-size: 14px;
  line-height: 1.42;
  font-weight: 850;
  border: 1px solid transparent;
}

.seva-subscription-alert.is-error {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fecaca;
}

.seva-subscription-alert.is-success {
  background: #ecfdf5;
  color: #15803d;
  border-color: #bbf7d0;
}

.seva-subscription-alert.is-locked {
  margin: 18px 0 0;
  background: var(--nt-warning-soft);
  color: var(--nt-warning);
  border-color: #fed7aa;
}

/* ======================================================
   05. CARTE PACK ACTUEL
====================================================== */

.seva-subscription-card,
.seva-pack-card {
  position: relative;
  margin-bottom: 18px;
  padding: 28px;
  border-radius: var(--nt-radius-xl);
  background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
  border: 1px solid rgba(226, 232, 240, 0.94);
  box-shadow: var(--nt-shadow-card);
  overflow: hidden;
}

.seva-subscription-card.is-current {
  padding: 32px;
}

.seva-current-top,
.seva-boost-head,
.seva-pack-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
}

.seva-current-top > div,
.seva-boost-head > div,
.seva-pack-head > div {
  min-width: 0;
}

.seva-subscription-card h2,
.seva-pack-card h2 {
  font-size: clamp(36px, 5vw, 54px);
  line-height: 0.98;
  color: var(--nt-dark);
}

.seva-subscription-card p {
  margin: 14px 0 0;
  color: var(--nt-muted);
  font-size: 18px;
  line-height: 1.44;
  font-weight: 780;
}

.seva-status-pill {
  min-height: 52px;
  padding: 0 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex: 0 0 auto;
  font-size: 16px;
  font-weight: 950;
  background: var(--nt-soft-2);
  color: var(--nt-blue-2);
  white-space: nowrap;
}

.seva-status-pill.is-pro {
  background: var(--nt-green-soft);
  color: #15803d;
}

.seva-status-pill.is-pro::before {
  content: "✓";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: rgba(22, 163, 74, 0.16);
}

.seva-status-pill.is-free {
  background: var(--nt-soft-2);
  color: var(--nt-blue-2);
}

.seva-current-note {
  margin-top: 22px;
  padding: 18px 20px;
  border-radius: 22px;
  background: #f6f9fd;
  border: 1px solid rgba(226, 232, 240, 0.72);
  color: #233044;
  font-size: 16px;
  line-height: 1.35;
  font-weight: 900;
}

.seva-current-note::before {
  content: "📅";
  margin-right: 9px;
}

.seva-current-note.is-pending {
  background: var(--nt-warning-soft);
  color: var(--nt-warning);
  border-color: #fed7aa;
}

.seva-current-note.is-pending::before {
  content: "⏳";
}

/* ======================================================
   06. GRILLE PACKS
====================================================== */

.seva-pack-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-bottom: 18px;
}

.seva-pack-card {
  margin-bottom: 0;
  min-height: 100%;
}

.seva-pack-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 100% 0%, rgba(40, 120, 255, 0.06), transparent 34%);
}

.seva-pack-card.is-featured {
  border: 2px solid rgba(255, 122, 0, 0.70);
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 122, 0, 0.12), transparent 35%),
    linear-gradient(180deg, #ffffff 0%, #fffdfb 100%);
  box-shadow: var(--nt-shadow-orange);
}

.seva-pack-card.is-featured::before {
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 122, 0, 0.16), transparent 35%),
    linear-gradient(135deg, rgba(255,255,255,0), rgba(255,122,0,0.03));
}

.seva-pack-head {
  position: relative;
  z-index: 1;
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: start;
}

.seva-pack-card .seva-card-kicker {
  margin-bottom: 2px;
}

.seva-pack-card.is-featured .seva-card-kicker {
  color: #c2410c;
  background: #fff1e8;
}

.seva-pack-card.is-featured .seva-card-kicker::before {
  content: "★";
  margin-right: 8px;
  letter-spacing: 0;
}

.seva-price {
  display: inline-flex;
  width: fit-content;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 999px;
  align-items: center;
  background: #f1f5f9;
  color: var(--nt-blue);
  font-size: 22px;
  line-height: 1;
  font-weight: 950;
  white-space: nowrap;
}

.seva-pack-card.is-featured .seva-price {
  background: #fff1e8;
  color: #c2410c;
}

.seva-pack-card ul {
  position: relative;
  z-index: 1;
  margin: 24px 0 24px;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 13px;
}

.seva-pack-card li {
  position: relative;
  padding-left: 32px;
  margin: 0;
  color: var(--nt-muted);
  font-size: 16px;
  line-height: 1.35;
  font-weight: 820;
}

.seva-pack-card li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: -1px;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(40, 120, 255, 0.10);
  color: var(--nt-blue);
  font-size: 13px;
  font-weight: 950;
}

.seva-pack-card.is-featured li::before {
  background: rgba(255, 122, 0, 0.12);
  color: var(--nt-orange);
}

/* ======================================================
   07. FORMULAIRES / BOUTONS
====================================================== */

.seva-subscription-request-form {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 14px;
}

.seva-subscription-request-form textarea {
  width: 100%;
  min-height: 96px;
  padding: 15px 16px;
  border-radius: 20px;
  border: 1px solid #dbe7f5;
  background: #f8fbff;
  color: var(--nt-dark);
  font-size: 15px;
  font-weight: 760;
  outline: none;
  resize: vertical;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.8);
}

.seva-subscription-request-form textarea:focus {
  border-color: rgba(40, 120, 255, 0.45);
  box-shadow: 0 0 0 4px rgba(40, 120, 255, 0.10);
}

.seva-subscription-btn {
  position: relative;
  z-index: 1;
  min-height: 58px;
  padding: 0 20px;
  border: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-decoration: none !important;
  font-size: 16px;
  font-weight: 950;
  cursor: pointer;
  width: 100%;
  transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease;
}

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

.seva-subscription-btn.is-primary {
  background:
    radial-gradient(circle at 28% 22%, rgba(255,255,255,0.30), transparent 28%),
    linear-gradient(135deg, var(--nt-orange), var(--nt-pink));
  color: #fff !important;
  box-shadow: 0 16px 34px rgba(255, 45, 85, 0.24);
}

.seva-subscription-btn.is-secondary {
  background: var(--nt-soft-2);
  color: var(--nt-blue-2) !important;
  box-shadow: 0 10px 22px rgba(40, 120, 255, 0.10);
}

.seva-subscription-btn.is-muted,
.seva-subscription-btn.is-success {
  background: #ecfdf5;
  color: #15803d !important;
  cursor: default;
  box-shadow: none;
}

.seva-subscription-btn.is-success::before {
  content: "♛";
  font-size: 18px;
}

.seva-subscription-btn:disabled {
  opacity: 0.72;
  cursor: not-allowed;
  transform: none !important;
}

/* ======================================================
   08. BOOST VISIBILITÉ
====================================================== */

.seva-subscription-card.is-boost {
  background:
    radial-gradient(circle at 100% 0%, rgba(40, 120, 255, 0.06), transparent 32%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%);
}

.seva-boost-options {
  margin-top: 24px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.seva-boost-option {
  padding: 20px;
  border-radius: 24px;
  border: 1px solid #dfe8f4;
  background:
    radial-gradient(circle at 100% 0%, rgba(40, 120, 255, 0.08), transparent 34%),
    #f8fbff;
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
}

.seva-boost-option::before {
  content: "🚀";
  width: 52px;
  height: 52px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(40, 120, 255, 0.12);
  color: var(--nt-blue);
  font-size: 24px;
}

.seva-boost-option:nth-child(2)::before {
  background: rgba(255, 122, 0, 0.13);
}

.seva-boost-option strong {
  color: var(--nt-dark);
  font-size: 20px;
  line-height: 1.15;
  font-weight: 950;
}

.seva-boost-option span {
  color: var(--nt-muted);
  font-size: 22px;
  line-height: 1;
  font-weight: 950;
}

.seva-boost-option:nth-child(2) span {
  color: var(--nt-orange);
}

.seva-boost-option:nth-child(2) .seva-subscription-btn.is-secondary {
  background: #fff1e8;
  color: #c2410c !important;
}

/* ======================================================
   09. VALIDATION MANUELLE
====================================================== */

.seva-subscription-card.is-payment {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 18px;
  align-items: center;
  background: linear-gradient(180deg, #f8fbff 0%, #ffffff 100%);
  border-color: rgba(191, 219, 254, 0.88);
}

.seva-subscription-card.is-payment::before {
  content: "✓";
  width: 74px;
  height: 74px;
  border-radius: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  grid-row: span 3;
  background: #eaf3ff;
  color: var(--nt-blue);
  font-size: 30px;
  font-weight: 950;
}

.seva-subscription-card.is-payment .seva-card-kicker,
.seva-subscription-card.is-payment h2,
.seva-subscription-card.is-payment p {
  grid-column: 2;
}

/* ======================================================
   10. ÉTATS SPÉCIAUX
====================================================== */

.seva-subscription-card .seva-subscription-btn + .seva-subscription-btn {
  margin-top: 10px;
}

.seva-pack-grid .seva-pack-card.is-featured:only-child {
  width: 100%;
  max-width: none;
}

/* ======================================================
   11. RESPONSIVE TABLETTE / DESKTOP
====================================================== */

@media (min-width: 760px) {
  .seva-pack-grid {
    grid-template-columns: 1fr;
  }

  .seva-boost-options {
    grid-template-columns: 1fr 1fr;
  }

  .seva-boost-option {
    min-height: 220px;
  }
}

@media (min-width: 980px) {
  .seva-subscription-page {
    padding-top: 30px;
  }

  .seva-pack-grid:has(.seva-pack-card:nth-child(2)) {
    grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  }

  .seva-pack-grid:has(.seva-pack-card:only-child) {
    grid-template-columns: 1fr;
  }

  .seva-pack-card.is-featured ul {
    grid-template-columns: 1fr 1fr;
    column-gap: 26px;
  }

  .seva-pack-grid .seva-pack-card.is-featured:only-child ul {
    grid-template-columns: 1fr 1fr;
  }
}

/* ======================================================
   12. RESPONSIVE MOBILE
====================================================== */

@media (max-width: 782px) {
  body.admin-bar .seva-subscription-page {
    padding-top: 0;
  }
}

@media (max-width: 680px) {
  .seva-subscription-page {
    padding: 0 0 90px;
  }

  .seva-subscription-shell {
    width: 100%;
  }

  .seva-subscription-hero {
    margin: 0 0 16px;
    min-height: auto;
    padding: 20px 18px 26px;
    border-radius: 0 0 30px 30px;
    gap: 12px;
  }

  .seva-subscription-hero::after {
    display: none;
  }

  .seva-subscription-back {
    width: 48px;
    height: 48px;
    flex-basis: 48px;
    font-size: 25px;
  }

  .seva-subscription-hero h1 {
    font-size: 40px;
  }

  .seva-subscription-hero p {
    font-size: 15px;
  }

  .seva-subscription-card,
  .seva-pack-card {
    margin-left: 14px;
    margin-right: 14px;
    padding: 22px;
    border-radius: 28px;
  }

  .seva-subscription-card.is-current {
    padding: 24px;
  }

  .seva-current-top,
  .seva-boost-head {
    flex-direction: column;
  }

  .seva-status-pill {
    min-height: 44px;
    padding: 0 16px;
    font-size: 14px;
  }

  .seva-subscription-card h2,
  .seva-pack-card h2 {
    font-size: 36px;
  }

  .seva-subscription-card p {
    font-size: 15px;
  }

  .seva-current-note {
    font-size: 14px;
    padding: 15px;
  }

  .seva-price {
    min-height: 44px;
    font-size: 18px;
  }

  .seva-pack-card li {
    font-size: 15px;
  }

  .seva-subscription-card.is-payment {
    grid-template-columns: 1fr;
  }

  .seva-subscription-card.is-payment::before {
    width: 60px;
    height: 60px;
    border-radius: 20px;
  }

  .seva-subscription-card.is-payment .seva-card-kicker,
  .seva-subscription-card.is-payment h2,
  .seva-subscription-card.is-payment p {
    grid-column: auto;
  }
}

@media (max-width: 380px) {
  .seva-subscription-card h2,
  .seva-pack-card h2 {
    font-size: 32px;
  }

  .seva-subscription-card,
  .seva-pack-card {
    margin-left: 10px;
    margin-right: 10px;
    padding: 20px;
  }
}

/* ======================================================
   13. SUPPORT ANCIENS NAVIGATEURS SANS :has()
====================================================== */

@supports not selector(:has(*)) {
  @media (min-width: 980px) {
    .seva-pack-grid {
      grid-template-columns: 1fr;
    }
  }
}
/* Masque le bouton retour haut/plugin sur la page abonnement */
body.page-template-page-abonnement .scroll-to-top,
body.page-template-page-abonnement #ast-scroll-top,
body.page-template-page-abonnement .ast-scroll-top-icon,
body.page-template-page-abonnement .astra-scroll-to-top {
  display: none !important;
}

/* Corrige la pastille recommandé si tu gardes la carte Pro */
.seva-pack-card.is-featured {
  overflow: visible;
}

.seva-pack-card.is-featured .seva-card-kicker {
  margin-left: 0;
  transform: none;
}

/* Rend la carte Pro plus lisible si elle reste affichée */
.seva-pack-card.is-featured {
  background:
    radial-gradient(circle at top right, rgba(255, 122, 0, 0.12), transparent 34%),
    #ffffff !important;
  color: #071120 !important;
}

.seva-pack-card.is-featured h2,
.seva-pack-card.is-featured li {
  color: #071120 !important;
}

.seva-pack-card.is-featured li {
  opacity: 1 !important;
}


/* ======================================================
   NOVTINIS — OPTIONS VISIBILITÉ + SÉLECTION
====================================================== */

.seva-subscription-card.is-selection,
.seva-subscription-card.is-visibility,
.seva-subscription-card.is-boost {
  background:
    radial-gradient(circle at 100% 0%, rgba(40, 120, 255, 0.08), transparent 30%),
    linear-gradient(180deg, #ffffff 0%, #fbfdff 100%) !important;
}

.seva-visibility-head,
.seva-boost-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
}

.seva-visibility-info,
.seva-selection-conditions {
  margin-top: 16px;
  padding: 14px;
  border-radius: 20px;
  background: #f8fbff;
  border: 1px solid #e4eef9;
  display: grid;
  gap: 4px;
  color: #334155;
  font-size: 13px;
  line-height: 1.42;
  font-weight: 780;
}

.seva-visibility-info strong,
.seva-selection-conditions strong {
  color: #071120;
  font-weight: 950;
}

.seva-option-group {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid #e9eef6;
}

.seva-option-group-head {
  display: grid;
  gap: 5px;
  margin-bottom: 12px;
}

.seva-option-group-head strong {
  color: #071120;
  font-size: 18px;
  font-weight: 950;
}

.seva-option-group-head span {
  color: #64748b;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 750;
}

.seva-boost-options {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.seva-boost-option {
  min-width: 0 !important;
  padding: 16px !important;
  border-radius: 22px !important;
  border: 1px solid #dfe8f4;
  background:
    radial-gradient(circle at 100% 0%, rgba(40, 120, 255, 0.08), transparent 34%),
    linear-gradient(180deg, #f8fbff 0%, #f4f8ff 100%);
  display: grid;
  gap: 10px;
}

.seva-subscription-card.is-selection .seva-boost-option,
.seva-option-group.is-selection .seva-boost-option {
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 122, 0, 0.10), transparent 34%),
    linear-gradient(180deg, #fffaf6 0%, #f8fbff 100%);
}

.seva-boost-option strong {
  color: #071120;
  font-size: 18px !important;
  line-height: 1.15 !important;
  font-weight: 950;
}

.seva-boost-option span {
  color: #071120;
  font-size: 22px !important;
  font-weight: 950;
}

.seva-boost-option .seva-subscription-btn {
  min-height: 48px !important;
  padding: 0 12px !important;
  font-size: 14px !important;
}

@media (max-width: 680px) {
  .seva-visibility-head,
  .seva-boost-head {
    flex-direction: column;
  }

  .seva-boost-options {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .seva-boost-option {
    padding: 14px !important;
  }

  .seva-boost-option strong {
    font-size: 16px !important;
  }

  .seva-boost-option span {
    font-size: 19px !important;
  }

  .seva-boost-option .seva-subscription-btn {
    min-height: 44px !important;
    font-size: 13px !important;
  }
}

@media (max-width: 360px) {
  .seva-boost-options {
    grid-template-columns: 1fr !important;
  }
}

/* ======================================================
   NOVTINIS — ABONNEMENT FINAL OPTIMISÉ
   Mobile-first + nav basse + UX Pro actif
====================================================== */

/* Page app */
.seva-subscription-page {
  width: 100%;
  min-height: 100vh;
  padding: 0 0 132px !important;
  overflow-x: hidden !important;
  background:
    radial-gradient(circle at 50% -8%, rgba(40, 120, 255, 0.34), transparent 34%),
    radial-gradient(circle at 100% 8%, rgba(255, 122, 0, 0.12), transparent 30%),
    linear-gradient(180deg, #071120 0%, #08172a 46%, #06101f 100%) !important;
}

.seva-subscription-shell {
  width: 100% !important;
  max-width: 520px !important;
  margin: 0 auto !important;
  overflow: hidden !important;
}

/* Hero premium compact */
.seva-subscription-hero {
  min-height: 214px !important;
  margin: 0 0 18px !important;
  padding: 24px 18px 26px !important;
  border-radius: 0 0 34px 34px !important;
  display: grid !important;
  grid-template-columns: 58px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  background:
    radial-gradient(circle at 88% 28%, rgba(40, 120, 255, 0.52), transparent 30%),
    radial-gradient(circle at 8% 100%, rgba(40, 120, 255, 0.22), transparent 36%),
    linear-gradient(135deg, #103a74 0%, #0b1e3e 56%, #071120 100%) !important;
  box-shadow:
    0 22px 54px rgba(0, 0, 0, 0.32),
    inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

.seva-subscription-hero::after {
  display: none !important;
}

.seva-subscription-back {
  width: 58px !important;
  height: 58px !important;
  flex: 0 0 58px !important;
}

.seva-subscription-hero h1 {
  margin-top: 8px !important;
  font-size: clamp(42px, 11vw, 56px) !important;
  line-height: 0.94 !important;
}

.seva-subscription-hero p {
  margin-top: 14px !important;
  font-size: 17px !important;
  line-height: 1.32 !important;
  font-weight: 850 !important;
}

/* Alertes */
.seva-subscription-alert {
  margin: 0 14px 16px !important;
  padding: 16px 18px !important;
  border-radius: 24px !important;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.08) !important;
}

/* Cards */
.seva-subscription-card,
.seva-pack-card {
  width: auto !important;
  max-width: 100% !important;
  margin: 0 14px 18px !important;
  padding: 24px !important;
  border-radius: 32px !important;
  overflow: hidden !important;
  box-shadow:
    0 18px 44px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.82) !important;
}

.seva-subscription-card h2,
.seva-pack-card h2 {
  font-size: clamp(34px, 9vw, 44px) !important;
  line-height: 0.98 !important;
  letter-spacing: -0.055em !important;
}

.seva-subscription-card p,
.seva-pack-card p {
  font-size: 16px !important;
  line-height: 1.45 !important;
}

.seva-current-top,
.seva-boost-head,
.seva-visibility-head {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 14px !important;
}

/* Si le commerce est déjà Pro, on ne revend pas le Pack Pro */
.seva-subscription-page.is-pro-active .seva-pack-card.is-hidden-when-active-pro {
  display: none !important;
}

/* Notes dans pack actuel */
.seva-current-note {
  margin-top: 16px !important;
  padding: 15px 16px !important;
  border-radius: 22px !important;
  font-size: 14px !important;
}

/* Grille packs */
.seva-pack-grid {
  width: 100% !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 18px !important;
  margin: 0 0 18px !important;
  padding: 0 14px !important;
}

.seva-pack-grid .seva-pack-card {
  margin: 0 !important;
}

.seva-pack-card.is-featured {
  overflow: hidden !important;
  border: 2px solid rgba(255, 122, 0, 0.72) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 122, 0, 0.12), transparent 35%),
    linear-gradient(180deg, #ffffff 0%, #fffdfb 100%) !important;
}

.seva-pack-card.is-featured .seva-card-kicker {
  transform: none !important;
  margin-left: 0 !important;
}

/* Options */
.seva-boost-options {
  width: 100% !important;
  margin-top: 22px !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.seva-boost-option {
  min-width: 0 !important;
  min-height: 174px !important;
  padding: 15px !important;
  border-radius: 24px !important;
  display: grid !important;
  gap: 10px !important;
  align-content: start !important;
}

.seva-boost-option strong {
  font-size: 16px !important;
  line-height: 1.15 !important;
}

.seva-boost-option span {
  font-size: 22px !important;
  line-height: 1 !important;
}

.seva-boost-option .seva-subscription-btn {
  min-height: 46px !important;
  margin-top: auto !important;
  padding: 0 12px !important;
  font-size: 13px !important;
}

/* Paiement */
.seva-subscription-card.is-payment {
  display: grid !important;
  grid-template-columns: 62px 1fr !important;
  gap: 16px !important;
  align-items: center !important;
}

.seva-subscription-card.is-payment::before {
  width: 62px !important;
  height: 62px !important;
  border-radius: 22px !important;
}

.seva-subscription-card.is-payment .seva-card-kicker,
.seva-subscription-card.is-payment h2,
.seva-subscription-card.is-payment p {
  grid-column: 2 !important;
}

.seva-subscription-card.is-payment h2 {
  font-size: 28px !important;
}

.seva-subscription-card.is-payment p {
  font-size: 14px !important;
}

/* NAV BASSE */
.seva-subscription-bottom-nav {
  position: fixed !important;
  left: 50% !important;
  bottom: 0 !important;
  z-index: 9990 !important;
  transform: translateX(-50%) !important;
  width: 100% !important;
  max-width: 520px !important;
  min-height: 94px !important;
  padding: 10px 8px calc(8px + env(safe-area-inset-bottom)) !important;
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 2px !important;
  align-items: end !important;
  border-radius: 28px 28px 0 0 !important;
  border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
  background:
    radial-gradient(circle at 50% -34%, rgba(40, 120, 255, 0.34), transparent 35%),
    linear-gradient(180deg, rgba(16, 29, 51, 0.98), rgba(7, 17, 32, 1)) !important;
  box-shadow:
    0 -18px 42px rgba(0, 0, 0, 0.30),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

.seva-subscription-bottom-nav::before {
  content: "" !important;
  position: absolute !important;
  left: 18px !important;
  right: 18px !important;
  top: 0 !important;
  height: 1px !important;
  background: linear-gradient(90deg, transparent, rgba(40, 120, 255, 0.76), rgba(255,255,255,0.35), rgba(40,120,255,0.76), transparent) !important;
  pointer-events: none !important;
}

.seva-subscription-bottom-link {
  min-width: 0 !important;
  min-height: 72px !important;
  border-radius: 24px !important;
  color: rgba(226, 232, 240, 0.78) !important;
  text-decoration: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 8px !important;
  padding: 0 0 5px !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.seva-subscription-bottom-icon,
.seva-subscription-bottom-icon svg {
  width: 25px !important;
  height: 25px !important;
  display: inline-flex !important;
  fill: currentColor !important;
}

.seva-subscription-bottom-link-center {
  position: relative !important;
  width: 78px !important;
  height: 78px !important;
  min-height: 78px !important;
  margin: 0 auto !important;
  border-radius: 999px !important;
  transform: translateY(-18px) !important;
  justify-content: center !important;
  gap: 0 !important;
  color: #ffffff !important;
  background:
    radial-gradient(circle at 32% 24%, rgba(255,255,255,0.34), transparent 26%),
    linear-gradient(135deg, #ff7a00 0%, #ff4b3e 48%, #ff2d55 100%) !important;
  box-shadow:
    0 18px 36px rgba(255, 45, 85, 0.38),
    0 8px 20px rgba(255, 122, 0, 0.28),
    inset 0 1px 0 rgba(255,255,255,0.28) !important;
}

.seva-subscription-bottom-link-center:active {
  transform: translateY(-18px) scale(0.96) !important;
}

.seva-subscription-bottom-icon-center,
.seva-subscription-bottom-icon-center svg {
  width: 31px !important;
  height: 31px !important;
}

.seva-subscription-bottom-link-center .seva-subscription-bottom-label {
  position: absolute !important;
  left: 50% !important;
  bottom: 13px !important;
  transform: translateX(-50%) !important;
  color: #fff !important;
  font-size: 11px !important;
}

.seva-subscription-bottom-label {
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

/* Très petits écrans */
@media (max-width: 380px) {
  .seva-subscription-card,
  .seva-pack-card {
    margin-left: 10px !important;
    margin-right: 10px !important;
    padding: 20px !important;
  }

  .seva-pack-grid {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .seva-boost-options {
    grid-template-columns: 1fr !important;
  }

  .seva-subscription-bottom-link-center {
    width: 72px !important;
    height: 72px !important;
    min-height: 72px !important;
  }
}

/* Tablette / desktop */
@media (min-width: 700px) {
  .seva-subscription-page {
    padding: 24px 16px 132px !important;
  }

  .seva-subscription-shell {
    max-width: 960px !important;
    overflow: visible !important;
  }

  .seva-subscription-hero {
    border-radius: 34px !important;
    padding: 32px !important;
  }

  .seva-pack-grid {
    padding: 0 !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .seva-subscription-card,
  .seva-pack-card {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}


/* ======================================================
   NOVTINIS — ABONNEMENT PATCH FINAL CORRIGE
   Compact mobile, cartes plus lisibles, validation plus légère
====================================================== */

/* Sécurise la page abonnement uniquement */
body.page-template-page-abonnement,
body.page-template-page-abonnement-php,
body.page-id-abonnement {
  background: #071120 !important;
  overflow-x: hidden !important;
}

body.page-template-page-abonnement #wpadminbar,
body.page-template-page-abonnement-php #wpadminbar,
body.page-id-abonnement #wpadminbar {
  display: none !important;
}

/* Empêche la nav basse de masquer la fin du contenu */
.seva-subscription-page {
  padding-bottom: 144px !important;
}

/* Shell app mobile */
.seva-subscription-shell {
  max-width: 520px !important;
  margin: 0 auto !important;
}

/* Header plus compact */
@media (max-width: 680px) {
  .seva-subscription-hero {
    min-height: 176px !important;
    margin-bottom: 16px !important;
    padding: 20px 18px 22px !important;
    border-radius: 0 0 30px 30px !important;
    grid-template-columns: 50px minmax(0, 1fr) !important;
    gap: 14px !important;
  }

  .seva-subscription-back {
    width: 50px !important;
    height: 50px !important;
    flex-basis: 50px !important;
    font-size: 24px !important;
  }

  .seva-subscription-hero h1 {
    margin-top: 6px !important;
    font-size: 38px !important;
    line-height: 0.96 !important;
  }

  .seva-subscription-hero p {
    margin-top: 10px !important;
    font-size: 15px !important;
    line-height: 1.32 !important;
  }

  .seva-subscription-hero .seva-subscription-kicker {
    min-height: 30px !important;
    padding: 0 14px !important;
    font-size: 12px !important;
    margin-bottom: 10px !important;
  }
}

/* Cartes plus compactes et plus régulières */
@media (max-width: 680px) {
  .seva-subscription-card,
  .seva-pack-card {
    margin-left: 14px !important;
    margin-right: 14px !important;
    margin-bottom: 16px !important;
    padding: 22px !important;
    border-radius: 30px !important;
  }

  .seva-subscription-card.is-current {
    padding: 22px !important;
  }

  .seva-subscription-card h2,
  .seva-pack-card h2 {
    font-size: 34px !important;
    line-height: 1 !important;
  }

  .seva-subscription-card p,
  .seva-pack-card p {
    font-size: 15px !important;
    line-height: 1.38 !important;
  }

  .seva-card-kicker,
  .seva-subscription-kicker {
    min-height: 30px !important;
    padding: 0 14px !important;
    font-size: 12px !important;
  }

  .seva-status-pill {
    min-height: 44px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
  }

  .seva-current-note,
  .seva-visibility-info,
  .seva-selection-conditions {
    padding: 13px 14px !important;
    border-radius: 18px !important;
    font-size: 13px !important;
    line-height: 1.42 !important;
  }
}

/* Options Mise en avant / Selection : cartes plus équilibrées */
.seva-boost-options {
  align-items: stretch !important;
}

.seva-boost-option {
  min-height: 160px !important;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.055) !important;
}

.seva-boost-option::before {
  width: 48px !important;
  height: 48px !important;
  border-radius: 17px !important;
  font-size: 22px !important;
}

.seva-boost-option .seva-subscription-btn {
  align-self: end !important;
}

@media (max-width: 680px) {
  .seva-boost-options {
    margin-top: 18px !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .seva-boost-option {
    min-height: 156px !important;
    padding: 14px !important;
    border-radius: 22px !important;
  }

  .seva-boost-option strong {
    font-size: 16px !important;
    line-height: 1.15 !important;
  }

  .seva-boost-option span {
    font-size: 20px !important;
  }

  .seva-boost-option .seva-subscription-btn {
    min-height: 44px !important;
    font-size: 13px !important;
  }
}

/* Validation manuelle plus compacte */
@media (max-width: 680px) {
  .seva-subscription-card.is-payment {
    grid-template-columns: 48px 1fr !important;
    gap: 14px !important;
    padding: 20px !important;
    border-radius: 28px !important;
    align-items: center !important;
  }

  .seva-subscription-card.is-payment::before {
    width: 48px !important;
    height: 48px !important;
    border-radius: 18px !important;
    font-size: 24px !important;
    grid-row: span 3 !important;
  }

  .seva-subscription-card.is-payment .seva-card-kicker,
  .seva-subscription-card.is-payment h2,
  .seva-subscription-card.is-payment p {
    grid-column: 2 !important;
  }

  .seva-subscription-card.is-payment .seva-card-kicker {
    min-height: 28px !important;
    padding: 0 12px !important;
    font-size: 11px !important;
    margin-bottom: 8px !important;
  }

  .seva-subscription-card.is-payment h2 {
    font-size: 25px !important;
    line-height: 1.05 !important;
  }

  .seva-subscription-card.is-payment p {
    font-size: 13px !important;
    line-height: 1.4 !important;
  }
}

/* Nav basse : assure la cohérence avec l'app */
.seva-subscription-bottom-nav {
  max-width: 520px !important;
}

@media (max-width: 680px) {
  .seva-subscription-bottom-nav {
    min-height: 92px !important;
    padding-left: 7px !important;
    padding-right: 7px !important;
  }

  .seva-subscription-bottom-link {
    min-height: 70px !important;
    border-radius: 22px !important;
  }

  .seva-subscription-bottom-link-center {
    width: 76px !important;
    height: 76px !important;
    min-height: 76px !important;
  }
}

@media (max-width: 380px) {
  .seva-subscription-card,
  .seva-pack-card {
    margin-left: 10px !important;
    margin-right: 10px !important;
    padding: 20px !important;
  }

  .seva-boost-options {
    grid-template-columns: 1fr !important;
  }
}


/* ======================================================
   NOVTINIS — ABONNEMENT STABILISATION MVP
   Correctifs légers : prix annuel, demandes en attente,
   options verrouillées et boutons mobiles.
====================================================== */

.seva-price-note {
  display: inline-flex !important;
  width: max-content !important;
  max-width: 100% !important;
  min-height: 34px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  align-items: center !important;
  background: #f8fafc !important;
  color: #64748b !important;
  border: 1px solid #e2e8f0 !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.seva-subscription-request-form-compact {
  margin-top: 10px !important;
}

.seva-subscription-btn:disabled,
.seva-subscription-btn.is-muted,
.seva-subscription-btn.is-success {
  opacity: 1 !important;
}

.seva-subscription-btn:disabled:not(.is-success):not(.is-muted) {
  color: #9a3412 !important;
  background: #fff7ed !important;
  border: 1px solid #fed7aa !important;
  box-shadow: none !important;
}

.seva-subscription-card.is-selection .seva-subscription-alert.is-locked,
.seva-subscription-card.is-boost .seva-subscription-alert.is-locked {
  margin: 16px 0 0 !important;
}

.seva-visibility-head .seva-status-pill,
.seva-boost-head .seva-status-pill {
  justify-self: start !important;
}

.seva-subscription-bottom-link:active {
  transform: scale(0.96) !important;
}

@media (max-width: 680px) {
  .seva-price-note {
    min-height: 32px !important;
    padding: 0 12px !important;
    font-size: 12px !important;
  }

  .seva-pack-card ul {
    margin-top: 18px !important;
    margin-bottom: 18px !important;
    gap: 10px !important;
  }

  .seva-pack-card li {
    padding-left: 30px !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
  }

  .seva-subscription-request-form textarea {
    min-height: 82px !important;
    border-radius: 18px !important;
    font-size: 14px !important;
  }

  .seva-subscription-btn {
    min-height: 52px !important;
    font-size: 14px !important;
  }
}


/* ======================================================
   STABLE 1.1 — ABONNEMENT PACK PRO COMPARATIF
====================================================== */

.seva-pro-compare-card {
  padding: 24px !important;
  border-radius: 30px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 122, 0, 0.10), transparent 34%),
    #ffffff !important;
  border: 1px solid rgba(226, 235, 245, 0.96) !important;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08) !important;
}

.seva-pro-compare-head h2 {
  margin: 8px 0 0 !important;
  color: #071120 !important;
  font-size: clamp(26px, 7vw, 36px) !important;
  line-height: 1.04 !important;
  font-weight: 950 !important;
  letter-spacing: -0.045em !important;
}

.seva-pro-compare-head p {
  margin: 10px 0 0 !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.42 !important;
  font-weight: 760 !important;
}

.seva-pro-compare-grid {
  margin-top: 18px !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.seva-pro-compare-column {
  min-width: 0 !important;
  padding: 16px !important;
  border-radius: 24px !important;
  border: 1px solid #e3ebf5 !important;
  background: #f7faff !important;
}

.seva-pro-compare-column.is-pro {
  color: #ffffff !important;
  border: 0 !important;
  background:
    radial-gradient(circle at 20% 10%, rgba(255,255,255,0.26), transparent 28%),
    linear-gradient(135deg, #ff7a00 0%, #ff2d55 100%) !important;
  box-shadow: 0 18px 34px rgba(255, 45, 85, 0.20) !important;
}

.seva-pro-compare-column strong {
  display: block !important;
  color: #071120 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.seva-pro-compare-column.is-pro strong {
  color: #ffffff !important;
}

.seva-pro-compare-column ul {
  margin: 14px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 9px !important;
}

.seva-pro-compare-column li {
  position: relative !important;
  padding-left: 22px !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.28 !important;
  font-weight: 800 !important;
}

.seva-pro-compare-column.is-pro li {
  color: rgba(255, 255, 255, 0.92) !important;
}

.seva-pro-compare-column li::before {
  content: "✓" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  color: #16a34a !important;
  font-weight: 950 !important;
}

.seva-pro-compare-column.is-pro li::before {
  color: #ffffff !important;
}

@media (max-width: 620px) {
  .seva-pro-compare-grid {
    grid-template-columns: 1fr !important;
  }

  .seva-pro-compare-card {
    padding: 20px !important;
    border-radius: 28px !important;
  }
}

/* ======================================================
   STABLE 1.1 — ABONNEMENT PREMIUM V1
   Refonte visuelle sans modifier la logique de prix admin.
====================================================== */

.nt-sub-page {
  padding: 0 0 128px !important;
  background:
    radial-gradient(circle at 50% -10%, rgba(40, 120, 255, 0.36), transparent 34%),
    radial-gradient(circle at 96% 12%, rgba(255, 122, 0, 0.16), transparent 32%),
    linear-gradient(180deg, #071120 0%, #08172a 48%, #06101f 100%) !important;
}

.nt-sub-shell {
  width: 100% !important;
  max-width: 520px !important;
  margin: 0 auto !important;
  overflow: visible !important;
}

.nt-sub-hero {
  min-height: 218px !important;
  margin: 0 0 14px !important;
  padding: 22px 18px 22px !important;
  border-radius: 0 0 34px 34px !important;
  display: grid !important;
  grid-template-columns: 56px minmax(0, 1fr) !important;
  gap: 14px !important;
  align-items: start !important;
  background:
    radial-gradient(circle at 88% 26%, rgba(40, 120, 255, 0.52), transparent 30%),
    radial-gradient(circle at 12% 100%, rgba(255, 122, 0, 0.12), transparent 32%),
    linear-gradient(135deg, #103a74 0%, #0b1e3e 58%, #071120 100%) !important;
  box-shadow:
    0 20px 48px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.10) !important;
}

.nt-sub-hero::after {
  display: none !important;
}

.nt-sub-back {
  width: 56px !important;
  height: 56px !important;
  flex: 0 0 56px !important;
  font-size: 27px !important;
}

.nt-sub-kicker,
.nt-sub-eyebrow,
.nt-sub-card-kicker {
  min-height: 30px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #2878ff !important;
  background: #eaf3ff !important;
  font-size: 11px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}

.nt-sub-hero .nt-sub-kicker {
  color: #dbeafe !important;
  background: rgba(40, 120, 255, 0.22) !important;
  border: 1px solid rgba(142, 197, 255, 0.28) !important;
}

.nt-sub-hero h1 {
  margin: 8px 0 0 !important;
  color: #ffffff !important;
  font-size: clamp(42px, 11vw, 58px) !important;
  line-height: 0.94 !important;
  letter-spacing: -0.06em !important;
}

.nt-sub-hero p {
  margin: 10px 0 0 !important;
  color: rgba(255, 255, 255, 0.86) !important;
  font-size: 16px !important;
  line-height: 1.32 !important;
  font-weight: 850 !important;
}

.nt-sub-hero-actions {
  margin-top: 14px !important;
  display: flex !important;
  gap: 9px !important;
  flex-wrap: wrap !important;
}

.nt-sub-current-pill,
.nt-sub-hero-cta {
  min-height: 38px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-decoration: none !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  white-space: nowrap !important;
}

.nt-sub-current-pill.is-free {
  color: #bfdbfe !important;
  background: rgba(255, 255, 255, 0.10) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.nt-sub-current-pill.is-pro {
  color: #bbf7d0 !important;
  background: rgba(34, 197, 94, 0.16) !important;
  border: 1px solid rgba(34, 197, 94, 0.24) !important;
}

.nt-sub-hero-cta {
  color: #ffffff !important;
  background: linear-gradient(135deg, #ff7a00, #ff2d55) !important;
  box-shadow: 0 14px 28px rgba(255, 45, 85, 0.26) !important;
}

.nt-sub-alert {
  margin: 0 14px 14px !important;
  border-radius: 22px !important;
}

.nt-sub-summary-card,
.nt-sub-compare-card,
.nt-sub-options-card,
.nt-sub-payment-note,
.nt-sub-empty-card {
  margin: 0 14px 16px !important;
  border-radius: 30px !important;
  background: #ffffff !important;
  border: 1px solid rgba(226, 235, 245, 0.96) !important;
  box-shadow:
    0 18px 42px rgba(15, 23, 42, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.86) !important;
}

.nt-sub-summary-card {
  padding: 22px !important;
  display: grid !important;
  gap: 16px !important;
}

.nt-sub-summary-card h2,
.nt-sub-compare-card h2,
.nt-sub-options-card h2,
.nt-sub-empty-card h2 {
  margin: 10px 0 0 !important;
  color: #071120 !important;
  font-size: clamp(30px, 8.4vw, 42px) !important;
  line-height: 0.98 !important;
  font-weight: 950 !important;
  letter-spacing: -0.055em !important;
}

.nt-sub-summary-card p,
.nt-sub-compare-card p,
.nt-sub-options-card p,
.nt-sub-empty-card p {
  margin: 10px 0 0 !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.42 !important;
  font-weight: 780 !important;
}

.nt-sub-summary-side {
  display: grid !important;
  gap: 9px !important;
}

.nt-sub-status {
  width: max-content !important;
  max-width: 100% !important;
  min-height: 38px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 13px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.nt-sub-status.is-free {
  color: #1d4ed8 !important;
  background: #eaf3ff !important;
}

.nt-sub-status.is-pro {
  color: #047857 !important;
  background: #dcfce7 !important;
}

.nt-sub-summary-side small {
  color: #64748b !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  font-weight: 850 !important;
}

.nt-sub-summary-side small.is-pending {
  color: #9a3412 !important;
}

.nt-sub-pro-card {
  position: relative !important;
  overflow: hidden !important;
  margin: 0 14px 16px !important;
  padding: 24px !important;
  border-radius: 34px !important;
  border: 2px solid rgba(255, 122, 0, 0.72) !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 122, 0, 0.18), transparent 34%),
    linear-gradient(180deg, #ffffff 0%, #fffaf6 100%) !important;
  box-shadow:
    0 22px 50px rgba(255, 122, 0, 0.18),
    0 16px 36px rgba(15, 23, 42, 0.12) !important;
}

.nt-sub-recommended {
  width: max-content !important;
  max-width: 100% !important;
  min-height: 32px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  color: #c2410c !important;
  background: #fff1e8 !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}

.nt-sub-pro-head h2 {
  margin: 12px 0 0 !important;
  color: #071120 !important;
  font-size: clamp(42px, 12vw, 62px) !important;
  line-height: 0.9 !important;
  font-weight: 950 !important;
  letter-spacing: -0.065em !important;
}

.nt-sub-pro-head p {
  margin: 12px 0 0 !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.38 !important;
  font-weight: 780 !important;
}

.nt-sub-price-row {
  margin-top: 18px !important;
  display: flex !important;
  gap: 9px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
}

.nt-sub-price-row strong,
.nt-sub-price-row em {
  min-height: 42px !important;
  padding: 0 15px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  font-style: normal !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

.nt-sub-price-row strong {
  color: #c2410c !important;
  background: #fff1e8 !important;
  font-size: 20px !important;
  font-weight: 950 !important;
}

.nt-sub-price-row strong span {
  margin-left: 4px !important;
  font-size: 13px !important;
}

.nt-sub-price-row em {
  color: #64748b !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.nt-sub-feature-list {
  margin: 20px 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 11px !important;
}

.nt-sub-feature-list li {
  position: relative !important;
  padding-left: 31px !important;
  color: #172033 !important;
  font-size: 15px !important;
  line-height: 1.32 !important;
  font-weight: 860 !important;
}

.nt-sub-feature-list li::before,
.nt-sub-compare-column li::before {
  content: "✓" !important;
  position: absolute !important;
  left: 0 !important;
  top: -2px !important;
  width: 22px !important;
  height: 22px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(255, 122, 0, 0.14) !important;
  color: #ff7a00 !important;
  font-size: 13px !important;
  font-weight: 950 !important;
}

.nt-sub-form {
  display: grid !important;
  gap: 12px !important;
}

.nt-sub-form textarea {
  width: 100% !important;
  min-height: 86px !important;
  padding: 14px 15px !important;
  border-radius: 20px !important;
  border: 1px solid #dbe7f5 !important;
  background: #f8fbff !important;
  color: #071120 !important;
  font-size: 14px !important;
  font-weight: 780 !important;
  resize: vertical !important;
}

.nt-sub-form-compact {
  margin-top: 10px !important;
}

.nt-sub-btn {
  min-height: 54px !important;
  border-radius: 999px !important;
  font-size: 15px !important;
  font-weight: 950 !important;
}

.nt-sub-btn-main {
  background:
    radial-gradient(circle at 28% 22%, rgba(255, 255, 255, 0.30), transparent 28%),
    linear-gradient(135deg, #ff7a00, #ff2d55) !important;
  color: #ffffff !important;
  box-shadow: 0 16px 34px rgba(255, 45, 85, 0.24) !important;
}

.nt-sub-btn-secondary {
  background: #eaf3ff !important;
  color: #1d4ed8 !important;
  box-shadow: none !important;
}

.nt-sub-btn:disabled,
.nt-sub-mini-plans button:disabled {
  opacity: 1 !important;
  color: #9a3412 !important;
  background: #fff7ed !important;
  border: 1px solid #fed7aa !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
}

.nt-sub-compare-card,
.nt-sub-options-card {
  padding: 22px !important;
}

.nt-sub-compare-grid {
  margin-top: 16px !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 11px !important;
}

.nt-sub-compare-column {
  padding: 16px !important;
  border-radius: 24px !important;
  border: 1px solid #e3ebf5 !important;
  background: #f8fbff !important;
}

.nt-sub-compare-column.is-pro {
  color: #ffffff !important;
  border: 0 !important;
  background:
    radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.24), transparent 28%),
    linear-gradient(135deg, #ff7a00, #ff2d55) !important;
  box-shadow: 0 16px 30px rgba(255, 45, 85, 0.20) !important;
}

.nt-sub-compare-column strong {
  display: block !important;
  color: #071120 !important;
  font-size: 18px !important;
  font-weight: 950 !important;
}

.nt-sub-compare-column.is-pro strong {
  color: #ffffff !important;
}

.nt-sub-compare-column ul {
  margin: 13px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 9px !important;
}

.nt-sub-compare-column li {
  position: relative !important;
  padding-left: 30px !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  font-weight: 820 !important;
}

.nt-sub-compare-column.is-pro li {
  color: rgba(255, 255, 255, 0.94) !important;
}

.nt-sub-compare-column.is-pro li::before {
  background: rgba(255, 255, 255, 0.20) !important;
  color: #ffffff !important;
}

.nt-sub-options-head {
  margin-bottom: 16px !important;
}

.nt-sub-option-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 12px !important;
}

.nt-sub-option-card {
  min-width: 0 !important;
  padding: 16px !important;
  border-radius: 24px !important;
  border: 1px solid #e3ebf5 !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(40, 120, 255, 0.08), transparent 32%),
    #f8fbff !important;
  display: grid !important;
  gap: 12px !important;
}

.nt-sub-option-card h3 {
  margin: 10px 0 0 !important;
  color: #071120 !important;
  font-size: 22px !important;
  line-height: 1.04 !important;
  font-weight: 950 !important;
  letter-spacing: -0.035em !important;
}

.nt-sub-option-card p,
.nt-sub-option-card small {
  margin: 8px 0 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.38 !important;
  font-weight: 760 !important;
}

.nt-sub-option-icon {
  width: 46px !important;
  height: 46px !important;
  border-radius: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: rgba(40, 120, 255, 0.12) !important;
  font-size: 22px !important;
}

.nt-sub-option-card.is-selection .nt-sub-option-icon {
  background: rgba(255, 122, 0, 0.14) !important;
}

.nt-sub-option-state {
  width: fit-content !important;
  min-height: 36px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.nt-sub-option-state.is-locked,
.nt-sub-option-state.is-pending {
  color: #9a3412 !important;
  background: #fff7ed !important;
  border: 1px solid #fed7aa !important;
}

.nt-sub-option-state.is-active {
  color: #047857 !important;
  background: #dcfce7 !important;
  border: 1px solid #bbf7d0 !important;
}

.nt-sub-mini-plans {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 10px !important;
}

.nt-sub-mini-plans form {
  margin: 0 !important;
}

.nt-sub-mini-plans button {
  width: 100% !important;
  min-height: 74px !important;
  padding: 10px !important;
  border-radius: 19px !important;
  border: 1px solid #dbe7f5 !important;
  background: #ffffff !important;
  color: #071120 !important;
  display: grid !important;
  gap: 6px !important;
  justify-items: start !important;
  cursor: pointer !important;
}

.nt-sub-mini-plans button span {
  color: #64748b !important;
  font-size: 12px !important;
  font-weight: 900 !important;
}

.nt-sub-mini-plans button strong {
  color: #071120 !important;
  font-size: 16px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.nt-sub-payment-note {
  padding: 16px !important;
  display: grid !important;
  grid-template-columns: 48px minmax(0, 1fr) !important;
  gap: 13px !important;
  align-items: center !important;
}

.nt-sub-payment-note > span {
  width: 48px !important;
  height: 48px !important;
  border-radius: 17px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #2878ff !important;
  background: #eaf3ff !important;
  font-size: 24px !important;
  font-weight: 950 !important;
}

.nt-sub-payment-note strong {
  display: block !important;
  color: #071120 !important;
  font-size: 18px !important;
  line-height: 1.1 !important;
  font-weight: 950 !important;
}

.nt-sub-payment-note p {
  margin: 5px 0 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.38 !important;
  font-weight: 760 !important;
}

.nt-sub-bottom-nav {
  box-shadow:
    0 -10px 26px rgba(0, 0, 0, 0.22),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

@media (min-width: 700px) {
  .nt-sub-page {
    padding: 24px 16px 140px !important;
  }

  .nt-sub-shell {
    max-width: 960px !important;
  }

  .nt-sub-hero {
    border-radius: 34px !important;
  }

  .nt-sub-summary-card,
  .nt-sub-compare-card,
  .nt-sub-options-card,
  .nt-sub-payment-note,
  .nt-sub-pro-card,
  .nt-sub-empty-card {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .nt-sub-summary-card {
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
  }

  .nt-sub-compare-grid,
  .nt-sub-option-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 380px) {
  .nt-sub-summary-card,
  .nt-sub-compare-card,
  .nt-sub-options-card,
  .nt-sub-payment-note,
  .nt-sub-pro-card,
  .nt-sub-empty-card {
    margin-left: 10px !important;
    margin-right: 10px !important;
  }

  .nt-sub-pro-card,
  .nt-sub-summary-card,
  .nt-sub-compare-card,
  .nt-sub-options-card {
    padding: 20px !important;
  }

  .nt-sub-mini-plans {
    grid-template-columns: 1fr !important;
  }
}


/* NOVTINIS V4.31 — Suppression ciblée Compte quick nav */
.nt-quick-app-nav__item[href*="/mon-compte/"] {
  display: none !important;
}

.nt-quick-app-nav__item .nt-quick-app-nav__label {
  pointer-events: none;
}


/* NOVTINIS V4.37 — Page abonnement / options commerçant */
.nt-v437-subscription {
  max-width: 1120px;
  margin: 0 auto;
  padding: 28px 16px 110px;
  background: #f1f5f9;
}

.nt-v437-hero {
  padding: 24px;
  border-radius: 30px;
  background: linear-gradient(135deg, #0f172a, #1e293b);
  color: #ffffff;
  box-shadow: 0 18px 44px rgba(15,23,42,.20);
}

.nt-v437-hero span,
.nt-v437-plan-top span {
  display: block;
  color: #93c5fd;
  font-size: 11px;
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.nt-v437-hero h1 {
  margin: 8px 0 10px;
  color: #ffffff;
  font-size: clamp(30px, 6vw, 54px);
  line-height: .98;
  letter-spacing: -.04em;
  font-weight: 950;
}

.nt-v437-hero p {
  max-width: 720px;
  margin: 0;
  color: rgba(226,232,240,.84);
  font-size: 16px;
  line-height: 1.45;
  font-weight: 750;
}

.nt-v437-hero-actions {
  margin-top: 18px;
}

.nt-v437-hero-actions a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: #ffffff;
  color: #0f172a !important;
  font-weight: 950;
  text-decoration: none !important;
}

.nt-v437-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 18px;
}

.nt-v437-plan {
  padding: 18px;
  border-radius: 28px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 12px 28px rgba(15,23,42,.07);
}

.nt-v437-plan.is-pack.is-active {
  border-color: #bbf7d0;
  background: linear-gradient(135deg, #ecfdf5, #ffffff);
}

.nt-v437-plan.is-option {
  border-color: #fed7aa;
  background: linear-gradient(135deg, #fff7ed, #ffffff);
}

.nt-v437-plan.is-selection {
  border-color: #bfdbfe;
  background: linear-gradient(135deg, #eff6ff, #ffffff);
}

.nt-v437-plan-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.nt-v437-plan-top strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: #e2e8f0;
  color: #0f172a;
  font-size: 12px;
  font-weight: 950;
}

.nt-v437-plan.is-pack.is-active .nt-v437-plan-top strong {
  background: #16a34a;
  color: #ffffff;
}

.nt-v437-plan.is-option .nt-v437-plan-top strong {
  background: #fb923c;
  color: #ffffff;
}

.nt-v437-plan.is-selection .nt-v437-plan-top strong {
  background: #2563eb;
  color: #ffffff;
}

.nt-v437-plan h2 {
  margin: 18px 0 8px;
  color: #0f172a;
  font-size: 25px;
  line-height: 1.05;
  font-weight: 950;
  letter-spacing: -.03em;
}

.nt-v437-plan p {
  min-height: 70px;
  margin: 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 750;
}

.nt-v437-plan ul {
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 8px;
}

.nt-v437-plan li {
  position: relative;
  padding-left: 18px;
  color: #334155;
  font-size: 13px;
  font-weight: 850;
}

.nt-v437-plan li::before {
  content: "";
  position: absolute;
  left: 0;
  top: .55em;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: #22c55e;
}

.nt-v437-plan.is-option li::before {
  background: #fb923c;
}

.nt-v437-plan.is-selection li::before {
  background: #2563eb;
}

.nt-v437-price {
  margin-top: 16px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(148,163,184,.22);
}

.nt-v437-price span {
  display: block;
  color: #64748b;
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .07em;
  text-transform: uppercase;
}

.nt-v437-price strong {
  display: block;
  margin-top: 4px;
  color: #0f172a;
  font-size: 18px;
  line-height: 1.05;
  font-weight: 950;
}

.nt-v437-button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  margin-top: 14px;
  padding: 0 14px;
  border-radius: 999px;
  background: #0f172a;
  color: #ffffff !important;
  text-decoration: none !important;
  font-size: 14px;
  font-weight: 950;
}

.nt-v437-button.is-orange {
  background: linear-gradient(135deg, #fb923c, #ef4444);
}

.nt-v437-button.is-blue {
  background: linear-gradient(135deg, #2563eb, #0ea5e9);
}

.nt-v437-note {
  margin-top: 18px;
  padding: 18px;
  border-radius: 26px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
}

.nt-v437-note h2 {
  margin: 0 0 8px;
  color: #0f172a;
  font-size: 22px;
  font-weight: 950;
}

.nt-v437-note p {
  margin: 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 750;
}

@media (max-width: 880px) {
  .nt-v437-grid {
    grid-template-columns: 1fr;
  }

  .nt-v437-plan p {
    min-height: 0;
  }
}

@media (max-width: 520px) {
  .nt-v437-subscription {
    padding: 18px 12px 100px;
  }

  .nt-v437-hero,
  .nt-v437-plan,
  .nt-v437-note {
    border-radius: 24px;
  }

  .nt-v437-hero {
    padding: 20px;
  }

  .nt-v437-plan {
    padding: 16px;
  }
}


/* NOVTINIS V4.38 — Page abonnement tarifs + design premium */
.nt-v438-subscription {
  min-height: 100vh;
  max-width: 1180px;
  margin: 0 auto;
  padding: 24px 16px 110px;
  background:
    radial-gradient(circle at top left, rgba(37,99,235,.16), transparent 30%),
    radial-gradient(circle at top right, rgba(249,115,22,.14), transparent 28%),
    #f1f5f9;
}

.nt-v438-hero {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 260px;
  gap: 18px;
  padding: 26px;
  border-radius: 34px;
  background: linear-gradient(135deg, #020617, #0f172a 52%, #1e293b);
  color: #ffffff;
  box-shadow: 0 24px 60px rgba(15,23,42,.26);
}

.nt-v438-hero::after {
  content: "";
  position: absolute;
  right: -90px;
  top: -90px;
  width: 240px;
  height: 240px;
  border-radius: 999px;
  background: rgba(59,130,246,.25);
  filter: blur(2px);
}

.nt-v438-hero-content,
.nt-v438-hero-price {
  position: relative;
  z-index: 1;
}

.nt-v438-kicker,
.nt-v438-plan-head span,
.nt-v438-combo span {
  display: block;
  color: #93c5fd;
  font-size: 11px;
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: .09em;
  text-transform: uppercase;
}

.nt-v438-hero h1 {
  max-width: 740px;
  margin: 9px 0 12px;
  color: #ffffff;
  font-size: clamp(34px, 7vw, 64px);
  line-height: .92;
  letter-spacing: -.055em;
  font-weight: 950;
}

.nt-v438-hero p {
  max-width: 690px;
  margin: 0;
  color: rgba(226,232,240,.82);
  font-size: 16px;
  line-height: 1.45;
  font-weight: 750;
}

.nt-v438-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}

.nt-v438-hero-badges span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.12);
  color: #e2e8f0;
  font-size: 12px;
  font-weight: 900;
}

.nt-v438-hero-price {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 18px;
  border-radius: 28px;
  background: rgba(255,255,255,.11);
  border: 1px solid rgba(255,255,255,.16);
  backdrop-filter: blur(12px);
}

.nt-v438-hero-price span {
  color: #cbd5e1;
  font-size: 12px;
  font-weight: 900;
}

.nt-v438-hero-price strong {
  margin-top: 4px;
  color: #ffffff;
  font-size: 48px;
  line-height: .95;
  letter-spacing: -.05em;
  font-weight: 950;
}

.nt-v438-hero-price em {
  margin-top: 4px;
  color: #cbd5e1;
  font-style: normal;
  font-size: 14px;
  font-weight: 850;
}

.nt-v438-hero-price a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  margin-top: 16px;
  padding: 0 16px;
  border-radius: 999px;
  background: #ffffff;
  color: #0f172a !important;
  text-decoration: none !important;
  font-size: 13px;
  font-weight: 950;
}

.nt-v438-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}

.nt-v438-plan {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 560px;
  padding: 18px;
  border-radius: 32px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 16px 38px rgba(15,23,42,.08);
}

.nt-v438-plan::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 7px;
  background: #22c55e;
}

.nt-v438-plan.is-featured::before {
  background: linear-gradient(90deg, #fb923c, #ef4444);
}

.nt-v438-plan.is-selection::before {
  background: linear-gradient(90deg, #2563eb, #0ea5e9);
}

.nt-v438-plan-badge {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  background: #dcfce7;
  color: #166534;
  font-size: 12px;
  font-weight: 950;
}

.nt-v438-plan-badge.is-hot {
  background: #ffedd5;
  color: #c2410c;
}

.nt-v438-plan-badge.is-premium {
  background: #dbeafe;
  color: #1d4ed8;
}

.nt-v438-plan-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-top: 18px;
}

.nt-v438-plan-head h2 {
  margin: 6px 0 0;
  color: #0f172a;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -.04em;
  font-weight: 950;
}

.nt-v438-plan-head strong {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: #0f172a;
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.nt-v438-plan p {
  min-height: 86px;
  margin: 14px 0 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 750;
}

.nt-v438-price {
  display: flex;
  align-items: flex-end;
  gap: 7px;
  margin-top: 16px;
  padding: 14px;
  border-radius: 22px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}

.nt-v438-price strong {
  color: #0f172a;
  font-size: 42px;
  line-height: .9;
  letter-spacing: -.06em;
  font-weight: 950;
}

.nt-v438-price span {
  color: #64748b;
  font-size: 14px;
  font-weight: 900;
  padding-bottom: 4px;
}

.nt-v438-plan ul {
  margin: 16px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 9px;
}

.nt-v438-plan li {
  position: relative;
  padding-left: 24px;
  color: #334155;
  font-size: 13px;
  line-height: 1.25;
  font-weight: 850;
}

.nt-v438-plan li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: -1px;
  width: 17px;
  height: 17px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #dcfce7;
  color: #166534;
  font-size: 11px;
  font-weight: 950;
}

.nt-v438-plan.is-featured li::before {
  background: #ffedd5;
  color: #c2410c;
}

.nt-v438-plan.is-selection li::before {
  background: #dbeafe;
  color: #1d4ed8;
}

.nt-v438-button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  margin-top: auto;
  padding: 0 14px;
  border-radius: 999px;
  background: #0f172a;
  color: #ffffff !important;
  text-decoration: none !important;
  font-size: 14px;
  font-weight: 950;
}

.nt-v438-button.is-orange {
  background: linear-gradient(135deg, #fb923c, #ef4444);
}

.nt-v438-button.is-blue {
  background: linear-gradient(135deg, #2563eb, #0ea5e9);
}

.nt-v438-combo {
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 14px;
  align-items: stretch;
  margin-top: 16px;
  padding: 20px;
  border-radius: 32px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  box-shadow: 0 14px 32px rgba(15,23,42,.07);
}

.nt-v438-combo h2 {
  max-width: 760px;
  margin: 7px 0 8px;
  color: #0f172a;
  font-size: 28px;
  line-height: 1.05;
  letter-spacing: -.04em;
  font-weight: 950;
}

.nt-v438-combo p {
  margin: 0;
  color: #64748b;
  font-size: 14px;
  line-height: 1.45;
  font-weight: 750;
}

.nt-v438-combo-total {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 16px;
  border-radius: 24px;
  background: linear-gradient(135deg, #0f172a, #1e293b);
  color: #ffffff;
}

.nt-v438-combo-total span {
  color: #93c5fd;
  font-size: 11px;
  font-weight: 950;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.nt-v438-combo-total strong {
  margin-top: 6px;
  color: #ffffff;
  font-size: 42px;
  line-height: .9;
  font-weight: 950;
  letter-spacing: -.05em;
}

.nt-v438-combo-total em {
  color: #cbd5e1;
  font-style: normal;
  font-size: 14px;
  font-weight: 850;
}

.nt-v438-combo-total small {
  display: block;
  margin-top: 8px;
  color: rgba(226,232,240,.78);
  font-size: 12px;
  line-height: 1.3;
  font-weight: 750;
}

.nt-v438-faq {
  margin-top: 16px;
  padding: 20px;
  border-radius: 32px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
}

.nt-v438-faq h2 {
  margin: 0 0 14px;
  color: #0f172a;
  font-size: 26px;
  line-height: 1;
  font-weight: 950;
}

.nt-v438-faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.nt-v438-faq article {
  padding: 14px;
  border-radius: 22px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}

.nt-v438-faq strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
  font-weight: 950;
}

.nt-v438-faq p {
  margin: 7px 0 0;
  color: #64748b;
  font-size: 13px;
  line-height: 1.35;
  font-weight: 750;
}

@media (max-width: 980px) {
  .nt-v438-hero,
  .nt-v438-combo {
    grid-template-columns: 1fr;
  }

  .nt-v438-grid,
  .nt-v438-faq-grid {
    grid-template-columns: 1fr;
  }

  .nt-v438-plan {
    min-height: auto;
  }

  .nt-v438-plan p {
    min-height: 0;
  }
}

@media (max-width: 520px) {
  .nt-v438-subscription {
    padding: 16px 12px 100px;
  }

  .nt-v438-hero,
  .nt-v438-plan,
  .nt-v438-combo,
  .nt-v438-faq {
    border-radius: 26px;
  }

  .nt-v438-hero {
    padding: 20px;
  }

  .nt-v438-price strong,
  .nt-v438-hero-price strong,
  .nt-v438-combo-total strong {
    font-size: 38px;
  }

  .nt-v438-plan-head {
    align-items: flex-start;
  }
}


/* NOVTINIS V4.39 — Abonnement style cohérent app */
.nt-v439-subscription {
  max-width: 1120px !important;
  margin: 0 auto !important;
  padding: 18px 14px 110px !important;
  background: #f1f5f9 !important;
}

.nt-v439-header,
.nt-v439-summary article,
.nt-v439-card,
.nt-v439-total,
.nt-v439-faq {
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  box-shadow: 0 10px 24px rgba(15,23,42,.06) !important;
}

.nt-v439-header {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 14px !important;
  padding: 18px !important;
  border-radius: 28px !important;
}

.nt-v439-chip,
.nt-v439-card-head span,
.nt-v439-summary span,
.nt-v439-total span {
  display: inline-flex !important;
  align-items: center !important;
  min-height: 28px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #dbeafe !important;
  color: #2563eb !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  letter-spacing: .09em !important;
  text-transform: uppercase !important;
}

.nt-v439-header h1 {
  margin: 10px 0 7px !important;
  color: #0f172a !important;
  font-size: clamp(34px, 7vw, 54px) !important;
  line-height: .96 !important;
  letter-spacing: -.05em !important;
  font-weight: 950 !important;
}

.nt-v439-header p {
  max-width: 700px !important;
  margin: 0 !important;
  color: #64748b !important;
  font-size: 15px !important;
  line-height: 1.4 !important;
  font-weight: 750 !important;
}

.nt-v439-back {
  flex: 0 0 auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 42px !important;
  padding: 0 15px !important;
  border-radius: 999px !important;
  background: #0f172a !important;
  color: #ffffff !important;
  text-decoration: none !important;
  font-size: 13px !important;
  font-weight: 950 !important;
}

.nt-v439-summary {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 10px !important;
  margin-top: 12px !important;
}

.nt-v439-summary article {
  padding: 14px !important;
  border-radius: 24px !important;
}

.nt-v439-summary article:nth-child(2) span {
  background: #ffedd5 !important;
  color: #c2410c !important;
}

.nt-v439-summary article:nth-child(3) span {
  background: #dcfce7 !important;
  color: #166534 !important;
}

.nt-v439-summary strong {
  display: block !important;
  margin-top: 10px !important;
  color: #0f172a !important;
  font-size: 32px !important;
  line-height: .95 !important;
  letter-spacing: -.05em !important;
  font-weight: 950 !important;
}

.nt-v439-summary em {
  margin-left: 4px !important;
  color: #64748b !important;
  font-style: normal !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
}

.nt-v439-plans {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
  margin-top: 12px !important;
}

.nt-v439-card {
  display: flex !important;
  flex-direction: column !important;
  min-height: 500px !important;
  padding: 16px !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  position: relative !important;
}

.nt-v439-card::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: 0 !important;
  width: 100% !important;
  height: 5px !important;
  background: #22c55e !important;
}

.nt-v439-card.is-featured::before {
  background: #fb923c !important;
}

.nt-v439-card.is-selection::before {
  background: #2563eb !important;
}

.nt-v439-card.is-pack {
  background: linear-gradient(135deg, #ecfdf5, #ffffff 52%) !important;
  border-color: #bbf7d0 !important;
}

.nt-v439-card.is-featured {
  background: linear-gradient(135deg, #fff7ed, #ffffff 52%) !important;
  border-color: #fed7aa !important;
}

.nt-v439-card.is-selection {
  background: linear-gradient(135deg, #eff6ff, #ffffff 52%) !important;
  border-color: #bfdbfe !important;
}

.nt-v439-card-head {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
}

.nt-v439-card-head h2 {
  margin: 10px 0 0 !important;
  color: #0f172a !important;
  font-size: 28px !important;
  line-height: 1.02 !important;
  letter-spacing: -.04em !important;
  font-weight: 950 !important;
}

.nt-v439-card-head em {
  flex: 0 0 auto !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 30px !important;
  padding: 0 11px !important;
  border-radius: 999px !important;
  background: #0f172a !important;
  color: #ffffff !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 950 !important;
}

.nt-v439-card-text {
  min-height: 68px !important;
  margin: 13px 0 0 !important;
  color: #64748b !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  font-weight: 750 !important;
}

.nt-v439-price {
  display: flex !important;
  align-items: flex-end !important;
  gap: 8px !important;
  margin-top: 14px !important;
  padding: 13px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.82) !important;
  border: 1px solid #e2e8f0 !important;
}

.nt-v439-price strong {
  color: #0f172a !important;
  font-size: 42px !important;
  line-height: .9 !important;
  letter-spacing: -.06em !important;
  font-weight: 950 !important;
}

.nt-v439-price span {
  padding-bottom: 4px !important;
  color: #64748b !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

.nt-v439-list {
  margin: 15px 0 0 !important;
  padding: 0 !important;
  list-style: none !important;
  display: grid !important;
  gap: 9px !important;
}

.nt-v439-list li {
  position: relative !important;
  padding-left: 25px !important;
  color: #334155 !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  font-weight: 850 !important;
}

.nt-v439-list li::before {
  content: "✓" !important;
  position: absolute !important;
  left: 0 !important;
  top: -1px !important;
  width: 18px !important;
  height: 18px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #dcfce7 !important;
  color: #166534 !important;
  font-size: 11px !important;
  font-weight: 950 !important;
}

.nt-v439-card.is-featured .nt-v439-list li::before {
  background: #ffedd5 !important;
  color: #c2410c !important;
}

.nt-v439-card.is-selection .nt-v439-list li::before {
  background: #dbeafe !important;
  color: #1d4ed8 !important;
}

.nt-v439-button {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 44px !important;
  margin-top: auto !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  background: #0f172a !important;
  color: #ffffff !important;
  text-decoration: none !important;
  font-size: 14px !important;
  font-weight: 950 !important;
}

.nt-v439-button.is-orange {
  background: linear-gradient(135deg, #fb923c, #ef4444) !important;
}

.nt-v439-button.is-blue {
  background: linear-gradient(135deg, #2563eb, #0ea5e9) !important;
}

.nt-v439-total {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  margin-top: 12px !important;
  padding: 16px !important;
  border-radius: 28px !important;
}

.nt-v439-total h2 {
  margin: 9px 0 4px !important;
  color: #0f172a !important;
  font-size: 34px !important;
  line-height: .95 !important;
  letter-spacing: -.05em !important;
  font-weight: 950 !important;
}

.nt-v439-total h2 em {
  color: #64748b !important;
  font-style: normal !important;
  font-size: 15px !important;
  font-weight: 850 !important;
  letter-spacing: 0 !important;
}

.nt-v439-total p,
.nt-v439-total small {
  margin: 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
  font-weight: 750 !important;
}

.nt-v439-total small {
  max-width: 330px !important;
  text-align: right !important;
}

.nt-v439-faq {
  margin-top: 12px !important;
  padding: 16px !important;
  border-radius: 28px !important;
}

.nt-v439-faq h2 {
  margin: 10px 0 12px !important;
  color: #0f172a !important;
  font-size: 28px !important;
  line-height: 1 !important;
  letter-spacing: -.04em !important;
  font-weight: 950 !important;
}

.nt-v439-faq details {
  border: 1px solid #e2e8f0 !important;
  border-radius: 20px !important;
  background: #f8fafc !important;
  padding: 13px 14px !important;
}

.nt-v439-faq details + details {
  margin-top: 8px !important;
}

.nt-v439-faq summary {
  cursor: pointer !important;
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 950 !important;
}

.nt-v439-faq p {
  margin: 8px 0 0 !important;
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
  font-weight: 750 !important;
}

/* Masque l'ancien design V4.38 si certains styles restent chargés */
.nt-v438-hero,
.nt-v438-grid,
.nt-v438-combo,
.nt-v438-faq {
  display: none !important;
}

@media (max-width: 920px) {
  .nt-v439-plans,
  .nt-v439-summary {
    grid-template-columns: 1fr !important;
  }

  .nt-v439-card {
    min-height: auto !important;
  }

  .nt-v439-card-text {
    min-height: 0 !important;
  }
}

@media (max-width: 560px) {
  .nt-v439-subscription {
    padding: 14px 12px 100px !important;
  }

  .nt-v439-header {
    display: block !important;
    border-radius: 24px !important;
  }

  .nt-v439-back {
    width: 100% !important;
    margin-top: 14px !important;
  }

  .nt-v439-card,
  .nt-v439-summary article,
  .nt-v439-total,
  .nt-v439-faq {
    border-radius: 24px !important;
  }

  .nt-v439-total {
    display: block !important;
  }

  .nt-v439-total small {
    display: block !important;
    max-width: none !important;
    margin-top: 8px !important;
    text-align: left !important;
  }

  .nt-v439-price strong,
  .nt-v439-summary strong {
    font-size: 36px !important;
  }

  .nt-v439-card-head h2 {
    font-size: 27px !important;
  }
}


/* NOVTINIS V4.40 — Abonnement compact mobile */
.nt-v440-subscription { padding-top: 12px !important; }
.nt-v440-header { padding: 16px !important; }
.nt-v440-header h1 { margin: 8px 0 6px !important; font-size: clamp(31px, 7vw, 48px) !important; }
.nt-v440-header p { max-width: 620px !important; font-size: 14px !important; }

.nt-v440-price-strip {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin-top: 10px !important;
}
.nt-v440-price-strip div {
  padding: 11px 12px !important;
  border-radius: 20px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  box-shadow: 0 8px 18px rgba(15,23,42,.05) !important;
}
.nt-v440-price-strip span {
  display: block !important;
  color: #64748b !important;
  font-size: 10px !important;
  line-height: 1.1 !important;
  font-weight: 950 !important;
  letter-spacing: .07em !important;
  text-transform: uppercase !important;
}
.nt-v440-price-strip strong {
  display: inline-block !important;
  margin-top: 6px !important;
  color: #0f172a !important;
  font-size: 25px !important;
  line-height: .95 !important;
  letter-spacing: -.05em !important;
  font-weight: 950 !important;
}
.nt-v440-price-strip em {
  margin-left: 4px !important;
  color: #64748b !important;
  font-style: normal !important;
  font-size: 12px !important;
  font-weight: 850 !important;
}

.nt-v440-plans { margin-top: 10px !important; gap: 10px !important; }
.nt-v440-card {
  min-height: 0 !important;
  padding: 14px !important;
  border-radius: 24px !important;
}
.nt-v440-card .nt-v439-card-head h2 { margin-top: 7px !important; font-size: 25px !important; }
.nt-v440-card .nt-v439-card-head em { min-height: 28px !important; padding: 0 10px !important; }
.nt-v440-card .nt-v439-card-text {
  min-height: 0 !important;
  margin: 10px 0 !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}
.nt-v440-card .nt-v439-price {
  margin-top: 0 !important;
  padding: 10px 12px !important;
  border-radius: 18px !important;
}
.nt-v440-card .nt-v439-price strong { font-size: 34px !important; }
.nt-v440-card .nt-v439-price span { font-size: 13px !important; }

.nt-v440-list { margin-top: 12px !important; gap: 7px !important; }
.nt-v440-list li { font-size: 12.5px !important; line-height: 1.22 !important; }
.nt-v440-button { min-height: 40px !important; margin-top: 13px !important; font-size: 13px !important; }

.nt-v440-total {
  margin-top: 10px !important;
  padding: 14px !important;
  border-radius: 24px !important;
}
.nt-v440-total h2 { margin-top: 7px !important; font-size: 30px !important; }
.nt-v440-total p, .nt-v440-total small { font-size: 12.5px !important; }

.nt-v440-faq {
  margin-top: 10px !important;
  padding: 14px !important;
  border-radius: 24px !important;
}
.nt-v440-faq h2 { margin: 8px 0 10px !important; font-size: 25px !important; }
.nt-v440-faq details { padding: 11px 12px !important; border-radius: 18px !important; }
.nt-v440-faq summary { font-size: 13.5px !important; }
.nt-v440-faq p { font-size: 12.5px !important; }

/* Ancien résumé V4.39 masqué */
.nt-v439-summary { display: none !important; }

@media (max-width: 920px) {
  .nt-v440-price-strip { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
}
@media (max-width: 560px) {
  .nt-v440-subscription { padding: 10px 12px 100px !important; }
  .nt-v440-header { border-radius: 22px !important; }
  .nt-v440-header h1 { font-size: 39px !important; }
  .nt-v440-price-strip { grid-template-columns: 1fr !important; }
  .nt-v440-price-strip div {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    padding: 10px 12px !important;
  }
  .nt-v440-price-strip span { font-size: 10px !important; }
  .nt-v440-price-strip strong { margin-top: 0 !important; font-size: 24px !important; }
  .nt-v440-card { border-radius: 22px !important; }
  .nt-v440-card .nt-v439-card-head h2 { font-size: 28px !important; }
  .nt-v440-card .nt-v439-price strong { font-size: 32px !important; }
  .nt-v440-total { border-radius: 22px !important; }
}

/* NOVTINIS V4.41 — Solutions commerçants / Pack Pro gratuit */
.nt-v441-solutions{max-width:1120px!important;margin:0 auto!important;padding:14px 12px 110px!important;background:#f1f5f9!important}
.nt-v441-header,.nt-v441-trust article,.nt-v441-card,.nt-v441-secondary,.nt-v441-rules{background:#fff!important;border:1px solid #e2e8f0!important;box-shadow:0 10px 24px rgba(15,23,42,.06)!important}
.nt-v441-header{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;gap:14px!important;padding:17px!important;border-radius:26px!important}
.nt-v441-chip,.nt-v441-card-head span,.nt-v441-trust span,.nt-v441-secondary-price span{display:inline-flex!important;align-items:center!important;min-height:27px!important;padding:0 11px!important;border-radius:999px!important;background:#dbeafe!important;color:#2563eb!important;font-size:10px!important;font-weight:950!important;letter-spacing:.08em!important;text-transform:uppercase!important}
.nt-v441-header h1{max-width:760px!important;margin:9px 0 7px!important;color:#0f172a!important;font-size:clamp(31px,7vw,52px)!important;line-height:.96!important;letter-spacing:-.05em!important;font-weight:950!important}
.nt-v441-header p{max-width:760px!important;margin:0!important;color:#64748b!important;font-size:14px!important;line-height:1.4!important;font-weight:750!important}
.nt-v441-back{flex:0 0 auto!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:40px!important;padding:0 14px!important;border-radius:999px!important;background:#0f172a!important;color:#fff!important;text-decoration:none!important;font-size:13px!important;font-weight:950!important}
.nt-v441-trust{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:9px!important;margin-top:10px!important}
.nt-v441-trust article{padding:12px!important;border-radius:21px!important}.nt-v441-trust article:nth-child(1) span{background:#dcfce7!important;color:#166534!important}.nt-v441-trust article:nth-child(2) span{background:#ffedd5!important;color:#c2410c!important}.nt-v441-trust article:nth-child(3) span{background:#f3e8ff!important;color:#7e22ce!important}
.nt-v441-trust strong{display:block!important;margin-top:8px!important;color:#0f172a!important;font-size:24px!important;line-height:.95!important;letter-spacing:-.04em!important;font-weight:950!important}.nt-v441-trust em{display:block!important;margin-top:5px!important;color:#64748b!important;font-style:normal!important;font-size:12px!important;font-weight:800!important}
.nt-v441-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important;margin-top:10px!important}
.nt-v441-card{position:relative!important;overflow:hidden!important;display:flex!important;flex-direction:column!important;min-height:430px!important;padding:15px!important;border-radius:25px!important}
.nt-v441-card:before{content:""!important;position:absolute!important;left:0!important;top:0!important;width:100%!important;height:5px!important;background:#22c55e!important}.nt-v441-card.is-featured:before{background:#fb923c!important}.nt-v441-card.is-ad:before{background:#2563eb!important}.nt-v441-card.is-selection:before{background:#7c3aed!important}
.nt-v441-card.is-free{background:linear-gradient(135deg,#ecfdf5,#fff 55%)!important;border-color:#bbf7d0!important}.nt-v441-card.is-featured{background:linear-gradient(135deg,#fff7ed,#fff 55%)!important;border-color:#fed7aa!important}.nt-v441-card.is-ad{background:linear-gradient(135deg,#eff6ff,#fff 55%)!important;border-color:#bfdbfe!important}.nt-v441-card.is-selection{background:linear-gradient(135deg,#faf5ff,#fff 55%)!important;border-color:#e9d5ff!important}
.nt-v441-card-head{display:flex!important;align-items:flex-start!important;justify-content:space-between!important;gap:12px!important}.nt-v441-card-head h2{margin:8px 0 0!important;color:#0f172a!important;font-size:27px!important;line-height:1.02!important;letter-spacing:-.04em!important;font-weight:950!important}.nt-v441-card-head em{flex:0 0 auto!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;min-height:28px!important;padding:0 10px!important;border-radius:999px!important;background:#0f172a!important;color:#fff!important;font-style:normal!important;font-size:11px!important;font-weight:950!important}
.nt-v441-card p{margin:12px 0 0!important;color:#64748b!important;font-size:13px!important;line-height:1.35!important;font-weight:750!important}
.nt-v441-price{display:flex!important;align-items:flex-end!important;gap:7px!important;margin-top:12px!important;padding:11px 12px!important;border-radius:18px!important;background:rgba(255,255,255,.82)!important;border:1px solid #e2e8f0!important}.nt-v441-price strong{color:#0f172a!important;font-size:36px!important;line-height:.9!important;letter-spacing:-.06em!important;font-weight:950!important}.nt-v441-price span{padding-bottom:4px!important;color:#64748b!important;font-size:13px!important;font-weight:900!important}.nt-v441-price.is-file{align-items:flex-start!important;flex-direction:column!important;gap:4px!important}.nt-v441-price.is-file strong{font-size:24px!important;line-height:1!important;letter-spacing:-.03em!important}.nt-v441-price.is-file span{padding-bottom:0!important}
.nt-v441-card ul{margin:13px 0 0!important;padding:0!important;list-style:none!important;display:grid!important;gap:7px!important}.nt-v441-card li{position:relative!important;padding-left:24px!important;color:#334155!important;font-size:12.5px!important;line-height:1.22!important;font-weight:850!important}.nt-v441-card li:before{content:"✓"!important;position:absolute!important;left:0!important;top:-1px!important;width:17px!important;height:17px!important;border-radius:999px!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;background:#dcfce7!important;color:#166534!important;font-size:10px!important;font-weight:950!important}.nt-v441-card.is-featured li:before{background:#ffedd5!important;color:#c2410c!important}.nt-v441-card.is-ad li:before{background:#dbeafe!important;color:#1d4ed8!important}.nt-v441-card.is-selection li:before{background:#f3e8ff!important;color:#7e22ce!important}
.nt-v441-card small{display:block!important;margin-top:12px!important;color:#64748b!important;font-size:12px!important;line-height:1.3!important;font-weight:800!important}
.nt-v441-button{display:flex!important;align-items:center!important;justify-content:center!important;min-height:40px!important;margin-top:auto!important;padding:0 13px!important;border-radius:999px!important;background:#0f172a!important;color:#fff!important;text-decoration:none!important;font-size:13px!important;font-weight:950!important}.nt-v441-button.is-orange{background:linear-gradient(135deg,#fb923c,#ef4444)!important}.nt-v441-button.is-blue{background:linear-gradient(135deg,#2563eb,#0ea5e9)!important}.nt-v441-button.is-purple{background:linear-gradient(135deg,#7c3aed,#2563eb)!important}
.nt-v441-secondary,.nt-v441-rules{margin-top:10px!important;padding:15px!important;border-radius:25px!important}.nt-v441-secondary{display:grid!important;grid-template-columns:1fr 150px!important;gap:12px!important;align-items:center!important}.nt-v441-secondary h2,.nt-v441-rules h2{margin:9px 0 7px!important;color:#0f172a!important;font-size:25px!important;line-height:1.03!important;letter-spacing:-.04em!important;font-weight:950!important}.nt-v441-secondary p{margin:0!important;color:#64748b!important;font-size:13px!important;line-height:1.35!important;font-weight:750!important}
.nt-v441-secondary-price{padding:13px!important;border-radius:20px!important;background:#f8fafc!important;border:1px solid #e2e8f0!important}.nt-v441-secondary-price strong{display:block!important;margin-top:7px!important;color:#0f172a!important;font-size:30px!important;line-height:.9!important;font-weight:950!important;letter-spacing:-.05em!important}.nt-v441-secondary-price em{display:block!important;margin-top:5px!important;color:#64748b!important;font-style:normal!important;font-size:12px!important;font-weight:850!important}
.nt-v441-rules-grid{display:grid!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:8px!important}.nt-v441-rules article{padding:12px!important;border-radius:20px!important;background:#f8fafc!important;border:1px solid #e2e8f0!important}.nt-v441-rules strong{display:block!important;color:#0f172a!important;font-size:13px!important;font-weight:950!important}.nt-v441-rules p{margin:6px 0 0!important;color:#64748b!important;font-size:12px!important;line-height:1.3!important;font-weight:750!important}
.nt-v439-summary,.nt-v440-price-strip,.nt-v439-plans,.nt-v439-total,.nt-v439-faq{display:none!important}
@media(max-width:860px){.nt-v441-grid,.nt-v441-rules-grid{grid-template-columns:1fr!important}.nt-v441-card{min-height:auto!important}}
@media(max-width:560px){.nt-v441-header{display:block!important;border-radius:23px!important;padding:15px!important}.nt-v441-header h1{font-size:37px!important}.nt-v441-back{width:100%!important;margin-top:13px!important}.nt-v441-trust{grid-template-columns:1fr!important}.nt-v441-card,.nt-v441-secondary,.nt-v441-rules,.nt-v441-trust article{border-radius:22px!important}.nt-v441-secondary{grid-template-columns:1fr!important}.nt-v441-card-head h2{font-size:26px!important}.nt-v441-price strong{font-size:32px!important}}

/* NOVTINIS V4.42 — Solutions commerçants / cartes propres */
.nt-v442-solutions{
  max-width:1120px!important;
  margin:0 auto!important;
  padding:14px 12px 110px!important;
  background:#f1f5f9!important;
}

.nt-v442-header,
.nt-v442-card,
.nt-v442-secondary,
.nt-v442-rules{
  background:#fff!important;
  border:1px solid #e2e8f0!important;
  box-shadow:0 10px 24px rgba(15,23,42,.06)!important;
}

.nt-v442-header{
  padding:18px!important;
  border-radius:26px!important;
}

.nt-v442-chip,
.nt-v442-card-head span,
.nt-v442-secondary-price span{
  display:inline-flex!important;
  align-items:center!important;
  min-height:28px!important;
  padding:0 12px!important;
  border-radius:999px!important;
  background:#dbeafe!important;
  color:#2563eb!important;
  font-size:10px!important;
  font-weight:950!important;
  letter-spacing:.08em!important;
  text-transform:uppercase!important;
}

.nt-v442-header h1{
  max-width:780px!important;
  margin:10px 0 8px!important;
  color:#0f172a!important;
  font-size:clamp(31px,7vw,50px)!important;
  line-height:.98!important;
  letter-spacing:-.05em!important;
  font-weight:950!important;
}

.nt-v442-header p{
  max-width:780px!important;
  margin:0!important;
  color:#64748b!important;
  font-size:14px!important;
  line-height:1.4!important;
  font-weight:750!important;
}

.nt-v442-back{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:42px!important;
  margin-top:14px!important;
  padding:0 15px!important;
  border-radius:999px!important;
  background:#0f172a!important;
  color:#fff!important;
  text-decoration:none!important;
  font-size:13px!important;
  font-weight:950!important;
}

.nt-v442-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:12px!important;
  margin-top:12px!important;
}

.nt-v442-card{
  position:relative!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  min-height:0!important;
  padding:18px!important;
  border-radius:26px!important;
}

.nt-v442-card:before{
  content:""!important;
  position:absolute!important;
  left:0!important;
  top:0!important;
  width:100%!important;
  height:5px!important;
  background:#22c55e!important;
}

.nt-v442-card.is-featured:before{background:#fb923c!important;}
.nt-v442-card.is-ad:before{background:#2563eb!important;}
.nt-v442-card.is-selection:before{background:#7c3aed!important;}

.nt-v442-card.is-free{
  background:linear-gradient(135deg,#ecfdf5,#fff 58%)!important;
  border-color:#bbf7d0!important;
}
.nt-v442-card.is-featured{
  background:linear-gradient(135deg,#fff7ed,#fff 58%)!important;
  border-color:#fed7aa!important;
}
.nt-v442-card.is-ad{
  background:linear-gradient(135deg,#eff6ff,#fff 58%)!important;
  border-color:#bfdbfe!important;
}
.nt-v442-card.is-selection{
  background:linear-gradient(135deg,#faf5ff,#fff 58%)!important;
  border-color:#e9d5ff!important;
}

.nt-v442-card-head{
  display:flex!important;
  align-items:flex-start!important;
  justify-content:space-between!important;
  gap:12px!important;
  margin-bottom:12px!important;
}

.nt-v442-card-head h2{
  margin:9px 0 0!important;
  color:#0f172a!important;
  font-size:28px!important;
  line-height:1.02!important;
  letter-spacing:-.04em!important;
  font-weight:950!important;
}

.nt-v442-card-head em{
  flex:0 0 auto!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:30px!important;
  padding:0 11px!important;
  border-radius:999px!important;
  background:#0f172a!important;
  color:#fff!important;
  font-style:normal!important;
  font-size:11px!important;
  font-weight:950!important;
}

.nt-v442-desc{
  margin:0!important;
  color:#64748b!important;
  font-size:13.5px!important;
  line-height:1.38!important;
  font-weight:750!important;
}

.nt-v442-price{
  display:flex!important;
  align-items:flex-end!important;
  gap:8px!important;
  margin-top:14px!important;
  padding:14px!important;
  border-radius:20px!important;
  background:rgba(255,255,255,.86)!important;
  border:1px solid #e2e8f0!important;
}

.nt-v442-price strong{
  color:#0f172a!important;
  font-size:38px!important;
  line-height:.9!important;
  letter-spacing:-.06em!important;
  font-weight:950!important;
}

.nt-v442-price span{
  padding-bottom:4px!important;
  color:#64748b!important;
  font-size:13px!important;
  font-weight:900!important;
}

.nt-v442-price.is-file{
  align-items:flex-start!important;
  flex-direction:column!important;
  gap:5px!important;
}

.nt-v442-price.is-file strong{
  font-size:24px!important;
  line-height:1!important;
  letter-spacing:-.03em!important;
}

.nt-v442-price.is-file span{
  padding-bottom:0!important;
}

.nt-v442-list{
  margin:15px 0 0!important;
  padding:0!important;
  list-style:none!important;
  display:grid!important;
  gap:8px!important;
}

.nt-v442-list li{
  position:relative!important;
  padding-left:25px!important;
  color:#334155!important;
  font-size:13px!important;
  line-height:1.25!important;
  font-weight:850!important;
}

.nt-v442-list li:before{
  content:"✓"!important;
  position:absolute!important;
  left:0!important;
  top:-1px!important;
  width:18px!important;
  height:18px!important;
  border-radius:999px!important;
  display:inline-flex!important;
  align-items:center!important;
  justify-content:center!important;
  background:#dcfce7!important;
  color:#166534!important;
  font-size:10px!important;
  font-weight:950!important;
}

.nt-v442-card.is-featured .nt-v442-list li:before{background:#ffedd5!important;color:#c2410c!important;}
.nt-v442-card.is-ad .nt-v442-list li:before{background:#dbeafe!important;color:#1d4ed8!important;}
.nt-v442-card.is-selection .nt-v442-list li:before{background:#f3e8ff!important;color:#7e22ce!important;}

.nt-v442-note{
  margin-top:14px!important;
  padding:11px 12px!important;
  border-radius:18px!important;
  background:rgba(248,250,252,.92)!important;
  border:1px solid #e2e8f0!important;
  color:#64748b!important;
  font-size:12.5px!important;
  line-height:1.32!important;
  font-weight:850!important;
}

.nt-v442-button{
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  min-height:42px!important;
  margin-top:14px!important;
  padding:0 14px!important;
  border-radius:999px!important;
  background:#0f172a!important;
  color:#fff!important;
  text-decoration:none!important;
  font-size:13px!important;
  font-weight:950!important;
}

.nt-v442-button.is-orange{background:linear-gradient(135deg,#fb923c,#ef4444)!important;}
.nt-v442-button.is-blue{background:linear-gradient(135deg,#2563eb,#0ea5e9)!important;}
.nt-v442-button.is-purple{background:linear-gradient(135deg,#7c3aed,#2563eb)!important;}

.nt-v442-secondary,
.nt-v442-rules{
  margin-top:12px!important;
  padding:18px!important;
  border-radius:26px!important;
}

.nt-v442-secondary{
  display:grid!important;
  grid-template-columns:1fr 150px!important;
  gap:14px!important;
  align-items:center!important;
}

.nt-v442-secondary h2,
.nt-v442-rules h2{
  margin:10px 0 7px!important;
  color:#0f172a!important;
  font-size:26px!important;
  line-height:1.03!important;
  letter-spacing:-.04em!important;
  font-weight:950!important;
}

.nt-v442-secondary p{
  margin:0!important;
  color:#64748b!important;
  font-size:13.5px!important;
  line-height:1.38!important;
  font-weight:750!important;
}

.nt-v442-secondary-price{
  padding:14px!important;
  border-radius:20px!important;
  background:#f8fafc!important;
  border:1px solid #e2e8f0!important;
}

.nt-v442-secondary-price strong{
  display:block!important;
  margin-top:7px!important;
  color:#0f172a!important;
  font-size:30px!important;
  line-height:.9!important;
  font-weight:950!important;
  letter-spacing:-.05em!important;
}

.nt-v442-secondary-price em{
  display:block!important;
  margin-top:5px!important;
  color:#64748b!important;
  font-style:normal!important;
  font-size:12px!important;
  font-weight:850!important;
}

.nt-v442-rules-grid{
  display:grid!important;
  grid-template-columns:repeat(3,minmax(0,1fr))!important;
  gap:9px!important;
}

.nt-v442-rules article{
  padding:13px!important;
  border-radius:20px!important;
  background:#f8fafc!important;
  border:1px solid #e2e8f0!important;
}

.nt-v442-rules strong{
  display:block!important;
  color:#0f172a!important;
  font-size:13px!important;
  font-weight:950!important;
}

.nt-v442-rules p{
  margin:6px 0 0!important;
  color:#64748b!important;
  font-size:12.5px!important;
  line-height:1.32!important;
  font-weight:750!important;
}

/* Masque les anciens blocs V4.39/V4.40/V4.41 */
.nt-v439-summary,
.nt-v440-price-strip,
.nt-v439-plans,
.nt-v439-total,
.nt-v439-faq,
.nt-v441-trust,
.nt-v441-grid,
.nt-v441-secondary,
.nt-v441-rules{
  display:none!important;
}

@media(max-width:860px){
  .nt-v442-grid,
  .nt-v442-rules-grid{
    grid-template-columns:1fr!important;
  }
}

@media(max-width:560px){
  .nt-v442-solutions{
    padding:12px 12px 100px!important;
  }
  .nt-v442-header,
  .nt-v442-card,
  .nt-v442-secondary,
  .nt-v442-rules{
    border-radius:23px!important;
  }
  .nt-v442-header{
    padding:16px!important;
  }
  .nt-v442-header h1{
    font-size:35px!important;
  }
  .nt-v442-card{
    padding:16px!important;
  }
  .nt-v442-card-head h2{
    font-size:27px!important;
  }
  .nt-v442-price strong{
    font-size:34px!important;
  }
  .nt-v442-secondary{
    grid-template-columns:1fr!important;
  }
}

/* NOVTINIS V4.43 — demandes visibilité + padding cartes */
.nt-v442-card,
.nt-v442-card.is-free,
.nt-v442-card.is-featured,
.nt-v442-card.is-ad,
.nt-v442-card.is-selection {
  padding: 20px !important;
}

.nt-v442-button.nt-v443-request-trigger {
  border: 0 !important;
  cursor: pointer !important;
  width: 100% !important;
  font-family: inherit !important;
}

.nt-v443-modal[aria-hidden="true"] {
  display: none !important;
}

.nt-v443-modal[aria-hidden="false"] {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999999 !important;
  display: flex !important;
  align-items: flex-end !important;
  justify-content: center !important;
}

.nt-v443-modal__backdrop {
  position: absolute !important;
  inset: 0 !important;
  background: rgba(15,23,42,.48) !important;
}

.nt-v443-modal__panel {
  position: relative !important;
  z-index: 1 !important;
  width: min(560px, calc(100% - 24px)) !important;
  max-height: calc(100vh - 40px) !important;
  overflow: auto !important;
  margin: 0 12px 12px !important;
  padding: 18px !important;
  border-radius: 28px !important;
  background: #ffffff !important;
  border: 1px solid #e2e8f0 !important;
  box-shadow: 0 24px 70px rgba(15,23,42,.26) !important;
}

.nt-v443-modal__close {
  position: absolute !important;
  right: 14px !important;
  top: 14px !important;
  width: 36px !important;
  height: 36px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #f1f5f9 !important;
  color: #0f172a !important;
  font-size: 24px !important;
  font-weight: 900 !important;
  cursor: pointer !important;
}

.nt-v443-modal__panel h2 {
  margin: 12px 44px 8px 0 !important;
  color: #0f172a !important;
  font-size: 30px !important;
  line-height: 1 !important;
  letter-spacing: -.04em !important;
  font-weight: 950 !important;
}

.nt-v443-modal__panel p {
  margin: 0 0 14px !important;
  color: #64748b !important;
  font-size: 13.5px !important;
  line-height: 1.4 !important;
  font-weight: 750 !important;
}

.nt-v443-modal__panel label {
  display: block !important;
  margin-bottom: 7px !important;
  color: #0f172a !important;
  font-size: 13px !important;
  font-weight: 950 !important;
}

.nt-v443-modal__panel textarea {
  width: 100% !important;
  min-height: 100px !important;
  padding: 12px !important;
  border-radius: 18px !important;
  border: 1px solid #e2e8f0 !important;
  background: #f8fafc !important;
  color: #0f172a !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  resize: vertical !important;
}

.nt-v443-modal__notice {
  display: grid !important;
  gap: 4px !important;
  margin-top: 12px !important;
  padding: 12px !important;
  border-radius: 18px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  color: #64748b !important;
  font-size: 12.5px !important;
  line-height: 1.32 !important;
  font-weight: 800 !important;
}

.nt-v443-modal__notice strong {
  color: #0f172a !important;
  font-weight: 950 !important;
}

.nt-v443-submit {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 44px !important;
  margin-top: 14px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #0f172a !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 950 !important;
  cursor: pointer !important;
}

.nt-v443-status {
  min-height: 20px !important;
  margin-top: 10px !important;
  color: #2563eb !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.nt-v443-modal-open {
  overflow: hidden !important;
}

@media (max-width: 560px) {
  .nt-v442-card,
  .nt-v442-card.is-free,
  .nt-v442-card.is-featured,
  .nt-v442-card.is-ad,
  .nt-v442-card.is-selection {
    padding: 20px !important;
  }

  .nt-v443-modal__panel {
    border-radius: 26px 26px 20px 20px !important;
    padding: 18px !important;
  }
}

/* NOVTINIS V4.44 — corrections Pack Pro + règles simples */
.nt-v442-card,
.nt-v442-card.is-free,
.nt-v442-card.is-featured,
.nt-v442-card.is-ad,
.nt-v442-card.is-selection {
  padding: 20px !important;
}

.nt-v442-rules-grid article,
.nt-v442-rules .nt-v442-rules-grid article {
  padding: 10px !important;
}

/* NOVTINIS V4.45 — Pack Pro sans prix + tarifs admin */
.nt-v445-pack-included {
  display: grid !important;
  gap: 5px !important;
  margin-top: 14px !important;
  padding: 14px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.86) !important;
  border: 1px solid #bbf7d0 !important;
}

.nt-v445-pack-included strong {
  color: #166534 !important;
  font-size: 24px !important;
  line-height: 1 !important;
  letter-spacing: -.03em !important;
  font-weight: 950 !important;
}

.nt-v445-pack-included span {
  color: #64748b !important;
  font-size: 13px !important;
  line-height: 1.3 !important;
  font-weight: 850 !important;
}

/* NOVTINIS V4.50 — tarifs visibilité 7 jours / 30 jours */
.nt-v450-price-options {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 8px !important;
  margin-top: 14px !important;
}

.nt-v450-price-options > div {
  padding: 13px !important;
  border-radius: 20px !important;
  background: rgba(255,255,255,.88) !important;
  border: 1px solid #e2e8f0 !important;
}

.nt-v450-price-options span {
  display: block !important;
  color: #64748b !important;
  font-size: 11px !important;
  font-weight: 950 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.nt-v450-price-options strong {
  display: block !important;
  margin-top: 6px !important;
  color: #0f172a !important;
  font-size: 26px !important;
  line-height: 1 !important;
  letter-spacing: -.05em !important;
  font-weight: 950 !important;
}

@media (max-width: 380px) {
  .nt-v450-price-options {
    grid-template-columns: 1fr !important;
  }
}

/* NOVTINIS V4.52E2H56 — choix durée demande visibilité */
.nt-v443-duration-field {
  display: grid !important;
  gap: 8px !important;
  margin: 12px 0 !important;
}
.nt-v443-duration-field[hidden] {
  display: none !important;
}
.nt-v443-duration-field label {
  font-weight: 900 !important;
  color: #0f172a !important;
}
.nt-v443-duration-field select {
  width: 100% !important;
  border-radius: 16px !important;
  border: 1px solid #e2e8f0 !important;
  background: #fff !important;
  padding: 12px 14px !important;
  font-weight: 900 !important;
}

/* NOVTINIS V4.52E2H56E — Navigation page Compte & visibilité */
.nt-v456e-account-visibility .nt-v456e-header {
  display: grid !important;
  gap: 12px !important;
}

.nt-v456e-account-visibility .nt-v456e-back {
  justify-self: start !important;
  width: auto !important;
  margin: 0 0 2px !important;
  min-height: 36px !important;
  padding: 0 13px !important;
  background: #0f172a !important;
  font-size: 12px !important;
}

.nt-v456e-quick-nav {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 2px !important;
}

.nt-v456e-quick-nav a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 36px !important;
  padding: 0 13px !important;
  border-radius: 999px !important;
  background: #f8fafc !important;
  border: 1px solid #e2e8f0 !important;
  color: #0f172a !important;
  text-decoration: none !important;
  font-size: 12.5px !important;
  font-weight: 950 !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro:before { background: #7c3aed !important; }
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro {
  background: linear-gradient(135deg,#faf5ff,#fff 58%) !important;
  border-color: #e9d5ff !important;
}
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v442-list li:before {
  background: #f3e8ff !important;
  color: #7e22ce !important;
}

.nt-v456e-account-visibility .nt-v442-rules-grid {
  grid-template-columns: repeat(4,minmax(0,1fr)) !important;
}

.nt-v456e-bottom-nav {
  position: fixed !important;
  left: 50% !important;
  bottom: 12px !important;
  z-index: 50 !important;
  transform: translateX(-50%) !important;
  display: none !important;
  width: min(420px, calc(100% - 24px)) !important;
  padding: 7px !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.96) !important;
  border: 1px solid #e2e8f0 !important;
  box-shadow: 0 14px 36px rgba(15,23,42,.18) !important;
}

.nt-v456e-bottom-nav a {
  flex: 1 1 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 40px !important;
  border-radius: 18px !important;
  color: #334155 !important;
  text-decoration: none !important;
  font-size: 11.5px !important;
  font-weight: 950 !important;
}

.nt-v456e-bottom-nav a:nth-child(3) {
  background: #0f172a !important;
  color: #fff !important;
}

@media (max-width: 860px) {
  .nt-v456e-account-visibility .nt-v442-rules-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 560px) {
  .nt-v456e-account-visibility {
    padding-bottom: 125px !important;
  }
  .nt-v456e-quick-nav {
    display: grid !important;
    grid-template-columns: repeat(2,minmax(0,1fr)) !important;
  }
  .nt-v456e-account-visibility .nt-v456e-back {
    width: 100% !important;
  }
  .nt-v456e-bottom-nav {
    display: flex !important;
  }
}


/* H65 — Carte création menu */
.nt-v442-card.is-menu-creation {
  border-color: rgba(255, 90, 31, .22);
  background: linear-gradient(180deg, #fff, #fff8f4);
}

.nt-h65-menu-prices {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nt-h65-menu-prices small {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  color: #64748b;
  font-weight: 800;
}

@media (max-width: 720px) {
  .nt-h65-menu-prices {
    grid-template-columns: 1fr;
  }
}


/* H69 — offres harmonisées */
.nt-h69-3prices,
.nt-h69-fiche-prices{
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.nt-h69-fiche-prices small{
  display:block;
  margin-top:4px;
  font-size:11px;
  color:#64748b;
  font-weight:850;
  line-height:1.25;
}

@media(max-width:720px){
  .nt-h69-3prices,
  .nt-h69-fiche-prices{
    grid-template-columns:1fr;
  }
}


/* H69D — prix 3 colonnes + euros lisibles */
.nt-v456e-account-visibility .nt-v450-price-options,
.nt-subscription-page .nt-v450-price-options,
.nt-v442-solutions .nt-v450-price-options {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 7px !important;
}

.nt-v456e-account-visibility .nt-v450-price-options > div,
.nt-subscription-page .nt-v450-price-options > div,
.nt-v442-solutions .nt-v450-price-options > div {
  min-width: 0 !important;
  padding: 10px !important;
  border-radius: 16px !important;
}

.nt-v456e-account-visibility .nt-v450-price-options span,
.nt-subscription-page .nt-v450-price-options span,
.nt-v442-solutions .nt-v450-price-options span {
  font-size: 10px !important;
  letter-spacing: .07em !important;
  line-height: 1.15 !important;
}

.nt-v456e-account-visibility .nt-v450-price-options strong,
.nt-subscription-page .nt-v450-price-options strong,
.nt-v442-solutions .nt-v450-price-options strong {
  margin-top: 5px !important;
  font-size: 20px !important;
  line-height: .98 !important;
  letter-spacing: -.04em !important;
  word-break: break-word !important;
}

.nt-v456e-account-visibility .nt-v450-price-options small,
.nt-subscription-page .nt-v450-price-options small,
.nt-v442-solutions .nt-v450-price-options small {
  display: block !important;
  margin-top: 4px !important;
  font-size: 9.5px !important;
  line-height: 1.15 !important;
  font-weight: 850 !important;
}

@media (max-width: 380px) {
  .nt-v456e-account-visibility .nt-v450-price-options,
  .nt-subscription-page .nt-v450-price-options,
  .nt-v442-solutions .nt-v450-price-options {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

@media (max-width: 430px) {
  .nt-v456e-account-visibility .nt-v450-price-options,
  .nt-subscription-page .nt-v450-price-options,
  .nt-v442-solutions .nt-v450-price-options {
    gap: 6px !important;
  }

  .nt-v456e-account-visibility .nt-v450-price-options > div,
  .nt-subscription-page .nt-v450-price-options > div,
  .nt-v442-solutions .nt-v450-price-options > div {
    padding: 9px 7px !important;
    border-radius: 14px !important;
  }

  .nt-v456e-account-visibility .nt-v450-price-options span,
  .nt-subscription-page .nt-v450-price-options span,
  .nt-v442-solutions .nt-v450-price-options span {
    font-size: 9px !important;
  }

  .nt-v456e-account-visibility .nt-v450-price-options strong,
  .nt-subscription-page .nt-v450-price-options strong,
  .nt-v442-solutions .nt-v450-price-options strong {
    font-size: 18px !important;
  }
}


/* H69E — sélection directe 24h / 7 jours / 30 jours */
.nt-v443-request-trigger[data-duration-options] ~ * {
  /* noop : garde la compatibilité CSS */
}

.nt-v442-card .nt-v450-price-options > div[role="button"]{
  cursor:pointer !important;
  transition:transform .16s ease, box-shadow .16s ease, border-color .16s ease, background .16s ease !important;
}

.nt-v442-card .nt-v450-price-options > div[role="button"]:hover{
  transform:translateY(-1px) !important;
  border-color:rgba(37,99,235,.35) !important;
  box-shadow:0 10px 24px rgba(15,23,42,.08) !important;
}

.nt-v442-card .nt-v450-price-options > div.is-selected-duration{
  border-color:rgba(37,99,235,.70) !important;
  background:linear-gradient(180deg,#eff6ff,#fff) !important;
  box-shadow:0 0 0 2px rgba(37,99,235,.10), 0 12px 26px rgba(37,99,235,.12) !important;
}

.nt-v442-card .nt-v450-price-options > div.is-selected-duration::after{
  content:"Sélectionné";
  display:inline-flex;
  margin-top:7px;
  border-radius:999px;
  padding:4px 7px;
  background:#dbeafe;
  color:#1d4ed8;
  font-size:9.5px;
  font-weight:950;
  letter-spacing:0;
  text-transform:none;
}

.nt-v442-card.is-featured .nt-v450-price-options > div.is-selected-duration{
  border-color:rgba(249,115,22,.62) !important;
  background:linear-gradient(180deg,#fff7ed,#fff) !important;
  box-shadow:0 0 0 2px rgba(249,115,22,.10), 0 12px 26px rgba(249,115,22,.12) !important;
}

.nt-v442-card.is-featured .nt-v450-price-options > div.is-selected-duration::after{
  background:#ffedd5;
  color:#c2410c;
}

@media(max-width:430px){
  .nt-v442-card .nt-v450-price-options > div.is-selected-duration::after{
    font-size:8.5px;
    padding:3px 5px;
  }
}


/* H69F — sélection durée robuste + padding cartes */
.nt-v456e-account-visibility .nt-v442-card{
  overflow: hidden !important;
}

.nt-v456e-account-visibility .nt-v442-card h2,
.nt-v456e-account-visibility .nt-v442-card .nt-v442-desc{
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation{
  padding-left: 18px !important;
  padding-right: 18px !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v442-card-head,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v442-card-head{
  margin-left: 0 !important;
  margin-right: 0 !important;
}

.nt-v456e-account-visibility .nt-v450-price-options > div[role="button"]{
  cursor: pointer !important;
  user-select: none !important;
}

.nt-v456e-account-visibility .nt-v450-price-options > div.is-selected-duration{
  position: relative !important;
  border-color: rgba(37,99,235,.75) !important;
  background: linear-gradient(180deg,#eff6ff,#ffffff) !important;
  box-shadow: 0 0 0 2px rgba(37,99,235,.10), 0 10px 24px rgba(37,99,235,.10) !important;
}

.nt-v456e-account-visibility .nt-v450-price-options > div.is-selected-duration::after{
  content: "✓";
  position: absolute;
  right: 7px;
  top: 7px;
  width: 18px;
  height: 18px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: #2563eb;
  color: #fff;
  font-size: 11px;
  font-weight: 950;
}

.nt-v456e-account-visibility .nt-v442-card.is-featured .nt-v450-price-options > div.is-selected-duration{
  border-color: rgba(249,115,22,.75) !important;
  background: linear-gradient(180deg,#fff7ed,#ffffff) !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-featured .nt-v450-price-options > div.is-selected-duration::after{
  background: #f97316;
}

@media(max-width:560px){
  .nt-v456e-account-visibility .nt-v442-card{
    padding-left: 18px !important;
    padding-right: 18px !important;
  }

  .nt-v456e-account-visibility .nt-v442-card h2{
    line-height: 1.08 !important;
  }

  .nt-v456e-account-visibility .nt-v442-card .nt-v442-desc{
    line-height: 1.38 !important;
  }
}


/* H69G — Fiche Pro et Création menu : cartes prix cliquables */
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v450-price-options > div,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div{
  cursor:pointer !important;
  user-select:none !important;
  transition:transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v450-price-options > div:hover,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div:hover{
  transform:translateY(-1px) !important;
  box-shadow:0 10px 24px rgba(15,23,42,.08) !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v450-price-options > div.is-selected-plan,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div.is-selected-plan{
  position:relative !important;
  border-color:rgba(124,58,237,.75) !important;
  background:linear-gradient(180deg,#f5f3ff,#fff) !important;
  box-shadow:0 0 0 2px rgba(124,58,237,.10), 0 12px 26px rgba(124,58,237,.12) !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div.is-selected-plan{
  border-color:rgba(34,197,94,.70) !important;
  background:linear-gradient(180deg,#f0fdf4,#fff) !important;
  box-shadow:0 0 0 2px rgba(34,197,94,.10), 0 12px 26px rgba(34,197,94,.12) !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v450-price-options > div.is-selected-plan::after,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div.is-selected-plan::after{
  content:"✓";
  position:absolute;
  right:7px;
  top:7px;
  width:18px;
  height:18px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background:#7c3aed;
  color:#fff;
  font-size:11px;
  font-weight:950;
}

.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div.is-selected-plan::after{
  background:#16a34a;
}

/* padding gauche/droite renforcé titre + paragraphe */
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro > .nt-v442-card-head,
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro > h2,
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro > .nt-v442-desc,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation > .nt-v442-card-head,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation > h2,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation > .nt-v442-desc{
  padding-left:0 !important;
  padding-right:0 !important;
}

.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro,
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation{
  padding-left:20px !important;
  padding-right:20px !important;
}


/* H69H — coche centrée dans les cartes sélectionnées */
.nt-v456e-account-visibility .nt-v450-price-options > div.is-selected-duration::after,
.nt-v456e-account-visibility .nt-v450-price-options > div.is-selected-plan::after,
.nt-v442-card .nt-v450-price-options > div.is-selected-duration::after,
.nt-v442-card .nt-v450-price-options > div.is-selected-plan::after{
  box-sizing: border-box !important;
  width: 20px !important;
  height: 20px !important;
  min-width: 20px !important;
  min-height: 20px !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  place-items: center !important;
  line-height: 1 !important;
  font-size: 12px !important;
  font-family: Arial, sans-serif !important;
  font-weight: 950 !important;
  text-align: center !important;
  border-radius: 999px !important;
  top: 8px !important;
  right: 8px !important;
  transform: none !important;
}

/* Orange : on met une coche blanche dans un rond orange plus contrasté */
.nt-v456e-account-visibility .nt-v442-card.is-featured .nt-v450-price-options > div.is-selected-duration::after,
.nt-v442-card.is-featured .nt-v450-price-options > div.is-selected-duration::after{
  background: #f97316 !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 4px 10px rgba(249,115,22,.22) !important;
}

/* Bleu publicité */
.nt-v456e-account-visibility .nt-v442-card.is-ad .nt-v450-price-options > div.is-selected-duration::after,
.nt-v442-card.is-ad .nt-v450-price-options > div.is-selected-duration::after{
  background: #2563eb !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 4px 10px rgba(37,99,235,.22) !important;
}

/* Violet Fiche Pro */
.nt-v456e-account-visibility .nt-v442-card.is-fiche-pro .nt-v450-price-options > div.is-selected-plan::after{
  background: #7c3aed !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 4px 10px rgba(124,58,237,.22) !important;
}

/* Vert Création menu / tarifs */
.nt-v456e-account-visibility .nt-v442-card.is-menu-creation .nt-v450-price-options > div.is-selected-plan::after{
  background: #16a34a !important;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,.92) !important;
  box-shadow: 0 4px 10px rgba(22,163,74,.22) !important;
}

@media(max-width:430px){
  .nt-v456e-account-visibility .nt-v450-price-options > div.is-selected-duration::after,
  .nt-v456e-account-visibility .nt-v450-price-options > div.is-selected-plan::after,
  .nt-v442-card .nt-v450-price-options > div.is-selected-duration::after,
  .nt-v442-card .nt-v450-price-options > div.is-selected-plan::after{
    width: 19px !important;
    height: 19px !important;
    min-width: 19px !important;
    min-height: 19px !important;
    font-size: 11px !important;
    top: 7px !important;
    right: 7px !important;
  }
}


/* H71 — Modèles de publicité locale */
.nt-h71-ad-model-field{
  display:grid;
  gap:10px;
  margin:12px 0;
  padding:14px;
  border:1px solid #dbeafe;
  border-radius:20px;
  background:linear-gradient(180deg,#eff6ff,#ffffff);
}

.nt-h71-ad-model-field[hidden]{display:none!important}

.nt-h71-ad-model-field label{
  color:#334155;
  font-size:12px;
  font-weight:900;
}

.nt-h71-ad-model-field input[type="text"],
.nt-h71-ad-model-field textarea,
.nt-h71-ad-model-field select{
  width:100%;
  border:1px solid #dbe3ef;
  border-radius:14px;
  padding:11px 12px;
  background:#fff;
  color:#0f172a;
  font-weight:800;
}

.nt-h71-ad-example{
  display:grid;
  gap:5px;
  border-radius:16px;
  padding:11px 12px;
  background:#fff;
  border:1px solid #e2e8f0;
}

.nt-h71-ad-example strong{
  color:#1d4ed8;
  font-size:13px;
  font-weight:950;
}

.nt-h71-ad-example span{
  color:#475569;
  font-size:12.5px;
  font-weight:800;
  line-height:1.3;
}

.nt-h71-check{
  display:flex!important;
  gap:9px;
  align-items:flex-start;
  padding:10px 12px;
  border-radius:14px;
  background:#f8fafc;
  border:1px solid #e2e8f0;
}

.nt-h71-check input{
  margin-top:2px;
}

.nt-h71-check span{
  color:#334155;
  font-size:13px;
  font-weight:850;
  line-height:1.3;
}


/* H71B — modèles pub visibles dans modal */
.nt-v443-modal__panel{
  max-height: calc(100vh - 36px) !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}
.nt-h71-ad-model-field:not([hidden]){
  display: grid !important;
}
.nt-h71-ad-model-field{
  margin-top: 12px !important;
  margin-bottom: 12px !important;
}


/* H73 — aperçu publicité avant envoi + photo obligatoire */
.nt-h73-photo-help{
  margin: -4px 0 2px;
  color:#64748b;
  font-size:12px;
  line-height:1.35;
  font-weight:750;
}

.nt-h73-photo-preview-wrap{
  display:grid;
  gap:10px;
}

.nt-h71-ad-model-field input[type="file"]{
  width:100%;
  border:1px dashed #93c5fd;
  border-radius:14px;
  padding:11px;
  background:#fff;
  color:#0f172a;
  font-weight:850;
}

.nt-h73-ad-preview{
  display:grid;
  gap:10px;
  padding:12px;
  border-radius:18px;
  background:linear-gradient(135deg,#eff6ff,#fff);
  border:1px solid #bfdbfe;
}

.nt-h73-ad-preview-kicker{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.nt-h73-ad-preview-kicker span{
  display:inline-flex;
  min-height:23px;
  align-items:center;
  border-radius:999px;
  padding:0 9px;
  background:#dbeafe;
  color:#1d4ed8;
  font-size:10.5px;
  font-weight:950;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.nt-h73-ad-preview-kicker em{
  color:#64748b;
  font-size:12px;
  font-style:normal;
  font-weight:850;
}

.nt-h73-ad-preview-body{
  display:grid;
  grid-template-columns:86px minmax(0,1fr);
  gap:11px;
  align-items:stretch;
}

.nt-h73-ad-preview-media{
  min-height:92px;
  border-radius:16px;
  overflow:hidden;
  background:linear-gradient(135deg,#2563eb,#7c3aed);
  display:grid;
  place-items:center;
}

.nt-h73-ad-preview-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.nt-h73-ad-preview-media strong{
  color:#fff;
  font-size:30px;
  font-weight:950;
}

.nt-h73-ad-preview-content{
  min-width:0;
  display:grid;
  gap:6px;
  align-content:center;
}

.nt-h73-ad-preview-content strong{
  color:#0f172a;
  font-size:17px;
  line-height:1.12;
  font-weight:950;
}

.nt-h73-ad-preview-content p{
  margin:0;
  color:#475569;
  font-size:13px;
  line-height:1.32;
  font-weight:750;
}

.nt-h73-ad-preview-content b{
  display:inline-flex;
  width:fit-content;
  border-radius:999px;
  padding:8px 11px;
  background:#2563eb;
  color:#fff;
  font-size:12px;
  font-weight:950;
}

@media(max-width:430px){
  .nt-h73-ad-preview-body{
    grid-template-columns:78px minmax(0,1fr);
    gap:9px;
  }
  .nt-h73-ad-preview-media{min-height:82px}
  .nt-h73-ad-preview-content strong{font-size:15px}
}


/* H73B — aperçu pub bien visible avant les champs */
.nt-h73-visible-preview-title{
  margin-top: 4px;
  color:#0f172a;
  font-size:14px;
  font-weight:950;
}

.nt-h73-ad-preview{
  order: 2;
}

.nt-h73-photo-preview-wrap{
  display:grid;
  gap:10px;
}

.nt-h71-ad-model-field #ntH73AdPreview{
  margin-bottom: 2px !important;
}

.nt-h71-ad-model-field #ntH73AdPhoto{
  margin-bottom: 0 !important;
}

.nt-h73-ad-preview-media strong{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
}


/* H73C — aperçu pub final visible + select centré verticalement */
.nt-h73c-preview-block{
  display:grid !important;
  gap:10px !important;
  margin:12px 0 14px !important;
}

.nt-h73c-preview-title{
  color:#0f172a !important;
  font-size:14px !important;
  font-weight:950 !important;
}

.nt-h73c-ad-preview{
  display:grid !important;
  gap:10px !important;
  padding:12px !important;
  border-radius:18px !important;
  background:linear-gradient(135deg,#eff6ff,#ffffff) !important;
  border:1px solid #bfdbfe !important;
}

.nt-h73c-ad-kicker{
  display:flex !important;
  align-items:center !important;
  gap:8px !important;
  flex-wrap:wrap !important;
}

.nt-h73c-ad-kicker span{
  display:inline-flex !important;
  align-items:center !important;
  min-height:23px !important;
  border-radius:999px !important;
  padding:0 9px !important;
  background:#dbeafe !important;
  color:#1d4ed8 !important;
  font-size:10.5px !important;
  font-weight:950 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
}

.nt-h73c-ad-kicker em{
  color:#64748b !important;
  font-size:12px !important;
  font-style:normal !important;
  font-weight:850 !important;
}

.nt-h73c-ad-body{
  display:grid !important;
  grid-template-columns:86px minmax(0,1fr) !important;
  gap:11px !important;
  align-items:stretch !important;
}

.nt-h73c-ad-media{
  min-height:92px !important;
  border-radius:16px !important;
  overflow:hidden !important;
  background:linear-gradient(135deg,#2563eb,#7c3aed) !important;
  display:grid !important;
  place-items:center !important;
  color:#fff !important;
}

.nt-h73c-ad-media strong{
  display:grid !important;
  place-items:center !important;
  width:40px !important;
  height:40px !important;
  border-radius:999px !important;
  background:rgba(255,255,255,.18) !important;
  color:#fff !important;
  font-size:26px !important;
  font-weight:950 !important;
}

.nt-h73c-ad-media small{
  display:block !important;
  margin-top:-20px !important;
  color:rgba(255,255,255,.85) !important;
  font-size:11px !important;
  font-weight:900 !important;
}

.nt-h73c-ad-media img{
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block !important;
}

.nt-h73c-ad-content{
  min-width:0 !important;
  display:grid !important;
  gap:6px !important;
  align-content:center !important;
}

.nt-h73c-ad-content strong{
  color:#0f172a !important;
  font-size:16px !important;
  line-height:1.12 !important;
  font-weight:950 !important;
}

.nt-h73c-ad-content p{
  margin:0 !important;
  color:#475569 !important;
  font-size:13px !important;
  line-height:1.32 !important;
  font-weight:750 !important;
}

.nt-h73c-ad-content b{
  display:inline-flex !important;
  width:fit-content !important;
  border-radius:999px !important;
  padding:8px 11px !important;
  background:#2563eb !important;
  color:#fff !important;
  font-size:12px !important;
  font-weight:950 !important;
}

.nt-h73c-photo-label{
  margin-top:2px !important;
  color:#0f172a !important;
  font-size:14px !important;
  font-weight:950 !important;
}

.nt-h73c-photo-label small{
  color:#ef4444 !important;
  font-size:11px !important;
  font-weight:950 !important;
}

#ntH73cAdPhoto{
  width:100% !important;
  border:1px dashed #93c5fd !important;
  border-radius:14px !important;
  padding:11px !important;
  background:#fff !important;
  color:#0f172a !important;
  font-weight:850 !important;
}

.nt-h73c-photo-help{
  margin:-4px 0 2px !important;
  color:#64748b !important;
  font-size:12px !important;
  line-height:1.35 !important;
  font-weight:750 !important;
}

/* Correction centrage vertical des listes déroulantes du modal */
.nt-v443-modal select,
.nt-h71-ad-model-field select,
#ntV443RequestDuration,
#ntH71AdModel,
#ntH71AdCta,
#ntH65MenuPlan{
  height:48px !important;
  min-height:48px !important;
  line-height:48px !important;
  padding-top:0 !important;
  padding-bottom:0 !important;
  display:block !important;
  font-size:15px !important;
  font-weight:900 !important;
  background-position:right 14px center !important;
}

/* Mobile */
@media(max-width:430px){
  .nt-h73c-ad-body{
    grid-template-columns:78px minmax(0,1fr) !important;
    gap:9px !important;
  }

  .nt-h73c-ad-media{
    min-height:82px !important;
  }

  .nt-h73c-ad-content strong{
    font-size:15px !important;
  }
}


/* H73D — select non coupé + aperçu/photo direct */
.nt-v443-modal select,
.nt-h71-ad-model-field select,
#ntV443RequestDuration,
#ntH71AdModel,
#ntH71AdCta,
#ntH65MenuPlan{
  box-sizing:border-box!important;
  height:54px!important;
  min-height:54px!important;
  line-height:normal!important;
  padding-top:0!important;
  padding-bottom:0!important;
  padding-left:16px!important;
  padding-right:44px!important;
  font-size:16px!important;
  font-weight:850!important;
  white-space:nowrap!important;
  overflow:visible!important;
  text-overflow:clip!important;
}
