/* ============================================================================
   YESMYTRIPS — Classes de train (page comparatif)
   Feuille consolidée. UNE seule version mobile par composant.
   Dépend des variables globales : --cream, --paper, --ink, --ink-soft,
   --ink-mute, --rule, --rule-soft, --maroon, --maroon-deep, --accent,
   --accent-pale, --serif, --sans, --mono.
   ============================================================================ */


/* ── Layout page ─────────────────────────────────────────────────────────── */
main.page-body{
  width:100%;
  box-sizing:border-box;
  padding-left:clamp(1rem,4vw,3rem);
  padding-right:clamp(1rem,4vw,3rem);
}
.wrap{max-width:920px;margin:0 auto}
.highlight{color:#4a1010;font-weight:600}


/* ── features-table (liste simple critère / valeur) ──────────────────────── */
.features-table{width:100%;border-collapse:collapse;margin:24px 0;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);font-size:15px}
.features-table tr{border-bottom:1px solid var(--rule);transition:background .1s}
.features-table tr:last-child{border-bottom:none}
.features-table tr:hover{background:var(--paper)}
.features-table td{padding:14px 16px 14px 0;vertical-align:top;color:var(--ink-soft);line-height:1.5}
.features-table td:first-child{font-family:var(--mono);font-size:11.5px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mute);white-space:nowrap;width:38%}
.features-table td:last-child{color:var(--ink);text-align:right;padding-right:0}
.val-yes,.val-no,.val-partial{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}
.val-yes{color:#4a6325}
.val-no{color:red}
.val-partial{color:var(--warn-text)}
.val-yes::before{content:'✓';font-size:14px}
.val-no::before{content:'\2717';font-size:14px}
.val-partial::before{content:'△';font-size:12px}


/* ── compare-grid (cartes liées génériques) ──────────────────────────────── */
.compare-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:24px 0}
.compare-card{display:block;background:var(--cream);border:1px solid var(--rule);padding:0 0 24px;text-decoration:none;color:var(--ink);transition:border-color .15s,background .15s;overflow:hidden}
.compare-card:hover{border-color:var(--ink);background:var(--paper)}
.compare-tag{font-family:var(--mono);font-size:10px;font-weight:500;text-transform:uppercase;letter-spacing:.14em;color:var(--maroon);margin:16px 22px 8px}
.compare-name{font-family:var(--serif);font-size:21px;font-weight:400;color:var(--ink);line-height:1.15;margin:0 22px 8px;letter-spacing:-.012em;font-variation-settings:'opsz' 24}
.compare-card:hover .compare-name{color:var(--maroon)}
.compare-name em{font-style:italic;color:var(--maroon);font-variation-settings:'opsz' 24,'WONK' 1}
.compare-summary{font-size:13.5px;color:var(--ink-mute);line-height:1.5;margin:0 22px}
.compare-image{width:100%;height:180px;overflow:hidden}
.compare-image img{width:100%;height:100%;object-fit:cover;object-position:center}
@media(max-width:760px){.compare-grid{grid-template-columns:1fr}}


/* ── classes-cmp-grid (cartes de classe avec image/badge/prix) ───────────── */
.classes-cmp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--rule);margin:0 0 8px}
.classes-cmp-grid--2col{grid-template-columns:repeat(2,1fr)}
.classes-cmp-grid--3col{grid-template-columns:repeat(3,1fr)}

.classes-cmp-card{display:flex;flex-direction:column;border-right:1px solid var(--rule);transition:background .15s;text-decoration:none;color:inherit}
.classes-cmp-card:last-child{border-right:none}
.classes-cmp-card:hover{background:var(--paper)}
.classes-cmp-card--featured{border-top:3px solid var(--maroon)}

.classes-cmp-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--cream-2)}
.classes-cmp-img img{width:100%;height:100%;object-fit:cover;filter:saturate(.9);transition:transform .4s ease}
.classes-cmp-card:hover .classes-cmp-img img{transform:scale(1.03)}

