/* ============================================================
   DKKA WooCommerce Shop Styles v1.0 (mu-plugin Asset)
   Branding fuer Shop, Cart (classic + block), Checkout (block),
   My Account, Single Product. Tokens: CLAUDE.md Design Tokens.
   ============================================================ */

:root {
  --dkka-navy: #12293D;
  --dkka-navy-deep: #0D1F2E;
  --dkka-navy-surface: #1E3D55;
  --dkka-orange: #F39239;
  --dkka-orange-hover: #D97A1F;
  --dkka-steel: #A8BCC8;
  --dkka-warm-white: #FBF7F2;
  --dkka-cream: #F0E6D4;
  --dkka-border: #E2E8EE;
  --dkka-font: 'Montserrat', Arial, sans-serif;
}

/* ---------- Typografie in WC-Scopes ---------- */
.woocommerce,
.woocommerce-page .woocommerce,
.wp-block-woocommerce-checkout,
.wp-block-woocommerce-cart,
.wc-block-components-sidebar-layout {
  font-family: var(--dkka-font);
  color: var(--dkka-navy);
  font-size: 16px;
}

.woocommerce h1, .woocommerce h2, .woocommerce h3, .woocommerce h4,
.woocommerce-page h1.entry-title,
.wp-block-woocommerce-checkout h2, .wp-block-woocommerce-checkout h3,
.wp-block-woocommerce-cart h2,
.wc-block-components-title,
.wc-block-components-checkout-step__title {
  font-family: var(--dkka-font);
  font-weight: 800;
  color: var(--dkka-navy);
}

/* ---------- Buttons: Classic WC ---------- */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce button[name="apply_coupon"],
.woocommerce-page a.button {
  background-color: var(--dkka-orange);
  color: #FFFFFF;
  font-family: var(--dkka-font);
  font-weight: 700;
  border: none;
  border-radius: 8px;
  padding: 0.85em 1.6em;
  transition: background-color 0.2s ease;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
  background-color: var(--dkka-orange-hover);
  color: #FFFFFF;
}

.woocommerce a.button.disabled, .woocommerce a.button:disabled,
.woocommerce button.button.disabled, .woocommerce button.button:disabled,
.woocommerce input.button.disabled, .woocommerce input.button:disabled[disabled] {
  background-color: var(--dkka-steel);
  color: #FFFFFF;
}

/* ---------- Buttons: WC Blocks (Checkout/Cart) ---------- */
.wc-block-components-button:not(.is-link) {
  background-color: var(--dkka-orange) !important;
  color: #FFFFFF !important;
  font-family: var(--dkka-font);
  font-weight: 700;
  border-radius: 8px;
  border: none;
}

.wc-block-components-button:not(.is-link):hover,
.wc-block-components-button:not(.is-link):focus {
  background-color: var(--dkka-orange-hover) !important;
  color: #FFFFFF !important;
}

