/**
 * DinnUP Base – Tema oficial (premium clean, Shopify/Stripe-like)
 * Depende de: theme.css (design system).
 * Breakpoints: Mobile ≤767 | Tablet 768–1023 | Desktop 1024–1279 | Wide ≥1280
 */

/* ========== TOKENS DE COR (sobrescritos pelo theme JSON no editor) ========== */
.dinnup-theme-base-v1,
.dn-page.dinnup-theme-base-v1 {
  --dinnup-primary: #0F766E;
  --dinnup-primary-hover: #0B5F59;
  --dinnup-text: #0F172A;
  --dinnup-text-secondary: #475569;
  --dinnup-bg: #FFFFFF;
  --dinnup-surface: #F8FAFC;
  --dinnup-border: #E2E8F0;
  --dinnup-radius-btn: 12px;
  --dinnup-radius-card: 16px;
  --dinnup-container-max: 1200px;
  --dinnup-shadow-card: 0 10px 30px rgba(0, 0, 0, 0.08);
  --dinnup-shadow-card-hover: 0 14px 36px rgba(0, 0, 0, 0.1);
  font-family: var(--font-sans);
  color: var(--dinnup-text);
  background: var(--dinnup-bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

.dinnup-theme-base-v1 .dinnup-section,
.dinnup-theme-base-v1 .dinnup-container,
.dn-page.dinnup-theme-base-v1 .dinnup-section,
.dn-page.dinnup-theme-base-v1 .dinnup-container {
  box-sizing: border-box;
}

/* Pré-visualizar (preview.php): mesma estrutura e dimensões do editor */
#store-preview-theme-wrap,
#editor-preview-theme-wrap,
#store-theme-wrap.store-preview-root,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap,
.dn-page.dinnup-theme-base-v1 #editor-preview-theme-wrap,
.dn-page.dinnup-theme-base-v1 #store-theme-wrap.store-preview-root {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden;
  display: block !important;
  box-sizing: border-box;
  min-height: 0;
  background: var(--dinnup-bg) !important;
}
#store-preview-content,
.editor-simple__preview-content {
  display: block !important;
  width: 100% !important;
  min-height: 100%;
  box-sizing: border-box;
}
/* Conteúdo dentro do wrap = mesmo layout do editor */
#store-preview-theme-wrap .dinnup-section,
#editor-preview-theme-wrap .dinnup-section,
#store-preview-theme-wrap .dinnup-container,
#editor-preview-theme-wrap .dinnup-container,
#store-theme-wrap.store-preview-root .dinnup-section,
#store-theme-wrap.store-preview-root .dinnup-container,
.dn-page.dinnup-theme-base-v1 #store-theme-wrap .dinnup-section,
.dn-page.dinnup-theme-base-v1 #editor-preview-theme-wrap .dinnup-section,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap .dinnup-section {
  display: block !important;
  box-sizing: border-box;
  width: 100%;
}
/* Pré-visualização: anúncio e header sempre visíveis (igual ao editor) */
body.store-preview-body #dn_announcement,
#editor-preview-theme-wrap #dn_announcement,
#store-preview-theme-wrap #dn_announcement,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap #dn_announcement {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  min-height: 28px !important;
  height: auto !important;
  background-color: var(--dinnup-text) !important;
}
body.store-preview-body #dn_header,
#editor-preview-theme-wrap #dn_header,
#store-preview-theme-wrap #dn_header,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap #dn_header {
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  min-height: 52px !important;
  background-color: var(--dinnup-header-bg, var(--dinnup-bg)) !important;
}
@media (min-width: 1024px) {
  body.store-preview-body #dn_header,
  #editor-preview-theme-wrap #dn_header,
  #store-preview-theme-wrap #dn_header {
    min-height: 56px !important;
  }
}

/* Loja sem engine (fallback): main + store-page-content */
.dn-page.dinnup-theme-base-v1 main.store-main-engine {
  width: 100%;
  max-width: 100%;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  display: block;
  box-sizing: border-box;
}
.dn-page.dinnup-theme-base-v1 .store-page-content {
  display: block !important;
  width: 100% !important;
  max-width: 100%;
  min-height: 0;
  box-sizing: border-box;
}
.dn-page.dinnup-theme-base-v1 .store-page-content .dinnup-section,
.dn-page.dinnup-theme-base-v1 .dinnup-section {
  display: block !important;
  box-sizing: border-box;
  width: 100%;
}

/* Garantir que hero/benefícios/etc. não fiquem escondidos (index e preview) */
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap #dn_hero,
.dn-page.dinnup-theme-base-v1 #editor-preview-theme-wrap #dn_hero,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap #dn_benefits,
.dn-page.dinnup-theme-base-v1 #editor-preview-theme-wrap #dn_benefits,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap #dn_products,
.dn-page.dinnup-theme-base-v1 #editor-preview-theme-wrap #dn_products,
.dn-page.dinnup-theme-base-v1 #store-preview-theme-wrap .dinnup-section,
.dn-page.dinnup-theme-base-v1 #editor-preview-theme-wrap .dinnup-section,
.dn-page.dinnup-theme-base-v1 #store-theme-wrap #dn_hero,
.dn-page.dinnup-theme-base-v1 #store-theme-wrap #dn_benefits,
.dn-page.dinnup-theme-base-v1 #store-theme-wrap #dn_products,
.dn-page.dinnup-theme-base-v1 .store-page-content #dn_hero,
.dn-page.dinnup-theme-base-v1 .store-page-content #dn_benefits,
.dn-page.dinnup-theme-base-v1 .store-page-content #dn_products,
.dn-page.dinnup-theme-base-v1 .store-page-content .dinnup-section {
  visibility: visible !important;
  opacity: 1 !important;
}
.dn-page.dinnup-theme-base-v1 #dn_hero {
  min-height: 320px !important;
  height: auto !important;
  max-height: 400px !important;
}
@media (min-width: 768px) {
  .dn-page.dinnup-theme-base-v1 #dn_hero {
    min-height: 420px !important;
    max-height: 500px !important;
  }
}
@media (min-width: 1024px) {
  .dn-page.dinnup-theme-base-v1 #dn_hero {
    min-height: 520px !important;
    max-height: 600px !important;
  }
}

/* ========== HEADER SUBPÁGINAS (produto, coleção, busca) ========== */
.dinnup-theme-base-v1 .dn-store-sub-header,
.dn-page.dinnup-theme-base-v1 .dn-store-sub-header {
  background: var(--dinnup-header-bg, var(--dinnup-bg)) !important;
  border-bottom: 1px solid var(--dinnup-border) !important;
  min-height: 64px !important;
  padding: 0 var(--container-padding-mobile) !important;
  display: flex !important;
  align-items: center !important;
}
.dinnup-theme-base-v1 .dn-store-sub-header .dn-container,
.dn-page.dinnup-theme-base-v1 .dn-store-sub-header .dn-container {
  width: 100% !important;
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
  padding: 0 var(--container-padding-mobile) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: var(--space-md) !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 .dn-store-sub-header,
  .dn-page.dinnup-theme-base-v1 .dn-store-sub-header {
    padding: 0 var(--container-padding-tablet) !important;
  }
  .dinnup-theme-base-v1 .dn-store-sub-header .dn-container,
  .dn-page.dinnup-theme-base-v1 .dn-store-sub-header .dn-container {
    padding: 0 var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 .dn-store-sub-header,
  .dn-page.dinnup-theme-base-v1 .dn-store-sub-header {
    min-height: 72px !important;
    padding: 0 var(--container-padding-desktop) !important;
  }
  .dinnup-theme-base-v1 .dn-store-sub-header .dn-container,
  .dn-page.dinnup-theme-base-v1 .dn-store-sub-header .dn-container {
    padding: 0 var(--container-padding-desktop) !important;
  }
}
.dn-page.dinnup-theme-base-v1 main .dn-container,
.dn-page.dinnup-theme-base-v1 main[style*="max-width"] {
  max-width: var(--dinnup-container-max) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: var(--container-padding-mobile) !important;
  padding-right: var(--container-padding-mobile) !important;
}
@media (min-width: 768px) {
  .dn-page.dinnup-theme-base-v1 main .dn-container,
  .dn-page.dinnup-theme-base-v1 main[style*="max-width"] {
    padding-left: var(--container-padding-tablet) !important;
    padding-right: var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dn-page.dinnup-theme-base-v1 main .dn-container,
  .dn-page.dinnup-theme-base-v1 main[style*="max-width"] {
    padding-left: var(--container-padding-desktop) !important;
    padding-right: var(--container-padding-desktop) !important;
  }
}

/* ========== BARRA DE ANÚNCIO (altura 36px, texto 13px) ========== */
.dinnup-theme-base-v1 #dn_announcement,
.dn-page.dinnup-theme-base-v1 #dn_announcement {
  min-height: 28px !important;
  height: 28px !important;
  padding: 0 var(--container-padding-mobile) !important;
  background-color: var(--dinnup-text) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}
.dinnup-theme-base-v1 #dn_announcement .dinnup-button,
.dn-page.dinnup-theme-base-v1 #dn_announcement .dinnup-button {
  color: #fff !important;
  font-size: 12px !important;
  padding: 0 !important;
  background: none !important;
  border: none !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_announcement,
  .dn-page.dinnup-theme-base-v1 #dn_announcement {
    padding: 0 var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_announcement,
  .dn-page.dinnup-theme-base-v1 #dn_announcement {
    padding: 0 var(--container-padding-desktop) !important;
  }
}

