/*
Theme Name: DigiGoods Commerce
Theme URI: https://example.com/digigoods-commerce
Author: DigiGoods
Author URI: https://example.com
Description: Original WooCommerce storefront theme for consumer digital products and assisted delivery.
Version: 2.9.0
Requires at least: 6.5
Tested up to: 7.0
Requires PHP: 8.1
Text Domain: digigoods-commerce
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
*/

:root {
  --dg-ink: #16191d;
  --dg-muted: #66707a;
  --dg-line: #dde2e7;
  --dg-soft: #f4f6f7;
  --dg-panel: #ffffff;
  --dg-brand: #087f78;
  --dg-brand-dark: #075d59;
  --dg-coral: #e96855;
  --dg-blue: #2867b2;
  --dg-gold: #d7a315;
  --dg-green: #36875a;
  --dg-danger: #b6342a;
  --dg-shadow: 0 18px 45px rgba(23, 31, 38, 0.12);
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  color: var(--dg-ink);
  background: #fff;
  font-family: Inter, "Segoe UI", Arial, Helvetica, sans-serif;
  line-height: 1.55;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
}

button,
input,
select,
textarea {
  font: inherit;
}

h1,
h2,
h3,
h4,
p {
  overflow-wrap: anywhere;
}

.dg-wrap {
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto;
}

.dg-topbar {
  background: #171a1e;
  color: #edf1f3;
  font-size: 12px;
}

.dg-topbar__inner,
.dg-topbar__contact,
.dg-topbar__meta,
.dg-header__inner,
.dg-header__actions,
.dg-hero__actions,
.dg-hero__proof,
.dg-footer__bottom {
  display: flex;
  align-items: center;
}

.dg-topbar__inner {
  min-height: 36px;
  justify-content: space-between;
  gap: 24px;
}

.dg-topbar__contact,
.dg-topbar__meta {
  gap: 20px;
}

.dg-topbar__contact-item {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: #edf1f3;
}

.dg-topbar__contact-item > span {
  color: #ffb739;
  font-size: 16px;
  line-height: 1;
}

.dg-topbar__contact-item .dg-whatsapp-mark {
  display: grid;
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  place-items: center;
  border-radius: 50%;
  background: #fff;
}

.dg-topbar__contact-item .dg-whatsapp-mark img {
  display: block;
  width: 18px;
  height: 18px;
  max-width: 18px;
  object-fit: contain;
  object-position: center;
}

.dg-topbar__contact-item--whatsapp.is-unconfigured {
  color: #aeb8bf;
}

.dg-topbar a:hover {
  color: #fff;
  text-decoration: underline;
}

.dg-site-header {
  position: relative;
  z-index: 30;
  background: #fff;
}

.dg-header__inner {
  min-height: 88px;
  justify-content: space-between;
  gap: 28px;
}

.dg-brand {
  min-width: 190px;
}

.dg-brand__fallback,
.dg-brand .custom-logo-link {
  display: inline-flex;
  align-items: center;
  gap: 11px;
}

.dg-brand .custom-logo-link {
  display: flex;
  align-items: center;
}

.dg-brand .custom-logo {
  width: auto;
  max-width: 220px;
  max-height: 58px;
}

.dg-brand__mark {
  display: grid;
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  place-items: center;
  border-radius: 7px;
  background: var(--dg-brand);
  color: #fff;
  font-size: 23px;
  font-weight: 800;
}

.dg-logo-placeholder {
  display: block;
  width: 92px;
  height: 44px;
  flex: 0 0 92px;
  border: 1px dashed #aeb8bf;
  border-radius: 3px;
  background:
    linear-gradient(135deg, transparent 48%, #dce2e5 49%, #dce2e5 51%, transparent 52%),
    #f6f8f9;
}

.dg-brand__text strong,
.dg-brand__text small {
  display: block;
}

.dg-brand__text strong {
  font-size: 21px;
  line-height: 1.1;
}

.dg-brand__text small {
  max-width: 180px;
  margin-top: 3px;
  color: var(--dg-muted);
  font-size: 11px;
}

.dg-search {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) auto;
  width: min(100%, 560px);
  flex: 1;
}

.dg-search input,
.dg-search button,
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  min-height: 46px;
  border: 1px solid var(--dg-line);
  border-radius: 4px;
}

.dg-search input {
  min-width: 0;
  padding: 0 15px;
  border-right: 0;
  border-radius: 4px 0 0 4px;
  background: #f8fafb;
}

.dg-search input:focus {
  outline: 2px solid rgba(8, 127, 120, 0.18);
  outline-offset: 0;
  background: #fff;
}

.dg-search button {
  border: 0;
  border-radius: 0 4px 4px 0;
  background: var(--dg-brand);
  color: #fff;
  padding: 0 22px;
  cursor: pointer;
  font-weight: 750;
}

.dg-search button:hover {
  background: var(--dg-brand-dark);
}

.dg-header__actions {
  gap: 8px;
  white-space: nowrap;
}

.dg-header-benefits {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  gap: 18px;
  color: #36424a;
  font-size: 12px;
  font-weight: 750;
  white-space: nowrap;
}

.dg-header-benefits span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.dg-header-benefits span::before {
  width: 16px;
  height: 16px;
  border: 2px solid var(--dg-coral);
  border-radius: 50%;
  content: "";
}

