/* ======================================================
   JOURNEYHAVEN.CLICK — SITE STYLES
   Colors & tokens (use exactly as provided)
   Headings: #fe6539  (with text border)
   Text: #ffcabb
   Accents: #fe6539
   Buttons: #fe6539
   Button text: #0d121c
   Button hover: #ffcabb
   Active links: #fe6539
   Background: #0d121c
   Prefix: journeyhaven-click-*
   Font: Space Grotesk (fallbacks provided)
   ====================================================== */

:root{
  --jh-bg: #0d121c;
  --jh-heading: #fe6539;
  --jh-text: #ffcabb;
  --jh-accent: #fe6539;
  --jh-btn-text: #0d121c;
  --jh-btn-hover: #ffcabb;
  --jh-border: rgba(254,101,57,0.15);
  --jh-radius: 12px;
  --jh-soft: rgba(255,202,187,0.06);
}

/* ---------- Base ---------- */
*{box-sizing:border-box}
body.journeyhaven-click{
  margin:0;
  background:var(--jh-bg);
  color:var(--jh-text);
  font-family: "Space Grotesk", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.6;
}

/* links */
a{ color:var(--jh-accent); text-decoration:none; transition:color .25s ease, text-shadow .25s ease; }
a:hover{ color:var(--jh-btn-hover); text-shadow:0 0 10px rgba(255,202,187,0.12) }

/* ---------- NAVBAR ---------- */
.journeyhaven-click-nav{
  background: rgba(13,18,28,0.95);
  border-bottom: 1px solid rgba(255, 101, 57, 0.06);
  padding: .8rem 0;
  position: sticky; top:0; z-index:1100;
  backdrop-filter: blur(6px);
}

.journeyhaven-click-logo{ height:80px; transition: transform .25s ease; }
.journeyhaven-click-brand:hover .journeyhaven-click-logo{ transform: scale(1.03); }

.journeyhaven-click-navlist .nav-link{
  color:var(--jh-text);
  font-weight:600;
  margin:0 .6rem;
  padding:.45rem .6rem;
  transition: color .2s ease, background .2s ease;
  border-radius:6px;
}

.journeyhaven-click-navlist .nav-link:hover{ color:var(--jh-btn-hover); background: rgba(255,202,187,0.03); }

.journeyhaven-click-navlist .nav-link.active{
  color:var(--jh-accent);
  position: relative;
  font-weight:700;
}
.journeyhaven-click-navlist .nav-link.active::after{
  content:"";
  display:block;
  height:3px;
  width:26px;
  background:var(--jh-accent);
  margin:6px auto 0;
  border-radius:3px;
}

/* toggler */
.navbar-toggler{ border: none; background: rgba(254,101,57,0.08); color:var(--jh-accent); padding:.35rem .6rem; border-radius:8px; }
.navbar-toggler:hover{ background: rgba(255,202,187,0.12); color:var(--jh-btn-text) }

/* ---------- HERO ---------- */
.journeyhaven-click-hero{
  min-height:90vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding: 6rem 1.25rem;
  background:
    linear-gradient(180deg, rgba(13,18,28,0.1), rgba(13,18,28,0.2)),
    url('../images/hero.jpg') center/cover no-repeat;
  position:relative;
}

.journeyhaven-click-hero .hero-inner{ max-width:850px; padding:0 18px; z-index:2; }

.hero-title{
  color:var(--jh-heading);
  font-size:2.8rem;
  font-weight:700;
  margin-bottom:14px;
  letter-spacing:0.6px;
  text-shadow: 0 0 12px rgba(254,101,57,0.12);
  /* text border effect */
  -webkit-text-stroke: 1px rgba(0,0,0,0.25);
}

.hero-copy{
  color:var(--jh-text);
  max-width:760px;
  margin:0 auto 22px;
  font-size:1.05rem;
  line-height:1.8;
}