/* ========== HEADER (72px desktop, 64px mobile) ========== */
.dinnup-theme-base-v1 #dn_header,
.dn-page.dinnup-theme-base-v1 #dn_header {
  background-color: var(--dinnup-header-bg, var(--dinnup-bg)) !important;
  border-bottom: 1px solid var(--dinnup-border) !important;
  min-height: 52px !important;
  padding: 0 var(--container-padding-mobile) !important;
  display: flex !important;
  align-items: center !important;
}
.dinnup-theme-base-v1 #dn_header .dinnup-container,
.dn-page.dinnup-theme-base-v1 #dn_header .dinnup-container,
.dinnup-theme-base-v1 #dn_header_c,
.dn-page.dinnup-theme-base-v1 #dn_header_c {
  max-width: 100% !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}
/* Logo: tamanho normal e responsivo (sem encolher demais) */
.dinnup-theme-base-v1 #dn_header_logo,
.dn-page.dinnup-theme-base-v1 #dn_header_logo {
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: var(--dinnup-text) !important;
  margin: 0 !important;
  text-decoration: none !important;
  max-width: 200px !important;
  flex-shrink: 0;
}
.dinnup-theme-base-v1 #dn_header_logo img,
.dn-page.dinnup-theme-base-v1 #dn_header_logo img {
  max-width: 100% !important;
  max-height: 34px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
  vertical-align: middle !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_header_logo,
  .dn-page.dinnup-theme-base-v1 #dn_header_logo {
    max-width: 220px !important;
  }
  .dinnup-theme-base-v1 #dn_header_logo img,
  .dn-page.dinnup-theme-base-v1 #dn_header_logo img {
    max-height: 52px !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_header_logo,
  .dn-page.dinnup-theme-base-v1 #dn_header_logo {
    max-width: 260px !important;
  }
  .dinnup-theme-base-v1 #dn_header_logo img,
  .dn-page.dinnup-theme-base-v1 #dn_header_logo img {
    max-height: 56px !important;
  }
}
/* Nav no header sempre escondido – links só no drawer (hamburger) */
.dinnup-theme-base-v1 #dn_header #dn_header_nav,
.dn-page.dinnup-theme-base-v1 #dn_header #dn_header_nav {
  display: none !important;
}
.dinnup-theme-base-v1 #dn_header_nav .dinnup-button,
.dn-page.dinnup-theme-base-v1 #dn_header_nav .dinnup-button {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  color: var(--dinnup-text-secondary) !important;
  text-decoration: none !important;
  cursor: pointer !important;
}
.dinnup-theme-base-v1 #dn_header_nav .dinnup-button:hover,
.dn-page.dinnup-theme-base-v1 #dn_header_nav .dinnup-button:hover {
  color: var(--dinnup-primary) !important;
}

/* Ordem do header: logo | (espaco) | busca | hamburger – sem vão gigante */
.dinnup-theme-base-v1 #dn_header_c #dn_header_logo,
.dn-page.dinnup-theme-base-v1 #dn_header_c #dn_header_logo {
  order: 1;
}
.dinnup-theme-base-v1 #dn_header_c .dn-header-search-wrap,
.dn-page.dinnup-theme-base-v1 #dn_header_c .dn-header-search-wrap {
  order: 2;
  margin-left: auto !important;
}
.dinnup-theme-base-v1 #dn_header_c .dn-header-hamburger,
.dn-page.dinnup-theme-base-v1 #dn_header_c .dn-header-hamburger {
  order: 3;
}
.dinnup-theme-base-v1 #dn_header_c #dn_header_nav {
  order: 4;
}

/* Barra de pesquisa: largura fixa, não estica (evita espaço gigante) */
.dinnup-theme-base-v1 .dn-header-search-wrap,
.dn-page.dinnup-theme-base-v1 .dn-header-search-wrap {
  flex: 0 1 auto !important;
  min-width: 0;
  width: 180px;
  max-width: 220px;
  margin: 0 !important;
}
.dinnup-theme-base-v1 .dn-header-search-input,
.dn-page.dinnup-theme-base-v1 .dn-header-search-input {
  width: 100%;
  height: 34px;
  padding: 0 12px 0 36px;
  font-size: 13px;
  color: var(--dinnup-text);
  background: var(--dinnup-surface);
  border: 1px solid var(--dinnup-border);
  border-radius: var(--radius-btn, 8px);
  outline: none;
  box-sizing: border-box;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%236B7280' viewBox='0 0 16 16'%3E%3Cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: 10px 50%;
}
.dinnup-theme-base-v1 .dn-header-search-input::placeholder,
.dn-page.dinnup-theme-base-v1 .dn-header-search-input::placeholder {
  color: var(--dinnup-text-secondary);
  opacity: 0.8;
}
.dinnup-theme-base-v1 .dn-header-search-input:focus,
.dn-page.dinnup-theme-base-v1 .dn-header-search-input:focus {
  border-color: var(--dinnup-primary);
  box-shadow: 0 0 0 2px rgba(15, 118, 110, 0.2);
}

/* Hamburger e busca sempre visíveis no header (evitar espaço vazio) */
.dinnup-theme-base-v1 #dn_header .dn-header-hamburger,
.dn-page.dinnup-theme-base-v1 #dn_header .dn-header-hamburger,
.dinnup-theme-base-v1 #dn_header_c .dn-header-hamburger,
.dn-page.dinnup-theme-base-v1 #dn_header_c .dn-header-hamburger {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: none !important;
  border-radius: var(--radius-btn) !important;
  color: var(--dinnup-text) !important;
  font-size: 18px !important;
  cursor: pointer !important;
  -webkit-tap-highlight-color: transparent !important;
  flex-shrink: 0;
  visibility: visible !important;
  opacity: 1 !important;
}
.dinnup-theme-base-v1 #dn_header .dn-header-search-wrap,
.dn-page.dinnup-theme-base-v1 #dn_header .dn-header-search-wrap,
.dinnup-theme-base-v1 #dn_header_c .dn-header-search-wrap,
.dn-page.dinnup-theme-base-v1 #dn_header_c .dn-header-search-wrap {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
}
.dinnup-theme-base-v1 .dn-header-hamburger:hover,
.dn-page.dinnup-theme-base-v1 .dn-header-hamburger:hover {
  background: var(--dinnup-surface) !important;
}

