/**
 * index.css — styles scoped à la page d'accueil
 * Chargé automatiquement par Arcane pour /
 */

/* =========================================================
   Utilitaires responsive
   ========================================================= */

/* Affiche le titre desktop et cache le mobile par défaut */
.hero__title--desktop {
  display: block;
}

.hero__title--mobile {
  display: none;
}

/* Sur mobile, inverse : cache desktop et affiche mobile */
@media (max-width: 767px) {
  .hero__title--desktop {
    display: none;
  }
  
  .hero__title--mobile {
    display: block;
  }
}

/* =========================================================
   Journey path – chemin de lecture guidé entre les sections
   ========================================================= */

.page-journey {
  position: relative;
}

.journey-path__svg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
  overflow: visible;
}

/* Tracé en pointillé principal */
.journey-path__line {
  fill: none;
  stroke: var(--clr-primary-light);
  stroke-width: 5;
  stroke-dasharray: 0.1 20;
  stroke-linecap: round;
}

@media (max-width: 767px) {
  .journey-path__svg { display: none; }
}

/* =========================================================
   Hero
   ========================================================= */
.hero {
  position: relative;
  min-height: calc(100vh - 64px);
  display: flex;
  align-items: center;
}

.hero__bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.hero__bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .3;
}

.hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, var(--clr-bg) 10%, transparent 80%);
}

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

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

.hero__title {
  margin-bottom: var(--s6);
  font-size: clamp(2rem, 4vw, 3.5rem);
}

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

.hero__title-mobile {
  margin-bottom: var(--s6);
  font-size: clamp(2rem, 4vw, 3.5rem);
}


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

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

.hero__visual {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: var(--s12);
}

.hero__visual-img-wrap {
  border-radius: 2rem;
  overflow: hidden;
  transform: rotate(3deg);
  box-shadow: 0 32px 64px rgba(30,28,6,.15);
  transition: transform .4s ease;
  width: 100%;
}

.hero__visual-img-wrap:hover { transform: rotate(0); }

.hero__visual-img-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

/* =========================================================
   Sections services (2 colonnes image + texte)
   ========================================================= */
.service-section {
  padding-block: var(--s20);
  background: var(--clr-bg);
}

.service-section--alt { background: var(--clr-s1); }

.service-section__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s16);
  align-items: center;
}

.service-section__media-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s4);
}

.service-section__col {
  display: flex;
  flex-direction: column;
  gap: var(--s4);
}

.service-section__col--top { padding-top: var(--s8); }

.service-card-img {
  border-radius: var(--r-md);
  overflow: hidden;
  background: var(--clr-s3);
}

.service-card-img img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

.service-card-img:hover img {
  transform: scale(1.2);
}

.service-section__eyebrow {
  display: block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--s4);
}

.service-section__title { margin-bottom: var(--s5); }

.service-section__title em {
  font-style: normal;
  color: var(--clr-primary-light);
}

.service-section__desc {
  color: var(--clr-subtle);
  margin-bottom: var(--s6);
  font-size: 1rem;
}

.service-section__list {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  margin-bottom: var(--s8);
}

.service-section__list li {
  padding-left: var(--s6);
  position: relative;
  font-weight: 600;
  font-size: .9375rem;
}

.service-section__list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: .5em;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--clr-primary-light);
}

.service-section__btn-container {
  display: flex;
  flex-direction: column;
  gap: var(--s4);
}

.service-section__btn-container .btn { width: fit-content; }

/* =========================================================
   Section Photographie (accueil — 3 cards)
   ========================================================= */
.photo-section {
  padding-block: var(--s20);
  background: var(--clr-bg);
}

.photo-section__header {
  text-align: center;
  margin-bottom: var(--s12);
}

.photo-section__eyebrow {
  display: block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--s3);
}

.photo-section__title-accent { color: var(--clr-primary-light); }

.photo-section__intro {
  color: var(--clr-subtle);
  max-width: 52ch;
  margin-inline: auto;
  margin-top: var(--s4);
}

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

.photo-card {
  border-radius: var(--r-lg);
  overflow: hidden;
}

.photo-card--offset { margin-top: 4rem; }
.photo-card--mid-offset { margin-top: 2rem; }

.photo-card__img-wrap {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
}

.photo-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .6s ease;
}

.photo-card:hover .photo-card__img { transform: scale(1.05); }

.photo-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.7) 0%, transparent 60%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--s6);
  color: white;
}

.photo-card__title {
  font-family: var(--ff-head);
  font-size: 1.125rem;
  font-weight: 700;
  margin-bottom: var(--s1, .25rem);
}

.photo-card__sub { font-size: .875rem; opacity: .85; }

/* =========================================================
   Section Web Strategy (accueil)
   ========================================================= */
.web-section {
  padding: var(--s16) var(--gutter);
  margin: var(--s16) var(--gutter);
  margin-bottom: 0px;
  background: var(--clr-s1);
  border-radius: 3rem;
}

.web-section__inner {
  max-width: var(--max-w);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s12);
  align-items: center;
}

.web-section__eyebrow {
  display: block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--s4);
}