/* CTA */
.journeyhaven-click-cta{
  display:inline-block;
  background: linear-gradient(180deg,var(--jh-accent),#fb6b3f);
  color:var(--jh-btn-text);
  padding: .85rem 1.6rem;
  border-radius: 999px;
  font-weight:700;
  box-shadow: 0 6px 28px rgba(254,101,57,0.12), inset 0 -4px 12px rgba(0,0,0,0.18);
  transition: transform .18s ease, box-shadow .18s ease;
}
.journeyhaven-click-cta:hover{
  transform: translateY(-3px);
  background: linear-gradient(180deg,var(--jh-btn-hover),#ffcabb);
  color:var(--jh-bg);
  box-shadow: 0 12px 36px rgba(255,202,187,0.22);
}

/* ---------- NOTICE ---------- */
.journeyhaven-click-notice{ padding:64px 20px; }
.notice-box{
  max-width:900px;
  margin:0 auto;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border:1px solid var(--jh-border);
  border-radius:var(--jh-radius);
  padding:34px;
  box-shadow: 0 6px 30px rgba(13,18,28,0.5);
}
.notice-title{ color:var(--jh-accent); font-size:1.4rem; margin-bottom:0.5rem; font-weight:700; }
.notice-text{ color:var(--jh-text); font-size:1.02rem; line-height:1.7; margin-bottom:18px; }
.journeyhaven-click-ghost{
  background: transparent;
  border: 2px solid var(--jh-accent);
  color: var(--jh-accent);
  padding: .6rem 1.25rem;
  border-radius: 999px;
  font-weight:700;
  transition: background .2s ease, color .2s ease, box-shadow .2s ease;
}
.journeyhaven-click-ghost:hover{
  background: var(--jh-accent);
  color: var(--jh-btn-text);
  box-shadow: 0 10px 30px rgba(254,101,57,0.12);
}

/* ---------- PLAY SECTION (Main frame 900px, 16:9) ---------- */
.journeyhaven-click-play{ padding:72px 16px; }
.journeyhaven-click-play .container{ max-width:950px; margin:0 auto; }

.section-title{ color:var(--jh-heading); font-size:2rem; margin-bottom:18px; font-weight:700; text-shadow:0 0 8px rgba(254,101,57,0.06); }
.journeyhaven-click-main-frame{
  width:100%;
  max-width:900px;
  aspect-ratio:16/9;
  margin:0 auto;
  border-radius:12px;
  overflow:hidden;
  background:#0b0f16;
  border:1px solid rgba(255,101,57,0.08);
  box-shadow: 0 10px 40px rgba(0,0,0,0.6);
}
.journeyhaven-click-main-frame iframe{ width:100%; height:100%; border:0; display:block; }

/* Thumbnails 200px wide 16:10 */
.journeyhaven-click-selector{ display:flex; justify-content:center; gap:16px; margin-top:22px; flex-wrap:wrap; }
.journeyhaven-click-thumb{
  width:200px;
  aspect-ratio:16/10;
  object-fit:cover;
  border-radius:10px;
  border:2px solid transparent;
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease, filter .18s ease;
  box-shadow:0 6px 18px rgba(0,0,0,0.5);
  filter:brightness(.86);
  cursor:pointer;
}
.journeyhaven-click-thumb:hover{ transform:translateY(-4px); filter:brightness(1); border-color:rgba(255,202,187,0.28); box-shadow:0 12px 30px rgba(254,101,57,0.08); }
.journeyhaven-click-thumb.active{ border-color:var(--jh-accent); box-shadow:0 14px 40px rgba(254,101,57,0.12); filter:brightness(1) }

/* ---------- FEATURES ---------- */
.journeyhaven-click-features{ padding:82px 16px; background: linear-gradient(180deg, rgba(255,255,255,0.01), transparent); }
.journeyhaven-click-features .container{ max-width:1100px; }
.journeyhaven-click-features .section-subtitle{ color: var(--jh-text); max-width:760px; margin: 0 auto 30px; }

.journeyhaven-click-features-grid{
  display:flex; justify-content:center; gap:26px; align-items:stretch; flex-wrap:wrap;
}
.journeyhaven-click-feature{
  flex: 1 1 240px;
  min-width:230px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border:1px solid var(--jh-border);
  border-radius:14px;
  padding:28px;
  text-align:center;
  transition: transform .22s ease, box-shadow .22s ease;
}
.journeyhaven-click-feature:hover{ transform:translateY(-6px); box-shadow:0 20px 50px rgba(254,101,57,0.06); border-color: rgba(255,202,187,0.18); }
.feature-icon{ font-size:1.8rem; color:var(--jh-accent); margin-bottom:12px; }
.feature-title{ color:var(--jh-heading); font-weight:700; margin-bottom:8px; }
.feature-text{ color:var(--jh-text); font-size:0.98rem; line-height:1.7; }

/* ---------- ABOUT ---------- */
.journeyhaven-click-about{ padding:84px 16px; }
.about-grid{ display:flex; gap:36px; align-items:center; justify-content:center; flex-wrap:wrap; max-width:1100px; margin:0 auto; }
.about-media{ flex:1 1 420px; text-align:center; }
.about-image{ width:100%; max-width:520px; border-radius:14px; box-shadow:0 18px 60px rgba(254,101,57,0.06); transition: transform .35s ease; }
.about-image:hover{ transform:scale(1.02); }
.about-content{ flex:1 1 420px; text-align:left; color:var(--jh-text); }
.about-subtitle{ color:var(--jh-accent); font-weight:700; letter-spacing:1px; margin-bottom:10px; text-transform:uppercase; }
.about-title{ color:var(--jh-heading); font-size:2rem; margin-bottom:12px; }

/* CTA variant in about */
.journeyhaven-click-cta{
  display:inline-block; margin-top:12px;
  background:var(--jh-accent); color:var(--jh-btn-text);
  padding:.7rem 1.4rem; border-radius:10rem; font-weight:800; box-shadow:0 8px 30px rgba(254,101,57,0.12);
}
.journeyhaven-click-cta:hover{ background:var(--jh-btn-hover); color:var(--jh-bg); transform:translateY(-3px); box-shadow:0 12px 40px rgba(255,202,187,0.18) }

/* ---------- REVIEWS ---------- */
.journeyhaven-click-reviews{ padding:82px 16px; background: linear-gradient(180deg, rgba(255,255,255,0.01), transparent); }
.journeyhaven-click-reviews .container{ max-width:1100px; }
.journeyhaven-click-reviews-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:22px; margin-top:20px; }

.review-card{
  background: rgba(255,255,255,0.02);
  border:1px solid var(--jh-border);
  border-radius:14px; padding:20px; text-align:left; box-shadow:0 10px 30px rgba(0,0,0,0.6);
}
.review-header{ display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.avatar{ width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--jh-accent),#ff8a5c); display:flex; align-items:center; justify-content:center; color:var(--jh-btn-text); font-weight:800; box-shadow:0 6px 20px rgba(254,101,57,0.08); }
.review-text{ color:var(--jh-text); font-style:italic; }

/* ---------- CONTACT ---------- */
.journeyhaven-click-contact{ padding:86px 16px; background: linear-gradient(180deg, rgba(255,255,255,0.01), transparent); }
.journeyhaven-click-contact .container{ max-width:1100px; }
.journeyhaven-click-contact-form{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius:14px; padding:28px; border:1px solid var(--jh-border); margin-top:18px; box-shadow:0 12px 40px rgba(0,0,0,0.5);
}
.journeyhaven-click-input{
  background: rgba(255,255,255,0.02); border:1px solid rgba(254,101,57,0.06); color:var(--jh-text); border-radius:8px; padding:.8rem .9rem;
}
.journeyhaven-click-input:focus{ outline:none; border-color:var(--jh-accent); box-shadow:0 0 12px rgba(254,101,57,0.08); }

/* submit */
.journeyhaven-click-submit{
  background:var(--jh-accent); color:var(--jh-btn-text); padding:.8rem 1.6rem; border-radius:999px; font-weight:800; box-shadow:0 12px 40px rgba(254,101,57,0.12);
}
.journeyhaven-click-submit:hover{ background:var(--jh-btn-hover); color:var(--jh-bg); transform:translateY(-3px); }

/* ---------- FOOTER ---------- */
.journeyhaven-click-footer{ padding:56px 18px 40px; background: linear-gradient(180deg,#0a0d14 0%, var(--jh-bg) 100%); color:var(--jh-text); border-top:1px solid rgba(254,101,57,0.04); }
.journeyhaven-click-footer-logo{ max-width:150px; margin-bottom:18px; display:inline-block; }
.journeyhaven-click-footer-links{ gap:14px; margin-bottom:20px; }
.journeyhaven-click-footer-links a{ color:var(--jh-text); font-weight:600; }
.journeyhaven-click-footer-links a:hover{ color:var(--jh-accent); text-shadow:0 0 8px rgba(254,101,57,0.08) }

.footer-disclaimer{ max-width:900px; margin:0 auto 18px; padding:18px; background:rgba(255,255,255,0.01); border-radius:10px; border:1px solid var(--jh-border); color:var(--jh-text) }
.disclaimer-title{ color:var(--jh-accent); font-weight:800; margin-bottom:6px }
.disclaimer-text{ color:var(--jh-text); font-size:.95rem; line-height:1.7; }

/* divider & credit */
.footer-divider{ border-top:1px solid rgba(255,255,255,0.04); margin:20px auto; width:85%; }
.footer-credit{ color: rgba(255,202,187,0.7); font-size:.9rem; }

/* ---------- POPUP ---------- */
.journeyhaven-click-popup{
  position:fixed; inset:0; display:flex; align-items:center; justify-content:center; background:rgba(13,18,28,0.9); z-index:2000; visibility:hidden; opacity:0; transition: opacity .24s ease, visibility .24s ease;
}
.journeyhaven-click-popup.active{ visibility:visible; opacity:1; }
.journeyhaven-click-popup-inner{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border-radius:14px; padding:28px; max-width:640px; border:1px solid var(--jh-border); box-shadow:0 30px 80px rgba(0,0,0,0.7);
}
.popup-title{ color:var(--jh-accent); font-size:1.4rem; margin-bottom:8px }
.popup-text{ color:var(--jh-text); line-height:1.8; margin-bottom:16px }
.popup-actions{ display:flex; gap:12px; justify-content:center; }

/* popup buttons */
.journeyhaven-click-accept{
  background:var(--jh-accent); color:var(--jh-btn-text); padding:.6rem 1.2rem; border-radius:999px; font-weight:800;
}
.journeyhaven-click-exit{ background:transparent; color:var(--jh-text); border:1px solid rgba(255,202,187,0.06); padding:.6rem 1.2rem; border-radius:999px; }

/* ---------- SCROLL TOP ---------- */
.journeyhaven-click-scroll-top{
  position:fixed; right:24px; bottom:24px; width:46px; height:46px; border-radius:50%; background:linear-gradient(180deg,var(--jh-accent),#fb6b3f); color:var(--jh-btn-text); display:none; align-items:center; justify-content:center; cursor:pointer; z-index:1500; box-shadow:0 10px 30px rgba(254,101,57,0.12);
}
.journeyhaven-click-scroll-top.show{ display:flex; transform:translateY(0); animation: jhFadeIn .28s ease; }
@keyframes jhFadeIn{ from{ opacity:0; transform:translateY(8px) } to{ opacity:1; transform:translateY(0) } }

/* ---------- Responsive ---------- */
@media (max-width: 992px){
  .about-grid{ grid-template-columns:1fr; flex-direction:column; }
  .journeyhaven-click-feature{ min-width:200px }
  .journeyhaven-click-thumb{ width:160px }
  .hero-title{ font-size:2.2rem }
}

@media (max-width: 576px){
  .journeyhaven-click-thumb{ width:100% ; max-width:260px }
  .journeyhaven-click-main-frame{ max-width:100% }
  .journeyhaven-click-cta, .journeyhaven-click-submit { width:100% !important; padding-left:0; padding-right:0 }
  .journeyhaven-click-features-grid{ gap:14px; }
}

/* small accessibility improvements */
.visually-hidden{ position:absolute !important; height:1px; width:1px; overflow:hidden; clip:rect(1px,1px,1px,1px); white-space:nowrap }


/*--------------------------------------
  JOURNEYHAVEN.CLICK — LEGAL PAGES
---------------------------------------*/

.journeyhaven-click-legal-section {
  background-color: #0d121c;
  color: #ffcabb;
  padding: 100px 20px;
  font-family: "Inter", system-ui, sans-serif;
  line-height: 1.8;
}

.journeyhaven-click-legal-section .container {
  max-width: 900px;
  margin: 0 auto;
}

/* Headings */
.legal-title {
  color: #fe6539;
  font-size: 2.2rem;
  margin-bottom: 25px;
  text-align: center;
  text-shadow: 0 0 5px rgba(254, 101, 57, 0.4);
  border-bottom: 2px solid rgba(254, 101, 57, 0.4);
  padding-bottom: 10px;
}

.journeyhaven-click-legal-section h3 {
  color: #fe6539;
  font-size: 1.4rem;
  margin-top: 40px;
  margin-bottom: 10px;
  text-shadow: 0 0 4px rgba(254, 101, 57, 0.3);
}

/* Paragraphs */
.journeyhaven-click-legal-section p {
  color: #ffcabb;
  font-size: 1rem;
  margin-bottom: 20px;
  opacity: 0.9;
}

/* Strong emphasis */
.journeyhaven-click-legal-section strong {
  color: #fe6539;
}

/* Links (if any) */
.journeyhaven-click-legal-section a {
  color: #fe6539;
  text-decoration: underline;
  transition: color 0.3s ease;
}

.journeyhaven-click-legal-section a:hover {
  color: #ffcabb;
}

/* Responsive */
@media (max-width: 768px) {
  .journeyhaven-click-legal-section {
    padding: 70px 15px;
  }

  .legal-title {
    font-size: 1.8rem;
  }

  .journeyhaven-click-legal-section h3 {
    font-size: 1.2rem;
  }
}