/* ---------- Formularfelder: Classic ---------- */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce table.cart td.actions .coupon .input-text,
.woocommerce .woocommerce-form-login .input-text,
.woocommerce .woocommerce-form-register .input-text,
.woocommerce .woocommerce-EditAccountForm .input-text {
  font-family: var(--dkka-font);
  border: 1px solid var(--dkka-border);
  border-radius: 8px;
  padding: 0.7em 0.9em;
  background: #FFFFFF;
  color: var(--dkka-navy);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus,
.woocommerce table.cart td.actions .coupon .input-text:focus,
.woocommerce .input-text:focus {
  border-color: var(--dkka-orange);
  box-shadow: 0 0 0 2px rgba(243, 146, 57, 0.25);
  outline: none;
}

/* ---------- Formularfelder: WC Blocks ---------- */
.wc-block-components-text-input input,
.wc-block-components-textarea,
.wc-block-components-combobox .components-combobox-control__input,
.wc-block-components-form .wc-block-components-text-input input {
  font-family: var(--dkka-font);
  border-radius: 8px;
}

.wc-block-components-text-input input:focus,
.wc-block-components-textarea:focus,
.wc-block-components-combobox .components-combobox-control__input:focus {
  border-color: var(--dkka-orange);
  box-shadow: 0 0 0 2px rgba(243, 146, 57, 0.35);
}

/* Radios + Checkboxen (beide Welten) */
.woocommerce input[type="radio"],
.woocommerce input[type="checkbox"],
.wp-block-woocommerce-checkout input[type="radio"],
.wp-block-woocommerce-checkout input[type="checkbox"] {
  accent-color: var(--dkka-orange);
}

.wc-block-components-radio-control__input:checked {
  border-color: var(--dkka-orange);
}

.wc-block-components-radio-control__input:checked::before {
  background: var(--dkka-orange);
}

.wc-block-components-checkbox__input[type="checkbox"]:checked {
  background-color: var(--dkka-orange);
  border-color: var(--dkka-orange);
}

/* ---------- Tabellen (Cart, Bestellungen, Abos) ---------- */
.woocommerce table.shop_table {
  border: 1px solid var(--dkka-border);
  border-radius: 12px;
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
}

.woocommerce table.shop_table thead th,
.woocommerce table.my_account_orders thead th,
.woocommerce table.my_account_subscriptions thead th {
  background-color: var(--dkka-navy);
  color: #FFFFFF;
  font-family: var(--dkka-font);
  font-weight: 700;
  padding: 14px 12px;
}

.woocommerce table.shop_table td {
  border-top: 1px solid var(--dkka-border);
  padding: 12px;
}

.woocommerce table.shop_table tbody tr:nth-child(even) td {
  background-color: var(--dkka-warm-white);
}

/* ---------- Preise ---------- */
.woocommerce .price,
.woocommerce span.woocommerce-Price-amount {
  color: var(--dkka-navy);
  font-weight: 700;
}

.woocommerce .price del,
.woocommerce span.woocommerce-Price-amount del {
  color: var(--dkka-steel);
  font-weight: 400;
}

/* ---------- Notices / Meldungen ---------- */
.woocommerce-message,
.woocommerce-info {
  border-top-color: var(--dkka-orange);
  background-color: var(--dkka-warm-white);
  color: var(--dkka-navy);
  font-family: var(--dkka-font);
  border-radius: 0 0 8px 8px;
}

.woocommerce-message::before {
  color: var(--dkka-orange);
}

.woocommerce-info::before {
  color: var(--dkka-navy-surface);
}

.woocommerce-error {
  font-family: var(--dkka-font);
  border-radius: 0 0 8px 8px;
}

.wc-block-components-notice-banner {
  font-family: var(--dkka-font);
  border-radius: 8px;
}

/* ---------- My Account ---------- */
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  margin: 0;
  padding: 10px;
  background-color: var(--dkka-navy);
  border-radius: 12px;
}

.woocommerce-MyAccount-navigation ul li {
  margin: 2px 0;
}

.woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 12px 16px;
  color: #FFFFFF;
  font-family: var(--dkka-font);
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  transition: background-color 0.15s ease;
}

.woocommerce-MyAccount-navigation ul li a:hover {
  background-color: var(--dkka-navy-surface);
  color: #FFFFFF;
}

.woocommerce-MyAccount-navigation ul li.is-active a {
  background-color: var(--dkka-orange);
  color: #FFFFFF;
}

.woocommerce-MyAccount-content {
  font-family: var(--dkka-font);
  color: var(--dkka-navy);
}

.woocommerce-MyAccount-content a:not(.button) {
  color: var(--dkka-orange-hover);
  font-weight: 600;
}

/* Login-/Registrierungs-Karte (My Account, ausgeloggt) */
.woocommerce form.login,
.woocommerce form.register,
.woocommerce form.lost_reset_password {
  border: 1px solid var(--dkka-border);
  border-radius: 12px;
  padding: 28px;
  background: #FFFFFF;
  box-shadow: 0 6px 24px rgba(18, 41, 61, 0.06);
}

/* ---------- Checkout-Block Feinschliff ---------- */
.wc-block-checkout__sidebar .wc-block-components-totals-wrapper,
.wc-block-checkout__sidebar .wc-block-components-totals-footer-item {
  font-family: var(--dkka-font);
}

.wc-block-components-totals-footer-item .wc-block-components-totals-item__value,
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  color: var(--dkka-navy);
  font-weight: 800;
}

a.wc-block-components-totals-coupon-link,
.wc-block-components-totals-coupon-link {
  color: var(--dkka-orange-hover);
}

/* ---------- Quantity-Input ---------- */
.woocommerce .quantity .qty {
  border: 1px solid var(--dkka-border);
  border-radius: 8px;
  padding: 0.6em 0.4em;
  font-family: var(--dkka-font);
}

/* ---------- Breadcrumb ---------- */
.woocommerce .woocommerce-breadcrumb {
  font-family: var(--dkka-font);
  color: var(--dkka-steel);
}

