/* ================================================================
   AloraKai — pages/home.css
   ================================================================ */

/* ── Hero ──────────────────────────────────────────────────── */
.home-hero {
  position: relative;
  background: var(--kai-sand-light);
  min-height: 90vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  padding: 120px 0 80px;
}

.home-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}

.home-hero__title {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(3rem, 7.5vw, 7rem);
  line-height: 0.9;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--kai-midnight);
  margin: var(--space-5) 0 0;
}

.home-hero__title em {
  font-style: italic;
  font-family: var(--font-heading);
  color: var(--kai-tide);
  letter-spacing: -0.02em;
}

.home-hero__lead {
  color: var(--color-gray);
  margin-top: var(--space-6);
  max-width: 42ch;
}

.home-hero__cta {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}

.home-hero__visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
}

.home-hero__visual img {
  width: min(340px, 80%);
  position: relative;
  z-index: 2;
  filter: drop-shadow(0 1.5rem 2.5rem rgba(6, 22, 57, 0.18));
}

.home-hero__visual-ring {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  border: 1px solid rgba(34, 127, 148, 0.15);
  pointer-events: none;
}

.home-hero__visual-ring--1 { width: 300px; height: 300px; }
.home-hero__visual-ring--2 { width: 460px; height: 460px; border-color: rgba(34, 127, 148, 0.07); }

.home-hero__scroll-hint {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  font-family: var(--font-ui);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--kai-dune);
}

.home-hero__arrow { animation: home-arrow 1.2s ease-in-out infinite; }

@keyframes home-arrow {
  0%, 100% { transform: translateY(-2px); }
  50%       { transform: translateY(4px); }
}

/* ── Section headers ───────────────────────────────────────── */
.home-section-head { margin-bottom: var(--space-12); }

/* ── Categories grid ───────────────────────────────────────── */
.home-cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.home-cat-card {
  display: flex;
  flex-direction: column;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  color: var(--kai-midnight);
  transition: transform var(--dur-base) var(--ease-out-quart),
              box-shadow var(--dur-base) var(--ease-out-quart);
}

.home-cat-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}

.home-cat-card::before,
.home-cat-card::after { display: none; }

.home-cat-card__visual {
  width: 100%;
  aspect-ratio: 4 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
  color: var(--kai-sand-light);
  background: linear-gradient(135deg, var(--kai-midnight), var(--kai-tide));
}

.home-cat-card__visual--amber { background: linear-gradient(135deg, var(--kai-midnight), var(--kai-amber)); }
.home-cat-card__visual--dune  { background: linear-gradient(135deg, var(--kai-tide-80), var(--kai-dune)); }

.home-cat-card__body { padding: var(--space-8); flex: 1; }

.home-cat-card__cta {
  display: inline-block;
  margin-top: var(--space-6);
  padding: 6px 14px;
  font-size: 0.8rem;
}

/* ── Steps ─────────────────────────────────────────────────── */
.home-steps-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
  margin-top: var(--space-8);
}

.home-step {
  padding: var(--space-8);
  border-radius: var(--radius-xl);
  transition: transform var(--dur-base) var(--ease-out-quart),
              box-shadow var(--dur-base) var(--ease-out-quart);
}

.home-step:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }

.home-step__num {
  font-family: var(--font-heading);
  font-size: 1.6rem;
  color: var(--kai-tide);
}

/* ── Empty featured state ──────────────────────────────────── */
.home-products-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: clamp(var(--space-10), 8vw, 5rem);
  border-radius: var(--radius-2xl);
  border: 1px dashed rgba(227, 195, 159, 0.7);
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 960px) {
  .home-hero__inner {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .home-hero__cta { justify-content: center; }
  .home-hero__lead { margin-left: auto; margin-right: auto; }

  .home-hero__visual { order: -1; min-height: 240px; }
  .home-hero__visual-ring--2 { width: 280px; height: 280px; }
  .home-hero__visual-ring--1 { width: 190px; height: 190px; }

  .home-cat-grid { grid-template-columns: repeat(2, 1fr); }
  .home-steps-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .home-hero { min-height: auto; padding: 100px 0 60px; }
  .home-hero__cta { flex-direction: column; align-items: center; }
  .home-cat-grid { grid-template-columns: 1fr; }
}
