/* ===========================================
   OFFRE-PROCESS PAGE – GRID SKELETON (DEBUG)
   =========================================== */

/* Color test (Offre & Process only) */
body {
  background: var(--color-bg);
  color: var(--color-text);
}

.site-header,
.site-footer,
.page-container {
  background: var(--color-bg);
}

.page-container h1,
.page-container h2,
.page-container h3 {
  color: var(--color-title);
}

.block__number {
  color: var(--color-secondary);
  opacity: var(--color-secondary-opacity);
}

.block {
}

.grid .block:nth-child(3n+1) {
  background: var(--color-block-a);
}

.grid .block:nth-child(3n+2) {
  background: var(--color-block-b);
}

.grid .block:nth-child(3n) {
  background: var(--color-block-c);
}

.block__text,
.block__image {
  background: transparent;
}

/* Container */
.page-container {
  width: 100%;
  max-width: 100%;
  padding-left: var(--site-pad);
  padding-right: var(--site-pad);
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
}

/* Grille 12 colonnes */
.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 40px;
}

/* Blocs */
.block {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 50px;
  padding: 0;
  height: 500px;
}

/* Bloc sans image (texte seul) */
.block.no-image {
  grid-template-columns: 1fr;
}

.block.no-image .block__text {
  padding: 50px 150px 50px 50px;
}

/* Zone texte */
.block__text {
  display: grid;
  gap: 12px;
  align-content: center;
  padding: 50px 0 50px 50px;
}

/* Typographie */
.block__number {
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 64px;
  font-weight: 400;
  line-height: 1;
  opacity: 0.35;
}

.block__title {
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 29px;
  font-weight: 600;
  margin: 0;
}

.block__desc {
  font-size: 19px;
  line-height: 1.5;
  margin: 0;
}
.block__desc a{text-decoration:underline;text-underline-offset:3px}

/* Zone image */
.block__image {
  min-height: 180px;
  overflow: hidden;
}

.block__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Bloc inversé (image à gauche, texte à droite) */
.block.is-reversed {
  grid-template-columns: 1fr 2fr;
}

.block.is-reversed .block__image {
  order: -1;
}

.block.is-reversed .block__text {
  padding: 50px 50px 50px 0;
}

/* Largeurs dans la grille 12 colonnes */
.block.is-half {
  grid-column: span 6;
}

.block.is-quarter {
  grid-column: span 4;
}

.block.is-threequarter {
  grid-column: span 8;
}

/* ===========================================
   BREAKPOINT – 1600px (stack text + image)
   =========================================== */
@media (max-width: 1600px) {
  .block {
    grid-template-columns: 1fr;
    height: auto;
  }

  .block.is-reversed {
    grid-template-columns: 1fr;
  }

  .block__text {
    padding: 40px 50px;
  }

  .block.is-reversed .block__text {
    padding: 40px 50px;
  }

  .block.is-reversed .block__text {
    order: 0;
  }

  .block.is-reversed .block__image {
    order: 1;
  }
}

/* ===========================================
   BREAKPOINT – Mobile / Tablette
   =========================================== */
