/* ========================= */
/* HERO */
/* ========================= */

.journal-hero{

  position:relative;

  height: var(--hero-height);
  min-height: var(--hero-min-height);

  display:flex;
  align-items:center;
  justify-content:center;

  text-align:center;

  overflow:hidden;

  background:
  url('../img/hero-journal-desktop.webp')
  center center / cover;
}

.journal-overlay{

  position:absolute;
  inset:0;

  background:
  linear-gradient(
    to bottom,
    rgba(0,0,0,0.55),
    rgba(0,0,0,0.45)
  );
}

.journal-hero-content{

  position:relative;
  z-index:2;

  color:white;

  width:min(900px, 92%);
}

.journal-hero-content h1{

  font-size:clamp(2.6rem, 6vw, 5rem);

  font-weight:300;

  margin:18px 0 22px;
}

.journal-hero-content p{

  color:rgba(255,255,255,0.78);

  font-size:1.1rem;

  line-height:1.8;
  
  margin-top:70px;
}

/* ========================= */
/* JOURNAL */
/* ========================= */

.journal-container{

  width:min(1000px, 92%);

  margin:auto;

  padding:100px 0;
}

.journal-timeline{

  display:flex;
  flex-direction:column;

  gap:32px;
}

.journal-card{

  position:relative;

  background:white;

  border-radius:30px;

  padding:40px;

  overflow:hidden;

  box-shadow:
  0 10px 35px rgba(0,0,0,0.05);

  transition:0.35s ease;
}

.journal-card::before{

  content:'';

  position:absolute;

  left:0;
  top:0;

  width:6px;
  height:100%;

  background:
  linear-gradient(
    to bottom,
    #d6a36a,
    #8f5e37
  );
}

.journal-card:hover{

  transform:translateY(-8px);

  box-shadow:
  0 20px 45px rgba(0,0,0,0.08);
}

.journal-card-top{

  display:flex;

  align-items:center;
  justify-content:space-between;

  gap:20px;

  margin-bottom:32px;

  flex-wrap:wrap;
}

.journal-week{

  background:#f5ede3;

  color:#8f5e37;

  padding:10px 18px;

  border-radius:999px;

  font-size:0.85rem;

  font-weight:600;

  letter-spacing:1px;

  text-transform:uppercase;
}

.journal-date{

  color:#9d8d80;

  font-size:0.92rem;
}

.journal-card-content{

  display:grid;

  grid-template-columns:1fr 1fr;

  gap:50px;
}

.journal-block h2{

  font-size:1.15rem;

  margin-bottom:16px;

  color:#2d241f;
}

.journal-block p{

  color:#5f544c;

  line-height:1.9;
}

.journal-block a{

  color:#b17743;

  text-decoration:none;

  font-weight:500;
}

.journal-block a:hover{

  text-decoration:underline;
}

/* ========================= */
/* LOADING / ERROR */
/* ========================= */

.loading,
.error{

  text-align:center;

  padding:80px 20px;

  color:#7a6b61;
}

/* ========================= */
/* REVEAL */
/* ========================= */

.reveal{

  opacity:0;

  transform:translateY(40px);

  transition:1s ease;
}

.reveal.active{

  opacity:1;

  transform:translateY(0);
}

/* ========================= */
/* MOBILE */
/* ========================= */

@media (max-width: 768px){

  .journal-hero{

    height:360px;
  }

  .journal-container{

    padding:70px 0;
  }

  .journal-card{

    padding:28px;
  }

  .journal-card-content{

    grid-template-columns:1fr;

    gap:32px;
  }

  .journal-card-top{

    align-items:flex-start;
  }

}