.classes-cmp-badge{position:absolute;top:10px;left:10px;background:var(--maroon);color:var(--cream);font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px}
.classes-cmp-badge--neutral{background:var(--ink-soft)}
.classes-cmp-badge--muted{background:var(--ink-mute)}
.classes-cmp-badge--old{background:#7a6040}
.classes-cmp-badge--classic{background:#5e6a6e}

.classes-cmp-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.classes-cmp-title{font-family:var(--serif);font-size:17px;font-weight:400;line-height:1.2;color:var(--ink);margin-bottom:8px;font-variation-settings:'opsz' 24}
.classes-cmp-label{font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);vertical-align:middle}
.classes-cmp-desc{font-size:13.5px;line-height:1.5;color:var(--ink-soft);margin-bottom:12px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.classes-cmp-tags{list-style:none;padding:0;margin:auto 0 14px;display:flex;flex-wrap:wrap;gap:6px}
.classes-cmp-tags li{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-mute);border:1px solid var(--rule);padding:3px 8px}
.classes-cmp-price{font-size:14px;font-weight:500;color:var(--ink);padding-top:12px;border-top:1px solid var(--rule)}
.classes-cmp-price span{font-size:12px;font-weight:400;color:var(--ink-mute)}
.classes-cmp-cta{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--maroon);margin-top:10px}

@media(max-width:900px){
  .classes-cmp-grid{grid-template-columns:repeat(2,1fr)}
  .classes-cmp-grid--3col{grid-template-columns:repeat(2,1fr)}
  .classes-cmp-card:nth-child(2){border-right:none}
  .classes-cmp-card:nth-child(1),.classes-cmp-card:nth-child(2){border-bottom:1px solid var(--rule)}
}
@media(max-width:560px){
  .classes-cmp-grid,.classes-cmp-grid--2col,.classes-cmp-grid--3col{grid-template-columns:1fr}
  .classes-cmp-card{border-right:none;border-bottom:1px solid var(--rule)}
  .classes-cmp-card:last-child{border-bottom:none}
}


/* ── reco-block / price-note / valeurs oui-non ───────────────────────────── */
.article-dek{font-family:var(--serif);font-size:clamp(16px,1.8vw,19px);color:var(--ink-soft);max-width:760px;margin:0 auto;line-height:1.6;font-variation-settings:'opsz' 24}
.section-intro{font-size:16px;color:var(--ink-soft);margin:0 0 28px;line-height:1.6;max-width:900px}

.reco-block{display:flex;gap:16px;padding:20px 24px;background:var(--paper);border:1px solid var(--rule);border-left:4px solid var(--maroon);margin:24px 0 8px}
.reco-icon{flex-shrink:0;width:22px;height:22px;margin-top:2px}
.reco-label{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--maroon);font-weight:500;margin-bottom:4px}
.reco-text{font-size:14.5px;color:var(--ink);line-height:1.6;margin:0}
.reco-text strong{color:var(--maroon-deep)}

.price-note{font-family:var(--mono);font-size:11px;color:var(--ink-mute);letter-spacing:.03em;margin:6px 0 32px;line-height:1.7}
.price-note strong{color:var(--ink)}

