/* Wedding Website Kit - Base Styles */
.wwk { 
  --wwk-bg: #ffffff;
  --wwk-surface: rgba(255,255,255,0.8);
  --wwk-text: #111827;
  --wwk-muted: rgba(17,24,39,0.68);
  --wwk-border: rgba(17,24,39,0.12);
  --wwk-accent: #2563eb;
  --wwk-accent-2: #111827;
  --wwk-radius: 18px;
  --wwk-shadow: 0 10px 30px rgba(0,0,0,0.10);
  --wwk-max: 1100px;
  --wwk-font-body: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  --wwk-font-heading: var(--wwk-font-body);
  --wwk-accent-gradient: var(--wwk-accent);
  --wwk-nav-bg: rgba(255,255,255,0.72);
  --wwk-hover: rgba(0,0,0,0.06);
  --wwk-panel: rgba(0,0,0,0.02);
  --wwk-input-bg: rgba(255,255,255,0.92);
  --wwk-footer-bg: rgba(0,0,0,0.01);
  --wwk-chip-bg: rgba(255,255,255,0.25);
  --wwk-ring: rgba(37,99,235,0.25);
  --wwk-glass-bg: rgba(255,255,255,0.12);
  --wwk-glass-border: rgba(255,255,255,0.20);
  --wwk-scrollbar-thumb: rgba(0,0,0,0.14);
  --wwk-carousel-media-bg: rgba(0,0,0,0.06);
  --wwk-glass-dark-bg: rgba(0,0,0,0.18);

  font-family: var(--wwk-font-body);
  color: var(--wwk-text);
  background: var(--wwk-bg);
  line-height: 1.55;
  font-size: 16px;
}

.wwk * { box-sizing: border-box; }
.wwk a { color: inherit; text-decoration: none; }
.wwk a:hover { text-decoration: underline; }

.wwk header.wwk-nav { height: auto !important; }

.wwk-nav {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: blur(10px);
  background: var(--wwk-nav-bg);
  border-bottom: 1px solid var(--wwk-border);
  text-align: left;
}
body.admin-bar .wwk-nav { top: 32px; }
@media (max-width: 782px) { body.admin-bar .wwk-nav { top: 46px; } }

.wwk-nav__inner {
  max-width: var(--wwk-max);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 18px;
  min-height: 64px;
  gap: 12px;
}
.wwk-brand { font-weight: 800; letter-spacing: 0.2px; font-size: 18px; line-height: 1.1; }
.wwk-nav__links { display: flex; gap: 12px; align-items: center; flex-wrap: nowrap; justify-content: flex-end; }
.wwk-nav__links a { padding: 10px 12px; border-radius: 999px; font-weight: 600; text-decoration: none; }
.wwk-nav__links a:hover { text-decoration: none; background: var(--wwk-hover); }
.wwk-nav__cta { background: var(--wwk-accent-gradient); color: #fff; }

/* Mobile nav layout */
@media (max-width: 520px) {
  .wwk-nav__inner {
    flex-direction: column;
    align-items: stretch;
    justify-content: center;
    gap: 10px;
    padding: 12px 14px;
    min-height: 0;
  }
  .wwk-brand { text-align: center; font-size: 18px; }
  .wwk-nav__links {
    width: 100%;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: 1fr;
    gap: 10px;
    justify-content: stretch;
  }
  .wwk-nav__links a {
    padding: 10px 10px;
    font-size: 14px;
    text-align: center;
    white-space: nowrap;
  }
}

/* Extra narrow: allow the CTA to span full width if needed */
@media (max-width: 360px) {
  .wwk-nav__links { grid-auto-flow: row; grid-template-columns: 1fr 1fr; }
  .wwk-nav__links a.wwk-nav__cta { grid-column: 1 / -1; }
}

.wwk-nav__cta:hover { background: var(--wwk-accent-gradient); color: #fff; filter: brightness(0.95); }

@media (max-width: 560px) {
  .wwk-nav__inner { justify-content: center; }
  .wwk-brand { width: 100%; text-align: center; }
  .wwk-nav__links { width: 100%; justify-content: center; }
}

.wwk-hero {
  position: relative;
  padding: 64px 18px 54px;
  background: radial-gradient(1200px 500px at 50% -20%, rgba(0,0,0,0.12), transparent),
              linear-gradient(180deg, rgba(0,0,0,0.04), transparent);
  overflow: hidden;
}
.wwk-hero[style*="--wwk-hero-image"] {
  background-image:
    linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.20) 45%, rgba(0,0,0,0.30)),
    var(--wwk-hero-image);
  background-size: cover;
  background-position: center;
  color: #fff;
}
.wwk-hero__overlay { display:none; }
.wwk-hero__inner {
  max-width: var(--wwk-max);
  margin: 0 auto;
  display: grid;
  gap: 28px;
  align-items: center;
}
.wwk-layout-a .wwk-hero__inner { grid-template-columns: 1fr; }
.wwk-layout-b .wwk-hero__inner { grid-template-columns: 1.1fr 0.9fr; }
.wwk-layout-c .wwk-hero__inner { grid-template-columns: 1fr; }