@media (max-width: 1100px) {
  .grid {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .block.is-reversed .block__text {
    order: 0;
  }

  .block.is-reversed .block__image {
    order: 1;
  }

  .block.is-half,
  .block.is-quarter,
  .block.is-threequarter {
    grid-column: span 12;
  }
}

/* ===========================================
   BREAKPOINT – 475px (full-bleed)
   =========================================== */
@media (max-width: 475px) {
  .page-container {
    padding-left: 0;
    padding-right: 0;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
  }

  .grid {
    gap: 20px;
  }

  .block__text {
    padding: 24px 0;
    justify-items: center;
    text-align: center;
  }

  .block.no-image .block__text {
    padding: 24px 0;
  }

  .block__number {
    font-size: 36px;
    width: var(--mobile-text-w, 70vw);
    max-width: var(--mobile-text-w, 70vw);
  }

  .block__title {
    font-size: 20px;
    width: var(--mobile-text-w, 70vw);
    max-width: var(--mobile-text-w, 70vw);
  }

  .block__desc {
    font-size: 17px;
    width: var(--mobile-text-w, 70vw);
    max-width: var(--mobile-text-w, 70vw);
  }
}

/* Offre & Process (moved from style.css) */
.offre-process .op-hero{margin-top:70px;margin-bottom:0;padding:0 var(--site-pad)}
.offre-process .op-title{display:none;margin:0 0 12px;font-size:calc(var(--services-title-size) * 1.1);font-weight:400}
.offre-process .op-lead{margin:0 0 10px;font-size:16px;line-height:1.5;white-space:pre-line;color:var(--color-text)}
.offre-process .op-contact{margin:0;font-size:16px;line-height:1.5;white-space:pre-line;color:var(--color-text)}
.offre-process .op-list{margin:0 0 10px;padding-left:20px;color:var(--color-text)}

/* Offer process - Methodology */
.offre-process .op-process{
  margin:80px 0;
  padding:24px var(--site-pad);
  width: calc(100% + var(--services-overshoot-right));
  margin-right: calc(-1 * var(--services-overshoot-right));
  background:rgba(0,0,0,0.02);
}
.offre-process .op-process-title{
  margin:0 0 32px;
  font-size:calc(var(--services-title-size) * 1.0);
  font-weight:600;
  font-family:Garamond,"EB Garamond",Georgia,serif;
  text-align:center;
  color:var(--color-title);
}
.offre-process .process-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
}
@media (min-width:768px){
  .offre-process .process-grid{
    grid-template-columns:repeat(3,1fr);
  }
  .offre-process .process-item:nth-child(4),
  .offre-process .process-item:nth-child(5){
    grid-column:span 1;
  }
}
@media (min-width:1200px){
  .offre-process .process-grid{
    grid-template-columns:repeat(5,1fr);
  }
  .offre-process .process-item:nth-child(4),
  .offre-process .process-item:nth-child(5){
    grid-column:auto;
  }
}
.offre-process .process-item{
  padding:20px;
}
.offre-process .process-number{
  font-size:16px;
  font-weight:700;
  margin:0 0 8px;
  color:var(--color-secondary);
  opacity:var(--color-secondary-opacity);
}
.offre-process .process-item-title{
  margin:0 0 10px;
  font-size:16px;
  font-weight:700;
  line-height:1.3;
  color:var(--color-title);
}
.offre-process .process-item-text{
  margin:0;
  font-size:14px;
  line-height:1.5;
  color:var(--color-text);
  opacity:0.85;
}

/* Offer process - Modules */
.offre-process .op-modules{
  margin:80px 0;
  padding:24px var(--site-pad);
  width: calc(100% + var(--services-overshoot-right));
  margin-right: calc(-1 * var(--services-overshoot-right));
}
.offre-process .op-modules-title{margin:0 0 8px;font-size:calc(var(--services-title-size) * 1.0);font-weight:600;font-family: Garamond, "EB Garamond", Georgia, serif;color:var(--color-title)}
.offre-process .op-modules-sub{margin:0 0 16px;font-size:16px;line-height:1.5;opacity:.9}
.offre-process .op-modules-note{margin:18px 0 0;font-size:15px;line-height:1.5;opacity:.75}

.offre-process .bullet-grid{display:grid;grid-template-columns:1fr;gap:26px}
@media (min-width:1024px){
  .offre-process .bullet-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
}

.offre-process .bullet-card{padding:18px 18px}