.dg-header-action {
  position: relative;
  display: inline-flex;
  min-width: 76px;
  min-height: 48px;
  align-items: center;
  justify-content: center;
  gap: 7px;
  color: #343a40;
  font-size: 13px;
}

.dg-header-action:hover {
  color: var(--dg-brand);
}

.dg-header-action__icon {
  font-size: 22px;
  line-height: 1;
}

.dg-cart-count {
  display: grid;
  width: 20px;
  height: 20px;
  place-items: center;
  border-radius: 999px;
  background: var(--dg-coral);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
}

.dg-menu-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--dg-line);
  border-radius: 4px;
  background: #fff;
  color: var(--dg-ink);
  cursor: pointer;
  font-size: 22px;
}

.dg-menu-toggle__lines,
.dg-menu-toggle__lines::before,
.dg-menu-toggle__lines::after {
  display: block;
  width: 20px;
  height: 2px;
  background: currentColor;
}

.dg-menu-toggle__lines {
  position: relative;
}

.dg-menu-toggle__lines::before,
.dg-menu-toggle__lines::after {
  position: absolute;
  left: 0;
  content: "";
}

.dg-menu-toggle__lines::before {
  top: -6px;
}

.dg-menu-toggle__lines::after {
  top: 6px;
}

.dg-nav {
  border-top: 1px solid var(--dg-line);
  border-bottom: 1px solid var(--dg-line);
  background: #fff;
}

.dg-nav__inner {
  display: flex;
  min-height: 62px;
  align-items: center;
  gap: 0;
  font-size: 13px;
  font-weight: 700;
}

