/* ===============================================================
   Dossier Le Boston Terrier — Navigation + pages standard/santé
   =============================================================== */
.cm-bt-page,
.cm-bt-standard-body,
.cm-bt-health-body{
  min-height:100vh;
  background-image:
    linear-gradient(180deg, rgba(255,246,235,.74), rgba(248,230,211,.84)),
    url('/assets/images/origine-boston/origine-boston-bg.webp');
  background-size:cover;
  background-position:center top;
  background-repeat:no-repeat;
  background-attachment:fixed;
  color:#3b2418;
}
.cm-bt-wrap{
  width:min(1180px, calc(100% - 34px));
  margin:0 auto;
  padding:34px 0 72px;
}
.cm-bt-dossier{
  position:relative;
  z-index:5;
  display:grid;
  gap:12px;
  margin:0 0 22px;
  padding:16px;
  border-radius:30px;
  background:rgba(255,250,244,.90);
  border:1px solid rgba(255,255,255,.72);
  box-shadow:0 18px 38px rgba(105,61,34,.12);
  backdrop-filter:blur(8px);
}
.cm-bt-dossier__title{
  display:flex;
  align-items:baseline;
  justify-content:center;
  gap:10px;
  text-align:center;
}
.cm-bt-dossier__title span{
  padding:6px 11px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,191,205,.95), rgba(255,221,154,.95));
  color:#793c30;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.cm-bt-dossier__title strong{
  color:#5a2d1d;
  font-size:clamp(24px, 3vw, 36px);
  line-height:1;
}
.cm-bt-dossier__tabs{
  display:grid;
  grid-template-columns:repeat(5, minmax(0, 1fr));
  gap:10px;
}
.cm-bt-dossier__tab{
  position:relative;
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:18px 18px 12px 12px;
  color:#67442e;
  background:linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,233,216,.68));
  border:1px solid rgba(143,91,62,.15);
  box-shadow:0 10px 18px rgba(116,65,38,.08);
  text-align:center;
  text-decoration:none;
  font-weight:950;
  transition:transform .15s ease, background .15s ease;
}
.cm-bt-dossier__tab:hover{ transform:translateY(-2px); }
.cm-bt-dossier__tab.is-active{
  color:#fff;
  background:linear-gradient(135deg, #d86f86, #c89145);
  box-shadow:0 14px 26px rgba(154,83,64,.22);
}
.cm-bt-panel,
.cm-bt-hero,
.cm-bt-card{
  position:relative;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.72);
  border-radius:34px;
  background:rgba(255,250,244,.90);
  box-shadow:0 22px 54px rgba(105,61,34,.14);
  backdrop-filter:blur(8px);
}
.cm-bt-hero::after,
.cm-bt-panel::after{
  content:"";
  position:absolute;
  inset:13px;
  border:1px solid rgba(142,82,48,.14);
  border-radius:26px;
  pointer-events:none;
}
.cm-bt-hero > *, .cm-bt-panel > *{ position:relative; z-index:1; }
.cm-bt-hero{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(260px, 340px);
  gap:24px;
  align-items:center;
  min-height:330px;
  padding:36px;
  background:linear-gradient(135deg, rgba(255,255,249,.96), rgba(255,238,222,.88));
}
.cm-bt-kicker{
  display:inline-flex;
  width:max-content;
  max-width:100%;
  padding:8px 14px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,191,205,.95), rgba(255,221,154,.95));
  color:#793c30;
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.cm-bt-hero h1,
.cm-bt-panel h2,
.cm-bt-card h3{
  color:#5a2d1d;
  line-height:1.02;
  text-shadow:0 2px 0 rgba(255,255,255,.58);
}
.cm-bt-hero h1{ margin:16px 0 14px; font-size:clamp(38px, 6vw, 68px); }
.cm-bt-panel h2{ margin:12px 0 18px; font-size:clamp(28px, 4vw, 46px); }
.cm-bt-hero p,
.cm-bt-panel p,
.cm-bt-card p,
.cm-bt-card li{
  color:#614633;
  line-height:1.72;
  font-size:17px;
}
.cm-bt-panel{ margin-top:24px; padding:32px; }
.cm-bt-grid{ display:grid; grid-template-columns:repeat(2, minmax(0, 1fr)); gap:18px; }
.cm-bt-grid--four{ grid-template-columns:repeat(4, minmax(0, 1fr)); }
.cm-bt-card{ padding:22px; border-radius:28px; background:rgba(255,255,255,.62); box-shadow:0 14px 28px rgba(116,65,38,.08); }
.cm-bt-card h3{ margin:0 0 10px; font-size:24px; }
.cm-bt-card p{ margin:0; }
.cm-bt-card ul{ margin:0; padding-left:20px; }
.cm-bt-btn-row{ display:flex; flex-wrap:wrap; gap:12px; margin-top:22px; }
.cm-bt-btn{ display:inline-flex; align-items:center; justify-content:center; min-height:46px; padding:0 18px; border-radius:999px; text-decoration:none; font-weight:950; color:#67442e; background:rgba(255,255,255,.74); border:1px solid rgba(143,91,62,.16); }
.cm-bt-btn--primary{ color:#fff; background:linear-gradient(135deg, #df748b, #c89145); box-shadow:0 14px 28px rgba(154,83,64,.24); }
.cm-bt-page-img{ display:block; width:100%; aspect-ratio:4/3; object-fit:contain; border-radius:24px; background:#fbf2e8; border:1px solid rgba(143,91,62,.12); }
.cm-bt-page-img--missing{ display:grid; place-items:center; align-content:center; gap:8px; color:#6a432e; background:rgba(255,244,235,.78); font-weight:900; text-align:center; padding:20px; }
.cm-bt-health-photos{ display:grid; grid-template-columns:repeat(3, minmax(0, 1fr)); gap:16px; margin-top:18px; }
.cm-bt-health-anchor-list{ display:flex; flex-wrap:wrap; gap:10px; margin:18px 0 0; }
.cm-bt-health-anchor-list a{ padding:9px 12px; border-radius:999px; color:#67442e; background:rgba(255,255,255,.70); border:1px solid rgba(143,91,62,.13); text-decoration:none; font-weight:900; }
.cm-bt-standard-list{ display:grid; gap:14px; }
.cm-bt-standard-item{ padding:18px; border-radius:22px; background:rgba(255,255,255,.58); border:1px solid rgba(143,91,62,.10); }
.cm-bt-standard-item h3{ margin:0 0 8px; color:#5a2d1d; font-size:22px; }
.cm-bt-standard-item p{ margin:0; }
.cm-bt-downloads{ display:flex; flex-wrap:wrap; gap:12px; margin-top:16px; }
@media (max-width:960px){
  .cm-bt-dossier__tabs{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .cm-bt-hero,.cm-bt-grid,.cm-bt-grid--four{ grid-template-columns:1fr; }
  .cm-bt-health-photos{ grid-template-columns:1fr; }
}
@media (max-width:620px){
  .cm-bt-wrap{ width:min(100% - 22px, 1180px); padding-top:20px; }
  .cm-bt-hero,.cm-bt-panel{ border-radius:26px; padding:22px; }
  .cm-bt-hero::after,.cm-bt-panel::after{ inset:9px; border-radius:20px; }
  .cm-bt-dossier__tabs{ grid-template-columns:1fr; }
  .cm-bt-dossier__tab{ min-height:50px; }
}


/* ===============================================================
   PATCH STANDARD BOSTON — HIÉRARCHIE DE LECTURE
   =============================================================== */
.cm-bt-standard-list--readable{
  gap:18px;
}

.cm-bt-standard-list--readable .cm-bt-standard-item{
  position:relative;
  padding:0;
  overflow:hidden;
  border-radius:24px;
  background:rgba(255,255,255,.66);
  border:1px solid rgba(143,91,62,.12);
  box-shadow:0 12px 26px rgba(116,65,38,.07);
}

.cm-bt-standard-list--readable .cm-bt-standard-item h3,
.cm-bt-standard-list--readable .cm-bt-standard-item h4{
  margin:0;
  text-shadow:none;
}

.cm-bt-standard-list--readable .cm-bt-standard-item h3{
  display:flex;
  align-items:center;
  min-height:54px;
  padding:14px 20px;
  color:#fff;
  background:linear-gradient(135deg, #8b4a34, #c89145);
  font-size:clamp(21px, 2.5vw, 30px);
  line-height:1.08;
  letter-spacing:.035em;
  text-transform:uppercase;
}

.cm-bt-standard-list--readable .cm-bt-standard-item--section h3::before{
  content:"";
  flex:0 0 12px;
  width:12px;
  height:12px;
  margin-right:12px;
  border-radius:50%;
  background:#ffe5b4;
  box-shadow:0 0 0 5px rgba(255,229,180,.18);
}

.cm-bt-standard-list--readable .cm-bt-standard-item--repere h3{
  background:linear-gradient(135deg, #d86f86, #c89145);
  font-size:clamp(18px, 2vw, 24px);
}

.cm-bt-standard-list--readable .cm-bt-standard-item h4{
  padding:13px 18px 9px;
  color:#6a321f;
  font-size:clamp(18px, 2vw, 23px);
  line-height:1.18;
  background:linear-gradient(90deg, rgba(255,229,206,.88), rgba(255,244,235,.40));
  border-bottom:1px solid rgba(143,91,62,.10);
}

.cm-bt-standard-list--readable .cm-bt-standard-item p,
.cm-bt-standard-list--readable .cm-bt-standard-item ul{
  margin:0;
  padding:17px 20px 19px;
  color:#4f3526;
  font-size:17px;
  line-height:1.75;
}

.cm-bt-standard-list--readable .cm-bt-standard-item--text p{
  padding:18px 20px;
  border-left:6px solid rgba(200,145,69,.65);
  background:rgba(255,250,244,.58);
  font-weight:820;
}

.cm-bt-standard-list--readable .cm-bt-standard-item ul{
  display:grid;
  gap:9px;
  list-style:none;
}

.cm-bt-standard-list--readable .cm-bt-standard-item li{
  position:relative;
  padding-left:22px;
}

.cm-bt-standard-list--readable .cm-bt-standard-item li::before{
  content:"•";
  position:absolute;
  left:0;
  top:0;
  color:#b9534d;
  font-weight:1000;
}

@media (max-width:620px){
  .cm-bt-standard-list--readable .cm-bt-standard-item h3{
    min-height:48px;
    padding:12px 15px;
    font-size:20px;
  }

  .cm-bt-standard-list--readable .cm-bt-standard-item h4{
    padding:12px 15px 8px;
    font-size:18px;
  }

  .cm-bt-standard-list--readable .cm-bt-standard-item p,
  .cm-bt-standard-list--readable .cm-bt-standard-item ul{
    padding:15px;
    font-size:15.8px;
  }
}


/* ===============================================================
   PATCH BOSTON DESCRIPTIF CLIENT + PRIX DYNAMIQUE
   =============================================================== */
.cm-bt-hero--portrait{
  grid-template-columns:minmax(0, 1fr) minmax(260px, 360px);
}

.cm-bt-price-card{
  min-height:230px;
  display:grid;
  place-items:center;
  align-content:center;
  gap:10px;
  padding:26px;
  border-radius:32px;
  text-align:center;
  background:
    radial-gradient(circle at 50% 38%, rgba(255,255,255,.88), transparent 45%),
    linear-gradient(145deg, rgba(255,231,204,.92), rgba(255,247,237,.76));
  border:1px solid rgba(143,91,62,.16);
  box-shadow:0 18px 38px rgba(105,61,34,.12), inset 0 1px 0 rgba(255,255,255,.72);
}

.cm-bt-price-card span{
  display:inline-flex;
  padding:7px 12px;
  border-radius:999px;
  color:#793c30;
  background:linear-gradient(135deg, rgba(255,191,205,.92), rgba(255,221,154,.92));
  font-size:12px;
  font-weight:950;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.cm-bt-price-card strong{
  color:#b9534d;
  font-size:clamp(36px, 5vw, 54px);
  line-height:1;
}

.cm-bt-price-card p{
  margin:0;
  color:#664530;
  font-weight:850;
  line-height:1.45;
}

.cm-bt-personal-copy{
  display:grid;
  gap:16px;
  max-width:920px;
  margin:0 auto;
  padding:24px;
  border-radius:28px;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(143,91,62,.11);
}

.cm-bt-personal-copy p{
  margin:0;
}

.cm-bt-grid--cards{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.cm-bt-card--accent{
  background:
    linear-gradient(145deg, rgba(255,255,255,.72), rgba(255,234,219,.68));
  border-color:rgba(200,145,69,.18);
}

.cm-bt-panel--price{
  background:
    radial-gradient(circle at 85% 15%, rgba(255,191,205,.26), transparent 28%),
    linear-gradient(135deg, rgba(255,252,247,.95), rgba(255,238,226,.88));
}

.cm-bt-price-block{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  max-width:940px;
  margin:0 auto;
  padding:24px;
  border-radius:28px;
  background:rgba(255,255,255,.64);
  border:1px solid rgba(143,91,62,.13);
}

.cm-bt-price-block strong{
  display:block;
  color:#b9534d;
  font-size:clamp(30px, 4vw, 48px);
  line-height:1;
}

.cm-bt-price-block p{
  margin:12px 0 0;
}

@media (max-width:960px){
  .cm-bt-hero--portrait,
  .cm-bt-grid--cards{
    grid-template-columns:1fr;
  }

  .cm-bt-price-block{
    align-items:flex-start;
    flex-direction:column;
  }
}

@media (max-width:620px){
  .cm-bt-page,
  .cm-bt-standard-body,
  .cm-bt-health-body{
    background-attachment:scroll;
    background-position:center top;
  }
}


/* ===============================================================
   PATCH BOSTON NETTOYAGE PRIX HAUT
   =============================================================== */
.cm-bt-card--gentleman{
  display:grid;
  align-content:center;
  min-height:230px;
  background:
    radial-gradient(circle at 50% 35%, rgba(255,255,255,.82), transparent 45%),
    linear-gradient(145deg, rgba(255,231,204,.88), rgba(255,247,237,.72));
  border:1px solid rgba(143,91,62,.14);
}

.cm-bt-card--gentleman h3{
  font-size:clamp(28px, 3vw, 38px);
  color:#b9534d;
}