.wwk-hero__content { 
  background: rgba(255,255,255,0.0);
  border-radius: var(--wwk-radius);
}
.wwk-hero[style*="--wwk-hero-image"] .wwk-hero__content {
  background: rgba(0,0,0,0.18);
  padding: 24px 22px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.16);
}
.wwk-kicker { margin: 0 0 8px; opacity: 0.92; font-weight: 600; letter-spacing: 0.3px; }
.wwk-title { margin: 0 0 10px; font-size: clamp(34px, 5vw, 52px); line-height: 1.05; }

.wwk-title,
.wwk-section h2,
.wwk-card h3,
.wwk-brand {
  font-family: var(--wwk-font-heading);
}
.wwk-subtitle { margin: 0 0 18px; font-size: 16px; opacity: 0.92; max-width: 60ch; }
.wwk-meta { display: grid; gap: 10px; margin: 16px 0 18px; }
.wwk-meta__item { display: grid; gap: 4px; }
.wwk-meta__label { font-size: 12px; opacity: 0.82; }
.wwk-meta__value { font-weight: 600; }

.wwk-countdown { 
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 18px 0 18px;
}
.wwk-countdown__box {
  border: 1px solid var(--wwk-glass-border);
  background: var(--wwk-glass-bg);
  border-radius: 16px;
  padding: 12px 10px;
  text-align: center;
  backdrop-filter: blur(8px);
}
.wwk-hero:not([style*="--wwk-hero-image"]) .wwk-countdown__box {
  border-color: var(--wwk-border);
  background: var(--wwk-panel);
}
.wwk-countdown__num { display: block; font-size: 22px; font-weight: 800; letter-spacing: 0.2px; }
.wwk-countdown__label { display: block; font-size: 12px; opacity: 0.85; margin-top: 2px; }

.wwk-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 11px 16px;
  border-radius: 999px;
  border: 1px solid var(--wwk-border);
  background: var(--wwk-chip-bg);
  color: inherit;
  box-shadow: none;
  transition: transform 0.12s ease, background 0.12s ease;
}
.wwk-btn:hover { transform: translateY(-1px); text-decoration: none; }
.wwk-btn--primary {
  background: var(--wwk-accent-gradient);
  border-color: rgba(0,0,0,0);
  color: #fff;
}
.wwk-btn--small { padding: 8px 12px; font-size: 13px; }

.wwk-hero__buttons { display:flex; gap: 10px; flex-wrap: wrap; }

.wwk-hero__image {
  width: 100%;
  min-height: 320px;
  border-radius: calc(var(--wwk-radius) + 10px);
  background-image:
    linear-gradient(180deg, rgba(0,0,0,0.28), rgba(0,0,0,0.12)),
    var(--wwk-hero-image);
  background-size: cover;
  background-position: center;
  box-shadow: var(--wwk-shadow);
}

.wwk-main { padding: 34px 18px 56px; }
.wwk-section__inner { max-width: var(--wwk-max); margin: 0 auto; }
.wwk-section { padding: 20px 0 8px; scroll-margin-top: 96px; }
body.admin-bar .wwk-section { scroll-margin-top: 128px; }
.wwk-section h2 { margin: 0 0 10px; font-size: 28px; letter-spacing: -0.2px; }
.wwk-section__head { display:flex; align-items: baseline; justify-content: space-between; gap: 16px; flex-wrap: wrap; margin-bottom: 10px; }
.wwk-muted { color: var(--wwk-muted); }
.wwk-link { color: var(--wwk-accent); font-weight: 600; }