.dg-category-menu {
  display: flex;
  flex: 1;
  min-width: 0;
  align-items: center;
  align-self: stretch;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.dg-category-menu__item {
  position: relative;
  display: flex;
  min-width: 0;
  flex: 1;
  align-items: stretch;
}

.dg-category-menu__item > a {
  display: flex;
  width: 100%;
  min-height: 62px;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border-left: 1px solid var(--dg-line);
  padding: 0 16px;
  color: #6b747c;
  text-align: center;
}

.dg-category-menu__item:last-child > a {
  border-right: 1px solid var(--dg-line);
}

.dg-category-menu__item:hover > a,
.dg-category-menu__item:focus-within > a {
  color: var(--dg-brand);
}

.dg-nav-icon {
  position: relative;
  display: block;
  width: 17px;
  height: 17px;
  flex: 0 0 17px;
  border-radius: 2px;
  background: var(--dg-brand);
}

.dg-nav-icon::before,
.dg-nav-icon::after {
  position: absolute;
  background: rgba(255, 255, 255, 0.9);
  content: "";
}

.dg-nav-icon::before {
  top: 3px;
  bottom: 3px;
  left: 8px;
  width: 1px;
}

.dg-nav-icon::after {
  top: 8px;
  right: 3px;
  left: 3px;
  height: 1px;
}

.dg-nav-icon--2 {
  background: var(--dg-coral);
}

.dg-nav-icon--3 {
  background: var(--dg-green);
}

.dg-nav-icon--4 {
  background: var(--dg-blue);
}

.dg-nav-icon--5 {
  background: var(--dg-danger);
}

.dg-menu-caret {
  width: 7px;
  height: 7px;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: rotate(45deg) translateY(-2px);
}

.dg-category-submenu {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 50;
  display: none;
  width: 230px;
  margin: 0;
  border: 1px solid var(--dg-line);
  background: #fff;
  padding: 8px 0;
  box-shadow: var(--dg-shadow);
  list-style: none;
}

.dg-category-menu__item:hover > .dg-category-submenu,
.dg-category-menu__item:focus-within > .dg-category-submenu {
  display: block;
}

.dg-category-submenu a {
  display: block;
  padding: 10px 16px;
  color: #4f5961;
  font-weight: 600;
}

.dg-category-submenu a:hover {
  background: var(--dg-soft);
  color: var(--dg-brand);
}

.dg-nav-account {
  display: flex;
  min-height: 62px;
  align-items: center;
  flex: 0 0 auto;
}

.dg-nav-login,
.dg-nav-cart {
  display: inline-flex;
  min-height: 62px;
  align-items: center;
  gap: 7px;
  border-right: 1px solid var(--dg-line);
  padding: 0 14px;
  white-space: nowrap;
}

.dg-nav-login:hover,
.dg-nav-cart:hover {
  color: var(--dg-brand);
}

.dg-account-icon {
  position: relative;
  width: 16px;
  height: 16px;
}

.dg-account-icon::before {
  position: absolute;
  top: 0;
  left: 5px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: currentColor;
  content: "";
}

.dg-account-icon::after {
  position: absolute;
  right: 1px;
  bottom: 0;
  left: 1px;
  height: 7px;
  border-radius: 8px 8px 2px 2px;
  background: currentColor;
  content: "";
}

.dg-bag-icon {
  position: relative;
  width: 16px;
  height: 15px;
  border: 2px solid currentColor;
  border-radius: 2px;
}

.dg-bag-icon::before {
  position: absolute;
  top: -7px;
  left: 3px;
  width: 6px;
  height: 6px;
  border: 2px solid currentColor;
  border-bottom: 0;
  border-radius: 5px 5px 0 0;
  content: "";
}

.dg-nav-cart .dg-cart-total {
  color: #30373d;
  font-weight: 800;
}

.dg-nav-cart .dg-cart-count {
  width: 18px;
  height: 18px;
  font-size: 10px;
}

.dg-announcement {
  background: #f1f8f7;
  color: #335452;
  font-size: 12px;
  text-align: center;
}

.dg-announcement .dg-wrap {
  display: flex;
  min-height: 34px;
  align-items: center;
  justify-content: center;
  gap: 9px;
}

.dg-contact-dock {
  position: fixed;
  top: 50%;
  right: 14px;
  z-index: 80;
  display: grid;
  gap: 7px;
  transform: translateY(-50%);
}

.dg-contact-dock__item {
  display: flex;
  min-height: 44px;
  align-items: center;
  flex-direction: row-reverse;
  justify-content: flex-end;
  color: #fff;
}

.dg-contact-dock__icon {
  display: grid;
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  place-items: center;
  border-radius: 4px;
  background: #252a2e;
  color: #fff;
  font-weight: 900;
  box-shadow: 0 9px 24px rgba(19, 26, 30, 0.2);
}

.dg-contact-dock__label {
  width: 0;
  overflow: hidden;
  border-radius: 4px 0 0 4px;
  background: #252a2e;
  font-size: 12px;
  font-weight: 800;
  opacity: 0;
  white-space: nowrap;
  transition: width 160ms ease, padding 160ms ease, opacity 160ms ease;
}

.dg-contact-dock__item:hover .dg-contact-dock__label,
.dg-contact-dock__item:focus-visible .dg-contact-dock__label {
  width: auto;
  padding: 0 12px;
  opacity: 1;
}

.dg-contact-dock__item--whatsapp .dg-contact-dock__icon,
.dg-contact-dock__item--whatsapp .dg-contact-dock__label {
  background: #18864b;
}

.dg-contact-dock__item--facebook .dg-contact-dock__icon,
.dg-contact-dock__item--facebook .dg-contact-dock__label {
  background: #2867b2;
}

.dg-contact-dock__item--tiktok .dg-contact-dock__icon,
.dg-contact-dock__item--tiktok .dg-contact-dock__label {
  background: #202124;
}

.dg-whatsapp-chat {
  position: fixed;
  right: 20px;
  bottom: 22px;
  z-index: 90;
  display: flex;
  min-height: 58px;
  align-items: center;
  color: var(--dg-ink);
  filter: drop-shadow(0 10px 24px rgba(19, 26, 30, 0.2));
}

.dg-whatsapp-chat:hover {
  color: var(--dg-ink);
  transform: translateY(-2px);
}

.dg-whatsapp-chat__copy {
  position: relative;
  display: flex;
  min-height: 40px;
  align-items: baseline;
  gap: 4px;
  border-radius: 4px 0 0 4px;
  background: #fff;
  padding: 0 14px;
  font-size: 12px;
}

.dg-whatsapp-chat__copy small {
  color: var(--dg-muted);
  font-size: 11px;
}

.dg-whatsapp-chat__copy strong {
  font-size: 12px;
}

.dg-whatsapp-chat__icon {
  display: grid;
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  place-items: center;
  border: 3px solid #20b95a;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 4px #fff;
}

.dg-whatsapp-chat__icon img {
  display: block;
  width: 38px;
  height: 38px;
  max-width: 38px;
  object-fit: contain;
  object-position: center;
}

.dg-whatsapp-chat--unconfigured .dg-whatsapp-chat__copy::after {
  position: absolute;
  right: 61px;
  bottom: calc(100% + 8px);
  width: max-content;
  max-width: 220px;
  border-radius: 4px;
  background: #202529;
  color: #fff;
  padding: 7px 10px;
  content: "Add your WhatsApp number in the Customizer";
  font-size: 10px;
  opacity: 0;
  pointer-events: none;
  transform: translateY(4px);
  transition: opacity 160ms ease, transform 160ms ease;
}

.dg-whatsapp-chat--unconfigured:hover .dg-whatsapp-chat__copy::after,
.dg-whatsapp-chat--unconfigured:focus-visible .dg-whatsapp-chat__copy::after {
  opacity: 1;
  transform: translateY(0);
}

.dg-hero {
  position: relative;
  min-height: min(590px, calc(100vh - 150px));
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: #192529;
  background-image:
    linear-gradient(90deg, rgba(16, 24, 27, 0.94) 0%, rgba(16, 24, 27, 0.84) 42%, rgba(16, 24, 27, 0.16) 72%, rgba(16, 24, 27, 0.04) 100%),
    var(--dg-hero-image);
  background-position: center;
  background-size: cover;
  color: #fff;
}

.dg-hero::after {
  position: absolute;
  inset: auto 0 0;
  height: 86px;
  background: linear-gradient(180deg, transparent, rgba(0, 0, 0, 0.14));
  content: "";
  pointer-events: none;
}

.dg-hero__content {
  position: relative;
  z-index: 1;
  padding: 70px 0 82px;
}

.dg-hero__content > * {
  max-width: 650px;
}

.dg-hero__badge {
  display: inline-flex;
  margin-bottom: 18px;
  border-left: 3px solid var(--dg-coral);
  padding: 4px 0 4px 12px;
  color: #dff8f5;
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.dg-hero h1 {
  margin: 0;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 1.04;
}

.dg-hero p {
  margin: 22px 0 0;
  color: #e1e8ea;
  font-size: 18px;
}

.dg-hero__actions {
  gap: 12px;
  margin-top: 30px;
}

.dg-button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.wp-block-button__link {
  display: inline-flex;
  min-height: 46px;
  align-items: center;
  justify-content: center;
  border: 1px solid transparent;
  border-radius: 4px;
  background: var(--dg-brand);
  color: #fff;
  padding: 0 20px;
  font-weight: 800;
  cursor: pointer;
}

.dg-button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--dg-brand-dark);
  color: #fff;
}