.woocommerce .woocommerce-breadcrumb a {
  color: var(--dkka-navy-surface);
}

/* ---------- v1.1: My-Account-Tabellen — Rand auf allen Seiten erzwingen ---------- */
/* Das Elementor-Pro-Widget zeichnet teils nur horizontale Divider, dadurch fehlt der linke/rechte Tabellenrand */
.elementor-widget-woocommerce-my-account table.shop_table,
.e-my-account-tab table.shop_table {
  border: 1px solid var(--dkka-border) !important;
  width: 100%;
}

.elementor-widget-woocommerce-my-account table.shop_table th,
.elementor-widget-woocommerce-my-account table.shop_table td,
.e-my-account-tab table.shop_table th,
.e-my-account-tab table.shop_table td {
  border-left: 0 !important;
  border-right: 0 !important;
}

.woocommerce-MyAccount-content {
  overflow-x: auto;
}

/* ---------- v1.1: Produktbeschreibung lesbar (globale Kit-Textfarbe ist Weiss) ---------- */
.elementor-widget-woocommerce-product-content,
.elementor-widget-woocommerce-product-content p,
.elementor-widget-woocommerce-product-content li {
  color: #3E5468;
  font-family: var(--dkka-font);
}

.elementor-widget-woocommerce-product-content h2,
.elementor-widget-woocommerce-product-content h3,
.elementor-widget-woocommerce-product-content h4 {
  color: var(--dkka-navy);
  font-family: var(--dkka-font);
  font-weight: 800;
}

/* Steuerhinweis-Widget: Template-spezifische Farben (A = hell, B = Navy-Hero) */
.elementor-1018195 .elementor-widget-woocommerce-gzd-tax-notice {
  color: #5A7184;
}

.elementor-1018196 .elementor-widget-woocommerce-gzd-tax-notice {
  color: #A8BCC8;
}

/* ---------- v1.2: Produktseiten-Fixes (Template A) ---------- */
/* WC-Gallery startet mit inline opacity:0 und wartet auf JS-Init, der in Elementor-Templates ausbleiben kann */
.woocommerce-product-gallery {
  opacity: 1 !important;
}

.woocommerce-product-gallery img {
  width: 100%;
  height: auto;
}

/* WC-Core faerbt p.price gruen (#77a464) - Suffixe wie 'als Einmalzahlung' / 'pro Monat' auf Navy zwingen */
.woocommerce div.product p.price,
.woocommerce div.product span.price,
.woocommerce .subscription-details,
.woocommerce .price .from {
  color: var(--dkka-navy);
}

/* Beschreibungs-Ueberschriften kompakter */
.elementor-widget-woocommerce-product-content h2 {
  font-size: 24px;
}

.elementor-widget-woocommerce-product-content h3 {
  font-size: 20px;
}

.elementor-widget-woocommerce-product-content h4 {
  font-size: 18px;
}

/* ---------- v1.3: Cart-Widget Brand-Farben (Elementor-Pro-Defaults uebersteuern) ---------- */
.elementor-widget-woocommerce-cart a.button,
.elementor-widget-woocommerce-cart button.button,
.elementor-widget-woocommerce-cart .checkout-button,
.elementor-widget-woocommerce-cart .actions .button,
.elementor-widget-woocommerce-cart .coupon .button {
  background-color: #F39239 !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 8px !important;
  font-family: 'Montserrat', Arial, sans-serif !important;
  font-weight: 700 !important;
}

.elementor-widget-woocommerce-cart a.button:hover,
.elementor-widget-woocommerce-cart button.button:hover,
.elementor-widget-woocommerce-cart .checkout-button:hover {
  background-color: #D97A1F !important;
  color: #FFFFFF !important;
}

.elementor-widget-woocommerce-cart button.button:disabled,
.elementor-widget-woocommerce-cart button.button.disabled {
  background-color: #A8BCC8 !important;
  color: #FFFFFF !important;
  opacity: 1;
}

/* Produkt-Link in der Cart-Tabelle: Navy statt Hellblau */
.elementor-widget-woocommerce-cart td.product-name a,
.elementor-widget-woocommerce-cart .product-name a {
  color: #1E3D55 !important;
  font-weight: 600;
  text-decoration: none;
}

.elementor-widget-woocommerce-cart td.product-name a:hover,
.elementor-widget-woocommerce-cart .product-name a:hover {
  color: #D97A1F !important;
}