@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_header,
  .dn-page.dinnup-theme-base-v1 #dn_header {
    padding: 0 var(--container-padding-tablet) !important;
  }
  .dinnup-theme-base-v1 .dn-header-search-wrap,
  .dn-page.dinnup-theme-base-v1 .dn-header-search-wrap {
    width: 200px;
    max-width: 220px;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_header,
  .dn-page.dinnup-theme-base-v1 #dn_header {
    min-height: 56px !important;
    padding: 0 var(--container-padding-desktop) !important;
  }
  .dinnup-theme-base-v1 .dn-header-search-wrap,
  .dn-page.dinnup-theme-base-v1 .dn-header-search-wrap {
    width: 200px;
    max-width: 220px;
  }
}

/* Header mobile: menu drawer (85vw, max 360px) */
.dinnup-theme-base-v1 .dn-header-drawer,
.dn-page.dinnup-theme-base-v1 .dn-header-drawer {
  position: fixed;
  top: 0;
  left: 0;
  width: 85vw;
  max-width: 360px;
  height: 100vh;
  z-index: 1000;
  background: var(--dinnup-bg) !important;
  box-shadow: 4px 0 24px rgba(0, 0, 0, 0.12);
  transform: translateX(-100%);
  transition: transform 0.25s ease;
  overflow-y: auto;
  padding: var(--space-lg);
}
.dinnup-theme-base-v1 .dn-header-drawer.is-open,
.dn-page.dinnup-theme-base-v1 .dn-header-drawer.is-open {
  transform: translateX(0);
}
.dinnup-theme-base-v1 .dn-header-drawer-overlay,
.dn-page.dinnup-theme-base-v1 .dn-header-drawer-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s, visibility 0.2s;
}
.dinnup-theme-base-v1 .dn-header-drawer-overlay.is-open,
.dn-page.dinnup-theme-base-v1 .dn-header-drawer-overlay.is-open {
  opacity: 1;
  visibility: visible;
}
.dinnup-theme-base-v1 .dn-header-drawer__nav,
.dn-page.dinnup-theme-base-v1 .dn-header-drawer__nav {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-xs) !important;
  padding-top: var(--space-lg) !important;
}
.dinnup-theme-base-v1 .dn-header-drawer__nav .dinnup-button,
.dn-page.dinnup-theme-base-v1 .dn-header-drawer__nav .dinnup-button {
  padding: var(--space-md) !important;
  font-size: var(--text-body) !important;
  text-align: left !important;
  justify-content: flex-start !important;
  border-radius: var(--radius-btn) !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 .dn-header-drawer,
  .dn-page.dinnup-theme-base-v1 .dn-header-drawer,
  .dinnup-theme-base-v1 .dn-header-drawer-overlay,
  .dn-page.dinnup-theme-base-v1 .dn-header-drawer-overlay {
    display: none !important;
  }
}

/* ========== HERO (320 mobile / 420 tablet / 520 desktop – igual editor e preview) ========== */
.dinnup-theme-base-v1 #dn_hero,
.dn-page.dinnup-theme-base-v1 #dn_hero {
  position: relative !important;
  width: 100% !important;
  min-height: 320px !important;
  max-height: 400px !important;
  padding: var(--space-xl) var(--container-padding-mobile) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  background-size: cover !important;
  background-position: center !important;
}
.dinnup-theme-base-v1 #dn_hero .dinnup-text,
.dn-page.dinnup-theme-base-v1 #dn_hero .dinnup-text {
  color: var(--dinnup-text) !important;
}
.dinnup-theme-base-v1 #dn_hero img.dinnup-image,
.dn-page.dinnup-theme-base-v1 #dn_hero img.dinnup-image {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}
.dinnup-theme-base-v1 #dn_hero h1,
.dn-page.dinnup-theme-base-v1 #dn_hero h1 {
  font-size: var(--text-h1) !important;
  line-height: var(--text-h1-lh) !important;
  font-weight: 700 !important;
  margin: 0 0 var(--space-sm) !important;
  color: var(--dinnup-text) !important;
  max-width: 100% !important;
  word-wrap: break-word !important;
}
.dinnup-theme-base-v1 #dn_hero #dn_hero_p,
.dn-page.dinnup-theme-base-v1 #dn_hero #dn_hero_p {
  font-size: var(--text-body-lg) !important;
  line-height: 1.65 !important;
  color: var(--dinnup-text-secondary) !important;
  margin: 0 0 var(--space-lg) !important;
  max-width: min(34em, 100%) !important;
}
.dinnup-theme-base-v1 #dn_hero #dn_hero_btn,
.dn-page.dinnup-theme-base-v1 #dn_hero #dn_hero_btn {
  min-width: 160px !important;
  min-height: var(--btn-height) !important;
  padding: 0 var(--btn-padding-x) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  background-color: var(--dinnup-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-btn) !important;
  cursor: pointer !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color 0.2s !important;
}
.dinnup-theme-base-v1 #dn_hero #dn_hero_btn:hover,
.dn-page.dinnup-theme-base-v1 #dn_hero #dn_hero_btn:hover {
  background-color: var(--dinnup-primary-hover) !important;
}
@media (max-width: 767px) {
  .dinnup-theme-base-v1 #dn_hero #dn_hero_btn,
  .dn-page.dinnup-theme-base-v1 #dn_hero #dn_hero_btn {
    width: 100% !important;
    min-width: 0 !important;
  }
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_hero,
  .dn-page.dinnup-theme-base-v1 #dn_hero {
    min-height: 420px !important;
    max-height: 500px !important;
    padding: var(--space-3xl) var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_hero,
  .dn-page.dinnup-theme-base-v1 #dn_hero {
    min-height: 520px !important;
    max-height: 600px !important;
    padding: var(--space-3xl) var(--container-padding-desktop) !important;
  }
}
.dinnup-theme-base-v1 #dn_hero_c,
.dn-page.dinnup-theme-base-v1 #dn_hero_c {
  position: relative !important;
  z-index: 2 !important;
  max-width: var(--container-max, 1200px) !important;
  margin: 0 auto !important;
  width: 100% !important;
  padding: 0 !important;
}

/* ========== BENEFÍCIOS (3 colunas, card min-height 96px, padding 18px) ========== */
.dinnup-theme-base-v1 #dn_benefits,
.dn-page.dinnup-theme-base-v1 #dn_benefits {
  padding: var(--space-2xl) var(--container-padding-mobile) !important;
  background-color: var(--dinnup-bg) !important;
}
.dinnup-theme-base-v1 #dn_benefits_c,
.dn-page.dinnup-theme-base-v1 #dn_benefits_c {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-md) !important;
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
}
.dinnup-theme-base-v1 #dn_benefits .dinnup-container:not(#dn_benefits_c),
.dn-page.dinnup-theme-base-v1 #dn_benefits .dinnup-container:not(#dn_benefits_c) {
  min-height: 96px !important;
  padding: 18px !important;
  background: var(--dinnup-surface) !important;
  border-radius: var(--radius-card) !important;
  box-shadow: var(--shadow-card) !important;
  text-align: center !important;
}
.dinnup-theme-base-v1 #dn_benefits h3,
.dn-page.dinnup-theme-base-v1 #dn_benefits h3 {
  font-size: 16px !important;
  font-weight: 600 !important;
  color: var(--dinnup-primary) !important;
  margin: 0 0 var(--space-xs) !important;
  white-space: normal !important;
}
.dinnup-theme-base-v1 #dn_benefits .dinnup-text,
.dn-page.dinnup-theme-base-v1 #dn_benefits .dinnup-text {
  font-size: var(--text-small) !important;
  color: var(--dinnup-text-secondary) !important;
  margin: 0 !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_benefits,
  .dn-page.dinnup-theme-base-v1 #dn_benefits {
    padding: var(--space-3xl) var(--container-padding-tablet) !important;
  }
  .dinnup-theme-base-v1 #dn_benefits_c,
  .dn-page.dinnup-theme-base-v1 #dn_benefits_c {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_benefits,
  .dn-page.dinnup-theme-base-v1 #dn_benefits {
    padding: var(--space-3xl) var(--container-padding-desktop) !important;
  }
  .dinnup-theme-base-v1 #dn_benefits_c,
  .dn-page.dinnup-theme-base-v1 #dn_benefits_c {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* ========== VITRINE DE PRODUTOS (grid 4/3/2/1, card padding 14px) ========== */