.dg-button--light {
  border-color: rgba(255, 255, 255, 0.62);
  background: #fff;
  color: var(--dg-ink);
}

.dg-button--light:hover {
  background: #edf2f3;
  color: var(--dg-ink);
}

.dg-hero__proof {
  gap: 20px;
  margin-top: 34px;
  color: #d9e2e4;
  font-size: 12px;
}

.dg-hero__proof span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}

.dg-hero__proof span::before {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #65d4ae;
  content: "";
}

.dg-category-strip {
  position: relative;
  z-index: 2;
  margin-top: -34px;
}

.dg-category-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  border: 1px solid var(--dg-line);
  background: #fff;
  box-shadow: var(--dg-shadow);
}

.dg-category-tile {
  display: flex;
  min-height: 108px;
  align-items: center;
  gap: 14px;
  border-right: 1px solid var(--dg-line);
  padding: 20px;
}

.dg-category-tile:nth-child(4n) {
  border-right: 0;
}

.dg-category-tile:hover strong {
  color: var(--dg-brand);
}

.dg-category-tile__number {
  display: grid;
  width: 45px;
  height: 45px;
  flex: 0 0 45px;
  place-items: center;
  border-radius: 50%;
  color: #fff;
  font-weight: 800;
}

.dg-category-tile--1 .dg-category-tile__number {
  background: var(--dg-brand);
}

.dg-category-tile--2 .dg-category-tile__number {
  background: var(--dg-coral);
}

.dg-category-tile--3 .dg-category-tile__number {
  background: var(--dg-blue);
}

.dg-category-tile--4 .dg-category-tile__number {
  background: var(--dg-gold);
}

.dg-category-tile strong,
.dg-category-tile small {
  display: block;
}

.dg-category-tile strong {
  font-size: 15px;
}

.dg-category-tile small {
  margin-top: 3px;
  color: var(--dg-muted);
  font-size: 12px;
}

.dg-section {
  padding: 76px 0;
}

.dg-section--soft {
  background: var(--dg-soft);
}

.dg-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 30px;
  margin-bottom: 28px;
}

.dg-section-head--center {
  display: block;
  max-width: 750px;
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.dg-eyebrow {
  display: block;
  margin-bottom: 8px;
  color: var(--dg-brand);
  font-size: 12px;
  font-weight: 850;
  text-transform: uppercase;
}

.dg-section-head h2,
.dg-promo h2,
.dg-faq-layout h2 {
  margin: 0;
  font-size: clamp(29px, 3vw, 42px);
  line-height: 1.12;
}

.dg-section-head p,
.dg-faq-layout > div > p {
  max-width: 620px;
  color: var(--dg-muted);
}

.dg-text-link {
  flex: 0 0 auto;
  color: var(--dg-brand);
  font-size: 13px;
  font-weight: 800;
}

.dg-text-link:hover {
  text-decoration: underline;
}

.dg-about {
  padding-top: 104px;
}

.dg-about__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(340px, 0.85fr);
  align-items: center;
  gap: 70px;
}

.dg-about__content h2 {
  margin: 7px 0 18px;
  font-size: 34px;
}

.dg-about__text {
  max-width: 760px;
  color: var(--dg-muted);
}

.dg-about__text p {
  margin: 0 0 14px;
}

.dg-about__content .dg-button {
  margin-top: 10px;
}

.dg-button--dark {
  background: var(--dg-ink);
}

.dg-button--dark:hover {
  background: #343a40;
}

.dg-about__visual {
  min-width: 0;
}

.dg-about__visual img,
.dg-process__visual img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
}

.dg-about__visual img {
  max-height: 390px;
}

.dg-image-placeholder {
  display: grid;
  min-height: 330px;
  place-items: center;
  align-content: center;
  gap: 9px;
  border: 1px dashed #bcc6cc;
  background: #f7f9fa;
  color: var(--dg-muted);
}

.dg-image-placeholder span {
  font-size: 48px;
  font-weight: 200;
}

.dg-image-placeholder small {
  font-weight: 700;
}

.dg-process {
  padding-top: 96px;
}

.dg-process .dg-section-head p {
  margin: 10px auto 0;
  color: var(--dg-muted);
}

.dg-process__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
  margin-top: 42px;
}

.dg-process__step {
  min-width: 0;
}

.dg-process__visual {
  height: 230px;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: #f7f9fa;
}

