/* ============================================================
   KZ HOMEPAGE — horizontal nav + hero image + topic cubes
   ============================================================ */

/* ── Horizontal Navigation ─────────────────────────────────── */
.hp-topbar{
  position: sticky; top: 0; z-index: 50;
  background: linear-gradient(180deg, rgba(11,31,58,.96), rgba(11,31,58,.88));
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(212,176,122,.22);
}
.hp-topbar-inner{
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 10px clamp(12px, 2vw, 28px);
  padding-top: max(10px, env(safe-area-inset-top));
}
.hp-brand{
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  color: #d4b07a;
  flex-shrink: 0;
}
.hp-brand-star{
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(241,213,151,.15), rgba(212,176,122,.08));
  border: 1px solid rgba(212,176,122,.35);
  display: grid; place-items: center;
  color: #f1d597;
}
.hp-brand-star svg{ width: 20px; height: 20px; }
.hp-brand-text{
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 700;
  font-size: 15px;
  line-height: 1.2;
  white-space: nowrap;
}
.hp-brand-sub{
  display: block;
  font-family: 'Heebo', sans-serif;
  font-size: 10px;
  font-weight: 400;
  color: rgba(212,176,122,.6);
  letter-spacing: .06em;
}

.hp-nav-wrap{
  flex: 1;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  mask-image: linear-gradient(to left, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
  -webkit-mask-image: linear-gradient(to left, transparent 0, #000 24px, #000 calc(100% - 24px), transparent 100%);
}
.hp-nav-wrap::-webkit-scrollbar{ display: none; }

.hp-nav{
  display: flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  padding: 2px 16px;
}
.hp-nav a{
  padding: 6px 12px;
  color: rgba(246,230,194,.75);
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  transition: background .2s, color .2s;
  text-decoration: none;
  flex-shrink: 0;
}
.hp-nav a:hover{
  background: rgba(212,176,122,.12);
  color: #f1d597;
}
.hp-nav a.is-active{
  background: rgba(212,176,122,.18);
  color: #f1d597;
  font-weight: 700;
}
.hp-nav-sep{
  width: 1px;
  height: 18px;
  background: rgba(212,176,122,.2);
  flex-shrink: 0;
  margin: 0 4px;
}

.hp-login{
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  background: linear-gradient(135deg, rgba(212,176,122,.2), rgba(241,213,151,.1));
  border: 1px solid rgba(212,176,122,.4);
  border-radius: 999px;
  color: #f1d597;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: background .2s, transform .15s;
  white-space: nowrap;
}
.hp-login:hover{
  background: linear-gradient(135deg, rgba(212,176,122,.3), rgba(241,213,151,.18));
  transform: translateY(-1px);
}

/* Mobile hamburger for small screens */
.hp-hamburger{
  display: none;
  width: 40px; height: 40px;
  background: rgba(212,176,122,.12);
  border: 1px solid rgba(212,176,122,.3);
  border-radius: 10px;
  cursor: pointer;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  flex-shrink: 0;
}
.hp-hamburger span{
  display: block;
  width: 18px; height: 2px;
  background: #d4b07a;
  border-radius: 2px;
}

@media (max-width: 860px){
  .hp-nav-wrap{ display: none; }
  .hp-hamburger{ display: inline-flex; }
  .hp-login span:last-child{ display: none; }
  .hp-nav{
    flex-wrap: wrap;
    gap: 2px;
  }
  .hp-nav a{
    padding: 8px 14px;
    font-size: 14px;
  }
}

/* ── Hero Section ──────────────────────────────────────────── */
.hp-hero{
  position: relative;
  min-height: clamp(380px, 55vh, 620px);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.hp-hero-img{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center 30%;
  z-index: 0;
}
.hp-hero::after{
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg,
      rgba(11,31,58,.35) 0%,
      rgba(11,31,58,.15) 30%,
      rgba(11,31,58,.25) 60%,
      rgba(11,31,58,.7) 100%);
  z-index: 1;
  pointer-events: none;
}
.hp-hero-content{
  position: relative;
  z-index: 2;
  text-align: center;
  padding: clamp(20px, 4vw, 48px);
  max-width: 900px;
}
.hp-hero-title{
  font-family: 'Frank Ruhl Libre', serif;
  font-size: clamp(42px, 7vw, 86px);
  font-weight: 900;
  line-height: 1.05;
  color: #fff;
  text-shadow: 0 4px 40px rgba(0,0,0,.5), 0 1px 3px rgba(0,0,0,.4);
  margin: 0 0 16px;
  letter-spacing: -.02em;
}
.hp-hero-sub{
  font-family: 'Heebo', sans-serif;
  font-size: clamp(16px, 2vw, 22px);
  color: rgba(255,255,255,.88);
  text-shadow: 0 2px 16px rgba(0,0,0,.4);
  margin: 0 0 28px;
  font-weight: 400;
}
.hp-hero-cta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 32px;
  background: linear-gradient(135deg, #D4B07A, #B8935A);
  color: #0B1F3A;
  border-radius: 999px;
  font-family: 'Heebo', sans-serif;
  font-weight: 800;
  font-size: 16px;
  text-decoration: none;
  box-shadow: 0 12px 36px rgba(184,147,90,.35);
  transition: transform .2s, box-shadow .25s;
}
.hp-hero-cta:hover{
  transform: translateY(-3px);
  box-shadow: 0 18px 48px rgba(184,147,90,.45);
  color: #0B1F3A;
}

/* ── Main Content Shell ────────────────────────────────────── */
.hp-shell{
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 clamp(12px, 2vw, 28px) 60px;
}

/* ── Section Titles ────────────────────────────────────────── */
.hp-section{
  margin-top: clamp(32px, 4vw, 52px);
}
.hp-section-title{
  font-family: 'Frank Ruhl Libre', serif;
  font-size: clamp(22px, 2.5vw, 30px);
  font-weight: 700;
  color: #f1d597;
  margin: 0 0 18px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.hp-section-title::before{
  content: '';
  width: 4px;
  height: 24px;
  background: linear-gradient(180deg, #f1d597, rgba(212,176,122,.3));
  border-radius: 2px;
  flex-shrink: 0;
}

/* ── Topic Cubes ───────────────────────────────────────────── */
.hp-cubes{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}
.hp-cube{
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 200px;
  border-radius: 18px;
  overflow: hidden;
  text-decoration: none;
  color: #fff;
  border: 1px solid rgba(212,176,122,.2);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .3s;
}
.hp-cube:hover{
  transform: translateY(-6px) scale(1.01);
  box-shadow: 0 24px 48px rgba(0,0,0,.4);
}
.hp-cube-bg{
  position: absolute;
  inset: 0;
  z-index: 0;
  transition: transform .5s ease;
}
.hp-cube:hover .hp-cube-bg{
  transform: scale(1.06);
}
.hp-cube::after{
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 20%, rgba(11,31,58,.75) 100%);
  z-index: 1;
  pointer-events: none;
}
.hp-cube-body{
  position: relative;
  z-index: 2;
  padding: 18px;
}
.hp-cube-icn{
  font-size: 28px;
  margin-bottom: 6px;
  filter: drop-shadow(0 2px 8px rgba(0,0,0,.4));
}
.hp-cube-title{
  font-family: 'Frank Ruhl Libre', serif;
  font-weight: 700;
  font-size: 18px;
  color: #f1d597;
  line-height: 1.2;
  margin-bottom: 3px;
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
}
.hp-cube-desc{
  font-size: 12px;
  color: rgba(255,255,255,.75);
  line-height: 1.4;
}

/* Cube gradient themes */
.hp-cube--prayer .hp-cube-bg{ background: linear-gradient(135deg, #1a3a2e, #2d6b4f); }
.hp-cube--candle .hp-cube-bg{ background: linear-gradient(135deg, #4a2800, #b45309); }
.hp-cube--family .hp-cube-bg{ background: linear-gradient(135deg, #2a1a3e, #6b3fa0); }
.hp-cube--world .hp-cube-bg{ background: linear-gradient(135deg, #0a2a4a, #1e5a8a); }
.hp-cube--learning .hp-cube-bg{ background: linear-gradient(135deg, #1a2a0a, #4a7a2a); }
.hp-cube--memorial .hp-cube-bg{ background: linear-gradient(135deg, #1a1a2a, #3a3a5a); }
.hp-cube--morning .hp-cube-bg{ background: linear-gradient(135deg, #3a2a0a, #8a6a2a); }
.hp-cube--tehilim .hp-cube-bg{ background: linear-gradient(135deg, #0a1a3a, #1a3a6a); }
.hp-cube--stories .hp-cube-bg{ background: linear-gradient(135deg, #2a1a1a, #6a3a3a); }
.hp-cube--soldiers .hp-cube-bg{ background: linear-gradient(135deg, #0a2a1a, #2a5a4a); }
.hp-cube--recipes .hp-cube-bg{ background: linear-gradient(135deg, #3a2a1a, #7a5a3a); }
.hp-cube--kids .hp-cube-bg{ background: linear-gradient(135deg, #1a0a3a, #4a2a7a); }
.hp-cube--rights .hp-cube-bg{ background: linear-gradient(135deg, #3a1a0a, #7a3a1a); }
.hp-cube--donate .hp-cube-bg{ background: linear-gradient(135deg, #3a0a2a, #8a2a5a); }
.hp-cube--travelers .hp-cube-bg{ background: linear-gradient(135deg, #0a3a3a, #2a6a6a); }
.hp-cube--simchas .hp-cube-bg{ background: linear-gradient(135deg, #3a3a0a, #7a7a2a); }
.hp-cube--health .hp-cube-bg{ background: linear-gradient(135deg, #0a2a2a, #1a6a5a); }
.hp-cube--security .hp-cube-bg{ background: linear-gradient(135deg, #2a0a0a, #6a2a2a); }
.hp-cube--employment .hp-cube-bg{ background: linear-gradient(135deg, #1a2a3a, #3a5a7a); }
.hp-cube--culture .hp-cube-bg{ background: linear-gradient(135deg, #2a1a2a, #5a3a6a); }
.hp-cube--holocaust .hp-cube-bg{ background: linear-gradient(135deg, #1a1a1a, #2a2a3a); }
.hp-cube--realestate .hp-cube-bg{ background: linear-gradient(135deg, #2a2a1a, #5a5a3a); }
.hp-cube--education .hp-cube-bg{ background: linear-gradient(135deg, #1a2a2a, #3a6a5a); }
.hp-cube--kashrut .hp-cube-bg{ background: linear-gradient(135deg, #2a1a0a, #6a4a2a); }
.hp-cube--calendar .hp-cube-bg{ background: linear-gradient(135deg, #1a1a3a, #3a3a7a); }

/* ── Quick Actions Row ─────────────────────────────────────── */
.hp-actions{
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}
.hp-action{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px 12px;
  border-radius: 16px;
  text-align: center;
  text-decoration: none;
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  transition: transform .2s, box-shadow .25s;
  min-height: 110px;
  border: 1px solid rgba(212,176,122,.25);
}
.hp-action:hover{
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 16px 36px rgba(0,0,0,.35);
}
.hp-action-icn{
  font-size: 32px;
  margin-bottom: 6px;
  filter: drop-shadow(0 0 10px rgba(255,255,255,.25));
}
.hp-action--pray{ background: linear-gradient(160deg, #166534, #16a34a); }
.hp-action--candle{ background: linear-gradient(160deg, #92400e, #fbbf24); }
.hp-action--give{ background: linear-gradient(160deg, #831843, #db2777); }
.hp-action--soldiers{ background: linear-gradient(160deg, #1e3a8a, #3b82f6); }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 540px){
  .hp-cubes{
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .hp-cube{
    min-height: 160px;
  }
  .hp-cube-title{ font-size: 15px; }
  .hp-cube-desc{ font-size: 11px; }
  .hp-actions{
    grid-template-columns: 1fr 1fr;
  }
  .hp-hero{
    min-height: 320px;
  }
  .hp-hero-title{
    font-size: clamp(32px, 8vw, 48px);
  }
}

@media (max-width: 380px){
  .hp-cubes{
    grid-template-columns: 1fr;
  }
}

/* ── Footer ────────────────────────────────────────────────── */
.hp-footer{
  margin-top: 60px;
  padding: 28px clamp(12px, 3vw, 28px);
  background: rgba(11,31,58,.6);
  border-top: 1px solid rgba(212,176,122,.15);
  text-align: center;
}
.hp-footer-brand{
  font-family: 'Frank Ruhl Libre', serif;
  font-size: 18px;
  font-weight: 700;
  color: #d4b07a;
  margin-bottom: 4px;
}
.hp-footer-copy{
  font-size: 12px;
  color: rgba(212,176,122,.5);
}