.dinnup-theme-base-v1 #dn_products,
.dn-page.dinnup-theme-base-v1 #dn_products {
  padding: var(--space-2xl) var(--container-padding-mobile) !important;
  background-color: var(--dinnup-bg) !important;
}
.dinnup-theme-base-v1 #dn_products_c,
.dn-page.dinnup-theme-base-v1 #dn_products_c {
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
  padding: 0 !important;
}
.dinnup-theme-base-v1 #dn_products_h,
.dn-page.dinnup-theme-base-v1 #dn_products_h {
  font-size: var(--text-h2) !important;
  line-height: var(--text-h2-lh) !important;
  font-weight: 700 !important;
  color: var(--dinnup-text) !important;
  margin: 0 0 var(--space-md) !important;
}
.dinnup-theme-base-v1 #dn_products_grid,
.dn-page.dinnup-theme-base-v1 #dn_products_grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-md) !important;
}
@media (min-width: 480px) {
  .dinnup-theme-base-v1 #dn_products_grid,
  .dn-page.dinnup-theme-base-v1 #dn_products_grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_products,
  .dn-page.dinnup-theme-base-v1 #dn_products {
    padding: var(--space-3xl) var(--container-padding-tablet) !important;
  }
  .dinnup-theme-base-v1 #dn_products_grid,
  .dn-page.dinnup-theme-base-v1 #dn_products_grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: var(--space-lg) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_products,
  .dn-page.dinnup-theme-base-v1 #dn_products {
    padding: var(--space-3xl) var(--container-padding-desktop) !important;
  }
  .dinnup-theme-base-v1 #dn_products_grid,
  .dn-page.dinnup-theme-base-v1 #dn_products_grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

/* Cards de produto */
.dinnup-theme-base-v1 .dinnup-product-card,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card,
.dinnup-theme-base-v1 .store-product-card,
.dn-page.dinnup-theme-base-v1 .store-product-card {
  background: var(--dinnup-bg) !important;
  border: 1px solid var(--dinnup-border) !important;
  border-radius: var(--radius-card) !important;
  overflow: hidden !important;
  box-shadow: var(--shadow-card) !important;
  transition: box-shadow 0.2s !important;
}
.dinnup-theme-base-v1 .dinnup-product-card:hover,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card:hover,
.dinnup-theme-base-v1 .store-product-card:hover,
.dn-page.dinnup-theme-base-v1 .store-product-card:hover {
  box-shadow: var(--shadow-card-hover) !important;
}
.dinnup-theme-base-v1 .dinnup-product-card__image-wrap,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card__image-wrap,
.dinnup-theme-base-v1 .store-product-card .aspect-square,
.dn-page.dinnup-theme-base-v1 .store-product-card .aspect-square {
  position: relative !important;
  aspect-ratio: 1 / 1 !important;
  background: var(--dinnup-surface) !important;
  overflow: hidden !important;
}
.dinnup-theme-base-v1 .dinnup-product-card .badge,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card .badge,
.dinnup-theme-base-v1 .store-product-card .badge,
.dn-page.dinnup-theme-base-v1 .store-product-card .badge {
  position: absolute !important;
  top: var(--space-sm) !important;
  left: var(--space-sm) !important;
  z-index: 2 !important;
}
.dinnup-theme-base-v1 .dinnup-product-card__image-wrap img,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card__image-wrap img,
.dinnup-theme-base-v1 .store-product-card img,
.dn-page.dinnup-theme-base-v1 .store-product-card img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.dinnup-theme-base-v1 .dinnup-product-card .dinnup-product-card__title,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card .dinnup-product-card__title,
.dinnup-theme-base-v1 .store-product-card h2,
.dinnup-theme-base-v1 .store-product-card h3,
.dn-page.dinnup-theme-base-v1 .store-product-card h2,
.dn-page.dinnup-theme-base-v1 .store-product-card h3 {
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  margin: 0 0 var(--space-xs) !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 2 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
}
.dinnup-theme-base-v1 .dinnup-product-card [data-price],
.dn-page.dinnup-theme-base-v1 .dinnup-product-card [data-price],
.dinnup-theme-base-v1 .store-product-card .text-lg,
.dn-page.dinnup-theme-base-v1 .store-product-card .text-lg {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--dinnup-primary) !important;
}
.dinnup-theme-base-v1 .dinnup-product-card > div:last-child,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card > div:last-child,
.dinnup-theme-base-v1 .store-product-card > div:last-child,
.dn-page.dinnup-theme-base-v1 .store-product-card > div:last-child {
  padding: 14px !important;
}
.dinnup-theme-base-v1 .dinnup-product-card .dinnup-button,
.dn-page.dinnup-theme-base-v1 .dinnup-product-card .dinnup-button,
.dinnup-theme-base-v1 .store-product-card .store-add-cart,
.dn-page.dinnup-theme-base-v1 .store-product-card .store-add-cart {
  min-height: var(--btn-height) !important;
  padding: 0 var(--btn-padding-x) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  border-radius: var(--radius-btn) !important;
  width: 100% !important;
}

/* ========== BANNER PROMOCIONAL (260px desktop, 200px mobile) ========== */
.dinnup-theme-base-v1 #dn_promo,
.dn-page.dinnup-theme-base-v1 #dn_promo {
  min-height: 200px !important;
  padding: var(--space-2xl) var(--container-padding-mobile) !important;
  background: linear-gradient(135deg, var(--dinnup-primary) 0%, var(--dinnup-primary-hover) 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.dinnup-theme-base-v1 #dn_promo .dinnup-container,
.dn-page.dinnup-theme-base-v1 #dn_promo .dinnup-container {
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
  text-align: center !important;
}
.dinnup-theme-base-v1 #dn_promo h2,
.dn-page.dinnup-theme-base-v1 #dn_promo h2 {
  font-size: var(--text-h2) !important;
  font-weight: 700 !important;
  color: #fff !important;
  margin: 0 0 var(--space-sm) !important;
}
.dinnup-theme-base-v1 #dn_promo .dinnup-text,
.dn-page.dinnup-theme-base-v1 #dn_promo .dinnup-text {
  color: rgba(255,255,255,0.95) !important;
  font-size: var(--text-body) !important;
  margin: 0 0 var(--space-lg) !important;
}
.dinnup-theme-base-v1 #dn_promo_btn,
.dn-page.dinnup-theme-base-v1 #dn_promo_btn {
  min-height: var(--btn-height) !important;
  padding: 0 var(--btn-padding-x) !important;
  background: #fff !important;
  color: var(--dinnup-primary) !important;
  border: none !important;
  border-radius: var(--radius-btn) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  cursor: pointer !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_promo,
  .dn-page.dinnup-theme-base-v1 #dn_promo {
    min-height: 260px !important;
    padding: var(--space-3xl) var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_promo,
  .dn-page.dinnup-theme-base-v1 #dn_promo {
    padding: var(--space-3xl) var(--container-padding-desktop) !important;
  }
}

/* ========== COLEÇÕES EM DESTAQUE (3/2/1 colunas, card 16/9) ========== */
.dinnup-theme-base-v1 #dn_featured_collections,
.dn-page.dinnup-theme-base-v1 #dn_featured_collections {
  padding: var(--space-2xl) var(--container-padding-mobile) !important;
  background: var(--dinnup-surface) !important;
}
.dinnup-theme-base-v1 #dn_fc_c,
.dn-page.dinnup-theme-base-v1 #dn_fc_c {
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
}
.dinnup-theme-base-v1 #dn_fc_grid,
.dn-page.dinnup-theme-base-v1 #dn_fc_grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-md) !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_fc_grid,
  .dn-page.dinnup-theme-base-v1 #dn_fc_grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_fc_grid,
  .dn-page.dinnup-theme-base-v1 #dn_fc_grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* ========== NEWSLETTER (container max 720px, input+btn 44px) ========== */
