/* RESET */
*{ box-sizing:border-box; }
html,body{ height:100%; margin:0; }
body{
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background:#f5f6f7;
  overflow:hidden;
  color:#111;
}

/* FULLSCREEN */
.frame{
  width:100vw;
  height:100vh;
  position:relative;
  overflow:hidden;
  background:#f5f6f7;
}

/* DOTTED BG */
.dots{
  position:absolute;
  inset:0;
  opacity:.55;
  background-image: radial-gradient(circle at 1px 1px, rgba(0,0,0,.14) 1px, transparent 1px);
  background-size: 22px 22px;
}

/* CONTENT */
.content{
  position:relative;
  height:100%;
  padding:22px;
  display:flex;
  flex-direction:column;
  gap:18px;
}

/* TOPBAR */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
}

.nav a{
  margin-left:22px;
  text-decoration:none;
  font-size:13px;
  color:rgba(0,0,0,.70);
}
.nav a:hover{ color:#000; }

/* BENTO GRID — EXACTEMENT comme la capture */
.bento{
  flex:1;
  display:grid;
  gap:16px;
  grid-template-columns: 2fr 1fr 1fr;  /* gauche large + 2 colonnes */
  grid-template-rows: 1fr 1fr;         /* 2 lignes */
  min-height:0;
}

/* CARDS */
.card{
  position:relative;
  border-radius:26px;
  padding:22px;
  border:1px solid rgba(0,0,0,.08);
  box-shadow: 0 16px 45px rgba(0,0,0,.10);
  text-decoration:none;
  color:inherit;
  overflow:hidden;
  transition: transform .18s ease, box-shadow .18s ease;
}
.card:hover{
  transform: translateY(-2px);
  box-shadow: 0 24px 70px rgba(0,0,0,.14);
}

.cardHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}

.cardBody{
  position:relative;
  z-index:2;
}

/* TYPO */
.kicker{
  margin:0;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  line-height:1.25;
}
.kicker.light{ color:rgba(255,255,255,.72); }
.kicker.dark{ color:rgba(0,0,0,.55); }

.heroTitle{
  margin:0;
  font-size:56px;
  line-height:1.03;
  letter-spacing:-.02em;
  font-weight:750;
}

.bigTitle{
  margin:0;
  font-size:34px;
  font-weight:700;
  letter-spacing:-.02em;
}

/* bottom titles like screenshot */
.bottomTitleWrap{
  position:absolute;
  left:22px;
  right:22px;
  bottom:18px;
  z-index:2;
}
.bottomTitle{
  margin:0;
  font-size:36px;
  font-weight:750;
  letter-spacing:-.02em;
}
.bottomTitle.soft{ color:rgba(255,255,255,.65); }

/* Icons */
.cornerIcon{
  width:30px; height:30px;
  border-radius:12px;
  display:grid;
  place-items:center;
  color:rgba(0,0,0,.7);
}
.miniIcon{
  width:40px; height:40px;
  border-radius:14px;
  display:grid;
  place-items:center;
  color:#fff;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.10);
}

/* HERO (gauche grand) */
.hero{
  grid-column: 1 / 2;
  grid-row: 1 / 3; /* ✅ sur 2 lignes */
  background: linear-gradient(180deg, #1c1c1c 0%, #101010 100%);
  color:#fff;
  border-color: rgba(255,255,255,.10);
}

.heroCTA{
  position:absolute;
  left:22px;
  right:22px;
  bottom:22px;      /* CTA collée en bas */
  top:auto;         /* annule toute ancienne valeur */
  padding:16px 18px;
  border-radius:16px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.10);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  z-index:2;        /* sous l’image */
}

.ctaKicker{
  margin:0;
  font-size:10px;
  letter-spacing:.14em;
  text-transform:uppercase;
  opacity:.85;
}
.ctaTitle{
  margin:10px 0 0 0;
  font-size:14px;
  font-weight:650;
}

/* ARTICLES (haut droite long) */
.articles{
  grid-column: 2 / 4; /* ✅ long sur 2 colonnes */
  grid-row: 1 / 2;
  background:#dfe2e6;
}

/* A PROPOS (bas droite carré gauche) */
.apropos{
  grid-column: 2 / 3;
  grid-row: 2 / 3;
  background:#b88bff;
}

/* CONTACT (bas droite carré droite) */
.contact{
  grid-column: 3 / 4;
  grid-row: 2 / 3;
  background:#baff2a;
}

/* IMAGES — plus grosses + coupées pour l’effet */
.img{
  position:absolute;
  pointer-events:none;
  user-select:none;
  filter: drop-shadow(0 22px 45px rgba(0,0,0,.18));
}

/* PROJETS: gros, déborde */
.heroImg{
  right: -120px;        /* déborde encore plus à droite */
  bottom: -40px;        /* ✅ REMONTÉE : passe au-dessus de la CTA */
  width: 720px;         /* ✅ plus grand */
  transform: rotate(-8deg);
  opacity: .95;
  z-index: 3;           /* ✅ AU-DESSUS de la CTA */
}

/* ARTICLES: gros, déborde à droite */
.articlesImg{
  right: -120px;        /* déborde beaucoup plus à droite */
  bottom: -80px;        /* descend un peu */
  width: 600px;         /* ✅ beaucoup plus grand */
  transform: rotate(-6deg);
  opacity: .95;
  z-index:1;            /* reste derrière le texte */
}

/* A PROPOS: pion plus gros, à droite */
.aproposImg{
  right: -40px;
  bottom: -20px;
  width: 320px;       /* ✅ plus gros */
  transform: rotate(-10deg);
  opacity:.95;
}

/* CONTACT: wave centrée, déborde */
.contactImg{
  left: 55%;
  bottom: -50px;
  width: 520px;       /* ✅ plus gros */
  transform: translateX(-50%) rotate(6deg);
  opacity:.95;
}

/* RESPONSIVE */
@media (max-width: 980px){
  .nav{ display:none; }
  body{ overflow:auto; }
  .frame{ height:auto; min-height:100vh; }

  .bento{
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }
  .hero{ grid-column:auto; grid-row:auto; min-height:520px; }
  .articles{ grid-column:auto; grid-row:auto; min-height:260px; }
  .apropos{ grid-column:auto; grid-row:auto; min-height:220px; }
  .contact{ grid-column:auto; grid-row:auto; min-height:220px; }

  .heroImg{ width:420px; right:-40px; bottom:-60px; }
  .articlesImg{ width:360px; right:-30px; }
  .aproposImg{ width:260px; right:-30px; }
  .contactImg{ width:420px; bottom:-40px; }
}

.logo{
  width:28px;                 /* ajuste si besoin */
  height:auto;
  display:block;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,.25));
}

.articles .cardBody{
  position:absolute;
  left:22px;
  right:22px;
  bottom:18px;
  z-index:2;
}
