/* ============================================================
 * THE JOURNAL -- Blog landing + destination archive
 * Direction A "Gilded Editorial"
 *
 * Loaded by inc/haven-blog.php on is_home() and is_tax('destination').
 * Everything is scoped to .haven-journal so it never touches the
 * rest of the theme. Brand values mirror theme.json.
 * ========================================================== */

.haven-journal{
  --j-ink:#111C26;
  --j-ink-deep:#0B131B;
  --j-gold:#B89A62;
  --j-gold-soft:#D7C39B;
  --j-gold-deep:#8F7648;
  --j-paper:#FBF9F4;
  --j-paper-2:#F3EFE6;
  --j-stone:#6F7680;
  --j-rule:rgba(17,28,38,.13);
  --j-rule-soft:rgba(17,28,38,.07);
  --j-serif:"Playfair Display",Georgia,"Times New Roman",serif;
  --j-sans:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;

  background:var(--j-paper);
  color:var(--j-ink);
  font-family:var(--j-sans);
  font-size:16px;
  overflow-x:clip;
}
.haven-journal *{box-sizing:border-box}
.haven-journal img{max-width:100%;display:block}
.haven-journal a{color:inherit}
.haven-journal ::selection{background:var(--j-gold-soft)}

/* ---- shared atoms ---- */
.haven-journal__diamond{
  width:1em;height:1em;display:inline-block;vertical-align:-.12em;color:var(--j-gold);
}
.haven-journal__eyebrow{
  font-family:var(--j-sans);font-size:11px;font-weight:700;
  letter-spacing:.24em;text-transform:uppercase;color:var(--j-gold-deep);
}
.haven-journal__dot{
  width:3px;height:3px;border-radius:50%;background:var(--j-gold);
  display:inline-block;flex:none;
}

/* photo placeholder -- fallback when a post has no featured image */
.haven-journal__ph{
  display:block;width:100%;height:100%;
  background:linear-gradient(150deg,#cab98f,#8f7648 54%,#241f15);
  position:relative;overflow:hidden;
}
.haven-journal__ph::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse at 50% 120%,rgba(0,0,0,.32),transparent 60%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  background-size:cover,140px 140px;mix-blend-mode:overlay;opacity:.85;
}

/* ============================================================
 * MASTHEAD
 * ========================================================== */
.haven-journal__masthead{
  text-align:center;
  padding:clamp(40px,6vw,64px) 24px clamp(34px,5vw,46px);
}
.haven-journal__wm{
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-size:10px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--j-gold-deep);font-weight:700;
}
.haven-journal__wm a{text-decoration:none}
.haven-journal__flourish{
  display:flex;align-items:center;justify-content:center;gap:16px;margin:18px 0 6px;
}
.haven-journal__flourish span{height:1px;width:68px;background:var(--j-gold);display:block}
.haven-journal__flourish .haven-journal__diamond{width:13px;height:13px}
.haven-journal__name{
  font-family:var(--j-serif);font-weight:500;color:var(--j-ink);
  font-size:clamp(2.6rem,6vw,5rem);line-height:1.02;margin:0;letter-spacing:.005em;
}
.haven-journal__dek{
  font-family:var(--j-serif);font-style:italic;color:var(--j-stone);
  font-size:clamp(15px,1.5vw,18px);line-height:1.6;
  margin:20px auto 0;max-width:520px;
}

/* ============================================================
 * FULL-BLEED FEATURED HERO
 * ========================================================== */
.haven-journal__hero{
  position:relative;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  width:100vw;
  min-height:clamp(440px,72vh,720px);
  display:flex;align-items:flex-end;
  overflow:hidden;background:var(--j-ink);color:#fff;
}
.haven-journal__hero-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:1;
}
.haven-journal__hero-scrim{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(180deg,rgba(11,19,27,.12) 0%,rgba(11,19,27,.5) 56%,rgba(11,19,27,.9) 100%);
}
.haven-journal__hero-inner{
  position:relative;z-index:3;width:100%;
  max-width:1320px;margin:0 auto;
  padding:0 clamp(20px,5vw,56px) clamp(38px,6vw,72px);
}
.haven-journal__hero-band{max-width:720px;animation:haven-journal-rise .8s both}
.haven-journal__hero .haven-journal__eyebrow{color:var(--j-gold-soft)}
.haven-journal__hero-title{
  font-family:var(--j-serif);font-weight:600;line-height:1.07;
  font-size:clamp(2.1rem,4.6vw,3.9rem);margin:.3em 0 .34em;letter-spacing:-.01em;
}
.haven-journal__hero-title a{text-decoration:none;transition:color .2s}
.haven-journal__hero-title a:hover{color:var(--j-gold-soft)}
.haven-journal__hero-dek{
  font-size:clamp(15px,1.5vw,18px);line-height:1.6;color:#e4e7ea;max-width:560px;margin:0;
}
.haven-journal__hero-meta{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:22px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:#cdd3d8;
}
.haven-journal__hero-link{
  display:inline-flex;align-items:center;gap:10px;margin-top:24px;
  font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:#fff;text-decoration:none;border-bottom:1px solid var(--j-gold);
  padding-bottom:6px;transition:gap .25s,color .2s;
}
.haven-journal__hero-link:hover{gap:16px;color:var(--j-gold-soft)}