.yes{color:#3a6e2a;font-weight:500}
.no{color:var(--ink-mute)}
.tag-new{font-family:var(--mono);font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:#3a6e2a;border:1px solid #b0d49a;padding:2px 6px;vertical-align:middle;margin-left:4px}


/* ── cmp-table : tableaux comparatifs (DESKTOP) ──────────────────────────── */
.cmp-table-wrap{overflow-x:auto;border:1px solid var(--rule);margin-bottom:48px}
.cmp-table{width:100%;border-collapse:collapse;font-size:14px}

.cmp-table thead th{font-family:var(--mono);font-size:10.5px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);text-align:left;padding:14px 18px;border-bottom:1px solid var(--ink);background:var(--cream);white-space:nowrap}
.cmp-table__feat{background:var(--paper) !important;border-left:1px solid var(--rule);border-right:1px solid var(--rule)}
thead .cmp-table__feat{color:var(--maroon) !important;border-top:3px solid var(--maroon)}

.cmp-table tbody td{padding:12px 18px;border-bottom:1px solid var(--rule);color:var(--ink);vertical-align:middle;line-height:1.4}
.cmp-table tbody td:first-child{font-family:var(--mono);font-size:11.5px;letter-spacing:.04em;color:var(--ink-mute);white-space:nowrap}
.cmp-table tbody tr:last-child td{border-bottom:none}
.cmp-table tbody tr:hover td{background:#fafaf8}
.cmp-table tbody tr:hover .cmp-table__feat{background:var(--cream-2) !important}


/* ── cmp-table : tableaux comparatifs (MOBILE) ───────────────────────────────
   UNE ligne du tableau = UNE carte.
   • 1ʳᵉ cellule (le CRITÈRE) = bandeau-titre maroon
   • cellules suivantes = flex : nom de la classe à GAUCHE, valeur à DROITE
   Aucun position:absolute → pas de chevauchement possible.
   C'EST LA SEULE VERSION MOBILE. Ne pas dupliquer ailleurs.
   ──────────────────────────────────────────────────────────────────────── */
@media (max-width:768px){

  .cmp-table-wrap{border:none;overflow:visible}

  .cmp-table-wrap .cmp-table,
  .cmp-table-wrap .cmp-table tbody,
  .cmp-table-wrap .cmp-table tr,
  .cmp-table-wrap .cmp-table td{display:block;width:100%}

  .cmp-table-wrap .cmp-table thead{display:none}

  /* une ligne = une carte */
  .cmp-table-wrap .cmp-table tbody tr{
    background:var(--paper);
    border:1px solid var(--rule);
    border-radius:8px;
    overflow:hidden;
    margin:0 0 18px;
  }
  .cmp-table-wrap .cmp-table tbody tr:last-child{margin-bottom:0}

  /* 1ʳᵉ cellule = le critère = titre de la carte (forcé visible) */
  .cmp-table-wrap .cmp-table tbody td:first-child{
    display:block;
    background:var(--maroon);
    color:#fff;
    font-family:var(--serif);
    font-size:16px;
    font-weight:500;
    letter-spacing:0;
    text-transform:none;
    white-space:normal;
    padding:12px 16px;
    border:none;
  }

  /* cellules de valeur : classe à gauche (::before), valeur à droite */
  .cmp-table-wrap .cmp-table tbody td:not(:first-child){
    display:flex;
    justify-content:space-between;
    align-items:baseline;
    gap:14px;
    text-align:right;
    padding:11px 16px;
    border-top:1px solid var(--rule-soft);
    border-bottom:none;
    font-size:14.5px;
    line-height:1.4;
  }

  .cmp-table-wrap .cmp-table tbody td:not(:first-child)::before{
    content:attr(data-label);
    flex-shrink:0;
    text-align:left;
    font-family:var(--mono);
    font-size:11px;
    letter-spacing:.05em;
    text-transform:uppercase;
    color:var(--ink-mute);
  }

  /* colonne recommandée mise en avant */
  .cmp-table-wrap .cmp-table tbody td.cmp-table__feat:not(:first-child){
    background:var(--accent-pale);
    box-shadow:inset 3px 0 0 var(--accent);
  }
  .cmp-table-wrap .cmp-table tbody td.cmp-table__feat:not(:first-child)::before{
    color:var(--maroon);
    font-weight:600;
  }
}


/* ── schedule-table (horaires) ───────────────────────────────────────────── */
.schedule-table-wrap{margin:24px 0}
.schedule-table{width:100%;border-collapse:collapse;font-family:var(--mono);font-size:14px;border-top:1px solid var(--ink);border-bottom:1px solid var(--ink)}
.schedule-table thead{border-bottom:1px solid var(--ink)}
.schedule-table thead th{padding:12px 12px 12px 0;text-align:left;font-size:10.5px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--ink-mute);white-space:nowrap;font-family:var(--mono)}
.schedule-table thead th:last-child{text-align:right;padding-right:0}
.schedule-table tbody tr{border-bottom:1px solid var(--rule);transition:background .1s}
.schedule-table tbody tr:last-child{border-bottom:none}
.schedule-table tbody tr:hover{background:var(--paper)}
.schedule-table tbody td{padding:18px 12px 18px 0;color:var(--ink);vertical-align:middle;font-variant-numeric:tabular-nums}
.schedule-table tbody td:last-child{text-align:right;padding-right:0}
.price-eur{font-size:12px}
.td-price{font-weight:500;color:var(--ink);white-space:nowrap;letter-spacing:.02em}
.table-note{font-family:var(--mono);font-size:11px;letter-spacing:.04em;color:var(--ink-mute);padding:12px 0 0;line-height:1.6}
.table-note strong{color:var(--ink);font-weight:500}

.schedule-cards{display:none}
.schedule-card{border-top:1px solid var(--rule);padding:18px 0}
.schedule-card:last-child{border-bottom:1px solid var(--rule)}
.sc-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px;gap:12px}
.sc-service{font-family:var(--mono);font-size:10.5px;font-weight:500;color:var(--ink-mute);text-transform:uppercase;letter-spacing:.12em}
.sc-price{font-family:var(--serif);font-size:19px;color:var(--maroon);font-style:italic}
.sc-row{display:flex;gap:12px;font-family:var(--mono);font-size:13.5px;margin-bottom:6px;align-items:baseline}
.sc-label{color:var(--ink-mute);font-size:11px;letter-spacing:.1em;text-transform:uppercase;min-width:84px;flex-shrink:0}
.sc-val{color:var(--ink);font-variant-numeric:tabular-nums}
.sc-val em{color:var(--maroon);font-family:var(--serif);font-size:18px;font-style:italic}
@media(max-width:768px){
  .schedule-table,.schedule-table+.table-note{display:none}
  .schedule-cards{display:block}
  .author-right{display:none}
}