.offre-process .bullet-card .icon{width:24px;height:24px;border-radius:9999px;background:#e5e5e5;color:var(--color-text);display:flex;align-items:center;justify-content:center;font-size:12px;line-height:1;margin-top:4px}
.offre-process .bullet-card .content{min-width:0}
.offre-process .bullet-card .row{display:grid;grid-template-columns:auto 1fr auto;align-items:baseline;gap:10px}
.offre-process .bullet-card .mod-title{margin:0;font-size:20px;font-weight:600;color:var(--color-title)}
.offre-process .bullet-card .leader{border-bottom:1px dotted rgba(0,0,0,.35);height:0;align-self:center}
.offre-process .bullet-card .price-badge{justify-self:end;color:var(--color-text);border-radius:9999px;padding:4px 10px;font-weight:700;font-size:16px}
.offre-process .bullet-card .note{margin-top:6px;font-size:16px;opacity:.8;line-height:1.5}

.offre-process .op-card{
  background:var(--color-block-b);
  padding:24px var(--site-pad);
  margin-bottom:80px;
}
/* Offer process card titles use .section-title class */
.offre-process .op-card .card-title{
  font-family: Garamond, "EB Garamond", Georgia, serif;
  font-size: 29px;
  font-weight: 600;
  margin: 0 0 12px;
  color: var(--color-title);
}
.offre-process .op-card .card-purpose{margin:0 0 50px;font-size:16px;line-height:1.5;white-space:pre-line;color:var(--color-text)}
.offre-process .op-card .card-usage{margin:20px 0 50px 0px}
.offre-process .op-card .card-usage-title{margin:0 0 8px;font-weight:600;font-size:16px;color:var(--color-title)}
.offre-process .op-card .card-usage-text{margin:0;font-size:16px;line-height:1.5;white-space:pre-line;color:var(--color-text)}
.offre-process .op-card .card-columns{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.offre-process .op-card h3{margin:0 0 8px;font-weight:700;font-size:20px;color:var(--color-title)}
.offre-process .op-card ul{margin:0 0 16px;padding-left:20px;color:var(--color-text)}
.offre-process .op-card ul li{margin-bottom:8px;line-height:1.5;color:var(--color-text)}
.offre-process .op-card .strong{font-weight:normal;text-decoration:none;color:var(--color-text)}

/* Offer process steps feature-frame override */
.offre-process .studio .feature-frame{
  width:100%;
  max-width:100%;
  margin-right:0;
  display:grid;
  grid-template-columns:1.2fr 1fr;
  gap:50px;
  box-sizing:border-box;
  overflow:hidden;
}
.offre-process .studio .feature-frame > *{
  min-width:0;
  max-width:100%;
  box-sizing:border-box;
}
.offre-process .studio .feature-frame .feature-content{
  min-width:0;
  overflow:hidden;
}
.offre-process .studio .feature-frame .feature-image{
  overflow:hidden;
  min-width:0;
  width:100%;
  height:100%;
}
.offre-process .studio .feature-frame .feature-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
/* Steps with image left (03, 06): invert columns */
.offre-process .studio .feature-frame.step03,
.offre-process .studio .feature-frame.step06{
  grid-template-columns:1fr 1.2fr;
}
/* Responsive: single column on narrow screens */
@media (max-width: 1024px){
  .offre-process .studio .feature-frame,
  .offre-process .studio .feature-frame.step03,
  .offre-process .studio .feature-frame.step06{
    grid-template-columns:1fr;
    gap:24px;
  }
}

/* Offer process anchor quick nav */
.offre-process .op-nav{position:sticky;top:calc(var(--header-h) - 1px);z-index:5;background:var(--color-bg);border-top:1px solid #e6e6e6;border-bottom:1px solid #e6e6e6;margin:0 0 40px}
.offre-process .op-nav .op-nav-inner{display:flex;gap:24px;overflow:auto;padding:10px var(--site-pad)}
.offre-process .op-nav a{font-size:16px;opacity:.9}
.offre-process .op-nav a:hover{opacity:1;text-decoration:underline}

/* Common clauses block */
.offre-process .op-clauses{
  padding:24px var(--site-pad);
  margin-top:40px;
  border-top:1px solid #e6e6e6;
  width: calc(100% + var(--services-overshoot-right));
  margin-right: calc(-1 * var(--services-overshoot-right));
}
.offre-process .op-clauses-title{margin:0 0 12px;font-size:calc(var(--services-title-size));font-weight:600;font-family: Garamond, "EB Garamond", Georgia, serif;color:var(--color-title)}
.offre-process .op-clauses-list{margin:0;padding-left:20px;color:var(--color-text)}
.offre-process .op-clauses-list li{margin:0 0 8px;white-space:pre-line;line-height:1.5;color:var(--color-text)}

/* Link to common clauses under each card */
.offre-process .card-common-clauses-link{margin:8px 0 0;opacity:.8;font-size:14px}
.offre-process .card-common-clauses-link a{text-decoration:underline}
.offre-process .op-modules .card-common-clauses-link{text-align:right}

/* Final CTA */
.offre-process .op-cta{padding:32px var(--site-pad);margin-top:30px;background:#f4f4f4;display:grid;place-items:center;text-align:center}
.offre-process .op-cta h3{margin:0 0 10px;font-weight:600}
.offre-process .op-cta .cta-actions{display:flex;gap:16px}
.offre-process .op-cta .btn{display:inline-block;padding:10px 16px;border:1px solid var(--color-text)}
.offre-process .op-cta .btn:hover{background:var(--color-text);color:var(--color-bg)}

@media (max-width: 900px){
  .offre-process .op-card .card-columns{grid-template-columns:1fr}
}

/* ========================================
   OFFRE & PROCESS - NOUVEAU LAYOUT
   ======================================== */

/* 1. EN-TÊTE */
.op-hero {
  text-align: center;
  padding: 60px var(--site-pad);
  margin-bottom: 0;
}

.op-hero .op-title {
  font-size: 32px;
  font-weight: 400;
  margin: 0;
}

/* 2 & 3. OFFRES CÔTE À CÔTE */
.offre-process {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}

/* Placer l'en-tête en pleine largeur */
.offre-process .op-hero {
  grid-column: 1 / -1;
}

/* Placer les 2 offres côte à côte sur desktop */
@media (min-width: 769px) {
  .offre-process {
    grid-template-columns: repeat(2, 1fr);
  }
  
  .offre-process .op-hero {
    grid-column: 1 / -1;
  }
  
  .offre-process #offre-esquisse {
    grid-column: 1;
    grid-row: 2;
  }
  
  .offre-process #offre-2-hero {
    grid-column: 2;
    grid-row: 2;
  }
  
  .offre-process .op-modules {
    grid-column: 1 / -1;
    grid-row: 3;
    margin-top: 0;
  }
  
  .offre-process .op-clauses {
    grid-column: 1 / -1;
    grid-row: 4;
    margin-top: 0;
  }
}

/* Styles des cartes offres */
.op-card {
  padding: 40px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
  margin-bottom: 0;
}

/* Couleurs de fond des sections */
#offre-esquisse {
  background-color: rgba(0, 0, 0, 0.02);
}

#offre-2-hero {
  background-color: rgba(0, 0, 0, 0.02);
}