.dinnup-theme-base-v1 #dn_newsletter,
.dn-page.dinnup-theme-base-v1 #dn_newsletter {
  padding: var(--space-2xl) var(--container-padding-mobile) !important;
  background: linear-gradient(135deg, var(--dinnup-primary) 0%, var(--dinnup-primary-hover) 100%) !important;
}
.dinnup-theme-base-v1 #dn_newsletter_c,
.dn-page.dinnup-theme-base-v1 #dn_newsletter_c {
  max-width: 720px !important;
  margin: 0 auto !important;
  text-align: center !important;
}
.dinnup-theme-base-v1 #dn_newsletter h2,
.dn-page.dinnup-theme-base-v1 #dn_newsletter h2 {
  color: #fff !important;
  font-size: var(--text-h2) !important;
  margin: 0 0 var(--space-sm) !important;
}
.dinnup-theme-base-v1 #dn_newsletter .dinnup-text,
.dn-page.dinnup-theme-base-v1 #dn_newsletter .dinnup-text {
  color: rgba(255,255,255,0.95) !important;
  margin: 0 0 var(--space-lg) !important;
}

/* ========== RODAPÉ (grid 4 colunas desktop, padding 48/32) ========== */
.dinnup-theme-base-v1 #dn_footer,
.dn-page.dinnup-theme-base-v1 #dn_footer {
  padding: var(--space-xl) var(--container-padding-mobile) !important;
  background-color: var(--dinnup-footer-bg, var(--dinnup-text)) !important;
  color: rgba(255,255,255,0.85) !important;
}
.dinnup-theme-base-v1 #dn_footer .dinnup-container,
.dn-page.dinnup-theme-base-v1 #dn_footer .dinnup-container {
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
  display: grid !important;
  gap: var(--space-lg) !important;
  grid-template-columns: 1fr !important;
  text-align: center !important;
}
.dinnup-theme-base-v1 #dn_footer .dinnup-text,
.dn-page.dinnup-theme-base-v1 #dn_footer .dinnup-button {
  color: rgba(255,255,255,0.85) !important;
  font-size: var(--text-small) !important;
}
.dinnup-theme-base-v1 #dn_footer .dinnup-button {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}
@media (min-width: 768px) {
  .dinnup-theme-base-v1 #dn_footer,
  .dn-page.dinnup-theme-base-v1 #dn_footer {
    padding: var(--space-2xl) var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dinnup-theme-base-v1 #dn_footer,
  .dn-page.dinnup-theme-base-v1 #dn_footer {
    padding: var(--space-2xl) var(--container-padding-desktop) !important;
  }
  .dinnup-theme-base-v1 #dn_footer .dinnup-container,
  .dn-page.dinnup-theme-base-v1 #dn_footer .dinnup-container {
    grid-template-columns: repeat(4, 1fr) !important;
    text-align: left !important;
  }
}

