/**
 * design.css — styles scoped à la page Graphisme
 * Chargé automatiquement par Arcane pour /design/
 */

.design-hero {
  padding-block: var(--s16) var(--s20);
  background: var(--clr-bg);
}

.design-hero__inner {
  display: grid;
  grid-template-columns: 7fr 5fr;
  gap: var(--s12);
  align-items: center;
}

.design-hero__badge {
  display: inline-flex;
  align-items: center;
  padding: var(--s2) var(--s4);
  background: var(--clr-s3);
  border-radius: var(--r-full);
  font-size: .8125rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--s5);
}

.design-hero__title {
  margin-bottom: var(--s6);
  font-size: clamp(2.5rem, 5vw, 4.5rem);
}

.design-hero__title-accent { color: var(--clr-primary-light); }

.design-hero__desc {
  font-size: 1.125rem;
  color: var(--clr-subtle);
  max-width: 44ch;
  margin-bottom: var(--s8);
}

.design-hero__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s3);
}

.design-hero__tag {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  padding: var(--s2) var(--s4);
  background: var(--clr-s3);
  border-radius: var(--r-full);
  font-size: .875rem;
  font-weight: 600;
}

.design-hero__tag .material-symbols-outlined {
  font-size: 1rem;
  color: var(--clr-primary);
}

.design-hero__visual {
  position: relative;
}

.design-hero__img-wrap {
  border-radius: 3rem;
  overflow: hidden;
  transform: rotate(3deg);
  transition: transform .4s ease;
  aspect-ratio: 1;
  background: var(--clr-s3);
  object-fit: cover;
}

.design-hero__img-wrap:hover { transform: rotate(0); }

.design-hero__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.design-hero__deco {
  position: absolute;
  inset: -2.5rem;
  border: 2px dashed rgba(175,49,1,.3);
  border-radius: 3rem;
  transform: rotate(-6deg);
  z-index: -1;
}

/* =========================================================
   32. Page Design — Réalisations Bento Grid
   ========================================================= */
.design-works {
  padding-block: var(--s20);
  background: var(--clr-s1);
}

.design-works__header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: var(--s10);
}

.design-works__title { margin-bottom: var(--s3); }

.design-works__desc {
  color: var(--clr-subtle);
  max-width: 44ch;
}

.design-works__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: var(--s5);
  height: 600px;
}

.design-work-item {
  border-radius: var(--r-md);
  overflow: hidden;
  position: relative;
  group: true;
}

.design-work-item--large {
  grid-column: span 2;
  grid-row: span 2;
}

.design-work-item--top-right {
  grid-column: span 2;
}

.design-work-item__img-wrap {
  position: absolute;
  inset: 0;
}

.design-work-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}

.design-work-item:hover .design-work-item__img { transform: scale(1.05); }

.design-work-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.6) 0%, transparent 55%);
  opacity: 0;
  transition: opacity .3s ease;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--s5);
  color: white;
}

.design-work-item:hover .design-work-item__overlay { opacity: 1; }

.design-work-item__title { font-family: var(--ff-head); font-weight: 700; font-size: 1.0625rem; }
.design-work-item__sub { font-size: .8125rem; opacity: .8; margin-top: .2rem; }

/* =========================================================
   33. Page Design — Process
   ========================================================= */
.design-process {
  padding-block: var(--s20);
  background: var(--clr-bg);
}

.design-process__header {
  text-align: center;
  margin-bottom: var(--s16);
}

.design-process__title { margin-bottom: var(--s4); }

.design-process__desc { color: var(--clr-subtle); }

.design-process__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s8);
  position: relative;
}

.design-process__deco {
  position: absolute;
  top: 2rem;
  left: 16.67%;
  right: 16.67%;
  height: 2px;
  background-image: repeating-linear-gradient(
    to right,
    var(--clr-primary-light) 0,
    var(--clr-primary-light) 8px,
    transparent 8px,
    transparent 16px
  );
}

.design-process__step {
  background: var(--clr-s2);
  border: 1px solid var(--clr-s4);
  border-radius: 3rem;
  padding: var(--s10);
  box-shadow: 0 24px 48px rgba(30,28,6,.04);
  position: relative;
  z-index: 1;
}

.design-process__step--offset {
  margin-top: -2rem;
}

.design-process__number {
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: var(--clr-primary);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--ff-head);
  font-size: 1.25rem;
  font-weight: 900;
  margin-bottom: var(--s8);
}

.design-process__step-title { margin-bottom: var(--s3); font-size: 1.125rem; }