/* ── sources ─────────────────────────────────────────────────────────────── */
.sources{margin-top:48px;padding-top:20px;border-top:1px solid var(--ink);font-family:var(--mono);font-size:11px;letter-spacing:.05em;color:var(--ink-mute);line-height:1.7}
.sources strong{display:block;text-transform:uppercase;letter-spacing:.12em;color:var(--ink);margin-bottom:8px;font-weight:500}
.sources a{color:var(--maroon);text-decoration:underline;text-underline-offset:2px}
::selection{background:var(--maroon);color:var(--cream)}


/* ── FAQ ─────────────────────────────────────────────────────────────────── */
.faq-item:last-child{border-bottom:1px solid var(--ink)}
.faq-item[open]{background:var(--paper)}
.faq-item summary{list-style:none;cursor:pointer;padding:20px 44px 20px 0;font-family:var(--serif);font-size:clamp(17px,2vw,19px);font-weight:400;line-height:1.35;color:var(--ink);font-variation-settings:'opsz' 24;position:relative;transition:color .15s ease}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--maroon)}
.faq-item summary::after{content:'+';position:absolute;right:8px;top:50%;transform:translateY(-50%);font-family:var(--serif);font-size:22px;font-weight:300;color:var(--maroon);line-height:1;transition:transform .2s ease}
.faq-item[open] summary::after{content:'−';transform:translateY(-50%)}
.faq-answer{padding:0 44px 24px 0;animation:faq-reveal .3s ease}
.faq-answer p{font-size:15.5px;line-height:1.7;color:var(--ink-soft);margin-bottom:12px}
.faq-answer p:last-child{margin-bottom:0}
.faq-answer strong{color:var(--ink);font-weight:500}
@keyframes faq-reveal{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:600px){
  .faq-item summary{font-size:16px;padding:18px 36px 18px 0}
  .faq-answer{padding-right:0}
  .faq-answer p{font-size:14.5px}
}