/* Entfernen-X dezent */
.elementor-widget-woocommerce-cart a.remove {
  color: #A8BCC8 !important;
}

.elementor-widget-woocommerce-cart a.remove:hover {
  color: #D97A1F !important;
  background: transparent !important;
}

/* ---------- v1.4: Header-Menue - 3. Ebene nach LINKS oeffnen (lief rechts aus dem Viewport) ---------- */
@media (min-width: 1025px) {
  .elementskit-navbar-nav .elementskit-dropdown .elementskit-dropdown,
  .elementskit-navbar-nav .elementskit-dropdown ul.elementskit-submenu-panel ul.elementskit-submenu-panel,
  .elementskit-navbar-nav li.elementskit-dropdown-submenu > .elementskit-dropdown {
    left: auto !important;
    right: 100% !important;
    top: 0 !important;
  }
}

/* ---------- v1.5: Template C Buy-Box - Bild kompakt + Box passt in den Viewport ---------- */
.dkka-buybox {
  padding: 18px 24px !important;
  gap: 10px !important;
}

.dkka-buybox .elementor-widget-woocommerce-product-images {
  max-width: 160px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.dkka-buybox .elementor-widget-woocommerce-product-images img {
  border-radius: 12px;
}

@media (min-width: 1025px) {
  .dkka-buybox {
    max-height: calc(100vh - 140px);
    overflow-y: auto;
  }
}

/* Steuerhinweis in der Buy-Box (Template C): lesbar auf Cream — Kit-Textfarbe ist weiss */
.dkka-buybox .elementor-widget-woocommerce-gzd-tax-notice {
  color: #5A7184 !important;
  font-size: 13px;
  text-align: center;
}

/* ---------- v1.6: Menu-Cart Side-Drawer (Header #874, Widget 75c63acd) ---------- */
/* Elementor-Pro-Side-Cart hat keine Kit-Anbindung - alles explizit (DKKA-Tokens) */

.elementor-menu-cart__container {
  z-index: 100000 !important;
}

/* Drawer lebt im Top-Bar-Container des Headers (#874, .dkka-toprow, z 999):
   bei offenem Drawer den Top-Bar ueber die weisse Haupt-Nav heben, sonst schneidet sie den Drawer */
.dkka-toprow:has(.elementor-menu-cart__container[aria-hidden="false"]) {
  z-index: 10000 !important;
}

.elementor-menu-cart__main {
  background: #FFFFFF !important;
  border: none !important;
  box-shadow: -10px 0 40px rgba(13, 31, 46, 0.22) !important;
  padding: 24px 26px !important;
  font-family: Montserrat, Arial, sans-serif !important;
}

@media (min-width: 768px) {
  .elementor-menu-cart__main {
    width: 380px !important;
    max-width: 90vw !important;
  }
}

/* Drawer-Titel */
.elementor-menu-cart__main::before {
  content: "Dein Warenkorb";
  display: block;
  color: #12293D;
  font-family: Montserrat, Arial, sans-serif;
  font-weight: 800;
  font-size: 20px;
  margin: 2px 36px 18px 0;
}

.elementor-menu-cart__close-button {
  color: #12293D !important;
}
.elementor-menu-cart__close-button:hover {
  color: #F39239 !important;
}

/* Produktliste */
.elementor-menu-cart__products {
  border: none !important;
}
.elementor-menu-cart__product {
  border-bottom: 1px solid #EDE6D8 !important;
  padding: 14px 0 !important;
}
.elementor-menu-cart__product-image img {
  border-radius: 8px;
}

.elementor-menu-cart__product-name,
.elementor-menu-cart__product-name a,
.elementor-menu-cart__main .woocommerce-mini-cart-item a:not(.remove) {
  color: #12293D !important;
  font-family: Montserrat, Arial, sans-serif !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  line-height: 1.45 !important;
  text-decoration: none !important;
}
.elementor-menu-cart__product-name a:hover,
.elementor-menu-cart__main .woocommerce-mini-cart-item a:not(.remove):hover {
  color: #F39239 !important;
}

/* Variations-Details (Zahlungsplan etc.) */
.elementor-menu-cart__main dl.variation,
.elementor-menu-cart__main dl.variation dt,
.elementor-menu-cart__main dl.variation dd,
.elementor-menu-cart__main dl.variation p {
  color: #5A7184 !important;
  font-family: Montserrat, Arial, sans-serif !important;
  font-weight: 400 !important;
  font-size: 12.5px !important;
}

/* Menge x Preis */
.elementor-menu-cart__product-price,
.elementor-menu-cart__main .quantity,
.elementor-menu-cart__main .woocommerce-Price-amount {
  color: #3E5468 !important;
  font-family: Montserrat, Arial, sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
}

/* Entfernen-X (Elementor nutzt remove_from_cart_button, kein a.remove) */
.elementor-menu-cart__product-remove a {
  color: #A8BCC8 !important;
}
.elementor-menu-cart__product-remove a:hover {
  color: #F39239 !important;
}

/* Zwischensumme */
.elementor-menu-cart__subtotal {
  color: #12293D !important;
  font-family: Montserrat, Arial, sans-serif !important;
  font-weight: 800 !important;
  font-size: 17px !important;
  border-top: 2px solid #12293D !important;
  border-bottom: 0 !important;
  padding: 16px 0 4px !important;
  margin-top: 4px;
}
.elementor-menu-cart__subtotal .woocommerce-Price-amount {
  color: #12293D !important;
  font-weight: 800 !important;
  font-size: 17px !important;
}

/* Footer-Buttons: Warenkorb = Navy-Outline, Kasse = Orange-Primary */
.elementor-menu-cart__footer-buttons {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}
.elementor-menu-cart__footer-buttons .elementor-button {
  display: block;
  width: 100%;
  text-align: center;
  font-family: Montserrat, Arial, sans-serif !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  border-radius: 8px !important;
  padding: 14px 20px !important;
  text-transform: none !important;
}
.elementor-menu-cart__footer-buttons .elementor-button--view-cart {
  background: transparent !important;
  color: #12293D !important;
  border: 2px solid #12293D !important;
}
.elementor-menu-cart__footer-buttons .elementor-button--view-cart:hover {
  background: #12293D !important;
  color: #FFFFFF !important;
}
.elementor-menu-cart__footer-buttons .elementor-button--checkout {
  background-color: #F39239 !important;
  color: #FFFFFF !important;
  border: none !important;
}
.elementor-menu-cart__footer-buttons .elementor-button--checkout:hover {
  background-color: #E07F22 !important;
}

/* Empty-State */
.elementor-menu-cart__main .woocommerce-mini-cart__empty-message {
  color: #3E5468 !important;
  font-family: Montserrat, Arial, sans-serif !important;
  font-weight: 600;
  font-size: 15px;
}


/* ============================================================
   v1.7: My-Account-Navigation - modernes Menue mit aktivem
   Orange-Akzentbalken (uebersteuert Elementor-Pro-Defaults).
   ============================================================ */
.woocommerce-MyAccount-navigation ul,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 8px !important;
  background-color: var(--dkka-navy) !important;
  border: 0 !important;
  border-radius: 14px !important;
  box-shadow: 0 12px 32px rgba(13, 31, 46, 0.18) !important;
}
.woocommerce-MyAccount-navigation ul li,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  list-style: none !important;
}
.woocommerce-MyAccount-navigation ul li a,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li a {
  position: relative;
  display: block;
  padding: 13px 18px 13px 22px !important;
  margin: 1px 0;
  color: var(--dkka-steel) !important;
  background: transparent !important;
  font-family: var(--dkka-font) !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  line-height: 1.4 !important;
  letter-spacing: 0.01em;
  border: 0 !important;
  border-radius: 10px !important;
  text-decoration: none !important;
  transition: color 0.18s ease, background-color 0.18s ease;
}
.woocommerce-MyAccount-navigation ul li a::before,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li a::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%) scaleY(0);
  width: 3px;
  height: 20px;
  border-radius: 3px;
  background: var(--dkka-orange);
  transition: transform 0.18s ease;
}
.woocommerce-MyAccount-navigation ul li a:hover,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: #FFFFFF !important;
  background: var(--dkka-navy-surface) !important;
}
.woocommerce-MyAccount-navigation ul li a:hover::before,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li a:hover::before {
  transform: translateY(-50%) scaleY(1);
}
.woocommerce-MyAccount-navigation ul li.is-active a,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li.is-active a {
  color: #FFFFFF !important;
  background: var(--dkka-navy-surface) !important;
  font-weight: 700 !important;
}
.woocommerce-MyAccount-navigation ul li.is-active a::before,
.elementor-widget-woocommerce-my-account .woocommerce-MyAccount-navigation ul li.is-active a::before {
  transform: translateY(-50%) scaleY(1);
}
