/* Masque les composants Alpine avant initialisation (évite le FOUC) */
[x-cloak] { display: none !important; }

/* ── CE Appearance spacing (Backoffice > Appearance tab) ── */
.frame-space-before-extra  { margin-top: 5rem; }
.frame-space-before-medium { margin-top: 2.5rem; }
.frame-space-before-small  { margin-top: 1.25rem; }
.frame-space-before-none   { margin-top: 0; }
.frame-space-after-extra   { margin-bottom: 5rem; }
.frame-space-after-medium  { margin-bottom: 2.5rem; }
.frame-space-after-small   { margin-bottom: 1.25rem; }
.frame-space-after-none    { margin-bottom: 0; }

/**
 * Layout portail MyCapricorne
 * Source: POC ressource_externes/assemblage/vue-ensemble-assemblee/layout.css
 * Structure: upper-menu + main-menu + breadcrumbs + page-shell(sidebar+main) + footer
 */

:root {
  --content-max-width: 1920px;
}

/* ================================================================
   WRAPS — contenu centré à max-width
   ================================================================ */

.page-shell > .page-content {
  max-width: var(--content-max-width); /* 1920px */
  margin-inline: auto;
}

/* ================================================================
   FRAME WRAPPER — suppression pour les plugins loyaltyportal
   display:contents rend le div transparent au flex de .main-col :
   ses enfants participent directement au gap de la colonne.
   ================================================================ */

.main-col > [class*="frame-type-airlinessystemloyaltyportal"] {
    display: contents;
}

/* ================================================================
   PAGE CONTENT — sidebar + main column
   ================================================================ */

.page-content {
  display: flex;
  flex-direction: column;
  gap: 1.875rem;          /* 30px */
  width: 100%;
  padding-top: 0;
  padding-bottom: 3.75rem;
  padding-inline: 1.25rem;   /* container-x = 20px */
}

@media (min-width: 428px) {  /* mobile */
  .page-content { padding-inline: 1.5rem; }
}

@media (min-width: 768px) {  /* md */
  .page-content {
    flex-direction: row;
    align-items: flex-start;
    padding-inline: 2rem;
  }
}

@media (min-width: 1024px) {  /* lg */
  .page-content { padding-inline: 4rem; }
}

@media (min-width: 1440px) {  /* xl */
  .page-content { padding-inline: 9rem; }
}

/* Sidebar */
.sidebar-col {
  width: 100%;
}

@media (min-width: 768px) {
  .sidebar-col {
    width: 20rem;
    flex-shrink: 0;
  }
}

.sidebar-col [x-data="sideMenu"] > div:last-child {
  gap: 1.5625rem;
  padding-top: 1.875rem;
}

.sidebar-col [x-data="sideMenu"] > div:last-child > button {
  padding-top: 0.9rem;
  padding-bottom: 0.9rem;
  min-height: 3.5rem;
}

