/* ============================================
   HnK Party — Layout: Container, Section, Footer, Responsive
   ============================================ */

/* ===== Layout primitives ===== */
/* ===== Layout ===== */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.section { padding: 80px 0; }
.section-sm { padding: 48px 0; }
.section-title { font-size: 36px; text-align: center; margin-bottom: 12px; }
.section-subtitle { text-align: center; color: var(--muted); max-width: 600px; margin: 0 auto 48px; }

/* ===== Footer ===== */
/* ===== Footer ===== */
.footer { background: var(--charcoal); color: #d9c9b7; padding: 60px 0 24px; }

/* Newsletter strip in footer */
.newsletter-inner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 32px;
  align-items: center;
}
.newsletter-form {
  display: flex; gap: 10px;
}
.newsletter-input {
  flex: 1;
  padding: 12px 18px;
  border-radius: 999px;
  border: 0;
  font-family: var(--sans);
  font-size: 14px;
  background: rgba(255,255,255,0.95);
  color: var(--charcoal);
  min-width: 0;
}
.newsletter-input::placeholder { color: var(--muted); }
.newsletter-btn {
  padding: 12px 22px;
  background: var(--gold);
  color: var(--charcoal);
  border: 0;
  border-radius: 999px;
  font-family: var(--sans);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  white-space: nowrap;
  transition: transform 0.15s, background 0.2s;
}
.newsletter-btn:hover {
  background: #d9c08e;
  transform: translateY(-1px);
}
@media (max-width: 800px) {
  .newsletter-inner { grid-template-columns: 1fr; gap: 22px; }
  .newsletter-strip { padding: 28px 24px !important; }
  .newsletter-strip h3 { font-size: 22px !important; }
}
@media (max-width: 500px) {
  .newsletter-form { flex-direction: column; }
  .newsletter-btn { width: 100%; }
}
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 40px; }
.footer h4 { color: var(--cream); font-family: var(--sans); font-size: 13px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 16px; }
.footer ul { list-style: none; }
.footer ul li { margin-bottom: 8px; font-size: 14px; }
.footer ul li a { transition: color 0.2s; }
.footer ul li a:hover { color: var(--terracotta); }
.footer-bottom { padding-top: 24px; border-top: 1px solid var(--charcoal-soft); text-align: center; font-size: 13px; color: #fff; }
.footer-bottom a { color: #fff; text-decoration: none; transition: color 0.2s; }
.footer-bottom a:hover { color: var(--terracotta); }
.footer-bottom span { color: var(--gold); }


/* ===== Responsive ===== */
/* ===== Responsive ===== */
@media (max-width: 900px) {
  .nav-links { display: none; position: fixed; top: 80px; left: 0; right: 0; bottom: 0; background: var(--cream); flex-direction: column; padding: 24px 20px; gap: 8px; z-index: 95; overflow-y: auto; box-shadow: 0 6px 18px rgba(43,37,32,0.10); }
  .nav-links.open { display: flex; }
  /* Tighten the wishlist button on mobile so the hamburger has room */
  .cart-btn span:first-child { display: none; }
  .cart-btn { padding: 6px 10px; }
  .hamburger { display: block; }
  .hero-title { font-size: 38px; }
  .page-hero h1 { font-size: 38px; overflow-wrap: break-word; }
  .page-hero { padding: 60px 0 50px; }
  .page-hero p { font-size: 16px; }
  .section { padding: 56px 0; }
  .section-title { font-size: 28px; }

  .features-grid, .steps, .testimonial-grid { grid-template-columns: 1fr; gap: 24px; }
  .category-grid { grid-template-columns: 1fr; }
  .product-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-grid { grid-template-columns: 1fr; gap: 32px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .form-row { grid-template-columns: 1fr; }
  .product-detail { grid-template-columns: 1fr; gap: 32px; }
  .package-grid { grid-template-columns: 1fr; }
  .catalog-layout { grid-template-columns: 1fr; gap: 24px; }
}

@media (max-width: 500px) {
  .page-hero h1 { font-size: 30px; }
  .product-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .hero { padding: 60px 0 80px; }
  .hero-title { font-size: 32px; }
  .hero-subtitle { font-size: 16px; }
}

