/* ============================================================
   Vora Gift Vouchers — Public Stylesheet v1.4
   Design System: Editorial Luxury & Liquid Glass (Cinematic)
   Author: Shaan Designs (shaandesigns.com)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Instrument+Serif:ital@0;1&family=Barlow:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap');

/* ── Design Tokens ──────────────────────────────────────────── */
:root {
  /* Palette */
  --vora-bg:           #f8f9ff;
  --vora-surface:      #f8f9ff;
  --vora-surf-low:     #eef4ff;
  --vora-surf-high:    #dbe9ff;
  --vora-surf-lowest:  #ffffff;
  --vora-on-surface:   #001d36;
  --vora-primary:      #5c5f61;
  --vora-on-primary:   #ffffff;
  --vora-secondary:    #585f69;
  --vora-tertiary:     #735c00;        /* gold accent */
  --vora-tert-fixed:   #ffe088;
  --vora-outline:      #73777f;
  --vora-outline-var:  #c3c6cf;
  --vora-error:        #ba1a1a;

  /* Typography */
  --vora-serif:   'Instrument Serif', Georgia, serif;
  --vora-sans:    'Barlow', system-ui, sans-serif;

  /* Geometry — everything fully rounded */
  --vora-radius:    1rem;
  --vora-radius-lg: 2rem;
  --vora-radius-xl: 3rem;
  --vora-radius-full: 9999px;

  /* Liquid Glass */
  --vora-glass:      rgba(255,255,255,0.10);
  --vora-glass-blur: blur(30px);
  --vora-glass-strong: rgba(255,255,255,0.15);
  --vora-glass-strong-blur: blur(40px);

  /* Depth */
  --vora-shadow:    0 40px 60px -5px rgba(0,29,54,0.05);
  --vora-shadow-lg: 0 60px 100px -20px rgba(0,29,54,0.10);

  /* Motion */
  --vora-transition: 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  --vora-transition-slow: 0.7s cubic-bezier(0.4, 0, 0.2, 1);
  --vora-header-h:   80px;

  /* Legacy compat aliases (basket/checkout/confirmation still use these) */
  --sdgv-primary:        var(--vora-on-surface);
  --sdgv-primary-c:      var(--vora-on-surface);
  --sdgv-primary-light:  var(--vora-primary);
  --sdgv-accent:         var(--vora-tertiary);
  --sdgv-accent-dark:    #5a4700;
  --sdgv-bg:             var(--vora-bg);
  --sdgv-surface:        var(--vora-surf-lowest);
  --sdgv-surface-low:    var(--vora-surf-low);
  --sdgv-surface-lowest: var(--vora-surf-lowest);
  --sdgv-surface-cont:   var(--vora-surf-high);
  --sdgv-text:           var(--vora-on-surface);
  --sdgv-text-muted:     var(--vora-secondary);
  --sdgv-text-light:     var(--vora-outline);
  --sdgv-border:         rgba(195,198,207,0.25);
  --sdgv-outline-var:    var(--vora-outline-var);
  --sdgv-success:        #2d6a4f;
  --sdgv-success-l:      rgba(45,106,79,0.08);
  --sdgv-danger:         var(--vora-error);
  --sdgv-danger-l:       #ffdad6;
  --sdgv-radius:         var(--vora-radius);
  --sdgv-radius-lg:      var(--vora-radius-lg);
  --sdgv-radius-xl:      var(--vora-radius-xl);
  --sdgv-radius-full:    var(--vora-radius-full);
  --sdgv-shadow:         var(--vora-shadow);
  --sdgv-shadow-hover:   var(--vora-shadow-lg);
  --sdgv-shadow-sm:      0 4px 16px rgba(0,29,54,0.04);
  --sdgv-font-serif:     var(--vora-serif);
  --sdgv-font-sans:      var(--vora-sans);
  --sdgv-transition:     var(--vora-transition);
  --sdgv-header-height:  var(--vora-header-h);
}

/* ── Reset ──────────────────────────────────────────────────── */
.sdgv-wrap *, .sdgv-wrap *::before, .sdgv-wrap *::after {
  box-sizing: border-box; margin: 0; padding: 0;
}
.sdgv-wrap {
  font-family: var(--vora-sans);
  font-size: var(--sdgv-body-font-size, 16px);
  color: var(--vora-on-surface);
  background: var(--vora-bg);
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow-x: hidden;
}
.sdgv-wrap a { color: inherit; text-decoration: none; }
.sdgv-wrap img { display: block; max-width: 100%; }

/* Cinematic atmospheric background */
.sdgv-wrap::before {
  content: '';
  position: fixed;
  top: -10%; right: -5%;
  width: 600px; height: 600px;
  border-radius: 50%;
  background: var(--vora-surf-low);
  filter: blur(120px);
  opacity: 0.6;
  pointer-events: none;
  z-index: 0;
}
.sdgv-wrap::after {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at top left, rgba(92,95,97,0.05), transparent);
  pointer-events: none;
  z-index: 0;
}
.sdgv-wrap > * { position: relative; z-index: 1; }
.sdgv-wrap > .sdgv-page-bg-media {
  position: fixed !important;
  inset: 0 !important;
  z-index: 0 !important;
  width: 100% !important;
  height: 100% !important;
  pointer-events: none !important;
}
.sdgv-page-bg-media--image {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.sdgv-page-bg-media--video {
  object-fit: cover;
}
.sdgv-wrap:has(.sdgv-page-bg-media)::after {
  background: rgba(250,249,246,0.62);
}

/* ── Liquid Glass Utility ────────────────────────────────────── */
.sdgv-glass {
  background: var(--vora-glass);
  backdrop-filter: var(--vora-glass-blur);
  -webkit-backdrop-filter: var(--vora-glass-blur);
  border-top: 0.5px solid rgba(255,255,255,0.4);
}
.sdgv-glass-strong {
  background: var(--vora-glass-strong);
  backdrop-filter: var(--vora-glass-strong-blur);
  -webkit-backdrop-filter: var(--vora-glass-strong-blur);
  border-top: 0.5px solid rgba(255,255,255,0.4);
}

/* ── Cinematic Floating NAV ─────────────────────────────────── */
.sdgv-header {
  position: fixed;
  top: 24px;
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
  max-width: 960px;
  z-index: 100;
  height: 64px;
  background: rgba(255,255,255,0.10);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  border-radius: var(--vora-radius-full);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  gap: 16px;
  box-shadow: var(--vora-shadow);
}
/* Page content offset for floating nav */
.sdgv-nav-offset { padding-top: 120px; }

.sdgv-header__logo { display: flex; align-items: center; }
.sdgv-header__logo img { max-height: 36px; max-width: 140px; object-fit: contain; }
.sdgv-header__logo--text {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 20px;
  color: var(--vora-on-surface);
  letter-spacing: -0.01em;
}
.sdgv-header__nav {
  display: none;
  align-items: center;
  gap: 32px;
}
@media (min-width: 640px) { .sdgv-header__nav { display: flex; } }
.sdgv-header__nav a {
  font-family: var(--vora-sans);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.05em;
  color: var(--vora-primary);
  opacity: 0.8;
  transition: all var(--vora-transition);
  text-decoration: none;
}
.sdgv-header__nav a:hover { opacity: 1; color: var(--vora-on-surface); }
.sdgv-header__nav a.is-active { font-weight: 700; color: var(--vora-tertiary); opacity: 1; border-bottom: 1px solid rgba(115,92,0,0.2); }
.sdgv-header__actions { display: flex; align-items: center; gap: 12px; }
.sdgv-header__actions button, .sdgv-header__actions a {
  display: flex; align-items: center; justify-content: center;
  padding: 6px;
  color: var(--vora-primary);
  background: none; border: none; cursor: pointer;
  transition: color var(--vora-transition);
  font-size: 22px;
}
.sdgv-header__actions button:hover, .sdgv-header__actions a:hover { color: var(--vora-on-surface); }
.sdgv-basket-icon {
  position: relative;
  color: var(--vora-primary);
  transition: color var(--vora-transition);
}
.sdgv-basket-icon:hover { color: var(--vora-on-surface); }
.sdgv-basket-count {
  position: absolute;
  top: 0; right: 0;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--vora-primary);
  display: block;
}
.sdgv-basket-count:empty, .sdgv-basket-count[style*="none"] { display: none; }

/* ── Mobile slide-in drawer (replaces old sidemenu) ────────── */
.sdgv-sidemenu {
  position: fixed; top: 0; left: 0;
  width: 300px; max-width: 85vw; height: 100%;
  background: var(--vora-surf-lowest);
  z-index: 200;
  transform: translateX(-100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  display: flex; flex-direction: column;
  box-shadow: 40px 0 80px rgba(0,29,54,0.12);
}
.sdgv-sidemenu.is-open { transform: translateX(0); }
.sdgv-sidemenu__close {
  background: none; border: none;
  padding: 22px 28px;
  font-size: 11px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--vora-outline);
  cursor: pointer; text-align: left;
  font-family: var(--vora-sans);
  border-bottom: 1px solid rgba(195,198,207,0.2);
}
.sdgv-sidemenu__nav { display: flex; flex-direction: column; }
.sdgv-sidemenu__nav a {
  display: block; padding: 18px 28px;
  font-family: var(--vora-serif); font-style: italic; font-size: 20px;
  color: var(--vora-on-surface);
  border-bottom: 1px solid rgba(195,198,207,0.15);
  transition: padding-left var(--vora-transition);
}
.sdgv-sidemenu__nav a:hover { padding-left: 40px; color: var(--vora-tertiary); }
.sdgv-overlay {
  position: fixed; inset: 0;
  background: rgba(0,29,54,0.35);
  backdrop-filter: blur(4px);
  z-index: 150; opacity: 0; pointer-events: none;
  transition: opacity 0.35s ease;
}
.sdgv-overlay.is-visible { opacity: 1; pointer-events: all; }

/* ── STOREFRONT — CINEMATIC HERO ────────────────────────────── */
.sdgv-cinematic-hero {
  text-align: center;
  padding: 80px 24px 60px;
}
.sdgv-cinematic-hero__title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: clamp(52px, 8vw, 96px);
  font-weight: 400;
  color: var(--vora-on-surface);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: 24px;
  opacity: 0.9;
}
.sdgv-cinematic-hero__sub {
  font-family: var(--vora-sans);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--vora-primary);
  max-width: 480px;
  margin: 0 auto;
  line-height: 1.7;
}

/* ── UTILITY BAR (replaces filter bar) ─────────────────────── */
.sdgv-util-bar {
  margin: 0 auto 48px;
  max-width: 1200px;
  padding: 0 48px;
}
.sdgv-util-bar__inner {
  background: var(--vora-glass);
  backdrop-filter: var(--vora-glass-blur);
  -webkit-backdrop-filter: var(--vora-glass-blur);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--vora-radius-full);
  padding: 14px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.sdgv-util-bar__cats {
  display: flex; align-items: center; gap: 28px;
  overflow-x: auto;
  -ms-overflow-style: none; scrollbar-width: none;
}
.sdgv-util-bar__cats::-webkit-scrollbar { display: none; }
.sdgv-util-bar__left {
  display: flex;
  align-items: center;
  min-width: 220px;
}
.sdgv-util-bar__cat {
  font-family: var(--vora-sans);
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--vora-on-surface);
  white-space: nowrap;
  background: none; border: none; cursor: pointer;
  transition: opacity var(--vora-transition); padding: 0;
  opacity: 0.5;
}
.sdgv-util-bar__cat.is-active, .sdgv-util-bar__cat:hover { opacity: 1; }
.sdgv-util-bar__right { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
.sdgv-util-bar__filter-label {
  font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: rgba(92,95,97,0.4); white-space: nowrap;
}
.sdgv-util-bar__sort {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--vora-sans); font-size: 11px; font-weight: 600;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--vora-on-surface);
  background: rgba(255,255,255,0.4);
  border: none; border-radius: var(--vora-radius-full);
  padding: 8px 18px; cursor: pointer;
  transition: background var(--vora-transition);
}
.sdgv-util-bar__filter-select {
  min-width: 240px;
  background: rgba(255,255,255,0.68);
  border: 1px solid rgba(195,198,207,0.28);
}
.sdgv-util-bar__sort:hover { background: rgba(255,255,255,0.7); }
.sdgv-util-bar__search {
  min-width: 180px;
  max-width: 240px;
  font-family: var(--vora-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--vora-on-surface);
  background: rgba(255,255,255,0.52);
  border: 1px solid rgba(195,198,207,0.28);
  border-radius: var(--vora-radius-full);
  padding: 12px 22px;
  outline: none;
  min-height: 46px;
}
.sdgv-util-bar__search::placeholder {
  color: rgba(92,95,97,0.55);
}
.sdgv-util-bar__result-count {
  font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(92,95,97,0.5);
}

/* ── VOUCHER GRID ────────────────────────────────────────────── */
.sdgv-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  padding: 0 48px 80px;
  max-width: 1200px;
  margin: 0 auto;
}
@media (max-width: 960px) { .sdgv-grid { grid-template-columns: repeat(2,1fr); padding: 0 24px 60px; gap: 28px; } }
@media (max-width: 580px) { .sdgv-grid { grid-template-columns: 1fr; padding: 0 16px 48px; gap: 20px; } }
@media (min-width: 961px) and (max-width: 1100px) { .sdgv-grid { gap: 28px; padding: 0 32px 60px; } }

