/* --- Fonts --- */
@font-face{
  font-family: 'NinLocal';
  src: local('Nin.otf'); /* police "Nin" installée sur l'ordinateur de l'utilisatrice */
  font-weight: 400 700;
  font-style: normal;
  font-display: swap;
}
:root{
  --bg-dark: #0D0D0D;
  --ivory: #FCFCFC;
  --red: #BA0B0B;
  --blue: #0014BD;

  --gutter: 48px;
  --max-width: 1200px;
}

/* --- Reset minimal --- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Helvetica, Arial, sans-serif;
  background:var(--ivory);
  color:var(--bg-dark);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.45;
}

/* --- Page wrapper --- */
header{
  position:fixed;left:0;right:0;top:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 28px;background:transparent;
  pointer-events:none;
}
.brand{font-family:'NinLocal', Helvetica, Arial, sans-serif; font-size:20px;letter-spacing:0.06em;pointer-events:auto}
nav{pointer-events:auto}
nav a{color:var(--bg-dark);text-decoration:none;margin-left:18px;font-weight:600}

/* --- Marquee / texte qui défile --- */
.marquee{position:fixed;bottom:10px;left:0;right:0;z-index:55;pointer-events:none}
.marquee__inner{white-space:nowrap;overflow:hidden}
.marquee__track{display:inline-block;padding-left:100%;animation:marquee 28s linear infinite}
@keyframes marquee{from{transform:translateX(0)} to{transform:translateX(-50%)}}
.marquee span{display:inline-block;padding:0 4rem;font-weight:700;letter-spacing:0.12em}

/* --- Fullscreen hero stack --- */
main{margin-top:0}
.hero-stack{min-height:100vh;display:flex;flex-direction:column}

.project-full{
  position:relative;min-height:100vh;display:flex;align-items:flex-end;justify-content:flex-start;
  background-size:cover;background-position:center center;overflow:hidden;
}
/* transition dégradé au blanc entre sections */
.project-full::after{
  content:'';position:absolute;left:0;right:0;bottom:0;height:35vh;
  background:linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(252,249,229,1) 65%);
  pointer-events:none;
}
.project-overlay{
  position:relative;z-index:3;padding:48px;max-width:640px;color:var(--bg-dark);
  backdrop-filter: blur(0.5px);
}

/* Hover summary card */
.project-tile{
  width:100%;height:100%;position:absolute;left:0;top:0;cursor:pointer;
}
.project-info{
  position:absolute;left:0;top:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(6%);transition:all .35s cubic-bezier(.2,.9,.3,1);
  pointer-events:none;z-index:4
}
.project-tile:hover .project-info{opacity:1;transform:translateY(0);pointer-events:auto}
.project-card{background:rgba(255,255,255,0.92);border-radius:8px;padding:22px;max-width:520px;box-shadow:0 8px 24px rgba(0,0,0,0.08)}
.project-card h3{margin:0 0 8px 0;font-size:20px}
.project-card p{margin:0 0 12px 0;color:rgba(0,0,0,0.7)}
.project-card .cta{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;border:2px solid var(--bg-dark);text-decoration:none;color:var(--bg-dark);font-weight:700}

/* --- About section --- */
section.about{padding:120px 24px;background:var(--ivory);display:flex;align-items:flex-start;justify-content:center}
.container{max-width:var(--max-width);width:100%;padding:0 var(--gutter)}
.about-grid{display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}
.about h2{font-size:36px;margin:0 0 12px 0}
.about p{color:rgba(0,0,0,0.8)}
.links a{display:inline-block;margin-right:12px;padding:10px 14px;border-radius:8px;border:1px solid var(--bg-dark);text-decoration:none}

/* --- More projects grid (3x3) --- */
.projects{padding:120px 24px;background:linear-gradient(180deg, rgba(252,249,229,1) 0%, rgba(252,249,229,1) 100%)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1200px;margin:0 auto}
.grid .card{position:relative;aspect-ratio:1/1;background-size:cover;background-position:center;overflow:hidden;border-radius:8px;cursor:pointer}
.grid .card::after{content:'';position:absolute;left:0;right:0;bottom:0;height:40%;background:linear-gradient(to bottom, rgba(255,255,255,0) 0%, rgba(252,249,229,1) 100%)}
.grid .meta{position:absolute;left:16px;bottom:16px;background:rgba(255,255,255,0.96);padding:10px;border-radius:6px}

/* --- Blog section --- */
.blog{padding:120px 24px;background:var(--ivory)}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:40px;align-items:start}
.post{padding:20px;border-radius:8px;border:1px dashed rgba(0,0,0,0.06);background:transparent;cursor:pointer}
.post .date{font-weight:700;color:var(--blue);display:block;margin-bottom:12px}
.post h4{margin:0}

/* --- Footer / contacts --- */
footer{padding:48px 24px;background:var(--bg-dark);color:var(--ivory)}
.footer-inner{max-width:var(--max-width);margin:0 auto;display:flex;justify-content:space-between;gap:20px;align-items:center}

/* --- Controls / visual vocabulary: lines/dots/rounded boxes/arrows --- */
.vocab{display:flex;gap:12px;align-items:center}
.line{width:40px;height:2px;background:var(--bg-dark)}
.dot{width:8px;height:8px;border-radius:50%;background:var(--bg-dark)}
.rounded-box{padding:8px 12px;border-radius:12px;border:2px solid var(--bg-dark)}
.arrow{width:18px;height:18px;border-right:2px solid var(--bg-dark);border-top:2px solid var(--bg-dark);transform:rotate(45deg)}

/* --- Responsive tweaks --- */
@media (max-width:900px){
  .about-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:repeat(2,1fr)}
  .brand{font-size:18px}
}
@media (max-width:520px){
  .grid{grid-template-columns:1fr}
  .brand{font-size:16px}
  .project-card{padding:14px}
  .about{padding:80px 18px}
}