/* ========== PÁGINA COLEÇÃO ========== */
.dn-page.dinnup-theme-base-v1 .store-collection-toolbar,
.dinnup-theme-base-v1 .store-collection-toolbar {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: var(--space-md) !important;
  min-height: 52px !important;
  margin-bottom: var(--space-lg) !important;
  padding: var(--space-sm) 0 !important;
}
.dn-page.dinnup-theme-base-v1 .store-collection-toolbar select,
.dinnup-theme-base-v1 .store-collection-toolbar select {
  min-height: var(--input-height) !important;
  padding: 0 var(--input-padding-x) !important;
  font-size: var(--text-body) !important;
  border: 1px solid var(--dinnup-border) !important;
  border-radius: var(--radius-input) !important;
  background: var(--dinnup-bg) !important;
  color: var(--dinnup-text) !important;
}
.dn-page.dinnup-theme-base-v1 .store-filter-btn,
.dinnup-theme-base-v1 .store-filter-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--space-xs) !important;
  min-height: var(--btn-height) !important;
  padding: 0 var(--btn-padding-x) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  border: 1px solid var(--dinnup-border) !important;
  border-radius: var(--radius-btn) !important;
  background: var(--dinnup-bg) !important;
  color: var(--dinnup-text) !important;
  cursor: pointer !important;
}
@media (min-width: 768px) {
  .dn-page.dinnup-theme-base-v1 .store-filter-btn,
  .dinnup-theme-base-v1 .store-filter-btn {
    display: none !important;
  }
}
.dn-page.dinnup-theme-base-v1 main .dn-products-grid,
.dn-page.dinnup-theme-base-v1 .store-products-grid {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-md) !important;
}
@media (min-width: 480px) {
  .dn-page.dinnup-theme-base-v1 main .dn-products-grid,
  .dn-page.dinnup-theme-base-v1 .store-products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (min-width: 768px) {
  .dn-page.dinnup-theme-base-v1 main .dn-products-grid,
  .dn-page.dinnup-theme-base-v1 .store-products-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: var(--space-lg) !important;
  }
}
@media (min-width: 1024px) {
  .dn-page.dinnup-theme-base-v1 main .dn-products-grid,
  .dn-page.dinnup-theme-base-v1 .store-products-grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

/* ========== PÁGINA PRODUTO (2 colunas desktop) ========== */
.dn-page.dinnup-theme-base-v1 .dn-pdp,
.dn-page.dinnup-theme-base-v1 main .store-pdp {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-xl) !important;
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
  padding: var(--space-xl) var(--container-padding-mobile) !important;
}
.dn-page.dinnup-theme-base-v1 .dn-pdp .dn-pdp__gallery img,
.dn-page.dinnup-theme-base-v1 .store-pdp__gallery img {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
}
.dn-page.dinnup-theme-base-v1 .dn-pdp .dn-pdp__buy .dinnup-button,
.dn-page.dinnup-theme-base-v1 .store-pdp__buy .store-add-cart {
  width: 100% !important;
  min-height: 48px !important;
}
/* PDP: galeria thumbs scroll horizontal no mobile */
.dn-page.dinnup-theme-base-v1 .dn-pdp-gallery,
.dn-page.dinnup-theme-base-v1 .store-pdp .dn-pdp-gallery {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--space-sm) !important;
}
.dn-page.dinnup-theme-base-v1 .dn-pdp-gallery > div:last-child,
.dn-page.dinnup-theme-base-v1 .store-pdp .dn-pdp-gallery > div[style*="flex"] {
  display: flex !important;
  gap: 10px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  padding-bottom: var(--space-xs) !important;
  scroll-snap-type: x proximity !important;
}
.dn-page.dinnup-theme-base-v1 .dn-pdp-gallery .pdp-thumb,
.dn-page.dinnup-theme-base-v1 .store-pdp .pdp-thumb {
  flex: 0 0 64px !important;
  width: 64px !important;
  height: 64px !important;
  scroll-snap-align: start !important;
}
/* PDP: accordion para descrição / frete / troca */
.dn-page.dinnup-theme-base-v1 .dn-pdp .accordion,
.dn-page.dinnup-theme-base-v1 .store-pdp__accordion {
  margin-top: var(--space-xl) !important;
}
.dn-page.dinnup-theme-base-v1 .dn-pdp .accordion__body,
.dn-page.dinnup-theme-base-v1 .store-pdp__accordion .accordion__body {
  font-size: var(--text-body) !important;
  color: var(--dinnup-text-secondary) !important;
}
@media (min-width: 768px) {
  .dn-page.dinnup-theme-base-v1 .dn-pdp,
  .dn-page.dinnup-theme-base-v1 main .store-pdp {
    grid-template-columns: 1fr 1fr !important;
    padding: var(--space-2xl) var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dn-page.dinnup-theme-base-v1 .dn-pdp,
  .dn-page.dinnup-theme-base-v1 main .store-pdp {
    grid-template-columns: 60% 1fr !important;
    padding: var(--space-2xl) var(--container-padding-desktop) !important;
  }
}

/* ========== CARRINHO (tabela → cards no mobile) ========== */
.dn-page.dinnup-theme-base-v1 main .store-cart-main,
.dinnup-theme-base-v1 .store-cart-main {
  max-width: var(--dinnup-container-max) !important;
  margin: 0 auto !important;
  padding: var(--space-xl) var(--container-padding-mobile) !important;
}
@media (min-width: 768px) {
  .dn-page.dinnup-theme-base-v1 main .store-cart-main,
  .dinnup-theme-base-v1 .store-cart-main {
    padding: var(--space-2xl) var(--container-padding-tablet) !important;
  }
}
@media (min-width: 1024px) {
  .dn-page.dinnup-theme-base-v1 main .store-cart-main,
  .dinnup-theme-base-v1 .store-cart-main {
    padding: var(--space-2xl) var(--container-padding-desktop) !important;
  }
}

/* Tabela do carrinho: no mobile vira cards */
.dn-page.dinnup-theme-base-v1 .store-cart-table,
.dinnup-theme-base-v1 .store-cart-table {
  width: 100% !important;
  border-collapse: collapse !important;
}
@media (max-width: 767px) {
  .dn-page.dinnup-theme-base-v1 .store-cart-table thead,
  .dinnup-theme-base-v1 .store-cart-table thead {
    display: none !important;
  }
  .dn-page.dinnup-theme-base-v1 .store-cart-table tbody tr,
  .dinnup-theme-base-v1 .store-cart-table tbody tr {
    display: block !important;
    border: 1px solid var(--dinnup-border) !important;
    border-radius: var(--radius-card) !important;
    padding: var(--space-md) !important;
    margin-bottom: var(--space-md) !important;
    background: var(--dinnup-bg) !important;
    box-shadow: var(--shadow-card) !important;
  }
  .dn-page.dinnup-theme-base-v1 .store-cart-table tbody td,
  .dinnup-theme-base-v1 .store-cart-table tbody td {
    display: block !important;
    padding: var(--space-xs) 0 !important;
    border: none !important;
  }
  .dn-page.dinnup-theme-base-v1 .store-cart-table tbody td::before,
  .dinnup-theme-base-v1 .store-cart-table tbody td::before {
    content: attr(data-label) !important;
    font-weight: 600 !important;
    font-size: var(--text-small) !important;
    color: var(--dinnup-text-secondary) !important;
    display: block !important;
    margin-bottom: 2px !important;
  }
}

/* Itens do carrinho (sidebar e lista) como card no mobile */
.dinnup-theme-base-v1 .store-cart-item,
.dn-page.dinnup-theme-base-v1 .store-cart-item {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: var(--space-sm) !important;
  padding: var(--space-sm) 0 !important;
  border-bottom: 1px solid var(--dinnup-border) !important;
}
.dinnup-theme-base-v1 .store-cart-item-name,
.dn-page.dinnup-theme-base-v1 .store-cart-item-name {
  flex: 1 1 100% !important;
  font-weight: 600 !important;
  font-size: var(--text-body) !important;
}
.dinnup-theme-base-v1 .store-cart-item-qty,
.dn-page.dinnup-theme-base-v1 .store-cart-item-qty {
  font-size: var(--text-small) !important;
  color: var(--dinnup-text-secondary) !important;
}
.dinnup-theme-base-v1 .store-cart-item-remove,
.dn-page.dinnup-theme-base-v1 .store-cart-item-remove {
  margin-left: auto !important;
  width: 32px !important;
  height: 32px !important;
  border: none !important;
  background: var(--dinnup-surface) !important;
  color: var(--dinnup-text-secondary) !important;
  border-radius: var(--radius-btn) !important;
  cursor: pointer !important;
  font-size: 18px !important;
  line-height: 1 !important;
}

/* ========== CART SIDEBAR (tema) ========== */
.dinnup-theme-base-v1 .store-cart-sidebar,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar {
  position: fixed !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  max-width: 400px !important;
  z-index: 9999 !important;
  background: transparent !important;
  pointer-events: none !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar.is-open,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar.is-open {
  pointer-events: auto !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar-inner,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar-inner {
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 100% !important;
  max-width: 400px !important;
  background: var(--dinnup-bg) !important;
  border-left: 1px solid var(--dinnup-border) !important;
  box-shadow: -4px 0 24px rgba(0, 0, 0, 0.1) !important;
  display: flex !important;
  flex-direction: column !important;
  transform: translateX(100%) !important;
  transition: transform 0.25s ease !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar.is-open .store-cart-sidebar-inner,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar.is-open .store-cart-sidebar-inner {
  transform: translateX(0) !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar-inner h3,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar-inner h3 {
  font-size: var(--text-h3) !important;
  color: var(--dinnup-text) !important;
  margin: 0 !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar #cart-sidebar-close,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar #cart-sidebar-close {
  background: transparent !important;
  border: none !important;
  color: var(--dinnup-text-secondary) !important;
  cursor: pointer !important;
  padding: var(--space-sm) !important;
  font-size: 24px !important;
  line-height: 1 !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar #cart-sidebar-checkout,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar #cart-sidebar-checkout {
  width: 100% !important;
  min-height: var(--btn-height) !important;
  background: var(--dinnup-primary) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-btn) !important;
  font-size: var(--btn-font-size) !important;
  font-weight: var(--btn-font-weight) !important;
  cursor: pointer !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar #cart-sidebar-total,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar #cart-sidebar-total {
  color: var(--dinnup-primary) !important;
}
.dinnup-theme-base-v1 .store-cart-sidebar-list,
.dn-page.dinnup-theme-base-v1 .store-cart-sidebar-list {
  padding: var(--space-md) !important;
}

/* ========== CHECKOUT TURBO ========== */
body.checkout-turbo-body {
  background:
    radial-gradient(circle at top left, rgba(15, 118, 110, 0.14), transparent 34%),
    linear-gradient(180deg, #f8fbfc 0%, #eef4f5 100%);
  color: var(--dinnup-text);
}

.dinnup-theme-base-v1 .checkout-turbo,
.dn-page.dinnup-theme-base-v1 .checkout-turbo {
  min-height: 100vh;
  padding: 32px 0 48px;
}

.dinnup-theme-base-v1 .checkout-turbo__shell,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shell {
  width: min(1200px, calc(100% - 32px));
  margin: 0 auto;
}

.dinnup-theme-base-v1 .checkout-turbo__shell--narrow,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shell--narrow {
  width: min(720px, calc(100% - 32px));
}

.dinnup-theme-base-v1 .checkout-turbo__header,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 28px;
}

.dinnup-theme-base-v1 .checkout-turbo__brand,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__brand {
  display: flex;
  align-items: center;
}

.dinnup-theme-base-v1 .checkout-turbo__brand-logo,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__brand-logo {
  max-width: 180px;
  max-height: 44px;
  width: auto;
  object-fit: contain;
}

.dinnup-theme-base-v1 .checkout-turbo__brand-text,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__brand-text {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--dinnup-primary);
}

.dinnup-theme-base-v1 .checkout-turbo__trust,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 10px;
}

.dinnup-theme-base-v1 .checkout-turbo__trust span,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust span {
  padding: 8px 12px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.75);
  color: var(--dinnup-text-secondary);
  font-size: 12px;
  font-weight: 600;
}

.dinnup-theme-base-v1 .checkout-turbo__layout,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, 420px);
  gap: 28px;
  align-items: start;
}

.dinnup-theme-base-v1 .checkout-turbo__intro,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__intro {
  margin-bottom: 24px;
}

.dinnup-theme-base-v1 .checkout-turbo__eyebrow,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__eyebrow,
.dinnup-theme-base-v1 .checkout-turbo__badge,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__badge,
.dinnup-theme-base-v1 .checkout-turbo__section-kicker,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin: 0 0 10px;
  color: var(--dinnup-primary);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dinnup-theme-base-v1 .checkout-turbo__title,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__title {
  margin: 0;
  color: #0f172a;
  font-size: clamp(1.85rem, 3vw, 2.75rem);
  line-height: 1.08;
  letter-spacing: -0.03em;
}

.dinnup-theme-base-v1 .checkout-turbo__subtitle,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__subtitle,
.dinnup-theme-base-v1 .checkout-turbo__helper,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__helper,
.dinnup-theme-base-v1 .checkout-turbo__meta,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__meta {
  margin: 12px 0 0;
  color: var(--dinnup-text-secondary);
  font-size: 0.95rem;
  line-height: 1.65;
}