.dg-process-placeholder {
  position: relative;
  width: min(82%, 290px);
  aspect-ratio: 16 / 10;
  border: 8px solid #20262b;
  border-bottom-width: 18px;
  border-radius: 8px 8px 3px 3px;
  background: #fff;
  box-shadow: 0 14px 22px rgba(19, 26, 30, 0.14);
}

.dg-process-placeholder::after {
  position: absolute;
  right: -24px;
  bottom: -27px;
  left: -24px;
  height: 9px;
  border-radius: 0 0 50% 50%;
  background: #aab3b8;
  content: "";
}

.dg-process-placeholder__bar {
  display: block;
  height: 18%;
  background: #e7ecef;
}

.dg-process-placeholder__panel {
  display: block;
  width: 68%;
  height: 48%;
  margin: 8% auto 0;
  background: linear-gradient(135deg, var(--dg-brand) 0 35%, #dce7e7 35% 100%);
}

.dg-process__body {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 16px;
  margin-top: 24px;
}

.dg-step-number {
  color: #376ed0;
  font-size: 52px;
  font-weight: 500;
  line-height: 0.95;
}

.dg-process h3 {
  margin: 0 0 8px;
  font-size: 18px;
}

.dg-process__body p {
  margin: 0;
  color: var(--dg-muted);
  font-size: 14px;
}

.woocommerce ul.products {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin: 0;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none;
}

.woocommerce ul.products li.product {
  position: relative;
  width: auto !important;
  margin: 0 !important;
  border: 1px solid var(--dg-line);
  border-radius: 5px;
  overflow: hidden;
  background: #fff;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.woocommerce ul.products li.product:hover {
  border-color: #b8c4ca;
  box-shadow: 0 13px 28px rgba(24, 34, 40, 0.1);
  transform: translateY(-3px);
}

.woocommerce ul.products li.product a img {
  width: 100%;
  aspect-ratio: 1 / 0.72;
  margin: 0;
  object-fit: cover;
  background: #eef1f2;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
  min-height: 61px;
  margin: 0;
  padding: 17px 16px 5px;
  color: var(--dg-ink);
  font-size: 16px;
  line-height: 1.35;
}

.woocommerce ul.products li.product .price {
  min-height: 28px;
  margin: 5px 16px 12px;
  color: var(--dg-danger);
  font-size: 16px;
  font-weight: 850;
}

.woocommerce ul.products li.product .price del {
  color: var(--dg-muted);
  font-size: 12px;
  opacity: 1;
}

.woocommerce ul.products li.product .star-rating {
  margin: 4px 16px 0;
}

.woocommerce ul.products li.product .button {
  width: calc(100% - 32px);
  min-height: 42px;
  margin: 0 16px 16px;
}

.woocommerce span.onsale {
  min-width: 48px;
  min-height: 28px;
  top: 11px;
  left: 11px;
  right: auto;
  margin: 0;
  border-radius: 3px;
  background: var(--dg-coral);
  padding: 3px 8px;
  line-height: 22px;
}

.dg-placeholder-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.dg-product-placeholder {
  border: 1px dashed #c7cfd4;
  border-radius: 5px;
  overflow: hidden;
  background: #fff;
}

.dg-product-placeholder__media {
  display: grid;
  aspect-ratio: 1 / 0.72;
  place-items: center;
  color: rgba(255, 255, 255, 0.9);
  font-size: 44px;
  font-weight: 200;
}

.dg-product-placeholder__media--coral {
  background: #d96a59;
}

.dg-product-placeholder__media--blue {
  background: #3673aa;
}

.dg-product-placeholder__media--green {
  background: #3e8b69;
}

.dg-product-placeholder__media--gold {
  background: #c29b32;
}

.dg-product-placeholder__body {
  padding: 17px;
}

.dg-product-placeholder__body small {
  color: var(--dg-brand);
  font-weight: 750;
}

.dg-product-placeholder h3 {
  margin: 6px 0;
  font-size: 17px;
}

.dg-product-placeholder p {
  min-height: 62px;
  margin: 0;
  color: var(--dg-muted);
  font-size: 13px;
}

.dg-placeholder-price {
  display: block;
  margin-top: 14px;
  color: var(--dg-danger);
  font-size: 13px;
  font-weight: 800;
}

.dg-promo {
  position: relative;
  min-height: 410px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background-image:
    linear-gradient(90deg, rgba(7, 67, 64, 0.96) 0%, rgba(7, 67, 64, 0.9) 48%, rgba(7, 67, 64, 0.28) 76%, rgba(7, 67, 64, 0.12) 100%),
    var(--dg-promo-image);
  background-position: center;
  background-size: cover;
  color: #fff;
}

.dg-promo__content {
  padding: 70px 0;
}

.dg-promo__content > * {
  max-width: 610px;
}

.dg-promo .dg-eyebrow {
  color: #9cf0d6;
}

.dg-promo p {
  color: #e4f1ef;
  font-size: 17px;
}

.dg-feedback-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.dg-feedback-card {
  border: 1px solid var(--dg-line);
  border-top: 4px solid var(--dg-brand);
  padding: 27px;
}

.dg-feedback-card:nth-child(2) {
  border-top-color: var(--dg-coral);
}

.dg-feedback-card:nth-child(3) {
  border-top-color: var(--dg-blue);
}

.dg-feedback-card__rating {
  color: var(--dg-muted);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.dg-feedback-card h3 {
  margin: 10px 0 8px;
  font-size: 18px;
}

.dg-feedback-card p {
  margin: 0;
  color: var(--dg-muted);
}

.dg-faq-layout {
  display: grid;
  grid-template-columns: minmax(260px, 0.72fr) minmax(420px, 1.28fr);
  gap: 70px;
  align-items: start;
}

.dg-accordion details {
  border-bottom: 1px solid var(--dg-line);
  background: #fff;
}

.dg-accordion summary {
  position: relative;
  padding: 21px 48px 21px 20px;
  cursor: pointer;
  font-weight: 800;
  list-style: none;
}

.dg-accordion summary::-webkit-details-marker {
  display: none;
}

.dg-accordion summary::after {
  position: absolute;
  top: 19px;
  right: 20px;
  color: var(--dg-brand);
  content: "+";
  font-size: 22px;
  line-height: 1;
}

.dg-accordion details[open] summary::after {
  content: "−";
}

.dg-accordion details p {
  margin: 0;
  padding: 0 20px 22px;
  color: var(--dg-muted);
}

.dg-service-strip {
  border-block: 1px solid var(--dg-line);
  background: #fff;
}

.dg-service-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.dg-service-strip__item {
  min-height: 150px;
  display: flex;
  align-items: center;
  gap: 18px;
  justify-content: center;
  border-right: 1px solid var(--dg-line);
  padding: 20px 24px;
}

.dg-service-strip__item:last-child {
  border-right: 0;
}

.dg-service-strip__copy,
.dg-service-strip__copy strong,
.dg-service-strip__copy span {
  display: block;
}

.dg-service-strip__icon {
  display: grid;
  width: 64px;
  height: 64px;
  flex: 0 0 64px;
  place-items: center;
  border: 3px solid var(--dg-ink);
  border-radius: 50%;
  color: var(--dg-ink);
  font-size: 31px;
  font-weight: 800;
  line-height: 1;
}

.dg-service-strip__copy strong {
  font-size: 15px;
  text-transform: uppercase;
}

.dg-service-strip__copy > span {
  margin-top: 4px;
  color: var(--dg-muted);
  font-size: 12px;
}

.woocommerce div.product {
  padding: 20px 0 45px;
}

.dg-shop-hero {
  border-bottom: 1px solid var(--dg-line);
  background: #f2f5f5;
  padding: 48px 0;
}

.dg-shop-hero h1 {
  margin: 0;
  font-size: clamp(36px, 4vw, 54px);
  line-height: 1.08;
}

.dg-shop-hero p,
.dg-shop-hero__description {
  max-width: 720px;
  margin: 12px 0 0;
  color: var(--dg-muted);
}

.woocommerce div.product div.images img {
  border: 1px solid var(--dg-line);
  border-radius: 5px;
  background: var(--dg-soft);
}

.woocommerce div.product .product_title {
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1.12;
}

.woocommerce div.product p.price {
  color: var(--dg-danger);
  font-size: 25px;
  font-weight: 850;
}

.woocommerce div.product form.cart {
  display: flex;
  align-items: center;
  gap: 10px;
}

.woocommerce div.product form.cart .button {
  min-height: 50px;
  padding: 0 28px;
}

.woocommerce .quantity .qty {
  min-height: 48px;
  border: 1px solid var(--dg-line);
}

.woocommerce-tabs {
  padding-top: 34px;
}

.dg-delivery-note {
  display: flex;
  flex-direction: column;
  margin: 18px 0;
  border-left: 3px solid var(--dg-brand);
  background: #eff8f6;
  padding: 13px 16px;
}

.dg-delivery-note span {
  margin-top: 2px;
  color: var(--dg-muted);
  font-size: 13px;
}

.dg-product-assurances {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  margin: 24px 0;
  border: 1px solid var(--dg-line);
}

.dg-product-assurances > div {
  min-width: 0;
  border-right: 1px solid var(--dg-line);
  padding: 14px;
}

.dg-product-assurances > div:last-child {
  border-right: 0;
}

.dg-product-assurances strong,
.dg-product-assurances small {
  display: block;
}

.dg-product-assurances strong {
  margin-top: 7px;
  font-size: 12px;
}

.dg-product-assurances small {
  margin-top: 3px;
  color: var(--dg-muted);
  font-size: 10px;
}

.dg-assurance-icon {
  display: block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--dg-brand);
  border-radius: 50%;
}

.dg-product-help {
  display: grid;
  grid-template-columns: minmax(260px, 0.72fr) minmax(420px, 1.28fr);
  gap: 60px;
  margin: 64px 0;
  border-block: 1px solid var(--dg-line);
  padding: 58px 0;
}

.dg-product-help__intro h2,
.dg-product-faq h2 {
  margin: 0;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.12;
}

.dg-product-help__intro p {
  color: var(--dg-muted);
}

.dg-product-help__steps {
  display: grid;
  gap: 0;
}

.dg-product-help__steps article {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  gap: 16px;
  border-bottom: 1px solid var(--dg-line);
  padding: 17px 0;
}

.dg-product-help__steps article:first-child {
  padding-top: 0;
}

.dg-product-help__steps article:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.dg-product-help__steps article > span {
  color: var(--dg-coral);
  font-size: 22px;
  font-weight: 300;
}

.dg-product-help__steps h3 {
  margin: 0 0 4px;
  font-size: 16px;
}

.dg-product-help__steps p {
  margin: 0;
  color: var(--dg-muted);
  font-size: 13px;
}

.dg-product-faq {
  max-width: 900px;
  margin: 60px auto;
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  border-top-color: var(--dg-brand);
  background: #f7f9fa;
}

.woocommerce table.shop_table {
  border-color: var(--dg-line);
  border-radius: 4px;
}

.woocommerce-checkout #payment {
  border-radius: 4px;
  background: var(--dg-soft);
}