.web-section__title { margin-bottom: var(--s5); }

.web-section__title span {
  color: var(--clr-primary-light);
}

.web-section__desc {
  color: var(--clr-subtle);
  margin-bottom: var(--s8);
}

.web-section__cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s4);
  margin-bottom: var(--s8);
}

.web-mini-card {
  background: var(--clr-text);
  color: white;
  border-radius: var(--r-md);
  padding: var(--s5);
}

.web-mini-card__label {
  display: block;
  font-family: var(--ff-head);
  font-weight: 700;
  font-size: .9375rem;
  margin-bottom: var(--s2);
}

.web-mini-card__desc {
  font-size: .875rem;
  color: rgba(255,255,255,.70);
}

.web-section__visual { display: flex; justify-content: center; }

.web-section__glass {
  border-radius: var(--r-lg);
  overflow: hidden;
  width: 100%;
  min-height: 280px;
}

.web-section__visual-img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  display: block;
}

/* =========================================================
   Témoignages
   ========================================================= */
.testimonials {
  padding-block: var(--s20);
  background: var(--clr-bg);
}

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

.testimonials__eyebrow {
  display: block;
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--s3);
}

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

.testimonial {
  background: var(--clr-s1);
  border-radius: var(--r-lg);
  padding: var(--s8);
  position: relative;
}

.testimonial--offset { margin-top: -2rem; }

.testimonial__icon {
  font-size: 3rem;
  color: var(--clr-primary-light);
  opacity: .4;
  line-height: 1;
  display: block;
  margin-bottom: var(--s1);
}

.testimonial__text {
  font-size: .9375rem;
  line-height: 1.7;
  color: var(--clr-muted);
  margin-bottom: var(--s6);
}

.testimonial__footer {
  display: flex;
  gap: var(--s3);
}

.testimonial__avatar {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
  background: var(--clr-s3);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--clr-primary);
  font-weight: 700;
}

.testimonial__author { font-weight: 700; font-size: .9375rem; }

.testimonial__role {
  font-size: .8125rem;
  color: var(--clr-subtle);
}

.testimonial__source {
  font-size: .75rem;
  color: var(--clr-subtle);
  opacity: .85;
}

/* =========================================================
   Grille projets
   ========================================================= */
.projects {
  padding-block: var(--s20);
  background: var(--clr-text);
}

.projects__header h2 {
  color: var(--clr-bg);
}

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

.projects__link {
  font-size: .9375rem;
  font-weight: 700;
  color: var(--clr-primary-light);
}

.projects__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: auto auto;
  gap: var(--s4);
}

.project-item {
  border-radius: var(--r-md);
  overflow: hidden;
  position: relative;
}

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

.project-item--wide { grid-column: span 2; }

.project-item__img-wrap {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 200px;
}

.project-item--large .project-item__img-wrap { min-height: 400px; }

.project-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .5s ease;
  position: absolute;
  inset: 0;
}

.project-item:hover .project-item__img { transform: scale(1.04); }

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

.project-item:hover .project-item__overlay { opacity: 1; }

.project-item__tag {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  opacity: .85;
  margin-bottom: .25rem;
}

.project-item__title {
  font-family: var(--ff-head);
  font-size: 1rem;
  font-weight: 700;
}

/* =========================================================
   CTA gradient (accueil)
   ========================================================= */
.cta-section {
  padding: var(--s16) var(--gutter);
  margin: var(--s16) var(--gutter);
}

.cta-section__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);
  text-align: center;
  position: relative;
  overflow: hidden;
  color: white;
}

.cta-section__deco {
  position: absolute;
  top: 0;
  right: 0;
  width: 200px;
  height: 200px;
  color: rgba(255,255,255,.25);
}

.cta-section__title {
  font-size: clamp(1.75rem, 4vw, 2.75rem);
  color: white;
  margin-bottom: var(--s8);
}

.cta-section__desc {
  font-size: 1.0625rem;
  color: rgba(255,255,255,.9);
  margin-bottom: var(--s8);
  max-width: 48ch;
  margin-inline: auto;
  text-align: center;
}

.cta-section__actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s4);
  justify-content: center;
}

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 1023px) {
  .testimonials__grid { grid-template-columns: repeat(2, 1fr); }
  .projects__grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 767px) {
  .hero__inner { grid-template-columns: 1fr; }
  .hero { min-height: auto; padding-block: var(--s16); }

  .service-section__inner,
  .web-section__inner { grid-template-columns: 1fr; }
  .service-section__media-grid { grid-template-columns: 1fr 1fr; }

  .photo-section__grid { grid-template-columns: 1fr; }
  .photo-card--offset,
  .photo-card--mid-offset { margin-top: 0; }

  .testimonials__grid { grid-template-columns: 1fr; }
  .testimonial--offset { margin-top: 0; }

  .projects__grid { grid-template-columns: 1fr; }
  .project-item--large,
  .project-item--wide { grid-column: span 1; grid-row: auto; }

  .cta-section { margin-inline: var(--s4); }
  .cta-section__inner { padding: var(--s10) var(--s6); }
}