.dinnup-theme-base-v1 .checkout-turbo__steps,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 20px;
}

.dinnup-theme-base-v1 .checkout-turbo__steps--top,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__steps--top {
  margin-bottom: 28px;
}

.dinnup-theme-base-v1 .checkout-turbo__step,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__step {
  display: flex;
  justify-content: center;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: rgba(255, 255, 255, 0.66);
  color: var(--dinnup-text-secondary);
  font-size: 13px;
  font-weight: 600;
}

.dinnup-theme-base-v1 .checkout-turbo__step.is-current,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__step.is-current {
  border-color: rgba(15, 118, 110, 0.28);
  background: rgba(15, 118, 110, 0.08);
  color: var(--dinnup-primary);
}

.dinnup-theme-base-v1 .checkout-turbo__step.is-complete,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__step.is-complete {
  border-color: rgba(5, 150, 105, 0.2);
  background: rgba(5, 150, 105, 0.08);
  color: #047857;
}

.dinnup-theme-base-v1 .checkout-turbo__form,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.dinnup-theme-base-v1 .checkout-turbo__card,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__card,
.dinnup-theme-base-v1 .checkout-turbo__summary,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary,
.dinnup-theme-base-v1 .checkout-turbo__panel,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__panel {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 24px 60px rgba(15, 23, 42, 0.08);
  backdrop-filter: blur(14px);
}

.dinnup-theme-base-v1 .checkout-turbo__card,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__card,
.dinnup-theme-base-v1 .checkout-turbo__summary,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary {
  padding: 24px;
}

.dinnup-theme-base-v1 .checkout-turbo__panel--payment,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__panel--payment {
  padding: 28px;
}

.dinnup-theme-base-v1 .checkout-turbo__section-head,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__section-head,
.dinnup-theme-base-v1 .checkout-turbo__summary-head,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.dinnup-theme-base-v1 .checkout-turbo__section-title,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__section-title {
  margin: 0;
  color: #0f172a;
  font-size: 1.2rem;
  line-height: 1.2;
}

.dinnup-theme-base-v1 .checkout-turbo__section-note,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__section-note,
.dinnup-theme-base-v1 .checkout-turbo__item-count,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__item-count {
  color: var(--dinnup-text-secondary);
  font-size: 13px;
  font-weight: 600;
}

.dinnup-theme-base-v1 .checkout-turbo__field-grid,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.dinnup-theme-base-v1 .checkout-turbo__field-grid--payment,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__field-grid--payment {
  margin-top: 16px;
}

.dinnup-theme-base-v1 .checkout-turbo__field,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.dinnup-theme-base-v1 .checkout-turbo__field--full,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__field--full {
  grid-column: 1 / -1;
}