.dg-footer {
  padding: 62px 0 22px;
  background: #171a1e;
  color: #e7ecef;
}

.dg-footer__grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(4, 1fr);
  gap: 34px;
}

.dg-footer .dg-brand {
  color: #fff;
}

.dg-footer .dg-logo-placeholder {
  border-color: #58646b;
  background:
    linear-gradient(135deg, transparent 48%, #4d585e 49%, #4d585e 51%, transparent 52%),
    #24292d;
}

.dg-footer .dg-brand__text small,
.dg-footer p,
.dg-footer a {
  color: #aeb8bf;
}

.dg-footer h3 {
  margin: 5px 0 15px;
  color: #fff;
  font-size: 14px;
}

.dg-footer a {
  display: block;
  margin: 9px 0;
  font-size: 13px;
}

.dg-footer a:hover {
  color: #fff;
}

.dg-footer ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

.dg-footer__brand p {
  max-width: 330px;
  font-size: 13px;
}

#dg-contact-details {
  scroll-margin-top: 30px;
}

.dg-payment-placeholder {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 18px;
}

.dg-payment-placeholder span {
  border: 1px solid #465158;
  border-radius: 3px;
  padding: 5px 8px;
  color: #d6dee2;
  font-size: 9px;
  font-weight: 800;
}

