/* ============================================================
   SVATBY.CSS — Kavárna Karolína — Weddings & Cakes subpage
   Refactored: spacing system, visual rhythm, card surfaces
   ============================================================ */

/* ── Page Hero ──────────────────────────────────────────────── */

.svatby-hero {
  position: relative;
  min-height: calc(75svh - var(--nav-height));
  min-height: calc(75vh - var(--nav-height));
  display: flex;
  align-items: center;
  overflow: hidden;
  margin-top: var(--nav-height);
}

.svatby-hero__bg {
  position: absolute;
  inset: 0;
}

.svatby-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 35%;
}

.svatby-hero__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      to bottom,
      rgba(43, 29, 23, 0.20) 0%,
      rgba(43, 29, 23, 0.55) 60%,
      rgba(43, 29, 23, 0.82) 100%
    ),
    linear-gradient(
      110deg,
      rgba(43, 29, 23, 0.95) 0%,
      rgba(43, 29, 23, 0.65) 50%,
      rgba(43, 29, 23, 0.18) 100%
    );
}

.svatby-hero__content {
  position: relative;
  z-index: 1;
  color: var(--color-warm-white);
  padding-block: clamp(3rem, 6vh, 5rem);
  max-width: 720px;
}

.svatby-hero__content .hero__tagline {
  color: var(--color-caramel);
  font-style: italic;
  letter-spacing: 0.14em;
  margin-bottom: var(--space-4);
}

.svatby-hero__content h1 {
  color: var(--color-warm-white);
  margin-bottom: var(--space-6);
  line-height: 1.12;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.28);
}

.svatby-hero__content h1 em {
  color: var(--color-caramel);
  font-style: italic;
}

.svatby-hero__lead {
  font-size: var(--text-lg);
  color: var(--color-cream);
  max-width: 600px;
  opacity: 0.95;
  line-height: 1.85;
  margin-bottom: var(--space-8);
}

.svatby-hero__ctas {
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

/* ── Intro split: text + features ───────────────────────────── */

.svatby-intro-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
  align-items: start;
}

@media (min-width: 900px) {
  .svatby-intro-grid {
    grid-template-columns: 1fr 1fr;
    gap: clamp(3rem, 5vw, 5rem);  /* replaces broken --space-14 */
    align-items: center;
  }
}

.svatby-intro__text .section-label {
  margin-bottom: var(--space-2);
}

.svatby-intro__text h2 {
  margin-bottom: var(--space-5);
}

.svatby-intro__text p {
  color: var(--color-bark);
  line-height: 1.85;
  margin-bottom: var(--space-4);
  font-size: var(--text-base);
  max-width: 54ch;
}

.svatby-intro__text p:last-child {
  margin-bottom: 0;
}

/* ── Feature cards ──────────────────────────────────────────── */

.svatby-feature__icon {
  display: none;
}

@media (min-width: 900px) {
  .svatby-feature__icon {
    display: flex;
  }
}

.svatby-features {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}

@media (min-width: 600px) {
  .svatby-features {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-4);
  }
}

@media (min-width: 900px) {
  .svatby-features {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
}

.svatby-feature {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-5);
  min-width: 0;          /* prevent flex content from blowing out the grid cell */
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.svatby-feature:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.svatby-feature__icon {
  width: 52px;
  height: 52px;
  flex-shrink: 0;
  border-radius: var(--radius-lg);
  background: rgba(197, 138, 60, 0.12);
  align-items: center;
  justify-content: center;
  color: var(--color-caramel);
  margin-top: 2px;
}

.svatby-feature__title {
  font-family: var(--font-heading);
  font-size: var(--text-base);
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-2);
}

.svatby-feature__desc {
  font-size: var(--text-sm);
  color: var(--color-bark);
  line-height: 1.7;
}

/* ── Wedding cake gallery ───────────────────────────────────── */

.svatby-gallery {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-4);
}

@media (min-width: 600px) {
  .svatby-gallery {
    grid-template-columns: repeat(4, 1fr);
    gap: var(--space-5);
  }
}