.dinnup-theme-base-v1 .checkout-turbo__field-label,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__field-label {
  color: #334155;
  font-size: 13px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__input,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__input,
.dinnup-theme-base-v1 .checkout-turbo__copy-input,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__copy-input {
  width: 100%;
  min-height: 48px;
  padding: 0 16px;
  border: 1px solid rgba(15, 23, 42, 0.12);
  border-radius: 14px;
  background: #fff;
  color: #0f172a;
  font-size: 14px;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.dinnup-theme-base-v1 .checkout-turbo__input:focus,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__input:focus,
.dinnup-theme-base-v1 .checkout-turbo__copy-input:focus,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__copy-input:focus {
  outline: none;
  border-color: rgba(15, 118, 110, 0.45);
  box-shadow: 0 0 0 4px rgba(15, 118, 110, 0.12);
}

.dinnup-theme-base-v1 .checkout-turbo__payment-options,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-options,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-options {
  display: grid;
  gap: 12px;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-option,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-option {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 18px 16px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 18px;
  background: #fff;
  cursor: pointer;
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-option:hover,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-option:hover {
  transform: translateY(-1px);
  border-color: rgba(15, 118, 110, 0.22);
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-option.is-active,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-option.is-active {
  border-color: rgba(15, 118, 110, 0.36);
  background: linear-gradient(180deg, rgba(15, 118, 110, 0.12), rgba(15, 118, 110, 0.05));
  box-shadow: inset 0 0 0 1px rgba(15, 118, 110, 0.08);
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-copy,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-copy {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-copy strong,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-copy strong {
  color: #0f172a;
  font-size: 14px;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-copy small,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-copy small {
  color: var(--dinnup-text-secondary);
  font-size: 12px;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-price,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-price {
  color: var(--dinnup-primary);
  font-size: 14px;
  font-weight: 800;
}

.dinnup-theme-base-v1 .checkout-turbo__payment-option,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 18px 16px;
  border: 1px solid rgba(15, 23, 42, 0.1);
  border-radius: 18px;
  background: #fff;
  cursor: pointer;
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease;
}

.dinnup-theme-base-v1 .checkout-turbo__payment-option:hover,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-option:hover {
  transform: translateY(-1px);
  border-color: rgba(15, 118, 110, 0.22);
}

.dinnup-theme-base-v1 .checkout-turbo__payment-option.is-active,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-option.is-active {
  border-color: rgba(15, 118, 110, 0.36);
  background: linear-gradient(180deg, rgba(15, 118, 110, 0.12), rgba(15, 118, 110, 0.05));
  box-shadow: inset 0 0 0 1px rgba(15, 118, 110, 0.08);
}

.dinnup-theme-base-v1 .checkout-turbo__payment-icon,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 56px;
  height: 56px;
  border-radius: 16px;
  background: #ecfeff;
  color: var(--dinnup-primary);
  font-size: 13px;
  font-weight: 800;
  letter-spacing: 0.08em;
}

.dinnup-theme-base-v1 .checkout-turbo__payment-copy,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-copy {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.dinnup-theme-base-v1 .checkout-turbo__payment-copy strong,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-copy strong {
  color: #0f172a;
  font-size: 14px;
}

.dinnup-theme-base-v1 .checkout-turbo__payment-copy small,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-copy small {
  color: var(--dinnup-text-secondary);
  font-size: 12px;
}

.dinnup-theme-base-v1 .checkout-turbo__aside,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__aside {
  position: sticky;
  top: 24px;
}

.dinnup-theme-base-v1 .checkout-turbo__product-list,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.dinnup-theme-base-v1 .checkout-turbo__product,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.dinnup-theme-base-v1 .checkout-turbo__product-media,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-media {
  width: 68px;
  height: 68px;
  border-radius: 18px;
  background: #f8fafc;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.dinnup-theme-base-v1 .checkout-turbo__product-image,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.dinnup-theme-base-v1 .checkout-turbo__product-fallback,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-fallback {
  width: 28px;
  height: 28px;
  color: #94a3b8;
}

.dinnup-theme-base-v1 .checkout-turbo__product-copy,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-copy {
  min-width: 0;
}

.dinnup-theme-base-v1 .checkout-turbo__product-name,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-name,
.dinnup-theme-base-v1 .checkout-turbo__product-meta,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-meta,
.dinnup-theme-base-v1 .checkout-turbo__product-price,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-price {
  margin: 0;
}

.dinnup-theme-base-v1 .checkout-turbo__product-name,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-name {
  color: #0f172a;
  font-size: 14px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__product-meta,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-meta {
  color: var(--dinnup-text-secondary);
  font-size: 12px;
  margin-top: 4px;
}

.dinnup-theme-base-v1 .checkout-turbo__product-price,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__product-price {
  color: var(--dinnup-primary);
  font-size: 14px;
  font-weight: 700;
  margin-top: 6px;
}

.dinnup-theme-base-v1 .checkout-turbo__summary-form,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-form,
.dinnup-theme-base-v1 .checkout-turbo__coupon,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__coupon,
.dinnup-theme-base-v1 .checkout-turbo__shipping,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping {
  margin-top: 18px;
}

.dinnup-theme-base-v1 .checkout-turbo__summary-glance,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-glance {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(15, 118, 110, 0.06);
  color: #0f172a;
  font-size: 13px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__summary-glance strong,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-glance strong {
  color: var(--dinnup-primary);
  font-size: 1rem;
}

.dinnup-theme-base-v1 .checkout-turbo__summary-toggle,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-toggle {
  display: none;
  border: none;
  background: transparent;
  color: var(--dinnup-primary);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
}

.dinnup-theme-base-v1 .checkout-turbo__shipping-pill,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-pill {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  border-radius: 14px;
  background: #f8fbfc;
  border: 1px solid rgba(15, 23, 42, 0.08);
  color: #0f172a;
  font-size: 13px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__trust-panel,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 18px;
}

.dinnup-theme-base-v1 .checkout-turbo__trust-panel article,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel article {
  padding: 16px;
  border-radius: 18px;
  background: #f8fbfc;
  border: 1px solid rgba(15, 23, 42, 0.06);
}

.dinnup-theme-base-v1 .checkout-turbo__trust-panel strong,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel strong,
.dinnup-theme-base-v1 .checkout-turbo__trust-panel span,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel span {
  display: block;
}

.dinnup-theme-base-v1 .checkout-turbo__trust-panel strong,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel strong {
  color: #0f172a;
  font-size: 13px;
  margin-bottom: 4px;
}

.dinnup-theme-base-v1 .checkout-turbo__trust-panel span,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel span {
  color: var(--dinnup-text-secondary);
  font-size: 12px;
  line-height: 1.55;
}

.dinnup-theme-base-v1 .checkout-turbo__trust-strip,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.dinnup-theme-base-v1 .checkout-turbo__trust-strip span,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-strip span {
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(15, 118, 110, 0.08);
  color: var(--dinnup-primary);
  font-size: 12px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__coupon-row,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__coupon-row,
.dinnup-theme-base-v1 .checkout-turbo__copy-row,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__copy-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.dinnup-theme-base-v1 .checkout-turbo__coupon-success,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__coupon-success {
  margin: 8px 0 0;
  color: #047857;
  font-size: 12px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__secondary-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__secondary-btn,
.dinnup-theme-base-v1 .checkout-turbo__copy-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__copy-btn,
.dinnup-theme-base-v1 .checkout-turbo__primary-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__primary-btn,
.dinnup-theme-base-v1 .checkout-turbo__link-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__link-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 14px;
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
  transition: transform 0.16s ease, box-shadow 0.16s ease, background-color 0.16s ease, border-color 0.16s ease;
  cursor: pointer;
}

.dinnup-theme-base-v1 .checkout-turbo__primary-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__primary-btn {
  border: none;
  background: linear-gradient(135deg, var(--dinnup-primary), #08918b);
  color: #fff;
  box-shadow: 0 16px 30px rgba(15, 118, 110, 0.2);
}

.dinnup-theme-base-v1 .checkout-turbo__primary-btn:hover,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__primary-btn:hover {
  transform: translateY(-1px);
}

.dinnup-theme-base-v1 .checkout-turbo__primary-btn--full,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__primary-btn--full {
  width: 100%;
}

.dinnup-theme-base-v1 .checkout-turbo__secondary-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__secondary-btn,
.dinnup-theme-base-v1 .checkout-turbo__copy-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__copy-btn {
  border: 1px solid rgba(15, 118, 110, 0.18);
  background: #fff;
  color: var(--dinnup-primary);
}

.dinnup-theme-base-v1 .checkout-turbo__link-btn,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__link-btn,
.dinnup-theme-base-v1 .checkout-turbo__inline-link,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__inline-link {
  color: var(--dinnup-primary);
  background: transparent;
  border: none;
  padding: 0;
  min-height: auto;
  font-size: 13px;
  font-weight: 700;
}

.dinnup-theme-base-v1 .checkout-turbo__totals,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__totals {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.dinnup-theme-base-v1 .checkout-turbo__total-row,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__total-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: var(--dinnup-text-secondary);
  font-size: 14px;
}

.dinnup-theme-base-v1 .checkout-turbo__total-row--success,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__total-row--success {
  color: #047857;
}

.dinnup-theme-base-v1 .checkout-turbo__total-row--grand,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__total-row--grand {
  margin-top: 4px;
  padding-top: 12px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  color: #0f172a;
  font-size: 17px;
  font-weight: 800;
}

.dinnup-theme-base-v1 .checkout-turbo__total-row--grand span:last-child,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__total-row--grand span:last-child {
  color: var(--dinnup-primary);
}

.dinnup-theme-base-v1 .checkout-turbo__cta,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__cta,
.dinnup-theme-base-v1 .checkout-turbo__footer,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__footer,
.dinnup-theme-base-v1 .checkout-turbo__payment-actions,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 20px;
}

.dinnup-theme-base-v1 .checkout-turbo__alert,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__alert {
  margin-bottom: 20px;
  padding: 16px 18px;
  border-radius: 16px;
  font-size: 14px;
  font-weight: 600;
}

.dinnup-theme-base-v1 .checkout-turbo__alert--error,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__alert--error {
  border: 1px solid rgba(220, 38, 38, 0.18);
  background: rgba(254, 242, 242, 0.95);
  color: #b91c1c;
}

.dinnup-theme-base-v1 .checkout-turbo__pix,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__pix {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 20px;
  align-items: start;
  margin-top: 18px;
}

.dinnup-theme-base-v1 .checkout-turbo__pix-qr,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__pix-qr {
  padding: 14px;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(15, 23, 42, 0.08);
}

.dinnup-theme-base-v1 .checkout-turbo__barcode,
.dn-page.dinnup-theme-base-v1 .checkout-turbo__barcode {
  margin: 18px 0;
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(15, 23, 42, 0.08);
  background: #fff;
  color: #0f172a;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;
  font-size: 13px;
  line-height: 1.6;
  word-break: break-all;
}

@media (max-width: 1023px) {
  .dinnup-theme-base-v1 .checkout-turbo__layout,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__layout {
    grid-template-columns: 1fr;
  }

  .dinnup-theme-base-v1 .checkout-turbo__aside,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__aside {
    position: static;
  }
}

@media (max-width: 767px) {
  .dinnup-theme-base-v1 .checkout-turbo,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo {
    padding: 20px 0 36px;
  }

  .dinnup-theme-base-v1 .checkout-turbo__shell,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__shell,
  .dinnup-theme-base-v1 .checkout-turbo__shell--narrow,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__shell--narrow {
    width: min(100%, calc(100% - 24px));
  }

  .dinnup-theme-base-v1 .checkout-turbo__header,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__header,
  .dinnup-theme-base-v1 .checkout-turbo__section-head,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__section-head,
  .dinnup-theme-base-v1 .checkout-turbo__summary-head,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .dinnup-theme-base-v1 .checkout-turbo__steps,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__steps,
  .dinnup-theme-base-v1 .checkout-turbo__payment-options,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__payment-options,
  .dinnup-theme-base-v1 .checkout-turbo__trust-panel,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__trust-panel,
  .dinnup-theme-base-v1 .checkout-turbo__field-grid,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__field-grid,
  .dinnup-theme-base-v1 .checkout-turbo__pix,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__pix,
  .dinnup-theme-base-v1 .checkout-turbo__shipping-option,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__shipping-option,
  .dinnup-theme-base-v1 .checkout-turbo__coupon-row,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__coupon-row,
  .dinnup-theme-base-v1 .checkout-turbo__copy-row,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__copy-row {
    grid-template-columns: 1fr;
  }

  .dinnup-theme-base-v1 .checkout-turbo__card,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__card,
  .dinnup-theme-base-v1 .checkout-turbo__summary,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__summary,
  .dinnup-theme-base-v1 .checkout-turbo__panel--payment,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__panel--payment {
    padding: 20px;
  }

  .dinnup-theme-base-v1 .checkout-turbo__summary-toggle,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-toggle {
    display: inline-flex;
  }

  .dinnup-theme-base-v1 .checkout-turbo__summary-body,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-body {
    display: none;
  }

  .dinnup-theme-base-v1 .checkout-turbo__summary-body.is-open,
  .dn-page.dinnup-theme-base-v1 .checkout-turbo__summary-body.is-open {
    display: block;
  }
}