/* ── CINEMATIC CARD ──────────────────────────────────────────── */
.sdgv-card {
  background: #ffffff;
  background-image: linear-gradient(160deg, rgba(255,255,255,1) 0%, rgba(248,246,242,0.9) 100%);
  border-radius: 20px;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,29,54,0.06), 0 20px 40px rgba(0,29,54,0.07);
  transition: transform 0.45s cubic-bezier(0.4,0,0.2,1), box-shadow 0.45s cubic-bezier(0.4,0,0.2,1);
  position: relative;
  border: 1px solid rgba(195,198,207,0.18);
}
.sdgv-card:hover { transform: translateY(-6px); box-shadow: 0 2px 6px rgba(0,29,54,0.04), 0 32px 60px rgba(0,29,54,0.13); }
.sdgv-card__image-link {
  display: block;
  overflow: hidden;
  aspect-ratio: 16/10;
  background: var(--vora-surf-high);
}
.sdgv-card__image {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.55s cubic-bezier(0.4,0,0.2,1);
}
.sdgv-card:hover .sdgv-card__image { transform: scale(1.06); }
.sdgv-card__image--placeholder { aspect-ratio: 16/10;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, var(--vora-surf-high), var(--vora-surf-low));
}
.sdgv-card__badge {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  background: rgba(26,26,26,0.82);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #fff;
  font-size: 8px; font-weight: 700; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 9999px;
}
.sdgv-card__body {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; text-align: center;
  padding: 24px 24px 28px;
  gap: 0;
}
.sdgv-card__cat {
  font-size: 9px; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(92,95,97,0.5); margin-bottom: 8px;
}
.sdgv-card__title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 24px; font-weight: 400;
  color: var(--vora-on-surface);
  line-height: 1.2; margin-bottom: 10px;
  min-height: 3.6rem; display: flex; align-items: center; justify-content: center;
}
.sdgv-card__title a:hover { color: var(--vora-tertiary); }
.sdgv-card__divider {
  width: 40px; border: none; border-top: 1px solid rgba(195,198,207,0.35);
  margin: 0 auto 14px;
}
.sdgv-card__more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  margin: 0 auto 16px;
  padding: 0 18px;
  border: 1px solid rgba(0,29,54,0.16);
  border-radius: var(--vora-radius-full);
  color: var(--vora-on-surface);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-decoration: none;
  text-transform: uppercase;
  transition: all var(--vora-transition);
}
.sdgv-card__more:hover {
  background: var(--vora-on-surface);
  border-color: var(--vora-on-surface);
  color: #fff;
  transform: translateY(-1px);
}
.sdgv-card__desc { font-size: 13px; color: var(--vora-secondary); line-height: 1.65; margin-bottom: 18px; flex: 1; max-width: 28ch; }
.sdgv-card__footer {
  width: 100%; display: flex; justify-content: space-between; align-items: center;
  padding: 0;
}
.sdgv-card__price {
  font-family: var(--vora-sans); font-size: 15px; font-weight: 300;
  color: var(--vora-on-surface); letter-spacing: 0.01em;
}
.sdgv-card__actions { display: flex; gap: 8px; align-items: center; }
.sdgv-card__actions .sdgv-btn { flex: 1; min-width: 0; }
.sdgv-card__variants {
  display: flex; flex-direction: column; gap: 6px;
  margin-top: 12px; width: 100%;
  animation: sdgv-fade-in 0.25s ease;
}
@keyframes sdgv-fade-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.sdgv-variant-btn {
  display: block; width: 100%; text-align: center;
  padding: 11px 16px;
  background: rgba(255,255,255,0.5);
  border: none; border-radius: var(--vora-radius-full);
  font-family: var(--vora-sans); font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--vora-on-surface); cursor: pointer;
  transition: all var(--vora-transition);
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: normal;
  line-height: 1.35;
  min-height: 44px;
}
.sdgv-variant-btn:hover { background: var(--vora-on-surface); color: #fff; }

/* ── EMPTY STATE ─────────────────────────────────────────────── */
.sdgv-empty { grid-column: 1/-1; text-align: center; padding: 80px 24px; color: var(--vora-outline); font-size: 15px; }
.sdgv-empty-state { text-align: center; padding: 80px 24px; }
.sdgv-empty-state h2 { font-family: var(--vora-serif); font-style: italic; font-size: 32px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 12px; }
.sdgv-empty-state p { color: var(--vora-secondary); margin-bottom: 32px; }

/* ── BUTTONS ─────────────────────────────────────────────────── */
.sdgv-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--vora-sans); font-size: 11px; font-weight: 700;
  letter-spacing: 0.15em; text-transform: uppercase;
  border: none; border-radius: var(--vora-radius-full);
  padding: 13px 24px; cursor: pointer;
  transition: all var(--vora-transition);
  white-space: nowrap; text-decoration: none; line-height: 1;
}
.sdgv-btn--primary {
  background: var(--vora-on-surface); color: #fff;
  box-shadow: 0 8px 24px rgba(0,29,54,0.12);
}
/* No colour change on hover — stays same dark colour for consistency */
.sdgv-btn--primary:hover { background: var(--vora-on-surface); color: #fff; transform: translateY(-1px); box-shadow: 0 14px 32px rgba(0,29,54,0.18); }
.sdgv-btn--outline {
  background: var(--vora-on-surface);
  color: #ffffff;
  border: none;
}
.sdgv-btn--outline:hover { background: var(--vora-on-surface); color: #ffffff; transform: translateY(-1px); box-shadow: 0 14px 32px rgba(0,29,54,0.18); }
.sdgv-btn--secondary { background: var(--vora-surf-low); color: var(--vora-on-surface); }
.sdgv-btn--secondary:hover { background: var(--vora-surf-high); }
.sdgv-btn--full { width: 100%; }
.sdgv-btn--large { font-size: 12px; padding: 17px 36px; }
.sdgv-btn:disabled, .sdgv-btn.is-loading { opacity: 0.45; cursor: not-allowed; pointer-events: none; }
.sdgv-btn.is-loading::after {
  content: ''; width: 14px; height: 14px;
  border: 2px solid currentColor; border-top-color: transparent;
  border-radius: 50%; animation: sdgv-spin 0.6s linear infinite;
}
@keyframes sdgv-spin { to { transform: rotate(360deg); } }

/* ── TOAST ───────────────────────────────────────────────────── */
.sdgv-toast {
  position: fixed; bottom: 32px; right: 32px; z-index: 999;
  background: var(--vora-on-surface); color: #fff;
  padding: 16px 24px; border-radius: var(--vora-radius-full);
  font-family: var(--vora-sans); font-size: 13px; letter-spacing: 0.05em;
  box-shadow: var(--vora-shadow-lg); transform: translateY(12px);
  opacity: 0; pointer-events: none; transition: all 0.3s ease; max-width: 340px;
}
.sdgv-toast.is-visible { transform: translateY(0); opacity: 1; pointer-events: all; }
.sdgv-toast a { color: #fff; font-weight: 700; text-decoration: underline; pointer-events: all; }
.sdgv-toast--success { background: #2d6a4f; }
.sdgv-toast--error   { background: var(--vora-error); }

/* ── CINEMATIC FOOTER ────────────────────────────────────────── */
.sdgv-footer {
  display: grid;
  grid-template-columns: minmax(160px, 1fr) auto minmax(220px, 1fr);
  align-items: start;
  gap: 20px;
  padding: 40px 48px;
  background: var(--vora-surface);
}
.sdgv-footer__brand {
  font-family: var(--vora-serif); font-style: italic; font-size: 18px;
  color: var(--vora-primary);
}
.sdgv-footer__links { display: flex; gap: 22px; flex-wrap: wrap; justify-content: center; }
.sdgv-footer__links a {
  font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--vora-primary); opacity: 0.6; transition: all var(--vora-transition);
}
.sdgv-footer__links a:hover { opacity: 1; color: var(--vora-tertiary); }
.sdgv-footer__copy {
  font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--vora-primary); opacity: 0.4;
}
.sdgv-footer__contact {
  justify-self: end;
  text-align: right;
  font-family: var(--vora-sans);
  font-size: 11px;
  line-height: 1.7;
  color: var(--vora-primary);
  opacity: 0.58;
  max-width: 340px;
}
.sdgv-footer__contact a { color: inherit; text-decoration: none; }
.sdgv-footer__contact a:hover { color: var(--vora-tertiary); }
@media (max-width: 720px) { .sdgv-footer { grid-template-columns: 1fr; text-align: center; padding: 32px 24px; } .sdgv-footer__links { justify-content: center; } .sdgv-footer__contact { justify-self: center; text-align: center; } }

.sdgv-legal-page {
  max-width: 920px;
  margin: 0 auto;
  padding: clamp(48px, 7vw, 92px) 24px clamp(56px, 8vw, 110px);
}
.sdgv-legal-page__eyebrow {
  display: block;
  margin: 28px 0 10px;
  font-family: var(--vora-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vora-outline);
}
.sdgv-legal-page__title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-weight: 400;
  margin: 0 0 30px;
}
.sdgv-legal-page__body {
  padding: clamp(28px, 4vw, 46px);
  border: 1px solid rgba(195,198,207,0.24);
  border-radius: var(--vora-radius-lg);
  background: rgba(255,255,255,0.62);
  box-shadow: 0 24px 70px rgba(0,29,54,0.06);
  color: var(--vora-secondary);
  line-height: 1.85;
}
.sdgv-legal-page__body p {
  margin: 0 0 1.2em;
}
.sdgv-legal-page__body p:last-child {
  margin-bottom: 0;
}

/* ── SECTION ALT (Need Assistance) ──────────────────────────── */
.sdgv-section-alt { background: var(--vora-surf-low); padding: 60px 48px; margin-top: 20px; }
.sdgv-section-alt__inner { max-width: 1100px; margin: 0 auto; text-align: center; }
.sdgv-section-alt h2 { font-family: var(--vora-serif); font-style: italic; font-size: 32px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 28px; }

/* ── CHECKOUT & BASKET PAGES ─────────────────────────────────── */
.sdgv-wrap--checkout { max-width: 1100px; margin: 0 auto; padding: 48px 32px 100px; }
.sdgv-wrap--page { padding: 60px 32px; max-width: 900px; margin: 0 auto; }
.sdgv-page-inner { max-width: 640px; margin: 0 auto; }
.sdgv-page-title { font-family: var(--vora-serif); font-style: italic; font-size: clamp(32px,4vw,52px); font-weight: 400; color: var(--vora-on-surface); letter-spacing: -0.02em; line-height: 1.1; margin-bottom: 12px; }
.sdgv-page-subtitle { font-size: 14px; color: var(--vora-secondary); line-height: 1.6; margin-bottom: 40px; }

/* Basket */
.sdgv-basket-layout { display: flex; gap: 40px; flex-wrap: wrap; align-items: flex-start; }
.sdgv-basket-items  { flex: 1 1 400px; }
.sdgv-basket-summary, .sdgv-basket__sidebar { flex: 0 0 320px; position: sticky; top: 120px; }
.sdgv-basket-item {
  display: flex; gap: 16px; align-items: flex-start;
  padding: 20px 0; border-bottom: 1px solid rgba(195,198,207,0.2);
}
.sdgv-basket-item:first-child { border-top: 1px solid rgba(195,198,207,0.2); }
.sdgv-basket-item__image { flex-shrink: 0; width: 72px; height: 72px; border-radius: var(--vora-radius); overflow: hidden; background: var(--vora-surf-low); }
.sdgv-basket-item__image img { width: 100%; height: 100%; object-fit: cover; }
.sdgv-basket-item__info { flex: 1; }
.sdgv-basket-item__title { font-family: var(--vora-serif); font-style: italic; font-size: 17px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 4px; }
.sdgv-basket-item__variant { font-size: 12px; color: var(--vora-secondary); }
.sdgv-basket-item__price { font-size: 16px; font-weight: 600; color: var(--vora-on-surface); white-space: nowrap; }
.sdgv-basket-item__remove { font-size: 10px; color: var(--vora-outline); background: none; border: none; cursor: pointer; padding: 0; text-transform: uppercase; letter-spacing: 0.1em; transition: color var(--vora-transition); }
.sdgv-basket-item__remove:hover { color: var(--vora-error); }
.sdgv-basket-item__actions { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.sdgv-basket-empty { text-align: center; padding: 80px 24px; }
.sdgv-basket-empty svg { margin: 0 auto 24px; opacity: 0.2; color: var(--vora-primary); }
.sdgv-basket-empty h2 { font-family: var(--vora-serif); font-style: italic; font-size: 32px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 12px; }
.sdgv-basket-empty p { color: var(--vora-secondary); margin-bottom: 32px; }

/* Basket Summary */
.sdgv-summary { background: rgba(255,255,255,0.6); backdrop-filter: blur(20px); border-radius: var(--vora-radius-xl); padding: 28px; box-shadow: var(--vora-shadow); }
.sdgv-summary h2 { font-family: var(--vora-serif); font-style: italic; font-size: 22px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 20px; padding-bottom: 14px; border-bottom: 1px solid rgba(195,198,207,0.2); }
.sdgv-summary__row { display: flex; justify-content: space-between; padding: 10px 0; font-size: 14px; color: var(--vora-secondary); border-bottom: 1px solid rgba(195,198,207,0.15); }
.sdgv-summary__total { display: flex; justify-content: space-between; align-items: baseline; padding: 18px 0 0; font-size: 22px; font-family: var(--vora-serif); font-style: italic; color: var(--vora-on-surface); }
.sdgv-summary__total-label { font-family: var(--vora-sans); font-style: normal; font-size: 11px; text-transform: uppercase; letter-spacing: 0.15em; color: var(--vora-outline); }

/* Basket Summary (basket page variant) */
.sdgv-basket-summary { background: rgba(255,255,255,0.6); backdrop-filter: blur(20px); border-radius: var(--vora-radius-xl); padding: 28px; box-shadow: var(--vora-shadow); }
.sdgv-basket-summary h3 { font-family: var(--vora-serif); font-style: italic; font-size: 22px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 20px; }
.sdgv-basket-summary__row { display: flex; justify-content: space-between; padding: 10px 0; font-size: 14px; color: var(--vora-secondary); border-bottom: 1px solid rgba(195,198,207,0.15); }
.sdgv-basket-summary__row--total { font-weight: 700; color: var(--vora-on-surface); border-bottom: none; padding-top: 16px; font-size: 16px; }
.sdgv-how-it-works { margin-top: 24px; padding-top: 20px; border-top: 1px solid rgba(195,198,207,0.2); }
.sdgv-how-it-works h4 { font-size: 11px; text-transform: uppercase; letter-spacing: 0.15em; color: var(--vora-outline); margin-bottom: 12px; }
.sdgv-how-it-works ol { padding-left: 16px; display: flex; flex-direction: column; gap: 8px; }
.sdgv-how-it-works ol li { font-size: 13px; color: var(--vora-secondary); line-height: 1.5; }

/* Checkout */
.sdgv-checkout-layout { display: flex; gap: 40px; flex-wrap: wrap; align-items: flex-start; }
.sdgv-checkout-form   { flex: 1 1 480px; }
.sdgv-checkout-sidebar { flex: 0 0 320px; }
.sdgv-checkout-header { margin-bottom: 32px; }
.sdgv-checkout-section { margin-bottom: 36px; }
.sdgv-personalise-section,
.sdgv-envelope-panel {
  position: relative;
  padding: clamp(24px, 3vw, 34px);
  border: 1px solid rgba(195,198,207,0.26);
  border-radius: 22px;
  background: rgba(255,255,255,0.5);
  box-shadow: 0 20px 60px rgba(0,29,54,0.055);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}
.sdgv-envelope-panel {
  margin-top: 20px;
  background: linear-gradient(145deg, rgba(255,255,255,0.62), rgba(248,249,255,0.42));
}
.sdgv-panel-intro {
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(195,198,207,0.2);
}
.sdgv-panel-kicker {
  margin-bottom: 6px;
  font-family: var(--vora-sans);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vora-outline);
}
.sdgv-panel-intro h3 {
  margin: 0 0 6px;
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 400;
  color: var(--vora-on-surface);
}
.sdgv-panel-intro p {
  max-width: 560px;
  margin: 0;
  font-size: 13px;
  line-height: 1.65;
  color: var(--vora-secondary);
}
.sdgv-envelope-grid {
  display: grid;
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
  gap: 18px;
  margin-bottom: 14px;
}
.sdgv-section-title { font-family: var(--vora-serif); font-style: italic; font-size: 22px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 16px; padding-bottom: 10px; border-bottom: 1px solid rgba(195,198,207,0.2); }
.sdgv-back-link { font-size: 12px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--vora-secondary); display: inline-block; margin-bottom: 12px; transition: color var(--vora-transition); }
.sdgv-back-link:hover { color: var(--vora-tertiary); }