.dg-footer__bottom {
  min-height: 64px;
  justify-content: space-between;
  gap: 20px;
  margin-top: 42px;
  border-top: 1px solid #30363b;
  color: #89959c;
  font-size: 11px;
}

.dg-card {
  border: 1px solid var(--dg-line);
  border-radius: 5px;
  background: #fff;
  padding: 25px;
}

.screen-reader-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

@media (max-width: 1080px) {
  .dg-header__inner {
    gap: 16px;
  }

  .dg-brand {
    min-width: 160px;
  }

  .dg-brand__text small {
    display: none;
  }

  .dg-header-action > span:not(.dg-header-action__icon, .dg-cart-count) {
    display: none;
  }

  .dg-header-action {
    min-width: 42px;
  }

  .dg-header-benefits {
    display: none;
  }

  .dg-category-menu__item > a {
    padding: 0 10px;
  }

  .dg-category-strip__grid,
  .woocommerce ul.products,
  .dg-placeholder-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dg-category-tile:nth-child(4n) {
    border-right: 1px solid var(--dg-line);
  }

  .dg-category-tile:nth-child(3n) {
    border-right: 0;
  }

  .dg-footer__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .dg-footer__brand {
    grid-column: span 3;
  }
}

@media (max-width: 820px) {
  .dg-topbar__meta span:first-child {
    display: none;
  }

  .dg-menu-toggle {
    display: grid;
    flex: 0 0 42px;
    place-items: center;
  }

  .dg-header__inner {
    min-height: 76px;
    flex-wrap: wrap;
  }

  .dg-brand {
    margin-right: auto;
  }

  .dg-search {
    order: 4;
    width: 100%;
    max-width: none;
    flex-basis: 100%;
    margin-bottom: 14px;
  }

  .dg-nav {
    display: none;
  }

  .dg-nav.is-open {
    display: block;
  }

  .dg-nav__inner,
  .dg-category-menu {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }

  .dg-nav__inner {
    padding: 12px 0;
  }

  .dg-category-menu {
    width: 100%;
  }

  .dg-category-menu__item {
    display: block;
    width: 100%;
  }

  .dg-category-menu__item > a {
    min-height: 48px;
    justify-content: flex-start;
    border-bottom: 1px solid var(--dg-line);
    border-left: 0;
    border-right: 0 !important;
    padding: 0 12px;
  }

  .dg-category-submenu {
    position: static;
    display: block;
    width: 100%;
    border: 0;
    border-bottom: 1px solid var(--dg-line);
    box-shadow: none;
  }

  .dg-category-submenu a {
    padding-left: 40px;
  }

  .dg-nav-account {
    width: 100%;
    min-height: 52px;
  }

  .dg-nav-login,
  .dg-nav-cart {
    min-height: 52px;
    flex: 1;
    justify-content: center;
    border-bottom: 0;
    border-left: 1px solid var(--dg-line);
  }

  .dg-hero {
    min-height: 540px;
    background-image:
      linear-gradient(90deg, rgba(16, 24, 27, 0.93), rgba(16, 24, 27, 0.7)),
      var(--dg-hero-image);
  }

  .dg-category-strip {
    margin-top: 0;
  }

  .dg-category-strip__grid,
  .dg-feedback-grid,
  .dg-service-strip__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dg-about__grid {
    grid-template-columns: 1fr;
    gap: 38px;
  }

  .dg-about__visual {
    order: -1;
  }

  .dg-process__grid {
    grid-template-columns: 1fr;
    gap: 46px;
  }

  .dg-process__visual {
    height: min(340px, 48vw);
  }

  .woocommerce ul.products,
  .dg-placeholder-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dg-faq-layout {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .dg-product-help {
    grid-template-columns: 1fr;
    gap: 30px;
  }

  .dg-service-strip__item:nth-child(2) {
    border-right: 0;
  }

  .dg-service-strip__item:nth-child(-n + 2) {
    border-bottom: 1px solid var(--dg-line);
  }
}

@media (max-width: 560px) {
  .dg-wrap {
    width: min(100% - 24px, 1240px);
  }

  .dg-topbar__inner {
    min-height: 42px;
  }

  .dg-topbar__contact span,
  .dg-topbar__meta {
    display: none;
  }

  .dg-header__inner {
    gap: 10px;
  }

  .dg-brand {
    min-width: 0;
  }

  .dg-brand__mark {
    width: 40px;
    height: 40px;
    flex-basis: 40px;
  }

  .dg-brand__text strong {
    max-width: 130px;
    font-size: 17px;
  }

  .dg-header__actions {
    gap: 0;
  }

  .dg-header-action {
    min-width: 36px;
  }

  .dg-search button {
    padding: 0 14px;
  }

  .dg-announcement span {
    display: none;
  }

  .dg-contact-dock {
    top: auto;
    right: 8px;
    bottom: 92px;
    transform: none;
  }

  .dg-whatsapp-chat {
    right: 10px;
    bottom: 16px;
  }

  .dg-whatsapp-chat__copy {
    padding: 0 10px;
  }

  .dg-whatsapp-chat__copy small {
    display: none;
  }

  .dg-whatsapp-chat__icon {
    width: 54px;
    height: 54px;
    flex-basis: 54px;
  }

  .dg-about {
    padding-top: 72px;
  }

  .dg-about__grid {
    gap: 28px;
  }

  .dg-about__content h2 {
    font-size: 29px;
  }

  .dg-image-placeholder {
    min-height: 230px;
  }

  .dg-service-strip__grid {
    grid-template-columns: 1fr;
  }

  .dg-service-strip__item {
    min-height: 118px;
    justify-content: flex-start;
    border-right: 0;
    border-bottom: 1px solid var(--dg-line);
  }

  .dg-service-strip__item:last-child {
    border-bottom: 0;
  }

  .dg-process {
    padding-top: 72px;
  }

  .dg-process__visual {
    height: 230px;
  }

  .dg-contact-dock__icon {
    width: 42px;
    height: 42px;
    flex-basis: 42px;
  }

  .dg-contact-dock__label {
    display: none;
  }

  .dg-hero {
    min-height: 500px;
    background-position: 62% center;
  }

  .dg-hero__content {
    padding: 54px 0 65px;
  }

  .dg-hero h1 {
    font-size: 40px;
  }

  .dg-hero p {
    font-size: 16px;
  }

  .dg-hero__actions {
    align-items: stretch;
    flex-direction: column;
  }

  .dg-hero__actions .dg-button {
    width: 100%;
  }

  .dg-hero__proof {
    align-items: flex-start;
    flex-direction: column;
    gap: 8px;
  }

  .dg-category-strip__grid,
  .dg-feedback-grid,
  .dg-service-strip__grid {
    grid-template-columns: 1fr;
  }

  .dg-category-tile,
  .dg-category-tile:nth-child(n),
  .dg-service-strip__grid > div,
  .dg-service-strip__grid > div:nth-child(n) {
    border-right: 0;
    border-bottom: 1px solid var(--dg-line);
  }

  .dg-category-tile:last-child,
  .dg-service-strip__grid > div:last-child {
    border-bottom: 0;
  }

  .dg-section {
    padding: 52px 0;
  }

  .dg-steps {
    padding-top: 60px;
  }

  .dg-section-head {
    display: block;
  }

  .dg-section-head .dg-text-link {
    display: inline-block;
    margin-top: 14px;
  }

  .dg-steps__grid {
    grid-template-columns: 1fr;
  }

  .dg-steps article,
  .dg-steps article:nth-child(n) {
    grid-column: auto;
    border-right: 0;
    border-bottom: 1px solid var(--dg-line);
    border-top: 0;
  }

  .dg-steps article:last-child {
    border-bottom: 0;
  }

  .woocommerce ul.products,
  .dg-placeholder-grid {
    grid-template-columns: 1fr;
  }

  .dg-promo {
    min-height: 440px;
    background-image:
      linear-gradient(90deg, rgba(7, 67, 64, 0.95), rgba(7, 67, 64, 0.72)),
      var(--dg-promo-image);
  }

  .dg-footer__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .dg-footer__brand {
    grid-column: span 2;
  }

  .dg-footer__bottom {
    align-items: flex-start;
    flex-direction: column;
    justify-content: center;
    padding: 16px 0;
  }

  .dg-product-assurances {
    grid-template-columns: 1fr;
  }

  .dg-product-assurances > div,
  .dg-product-assurances > div:last-child {
    border-right: 0;
    border-bottom: 1px solid var(--dg-line);
  }

  .dg-product-assurances > div:last-child {
    border-bottom: 0;
  }
}