.op-modules {
  background-color: rgba(0, 0, 0, 0.02);
}

.op-clauses {
  background-color: rgba(0, 0, 0, 0.02);
  color: var(--color-text);
}

.op-card .card-title {
  font-size: 24px;
  font-weight: 600;
  margin: 0 0 16px;
  font-family: Garamond, "EB Garamond", Georgia, serif;
}

.op-card .card-purpose {
  margin: 0 0 32px;
  line-height: 1.5;
  opacity: 0.9;
}

.op-card .card-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

.op-card .card-col h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 24px 0 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  opacity: 0.8;
}

.op-card .card-col h3:first-child {
  margin-top: 0;
}

.op-card ul {
  margin: 0;
  padding-left: 20px;
  list-style: disc;
}

.op-card ul li {
  margin-bottom: 8px;
  line-height: 1.5;
}

.offre-process .op-card .card-price-main {
  font-size: 18px;
  font-weight: 600;
  margin: 12px 0;
  white-space: pre-line;
  color: var(--color-text);
}

.offre-process .op-card .card-price-note {
  font-size: 14px;
  opacity: 0.7;
  margin: 8px 0 16px;
  color: var(--color-text);
}

/* 4. MODULES */
.op-modules {
  padding: 60px 40px;
  margin-bottom: 0;
}

.op-modules .op-modules-title {
  font-size: 29px;
  font-weight: 600;
  margin: 0 0 7px;
  text-align: center;
  color: var(--color-title);
}

.op-modules .op-modules-sub {
  text-align: center;
  margin: 0 0 40px;
  opacity: 0.9;
  color: var(--color-text);
}

.op-modules .bullet-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-bottom: 32px;
}

.op-modules .bullet-card {
  background: rgba(255, 255, 255, 0.1);
  padding: 24px;
  border-radius: 6px;
}

.op-modules .bullet-card .mod-title {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 8px;
  color: var(--color-title);
}

.op-modules .bullet-card .row {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 12px;
}

.op-modules .bullet-card .leader {
  flex: 1;
  border-bottom: 1px dotted rgba(0,0,0,.35);
  height: 0;
  align-self: center;
}

.op-modules .bullet-card .price-badge {
  justify-self: end;
  color: var(--color-text);
  border-radius: 9999px;
  padding: 4px 10px;
  font-weight: 700;
  font-size: 16px;
}