/* Form fields */
.sdgv-field { margin-bottom: 18px; }
.sdgv-field label, .sdgv-field > label {
  display: block; font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--vora-outline); margin-bottom: 8px; font-weight: 600;
}
.sdgv-form-row { display: flex; gap: 14px; flex-wrap: wrap; }
.sdgv-form-row .sdgv-field { flex: 1; min-width: 0; }
.sdgv-select, .sdgv-input, .sdgv-textarea {
  font-family: var(--vora-sans); font-size: 14px;
  color: var(--vora-on-surface); border: 1px solid rgba(195,198,207,0.3);
  border-radius: 10px; background: rgba(255,255,255,0.74);
  outline: none; line-height: 1.4; transition: border-color var(--vora-transition);
}
.sdgv-select { padding: 12px 36px 12px 20px; appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2373777f' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 14px center; background-color: var(--vora-surf-lowest); cursor: pointer; }
.sdgv-input { padding: 12px 20px; width: 100%; display: block; }
.sdgv-input--large { font-size: 18px; padding: 18px 24px; letter-spacing: 0.08em; border-radius: var(--vora-radius-full); }
.sdgv-textarea { padding: 14px 20px; width: 100%; display: block; resize: vertical; min-height: 100px; border-radius: var(--vora-radius); }
.sdgv-select:focus, .sdgv-input:focus, .sdgv-textarea:focus { border-color: var(--vora-tertiary); box-shadow: 0 0 0 3px rgba(184,135,42,0.1); }
.sdgv-hint { font-size: 11px; color: var(--vora-outline); margin-top: 5px; display: block; }
.sdgv-optional { font-size: 10px; color: var(--vora-outline); text-transform: uppercase; letter-spacing: 0.1em; }

/* Voucher type selection */
.sdgv-voucher-type-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 10px; margin-bottom: 16px; }
@media (max-width: 640px) { .sdgv-voucher-type-grid { grid-template-columns: 1fr; } }
.sdgv-type-card { position: relative; background: rgba(255,255,255,0.72); backdrop-filter: blur(12px); border: 1px solid rgba(195,198,207,0.34); border-radius: var(--vora-radius-full); padding: 22px 28px; cursor: pointer; transition: all var(--vora-transition); text-align: center; }
.sdgv-type-card:hover, .sdgv-type-card:focus-within { border-color: rgba(115,92,0,0.42); background: rgba(255,255,255,0.9); }
.sdgv-type-card--active { background: #fff; border-color: var(--vora-tertiary); box-shadow: inset 0 0 0 1px var(--vora-tertiary), 0 14px 34px rgba(0,29,54,0.055); }
.sdgv-type-card__icon, .sdgv-type-card__desc, .sdgv-type-card__price, .sdgv-type-premium { display: none !important; }
.sdgv-type-card__label { font-size: 13px; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; color: var(--vora-on-surface); margin: 0; line-height: 1.35; }
.sdgv-type-card__details { display: none !important; }
.sdgv-type-card:hover .sdgv-type-card__details, .sdgv-type-card:focus-within .sdgv-type-card__details { display: none !important; }
.sdgv-type-card__details ul { margin:0; padding:16px 18px 10px 34px; }
.sdgv-type-card__details li { font-size:12px; line-height:1.55; color:var(--vora-secondary); margin:0 0 6px; }
.sdgv-type-card__details strong { display:block; padding:0 18px 16px 34px; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--vora-tertiary); }
.sdgv-type-card__price { font-size: 11px; font-weight: 700; color: var(--vora-tertiary); }
.sdgv-type-premium { font-size: 9px; background: var(--vora-tert-fixed); color: var(--vora-tertiary); padding: 2px 7px; border-radius: var(--vora-radius-full); margin-left: 4px; font-weight: 700; letter-spacing: 0.1em; }
.sdgv-print-note { display: flex; gap: 10px; padding: 14px 18px; background: rgba(255,255,255,0.48); border: 1px solid rgba(195,198,207,0.18); border-radius: 999px; font-size: 12px; color: var(--vora-secondary); margin-top: 18px; line-height: 1.5; }

/* Gateway */
.sdgv-gateway-options { display: flex; gap: 8px; flex-wrap: wrap; }
.sdgv-gateway-btn { flex: 1; min-width: 100px; padding: 14px 12px; text-align: center; background: rgba(255,255,255,0.5); border: 1px solid rgba(195,198,207,0.3); border-radius: var(--vora-radius); font-size: 13px; color: var(--vora-secondary); cursor: pointer; transition: all var(--vora-transition); font-family: var(--vora-sans); }
.sdgv-gateway-btn.is-active { border-color: var(--vora-on-surface); background: rgba(255,255,255,0.9); color: var(--vora-on-surface); box-shadow: 0 0 0 1px var(--vora-on-surface); }
.sdgv-gateway-btn__name { font-weight: 700; display: block; font-size: 13px; margin-bottom: 2px; }
.sdgv-gateway-btn__sub  { font-size: 11px; opacity: 0.7; }
#sdgv-card-element { padding: 14px 20px; background: var(--vora-surf-lowest); border: 1px solid rgba(195,198,207,0.3); border-radius: var(--vora-radius-full); }

/* Discount */
.sdgv-discount-row { display: flex; gap: 8px; align-items: flex-end; }
.sdgv-discount-row .sdgv-input { flex: 1; }
.sdgv-discount-msg { font-size: 12px; margin-top: 8px; padding: 10px 16px; border-radius: var(--vora-radius-full); }
.sdgv-discount-msg--error { background: var(--vora-danger-l); color: var(--vora-error); }
.sdgv-discount-applied { display: flex; align-items: center; justify-content: space-between; padding: 10px 16px; background: var(--sdgv-success-l); border-radius: var(--vora-radius-full); }
.sdgv-discount-label { font-size: 13px; font-weight: 600; color: var(--sdgv-success); }
.sdgv-summary-discount { display: flex; justify-content: space-between; font-size: 13px; padding: 8px 0; border-bottom: 1px solid rgba(195,198,207,0.15); color: var(--vora-secondary); }

/* Stripe */
.sdgv-stripe-field { display: none; margin-top: 14px; animation: sdgv-fade-in 0.2s ease; }
.sdgv-bacs-field   { display: none; margin-top: 14px; animation: sdgv-fade-in 0.2s ease; }
.sdgv-bacs-details { font-size: 13px; color: var(--vora-secondary); line-height: 1.7; padding: 16px 20px; background: var(--vora-surf-low); border-radius: var(--vora-radius); }
.sdgv-bacs-details p { margin: 0; }

/* Quantity */
.sdgv-qty { display: flex; align-items: center; gap: 8px; }
.sdgv-qty__btn { width: 28px; height: 28px; border-radius: 50%; border: 1px solid rgba(195,198,207,0.4); background: none; color: var(--vora-on-surface); font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all var(--vora-transition); }
.sdgv-qty__btn:hover { background: var(--vora-on-surface); color: #fff; border-color: var(--vora-on-surface); }
.sdgv-qty__input { width: 40px; text-align: center; border: none; background: none; font-size: 14px; font-weight: 600; color: var(--vora-on-surface); }

/* Envelope fields */
.sdgv-env-drop {
  min-height: 122px;
  border: 1px dashed rgba(0,29,54,0.28);
  border-radius: 16px;
  padding: 22px 18px;
  text-align: center;
  cursor: pointer;
  background: rgba(255,255,255,0.54);
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
.sdgv-env-drop:hover {
  border-color: var(--vora-tertiary);
  background: rgba(255,255,255,0.78);
  box-shadow: 0 10px 28px rgba(0,29,54,0.06);
}
.sdgv-env-drop__text {
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: var(--vora-secondary);
  font-size: 13px;
}
.sdgv-env-drop__text strong {
  color: var(--vora-on-surface);
  font-size: 13px;
  letter-spacing: 0.02em;
}
.sdgv-env-drop__text span {
  font-size: 12px;
  color: var(--vora-outline);
}
.sdgv-envelope-preview-strip { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: var(--vora-surf-low); border-radius: var(--vora-radius); font-size: 13px; color: var(--vora-secondary); }
.sdgv-envelope-preview-icon { font-size: 20px; }

/* ── CONFIRMATION PAGE ──────────────────────────────────────── */
.sdgv-wrap--confirmation { max-width: 640px; margin: 0 auto; padding: 80px 32px; }
.sdgv-confirmation { text-align: center; }
.sdgv-confirmation__icon { font-size: 48px; margin-bottom: 20px; }
.sdgv-confirmation__title { font-family: var(--vora-serif); font-style: italic; font-size: 44px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 12px; letter-spacing: -0.02em; }
.sdgv-confirmation__sub { font-size: 14px; color: var(--vora-secondary); margin-bottom: 40px; line-height: 1.6; }
.sdgv-confirmation__card { background: rgba(255,255,255,0.7); backdrop-filter: blur(20px); border-radius: var(--vora-radius-xl); padding: 28px; margin-bottom: 16px; text-align: left; box-shadow: var(--vora-shadow); }
.sdgv-confirmation__order { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--vora-outline); margin-bottom: 6px; }
.sdgv-confirmation__voucher { font-family: var(--vora-serif); font-style: italic; font-size: 22px; color: var(--vora-on-surface); margin-bottom: 16px; }
.sdgv-confirmation__code-box { text-align: center; border: 1px dashed rgba(115,92,0,0.4); border-radius: var(--vora-radius); padding: 18px; margin: 12px 0; background: rgba(255,224,136,0.1); }
.sdgv-confirmation__code-label { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--vora-outline); margin-bottom: 8px; }
.sdgv-confirmation__code { font-family: 'Courier New', monospace; font-size: 22px; font-weight: 700; letter-spacing: 4px; color: var(--vora-tertiary); }
.sdgv-confirmation__sent { font-size: 13px; color: var(--vora-secondary); margin-top: 10px; }
.sdgv-scheduled-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 18px; background: rgba(255,224,136,0.2); color: var(--vora-tertiary); border-radius: var(--vora-radius-full); font-size: 12px; font-weight: 600; margin-bottom: 24px; }
.sdgv-thankyou-code { background: rgba(255,255,255,0.5); border-radius: var(--vora-radius-xl); padding: 28px; margin-top: 24px; text-align: center; }
.sdgv-thankyou-code__eyebrow { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--vora-outline); margin-bottom: 8px; }
.sdgv-thankyou-code__headline { font-family: var(--vora-serif); font-style: italic; font-size: 22px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 16px; }
.sdgv-thankyou-code__box { display: inline-block; padding: 14px 28px; margin-bottom: 12px; border-radius: var(--vora-radius); border: 1px dashed rgba(115,92,0,0.4); }
.sdgv-thankyou-code__label { font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--vora-outline); margin-bottom: 6px; }
.sdgv-thankyou-code__value { font-family: 'Courier New', monospace; font-size: 20px; font-weight: 700; letter-spacing: 3px; color: var(--vora-tertiary); }
.sdgv-thankyou-code__desc { font-size: 13px; color: var(--vora-secondary); line-height: 1.6; }

/* ── REDEMPTION PAGE ─────────────────────────────────────────── */
.sdgv-redeem-wrap {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 32px;
  align-items: start;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 48px 80px;
}
@media (max-width: 860px) {
  .sdgv-redeem-wrap {
    grid-template-columns: 1fr;
    padding: 0 20px 60px;
  }
  /* On mobile: hide the left ledger panel entirely — it replicates the form's results.
     Only the right-hand code input form is shown. The ledger balance still updates
     inside the form via JS when Check Balance is tapped. */
  .sdgv-redeem-wrap .sdgv-ledger {
    display: none !important;
  }
  .sdgv-redeem__right {
    width: 100%;
  }
}