.sidebar-col [x-data="sideMenu"] > div:last-child > button > span[aria-hidden="true"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sidebar-col [x-data="sideMenu"] > div:last-child > button > span[aria-hidden="true"] svg {
  width: 1rem;
  height: 1rem;
}

/* Main column */
.main-col {
  flex: 1 1 0%;
  min-width: 0;
  min-height: 18rem;
  display: flex;
  flex-direction: column;
  gap: 1.875rem;             /* 30px mobile */
  padding: 2.5rem 0;
}

@media (min-width: 768px) {
  .main-col {
    gap: 3.75rem;            /* 60px — md:gap-15 */
    padding: 2.5rem 2.75rem; /* py-10 + md:px-11 */
  }
}

.main-header {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;              /* gap-3 — Figma */
}

.content-block {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* Hero zone — 2 colonnes (points/download à gauche, tier-status à droite) */
.hero-zone {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  justify-content: center;
}

@media (min-width: 1440px) {
  /* xl+ : deux colonnes (gauche : points/download, droite : carte)
     flex-wrap: graceful stack when sidebar+padding leave < 22rem for hero-left */
  .hero-zone {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 1.875rem;
  }
}

.hero-left,
.hero-right { min-width: 0; }

.hero-left {
  flex: 1 1 22rem;
  min-width: min(100%, 20rem);
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

@media (min-width: 768px) {
  .hero-left { gap: 1.875rem; }
}

.hero-right {
  display: none;
}

@media (min-width: 768px) {
  /* md→xl : ligne 1, pleine largeur, centrée, avant le hero-left */
  .hero-right {
    display: flex;
    order: -1;
    width: 100%;
    justify-content: center;
    flex: none;
  }
}

@media (min-width: 1440px) {
  /* fhd+ : colonne droite à largeur fixe (side-by-side)
     Below fhd, hero-right keeps md behavior: centered, full-width, order -1 */
  .hero-right {
    order: 0;
    width: var(--width-card-loyalty-lg);
    justify-content: initial;
    flex: 0 0 auto;
  }
}

/* La carte tier-status gère ses propres dimensions via
   w-full max-w-card-loyalty-lg + aspect-card-loyalty. Ne pas forcer ici. */

/* ================================================================
   FELOGIN — styles temporaires pour le formulaire de connexion
   À supprimer quand le composant Fluid login sera intégré.
   ================================================================ */

.frame-type-felogin_login {
  max-width: 28rem;
  margin: 2rem auto;
  padding: 2rem;
  background: #fff;
  border-radius: 1rem;
  box-shadow: 0 4px 20px rgb(0 0 0 / 0.08);
}

.frame-type-felogin_login h3 {
  font-family: 'Poppins', sans-serif;
  font-size: 1.25rem;
  font-weight: 600;
  color: #192951;
  margin-bottom: 0.5rem;
}

.frame-type-felogin_login p {
  font-size: 0.875rem;
  color: #444;
  margin-bottom: 1.5rem;
}

.frame-type-felogin_login fieldset {
  border: none;
  padding: 0;
  margin: 0;
}

.frame-type-felogin_login legend {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.frame-type-felogin_login label {
  display: block;
  font-family: 'Roboto', sans-serif;
  font-size: 0.875rem;
  font-weight: 500;
  color: #192951;
  margin-bottom: 0.375rem;
}

.frame-type-felogin_login input[type="text"],
.frame-type-felogin_login input[type="password"] {
  display: block;
  width: 100%;
  padding: 0.625rem 0.75rem;
  font-family: 'Roboto', sans-serif;
  font-size: 1rem;
  color: #192951;
  background: #f8f8f8;
  border: 1px solid #d7d7d7;
  border-radius: 0.5rem;
  margin-bottom: 1rem;
  outline: none;
  transition: border-color 0.15s;
}

.frame-type-felogin_login input[type="text"]:focus,
.frame-type-felogin_login input[type="password"]:focus {
  border-color: #13D6FF;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px #13D6FF;
}

.frame-type-felogin_login input[type="submit"] {
  display: block;
  width: 100%;
  padding: 0.75rem 1.75rem;
  font-family: 'Poppins', sans-serif;
  font-size: 1rem;
  font-weight: 500;
  text-transform: uppercase;
  color: #fff;
  background: #192951;
  border: 2px solid transparent;
  border-radius: 2.5rem;
  cursor: pointer;
  transition: background-color 0.15s;
}

.frame-type-felogin_login input[type="submit"]:hover {
  background: #222;
}

.frame-type-felogin_login input[type="submit"]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px #fff, 0 0 0 4px #13D6FF;
}

.frame-type-felogin_login .felogin-hidden {
  display: none;
}

.frame-type-felogin_login + a,
.frame-type-felogin_login ~ a {
  display: block;
  text-align: center;
  margin-top: 1rem;
  font-size: 0.875rem;
  color: #297FCA;
}

.frame-type-felogin_login + a:hover,
.frame-type-felogin_login ~ a:hover {
  text-decoration: underline;
}

/* Conteneur parent guest prompt */
.content-block h2 {
  font-family: 'Poppins', sans-serif;
  font-weight: 500;
}

.content-block > div > p > a {
  color: #297FCA;
}

.content-block > div > p > a:hover {
  text-decoration: underline;
}

/* ── Titres dans le corps éditorial (h2, h3) ── */

.editorial-content .frame-type-text h2,
.editorial-content .frame-type-textmedia h2,
.editorial-content .frame-type-textpic h2,
.editorial-content .ce-bodytext h2 {
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-weight: 500;
    font-size: 1.5rem;
    color: var(--color-ink-primary, #192951);
    margin-top: 2rem;
    margin-bottom: 0.75rem;
    line-height: 1.3;
}

.editorial-content .frame-type-text h3,
.editorial-content .frame-type-textmedia h3,
.editorial-content .frame-type-textpic h3,
.editorial-content .ce-bodytext h3 {
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-weight: 500;
    font-size: 1.25rem;
    color: var(--color-ink-primary, #192951);
    margin-top: 1.5rem;
    margin-bottom: 0.5rem;
    line-height: 1.35;
}

/* ── Custom CEs dans éditorial : laisser Tailwind gérer couleurs/typo ── */
/* Tailwind v4 @layer a une priorité plus basse que le CSS non-layered,
   donc on doit explicitement reset les propriétés héritées. */

.editorial-content [class*="bg-primary"] h2,
.editorial-content [class*="bg-surface-dark"] h2 {
    color: var(--color-on-dark, white);
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-weight: 500;
    font-size: 1.875rem;
    line-height: 1.2;
    margin: 0;
}
@media (min-width: 768px) {
    .editorial-content [class*="bg-primary"] h2,
    .editorial-content [class*="bg-surface-dark"] h2 {
        font-size: 2.25rem;
    }
}
.editorial-content [class*="bg-primary"] h3,
.editorial-content [class*="bg-surface-dark"] h3 {
    color: var(--color-on-dark, white);
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-weight: 500;
    margin: 0;
}
.editorial-content [class*="bg-primary"] p,
.editorial-content [class*="bg-surface-dark"] p {
    color: var(--color-on-dark, white);
    margin: 0;
}
.editorial-content [class*="bg-primary"] a:not([x-data]),
.editorial-content [class*="bg-surface-dark"] a:not([x-data]) {
    color: var(--color-on-dark, white);
    text-decoration: inherit;
}

/* ── Liens dans le corps éditorial (texte RTE uniquement) ── */

.editorial-content .ce-bodytext a,
.editorial-content .ce-text a,
.editorial-content .frame-type-text p a,
.editorial-content .frame-type-textmedia p a,
.editorial-content .frame-type-textpic p a,
.editorial-content .frame-type-text li a,
.editorial-content .frame-type-textmedia li a,
.editorial-content .frame-type-textpic li a {
    text-decoration: underline;
    color: var(--color-ink-primary, #192951);
}

/* ── Espacement des listes ── */

.editorial-content .frame-type-text li,
.editorial-content .frame-type-textmedia li,
.editorial-content .frame-type-textpic li,
.editorial-content .ce-bodytext li {
    margin-bottom: 0.5rem;
    line-height: 1.6;
}

.editorial-content .frame-type-text li:last-child,
.editorial-content .frame-type-textmedia li:last-child,
.editorial-content .frame-type-textpic li:last-child,
.editorial-content .ce-bodytext li:last-child {
    margin-bottom: 0;
}

/* ── Image hero : premier CE image dans le corps éditorial ── */

.editorial-content .ce-image,
.editorial-content .ce-image figure,
.editorial-content .ce-image .ce-gallery,
.editorial-content .ce-image .ce-gallery-container,
.editorial-content .ce-image .ce-gallery-row,
.editorial-content .ce-image .ce-gallery-item,
.editorial-content .ce-image .ce-align-above {
    text-align: left;
    margin-left: 0;
    margin-right: 0;
}

.editorial-content .ce-image:first-child {
    margin-bottom: 2.5rem;
}

.editorial-content .ce-image:first-child img,
.editorial-content .csc-textpic:first-child img,
.editorial-content .ce-textpic:first-child img {
    border-radius: 16px;
    width: 100%;
    height: auto;
    display: block;
}

/* ── Checkbox toggle (circle filled on checked) ── */

input.peer + span[data-toggle-dot] {
    background-color: var(--color-surface, white);
}

input.peer:checked + span[data-toggle-dot] {
    background-color: var(--color-primary, #192951);
}

input.peer:checked + span[data-toggle-dot] > span[data-toggle-check] {
    display: block;
}

/* ── Badge numéro de téléphone (Nous contacter) ── */

.editorial-content .phone-badge-img {
    max-width: 300px;
    height: auto;
    display: block;
    margin-top: 0.75rem;
}

/* ── Tables dans le corps éditorial ── */

.editorial-content table {
    width: auto;
    max-width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.5rem;
    font-family: var(--font-primary, 'Roboto', sans-serif);
    font-size: 0.9375rem;
}

.editorial-content table thead tr {
    background-color: var(--color-primary, #192951);
    color: white;
}

.editorial-content table th {
    padding: 0.875rem 1.25rem;
    text-align: center;
    font-weight: 400;
    font-size: 1rem;
}

.editorial-content table th:first-child {
    border-radius: 8px 0 0 8px;
}

.editorial-content table th:last-child {
    border-radius: 0 8px 8px 0;
}

.editorial-content table tbody tr:nth-child(odd) {
    background-color: white;
}

.editorial-content table tbody tr:nth-child(even) {
    background-color: var(--color-surface-muted, #f8f8f8);
}

.editorial-content table td {
    padding: 0.875rem 1.25rem;
    text-align: center;
    color: var(--color-ink-primary, #192951);
    border-bottom: 1px solid var(--color-surface-muted, #f8f8f8);
}

/* ── Zone avantages abonnement (fieldset visuel) ── */

.editorial-content .advantages-fieldset {
    border: 1.5px solid var(--color-primary, #192951);
    border-radius: 8px;
    padding: 1.5rem 1.5rem 1.25rem;
    margin-bottom: 1.5rem;
    position: relative;
}

.editorial-content .advantages-fieldset .advantages-legend {
    position: absolute;
    top: -0.75rem;
    left: 1.25rem;
    background: white;
    padding: 0 0.5rem;
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    color: var(--color-primary, #192951);
    margin: 0;
}

.editorial-content .advantages-fieldset ul {
    list-style: none;
    padding-left: 0;
    margin: 0.5rem 0 0;
}

.editorial-content .advantages-fieldset li {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    padding-left: 0;
    margin-bottom: 0.625rem;
}

.editorial-content .advantages-fieldset li:last-child {
    margin-bottom: 0;
}

.editorial-content .advantages-fieldset li::before {
    content: '';
    flex-shrink: 0;
    width: 1.25rem;
    height: 1.25rem;
    margin-top: 0.125rem;
    background-color: var(--color-primary, #192951);
    border-radius: 50%;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath fill='white' d='M1.5 5L4.5 8 10.5 2' stroke='white' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round' fill='none'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 55%;
}

/* ── Boutons dans le fieldset avantages ── */

.editorial-content .advantages-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    margin-top: 1.5rem;
}

.editorial-content .advantages-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.625rem 1.75rem;
    font-family: var(--font-heading, 'Poppins', sans-serif);
    font-weight: 500;
    font-size: 0.9375rem;
    text-transform: uppercase;
    text-decoration: none !important;
    border-radius: 4px;
    border: 1.5px solid var(--color-primary, #192951);
    transition: background-color 0.15s, color 0.15s;
    white-space: nowrap;
}

.editorial-content .advantages-btn--primary {
    background-color: var(--color-primary, #192951);
    color: white !important;
}

.editorial-content .advantages-btn--primary:hover {
    background-color: #111e38;
    color: white !important;
}

.editorial-content .advantages-btn--secondary {
    background-color: transparent;
    color: var(--color-primary, #192951) !important;
}

.editorial-content .advantages-btn--secondary:hover {
    background-color: var(--color-primary, #192951);
    color: white !important;
}

/* Masquer le marqueur de liste hérité si le callout CE a un header */
.editorial-chapo .frame,
.editorial-chapo .ce-text {
    margin: 0;
    padding: 0;
}

/* ── Zone chapeau / introduction (colPos 10, page éditoriale) ── */
/* Typographie intro identique au champ abstract : Roboto Regular, large  */

.editorial-chapo .ce-textpic,
.editorial-chapo .ce-text,
.editorial-chapo .csc-default {
    font-family: var(--font-primary, 'Roboto', sans-serif);
}

.editorial-chapo p {
    font-family: var(--font-primary, 'Roboto', sans-serif);
    font-size: var(--text-xl, 1.25rem);
    line-height: 1.5;
    color: var(--color-ink-primary, #192951);
    margin-bottom: 0.75rem;
}

.editorial-chapo p:last-child {
    margin-bottom: 0;
}

@media (min-width: 1440px) {
    .editorial-chapo p {
        font-size: var(--text-2xl, 1.5rem);
    }
}

/* ── SalesGrid price-tag font-size reset (CSP-safe, replaces inline style) */
.price-tag-fare { font-size: 0; }

/* ── CardCta2 auto-grid ──────────────────────────────────────────────────────
   Parent becomes flex-wrap when it contains CardCta2 CEs.
   Cards: 3 cols desktop, 2 cols tablet, 1 col mobile.
   Same-row cards stretch to equal height (align-items: stretch). */

.editorial-content:has(.frame-type-tx_theme_cardcta2),
.content-block:has(.frame-type-tx_theme_cardcta2),
.main-col:has(.frame-type-tx_theme_cardcta2) {
    display: flex;
    flex-wrap: wrap;
    gap: 30px;
    align-items: stretch;
}

.editorial-content > .frame-type-tx_theme_cardcta2,
.content-block > .frame-type-tx_theme_cardcta2,
.main-col > .frame-type-tx_theme_cardcta2 {
    width: calc((100% - 60px) / 3);
    display: flex;
    flex-direction: column;
}

.frame-type-tx_theme_cardcta2 > *,
.frame-type-tx_theme_cardcta2 > * > *,
.frame-type-tx_theme_cardcta2 > * > * > * {
    display: flex;
    flex-direction: column;
    flex: 1;
}

.editorial-content:has(.frame-type-tx_theme_cardcta2) > :not(.frame-type-tx_theme_cardcta2),
.content-block:has(.frame-type-tx_theme_cardcta2) > :not(.frame-type-tx_theme_cardcta2),
.main-col:has(.frame-type-tx_theme_cardcta2) > :not(.frame-type-tx_theme_cardcta2) {
    width: 100%;
}

@media (max-width: 1023px) {
    .editorial-content > .frame-type-tx_theme_cardcta2,
    .content-block > .frame-type-tx_theme_cardcta2,
    .main-col > .frame-type-tx_theme_cardcta2 {
        width: calc((100% - 30px) / 2);
    }
}

@media (max-width: 767px) {
    .editorial-content > .frame-type-tx_theme_cardcta2,
    .content-block > .frame-type-tx_theme_cardcta2,
    .main-col > .frame-type-tx_theme_cardcta2 {
        width: 100%;
    }
}