.op-modules .bullet-card .note {
  margin-top: 6px;
  font-size: 16px;
  opacity: .8;
  line-height: 1.5;
  color: var(--color-text);
}

.op-modules .op-modules-note {
  text-align: center;
  font-size: 14px;
  opacity: 0.8;
  line-height: 1.5;
  margin: 32px 0 0;
}

.op-modules .card-common-clauses-link {
  text-align: center;
  margin-top: 24px;
}

.op-modules .card-common-clauses-link a {
  color: inherit;
  text-decoration: underline;
}

/* 5. CLAUSES */
.op-clauses {
  padding: 60px 40px;
  margin-bottom: 0;
}

.op-clauses .op-clauses-title {
  font-size: 28px;
  font-weight: 600;
  margin: 0 0 32px;
  text-align: center;
}

.op-clauses .op-clauses-list {
  max-width: 800px;
  margin: 0 auto;
  padding: 0;
  list-style: none;
}

.op-clauses .op-clauses-list li {
  position: relative;
  padding-left: 32px;
  margin-bottom: 16px;
  line-height: 1.5;
}

.op-clauses .op-clauses-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  font-weight: bold;
  color: var(--color-text);
}

/* RESPONSIVE */
@media (max-width: 1230px) {
  .op-modules .bullet-grid {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 600px) {
  .op-process {
    margin: 40px 0 60px !important;
  }

  .op-process-title {
    font-size: 20px !important;
    margin-bottom: 24px !important;
  }

  .process-grid {
    gap: 20px !important;
  }

  .process-item {
    padding: 16px !important;
  }

  .process-item-title {
    font-size: 15px !important;
  }

  .process-item-text {
    font-size: 14px !important;
  }

  .op-modules .bullet-card .mod-title {
    font-size: 16px !important;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .op-modules .bullet-card .price-badge {
    font-size: 14px !important;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .op-modules .bullet-card .note {
    font-size: 14px !important;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .op-modules .bullet-card .row {
    flex-direction: column;
    gap: 8px;
  }
}

@media (max-width: 360px) {
  .op-modules .bullet-card {
    padding: 12px !important;
  }

  .op-modules .bullet-card .mod-title {
    font-size: 14px !important;
  }

  .op-modules .bullet-card .price-badge {
    font-size: 12px !important;
  }

  .op-modules .bullet-card .note {
    font-size: 14px !important;
  }

  .op-modules .bullet-grid {
    gap: 16px !important;
  }
}

@media (max-width: 768px) {
  .op-hero {
    padding: 40px 24px;
  }
  
  .op-card {
    padding: 24px;
    margin-bottom: 24px;
  }
  
  .op-card .card-columns {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  
  .op-modules {
    padding: 40px 24px;
  }
  
  .op-modules .bullet-grid {
    grid-template-columns: 1fr;
  }
  
  .op-clauses {
    padding: 40px 24px;
  }
}

@media (max-width: 480px) {
  .offre-process .op-process,
  .offre-process .op-card,
  .offre-process .op-modules,
  .offre-process .op-clauses {
    width: 100vw !important;
    max-width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    box-sizing: border-box;
  }

  .offre-process .op-modules-title,
  .offre-process .op-card .card-title,
  .offre-process .op-clauses-title {
    font-size: 20px !important;
  }

  .offre-process h3 {
    font-size: 18px !important;
  }

  .op-card {
    padding: 20px;
  }

  .op-card .card-title {
    font-size: 14px !important;
  }

  .op-card h3 {
    font-size: 14px !important;
  }

  .op-modules {
    padding: 20px !important;
    overflow: hidden !important;
  }

  .op-modules .bullet-grid {
    grid-template-columns: 1fr !important;
  }

  .op-modules .bullet-card {
    padding: 16px !important;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .op-modules .bullet-card .row {
    flex-wrap: wrap;
  }

  .op-modules .bullet-card .leader {
    display: none;
  }

  .op-clauses {
    padding: 20px !important;
  }

  .op-clauses .op-clauses-list {
    max-width: 100% !important;
  }

  .op-clauses .op-clauses-list li {
    word-wrap: break-word;
    overflow-wrap: break-word;
  }

  .offre-process .op-card ul {
    font-size: 14px !important;
  }

  .offre-process .op-card ul li {
    font-size: 14px !important;
  }

  .offre-process .op-clauses-list li {
    font-size: 14px !important;
  }
}