/* Left ledger column */
.sdgv-ledger {
  background: var(--vora-surf-low);
  border-radius: var(--vora-radius-lg);
  padding: 32px;
  position: sticky;
  top: 120px;
}
.sdgv-ledger__header { display: flex; justify-content: space-between; align-items: flex-end; padding-bottom: 24px; border-bottom: 1px solid rgba(195,198,207,0.15); margin-bottom: 28px; }
.sdgv-ledger__eyebrow { font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--vora-outline); margin-bottom: 4px; display: block; }
.sdgv-ledger__title { font-family: var(--vora-sans); font-size: 28px; font-weight: 300; color: var(--vora-on-surface); }
.sdgv-ledger__icon { color: var(--vora-tertiary); font-size: 24px; }
.sdgv-ledger__rows { display: flex; flex-direction: column; gap: 16px; margin-bottom: 24px; }
.sdgv-ledger__row { display: flex; justify-content: space-between; align-items: flex-start; font-size: 13px; }
.sdgv-ledger__row-label { color: var(--vora-secondary); font-weight: 500; font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; }
.sdgv-ledger__row-sub { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--vora-outline); margin-top: 2px; }
.sdgv-ledger__row-val { font-weight: 600; color: var(--vora-on-surface); font-size: 14px; }
.sdgv-ledger__row-val--debit { color: var(--vora-error); }
.sdgv-ledger__row-val--muted { color: var(--vora-outline); }
.sdgv-ledger__balance { padding-top: 20px; border-top: 1px solid rgba(195,198,207,0.15); margin-bottom: 24px; }
.sdgv-ledger__balance-label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--vora-outline); margin-bottom: 8px; display: block; }
.sdgv-ledger__balance-amount { font-family: var(--vora-sans); font-size: 36px; font-weight: 700; color: var(--vora-tertiary); line-height: 1; }
.sdgv-ledger__balance-amount--pending { color: var(--vora-outline); font-size: 20px; font-weight: 400; }
.sdgv-ledger__redeem-btn {
  width: 100%; background: var(--vora-on-surface); color: #fff;
  border-radius: var(--vora-radius-full); padding: 16px;
  border: none; font-family: var(--vora-sans); font-size: 11px;
  font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase;
  cursor: pointer; transition: all var(--vora-transition); margin-bottom: 12px;
}
.sdgv-ledger__redeem-btn:hover:not(:disabled) { background: var(--vora-tertiary); }
.sdgv-ledger__redeem-btn:disabled { opacity: 0.3; cursor: not-allowed; }
.sdgv-ledger__redeem-btn.is-loading::after { content: ''; width: 13px; height: 13px; border: 2px solid rgba(255,255,255,0.5); border-top-color: #fff; border-radius: 50%; animation: sdgv-spin 0.6s linear infinite; display: inline-block; margin-left: 8px; }
.sdgv-ledger__security { text-align: center; font-size: 10px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--vora-outline); }
/* Ledger decorative image */
.sdgv-ledger__image { border-radius: var(--vora-radius-lg); overflow: hidden; aspect-ratio: 4/3; margin-top: 24px; position: relative; }
.sdgv-ledger__image img { width: 100%; height: 100%; object-fit: cover; transition: transform var(--vora-transition-slow); }
.sdgv-ledger__image:hover img { transform: scale(1.05); }
.sdgv-ledger__image-caption {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,29,54,0.8) 0%, transparent 50%);
  display: flex; align-items: flex-end; padding: 24px;
}
.sdgv-ledger__image-caption p { font-family: var(--vora-serif); font-style: italic; color: #fff; font-size: 20px; }

/* Right form column */
.sdgv-redeem__right {
  background: var(--vora-glass-strong);
  backdrop-filter: var(--vora-glass-strong-blur);
  -webkit-backdrop-filter: var(--vora-glass-strong-blur);
  border-top: 0.5px solid rgba(255,255,255,0.4);
  border-radius: var(--vora-radius-lg);
  padding: 48px;
  box-shadow: var(--vora-shadow-lg);
}
@media (max-width: 640px) { .sdgv-redeem__right { padding: 28px; } }
.sdgv-redeem__form-title { font-family: var(--vora-serif); font-style: italic; font-size: 32px; color: var(--vora-on-surface); margin-bottom: 8px; }
.sdgv-redeem__form-sub { font-size: 13px; color: rgba(92,95,97,0.7); margin-bottom: 40px; line-height: 1.6; }
.sdgv-redeem__input-label {
  display: block; font-size: 10px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--vora-outline); margin-bottom: 10px; margin-left: 16px;
}
.sdgv-redeem__code-input {
  width: 100%; font-size: 16px; padding: 16px 24px;
  border-radius: var(--vora-radius-full);
  background: var(--vora-surf-lowest);
  border: 1px solid rgba(195,198,207,0.3);
  color: var(--vora-on-surface); outline: none;
  letter-spacing: 0.08em; text-transform: uppercase;
  transition: border-color var(--vora-transition); margin-bottom: 24px; display: block;
  font-family: var(--vora-sans);
}
.sdgv-redeem__code-input::placeholder { opacity: 0.3; text-transform: none; }
.sdgv-redeem__code-input:focus { border-color: var(--vora-tertiary); }
.sdgv-redeem__btn-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 12px; }
@media (max-width: 480px) { .sdgv-redeem__btn-row { grid-template-columns: 1fr; } }
.sdgv-btn--balance {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--vora-on-surface); color: #fff;
  border: none; border-radius: var(--vora-radius-full);
  padding: 18px 20px; font-family: var(--vora-sans); font-size: 11px;
  font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
  cursor: pointer; transition: all var(--vora-transition);
  box-shadow: 0 8px 24px rgba(0,29,54,0.12); white-space: nowrap;
}
.sdgv-btn--balance:hover { background: var(--vora-tertiary); transform: translateY(-1px); }
.sdgv-btn--balance.is-loading::after { content: ''; width: 13px; height: 13px; border: 2px solid rgba(255,255,255,0.5); border-top-color: #fff; border-radius: 50%; animation: sdgv-spin 0.6s linear infinite; display: inline-block; margin-left: 8px; }
.sdgv-btn--redeem {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  background: var(--vora-glass-strong);
  backdrop-filter: var(--vora-glass-strong-blur);
  -webkit-backdrop-filter: var(--vora-glass-strong-blur);
  color: var(--vora-on-surface);
  border: 1px solid rgba(195,198,207,0.3);
  border-radius: var(--vora-radius-full);
  padding: 18px 20px; font-family: var(--vora-sans); font-size: 11px;
  font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase;
  cursor: pointer; transition: all var(--vora-transition);
  box-shadow: 0 8px 24px rgba(0,29,54,0.05); white-space: nowrap;
}
.sdgv-btn--redeem:hover:not(:disabled) { background: rgba(255,255,255,0.4); }
.sdgv-btn--redeem:disabled { opacity: 0.35; cursor: not-allowed; }
.sdgv-btn--redeem.is-loading::after { content: ''; width: 13px; height: 13px; border: 2px solid rgba(0,29,54,0.3); border-top-color: var(--vora-on-surface); border-radius: 50%; animation: sdgv-spin 0.6s linear infinite; display: inline-block; margin-left: 8px; }
.sdgv-redeem__disclaimer { font-size: 10px; color: rgba(92,95,97,0.5); letter-spacing: 0.1em; text-transform: uppercase; font-style: italic; margin-bottom: 40px; }
/* Redeem info cards */
.sdgv-redeem__trust { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; padding-top: 32px; border-top: 1px solid rgba(195,198,207,0.15); }
@media (max-width: 480px) { .sdgv-redeem__trust { grid-template-columns: 1fr; } }
.sdgv-redeem__trust-item { display: flex; gap: 12px; }
.sdgv-redeem__trust-icon { font-size: 22px; color: rgba(92,95,97,0.4); flex-shrink: 0; line-height: 1.4; }
.sdgv-redeem__trust-title { font-size: 10px; font-weight: 700; letter-spacing: 0.15em; text-transform: uppercase; color: var(--vora-on-surface); margin-bottom: 4px; }
.sdgv-redeem__trust-text { font-size: 11px; line-height: 1.6; color: rgba(92,95,97,0.6); }
/* Redemption result */
.sdgv-redemption-result { margin-top: 24px; border-radius: var(--vora-radius-lg); padding: 28px; animation: sdgv-fade-in 0.3s ease; box-shadow: var(--vora-shadow); }
.sdgv-redemption-result--valid { background: rgba(255,255,255,0.8); }
.sdgv-redemption-result--invalid { background: var(--vora-danger-l); }
.sdgv-redemption-result__status { font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; font-weight: 700; margin-bottom: 8px; color: var(--vora-outline); }
.sdgv-redemption-result--valid .sdgv-redemption-result__status { color: var(--sdgv-success); }
.sdgv-redemption-result--invalid .sdgv-redemption-result__status { color: var(--vora-error); }
.sdgv-redemption-result__title { font-family: var(--vora-serif); font-style: italic; font-size: 26px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 18px; }
.sdgv-redemption-result__row { display: flex; justify-content: space-between; align-items: center; padding: 10px 0; border-bottom: 1px solid rgba(195,198,207,0.15); font-size: 14px; }
.sdgv-redemption-result__row:last-child { border-bottom: none; }
.sdgv-redemption-result__row span:first-child { color: var(--vora-secondary); font-size: 11px; text-transform: uppercase; letter-spacing: 0.08em; }
.sdgv-redemption-result__row span:last-child { font-weight: 600; color: var(--vora-on-surface); }
.sdgv-redemption-info { margin-top: 24px; padding: 20px 24px; background: var(--vora-surf-low); border-radius: var(--vora-radius-lg); font-size: 13px; color: var(--vora-secondary); line-height: 1.7; }
.sdgv-redeem-success { background: rgba(255,255,255,0.8); border-radius: var(--vora-radius-xl); padding: 36px; text-align: center; animation: sdgv-fade-in 0.4s ease; }
.sdgv-redeem-success__icon { font-size: 44px; margin-bottom: 14px; }
.sdgv-redeem-success__title { font-family: var(--vora-serif); font-style: italic; font-size: 28px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 8px; }
.sdgv-redeem-success__sub { font-size: 13px; color: var(--vora-secondary); line-height: 1.6; margin-bottom: 20px; }
.sdgv-redeem-success__amount { font-family: var(--vora-serif); font-style: italic; font-size: 44px; font-weight: 400; color: var(--vora-tertiary); margin-bottom: 20px; }

/* ── BALANCE CHECK PAGE ─────────────────────────────────────── */
.sdgv-balance-history { margin-top: 12px; }
.sdgv-balance-history h4 { font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em; color: var(--vora-outline); font-weight: 600; margin-bottom: 8px; margin-top: 16px; }

/* ── BULK / LOYALTY (kept for admin usage, hidden from frontend) */
.sdgv-bulk-tiers { display: flex; gap: 10px; margin-bottom: 24px; flex-wrap: wrap; }
.sdgv-bulk-tier { flex: 1; min-width: 70px; background: rgba(255,255,255,0.6); border-radius: var(--vora-radius); padding: 16px 10px; text-align: center; transition: all var(--vora-transition); box-shadow: var(--sdgv-shadow-sm); }
.sdgv-bulk-tier:hover { transform: translateY(-2px); box-shadow: var(--vora-shadow); }
.sdgv-bulk-tier__qty { font-family: var(--vora-serif); font-style: italic; font-size: 22px; font-weight: 400; color: var(--vora-on-surface); margin-bottom: 4px; }
.sdgv-bulk-tier__disc { font-size: 11px; font-weight: 700; color: var(--sdgv-success); text-transform: uppercase; letter-spacing: 0.1em; }
.sdgv-bulk-form { margin-bottom: 20px; }
.sdgv-bulk-step { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid rgba(195,198,207,0.15); }
.sdgv-bulk-step:last-child { border-bottom: none; }
.sdgv-bulk-step__num { flex-shrink: 0; width: 26px; height: 26px; border-radius: 50%; background: var(--vora-on-surface); color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin-top: 2px; }
.sdgv-bulk-step__body { flex: 1; }
.sdgv-bulk-step__body h3 { font-family: var(--vora-serif); font-style: italic; font-size: 18px; font-weight: 400; margin-bottom: 10px; color: var(--vora-on-surface); }
.sdgv-bulk-pricing-summary { background: var(--vora-surf-low); border-radius: var(--vora-radius); padding: 18px; height: 100%; display: flex; flex-direction: column; justify-content: center; }
.sdgv-bulk-pricing__label { font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em; color: var(--vora-outline); margin-bottom: 8px; }
.sdgv-bulk-pricing__total { font-family: var(--vora-serif); font-style: italic; font-size: 28px; font-weight: 400; color: var(--vora-on-surface); }
.sdgv-bulk-pricing__saving { font-size: 12px; font-weight: 600; color: var(--sdgv-success); margin-top: 4px; }
.sdgv-csv-drop { border: 1px dashed rgba(195,198,207,0.5); border-radius: var(--vora-radius-lg); padding: 36px 20px; text-align: center; cursor: pointer; transition: all var(--vora-transition); background: var(--vora-surf-low); }
.sdgv-csv-drop:hover, .sdgv-csv-drop.dragover { border-color: var(--vora-tertiary); background: rgba(255,224,136,0.05); }
.sdgv-csv-drop__icon { font-size: 30px; margin-bottom: 10px; }
.sdgv-csv-drop__label { font-size: 14px; font-weight: 600; color: var(--vora-on-surface); margin-bottom: 4px; }
.sdgv-csv-drop__hint { font-size: 12px; color: var(--vora-secondary); }
.sdgv-csv-preview { margin-top: 12px; background: rgba(255,255,255,0.7); border-radius: var(--vora-radius); overflow: hidden; }
.sdgv-csv-preview-row { display: flex; border-bottom: 1px solid rgba(195,198,207,0.15); font-size: 13px; }
.sdgv-csv-preview-row:last-child { border-bottom: none; }
.sdgv-csv-preview-row span { flex: 1; padding: 8px 12px; border-right: 1px solid rgba(195,198,207,0.12); }
.sdgv-csv-preview-row span:last-child { border-right: none; }
.sdgv-csv-preview-row.header { background: var(--vora-surf-low); font-weight: 600; font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--vora-outline); }
.sdgv-csv-count { font-size: 12px; color: var(--vora-secondary); padding: 8px 12px; background: var(--vora-surf-low); }
.sdgv-bulk-actions { padding-top: 20px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }

/* ── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 760px) {
  .sdgv-basket-layout, .sdgv-checkout-layout { flex-direction: column; }
  .sdgv-basket-summary, .sdgv-basket__sidebar, .sdgv-checkout-sidebar { width: 100%; }
  .sdgv-wrap--checkout, .sdgv-wrap--page, .sdgv-wrap--confirmation { padding-left: 20px; padding-right: 20px; }
  .sdgv-util-bar { padding: 0 16px; }
  .sdgv-grid { padding-left: 16px; padding-right: 16px; }
  .sdgv-footer { padding: 28px 20px; }
}

/* ============================================================
   v1.6 PATCHES — Mobile-optimized, full-width, button fixes
   ============================================================ */

/* ── 1. Full-width layout: remove page-level max-width constraints ── */
.sdgv-wrap--checkout { max-width: 100%; padding: 48px 24px 100px; }
@media (min-width: 768px) { .sdgv-wrap--checkout { padding: 48px 48px 100px; } }
@media (min-width: 1200px) { .sdgv-wrap--checkout { padding: 56px 80px 120px; max-width: 1400px; margin: 0 auto; } }