.svatby-gallery .gallery-item {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 1 / 1;
  display: block;
  box-shadow: var(--shadow-md);
  /* cancel global gallery span rules from style.css */
  grid-row: span 1;
  grid-column: span 1;
}

.svatby-gallery .gallery-item__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s ease;
  display: block;
}

.svatby-gallery .gallery-item:hover .gallery-item__img {
  transform: scale(1.07);
}

.svatby-gallery .gallery-item__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(43, 29, 23, 0.85) 0%,
    rgba(43, 29, 23, 0.08) 55%,
    transparent 100%
  );
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: var(--space-4);
  opacity: 0;
  transition: opacity 0.35s ease;
}

.svatby-gallery .gallery-item:hover .gallery-item__overlay {
  opacity: 1;
}

.svatby-gallery .gallery-item__caption {
  color: var(--color-warm-white);
  font-family: var(--font-heading);
  font-size: var(--text-sm);
  font-weight: 600;
  display: block;
}

.svatby-gallery .gallery-item__sub {
  color: var(--color-cream);
  font-size: var(--text-xs);
  opacity: 0.85;
  display: block;
  margin-top: 4px;
}

.svatby-gallery .gallery-item__zoom {
  position: absolute;
  top: var(--space-3);
  right: var(--space-3);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.18);
  display: flex;
  align-items: center;
  justify-content: center;
  color: white;
  opacity: 0;
  transition: opacity 0.3s ease;
  backdrop-filter: blur(6px);
}

.svatby-gallery .gallery-item:hover .gallery-item__zoom {
  opacity: 1;
}

/* ── Gallery section CTA link ───────────────────────────────── */

.svatby-gallery + div {
  margin-top: var(--space-10);
}

/* ── Process steps ──────────────────────────────────────────── */

.svatby-process {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  position: relative;
}

@media (min-width: 640px) {
  .svatby-process {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
  }
}

.svatby-step {
  padding: var(--space-8) var(--space-6);
  position: relative;
  text-align: center;
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.svatby-step:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
}

/* Connector arrow between steps on desktop */
@media (min-width: 640px) {
  .svatby-step:not(:last-child)::after {
    content: '→';
    position: absolute;
    right: calc(-1 * var(--space-4));
    top: 50%;
    transform: translateY(-50%);
    color: var(--color-caramel);
    font-size: var(--text-xl);
    opacity: 0.55;
    line-height: 1;
    pointer-events: none;
  }
}

.svatby-step__number {
  display: inline-flex;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: var(--color-caramel);
  color: #fff;
  align-items: center;
  justify-content: center;
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  font-weight: 700;
  margin-bottom: var(--space-5);
  margin-inline: auto;
  box-shadow: 0 4px 16px rgba(197, 138, 60, 0.35);
}

.svatby-step__title {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  font-weight: 600;
  color: var(--color-espresso);
  margin-bottom: var(--space-3);
}

.svatby-step__desc {
  font-size: var(--text-sm);
  color: var(--color-bark);
  line-height: 1.75;
  max-width: 240px;
  margin-inline: auto;
}

/* ── Dark CTA section ───────────────────────────────────────── */

.svatby-cta-section {
  background: var(--gradient-dark);
  padding-block: clamp(4rem, 8vw, 8rem);
  text-align: center;
}

.svatby-cta-section .section-label {
  color: var(--color-caramel);
  margin-bottom: var(--space-3);
}

.svatby-cta-section h2 {
  color: var(--color-warm-white);
  margin-bottom: var(--space-5);
}

.svatby-cta-section h2 em {
  color: var(--color-caramel);
  font-style: italic;
}

.svatby-cta-section p {
  color: var(--color-cream);
  opacity: 0.88;
  max-width: 480px;
  margin-inline: auto;
  margin-bottom: var(--space-8);
  line-height: 1.8;
  font-size: var(--text-base);
}

.svatby-cta-btns {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Reduced motion ─────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  .svatby-gallery .gallery-item__img,
  .svatby-gallery .gallery-item__overlay,
  .svatby-gallery .gallery-item__zoom,
  .svatby-feature,
  .svatby-step {
    transition: none !important;
    transform: none !important;
  }
}