.wwk-cards { display:grid; gap: 14px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.wwk-card {
  background: var(--wwk-panel);
  border: 1px solid var(--wwk-border);
  border-radius: var(--wwk-radius);
  padding: 18px 18px;
  box-shadow: none;
}
.wwk-hero[style*="--wwk-hero-image"] ~ .wwk-main .wwk-card { background: rgba(255,255,255,0.86); }
.wwk-card h3 { margin: 0 0 8px; font-size: 18px; }
.wwk-card p { margin: 0 0 8px; }
.wwk-card p:last-child { margin-bottom: 0; }

.wwk-carousel { position: relative; margin-top: 10px; }
.wwk-carousel__track {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  padding: 8px 52px 16px;
  border-radius: var(--wwk-radius);
}
.wwk-carousel__track::-webkit-scrollbar { height: 10px; }
.wwk-carousel__track::-webkit-scrollbar-thumb { background: var(--wwk-scrollbar-thumb); border-radius: 999px; }

.wwk-carousel__item {
  flex: 0 0 auto;
  width: min(72vw, 260px);
  scroll-snap-align: center;
}
.wwk-gal-ar-16x9 .wwk-carousel__item { width: min(86vw, 560px); }

.wwk-carousel__media {
  width: 100%;
  aspect-ratio: 9 / 16;
  border-radius: calc(var(--wwk-radius) + 10px);
  overflow: hidden;
  box-shadow: var(--wwk-shadow);
  background: var(--wwk-carousel-media-bg);
}
.wwk-gal-ar-16x9 .wwk-carousel__media { aspect-ratio: 16 / 9; }

.wwk-carousel__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.wwk-carousel__btn {
  position:absolute;
  top: 50%;
  transform: translateY(-50%);
  border: 1px solid var(--wwk-border);
  background: var(--wwk-surface);
  backdrop-filter: blur(10px);
  width: 42px;
  height: 42px;
  border-radius: 999px;
  cursor: pointer;
}
.wwk-carousel__btn:hover { background: var(--wwk-input-bg); }
.wwk-carousel__btn[data-dir="prev"] { left: 8px; }
.wwk-carousel__btn[data-dir="next"] { right: 8px; }

.wwk-form {
  max-width: 680px;
  background: var(--wwk-panel);
  border: 1px solid var(--wwk-border);
  border-radius: var(--wwk-radius);
  padding: 18px;
}
.wwk-form__row { display:grid; gap: 6px; margin-bottom: 12px; }
.wwk-form label { font-weight: 600; font-size: 13px; }
.wwk-form input, .wwk-form select, .wwk-form textarea {
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--wwk-border);
  background: var(--wwk-input-bg);
  color: var(--wwk-text);
  outline: none;
}

.wwk-form input:focus, .wwk-form select:focus, .wwk-form textarea:focus {
  border-color: var(--wwk-accent);
  box-shadow: 0 0 0 4px var(--wwk-ring);
}
.wwk-form input::placeholder, .wwk-form textarea::placeholder {
  color: var(--wwk-muted);
  opacity: 0.9;
}
.wwk-btn:disabled, .wwk-btn[disabled] {
  background: var(--wwk-panel) !important;
  border-color: var(--wwk-border) !important;
  color: var(--wwk-muted) !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: not-allowed;
  opacity: 0.75;
}
.wwk-btn--primary {
  background: var(--wwk-accent-gradient) !important;
  color: #fff !important;
  border-color: rgba(0,0,0,0) !important;
}
.wwk-nav__cta {
  background: var(--wwk-accent-gradient) !important;
  color: #fff !important;
}
.wwk-form textarea { resize: vertical; }
.wwk-form__actions { display:flex; align-items:center; gap: 12px; flex-wrap: wrap; }
.wwk-form__status { color: var(--wwk-muted); font-weight: 600; }

.wwk-footer {
  border-top: 1px solid var(--wwk-border);
  background: var(--wwk-footer-bg);
  padding: 18px;
}
.wwk-footer__inner {
  max-width: var(--wwk-max);
  margin: 0 auto;
  display:flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}
.wwk-footer__right { display:flex; gap: 14px; }

.wwk-cookie {
  position: fixed;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 1000;
  display: none;
}
.wwk-cookie.is-visible { display:block; }
.wwk-cookie__inner {
  max-width: var(--wwk-max);
  margin: 0 auto;
  border-radius: var(--wwk-radius);
  border: 1px solid var(--wwk-border);
  background: var(--wwk-input-bg);
  backdrop-filter: blur(10px);
  padding: 12px 12px;
  display:flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  box-shadow: var(--wwk-shadow);
}
.wwk-cookie__text { font-size: 13px; color: var(--wwk-muted); }
@media (max-width: 800px) {
  .wwk-cards { grid-template-columns: 1fr; }
  .wwk-layout-b .wwk-hero__inner { grid-template-columns: 1fr; }  .wwk-carousel__track { padding-left: 44px; padding-right: 44px; }
  .wwk-carousel__item { width: min(78vw, 240px); }
  .wwk-gal-ar-16x9 .wwk-carousel__item { width: min(92vw, 420px); }
  .wwk-nav__links { gap: 6px; }
  .wwk-nav__links a { padding: 8px 10px; }
}