.sdgv-wrap--page { padding: 60px 20px; max-width: 100%; }
@media (min-width: 768px) { .sdgv-wrap--page { padding: 60px 48px; } }

/* ── 2. Header: full-width style ───────────────────────────── */
.sdgv-header--full {
  position: sticky !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  width: 100% !important;
  border-radius: 0 !important;
  transform: none !important;
  max-width: 100% !important;
  height: 70px !important;
  padding: 0 24px !important;
}
@media (min-width: 768px) { .sdgv-header--full { padding: 0 48px !important; height: 72px !important; } }

/* ── 3. Mobile: floating pill scales correctly ──────────────── */
@media (max-width: 639px) {
  .sdgv-header {
    width: 94% !important;
    top: 12px !important;
    padding: 0 18px !important;
    height: 56px !important;
  }
  .sdgv-nav-offset { padding-top: 88px !important; }
  .sdgv-header__nav { display: none !important; } /* hidden on mobile – use drawer */
}

/* ── 4. Global page offset for full-width header ────────────── */
.sdgv-nav-offset--full { padding-top: 70px; }
@media (min-width: 768px) { .sdgv-nav-offset--full { padding-top: 72px; } }

/* ── 5. Storefront: edge-to-edge with safe-zone gutters ─────── */
.sdgv-cinematic-hero { padding: 60px 20px 48px; }
@media (min-width: 768px) { .sdgv-cinematic-hero { padding: 80px 48px 60px; } }

.sdgv-util-bar { padding: 0 16px; }
@media (min-width: 768px) { .sdgv-util-bar { padding: 0 48px; } }

.sdgv-grid { padding: 0 16px 60px; gap: 20px; }
@media (min-width: 640px) { .sdgv-grid { padding: 0 24px 60px; gap: 24px; } }
@media (min-width: 960px) { .sdgv-grid { padding: 0 48px 80px; gap: 32px; } }

/* ── 6. Checkout button: white bold text, always visible ─────── */
.sdgv-btn--primary {
  background: var(--vora-on-surface) !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  letter-spacing: 0.15em !important;
  -webkit-font-smoothing: antialiased;
  min-height: 52px;
  padding: 16px 28px !important;
}
.sdgv-btn--primary:hover {
  background: var(--vora-on-surface) !important;
  color: #ffffff !important;
}
/* Ensure text is never hidden by backdrop filter on ios */
.sdgv-btn--primary span,
.sdgv-btn--primary strong { color: inherit; }

/* ── 7. Basket: proceed-to-checkout button ──────────────────── */
.sdgv-basket-summary .sdgv-btn--primary,
.sdgv-basket-summary a.sdgv-btn--primary {
  display: flex !important;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase;
  min-height: 52px;
  border-radius: 9999px !important;
}

/* ── 8. Mobile touch targets — minimum 44px ─────────────────── */
.sdgv-btn { min-height: 44px; }
.sdgv-qty__btn { min-width: 44px; min-height: 44px; }
.sdgv-basket-icon { min-width: 44px; min-height: 44px; display: flex; align-items: center; justify-content: center; }
.sdgv-header__actions a, .sdgv-header__actions button { min-width: 44px; min-height: 44px; }

/* ── 9. Basket count: numeric badge on icon ─────────────────── */
.sdgv-basket-count {
  position: absolute;
  top: -2px; right: -4px;
  background: var(--vora-on-surface);
  color: #fff;
  font-family: var(--vora-sans);
  font-size: 10px;
  font-weight: 700;
  min-width: 18px;
  height: 18px;
  border-radius: 9999px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid rgba(255,255,255,0.8);
}
.sdgv-basket-icon { position: relative; }

/* ── 10. Voucher card: quantity overlay badge ───────────────── */
.sdgv-card__qty-badge {
  position: absolute;
  top: 12px; right: 12px;
  background: var(--vora-on-surface);
  color: #fff;
  font-family: var(--vora-sans);
  font-size: 11px; font-weight: 700;
  border-radius: 9999px;
  padding: 3px 10px;
  display: none;
  align-items: center;
  gap: 4px;
  z-index: 3;
  pointer-events: none;
}
.sdgv-card__qty-badge.is-visible { display: flex; }
.sdgv-card__qty-badge svg { width: 12px; height: 12px; }

/* ── 11. Checkout: voucher type cards — mobile stack ────────── */
.sdgv-voucher-type-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-bottom: 16px;
}
@media (min-width: 500px) { .sdgv-voucher-type-grid { grid-template-columns: repeat(3, 1fr); } }