.design-process__step-desc { color: var(--clr-subtle); font-size: .9375rem; line-height: 1.7; }

/* =========================================================
   34. Page Design — CTA Dark
   ========================================================= */
.design-cta {
  padding: var(--s16) var(--gutter);
  margin-bottom: var(--s20);
}

.design-cta__inner {
  max-width: var(--max-w);
  margin-inline: auto;
  background: linear-gradient(135deg, var(--clr-primary), var(--clr-primary-light));
  border-radius: 3rem;
  padding: var(--s16) var(--s12);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s12);
}

.design-cta__content { flex: 1; }

.design-cta__title {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  color: white;
  margin-bottom: var(--s5);
}

.design-cta__desc {
  color: rgba(255,255,255,.9);
  font-size: 1.0625rem;
  margin-bottom: var(--s8);
}

.design-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s4);
}

.design-cta__portrait { flex-shrink: 0; }

.design-cta__avatar-wrap {
  width: 12rem;
  height: 12rem;
  border-radius: 50%;
  border: 4px solid var(--clr-primary);
  overflow: hidden;
  padding: 3px;
  background: var(--clr-s3);
}

.design-cta__avatar {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  filter: grayscale(100%);
}

/* =========================================================
   35. Page Design — Tarifs
   ========================================================= */
.design-pricing {
  padding-block: var(--s20);
  background: var(--clr-bg);
}

.design-pricing__header {
  text-align: center;
  margin-bottom: var(--s12);
}

.design-pricing__title { margin-bottom: var(--s4); }

.design-pricing__desc { color: var(--clr-subtle); }

.design-pricing__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s6);
  align-items: start;
}

.pricing-card {
  background: var(--clr-s1);
  border-radius: var(--r-lg);
  padding: var(--s8);
  display: flex;
  flex-direction: column;
  gap: var(--s6);
  height: 100%;
}

.pricing-card--featured {
  background: var(--clr-text);
  color: var(--clr-bg);
  transform: translateY(-1rem);
  box-shadow: 0 32px 64px rgba(30,28,6,.2);
}

.pricing-card__badge {
  display: inline-block;
  background: linear-gradient(135deg, var(--clr-primary), var(--clr-primary-light));
  color: white;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .25rem .875rem;
  border-radius: var(--r-full);
  margin-bottom: var(--s2);
}

.pricing-card__header { display: flex; flex-direction: column; gap: var(--s2); }

.pricing-card__name {
  font-family: var(--ff-head);
  font-size: 1.25rem;
  font-weight: 700;
}

.pricing-card--featured .pricing-card__name { color: var(--clr-bg); }

.pricing-card__price { font-size: .9375rem; color: var(--clr-subtle); }

.pricing-card--featured .pricing-card__price { color: rgba(255,250,227,.7); }

.pricing-card__price strong {
  display: block;
  font-size: 1.625rem;
  font-family: var(--ff-head);
  color: var(--clr-primary-light);
}

.pricing-card__list {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  flex: 1;
}

.pricing-card__list li {
  padding-left: var(--s6);
  position: relative;
  font-size: .9375rem;
  line-height: 1.55;
}

.pricing-card__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .55em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--clr-primary-light);
}

.pricing-card--featured .pricing-card__list li { color: rgba(255,250,227,.85); }

.pricing-card__cta { align-self: flex-start; }


@media (max-width: 1023px) {
  .design-hero__inner,
  .design-cta__inner  { grid-template-columns: 1fr; }

  .design-works__grid { 
    height: auto; 
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }
  
  .design-work-item {
    min-height: 280px;
    aspect-ratio: 4/3;
  }
  
  .design-work-item--large,
  .design-work-item--top-right { grid-column: span 2; grid-row: auto; }

  .design-process__grid { grid-template-columns: 1fr; }
  .design-process__step--offset { margin-top: 0; }
  .design-process__deco { display: none; }

  .design-pricing__grid { grid-template-columns: 1fr; }
  .pricing-card--featured { transform: none; }
}

@media (max-width: 767px) {
  .design-works__grid { 
    grid-template-columns: 1fr; 
    grid-template-rows: auto;
    height: auto;
  }
  
  .design-work-item {
    min-height: 300px;
    aspect-ratio: 4/3;
  }
  
  .design-work-item--large,
  .design-work-item--top-right { 
    grid-column: span 1; 
    grid-row: auto;
  }

  .design-cta__inner { flex-direction: column; text-align: center; }
  .design-cta__portrait { margin-inline: auto; }
}