/* MatricaDiszkont – DINAMIKUS ÁR-KAPU (pasztell minimal, termékoldal UI) */

/* Mennyiségi kedvezmény – fő ár alatt (csak kalkulátoros termékeken) */
.j2store-single-product.detail .product-price-container .md-dp-price-hint {
  margin: 8px 0 0;
  padding: 0;
  font-family: var(--md-pd-font, var(--md-dp-font));
  font-size: 12px;
  line-height: 1.45;
  font-weight: 500;
  color: var(--md-pd-muted, #556575);
}

.j2store-single-product.detail .product-price-container .md-dp-price-hint__sub {
  font-weight: 400;
  color: var(--md-pd-strike, #7a8796);
}

.j2store-single-product.detail .product-price-container .md-dp-price-hint.is-applied {
  color: var(--md-pd-accent, #4a6d92);
}

.j2store-single-product.detail .product-price-container .md-dp-preset-price-hint {
  margin: 8px 0 0;
  padding: 0;
  font-family: var(--md-pd-font, var(--md-dp-font));
  font-size: 12px;
  line-height: 1.45;
  font-weight: 500;
  color: var(--md-pd-muted, #556575);
}

.j2store-single-product.detail .md-dp-size-option-hint {
  margin: 8px 0 12px;
  padding: 10px 12px;
  font-family: var(--md-pd-font, var(--md-dp-font));
  font-size: 13px;
  line-height: 1.45;
  color: var(--md-dp-info-text, #4a6278);
  background: var(--md-dp-info-bg, #edf4fa);
  border-radius: var(--md-dp-radius, 6px);
}

.j2store-single-product.detail .md-dp-size-option-hint .md-dp-printed-preset-warn {
  display: block;
  margin-top: 6px;
  font-weight: 600;
  color: var(--md-dp-warn-text, #8a6b3e);
}

.md-dp-printed-preset-cart-block {
  margin: 0 0 12px;
  padding: 12px 14px;
  border-radius: var(--md-dp-radius, 6px);
  background: var(--md-dp-warn-bg, #faf3e8);
  border: 1px solid rgba(138, 107, 62, 0.35);
  color: var(--md-dp-warn-text, #8a6b3e);
}

.md-dp-printed-preset-cart-block__title {
  margin: 0 0 6px;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 14px;
  font-weight: 700;
  line-height: 1.35;
}

.md-dp-printed-preset-cart-block__text {
  margin: 0;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 13px;
  line-height: 1.45;
}

.j2store-single-product.detail .j2store-add-to-cart.is-md-dp-cart-blocked > .j2store-cart-button > .j2store-cart-button,
.j2store-single-product.detail .j2store-add-to-cart.is-md-dp-cart-blocked > .j2store-cart-button > button.j2store-cart-button,
.j2store-single-product.detail .j2store-add-to-cart.is-md-dp-cart-blocked > .j2store-cart-button > input.j2store-cart-button,
body.j2store-single-product-view .j2store-single-product.detail .j2store-add-to-cart.is-md-dp-cart-blocked > .j2store-cart-button > .btn-primary {
  opacity: 0.42;
  cursor: not-allowed;
  pointer-events: none;
  filter: grayscale(0.15);
}

.md-dp__quick-sizes {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  margin: 0 0 14px;
}

.md-dp__quick-sizes-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.md-dp__quick-size {
  margin: 0;
  padding: 5px 10px;
  border: 1px solid var(--md-dp-border);
  border-radius: var(--md-dp-radius);
  background: #fff;
  font-family: var(--md-dp-font);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--md-dp-accent);
  cursor: pointer;
  transition: background 0.2s var(--md-dp-ease), border-color 0.2s var(--md-dp-ease);
}

.md-dp__quick-size:hover,
.md-dp__quick-size:focus-visible {
  background: var(--md-dp-accent-soft);
  border-color: rgba(74, 109, 146, 0.35);
  outline: none;
}

.md-dp {
  --md-dp-font: var(--md-pd-font, 'Metropolis', system-ui, sans-serif);
  --md-dp-text: var(--md-pd-text, #2d3436);
  --md-dp-muted: var(--md-pd-muted, #556575);
  --md-dp-accent: var(--md-pd-accent, #4a6d92);
  --md-dp-accent-soft: var(--md-pd-accent-soft, #e8f0f7);
  --md-dp-surface: var(--md-pd-surface, #f4f6f8);
  --md-dp-border: var(--md-pd-border, rgba(15, 23, 42, 0.1));
  --md-dp-radius: var(--md-pd-radius, 6px);
  --md-dp-warn-bg: #faf3e8;
  --md-dp-warn-text: #8a6b3e;
  --md-dp-info-bg: #edf4fa;
  --md-dp-info-text: #4a6278;
  --md-dp-ease: cubic-bezier(0.22, 1, 0.36, 1);
  margin: 18px 0 8px;
  font-family: var(--md-dp-font);
}

.md-dp[hidden] {
  display: none !important;
}

.md-dp.is-visible {
  animation: mdDpReveal 0.45s var(--md-dp-ease) both;
}

@keyframes mdDpReveal {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.md-dp__card {
  padding: 18px 18px 16px;
  border: 1px solid var(--md-dp-border);
  border-radius: calc(var(--md-dp-radius) + 2px);
  background: linear-gradient(165deg, #fff 0%, var(--md-dp-surface) 100%);
}

.md-dp__header {
  margin-bottom: 14px;
}

.md-dp__title {
  margin: 0 0 6px;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--md-dp-text);
}

.md-dp__hint {
  margin: 0;
  font-size: 13px;
  line-height: 1.45;
  color: var(--md-dp-muted);
}

.md-dp__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.md-dp__field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin: 0;
}

.md-dp__label {
  font-size: 12px;
  font-weight: 500;
  color: var(--md-dp-muted);
}

.md-dp__input-wrap {
  display: flex;
  align-items: stretch;
  border: 1px solid var(--md-dp-border);
  border-radius: var(--md-dp-radius);
  background: #fff;
  overflow: hidden;
  transition: border-color 0.2s var(--md-dp-ease), box-shadow 0.2s var(--md-dp-ease);
}

.md-dp__input-wrap:focus-within {
  border-color: rgba(74, 109, 146, 0.45);
  box-shadow: 0 0 0 3px rgba(74, 109, 146, 0.12);
}

.md-dp__input {
  flex: 1 1 auto;
  width: 100%;
  min-width: 0;
  border: 0;
  padding: 10px 12px;
  font-family: var(--md-dp-font);
  font-size: 15px;
  font-weight: 500;
  color: var(--md-dp-text);
  background: transparent;
  outline: none;
  -moz-appearance: textfield;
}

.md-dp__input::-webkit-outer-spin-button,
.md-dp__input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.md-dp__unit {
  display: inline-flex;
  align-items: center;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--md-dp-muted);
  background: var(--md-dp-accent-soft);
  border-left: 1px solid var(--md-dp-border);
}

.md-dp__messages {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.md-dp__notices,
.md-dp__warnings {
  margin: 0;
  padding: 10px 12px;
  border-radius: var(--md-dp-radius);
  font-size: 13px;
  line-height: 1.45;
}

.md-dp__notices {
  color: var(--md-dp-info-text);
  background: var(--md-dp-info-bg);
}

.md-dp-layout-pieces {
  position: relative;
  margin: 14px 0 0;
  padding: 16px 16px 14px;
  overflow: hidden;
  border-radius: var(--md-dp-radius, 8px);
  border: 2px solid rgba(74, 109, 146, 0.45);
  background: linear-gradient(135deg, #e8f4ff 0%, #f0f7ff 48%, #e3f0fa 100%);
  box-shadow: 0 8px 24px rgba(74, 109, 146, 0.14);
  opacity: 0;
  transform: translateY(8px) scale(0.98);
  transition:
    opacity 0.45s var(--md-dp-ease, ease),
    transform 0.45s var(--md-dp-ease, ease);
}

.md-dp-layout-pieces.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
}

.md-dp-layout-pieces__pulse {
  position: absolute;
  inset: -40% -20%;
  background: radial-gradient(circle at 30% 40%, rgba(74, 109, 146, 0.18), transparent 62%);
  animation: md-dp-layout-pulse 2.8s ease-in-out infinite;
  pointer-events: none;
}

.md-dp-layout-pieces__eyebrow {
  position: relative;
  margin: 0 0 8px;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--md-dp-accent, #4a6d92);
}

.md-dp-layout-pieces__count {
  position: relative;
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin: 0 0 8px;
  line-height: 1;
}

.md-dp-layout-pieces__num {
  display: inline-block;
  transform-origin: center center;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: clamp(36px, 7vw, 48px);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #2f5578;
  animation:
    md-dp-layout-pop-in 0.62s cubic-bezier(0.34, 1.56, 0.64, 1) both,
    md-dp-layout-num-breathe 3.8s ease-in-out 0.62s infinite;
}

.md-dp-layout-pieces__unit {
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 18px;
  font-weight: 700;
  color: #3d5f82;
}

.md-dp-layout-pieces__text {
  position: relative;
  margin: 0;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 13px;
  line-height: 1.5;
  color: #3a5368;
}

.md-dp-layout-pieces__per-unit {
  position: relative;
  margin: 0 0 6px;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 14px;
  font-weight: 600;
  line-height: 1.35;
  color: #2f5578;
  letter-spacing: 0.01em;
}

.md-dp-printed-strip-tip {
  margin: 10px 0 0;
  padding: 10px 12px;
  border: 1px solid rgba(47, 85, 120, 0.28);
  border-radius: 8px;
  background: linear-gradient(135deg, #f3f8fc 0%, #eef5fa 100%);
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 13px;
  font-weight: 600;
  line-height: 1.45;
  color: #2f5578;
}

.md-dp-printed-strip-tip.is-preview {
  border-style: dashed;
  color: #4a6278;
  font-weight: 600;
}

.md-dp__pricing-mode {
  margin: 0 0 8px;
  font-family: var(--md-dp-font, var(--md-pd-font));
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.md-dp__pricing-mode.is-cut {
  color: #4a6278;
}

.md-dp__pricing-mode.is-printed {
  color: #2f5578;
}

.md-dp-printed-strip-tip[hidden] {
  display: none !important;
}

@keyframes md-dp-layout-pulse {
  0%,
  100% {
    opacity: 0.55;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.06);
  }
}

@keyframes md-dp-layout-pop-in {
  0% {
    opacity: 0;
    transform: scale(0.72);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes md-dp-layout-num-breathe {
  0%,
  100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.09);
  }
}

/* DTF (A3 ív) – enyhén melegebb accent, ugyanaz az animáció */
.md-dp-layout-pieces--a3 {
  border-color: rgba(92, 118, 88, 0.42);
  background: linear-gradient(135deg, #edf6eb 0%, #f4faf2 48%, #e6f0e4 100%);
  box-shadow: 0 8px 24px rgba(92, 118, 88, 0.12);
}

.md-dp-layout-pieces--a3 .md-dp-layout-pieces__pulse {
  background: radial-gradient(circle at 30% 40%, rgba(92, 118, 88, 0.16), transparent 62%);
}

.md-dp-layout-pieces--a3 .md-dp-layout-pieces__eyebrow {
  color: #4a6b47;
}

.md-dp-layout-pieces--a3 .md-dp-layout-pieces__num {
  color: #3d5c3a;
}

.md-dp-layout-pieces--a3 .md-dp-layout-pieces__unit {
  color: #4a6b47;
}

.md-dp-layout-pieces--a3 .md-dp-layout-pieces__text {
  color: #3f5640;
}

@media (prefers-reduced-motion: reduce) {
  .md-dp-layout-pieces,
  .md-dp-layout-pieces__pulse,
  .md-dp-layout-pieces__num {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }

  .md-dp-layout-pieces.is-visible {
    opacity: 1;
  }
}

.md-dp__warnings {
  color: var(--md-dp-warn-text);
  background: var(--md-dp-warn-bg);
}

.md-dp__result {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--md-dp-border);
}

.md-dp__price-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.md-dp__price-label {
  font-size: 13px;
  color: var(--md-dp-muted);
}

.md-dp__price {
  font-size: clamp(20px, 3vw, 24px);
  font-weight: 600;
  color: var(--md-dp-text);
  letter-spacing: -0.02em;
}

.md-dp__price.md-dp__price--discounted {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
}

.md-dp__delta,
.md-dp__volume,
.md-dp__status {
  margin: 8px 0 0;
  font-size: 12px;
  line-height: 1.4;
  color: var(--md-dp-muted);
}

.md-dp__wait {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: var(--md-dp-accent-soft);
  color: var(--md-dp-accent);
  font-size: 13px;
  font-weight: 500;
  font-style: normal;
  animation: mdDpWaitIn 0.28s var(--md-dp-ease) both;
}

.md-dp__wait-spinner {
  width: 16px;
  height: 16px;
  border: 2px solid rgba(74, 109, 146, 0.22);
  border-top-color: var(--md-dp-accent);
  border-radius: 50%;
  flex-shrink: 0;
  animation: mdDpSpin 0.75s linear infinite;
}

.md-dp__wait-text {
  letter-spacing: 0.01em;
}

@keyframes mdDpSpin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes mdDpWaitIn {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.md-dp.is-pending .md-dp__card {
  border-color: rgba(74, 109, 146, 0.18);
}

.md-dp.is-waiting .md-dp__card {
  animation: mdDpCardPulse 1.4s ease-in-out infinite;
}

@keyframes mdDpCardPulse {
  0%,
  100% {
    box-shadow: none;
  }
  50% {
    box-shadow: 0 0 0 3px rgba(74, 109, 146, 0.1);
  }
}

.md-dp.is-busy .md-dp__input-wrap,
.md-dp.is-pending .md-dp__input-wrap {
  opacity: 0.78;
}

.md-dp.is-busy .md-dp__result .md-dp__price,
.md-dp.is-pending .md-dp__result .md-dp__price {
  opacity: 0.55;
}

.md-dp__wait--global {
  margin-top: 8px;
}

.md-dp-global-price-wait {
  margin-top: 10px;
}

.j2store-single-product.detail .product-price-container .sale-price.is-md-dp-waiting {
  opacity: 0.55;
  transition: opacity 0.25s var(--md-dp-ease);
}

.j2store-single-product.detail .product-price-container.is-md-dp-price-waiting {
  animation: mdDpCardPulse 1.4s ease-in-out infinite;
}

.md-dp__volume {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--md-dp-accent-soft);
  color: var(--md-dp-muted);
  font-weight: 500;
  font-size: 12px;
}

.md-dp__volume.is-applied {
  color: var(--md-dp-accent);
  background: #e3edf7;
  font-weight: 600;
}

.md-dp__status {
  font-style: normal;
}

.j2store-single-product.detail .sale-price.is-md-dp-price,
.j2store-single-product.detail .md-pd-cart-price__amount.is-md-dp-price {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 8px;
  transition: color 0.25s var(--md-dp-ease);
}

.j2store-single-product.detail .sale-price .md-dp-sale-price--was,
.j2store-single-product.detail .md-pd-cart-price__amount .md-dp-sale-price--was {
  font-size: 0.72em;
  font-weight: 400;
  color: var(--md-pd-strike, #7a8796) !important;
  text-decoration: line-through;
  opacity: 0.9;
}

.md-dp__price .md-dp-panel-price--was,
.md-dp__price s.md-dp-panel-price--was {
  font-size: 0.85em;
  font-weight: 400;
  color: var(--md-pd-strike, #7a8796) !important;
  text-decoration: line-through !important;
  -webkit-text-decoration: line-through !important;
  text-decoration-thickness: 1px;
  margin-right: 2px;
}

.md-dp__price .md-dp-panel-price--now {
  font-weight: 600;
}

@media (max-width: 575.98px) {
  .md-dp__grid {
    grid-template-columns: 1fr;
  }

  .md-dp__card {
    padding: 16px 14px 14px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .md-dp.is-visible {
    animation: none;
  }

  .md-dp.is-waiting .md-dp__card {
    animation: none;
    box-shadow: 0 0 0 2px rgba(74, 109, 146, 0.12);
  }

  .j2store-single-product.detail .product-price-container.is-md-dp-price-waiting {
    animation: none;
    box-shadow: 0 0 0 2px rgba(74, 109, 146, 0.12);
  }

  .md-dp__wait-spinner {
    animation: none;
    border-top-color: var(--md-dp-accent);
    opacity: 0.85;
  }

  .md-dp__wait {
    animation: none;
  }

  .md-dp__input-wrap,
  .j2store-single-product.detail .sale-price.is-md-dp-price {
    transition: none;
  }
}

.md-dp.is-note-only .md-dp__result,
.md-dp.is-note-only .md-dp__status,
.md-dp.is-note-only .md-dp__messages {
  display: none !important;
}

.md-dp__shape-row,
.md-dp__pack-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 12px;
}

.md-dp__shape-option {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border: 1px solid var(--md-dp-border);
  border-radius: 999px;
  background: #fff;
  font-size: 13px;
  cursor: pointer;
}

.md-dp__shape-option input {
  margin: 0;
}

.md-dp__hint--sub {
  margin-top: 6px;
  font-size: 12px;
}

.md-dp__toolbar--shape {
  display: block;
  width: 100%;
  margin: 0 0 12px;
}

.md-dp__circle-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  font-size: 13px;
  color: var(--md-dp-text);
  cursor: pointer;
}

.md-dp__circle-toggle input[type='checkbox'] {
  width: 18px;
  height: 18px;
  margin: 0;
  accent-color: var(--md-dp-accent, #4a6d92);
  cursor: pointer;
  flex-shrink: 0;
}

.md-dp__pack-row {
  flex-direction: column;
  align-items: flex-start;
  margin-top: 4px;
}

.md-dp--resin .md-dp__unit {
  min-width: 42px;
  justify-content: center;
}

.md-dp--shape-circle .md-dp__grid {
  grid-template-columns: 1fr;
}