.sdgv-type-card {
  border: 1px solid rgba(195,198,207,0.3);
  border-radius: var(--vora-radius-lg);
  padding: 20px 16px;
  cursor: pointer;
  transition: all var(--vora-transition);
  background: rgba(255,255,255,0.5);
}
/* Template-aware button colour: set via JS via data-attr on form */
.sdgv-btn--pay[data-template="classic"]  { background: #1a1a1a !important; }
.sdgv-btn--pay[data-template="minimal"]  { background: #444 !important; }
.sdgv-btn--pay[data-template="elegant"]  { background: #c9a96e !important; }
.sdgv-btn--pay[data-template="bold"]     { background: #2c5f2e !important; }
.sdgv-btn--pay[data-template="seasonal"] { background: #8b2500 !important; }

/* ── 12. Checkout layout: responsive sidebar ────────────────── */
.sdgv-checkout-layout { display: flex; gap: 32px; flex-wrap: wrap; align-items: flex-start; }
.sdgv-checkout-form   { flex: 1 1 320px; min-width: 0; }
.sdgv-checkout-sidebar { flex: 0 0 100%; order: -1; }
@media (min-width: 900px) {
  .sdgv-checkout-sidebar { flex: 0 0 320px; order: 0; position: sticky; top: 100px; }
}

/* ── 13. Body font setting (applied via inline CSS on wrap) ──── */
.sdgv-wrap { font-family: var(--sdgv-body-font, var(--vora-sans)); }

/* ── 14. Voucher card shape — CSS custom property ───────────── */
.sdgv-card { border-radius: var(--sdgv-card-radius, var(--vora-radius-lg)); }
.sdgv-card__image-link { border-radius: var(--sdgv-card-radius, var(--vora-radius-lg)) var(--sdgv-card-radius, var(--vora-radius-lg)) 0 0; }

/* ── 15. Portal template cards: selection state ─────────────── */
.sp-tpl-card {
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 8px;
  overflow: hidden;
  transition: all 0.2s ease;
  position: relative;
}
.sp-tpl-card:hover { border-color: var(--sp-accent); }
.sp-tpl-card.is-selected { border-color: var(--sp-accent); }
.sp-tpl-card__checkmark {
  display: none;
  position: absolute;
  top: 8px; right: 8px;
  width: 22px; height: 22px;
  background: var(--sp-accent);
  border-radius: 50%;
  align-items: center; justify-content: center;
  font-size: 12px; color: #fff;
}
.sp-tpl-card.is-selected .sp-tpl-card__checkmark { display: flex; }

/* ── 16. Mobile bottom safe-area padding ────────────────────── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  .sdgv-footer, .sdgv-section-alt { padding-bottom: calc(40px + env(safe-area-inset-bottom)); }
}

/* ── 17. Prevent horizontal overflow on all pages ───────────── */
.sdgv-wrap { overflow-x: hidden; }

/* ============================================================
   SINGLE VOUCHER PAGE — sdgv-sv__* components
   ============================================================ */

/* ── Reset inside single page ──────────────────────────────── */
.sdgv-single-voucher { font-family: var(--vora-sans); color: #1A1A1A; background: #FAF9F6; }
.sdgv-single-voucher *, .sdgv-single-voucher *::before, .sdgv-single-voucher *::after { box-sizing: border-box; }
.sdgv-single-voucher a { text-decoration: none; color: inherit; }
.sdgv-single-voucher img { display: block; max-width: 100%; }

/* ── Hero ─────────────────────────────────────────────────── */
.sdgv-sv__hero {
  max-width: 1536px; margin: 0 auto;
  padding: 48px 24px 64px; text-align: center;
}
@media (min-width: 768px) { .sdgv-sv__hero { padding: 64px 48px 80px; } }
@media (min-width: 1280px) { .sdgv-sv__hero { padding: 64px 80px 96px; } }

.sdgv-sv__eyebrow {
  display: block;
  font-family: var(--vora-sans);
  font-size: 11px; letter-spacing: 0.5em; text-transform: uppercase;
  color: #5c5f61; margin-bottom: 20px;
}
.sdgv-sv__title {
  font-family: var(--vora-serif); font-style: italic;
  font-size: clamp(40px, 7vw, 96px); font-weight: 400;
  color: #1A1A1A; line-height: 1.05; letter-spacing: -0.01em; margin: 0;
}

/* ── Hero image ───────────────────────────────────────────── */
.sdgv-sv__hero-image-wrap { max-width: 1536px; margin: 0 auto; padding: 0 24px 64px; }
@media (min-width: 768px) { .sdgv-sv__hero-image-wrap { padding: 0 48px 80px; } }
.sdgv-sv__hero-image {
  width: 100%; aspect-ratio: 21/9; overflow: hidden;
  border-radius: 4px; background: #e8e5e0;
}
/* Fallback for browsers without aspect-ratio */
@supports not (aspect-ratio: 21/9) { .sdgv-sv__hero-image { height: 420px; } }
.sdgv-sv__hero-img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(0.2); transform: scale(1.05);
  transition: filter 1s ease;
}
.sdgv-sv__hero-img:hover { filter: grayscale(0); }

/* ── Detail grid ─────────────────────────────────────────── */
.sdgv-sv__detail-section {
  max-width: 1280px; margin: 0 auto; padding: 0 24px 80px;
}
@media (min-width: 768px) { .sdgv-sv__detail-section { padding: 0 48px 80px; } }

.sdgv-sv__detail-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
}
@media (min-width: 768px) {
  .sdgv-sv__detail-grid { grid-template-columns: 5fr 4fr; gap: 40px; }
}
@media (min-width: 1100px) {
  .sdgv-sv__detail-grid { grid-template-columns: 5fr 4fr 3fr; }
}

/* Description */
.sdgv-sv__excerpt {
  font-size: 18px; line-height: 1.75; color: #4A4A4A;
  font-weight: 300; margin-bottom: 20px;
}
@media (min-width: 768px) { .sdgv-sv__excerpt { font-size: 20px; } }
.sdgv-sv__body { font-size: 15px; line-height: 1.8; color: #4A4A4A; }
.sdgv-sv__body p { margin-bottom: 16px; }

/* Order controls */
.sdgv-sv__col-order {
  border-top: 1px solid #E5E5E5; padding-top: 32px;
}
@media (min-width: 768px) {
  .sdgv-sv__col-order { border-top: none; border-left: 1px solid #E5E5E5; padding-top: 0; padding-left: 40px; }
}
@media (min-width: 1100px) { .sdgv-sv__col-order { padding-left: 56px; } }

.sdgv-sv__price-wrap { margin-bottom: 24px; }
.sdgv-sv__price-label {
  display: block; font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: #4A4A4A; margin-bottom: 8px;
}
.sdgv-sv__price {
  font-family: var(--vora-serif); font-style: italic;
  font-size: clamp(28px, 4vw, 40px); color: #1A1A1A; display: block;
}
.sdgv-sv__field { margin-bottom: 16px; }
.sdgv-sv__field-label {
  display: block; font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.15em; text-transform: uppercase; color: #4A4A4A; margin-bottom: 8px;
}
.sdgv-sv__select {
  width: 100%; background: transparent;
  border: none; border-bottom: 1px solid #E5E5E5;
  padding: 14px 0; font-family: var(--vora-sans);
  font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase;
  appearance: none; outline: none; cursor: pointer; color: #1A1A1A; border-radius: 0;
}
.sdgv-sv__input {
  width: 100%; background: transparent;
  border: none; border-bottom: 1px solid #E5E5E5;
  padding: 14px 0; font-family: var(--vora-sans);
  font-size: 18px; outline: none; color: #1A1A1A; border-radius: 0;
}
.sdgv-sv__add-btn {
  width: 100%; background: #2D3436; color: #fff;
  border: none; padding: 20px 24px;
  font-family: var(--vora-sans); font-size: 11px;
  letter-spacing: 0.3em; text-transform: uppercase;
  cursor: pointer; transition: background 0.5s, opacity 0.3s;
  margin-top: 8px; margin-bottom: 20px; min-height: 60px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 0;
}
.sdgv-sv__add-btn:hover { background: #1a1a1a; }
.sdgv-sv__add-btn:disabled, .sdgv-sv__add-btn.is-loading { opacity: 0.5; pointer-events: none; }
.sdgv-sv__links { display: flex; flex-direction: column; gap: 0; }
.sdgv-sv__link {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--vora-sans); font-size: 11px; letter-spacing: 0.15em;
  text-transform: uppercase; color: #4A4A4A;
  padding: 14px 0; border-bottom: 1px solid #E5E5E5;
  transition: color 0.3s;
}
.sdgv-sv__link:hover { color: #1A1A1A; }

/* Process column */
.sdgv-sv__col-process {
  border-top: 1px solid #E5E5E5; padding-top: 32px;
}
@media (min-width: 1100px) { .sdgv-sv__col-process { border-top: none; padding-top: 0; padding-left: 32px; border-left: 1px solid #E5E5E5; } }

.sdgv-sv__process-title {
  font-family: var(--vora-serif); font-style: italic;
  font-size: 22px; color: #2D3436; margin-bottom: 28px;
}
.sdgv-sv__step { display: flex; gap: 16px; margin-bottom: 24px; }
.sdgv-sv__step:last-child { margin-bottom: 0; }
.sdgv-sv__step-num {
  font-family: var(--vora-sans); font-size: 11px;
  color: #A68911; flex-shrink: 0; padding-top: 2px; font-weight: 600;
}
.sdgv-sv__step-text { font-size: 14px; color: #4A4A4A; line-height: 1.7; margin: 0; }

/* ── Reviews ─────────────────────────────────────────────── */
.sdgv-sv__reviews-section {
  padding: 60px 24px; border-top: 1px solid #E5E5E5;
  background: rgba(255,255,255,0.4);
}
@media (min-width: 768px) { .sdgv-sv__reviews-section { padding: 80px 48px; } }
.sdgv-sv__reviews-header { text-align: center; margin-bottom: 48px; }
.sdgv-sv__reviews-title {
  font-family: var(--vora-serif); font-style: italic;
  font-size: clamp(32px, 4vw, 48px); color: #1A1A1A; margin-bottom: 8px;
}
.sdgv-sv__reviews-sub {
  font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.4em; text-transform: uppercase; color: #A68911;
}
.sdgv-sv__reviews-grid { max-width: 900px; margin: 0 auto; display: flex; gap: 40px; flex-wrap: wrap; }
.sdgv-sv__review { flex: 1 1 240px; text-align: center; }
.sdgv-sv__review-text { font-size: 16px; line-height: 1.75; color: #4A4A4A; font-style: italic; margin-bottom: 16px; }
.sdgv-sv__review-rating { color: #A68911; font-size: 18px; }

/* ── Delivery info ───────────────────────────────────────── */
.sdgv-sv__delivery-section {
  padding: 60px 24px; border-top: 1px solid #E5E5E5;
}
@media (min-width: 768px) { .sdgv-sv__delivery-section { padding: 80px 48px; } }
.sdgv-sv__delivery-inner {
  max-width: 960px; margin: 0 auto;
  display: flex; flex-wrap: wrap; gap: 48px; align-items: flex-start;
}
.sdgv-sv__delivery-icon { flex-shrink: 0; }
.sdgv-sv__envelope-mock {
  width: 160px; height: 200px;
  background: #fff; border: 1px solid #E5E5E5;
  border-radius: 2px; display: flex; align-items: center; justify-content: center;
  filter: grayscale(0.5); transition: filter 0.7s;
}
.sdgv-sv__envelope-mock:hover { filter: grayscale(0); }
@media (max-width: 600px) { .sdgv-sv__envelope-mock { width: 120px; height: 150px; } }
.sdgv-sv__delivery-body { flex: 1; min-width: 260px; }
.sdgv-sv__delivery-title {
  font-family: var(--vora-serif); font-style: italic;
  font-size: clamp(28px, 3vw, 40px); color: #1A1A1A;
  margin-bottom: 16px; line-height: 1.2;
}
.sdgv-sv__delivery-desc {
  font-size: 16px; line-height: 1.8; color: #4A4A4A;
  font-weight: 300; margin-bottom: 28px;
}
.sdgv-sv__delivery-meta {
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  margin-bottom: 20px;
}
.sdgv-sv__meta-label {
  font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: #4A4A4A; margin-bottom: 4px;
}
.sdgv-sv__meta-val { font-size: 14px; font-weight: 500; color: #1A1A1A; }
.sdgv-sv__terms { font-size: 12px; color: #4A4A4A; line-height: 1.6; }

/* ── Related vouchers ────────────────────────────────────── */
.sdgv-sv__related-section {
  padding: 60px 24px; border-top: 1px solid #E5E5E5;
}
@media (min-width: 768px) { .sdgv-sv__related-section { padding: 80px 48px; } }
.sdgv-sv__related-header { text-align: center; margin-bottom: 48px; }
.sdgv-sv__related-title {
  font-family: var(--vora-serif); font-style: italic;
  font-size: clamp(36px, 4vw, 52px); color: #2D3436;
}
.sdgv-sv__related-grid {
  max-width: 1280px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr;
  gap: 32px;
}
@media (min-width: 600px)  { .sdgv-sv__related-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 900px)  { .sdgv-sv__related-grid { grid-template-columns: repeat(3, 1fr); gap: 40px; } }

.sdgv-sv__related-card { cursor: pointer; }
.sdgv-sv__related-img-wrap {
  position: relative; aspect-ratio: 3/4; overflow: hidden;
  border-radius: 8px; margin-bottom: 20px; background: #e8e5e0;
}
@supports not (aspect-ratio: 3/4) { .sdgv-sv__related-img-wrap { height: 320px; } }
.sdgv-sv__related-img {
  width: 100%; height: 100%; object-fit: cover;
  filter: grayscale(1); transition: all 1s ease;
}
.sdgv-sv__related-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.05); transition: background 0.5s;
}
.sdgv-sv__related-card:hover .sdgv-sv__related-overlay { background: rgba(0,0,0,0); }
.sdgv-sv__related-add {
  position: absolute; bottom: 16px; right: 16px;
  width: 44px; height: 44px; background: #fff; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  font-size: 20px; color: #1A1A1A;
  transition: transform 0.3s;
}
.sdgv-sv__related-add:hover { transform: scale(1.1); }
.sdgv-sv__related-placeholder { width: 100%; height: 100%; background: linear-gradient(135deg, #e8e5e0, #d0cdc8); }
.sdgv-sv__related-info { text-align: center; }
.sdgv-sv__related-name {
  font-family: var(--vora-serif); font-style: italic;
  font-size: 22px; color: #1A1A1A; margin-bottom: 8px;
}
.sdgv-sv__related-price {
  font-family: var(--vora-sans); font-size: 11px;
  letter-spacing: 0.15em; text-transform: uppercase; color: #4A4A4A; margin-bottom: 10px;
}
.sdgv-sv__related-link {
  font-family: var(--vora-sans); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: #4A4A4A;
  border-bottom: 1px solid #E5E5E5; padding-bottom: 3px;
  display: inline-block; transition: color 0.3s, border-color 0.3s;
}
.sdgv-sv__related-link:hover { color: #1A1A1A; border-color: #1A1A1A; }

/* ── Suppress WordPress theme title/content on voucher singles ── */
.single-sdgv_voucher .entry-title,
.single-sdgv_voucher .page-title,
.single-sdgv_voucher .entry-header,
.single-sdgv_voucher .post-thumbnail { display: none !important; }

/* ============================================================
   MOBILE BASKET — complete rewrite to fix stacking bug
   ============================================================ */

/* Override conflicting flex rules */
.sdgv-basket-layout {
  display: flex !important;
  flex-direction: column !important;
  gap: 24px !important;
}
@media (min-width: 860px) {
  .sdgv-basket-layout {
    flex-direction: row !important;
    gap: 40px !important;
    align-items: flex-start !important;
  }
}

/* Items column — always full width on mobile */
.sdgv-basket-items {
  flex: 1 1 auto !important;
  width: 100% !important;
  min-width: 0 !important;
}

/* Summary sidebar — full width mobile, fixed width desktop */
.sdgv-basket-summary {
  flex: 0 0 auto !important;
  width: 100% !important;
  max-width: 100% !important;
  position: static !important;
}
@media (min-width: 860px) {
  .sdgv-basket-summary {
    width: 340px !important;
    max-width: 340px !important;
    flex: 0 0 340px !important;
    position: sticky !important;
    top: 100px !important;
  }
}

/* Basket items always visible — remove the old flex:1 1 400px that hides them */
.sdgv-basket-item {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 12px !important;
  align-items: flex-start !important;
  padding: 16px 0 !important;
  border-bottom: 1px solid rgba(195,198,207,0.2) !important;
  width: 100% !important;
}
.sdgv-basket-item__info { flex: 1 1 auto !important; min-width: 0 !important; overflow: hidden; }
.sdgv-basket-item__info h3 { font-size: 15px !important; white-space: normal !important; word-break: break-word; }
.sdgv-basket-item__actions { flex-shrink: 0 !important; }

/* Basket item image */
.sdgv-basket-item > div:first-child:has(img) {
  flex-shrink: 0 !important; width: 64px !important; height: 64px !important;
}
@media (max-width: 400px) {
  .sdgv-basket-item > div:first-child:has(img) { width: 52px !important; height: 52px !important; }
}

/* ── HEADER: ensure it renders on WP single CPT pages ─────── */
/* When WP theme renders its own header, this CSS scopes correctly */
.sdgv-wrap .sdgv-global-header,
#sdgv-global-header { z-index: 9999 !important; }

/* On floating pill: mobile safe zone */
@media (max-width: 480px) {
  #sdgv-global-header[style*="fixed"] {
    width: 95% !important;
    top: 12px !important;
    padding: 0 16px !important;
    height: 54px !important;
  }
}

/* ==========================================================
   v2.0 — Layout & UI Fixes
   ========================================================== */

/* FIX 1 & 6 — Hero: remove excess top gap, shrink overall size */
.sdgv-cinematic-hero {
  padding-top: 0 !important;
  padding-bottom: 32px !important;
}
@media (min-width: 768px) {
  .sdgv-cinematic-hero {
    padding-top: 0 !important;
    padding-bottom: 40px !important;
  }
}
.sdgv-cinematic-hero__title {
  font-size: clamp(32px, 4.5vw, 60px) !important;
  margin-bottom: 12px !important;
}

/* FIX 4 — Filter bar: allow working controls without clipping */
.sdgv-util-bar__inner {
  flex-wrap: wrap !important;
  overflow-x: visible !important;
  -webkit-overflow-scrolling: touch !important;
}
.sdgv-util-bar__inner::-webkit-scrollbar { display: none !important; }
.sdgv-util-bar__right {
  flex-shrink: 0 !important;
  margin-left: auto !important;
  white-space: normal !important;
}
.sdgv-util-bar__filter-label,
.sdgv-util-bar__sort,
.sdgv-util-bar__result-count {
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}

@media (max-width: 760px) {
  .sdgv-util-bar__inner {
    border-radius: 22px !important;
    align-items: stretch !important;
  }
  .sdgv-util-bar__cats,
  .sdgv-util-bar__left,
  .sdgv-util-bar__right {
    width: 100% !important;
    margin-left: 0 !important;
  }
  .sdgv-util-bar__right {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }
  .sdgv-util-bar__search,
  .sdgv-util-bar__filter-select,
  .sdgv-util-bar__sort {
    max-width: none !important;
    width: 100% !important;
  }
}

/* FIX 5 — Filter bar: push further down from hero */
.sdgv-util-bar {
  margin-top: 40px !important;
  margin-bottom: 32px !important;
}

/* FIX 3 — Account page: mobile-responsive layout */
.sdgv-account-wrap {
  max-width: 1100px;
  margin: 0 auto;
  padding: 36px 16px 80px;
}
@media (min-width: 640px) {
  .sdgv-account-wrap { padding: 40px 32px 80px; }
}
@media (min-width: 900px) {
  .sdgv-account-wrap { padding: 48px 48px 80px; }
}
.sdgv-account-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
@media (min-width: 860px) {
  .sdgv-account-layout {
    grid-template-columns: 280px 1fr;
    gap: 28px;
  }
}
.sdgv-account-card {
  background: rgba(255,255,255,0.72);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-radius: var(--vora-radius-xl);
  padding: 24px;
  box-shadow: var(--vora-shadow);
}
.sdgv-account-card__eyebrow {
  display: block;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--vora-outline);
  margin-bottom: 8px;
}
.sdgv-account-card__name {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 22px;
  font-weight: 400;
  color: var(--vora-on-surface);
  margin-bottom: 3px;
}
.sdgv-account-card__email {
  font-size: 12px;
  color: var(--vora-secondary);
  margin-bottom: 16px;
}
.sdgv-account-stat {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid rgba(195,198,207,0.15);
}
.sdgv-account-stat:last-child { border-bottom: none; }
.sdgv-account-stat__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--vora-outline);
}
.sdgv-account-stat__val {
  font-weight: 600;
  color: var(--vora-on-surface);
  font-size: 13px;
}
.sdgv-orders-title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 22px;
  font-weight: 400;
  color: var(--vora-on-surface);
  margin-bottom: 16px;
}
.sdgv-order-row {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(195,198,207,0.15);
}
.sdgv-order-row:first-of-type {
  border-top: 1px solid rgba(195,198,207,0.15);
}
@media (min-width: 480px) {
  .sdgv-order-row {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }
}
.sdgv-order-row__title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 15px;
  color: var(--vora-on-surface);
  flex: 1;
}
.sdgv-order-row__meta {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.sdgv-order-row__code {
  font-family: 'Courier New', monospace;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--vora-tertiary);
  background: rgba(255,224,136,0.12);
  padding: 3px 8px;
  border-radius: var(--vora-radius-full);
}
.sdgv-order-row__price {
  font-size: 13px;
  font-weight: 600;
  color: var(--vora-on-surface);
  white-space: nowrap;
}
.sdgv-order-row__status {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--vora-radius-full);
  white-space: nowrap;
}
.sdgv-order-row__status--complete  { background: rgba(45,106,79,0.10);  color: #2d6a4f; }
.sdgv-order-row__status--scheduled { background: rgba(255,224,136,0.22); color: var(--vora-tertiary); }
.sdgv-order-row__status--redeemed  { background: rgba(195,198,207,0.2);  color: var(--vora-outline); }
.sdgv-order-row__status--pending   { background: rgba(92,95,97,0.07);    color: var(--vora-secondary); }
.sdgv-orders-empty {
  text-align: center;
  padding: 40px 20px;
  font-size: 13px;
  color: var(--vora-secondary);
}
.sdgv-orders-empty__icon {
  font-size: 32px;
  margin-bottom: 10px;
  opacity: 0.3;
}

/* ============================================================
   v2.1 — Create Account Section + Card 4:3 + Header fixes
   ============================================================ */

/* ── Create Account Section ─────────────────────────────────── */
.sdgv-create-account-section {
  background: linear-gradient(135deg, #f8f9ff 0%, #eef1f8 100%);
  padding: 80px 24px;
  margin-top: 64px;
  display: block !important;
  visibility: visible !important;
}
/* Ensure anchor scroll target is reachable */
#sdgv-create-account { scroll-margin-top: 80px; }
.sdgv-create-account-inner {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  align-items: start;
}
@media (min-width: 860px) {
  .sdgv-create-account-inner {
    grid-template-columns: 1fr 1fr;
    gap: 64px;
  }
}
.sdgv-ca-eyebrow {
  display: block;
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--vora-tertiary);
  margin-bottom: 12px;
}
.sdgv-ca-title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: clamp(28px, 3.5vw, 44px);
  font-weight: 400;
  color: var(--vora-on-surface);
  line-height: 1.1;
  margin: 0 0 14px;
}
.sdgv-ca-sub {
  font-size: 15px;
  color: var(--vora-secondary);
  line-height: 1.7;
  margin-bottom: 28px;
}
.sdgv-ca-benefits { display: flex; flex-direction: column; gap: 10px; }
.sdgv-ca-benefit {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--vora-on-surface);
}
.sdgv-ca-benefit span {
  color: var(--vora-tertiary);
  font-weight: 700;
  font-size: 16px;
}

/* ── Right: form card ─ */
.sdgv-ca-right {
  background: rgba(255,255,255,0.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--vora-radius-xl);
  padding: 36px;
  box-shadow: var(--vora-shadow);
}
.sdgv-ca-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 480px) { .sdgv-ca-row { grid-template-columns: 1fr; } }
.sdgv-ca-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}
.sdgv-ca-field label {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--vora-outline);
  font-weight: 600;
}
.sdgv-ca-field input {
  padding: 11px 14px;
  border: 1.5px solid rgba(195,198,207,0.4);
  border-radius: var(--vora-radius);
  font-size: 14px;
  color: var(--vora-on-surface);
  background: rgba(248,249,255,0.6);
  transition: border-color 0.2s;
  width: 100%;
  box-sizing: border-box;
  font-family: var(--vora-sans);
}
.sdgv-ca-field input:focus {
  outline: none;
  border-color: var(--vora-tertiary);
  background: #fff;
}
.sdgv-ca-checkbox {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 18px;
  cursor: pointer;
  font-size: 13px;
  color: var(--vora-secondary);
  line-height: 1.5;
}
.sdgv-ca-checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  margin-top: 1px;
  accent-color: var(--vora-tertiary);
}
.sdgv-ca-submit {
  width: 100%;
  padding: 15px;
  background: var(--vora-on-surface);
  color: #fff;
  border: none;
  border-radius: var(--vora-radius-full);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity 0.2s;
}
.sdgv-ca-submit:hover { opacity: 0.85; }
.sdgv-ca-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.sdgv-ca-panel .sdgv-ca-submit,
.sdgv-create-account-section .sdgv-ca-submit {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 50px !important;
  border: 0 !important;
  border-radius: var(--vora-radius-full) !important;
  background: var(--vora-on-surface) !important;
  color: #ffffff !important;
  font-family: var(--vora-sans), sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.15em !important;
  line-height: 1.2 !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  box-shadow: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
}
.sdgv-ca-panel .sdgv-ca-submit *,
.sdgv-create-account-section .sdgv-ca-submit * {
  color: #ffffff !important;
}
.sdgv-ca-panel .sdgv-ca-submit:hover,
.sdgv-create-account-section .sdgv-ca-submit:hover {
  background: var(--vora-on-surface) !important;
  color: #ffffff !important;
  opacity: 0.88 !important;
}
.sdgv-ca-terms {
  text-align: center;
  font-size: 11px;
  color: var(--vora-outline);
  margin-top: 12px;
  line-height: 1.5;
}
.sdgv-ca-terms a { color: var(--vora-tertiary); text-decoration: none; }

.sdgv-create-page {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
  padding: 34px 0 90px;
}
.sdgv-create-hero {
  padding: 0;
}
.sdgv-create-hero .sdgv-ca-panel {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(320px, 1.1fr);
  gap: 42px;
  align-items: stretch;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(195,198,207,0.24);
  border-radius: min(32px, var(--vora-radius-xl));
  padding: clamp(24px, 4vw, 46px);
  box-shadow: 0 28px 80px rgba(0,29,54,0.10);
  backdrop-filter: blur(22px);
  -webkit-backdrop-filter: blur(22px);
}
.sdgv-create-hero .sdgv-ca-panel__intro {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.sdgv-create-hero .sdgv-ca-title {
  font-size: clamp(36px, 5vw, 66px);
}
.sdgv-create-hero .sdgv-ca-sub {
  max-width: 440px;
}
.sdgv-create-hero .sdgv-ca-panel__form {
  background: rgba(248,249,255,0.76);
  border: 1px solid rgba(195,198,207,0.18);
  border-radius: 24px;
  padding: clamp(20px, 3vw, 32px);
}
.sdgv-create-login-note,
.sdgv-auth-foot {
  text-align: center;
  color: var(--vora-secondary);
  font-size: 13px;
  margin: 18px 0 0;
}
.sdgv-create-login-note a,
.sdgv-auth-foot a {
  color: var(--vora-tertiary);
  text-decoration: none;
  font-weight: 700;
}
.sdgv-account-cta {
  width: 100%;
  box-sizing: border-box;
  background: linear-gradient(145deg, rgba(255,255,255,0.84), rgba(248,249,255,0.68));
  border: 1px solid rgba(195,198,207,0.24);
  border-radius: min(28px, var(--vora-radius-xl));
  padding: 30px;
  box-shadow: 0 22px 60px rgba(0,29,54,0.08);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.sdgv-account-cta h2 {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: clamp(26px, 3vw, 38px);
  font-weight: 400;
  color: var(--vora-on-surface);
  margin: 0 0 10px;
  line-height: 1.1;
}
.sdgv-account-cta p {
  color: var(--vora-secondary);
  font-size: 14px;
  line-height: 1.7;
  margin: 0 0 20px;
}
.sdgv-account-cta__button {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 0 22px;
  border-radius: 9999px;
  background: var(--vora-on-surface);
  color: #fff !important;
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
}
.sdgv-account-cta__link {
  display: block;
  margin-top: 14px;
  color: var(--vora-tertiary);
  text-align: center;
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
}
.sdgv-auth-shell {
  max-width: 560px;
  margin: 0 auto;
  padding: 20px 0 70px;
}
.sdgv-auth-heading {
  text-align: center;
  margin-bottom: 30px;
}
.sdgv-auth-panel {
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border: 1px solid rgba(195,198,207,0.22);
  border-radius: min(28px, var(--vora-radius-xl));
  padding: clamp(24px, 4vw, 34px);
  box-shadow: 0 24px 70px rgba(0,29,54,0.10);
}
.sdgv-auth-title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: clamp(34px, 5vw, 52px);
  font-weight: 400;
  color: var(--vora-on-surface);
  line-height: 1.05;
  margin: 0 0 10px;
}
.sdgv-auth-subtitle {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 28px;
  font-weight: 400;
  color: var(--vora-on-surface);
  margin: 0 0 8px;
}
.sdgv-auth-copy {
  font-size: 14px;
  color: var(--vora-secondary);
  line-height: 1.7;
  margin: 0 0 20px;
}
.sdgv-auth-links {
  display: flex;
  justify-content: center;
  margin-top: 14px;
}
.sdgv-auth-links button {
  border: 0;
  background: transparent;
  color: var(--vora-tertiary);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.sdgv-ca-error {
  background: rgba(186,26,26,0.08);
  border-radius: var(--vora-radius);
  padding: 12px 14px;
  margin-bottom: 14px;
  font-size: 13px;
  color: var(--vora-error,#ba1a1a);
}
.sdgv-ca-success {
  background: rgba(22,101,52,0.09);
  border-radius: var(--vora-radius);
  padding: 13px 15px;
  margin-bottom: 14px;
  font-size: 13px;
  color: #14532d;
}
@media (max-width: 820px) {
  .sdgv-create-hero .sdgv-ca-panel {
    grid-template-columns: 1fr;
    gap: 24px;
  }
}
@media (max-width: 520px) {
  .sdgv-create-page {
    width: min(100% - 20px, 480px);
    padding-top: 18px;
  }
  .sdgv-create-hero .sdgv-ca-panel,
  .sdgv-auth-panel,
  .sdgv-account-cta {
    border-radius: 20px;
    padding: 22px;
  }
}

/* ── Mini create account bar (basket/checkout) ─────────────── */
.sdgv-ca-mini {
  background: rgba(248,249,255,0.95);
  border-top: 1px solid rgba(195,198,207,0.3);
  padding: 20px 24px;
}
.sdgv-ca-mini__inner {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.sdgv-ca-mini__text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.sdgv-ca-mini__text strong {
  font-size: 14px;
  color: var(--vora-on-surface);
}
.sdgv-ca-mini__text span {
  font-size: 12px;
  color: var(--vora-secondary);
}
.sdgv-ca-mini__btn {
  padding: 10px 22px;
  background: var(--vora-on-surface);
  color: #fff;
  border-radius: var(--vora-radius-full);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.sdgv-ca-mini__btn:hover { opacity: 0.8; }

/* ── Remove theme footer below plugin footer ────────────────── */
.sdgv-fullpage .site-footer,
.sdgv-fullpage #colophon,
.sdgv-fullpage footer:not(.sdgv-footer) {
  display: none !important;
}

/* ============================================================
   v2.1 — Basket count live update fix
   ============================================================ */

/* Ensure the basket badge can be shown/hidden by JS
   even when initially hidden with !important */
.sdgv-basket-count[style*="display:flex"] {
  display: flex !important;
}

/* Pulse animation when item is added */
@keyframes sdgv-badge-pop {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.55); }
  70%  { transform: scale(0.9); }
  100% { transform: scale(1); }
}
.sdgv-badge-pulse {
  animation: sdgv-badge-pop 0.4s cubic-bezier(0.36, 0.07, 0.19, 0.97) forwards;
}

/* ── Short description on storefront card ─────────────────── */
.sdgv-card__excerpt {
  font-size: 12px;
  color: var(--vora-secondary);
  line-height: 1.55;
  margin: 4px 0 10px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* ============================================================
   IMPECCABLE DESIGN IMPROVEMENTS — Mobile, Cards, Animations
   ============================================================ */

/* ── Mobile: Single-column cards fill edge-to-edge ─── */
@media (max-width: 580px) {
  .sdgv-grid {
    grid-template-columns: 1fr;
    padding: 0 12px 48px;
    gap: 16px;
  }
  .sdgv-card {
    border-radius: 16px;
  }
  .sdgv-card__body {
    padding: 20px 20px 24px;
  }
  .sdgv-card__title {
    font-size: 22px;
    min-height: auto;
    margin-bottom: 8px;
  }
  .sdgv-card__desc {
    display: none; /* hide on mobile for cleaner card */
  }
  .sdgv-card__footer {
    margin-top: 12px;
  }
  /* Hero text scales well on small screens */
  .sdgv-cinematic-hero {
    padding: 48px 16px 36px !important;
    text-align: center;
  }
  /* Utility bar scrollable on mobile */
  .sdgv-util-bar {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
    justify-content: flex-start;
    padding-bottom: 4px;
  }
  .sdgv-util-bar::-webkit-scrollbar { display: none; }
  /* Header pill smaller on very small screens */
  .sdgv-header {
    height: 52px !important;
    padding: 0 16px !important;
    top: 10px !important;
    width: 92% !important;
  }
  .sdgv-header__logo--text { font-size: 17px; }
  .sdgv-nav-offset { padding-top: 80px !important; }
  /* Checkout full-width on mobile */
  .sdgv-wrap--checkout { padding: 32px 14px 80px !important; }
  /* Basket item title truncation */
  .sdgv-basket-item__info h3 { font-size: 15px; }
  /* Toast full-width on mobile */
  .sdgv-toast {
    bottom: 16px; right: 12px; left: 12px;
    max-width: none;
    text-align: center;
  }
  /* Redemption page mobile */
  .sdgv-redeem__form-title { font-size: 22px; }
  .sdgv-redeem-wrap { padding: 0 14px 48px !important; }
}

/* ── Voucher detail page: mobile improvements ─── */
@media (max-width: 640px) {
  .sdgv-sv-layout {
    flex-direction: column !important;
    padding: 0 16px !important;
  }
  .sdgv-sv__sidebar { display: none !important; }
  .sdgv-sv__content { padding: 24px 0 !important; max-width: 100% !important; }
  .sdgv-sv__hero-img { border-radius: 12px; }
  /* Gift card preview fills width */
  .sdgv-voucher-preview-wrap { padding: 0 16px !important; }
}

/* ── Card: show description at 2 columns ─── */
@media (min-width: 581px) and (max-width: 960px) {
  .sdgv-card__title { font-size: 21px; }
  .sdgv-card__body { padding: 20px 20px 24px; }
  .sdgv-card__desc { font-size: 12px; }
}

/* ── Card hover: only on touch-capable devices ─── */
@media (hover: none) {
  .sdgv-card:hover {
    transform: none;
    box-shadow: 0 1px 3px rgba(0,29,54,0.06), 0 20px 40px rgba(0,29,54,0.07);
  }
  .sdgv-card:active {
    transform: scale(0.98);
    transition: transform 0.15s;
  }
}

/* ── Button: user-set colour vars (overrideable from portal settings) ─── */
.sdgv-btn--primary,
.sdgv-btn--outline {
  background: var(--sdgv-btn-bg, var(--vora-on-surface)) !important;
  color: var(--sdgv-btn-text, #ffffff) !important;
}
.sdgv-btn--primary:hover,
.sdgv-btn--outline:hover {
  background: var(--sdgv-btn-bg, var(--vora-on-surface)) !important;
  color: var(--sdgv-btn-text, #ffffff) !important;
  opacity: 0.88;
}

/* ── Variant button: cleaner style ─── */
.sdgv-variant-btn {
  border-radius: 9999px !important;
  font-size: 11px !important;
  letter-spacing: 0.1em !important;
  padding: 10px 16px !important;
  border: 1px solid rgba(195,198,207,0.3) !important;
  background: rgba(255,255,255,0.7) !important;
  transition: all 0.2s !important;
  white-space: normal !important;
  overflow-wrap: anywhere !important;
  line-height: 1.35 !important;
}
.sdgv-variant-btn:hover {
  background: rgba(255,255,255,1) !important;
  border-color: var(--vora-on-surface) !important;
}

/* ── Hero: bigger, more editorial ─── */
.sdgv-cinematic-hero__eyebrow {
  font-size: 9px;
  letter-spacing: 0.28em;
}
.sdgv-cinematic-hero__title {
  line-height: 1.05;
  letter-spacing: -0.02em;
}

/* ── Checkout: improve mobile padding ─── */
@media (max-width: 480px) {
  .sdgv-checkout-section { padding: 20px 16px; border-radius: 16px; }
  .sdgv-checkout-section h2 { font-size: 14px; }
  .sdgv-checkout-field input,
  .sdgv-checkout-field select,
  .sdgv-checkout-field textarea {
    font-size: 16px !important; /* prevents iOS zoom */
    border-radius: 12px;
  }
  /* Stripe card element */
  #sdgv-card-element { border-radius: 12px; }
  /* Order summary sticky on mobile */
  .sdgv-checkout-sidebar {
    position: static !important;
    margin-top: 24px;
  }
}

/* ── Redemption page: more refined ─── */
.sdgv-redeem__code-input {
  border-radius: 12px !important;
  font-size: 16px !important; /* prevents iOS zoom */
  padding: 14px 18px !important;
}
.sdgv-btn--balance,
.sdgv-btn--redeem {
  border-radius: 9999px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.14em !important;
  min-height: 48px !important;
}

/* ── Footer: cleaner on mobile ─── */
@media (max-width: 580px) {
  .sdgv-footer {
    flex-direction: column;
    text-align: center;
    padding: 28px 16px;
    gap: 12px;
  }
  .sdgv-footer__links {
    justify-content: center;
  }
}

/* ── Confirmation page: more celebratory ─── */
.sdgv-confirmation-icon {
  font-size: 56px !important;
  animation: celebrateBounce 0.6s cubic-bezier(0.68,-0.55,0.27,1.55) !important;
}
@keyframes celebrateBounce {
  0%   { transform: scale(0.5); opacity: 0; }
  70%  { transform: scale(1.15); }
  100% { transform: scale(1); opacity: 1; }
}


/* ── Checkout: order summary items vertical stack ─── */
.sdgv-summary-item {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(195,198,207,0.15);
}
.sdgv-summary-item:last-of-type { border-bottom: none; }
.sdgv-summary-item__img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  border-radius: 10px;
  margin-bottom: 6px;
}
.sdgv-summary-item__title {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 17px; font-weight: 400;
  color: var(--vora-on-surface);
}
.sdgv-summary-item__variant {
  font-size: 12px; color: var(--vora-secondary); font-style: italic;
}
.sdgv-summary-item__price {
  font-size: 15px; font-weight: 600; color: var(--vora-on-surface);
}
.sdgv-summary-total {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 16px 0 0; font-size: 18px;
  font-family: var(--vora-serif); font-style: italic;
  color: var(--vora-on-surface); margin-top: 4px;
}
.sdgv-checkout-summary h3 {
  font-family: var(--vora-serif); font-style: italic;
  font-size: 22px; font-weight: 400; color: var(--vora-on-surface);
  margin-bottom: 16px; padding-bottom: 12px;
  border-bottom: 1px solid rgba(195,198,207,0.2);
}

/* ── Variant btn: keep dark text on hover (no white flash) ─── */
.sdgv-variant-btn:hover {
  background: var(--vora-on-surface) !important;
  color: var(--sdgv-btn-text, #ffffff) !important;
  border-color: var(--vora-on-surface) !important;
}

/* ============================================================
   v2.5.8 — Basket/checkout account placement + luxury summary
   ============================================================ */
.sdgv-mobile-title-row {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
}
.sdgv-header-account-btn {
  display: none;
  flex: 0 0 auto;
  min-height: 40px;
  align-items: center;
  justify-content: center;
  border-radius: 9999px;
  padding: 10px 14px;
  background: var(--vora-on-surface);
  color: #fff !important;
  font-size: 10px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  text-decoration: none;
  box-shadow: 0 10px 26px rgba(0,29,54,0.12);
}

.sdgv-basket-options {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 22px;
  align-items: start;
}
@media (min-width: 900px) {
  .sdgv-basket-options {
    grid-template-columns: minmax(340px, 0.82fr) minmax(520px, 1.18fr);
    gap: 48px;
  }
  .sdgv-basket-options .sdgv-basket-summary {
    position: static !important;
    top: auto !important;
    max-width: none !important;
  }
}

@media (min-width: 1180px) {
  .sdgv-basket-options {
    grid-template-columns: minmax(360px, 420px) minmax(620px, 1fr);
    gap: 72px;
  }
}

@media (min-width: 900px) {
  .sdgv-checkout-form {
    flex: 1 1 720px !important;
  }
  .sdgv-checkout-sidebar {
    flex: 0 0 340px !important;
  }
  .sdgv-checkout-form > .sdgv-ca-panel {
    max-width: 760px;
  }
}

.sdgv-ca-panel {
  background:
    linear-gradient(135deg, rgba(255,255,255,0.92), rgba(248,249,255,0.82));
  border: 1px solid rgba(195,198,207,0.36);
  border-radius: var(--vora-radius-xl);
  padding: 28px;
  box-shadow: 0 24px 70px rgba(0,29,54,0.09);
  scroll-margin-top: 96px;
}
.sdgv-checkout-form > .sdgv-ca-panel {
  margin-bottom: 28px;
}
.sdgv-checkout-account-bottom {
  width: 100%;
  max-width: 920px;
  margin: 56px auto 0;
}
.sdgv-checkout-account-bottom .sdgv-ca-panel {
  display: grid;
  grid-template-columns: minmax(260px, 0.85fr) minmax(360px, 1.15fr);
  gap: 28px;
  align-items: start;
}
.sdgv-checkout-account-bottom .sdgv-ca-panel__intro {
  border-bottom: 0;
  border-right: 1px solid rgba(195,198,207,0.22);
  padding-bottom: 0;
  padding-right: 28px;
  margin-bottom: 0;
}
.sdgv-ca-panel__intro {
  border-bottom: 1px solid rgba(195,198,207,0.22);
  padding-bottom: 20px;
  margin-bottom: 22px;
}
.sdgv-ca-panel__form {
  min-width: 0;
}
.sdgv-ca-field small {
  color: var(--vora-secondary);
  font-weight: 400;
  letter-spacing: 0;
  text-transform: none;
}
.sdgv-ca-error {
  color: var(--vora-error, #ba1a1a);
  font-size: 13px;
  margin-bottom: 12px;
  line-height: 1.45;
}
.sdgv-ca-success {
  text-align: center;
  padding: 30px 10px;
}
.sdgv-ca-success__mark {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(184,135,42,0.12);
  color: var(--vora-tertiary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 14px;
  font-size: 28px;
  font-weight: 700;
}
.sdgv-ca-success h3 {
  font-family: var(--vora-serif);
  font-style: italic;
  font-size: 24px;
  font-weight: 400;
  margin: 0 0 8px;
}
.sdgv-ca-success p {
  font-size: 13px;
  color: var(--vora-secondary);
  line-height: 1.65;
  margin: 0;
}

.sdgv-how-it-works {
  margin-top: 18px;
}
.sdgv-how-it-works h4 {
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--vora-outline);
  margin-bottom: 14px;
}
.sdgv-how-step {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 11px;
  align-items: start;
  padding: 10px 0;
  border-bottom: 1px solid rgba(195,198,207,0.14);
}
.sdgv-how-step:last-child { border-bottom: none; }
.sdgv-how-step__icon,
.sdgv-how-it-works--luxury li span {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(184,135,42,0.10);
  color: var(--vora-tertiary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
}
.sdgv-how-step span:last-child {
  color: var(--vora-secondary);
  font-size: 13px;
  line-height: 1.55;
}
.sdgv-how-it-works--luxury ol {
  margin: 0;
}
.sdgv-how-it-works--luxury li {
  display: grid;
  grid-template-columns: 34px 1fr;
  grid-template-areas: "num title" "num text";
  column-gap: 11px;
  row-gap: 2px;
  padding: 9px 0;
  border-bottom: 1px solid rgba(195,198,207,0.14);
}
.sdgv-how-it-works--luxury li:last-child { border-bottom: none; }
.sdgv-how-it-works--luxury li span { grid-area: num; }
.sdgv-how-it-works--luxury li strong {
  grid-area: title;
  color: var(--vora-on-surface);
  font-size: 13px;
  letter-spacing: 0.02em;
}
.sdgv-how-it-works--luxury li em {
  grid-area: text;
  color: var(--vora-secondary);
  font-size: 12px;
  font-style: normal;
  line-height: 1.55;
}

@media (max-width: 640px) {
  .sdgv-mobile-title-row {
    align-items: center;
    gap: 12px;
  }
  .sdgv-mobile-title-row .sdgv-page-title {
    min-width: 0;
    overflow-wrap: anywhere;
  }
  .sdgv-header-account-btn {
    display: inline-flex;
    max-width: 138px;
    text-align: center;
    white-space: normal;
  }
  .sdgv-basket-options {
    gap: 18px;
  }
  .sdgv-ca-panel {
    padding: 22px 16px;
    border-radius: 18px;
  }
  .sdgv-ca-panel__intro {
    padding-bottom: 16px;
    margin-bottom: 18px;
  }
  .sdgv-ca-title {
    font-size: 28px;
  }
  .sdgv-ca-submit {
    color: #fff !important;
    min-height: 50px;
    line-height: 1.2;
  }
  .sdgv-ca-row {
    grid-template-columns: 1fr !important;
    gap: 0;
  }
  .sdgv-checkout-account-bottom {
    margin-top: 34px;
  }
  .sdgv-checkout-account-bottom .sdgv-ca-panel {
    display: block;
  }
  .sdgv-checkout-account-bottom .sdgv-ca-panel__intro {
    border-right: 0;
    border-bottom: 1px solid rgba(195,198,207,0.22);
    padding-right: 0;
    padding-bottom: 16px;
    margin-bottom: 18px;
  }
  .sdgv-how-step,
  .sdgv-how-it-works--luxury li {
    grid-template-columns: 30px 1fr;
  }
}

/* v2.6.0 — remaining responsive fixes */
.sdgv-voucher-type-grid[style] {
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
}
.sdgv-type-card {
  min-height: 76px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
#type-animated-card {
  padding: 22px 28px;
}
#type-animated-card .sdgv-type-card__icon {
  font-size: clamp(30px, 3vw, 42px);
}
#type-animated-card .sdgv-type-card__label {
  max-width: 24ch;
  font-size: clamp(13px, 1.2vw, 16px);
  line-height: 1.25;
  white-space: normal;
  overflow-wrap: anywhere;
}
#type-animated-card .sdgv-type-card__desc {
  max-width: 34ch;
  font-size: clamp(12px, 1vw, 13px);
}

@media (max-width: 700px) {
  .sdgv-voucher-type-grid[style] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  .sdgv-envelope-grid {
    grid-template-columns: 1fr;
  }
  .sdgv-envelope-panel,
  .sdgv-personalise-section {
    padding: 22px 16px;
    border-radius: 18px;
  }
  .sdgv-panel-intro {
    margin-bottom: 18px;
    padding-bottom: 14px;
  }
  .sdgv-print-note {
    border-radius: 18px;
  }
  .sdgv-type-card {
    min-height: 70px;
    padding: 20px 18px !important;
  }
  .sdgv-type-card__label {
    white-space: normal;
    overflow-wrap: anywhere;
    line-height: 1.2;
  }
  .sdgv-type-card__desc {
    font-size: 11px;
  }
}

@media (max-width: 420px) {
  .sdgv-voucher-type-grid[style] {
    grid-template-columns: 1fr !important;
  }
  .sdgv-type-card {
    min-height: 68px;
  }
}

/* v2.6.5 — Portal-controlled typography, backgrounds and hero media */
.sdgv-cinematic-hero {
  position: relative;
  overflow: hidden;
}
.sdgv-cinematic-hero__title,
.sdgv-sv__title,
.sdgv-page-title {
  font-size: clamp(32px, 5vw, var(--sdgv-page-title-size, 60px)) !important;
}
.sdgv-global-header a,
#sdgv-hdr a {
  font-size: var(--sdgv-nav-font-size, 13px) !important;
}
.sdgv-card__title {
  font-size: var(--sdgv-card-title-size, 24px) !important;
}
.sdgv-card__excerpt,
.sdgv-card__cat,
.sdgv-sv__body,
.sdgv-sv__excerpt,
.sdgv-form-group input,
.sdgv-form-group textarea,
.sdgv-form-group select {
  font-size: var(--sdgv-card-body-size, var(--sdgv-body-font-size, 14px)) !important;
}
.sdgv-btn,
.sdgv-variant-btn,
button.sdgv-btn {
  font-size: var(--sdgv-button-font-size, 12px) !important;
}
.sdgv-cinematic-hero--media {
  width: 100vw !important;
  max-width: none !important;
  min-height: clamp(420px, 64vh, 760px);
  margin: 0 0 42px 50% !important;
  transform: translateX(-50%) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
  color: #fff;
}
.sdgv-cinematic-hero--media .sdgv-cinematic-hero__media {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  object-fit: cover;
  z-index: 0;
}
.sdgv-cinematic-hero--media::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,29,54,0.18), rgba(0,29,54,0.58));
  z-index: 1;
}
.sdgv-cinematic-hero__content {
  position: relative;
  z-index: 2;
  padding: 36px 20px;
}
.sdgv-cinematic-hero--media .sdgv-cinematic-hero__title,
.sdgv-cinematic-hero--media .sdgv-cinematic-hero__sub {
  color: #fff !important;
}
@media (max-width: 640px) {
  .sdgv-cinematic-hero--media {
    max-width: 100%;
    min-height: 420px;
    border-radius: 0;
  }
}

/* v2.8.4 — voucher detail preview: desktop stays desktop, phones stack portrait */
.sdgv-sv-responsive-preview {
  width: 100%;
}
@media (max-width: 640px) {
  .sdgv-sv-responsive-preview {
    width: min(100%, 430px);
    margin: 0 auto;
    padding: 10px;
    background: #050607;
    border-radius: 24px;
    box-shadow: 0 22px 58px rgba(0,29,54,0.22);
  }
  .sdgv-sv-responsive-preview > div {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    min-height: 680px !important;
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: 1fr !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }
  .sdgv-sv-responsive-preview > div > div:first-child {
    order: 1 !important;
    width: 100% !important;
    min-height: 260px !important;
    flex: 0 0 260px !important;
  }
  .sdgv-sv-responsive-preview > div > div:not(:first-child) {
    order: 2 !important;
    width: 100% !important;
    min-height: auto !important;
    flex: 1 1 auto !important;
  }
  .sdgv-sv-responsive-preview > div > div:first-child img,
  .sdgv-sv-responsive-preview > div img:first-child {
    width: 100% !important;
    height: 260px !important;
    min-height: 260px !important;
    object-fit: cover !important;
  }
  .sdgv-sv-responsive-preview > div > div:first-child > div[style*="linear-gradient"] {
    background: linear-gradient(to bottom, transparent 56%, rgba(13,35,64,0.96) 100%) !important;
  }
}