/* ============================================================
 * DESTINATION FILTER
 * ========================================================== */
.haven-journal__filter{
  max-width:1320px;margin:0 auto;
  padding:clamp(30px,4vw,40px) clamp(20px,5vw,56px) 6px;
  text-align:center;
}
.haven-journal__filter-label{
  display:block;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--j-stone);margin-bottom:15px;
}
.haven-journal__chips{
  display:flex;flex-wrap:wrap;gap:9px;justify-content:center;
}
.haven-journal__chip{
  font-family:var(--j-sans);font-size:12px;font-weight:700;letter-spacing:.07em;
  text-transform:uppercase;color:var(--j-ink);text-decoration:none;
  border:1px solid var(--j-rule);border-radius:30px;padding:9px 17px;
  transition:border-color .2s,color .2s,background-color .2s;
}
.haven-journal__chip:hover,
.haven-journal__chip:focus-visible{border-color:var(--j-gold);color:var(--j-gold-deep)}
.haven-journal__chip.is-active{background:var(--j-ink);color:#fff;border-color:var(--j-ink)}
.haven-journal__chip.is-active:hover{color:var(--j-gold-soft)}

/* ============================================================
 * STORY GRID
 * ========================================================== */
.haven-journal__gridwrap{
  max-width:1320px;margin:0 auto;
  padding:clamp(30px,4vw,40px) clamp(20px,5vw,56px) 16px;
}
.haven-journal__sectlabel{
  display:flex;align-items:center;gap:18px;margin:6px 0 32px;
}
.haven-journal__sectlabel em{
  font-family:var(--j-serif);font-style:italic;font-size:18px;color:var(--j-ink);
  flex:none;
}
.haven-journal__sectlabel span{height:1px;background:var(--j-rule);flex:1}
.haven-journal__grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px 34px;
}

/* card */
.haven-journal__card{
  display:flex;flex-direction:column;background:transparent;
}
.haven-journal__card-img{
  display:block;position:relative;aspect-ratio:4/3;
  border-radius:3px;overflow:hidden;margin-bottom:18px;
  background:var(--j-paper-2);
}
.haven-journal__card-img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .6s ease;
}
.haven-journal__card-img .haven-journal__ph{position:absolute;inset:0}
.haven-journal__card:hover .haven-journal__card-img img{transform:scale(1.05)}
.haven-journal__card-body{display:flex;flex-direction:column;flex:1}
.haven-journal__card-tag{
  font-size:10.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--j-gold-deep);text-decoration:none;margin-bottom:10px;
}
.haven-journal__card-tag:hover{color:var(--j-ink)}
.haven-journal__card-title{
  font-family:var(--j-serif);font-weight:600;font-size:1.5rem;line-height:1.22;
  margin:0 0 10px;color:var(--j-ink);
}
.haven-journal__card-title a{text-decoration:none;transition:color .2s}
.haven-journal__card:hover .haven-journal__card-title a{color:var(--j-gold-deep)}
.haven-journal__card-dek{
  font-size:14px;line-height:1.62;color:var(--j-stone);margin:0 0 16px;
}
.haven-journal__card-meta{
  margin-top:auto;padding-top:13px;border-top:1px solid var(--j-rule-soft);
  display:flex;align-items:center;gap:11px;flex-wrap:wrap;
  font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--j-stone);
}
.haven-journal__byline{color:var(--j-ink);font-weight:700}
.haven-journal__card-meta time{color:inherit}

/* empty state */
.haven-journal__empty{
  text-align:center;padding:70px 20px;
}
.haven-journal__empty h2{
  font-family:var(--j-serif);font-weight:500;font-size:1.9rem;color:var(--j-ink);margin:0 0 10px;
}
.haven-journal__empty p{color:var(--j-stone);font-size:15px;margin:0}

/* ============================================================
 * PAGINATION (the_posts_pagination output)
 * ========================================================== */
.haven-journal .pagination{
  max-width:1320px;margin:0 auto;
  padding:26px clamp(20px,5vw,56px) 54px;
}
.haven-journal .pagination .nav-links{
  display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;
}
.haven-journal .pagination .page-numbers{
  min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;
  padding:0 6px;font-size:13px;font-weight:700;color:var(--j-ink);text-decoration:none;
  border:1px solid var(--j-rule);border-radius:50%;
  transition:border-color .2s,color .2s,background-color .2s;
}
.haven-journal .pagination .page-numbers:hover{border-color:var(--j-gold);color:var(--j-gold-deep)}
.haven-journal .pagination .page-numbers.current{
  background:var(--j-ink);color:#fff;border-color:var(--j-ink);
}
.haven-journal .pagination .page-numbers.dots{border-color:transparent}
.haven-journal .pagination .page-numbers.prev,
.haven-journal .pagination .page-numbers.next{
  border-radius:24px;padding:0 22px;letter-spacing:.14em;
  text-transform:uppercase;font-size:11px;
}

/* ============================================================
 * DESTINATION ARCHIVE HEADER
 * ========================================================== */
.haven-journal__archive-head{
  text-align:center;background:var(--j-paper-2);
  border-bottom:1px solid var(--j-rule-soft);
  padding:clamp(44px,6vw,70px) 24px clamp(34px,4vw,46px);
}
.haven-journal__archive-head .haven-journal__wm{margin-bottom:20px}
.haven-journal__archive-head .haven-journal__eyebrow{display:block;margin-bottom:12px}
.haven-journal__archive-head .haven-journal__name{font-size:clamp(2.3rem,5vw,3.8rem)}
.haven-journal--archive .haven-journal__dek{margin-top:16px}
.haven-journal__count{
  margin:18px 0 0;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--j-gold-deep);font-weight:700;
}

/* ============================================================
 * NEWSLETTER BAND  (wraps templates/partials/newsletter-signup.php)
 * ========================================================== */
.haven-journal__news{
  background:var(--j-paper-2);
  border-top:1px solid var(--j-rule-soft);
  padding:clamp(48px,6vw,66px) clamp(20px,5vw,56px);
  text-align:center;
}
.haven-journal__news-inner{max-width:560px;margin:0 auto}
.haven-journal__news-inner > .haven-journal__diamond{
  width:20px;height:20px;margin-bottom:6px;
}
.haven-journal__news .haven-newsletter{margin:0}
.haven-journal__news .haven-newsletter-heading{
  font-family:var(--j-serif);font-weight:500;
  font-size:clamp(1.7rem,3vw,2.4rem);line-height:1.16;
  color:var(--j-ink);margin:8px 0 12px;
}
.haven-journal__news .haven-newsletter-desc{
  color:var(--j-stone);font-size:14.5px;line-height:1.65;margin:0 auto 24px;max-width:460px;
}
.haven-journal__news .haven-newsletter-fields{
  display:flex;gap:10px;max-width:440px;margin:0 auto;
}
.haven-journal__news .haven-newsletter-input-wrapper{flex:1}
.haven-journal__news .haven-newsletter-fields input[type="email"]{
  width:100%;border:1px solid var(--j-rule);background:#fff;border-radius:3px;
  padding:14px 16px;font-family:var(--j-sans);font-size:14px;color:var(--j-ink);
}
.haven-journal__news .haven-newsletter-fields input[type="email"]::placeholder{color:#9ba2a8}
.haven-journal__news .haven-btn{
  background:var(--j-ink);color:#fff;border:0;border-radius:3px;cursor:pointer;
  padding:0 26px;min-height:48px;
  font-family:var(--j-sans);font-size:11px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  transition:background-color .2s;
}
.haven-journal__news .haven-btn:hover{background:var(--j-gold-deep)}
.haven-journal__news .haven-newsletter-consent{
  margin-top:14px;font-size:12px;color:var(--j-stone);line-height:1.5;
}
.haven-journal__news .haven-newsletter-consent label{
  display:flex;gap:8px;align-items:flex-start;justify-content:center;
}
.haven-journal__news .haven-newsletter-consent a{color:var(--j-gold-deep)}
.haven-journal__news .haven-newsletter-messages{
  margin-top:12px;font-size:13px;
}
.haven-journal__news .haven-honeypot{
  position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;
}

/* ============================================================
 * MOTION
 * ========================================================== */
@keyframes haven-journal-rise{
  from{opacity:0;transform:translateY(22px)}
  to{opacity:1;transform:none}
}
@media(prefers-reduced-motion:reduce){
  .haven-journal__hero-band{animation:none}
  .haven-journal__card-img img,
  .haven-journal__chip,
  .haven-journal__hero-link{transition:none}
}

/* ============================================================
 * RESPONSIVE
 * ========================================================== */
@media(max-width:900px){
  .haven-journal__grid{grid-template-columns:1fr 1fr;gap:34px 26px}
}
@media(max-width:560px){
  .haven-journal__grid{grid-template-columns:1fr;gap:36px}
  .haven-journal__news .haven-newsletter-fields{flex-direction:column}
  .haven-journal__news .haven-btn{padding:14px 26px}
  .haven-journal__sectlabel em{font-size:16px}
}
