/* YITH WAPO - CSS Variable Aliases */
:root {
  --wapo-accent: var(--yith-wapo-accent-color-color, #06bfb3);
  --wapo-border: var(--yith-wapo-form-border-color-color, #e0e0e0);
  --wapo-radius: var(--yith-wapo-border-radius, 12px);
  --wapo-radius-sm: var(--yith-wapo-border-radius-sm, 8px);
  --wapo-checkbox-radius: var(--yith-wapo-checkbox-style, 4px);
  --wapo-bg: var(--yith-wapo-block-background-color, transparent);
  --wapo-card-bg: var(--yith-wapo-card-background, #ffffff);
  --wapo-card-hover: var(--yith-wapo-card-hover-background, #f8f8f8);
  --wapo-card-selected: var(--yith-wapo-card-selected-background, #f0f7ff);
  --wapo-text: var(--yith-wapo-text-color, #1a1a1a);
  --wapo-text-muted: var(--yith-wapo-text-secondary-color, #6b7280);
  --wapo-price-text: var(--yith-wapo-price-text-color, #6b7280);
  --wapo-desc-font-size: var(--yith-wapo-description-font-size, 12px);
  --wapo-required-color: var(--yith-wapo-required-option-color, #dc2626);
  --wapo-gap: var(--yith-wapo-options-gap, 10px);
  --wapo-desc-text: var(--yith-wapo-text-secondary-color, #6b7280);
  --wapo-price: var(--yith-wapo-price-text-color, #6b7280);
  --wapo-label-font-size: var(--yith-wapo-label-font-size, 15px);
  --wapo-tooltip-bg: var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  --wapo-tooltip-text: var(--yith-wapo-tooltip-colors-text, #ffffff);
  --wapo-swatch-size: var(--yith-wapo-color-swatch-size, 40px);
  --wapo-swatch-radius: var(--yith-wapo-color-swatch-style, 50%);
  --wapo-pricebox-text: var(--yith-wapo-price-box-colors-text, #1a1a1a);
  --wapo-pricebox-bg: var(--yith-wapo-price-box-colors-background, transparent);
  --wapo-ease: 0.2s ease;
  --wapo-shadow: 0 1px 3px rgba(0,0,0,0.06);
  --wapo-shadow-hover: 0 4px 12px rgba(0,0,0,0.08);
}
/* ============================================================
   YITH WAPO - MODERN FRONTEND CSS v2.0
   Card-based design, clean accordions, transparent backgrounds
   ============================================================ */

form.cart:has(#yith-wapo-container .yith-wapo-block),
:is(.woocommerce div.product .elementor-widget-woocommerce-product-add-to-cart) form.cart.variations_form .woocommerce-variation-add-to-cart {
  display: block !important;
}
.yith-wapo-block *, .yith-wapo-block *:before, .yith-wapo-block *:after { box-sizing: border-box; }

/* === CSS VARIABLES === */
#yith-wapo-container.yith-wapo-container {
  --wapo-radius: var(--yith-wapo-border-radius, 12px);
  --wapo-radius-sm: var(--yith-wapo-border-radius-sm, 8px);
  --wapo-gap: var(--yith-wapo-options-gap, 10px);
  --wapo-accent: var(--yith-wapo-accent-color-color, #06bfb3);
  --wapo-border: var(--yith-wapo-form-border-color-color, #e0e0e0);
  --wapo-bg: var(--yith-wapo-block-background-color, transparent);
  --wapo-card-bg: var(--yith-wapo-card-background, #ffffff);
  --wapo-card-hover: var(--yith-wapo-card-hover-background, #f8f8f8);
  --wapo-card-selected: var(--yith-wapo-card-selected-background, #f0f7ff);
  --wapo-text: var(--yith-wapo-text-color, #1a1a1a);
  --wapo-text-muted: var(--yith-wapo-text-secondary-color, #6b7280);
  --wapo-price: var(--yith-wapo-price-text-color, #6b7280);
  --wapo-ease: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  --wapo-shadow: 0 1px 3px rgba(0,0,0,0.04);
  --wapo-shadow-hover: 0 4px 12px rgba(0,0,0,0.08);
  font-family: inherit;
  color: var(--wapo-text);
}

/* === BLOCK === */
#yith-wapo-container .yith-wapo-block {
  padding: var(--yith-wapo-block-padding, 0);
  background-color: var(--wapo-bg);
  border-radius: var(--wapo-radius);
}

/* === ADDON SECTIONS === */
.yith-wapo-block .yith-wapo-addon {
  border-bottom: 1px solid var(--wapo-border);
  padding: 0; margin: 0 !important;
}
.yith-wapo-block .yith-wapo-addon:last-child { border-bottom: none; }
.yith-wapo-block .yith-wapo-addon.empty-title { margin-top: 0 !important; padding-top: 16px; }
.yith-wapo-block .yith-wapo-addon:not(:first-child):not(.empty-title):not(.toggle-open) { margin-top: 0; }
.yith-wapo-block .yith-wapo-addon:not(:first-child):not(.empty-title).wapo-toggle.toggle-closed { margin-top: 0; }
.yith-wapo-block .yith-wapo-addon:after { content: ''; display: block; clear: both; }

/* === HEADER === */
.yith-wapo-block .yith-wapo-addon .addon-header {
  display: flex; align-items: center; column-gap: 10px; padding: 18px 4px;
}
.yith-wapo-block .yith-wapo-addon .addon-header .title-image { max-width: 40px; padding: 0; }
.yith-wapo-block .yith-wapo-addon .addon-header .title-image img { border-radius: 6px; }

/* === TITLES === */
.yith-wapo-block .yith-wapo-addon .wapo-block-title,
.yith-wapo-block .yith-wapo-addon .wapo-addon-title {
  margin: 0; clear: none; font-size: 18px; font-weight: 700;
  letter-spacing: -0.01em; color: var(--wapo-text); line-height: 1.3;
}
.yith-wapo-block .yith-wapo-addon .wapo-addon-title span.required {
  color: var(--yith-wapo-required-option-color, #dc2626); margin-left: 2px;
}

/* === TOGGLE/ACCORDION === */
.yith-wapo-block .yith-wapo-addon.wapo-toggle { width: auto; }
.yith-wapo-block .yith-wapo-addon:not(.empty-title).wapo-toggle .wapo-addon-title {
  display: flex; flex: 0 0 100%; align-items: center; justify-content: space-between;
  column-gap: 10px; margin-bottom: 0; flex-direction: row;
}
.yith-wapo-block .yith-wapo-addon.wapo-toggle .addon-header {
  cursor: pointer; padding: 18px 4px; transition: background-color var(--wapo-ease);
  border-radius: var(--wapo-radius-sm); flex: 1;
}
.yith-wapo-block .yith-wapo-addon.wapo-toggle .addon-header:hover { background-color: var(--wapo-card-hover); }
.yith-wapo-block .yith-wapo-addon.wapo-toggle:not(:last-child) { margin-bottom: 0; }
.yith-wapo-block .yith-wapo-addon.wapo-toggle.toggle-open:not(:last-child) { margin-bottom: 0; }
.yith-wapo-block .yith-wapo-addon.wapo-toggle .options-container.default-closed { display: none; }
.yith-wapo-block .yith-wapo-addon.wapo-toggle .options-container.default-open { display: block; }

/* Chevron SVG — replaces old dashicons */
.yith-wapo-block .yith-wapo-addon.wapo-toggle .wapo-addon-title:before { content: ''; display: none; }
.yith-wapo-block .yith-wapo-addon.wapo-toggle .wapo-addon-title:after {
  content: ''; display: inline-block; width: 20px; height: 20px; min-width: 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-size: contain; background-repeat: no-repeat;
  transition: transform var(--wapo-ease); margin-left: auto; order: 99;
}
.yith-wapo-block .yith-wapo-addon.wapo-toggle .wapo-addon-title.toggle-open:before { content: ''; display: none; }
.yith-wapo-block .yith-wapo-addon.wapo-toggle .wapo-addon-title.toggle-open:after { transform: rotate(180deg); }

/* === OPTIONS CONTAINER === */
.yith-wapo-block .yith-wapo-addon .options-container { padding: 0 4px 20px 4px; }
.yith-wapo-block .yith-wapo-addon .wapo-addon-description {
  font-size: 14px; color: var(--wapo-text-muted); margin: 0 0 12px 0; line-height: 1.5;
}

/* === GRID === */
.yith-wapo-block .yith-wapo-addon .options { display: grid; gap: var(--wapo-gap); }
.yith-wapo-block .yith-wapo-addon .options.per-row-1 { grid-template-columns: 1fr; row-gap: 8px; }
.yith-wapo-block .yith-wapo-addon .options.per-row-2 { grid-template-columns: repeat(2, 1fr); }
.yith-wapo-block .yith-wapo-addon .options.per-row-3 { grid-template-columns: repeat(3, 1fr); }
.yith-wapo-block .yith-wapo-addon .options.per-row-4 { grid-template-columns: repeat(4, 1fr); }
.yith-wapo-block .yith-wapo-addon .options.per-row-5 { grid-template-columns: repeat(5, 1fr); }
.yith-wapo-block .yith-wapo-addon .options.per-row-6 { grid-template-columns: repeat(6, 1fr); }

/* === OPTION BASE === */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option { word-break: normal; position: relative; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option label,
.yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label { word-break: normal; margin: 0; cursor: pointer; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option small del { opacity: 0.5; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .description {
  font-size: 12px; word-break: break-word; color: var(--wapo-text-muted); margin-top: 4px;
}

/* ============================================================
   CARD-STYLE RADIO & CHECKBOX
   ============================================================ */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option { line-height: 1.4; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .label,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option .label,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option div.label,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option div.label { display: flex; align-items: center; }

/* Card mode (custom style) */
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option {
  background: var(--wapo-card-bg); border: 1.5px solid var(--wapo-border);
  border-radius: var(--wapo-radius); padding: 14px 18px;
  transition: all var(--wapo-ease); cursor: pointer; box-shadow: var(--wapo-shadow);
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option:hover,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option:hover {
  border-color: var(--wapo-accent); background: var(--wapo-card-hover); box-shadow: var(--wapo-shadow-hover);
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option.selected,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option.selected {
  border-color: var(--wapo-accent); background: var(--wapo-card-selected);
  box-shadow: 0 0 0 1px var(--wapo-accent), var(--wapo-shadow);
}

/* Custom radio */
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.radiobutton {
  width: 20px; height: 20px; position: relative; display: block; float: left; margin-right: 10px; flex-shrink: 0;
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.radiobutton input[type="radio"] {
  width: 20px; height: 20px; opacity: 0; position: absolute; top: 0; left: 0; cursor: pointer;
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.radiobutton:before {
  content: ''; background: #fff; background-clip: content-box;
  width: 20px; height: 20px; border: 2px solid var(--wapo-border);
  border-radius: 100%; padding: 3px; display: inline-block; float: left; cursor: pointer;
  transition: all var(--wapo-ease);
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.radiobutton.checked:before {
  border-color: var(--wapo-accent); background-color: var(--wapo-accent); background-clip: content-box !important;
}

/* Custom checkbox */
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.checkboxbutton {
  width: 20px; height: 20px; position: relative; display: block; float: left; margin-right: 10px; flex-shrink: 0;
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.checkboxbutton input[type="checkbox"] {
  width: 20px; height: 20px; opacity: 0; position: absolute; top: 0; left: 0; cursor: pointer;
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.checkboxbutton:before {
  content: ''; background: #fff; width: 20px; height: 20px;
  border: 2px solid var(--wapo-border); border-radius: var(--yith-wapo-checkbox-style, 6px);
  text-align: center; display: inline-block; cursor: pointer; transition: all var(--wapo-ease);
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon span.checkboxbutton.checked:before {
  background-image: url(../img/check.svg) !important; background-size: 65%;
  background-repeat: no-repeat !important; background-color: var(--wapo-accent);
  border-color: var(--wapo-accent); color: #fff; background-position: center;
}

/* Containers */
.yith-wapo-addon.yith-wapo-addon-type-checkbox .checkbox-button-container { display: flex; }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon .yith-wapo-option .radio-button-container,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon .yith-wapo-option .checkbox-button-container {
  display: flex; align-items: center; width: 100%;
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-checkbox .yith-wapo-option input { margin-right: 10px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option input { margin-top: 0; }
.yith-wapo-addon-type-checkbox .options .yith-wapo-option .yith-wapo-addon-label { margin-left: 5px; }

/* Labels */
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label label,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon .yith-wapo-option .yith-wapo-label,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon .yith-wapo-option .yith-wapo-addon-label {
  font-size: var(--yith-wapo-label-font-size, 15px); font-weight: 600; color: var(--wapo-text);
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px; line-height: 1.4;
}
.yith-wapo-block .yith-wapo-addon .yith-wapo-option small.option-price {
  font-size: 13px; font-weight: 500; color: var(--wapo-price); white-space: nowrap;
}
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon .yith-wapo-option .description {
  font-size: var(--yith-wapo-description-font-size, 12px); overflow-y: auto; max-height: 70px;
}

/* Image positions */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label.position-above .option-container,
.yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label.position-under .option-container { display: flex; flex-direction: column; gap: 5px; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label.position-right .option-container,
.yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label.position-left .option-container { display: flex; align-items: center; flex-direction: row; gap: 10px; width: 100%; }

/* Radio images */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image { display: inline-block; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-left { display: block; float: left; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-left img { width: auto; height: 20px; margin-right: 10px; display: block; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-right { margin-left: 0; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-right img { width: auto; height: 20px; margin-left: 10px; display: block; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-above { display: block; margin-bottom: 5px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-above img { width: auto; max-height: 100px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-under { display: block; margin-top: 5px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-radio .yith-wapo-option .image.position-under img { width: auto; max-height: 100px; }

/* Tooltips */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip { display: none; position: absolute; left: 0; bottom: 100%; margin-bottom: 8px; width: auto; max-width: 250px; z-index: 100; pointer-events: none; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip img { display: inline-block; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip span {
  background-color: var(--yith-wapo-tooltip-colors-background, #1a1a1a); color: var(--yith-wapo-tooltip-colors-text, #fff);
  padding: 8px 14px; font-size: 12px; border-radius: 8px; position: absolute; left: 50%; bottom: 100%;
  transform: translateX(-50%) translateY(-5px); display: none; white-space: nowrap; box-shadow: 0 4px 12px rgba(0,0,0,0.15);
}
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip span:after {
  content: ''; width: 0; height: 0; border-left: 6px solid transparent; border-right: 6px solid transparent;
  border-top: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  margin-left: -6px; display: block; position: absolute; left: 50%; bottom: -6px;
}
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-bottom { margin: 7px 0 0 0; top: 100%; bottom: auto; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-bottom span { bottom: auto; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-bottom span:after {
  border-top: 0; border-bottom: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a); top: -6px; bottom: auto;
}
.yith-wapo-block .yith-wapo-addon .yith-wapo-option:hover .tooltip { display: block; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip span { display: block; transform: translateX(-50%) translateY(0); }

/* ============================================================
   COLOR, LABEL, SELECT, DATE, TEXT, TEXTAREA, COLORPICKER, NUMBER, PRODUCT, FILE
   All remaining addons - keeping full compatibility
   ============================================================ */

/* COLOR */
.yith-wapo-block .yith-wapo-addon-type-color .yith-wapo-option { margin: 0 5px 5px 0; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label { position: relative; margin-bottom: 10px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label .color-container { width: fit-content; display: flex; flex-direction: column; align-items: center; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label .color-container small { text-align: center; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label span.color {
  width: var(--yith-wapo-color-swatch-size, 40px); height: var(--yith-wapo-color-swatch-size, 40px);
  border-radius: var(--yith-wapo-color-swatch-style, 50%); border: 2px solid var(--wapo-border);
  position: relative; display: flex; justify-content: center; transition: all var(--wapo-ease);
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option:not(.rounded) div.label span.color { align-items: center; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label span.color img { border-radius: var(--yith-wapo-color-swatch-style, 50%); width: 100%; height: 100%; object-fit: cover; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label:hover span.color { border-color: var(--wapo-accent); transform: scale(1.08); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option.selected div.label span.color { border-color: var(--wapo-accent); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option.selected span.color:after, .select_box .select_option.selected:after {
  content: ''; width: 18px; height: 18px; background: var(--wapo-accent) url('../img/icon-check.png') center no-repeat; background-size: 50%;
  border-radius: 50%; display: block; position: absolute; top: -6px; right: -6px;
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option * { max-width: 100%; }
.yith-wapo-container .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label span.color { width: var(--yith-wapo-color-swatch-size, 40px); height: var(--yith-wapo-color-swatch-size, 40px); }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option div.label:hover span.color,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option.selected div.label span.color { border: 2px solid var(--wapo-accent); }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-color .yith-wapo-option.selected span.color:after { background: var(--wapo-accent) url('../img/icon-check.png') center no-repeat; background-size: 50%; }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option.selected div.label .label-container-display:after,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.selected div.label::after { background-color: var(--wapo-accent); }

/* LABEL */
.yith-wapo-block .yith-wapo-addon .options.per-row-1 .yith-wapo-option .label_container .image img { max-width: 150px; max-height: 150px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option div.label { position: relative; display: flex; flex-direction: column; justify-content: center; height: 100%; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option div.label .label-container-display {
  border-radius: var(--wapo-radius); border: 1.5px solid var(--wapo-border); padding: 14px; height: 100%;
  transition: all var(--wapo-ease); background: var(--wapo-card-bg); box-shadow: var(--wapo-shadow);
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option.selected div.label .label-container-display {
  border-color: var(--wapo-accent); background: var(--wapo-card-selected); box-shadow: 0 0 0 1px var(--wapo-accent);
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option.selected div.label .label-container-display:after {
  content: ''; width: 22px; height: 22px; background: var(--wapo-accent) url('../img/icon-check.png') center no-repeat; background-size: 50%;
  border-radius: 50%; display: block; position: absolute; top: -8px; right: -8px; z-index: 10;
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option p { margin: 6px 0 0 0; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container { height: 100%; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container:after { content: ''; display: block; clear: both; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container .label_price { display: flex; flex-wrap: wrap; align-items: center; column-gap: 5px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container.content-align-left .label_price { justify-content: flex-start; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container.content-align-center .label_price { justify-content: center; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container.content-align-right .label_price { justify-content: flex-end; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container.content-align-left .label-container-display { display: flex; flex-direction: column; align-items: flex-start; text-align: left; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container.content-align-center .label-container-display { display: flex; flex-direction: column; align-items: center; text-align: center; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label_container.content-align-right .label-container-display { display: flex; flex-direction: column; align-items: flex-end; text-align: right; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label.position-left .label-container-display,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .label.position-right .label-container-display { display: flex; flex-direction: row; align-items: center; }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option div.label .label-container-display,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .product-container { border: 1.5px solid var(--wapo-border); }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option.selected div.label .label-container-display,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.selected .product-container { border-color: var(--wapo-accent); }

/* TEXT & TEXTAREA */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-text .yith-wapo-option .input-text-container input {
  min-width: initial; border-radius: var(--wapo-radius-sm); border: 1.5px solid var(--wapo-border);
  padding: 10px 14px; transition: border-color var(--wapo-ease);
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-text .yith-wapo-option .input-text-container input:focus { border-color: var(--wapo-accent); outline: none; box-shadow: 0 0 0 3px rgba(0,0,0,0.05); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-text .yith-wapo-option .label { margin-bottom: 10px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-textarea .yith-wapo-option .label { margin-bottom: 10px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-textarea .yith-wapo-option textarea {
  min-height: 200px; border-radius: var(--wapo-radius-sm); border: 1.5px solid var(--wapo-border);
  padding: 12px 14px; transition: border-color var(--wapo-ease);
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-textarea .yith-wapo-option textarea:focus { border-color: var(--wapo-accent); outline: none; box-shadow: 0 0 0 3px rgba(0,0,0,0.05); }

/* Date/colorpicker/text margin */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-date .yith-wapo-option .date-container,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-colorpicker .yith-wapo-option .yith-wapo-colorpicker-container,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-textarea .yith-wapo-option .textarea-container textarea,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-text .yith-wapo-option .input-text-container { margin-top: 8px; }

/* DATE */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-date .yith-wapo-option .date-container input { min-width: initial; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-date .yith-wapo-option .label { display: flex; flex-direction: column; }
#ui-datepicker-div { padding: 20px; border-radius: 12px; box-shadow: 0 8px 30px rgba(0,0,0,0.12); }
#ui-datepicker-div #wapo-datepicker-time { height: 60px; padding-top: 10px; }
#ui-datepicker-div #wapo-datepicker-time label { width: 43%; height: 40px; line-height: 40px; font-weight: bold; display: block; float: left; }
#ui-datepicker-div #wapo-datepicker-time select { width: 57%; background-color: #f7f7f7; border: 1px solid #efefef; display: block; float: left; cursor: pointer; border-radius: 6px; }
#ui-datepicker-div #wapo-datepicker-save button { width: 100%; border-radius: 8px; margin: 0; }

/* SELECT */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-select .image-container img { max-width: 200px; max-height: 200px; margin-bottom: 10px; border-radius: var(--wapo-radius-sm); }
.yith-wapo-addon.yith-wapo-addon-type-select.required-min .select2-selection.select2-selection--single { border: 1px solid var(--yith-wapo-required-option-color, #dc2626); }
#yith-wapo-container .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-select.required-min { border: inherit; border-radius: inherit; }

/* NUMBER */
.single-product div.product .summary.entry-summary form.cart .yith-wapo-block .quantity { max-width: 80px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-number.numbers-check .options.error-message { border: 1px solid var(--yith-wapo-required-option-color, #dc2626); padding: 10px; border-radius: var(--wapo-radius-sm); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-number.numbers-check .yith-wapo-numbers-error-message { color: var(--yith-wapo-required-option-color, #dc2626); }

/* PRODUCT */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-image { margin-right: 12px; max-width: 80px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-image img { display: block; border-radius: var(--wapo-radius-sm); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container {
  position: relative; display: flex; align-items: center; cursor: pointer; line-height: 1.4;
  border-radius: var(--wapo-radius); border: 1.5px solid var(--wapo-border); padding: 14px; font-size: 15px; height: 100%;
  transition: all var(--wapo-ease); background: var(--wapo-card-bg); box-shadow: var(--wapo-shadow);
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container:hover { border-color: var(--wapo-accent); box-shadow: var(--wapo-shadow-hover); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container .product-info { word-break: break-word; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container .product-info .stock-info { padding-bottom: 10px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.selected .product-container { border-color: var(--wapo-accent); background: var(--wapo-card-selected); box-shadow: 0 0 0 1px var(--wapo-accent); }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.selected .product-container:after {
  content: ''; width: 22px; height: 22px; background: var(--wapo-accent) url('../img/icon-check.png') center no-repeat; background-size: 50%;
  border-radius: 50%; display: block; position: absolute; top: -8px; right: -8px;
}
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container small.option-price { margin: 7px 0 5px; font-size: 16px; font-weight: bold; display: block; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container .sign.positive { display: none; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container .brackets { display: none; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .product-container .button { margin: 0; font-size: 15px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.out-of-stock { pointer-events: none; opacity: 0.5; color: #8b8b8b; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.out-of-stock .stock.out-of-stock { opacity: initial; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option .option-add-to-cart .quantity { display: block; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .options.per-row-1 { gap: 8px; }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .product-container:hover { border-color: var(--wapo-accent); }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option:not(.out-of-stock) label { border: 1.5px solid var(--wapo-border); border-radius: var(--wapo-radius); transition: all var(--wapo-ease); }
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option label:hover,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-product .yith-wapo-option.selected label { border-color: var(--wapo-accent); }

/* FILE UPLOAD */
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-option input.file { display: none; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-option div.label.position-under .option-container,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-option div.label.position-above .option-container { max-width: 100px; }
.yith-wapo-block .yith-wapo-addon .yith-wapo-option div.label.file-input { cursor: initial; }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-ajax-uploader { background: var(--yith-wapo-uploads-file-colors-background, #f9fafb); border: 2px dashed var(--yith-wapo-uploads-file-colors-border, #d1d5db); border-radius: var(--wapo-radius); padding: 24px; margin: 10px 0; font-size: 14px; transition: border-color var(--wapo-ease); }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-ajax-uploader:hover { border-color: var(--wapo-accent); }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-ajax-uploader .yith-wapo-ajax-uploader-container { display: flex; align-items: center; flex-wrap: wrap; column-gap: 10px; }
.yith-wapo-ajax-uploader .button { border-radius: var(--wapo-radius-sm); padding: 10px 18px; font-size: 13px; font-weight: 600; cursor: pointer; overflow: auto; transition: all var(--wapo-ease); }
.yith-wapo-ajax-uploader .link { color: var(--wapo-accent); cursor: pointer; }
.yith-wapo-uploaded-file .remove { position: relative; top: 2px; cursor: pointer; font-size: 14px; margin-bottom: 10px; }
.yith-wapo-uploaded-file-element .yith-wapo-uploaded-file-info .file-size { opacity: 0.7; }
.yith-wapo-uploaded-file-element .yith-wapo-uploaded-file-info .file-name { color: var(--wapo-text); }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-uploaded-file-element.completed span.info label:before { content: ''; display: block; width: 18px; height: 18px; background: var(--wapo-accent) url('../img/icon-check.png') center no-repeat; background-size: 50%; border-radius: 50%; z-index: 10; }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-uploaded-file-element.completed span.info .file-name { display: flex; align-items: center; column-gap: 10px; }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-loader-container { position: relative; top: 5px; }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-uploaded-file span.info { display: flex; flex-direction: column; }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-uploaded-file-info { display: flex; flex-wrap: wrap; justify-content: space-between; }
.yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-uploaded-file-element { margin-bottom: 10px; }
.yith-wapo-addon .yith-wapo-option.allow-multiple .yith-wapo-uploaded-file-element.completed { border-bottom: 1px solid #d1d1d1; }
.yith-wapo-addon.yith-wapo-addon-type-file hr.upload-separator { border-top: 1px solid var(--yith-wapo-uploads-file-colors-border); opacity: 0.6; }
.yith-wapo-addon.yith-wapo-addon-type-file img.yith-wapo-img-uploaded { margin: 10px 0; width: 45px; }
.yith-wapo-addon.yith-wapo-addon-type-file .ui-progressbar { position: relative; top: 5px; height: 10px; border: none; border-radius: 5px; overflow: hidden; }
.yith-wapo-loader.ui-progressbar .ui-progressbar-value { background-color: var(--wapo-accent); border-radius: 5px; }

/* COLORPICKER */
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container { background-color: #fff; min-width: 200px; width: auto; border: 1px solid #d9d9d9; border-radius: var(--wapo-radius-sm); padding: 7px; }
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container span.wp-picker-input-wrap.hidden { display: inline-block !important; }
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container button.wp-color-result { margin: 0 6px 3px 0; vertical-align: middle; position: relative; border-radius: 6px !important; }
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-default-custom:before { content: "\e91a"; text-indent: 0; font-family: 'yith-icon'; color: #d8d8d8; font-weight: normal; width: 15px; background: none; line-height: 30px; margin-left: 8px; }
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-default-custom { padding: 10px; }
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-default-custom.default_color:before { color: #5d5d5d; }
.yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container .wp-picker-default, .yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container .wp-picker-clear { opacity: 0; width: 25px; margin-left: -20px; padding: 0; position: absolute; z-index: 2; }
.yith-wapo-block .yith-wapo-addon-type-colorpicker input[type="text"].wp-color-picker { width: 6rem; display: initial; border: none; line-height: 3.0; }
.yith-wapo-block .yith-wapo-addon-type-colorpicker input[type="text"].wp-color-picker:focus { box-shadow: none; }
.yith-wapo-block .yith-wapo-addon-type-colorpicker span.wp-color-result-text:empty { padding: 0; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-colorpicker .yith-wapo-option div.label.position-under .option-container,
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-colorpicker .yith-wapo-option div.label.position-above .option-container { max-width: 100px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-colorpicker .yith-wapo-option div.label.position-left .yith-wapo-addon-label { margin-left: 10px; }
.yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-colorpicker .yith-wapo-option div.label.position-right .yith-wapo-addon-label { margin-right: 10px; }
.yith-wapo-block .yith-wapo-addon-type-colorpicker span.wp-picker-custom-placeholder { line-height: 3.0; font-size: 12px; }
.yith-wapo-addon .yith-wapo-option .wp-picker-container.yith-wapo-colorpicker-initialized.wp-picker-active .wp-picker-open { vertical-align: bottom; }

/* TOTAL PRICE TABLE */
#wapo-total-price-table { margin-top: 30px; color: var(--yith-wapo-price-box-colors-text, #1a1a1a); background: var(--yith-wapo-price-box-colors-background, transparent); border-radius: var(--wapo-radius); padding: 16px 0; }
#wapo-total-price-table table { width: auto; font-size: 18px; line-height: 40px; }
#wapo-total-price-table table th { padding-right: 10px; text-align: left; font-weight: 600; }

/* CART/CHECKOUT */
.woocommerce-cart-form .yith-wapo-group-title, #order_review .yith-wapo-group-title { font-size: 16px; }
tr.cart_item.yith-wapo-product-has-individual-addons td { border-bottom: none !important; }
tr.cart_item.yith-wapo-product-is-individual-addons td { padding-top: 0 !important; font-size: 0.9em; }
tr.cart_item.yith-wapo-product-as-item td { font-size: 0.9em; }
tr.cart_item.yith-wapo-product-as-item td img { transform: scale(.7); }

/* ERROR STATES */
.yith-wapo-addon .yith-wapo-option .required-error .required-message { color: var(--yith-wapo-required-option-color, #dc2626); }
.yith-wapo-block .yith-wapo-addon .min-error { font-size: 13px; margin-top: 15px; }
.yith-wapo-block .yith-wapo-addon .min-error *, .yith-wapo-addon .options-container .max-selected-error { color: var(--yith-wapo-required-option-color, #dc2626); }
.yith-wapo-block .yith-wapo-addon .wapo-error { color: var(--yith-wapo-required-option-color, #dc2626); }
.length-error-message { display: none; padding: 5px 0; color: var(--yith-wapo-required-option-color, #dc2626); word-break: break-word; }
.yith-wapo-option small.yith-wapo-error { word-break: break-word; }
.yith-wapo-addon-type-text input.length-error { border-color: #ff0000 !important; }

/* IMAGES */
.yith-wapo-addon:not(.yith-wapo-addon-type-label) .yith-wapo-option .image img { max-width: 100%; max-height: 200px; border-radius: var(--wapo-radius-sm); }

/* PROTEO THEME SUPPORT */
.theme-yith-proteo .yith-wapo-addon-type-colorpicker .wp-picker-container .button.wp-color-result { border: 1px solid #ccc; background: none; border-radius: initial; }
.theme-yith-proteo .yith-wapo-addon-type-colorpicker .wp-picker-container .button.wp-picker-clear { border: 1px solid #ccc; border-radius: initial; line-height: normal; }
.theme-yith-proteo .yith-wapo-option .yith-wapo-ajax-uploader .button { margin-bottom: 0; margin-right: 0; }
.theme-yith-proteo.single-product div.product form.cart .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-number .yith-wapo-option .input-number.quantity input,
.theme-yith-proteo.single-product div.product form.cart .yith-wapo-addon-type-product .quantity input.wapo-product-qty,
.theme-yith-proteo .single-product div.product form.cart .yith-wapo-addon-type-product .quantity input.wapo-product-qty { height: 45px; width: 70px; font-size: 1rem; }
.theme-yith-proteo #wapo-datepicker-time select { font-family: Montserrat, sans-serif; font-weight: bold; }
body.theme-yith-proteo.yith-wapo-modal-is-open { position: fixed; }
body.theme-yith-proteo.yith-wapo-modal-is-open .single-product div.product .summary.entry-summary { padding-left: 50px; }
.theme-yith-proteo .yith-wapo-edit-product-cart small { color: var(--proteo-general_link_color); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media only screen and (max-width: 768px) {
  body.theme-yith-proteo.yith-wapo-modal-is-open .single-product div.product .summary.entry-summary { padding-left: 0; }
  .yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container button.wp-color-result { vertical-align: inherit; }
  .yith-wapo-addon.yith-wapo-addon-type-file .yith-wapo-ajax-uploader-container .button { margin-top: 10px; }
  .yith-wapo-addon-type-colorpicker .yith-wapo-option .wp-picker-container { min-width: auto; }
  .yith-wapo-block .yith-wapo-addon .options.per-row-3,
  .yith-wapo-block .yith-wapo-addon .options.per-row-4,
  .yith-wapo-block .yith-wapo-addon .options.per-row-5,
  .yith-wapo-block .yith-wapo-addon .options.per-row-6 { grid-template-columns: repeat(2, 1fr); }
  .yith-wapo-block .yith-wapo-addon .addon-header { padding: 14px 4px; }
}
@media only screen and (max-width: 480px) {
  .yith-wapo-block .yith-wapo-addon .options.per-row-2,
  .yith-wapo-block .yith-wapo-addon .options.per-row-3,
  .yith-wapo-block .yith-wapo-addon .options.per-row-4,
  .yith-wapo-block .yith-wapo-addon .options.per-row-5,
  .yith-wapo-block .yith-wapo-addon .options.per-row-6 { grid-template-columns: 1fr; }
}
@media screen and (min-width: 1024px) {
  .yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option div.label .label-container-display:hover,
  .yith-wapo-block .yith-wapo-addon.yith-wapo-addon-type-label .yith-wapo-option div.label .label-container-display:hover { border-color: var(--wapo-accent); }
}

/* ==========================================
   PREMIUM ADDON TYPES - CSS
   ========================================== */

/* Color Swatch */
.yith-wapo-option-color .color-swatch-container {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
}
.yith-wapo-option-color .color-swatch {
  transition: all 0.2s ease;
  position: relative;
}
.yith-wapo-option-color .color-swatch:hover,
.yith-wapo-option-color.selected .color-swatch {
  border-color: var(--yith-wapo-accent, #06bfb3) !important;
  box-shadow: 0 0 0 2px var(--yith-wapo-accent, #06bfb3);
  transform: scale(1.1);
}
.yith-wapo-option-color.selected .color-swatch::after {
  content: '✓';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  font-size: 16px;
  font-weight: bold;
  text-shadow: 0 0 3px rgba(0,0,0,0.5);
}
.yith-wapo-option-color .color-swatch-text-label {
  font-size: 12px;
  text-align: center;
  display: block;
}

/* Color Picker */
.yith-wapo-option-colorpicker .colorpicker-container {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.yith-wapo-option-colorpicker .wp-picker-container {
  display: inline-block;
}

/* Number */
.yith-wapo-option-number .number-container {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.yith-wapo-option-number .yith-wapo-number-input {
  width: 100px;
  padding: 8px 12px;
  border: 1px solid var(--yith-wapo-border-color, #b8b6b6);
  border-radius: 4px;
  font-size: 14px;
}

/* Textarea */
.yith-wapo-option-textarea .textarea-container {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.yith-wapo-option-textarea textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid var(--yith-wapo-border-color, #b8b6b6);
  border-radius: 4px;
  font-size: 14px;
  resize: vertical;
}
.yith-wapo-option-textarea .char-counter {
  font-size: 12px;
  color: #888;
  text-align: right;
}

/* Label / Image */
.yith-wapo-option-label {
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 4px;
  padding: 0;
  transition: all 0.2s ease;
}
.yith-wapo-option-label:hover {
  border-color: var(--yith-wapo-accent, #06bfb3);
}
.yith-wapo-option-label.selected {
  border-color: var(--yith-wapo-accent, #06bfb3);
  box-shadow: 0 0 0 1px var(--yith-wapo-accent, #06bfb3);
}
.yith-wapo-option-label .label-or-image-label {
  display: block;
  border: 1px solid #ddd;
  border-radius: 4px;
  overflow: hidden;
  transition: border-color 0.2s ease;
}
.yith-wapo-option-label.selected .label-or-image-label {
  border-color: var(--yith-wapo-accent, #06bfb3);
}
.yith-wapo-addon-type-label .label-container-display {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.yith-wapo-addon-type-label .label-container-display.image-left,
.yith-wapo-addon-type-label .label.position-right .label-container-display {
  flex-direction: row;
}
.yith-wapo-addon-type-label .label.position-right .label-container-display {
  flex-direction: row-reverse;
}
.yith-wapo-option-label .label-image img {
  display: block;
  max-width: 100%;
  height: auto;
}
.yith-wapo-option-label .label-text {
  padding: 8px;
  font-size: 14px;
  display: block;
}
.yith-wapo-option-label .label-text.outside {
  padding: 6px 0 0;
  text-align: center;
}

/* Date Picker */
.yith-wapo-option-date .date-container {
  display: flex;
  flex-direction: column;
  gap: 6px;
  position: relative;
}
.yith-wapo-option-date .yith-wapo-date-input {
  width: 200px;
  padding: 8px 12px 8px 36px;
  border: 1px solid var(--yith-wapo-border-color, #b8b6b6);
  border-radius: 4px;
  font-size: 14px;
  cursor: pointer;
}
.yith-wapo-option-date .yith-wapo-date-icon {
  position: absolute;
  bottom: 8px;
  left: 10px;
  color: #888;
  font-size: 16px;
}

/* File Upload */
.yith-wapo-option-file .file-container {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.yith-wapo-option-file .yith-wapo-dropzone {
  border: 2px dashed var(--yith-wapo-border-color, #b8b6b6);
  border-radius: 8px;
  padding: 30px 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.3s ease, background-color 0.3s ease;
  background: var(--wapo-card-bg, #fafafa);
}
.yith-wapo-option-file .yith-wapo-dropzone:hover,
.yith-wapo-option-file .yith-wapo-dropzone.dragover {
  border-color: var(--yith-wapo-accent, #06bfb3);
  background: var(--wapo-card-selected, #f0faf9);
}
.yith-wapo-option-file .yith-wapo-dropzone .dashicons {
  font-size: 40px;
  width: 40px;
  height: 40px;
  color: #aaa;
  display: block;
  margin: 0 auto 10px;
}
.yith-wapo-option-file .yith-wapo-dropzone p {
  margin: 0 0 5px;
  font-size: 14px;
  color: #666;
}
.yith-wapo-option-file .yith-wapo-dropzone small {
  color: #999;
  font-size: 12px;
}
.yith-wapo-option-file .yith-wapo-upload-button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.yith-wapo-option-file .upload-info {
  font-size: 12px;
  color: #999;
}
.yith-wapo-option-file .yith-wapo-upload-progress {
  position: relative;
}
.yith-wapo-option-file .progress-bar {
  height: 6px;
  background: #eee;
  border-radius: 3px;
  overflow: hidden;
}
.yith-wapo-option-file .progress-fill {
  height: 100%;
  background: var(--yith-wapo-accent, #06bfb3);
  width: 0;
  transition: width 0.3s ease;
  border-radius: 3px;
}
.yith-wapo-option-file .progress-text {
  font-size: 12px;
  color: #666;
}
.yith-wapo-option-file .yith-wapo-uploaded-files {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.yith-wapo-option-file .uploaded-file-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: var(--wapo-card-bg, #f5f5f5);
  border-radius: 4px;
  font-size: 13px;
}
.yith-wapo-option-file .uploaded-file-item .remove-file {
  color: var(--wapo-required-color, #dc2626);
  cursor: pointer;
  font-weight: bold;
  margin-left: auto;
}

/* Product Addon */
.yith-wapo-option-product .product-addon-container {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 12px;
  border: 1px solid #eee;
  border-radius: 6px;
  background: #fff;
  transition: border-color 0.2s ease;
}
.yith-wapo-option-product.selected .product-addon-container {
  border-color: var(--yith-wapo-accent, #06bfb3);
  background: var(--wapo-card-hover, #f8fdfc);
}
.yith-wapo-option-product.out-of-stock .product-addon-container {
  opacity: 0.5;
}
.yith-wapo-option-product .product-addon-image {
  flex: 0 0 80px;
}
.yith-wapo-option-product .product-addon-image img {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 4px;
}
.yith-wapo-option-product .product-addon-info {
  flex: 1;
}
.yith-wapo-option-product .product-addon-name {
  font-weight: 600;
  font-size: 14px;
  margin-bottom: 4px;
}
.yith-wapo-option-product .product-addon-price {
  font-size: 14px;
  font-weight: 500;
  color: var(--yith-wapo-accent, #06bfb3);
}
.yith-wapo-option-product .product-addon-sku {
  color: #999;
  font-size: 12px;
  display: block;
}
.yith-wapo-option-product .product-addon-stock {
  font-size: 12px;
}
.yith-wapo-option-product .product-addon-stock.instock { color: #7ad03a; }
.yith-wapo-option-product .product-addon-stock.outofstock { color: #a44; }
.yith-wapo-option-product .product-addon-actions {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.yith-wapo-option-product .wapo-product-qty {
  width: 60px;
  padding: 4px 8px;
  text-align: center;
  border: 1px solid #ddd;
  border-radius: 4px;
}
.yith-wapo-option-product .add-to-cart-btn {
  font-size: 11px;
  padding: 6px 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: var(--yith-wapo-accent, #06bfb3);
  color: #fff;
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

/* Edit options modal (cart) */
.yith-wapo-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
}
.yith-wapo-modal-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
}
.yith-wapo-modal-content {
  position: relative;
  background: #fff;
  border-radius: 8px;
  padding: 30px;
  max-width: 700px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 0 10px 40px rgba(0,0,0,0.2);
}
.yith-wapo-modal-close {
  position: absolute;
  top: 12px;
  right: 16px;
  font-size: 24px;
  cursor: pointer;
  color: #666;
  line-height: 1;
}
.yith-wapo-modal-close:hover {
  color: #000;
}
.yith-wapo-modal-footer {
  margin-top: 20px;
  text-align: right;
}
.yith-wapo-modal-update {
  background: var(--yith-wapo-accent, #06bfb3) !important;
  color: #fff !important;
  border: none !important;
  padding: 10px 30px !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  cursor: pointer !important;
}
.yith-wapo-edit-options-link {
  display: inline-block;
  margin-top: 5px;
  font-size: 13px;
  color: var(--yith-wapo-accent, #06bfb3);
  cursor: pointer;
  text-decoration: underline;
}
.yith-wapo-edit-product-info {
  display: flex;
  align-items: center;
  gap: 15px;
  padding-bottom: 15px;
  margin-bottom: 15px;
  border-bottom: 1px solid #eee;
}
.yith-wapo-edit-product-info img {
  width: 80px;
  height: auto;
  border-radius: 4px;
}

/* Description inside card */
.yith-wapo-addon-type-label .label-container-display .option-desc {
  margin: 6px 0 0;
  font-size: 13px;
  color: #6b7280;
  line-height: 1.4;
}
/* Label outside card */
.yith-wapo-addon-type-label .outside-label {
  margin-top: 6px;
  text-align: center;
}
.yith-wapo-addon-type-label .outside-label .label-text {
  font-weight: 600;
}
/* Image sizing inside label cards */
.yith-wapo-addon-type-label .label-container-display .image img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

/* ===== IMPROVED LABEL CARD STYLES ===== */

/* Text inside card - center it properly */
.yith-wapo-addon-type-label .label-container-display {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 60px;
}

/* Label text styling */
.yith-wapo-addon-type-label .label_price {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 5px;
  width: 100%;
}

.yith-wapo-addon-type-label .label_price .label-text {
  font-weight: 600;
  font-size: 15px;
  line-height: 1.3;
}

/* Description inside card - subtle style */
.yith-wapo-addon-type-label .label-container-display .option-desc {
  margin: 4px 0 0;
  font-size: 12px;
  color: #6b7280;
  line-height: 1.3;
  font-weight: 400;
}

/* Image in label cards - controlled sizing */
.yith-wapo-addon-type-label .label-container-display .image {
  margin-bottom: 8px;
  width: 100%;
  display: flex;
  justify-content: center;
}

.yith-wapo-addon-type-label .label-container-display .image img {
  max-width: 100%;
  height: auto;
  border-radius: 6px;
}

/* Alignment overrides */
.yith-wapo-addon-type-label .content-align-left .label-container-display {
  align-items: flex-start;
  text-align: left;
}
.yith-wapo-addon-type-label .content-align-left .label_price {
  justify-content: flex-start;
}

.yith-wapo-addon-type-label .content-align-right .label-container-display {
  align-items: flex-end;
  text-align: right;
}
.yith-wapo-addon-type-label .content-align-right .label_price {
  justify-content: flex-end;
}

/* Image position left/right - horizontal layout */
.yith-wapo-addon-type-label .label.position-left .label-container-display,
.yith-wapo-addon-type-label .label.position-right .label-container-display {
  flex-direction: row;
  gap: 12px;
  text-align: left;
  align-items: center;
}

.yith-wapo-addon-type-label .label.position-right .label-container-display {
  flex-direction: row-reverse;
}

.yith-wapo-addon-type-label .label.position-left .label-container-display .image,
.yith-wapo-addon-type-label .label.position-right .label-container-display .image {
  flex: 0 0 auto;
  width: auto;
  margin-bottom: 0;
}

.yith-wapo-addon-type-label .label.position-left .label-container-display .image img,
.yith-wapo-addon-type-label .label.position-right .label-container-display .image img {
  width: auto;
  max-height: 80px;
}

/* Outside label styling */
.yith-wapo-addon-type-label .outside-label {
  margin-top: 8px;
  text-align: center;
}

/* Responsive grid fix */
@media screen and (max-width: 600px) {
  .yith-wapo-addon .options.grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media screen and (max-width: 400px) {
  .yith-wapo-addon .options.grid {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   GLOBAL IMAGE SIZE CONTROL FOR ALL ADDON TYPES
   ============================================================ */

/* Default max image size for ALL addon types */
.yith-wapo-block .yith-wapo-addon .image-container img,
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .image img {
  max-width: 100%;
  max-height: 80px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

/* When options are in a grid, constrain images more */
.yith-wapo-block .yith-wapo-addon .options.grid .image-container img,
.yith-wapo-block .yith-wapo-addon .options.grid .yith-wapo-option .image img {
  max-height: 60px;
}

/* ============================================================
   CHECKBOX & RADIO - IMPROVED STYLING
   ============================================================ */

/* Better layout for checkbox/radio with images */
.yith-wapo-addon-type-checkbox .yith-wapo-option .label,
.yith-wapo-addon-type-radio .yith-wapo-option .label {
  display: flex;
  align-items: center;
  gap: 10px;
}

/* Image above: stack vertically */
.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-above,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-above {
  flex-direction: column;
  align-items: flex-start;
}

.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-above .image-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-above .image-container {
  margin-bottom: 6px;
}

/* Image position left */
.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-left .image-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-left .image-container {
  order: -1;
}

/* Image position right */
.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-right .image-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-right .image-container {
  order: 99;
}

/* Image container sizing */
.yith-wapo-addon-type-checkbox .image-container,
.yith-wapo-addon-type-radio .image-container {
  flex: 0 0 auto;
}

.yith-wapo-addon-type-checkbox .image-container img,
.yith-wapo-addon-type-radio .image-container img {
  max-width: 60px !important;
  max-height: 60px !important;
  border-radius: 6px;
  object-fit: cover;
}

/* Checkbox container */
.yith-wapo-addon-type-checkbox .checkbox-button-container {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ============================================================
   IMPROVED CARD STYLES FOR CUSTOM FORM STYLE
   ============================================================ */

/* Checkbox/Radio as cards when custom style */
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-addon-type-checkbox .yith-wapo-option,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-addon-type-radio .yith-wapo-option {
  border: 1.5px solid var(--yith-wapo-border-color, #e0e0e0);
  border-radius: var(--yith-wapo-border-radius, 8px);
  padding: 12px 16px;
  background: #fff;
  transition: all 0.2s ease;
  cursor: pointer;
}

.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-addon-type-checkbox .yith-wapo-option:hover,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-addon-type-radio .yith-wapo-option:hover {
  border-color: var(--yith-wapo-accent, #06bfb3);
  background: var(--wapo-card-hover, #fafffe);
}

.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-addon-type-checkbox .yith-wapo-option.selected,
.yith-wapo-container.yith-wapo-form-style-custom .yith-wapo-addon-type-radio .yith-wapo-option.selected {
  border-color: var(--yith-wapo-accent, #06bfb3);
  background: var(--wapo-card-selected, #f0faf9);
  box-shadow: 0 0 0 1px var(--yith-wapo-accent, #06bfb3);
}

/* ============================================================
   COLOR SWATCH - IMPROVED
   ============================================================ */

.yith-wapo-addon-type-color .options {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.yith-wapo-option-color {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

/* ============================================================
   NUMBER / TEXTAREA / TEXT - IMPROVED
   ============================================================ */

.yith-wapo-addon-type-number .yith-wapo-option,
.yith-wapo-addon-type-textarea .yith-wapo-option,
.yith-wapo-addon-type-text .yith-wapo-option {
  margin-bottom: 10px;
}

.yith-wapo-addon-type-number input[type="number"],
.yith-wapo-addon-type-text input[type="text"] {
  min-width: 200px;
  max-width: 100%;
}

/* ============================================================
   PRODUCT ADDON - GRID SUPPORT
   ============================================================ */

.yith-wapo-addon-type-product .options.grid .yith-wapo-option-product {
  height: 100%;
}

.yith-wapo-addon-type-product .product-addon-container {
  height: 100%;
}

.yith-wapo-addon-type-product .product-addon-image img {
  max-width: 80px;
  max-height: 80px;
  object-fit: cover;
  border-radius: 6px;
}

/* ============================================================
   TITLE & DESCRIPTION IMPROVEMENTS
   ============================================================ */

.yith-wapo-addon .wapo-addon-title {
  margin: 0 0 8px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.3;
}

.yith-wapo-addon .wapo-addon-description {
  margin: 0 0 12px;
  font-size: 13px;
  color: #6b7280;
  line-height: 1.4;
}

/* Required asterisk */
.yith-wapo-addon .required {
  color: #dc2626;
  margin-left: 2px;
}

/* ============================================================
   PRICE TABLE IMPROVEMENTS
   ============================================================ */

.yith-wapo-addon .option-price {
  font-size: 13px;
  color: #6b7280;
  margin-left: 4px;
}

.yith-wapo-addon .option-price .sign.positive { color: #059669; }
.yith-wapo-addon .option-price .sign.negative { color: #dc2626; }

/* ============================================================
   TOOLTIP IMPROVEMENTS
   ============================================================ */

/* Tooltip styles consolidated above */

/* ============================================================
   GRID LAYOUT IMPROVEMENTS
   ============================================================ */

.yith-wapo-addon .options.grid {
  gap: 10px !important;
}

.yith-wapo-addon .options.grid .yith-wapo-option {
  min-width: 0;
}

/* ============================================================
   MOBILE RESPONSIVE
   ============================================================ */

@media screen and (max-width: 768px) {
  .yith-wapo-addon .options.grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .yith-wapo-addon-type-checkbox .image-container img,
  .yith-wapo-addon-type-radio .image-container img {
    max-width: 40px !important;
    max-height: 40px !important;
  }

  .yith-wapo-addon-type-product .product-addon-container {
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 480px) {
  .yith-wapo-addon .options.grid {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   PREMIUM CHECKBOX/RADIO CUSTOM STYLING (always active)
   ============================================================ */

/* Custom checkbox appearance */
.yith-wapo-block .yith-wapo-addon span.checkboxbutton {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.yith-wapo-block .yith-wapo-addon span.checkboxbutton input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.yith-wapo-block .yith-wapo-addon span.checkboxbutton:before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--wapo-border, #d1d5db);
  border-radius: var(--wapo-checkbox-radius, 4px);
  background: #fff;
  transition: all 0.15s ease;
  margin-right: 8px;
  flex-shrink: 0;
}

.yith-wapo-block .yith-wapo-addon span.checkboxbutton.checked:before,
.yith-wapo-block .yith-wapo-addon span.checkboxbutton input[type="checkbox"]:checked + span:before {
  background: var(--wapo-accent, #06bfb3);
  border-color: var(--wapo-accent, #06bfb3);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E");
  background-size: 14px;
  background-position: center;
  background-repeat: no-repeat;
}

/* Custom radio appearance */
.yith-wapo-block .yith-wapo-addon span.radiobutton {
  position: relative;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.yith-wapo-block .yith-wapo-addon span.radiobutton input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.yith-wapo-block .yith-wapo-addon span.radiobutton:before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 20px;
  border: 2px solid var(--wapo-border, #d1d5db);
  border-radius: 50%;
  background: #fff;
  transition: all 0.15s ease;
  margin-right: 8px;
  flex-shrink: 0;
}

.yith-wapo-block .yith-wapo-addon span.radiobutton.checked:before,
.yith-wapo-block .yith-wapo-addon span.radiobutton input[type="radio"]:checked ~ span:before {
  border-color: var(--wapo-accent, #06bfb3);
  border-width: 6px;
}

/* Price display next to label */
.yith-wapo-addon .option-price,
.yith-wapo-addon .yith-wapo-option-price {
  color: var(--wapo-price-text, #6b7280);
  font-size: 14px;
  margin-left: 4px;
}

/* Positive price = green */
.yith-wapo-addon .yith-wapo-option-price .increase {
  color: #059669;
}

/* Description text */
.yith-wapo-addon .yith-wapo-option .description {
  color: var(--wapo-desc-text, #6b7280);
  font-size: var(--wapo-desc-font-size, 12px);
  margin-top: 4px;
  line-height: 1.4;
}

/* Addon title */
.yith-wapo-block .yith-wapo-addon > h3,
.yith-wapo-block .yith-wapo-addon > h4,
.yith-wapo-block .yith-wapo-addon > .wapo-addon-heading {
  font-weight: 700;
  margin-bottom: 8px;
}

/* Addon subtitle/description under title */
.yith-wapo-block .yith-wapo-addon > .wapo-addon-heading + p {
  color: #6b7280;
  font-size: 13px;
  margin: -4px 0 12px;
}

/* Required asterisk */
.yith-wapo-addon .required {
  color: var(--wapo-required-color, #dc2626) !important;
  font-weight: 700;
}

/* ============================================================
   COLORPICKER WIDGET
   ============================================================ */
.yith-wapo-colorpicker-wrapper {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 8px 12px !important;
  border: 1.5px solid var(--wapo-border, #e0e0e0) !important;
  border-radius: 8px !important;
  background: #fff !important;
}

.yith-wapo-colorpicker-wrapper .color-preview {
  width: 32px !important;
  height: 32px !important;
  border-radius: 4px !important;
  border: 1px solid #ddd !important;
  cursor: pointer !important;
}

.yith-wapo-colorpicker-wrapper input {
  border: none !important;
  font-family: monospace !important;
  font-size: 14px !important;
  width: 80px !important;
}

/* ============================================================
   DATE PICKER IMPROVEMENTS
   ============================================================ */
.yith-wapo-option-date .date-container input {
  padding: 10px 14px;
  border: 1.5px solid var(--wapo-border, #e0e0e0);
  border-radius: 8px;
  font-size: 14px;
  cursor: pointer;
}

.yith-wapo-option-date .time-picker-container select {
  padding: 8px 12px;
  border: 1.5px solid var(--wapo-border, #e0e0e0);
  border-radius: 8px;
  font-size: 14px;
}

/* ============================================================
   FILE UPLOAD DROPZONE
   ============================================================ */
.yith-wapo-upload-dropzone {
  transition: all 0.2s ease !important;
}

.yith-wapo-upload-dropzone:hover {
  border-color: var(--wapo-accent, #06bfb3) !important;
  background: #f0fffe !important;
}

.yith-wapo-upload-dropzone .button {
  background: var(--wapo-accent, #06bfb3) !important;
  color: #fff !important;
  border: none !important;
  padding: 8px 20px !important;
  border-radius: 6px !important;
  cursor: pointer !important;
}

/* ============================================================
   NUMBER INPUT STYLING
   ============================================================ */
.yith-wapo-option-number input[type="number"] {
  padding: 10px 14px;
  border: 1.5px solid var(--wapo-border, #e0e0e0);
  border-radius: 8px;
  font-size: 14px;
  min-width: 120px;
}

/* ============================================================
   TEXTAREA STYLING
   ============================================================ */
.yith-wapo-option-textarea textarea {
  padding: 12px 14px;
  border: 1.5px solid var(--wapo-border, #e0e0e0);
  border-radius: 8px;
  font-size: 14px;
  min-height: 100px;
  resize: vertical;
  width: 100%;
}

.yith-wapo-option-textarea textarea:focus {
  border-color: var(--wapo-accent, #06bfb3);
  outline: none;
  box-shadow: 0 0 0 3px rgba(6, 191, 179, 0.1);
}

.yith-wapo-option-textarea .char-counter {
  display: block;
  text-align: right;
  color: #9ca3af;
  font-size: 12px;
  margin-top: 4px;
}

/* Tooltip positioning fix - option must be relative for tooltip absolute */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option {
  position: relative;
}

/* Tooltip for label type - position correctly */
.yith-wapo-addon-type-label .yith-wapo-option .tooltip {
  left: 50%;
  transform: translateX(-50%);
  bottom: 100%;
  margin-bottom: 8px;
  white-space: nowrap;
}

.yith-wapo-addon-type-label .yith-wapo-option .tooltip span {
  display: block !important;
}

/* Fix: Label container must have width for flex children to display */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .label {
  width: 100%;
}

/* Fix: option-container must also have width */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .option-container {
  width: 100%;
}

/* Fix: Image container in flex layouts */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .image-container {
  flex-shrink: 0;
}

.yith-wapo-block .yith-wapo-addon .yith-wapo-option .image-container img {
  display: block;
  width: auto;
}


/* ============================================================
   LABEL/IMAGE CARD - POSITION LAYOUTS (FIXED)
   ============================================================ */

/* Position: ABOVE (default) - image on top, text below */
.yith-wapo-addon-type-label .label.position-above .label-container-display {
  display: flex !important;
  flex-direction: column !important;
  align-items: center;
  text-align: center;
  gap: 8px;
}

/* Position: UNDER - text on top, image below */
.yith-wapo-addon-type-label .label.position-under .label-container-display {
  display: flex !important;
  flex-direction: column !important;
  align-items: center;
  text-align: center;
  gap: 8px;
}

/* Position: LEFT - image on left, text on right */
.yith-wapo-addon-type-label .label.position-left .label-container-display {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  text-align: left;
  gap: 12px;
}

.yith-wapo-addon-type-label .label.position-left .label-container-display .image {
  flex: 0 0 auto;
  order: -1;
}

.yith-wapo-addon-type-label .label.position-left .label-container-display .label_price {
  flex: 1;
  justify-content: flex-start;
}

/* Position: RIGHT - text on left, image on right */
.yith-wapo-addon-type-label .label.position-right .label-container-display {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  text-align: left;
  gap: 12px;
}

.yith-wapo-addon-type-label .label.position-right .label-container-display .image {
  flex: 0 0 auto;
  order: 99;
}

.yith-wapo-addon-type-label .label.position-right .label-container-display .label_price {
  flex: 1;
  justify-content: flex-start;
}

/* Image inside label card - controlled size */
.yith-wapo-addon-type-label .label-container-display .image {
  display: flex;
  align-items: center;
  justify-content: center;
}

.yith-wapo-addon-type-label .label-container-display .image img {
  border-radius: 6px;
  object-fit: cover;
}

/* Description inside card */
.yith-wapo-addon-type-label .label-container-display .option-desc {
  font-size: 13px;
  color: var(--wapo-text-muted, #6b7280);
  margin: 4px 0 0;
  width: 100%;
}

/* ============================================================
   CHECKBOX/RADIO - IMAGE POSITION LAYOUTS (FIXED)
   ============================================================ */

/* Position left/right for checkbox/radio */
.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-left .option-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-left .option-container,
.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-right .option-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-right .option-container {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-left .image-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-left .image-container {
  order: -1;
  flex: 0 0 auto;
}

.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-right .image-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-right .image-container {
  order: 99;
  flex: 0 0 auto;
}

/* Position above for checkbox/radio */
.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-above .option-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-above .option-container {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start;
  gap: 8px;
}

.yith-wapo-addon-type-checkbox .yith-wapo-option .label.position-above .image-container,
.yith-wapo-addon-type-radio .yith-wapo-option .label.position-above .image-container {
  order: -1;
}

/* ============================================================
   TOOLTIP - LEFT/RIGHT POSITIONS
   ============================================================ */
.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-left {
  bottom: auto;
  top: 50%;
  transform: translateY(-50%);
  right: 100%;
  left: auto;
  margin: 0 8px 0 0;
}

.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-left span:after {
  left: auto;
  right: -6px;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  border-right: 0;
}

.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-right {
  bottom: auto;
  top: 50%;
  transform: translateY(-50%);
  left: 100%;
  right: auto;
  margin: 0 0 0 8px;
}

.yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-right span:after {
  right: auto;
  left: -6px;
  top: 50%;
  bottom: auto;
  transform: translateY(-50%);
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-right: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  border-left: 0;
}

/* ============================================================
   TOOLTIP - ALIGNMENT CONTROL
   ============================================================ */
/* Tooltip aligned left (for top/bottom positions) */
.yith-wapo-option .tooltip.align-left {
  left: 0;
  transform: none;
}
.yith-wapo-option .tooltip.align-left span:after {
  left: 20px;
}

/* Tooltip aligned right (for top/bottom positions) */
.yith-wapo-option .tooltip.align-right {
  left: auto;
  right: 0;
  transform: none;
}
.yith-wapo-option .tooltip.align-right span:after {
  left: auto;
  right: 20px;
}

/* Tooltip aligned center (default) */
.yith-wapo-option .tooltip.align-center {
  left: 50%;
  transform: translateX(-50%);
}

/* ============================================================
   DESCRIPTION - ALIGNMENT & DISPLAY CONTROL
   ============================================================ */
.yith-wapo-option .description.desc-align-left { text-align: left; }
.yith-wapo-option .description.desc-align-center { text-align: center; }
.yith-wapo-option .description.desc-align-right { text-align: right; }

.yith-wapo-option .description.desc-display-block {
  display: block;
  width: 100%;
  margin-top: 4px;
}

.yith-wapo-option .description.desc-display-inline {
  display: inline;
  margin-left: 8px;
}

/* ============================================================
   MOBILE RESPONSIVE - TOOLTIPS
   ============================================================ */
@media (max-width: 768px) {
  /* Tooltips on mobile: always show below, full width */
  .yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip {
    position: absolute;
    left: 0 !important;
    right: 0 !important;
    transform: none !important;
    max-width: 100% !important;
    width: auto !important;
    white-space: normal !important;
  }

  /* Force bottom position on mobile for readability */
  .yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-top,
  .yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-left,
  .yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip.position-right {
    bottom: auto !important;
    top: 100% !important;
    margin: 8px 0 0 0 !important;
  }

  .yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip span {
    transform: none !important;
    left: auto !important;
    position: relative !important;
    display: block !important;
    width: 100% !important;
  }

  .yith-wapo-block .yith-wapo-addon .yith-wapo-option .tooltip span:after {
    display: none !important;
  }
}

/* ============================================================
   TOOLTIP - 2-AXIS POSITIONING
   Position = which side (top/bottom/left/right)
   Align = where on that side (start/center/end)
   ============================================================ */

/* TOP + align left */
.yith-wapo-option .tooltip.position-top.align-left {
  bottom: 100%; top: auto;
  left: 0; right: auto;
  transform: none;
  margin-bottom: 8px;
}
.yith-wapo-option .tooltip.position-top.align-left span { left: 0; transform: none; }
.yith-wapo-option .tooltip.position-top.align-left span:after { left: 20px; }

/* TOP + align center */
.yith-wapo-option .tooltip.position-top.align-center {
  bottom: 100%; top: auto;
  left: 50%; right: auto;
  transform: translateX(-50%);
  margin-bottom: 8px;
}
.yith-wapo-option .tooltip.position-top.align-center span { left: 50%; transform: translateX(-50%); }
.yith-wapo-option .tooltip.position-top.align-center span:after { left: 50%; margin-left: -6px; }

/* TOP + align right */
.yith-wapo-option .tooltip.position-top.align-right {
  bottom: 100%; top: auto;
  left: auto; right: 0;
  transform: none;
  margin-bottom: 8px;
}
.yith-wapo-option .tooltip.position-top.align-right span { left: auto; right: 0; transform: none; }
.yith-wapo-option .tooltip.position-top.align-right span:after { left: auto; right: 20px; }

/* BOTTOM + align left */
.yith-wapo-option .tooltip.position-bottom.align-left {
  top: 100%; bottom: auto;
  left: 0; right: auto;
  transform: none;
  margin-top: 8px;
}
.yith-wapo-option .tooltip.position-bottom.align-left span:after {
  top: -6px; bottom: auto;
  border-top: 0; border-bottom: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  left: 20px;
}

/* BOTTOM + align center */
.yith-wapo-option .tooltip.position-bottom.align-center {
  top: 100%; bottom: auto;
  left: 50%; right: auto;
  transform: translateX(-50%);
  margin-top: 8px;
}
.yith-wapo-option .tooltip.position-bottom.align-center span:after {
  top: -6px; bottom: auto;
  border-top: 0; border-bottom: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  left: 50%; margin-left: -6px;
}

/* BOTTOM + align right */
.yith-wapo-option .tooltip.position-bottom.align-right {
  top: 100%; bottom: auto;
  left: auto; right: 0;
  transform: none;
  margin-top: 8px;
}
.yith-wapo-option .tooltip.position-bottom.align-right span:after {
  top: -6px; bottom: auto;
  border-top: 0; border-bottom: 6px solid var(--yith-wapo-tooltip-colors-background, #1a1a1a);
  left: auto; right: 20px;
}

/* LEFT + align top */
.yith-wapo-option .tooltip.position-left.align-left {
  right: 100%; left: auto; top: 0; bottom: auto;
  transform: none;
  margin-right: 8px;
}

/* LEFT + align center */
.yith-wapo-option .tooltip.position-left.align-center {
  right: 100%; left: auto; top: 50%; bottom: auto;
  transform: translateY(-50%);
  margin-right: 8px;
}

/* LEFT + align bottom */
.yith-wapo-option .tooltip.position-left.align-right {
  right: 100%; left: auto; top: auto; bottom: 0;
  transform: none;
  margin-right: 8px;
}

/* RIGHT + align top */
.yith-wapo-option .tooltip.position-right.align-left {
  left: 100%; right: auto; top: 0; bottom: auto;
  transform: none;
  margin-left: 8px;
}

/* RIGHT + align center */
.yith-wapo-option .tooltip.position-right.align-center {
  left: 100%; right: auto; top: 50%; bottom: auto;
  transform: translateY(-50%);
  margin-left: 8px;
}

/* RIGHT + align bottom */
.yith-wapo-option .tooltip.position-right.align-right {
  left: 100%; right: auto; top: auto; bottom: 0;
  transform: none;
  margin-left: 8px;
}

/* ============================================================
   QUANTITY COUNTER TYPE
   ============================================================ */
.yith-wapo-addon-type-quantity .yith-wapo-option {
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  background: transparent !important;
}

.yith-wapo-addon-type-quantity .quantity-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  border-bottom: 1px solid #f0f0f0;
  gap: 12px;
}

.yith-wapo-addon-type-quantity .quantity-row:last-child {
  border-bottom: none;
}

.yith-wapo-addon-type-quantity .qty-controls {
  display: flex;
  align-items: center;
  gap: 0;
}

.yith-wapo-addon-type-quantity .qty-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid #ddd;
  background: #f5f5f5;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #333;
  transition: all 0.15s ease;
  -webkit-appearance: none;
  appearance: none;
  padding: 0;
}

.yith-wapo-addon-type-quantity .qty-btn:hover {
  background: var(--wapo-accent, #06bfb3);
  border-color: var(--wapo-accent, #06bfb3);
  color: #fff;
}

.yith-wapo-addon-type-quantity .qty-btn:active {
  transform: scale(0.92);
}

.yith-wapo-addon-type-quantity .yith-wapo-qty-input {
  width: 40px !important;
  text-align: center;
  border: none !important;
  background: transparent !important;
  font-size: 16px;
  font-weight: 700;
  -moz-appearance: textfield;
  margin: 0 4px;
  padding: 0 !important;
}

.yith-wapo-addon-type-quantity .yith-wapo-qty-input::-webkit-outer-spin-button,
.yith-wapo-addon-type-quantity .yith-wapo-qty-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.yith-wapo-addon-type-quantity .image-container img {
  width: 45px;
  height: 45px;
  border-radius: 8px;
  object-fit: cover;
}

.yith-wapo-addon-type-quantity .qty-label-price .yith-wapo-addon-label {
  font-weight: 600;
  font-size: 15px;
  display: block;
}

.yith-wapo-addon-type-quantity .qty-label-price .option-price {
  font-size: 13px;
  color: var(--wapo-text-muted, #6b7280);
}

/* ============================================================
   NUTRITION INFO TYPE
   ============================================================ */
.yith-wapo-addon-type-nutrition {
  border: 1px solid #e5e5e5;
  border-radius: var(--wapo-radius, 12px);
  overflow: hidden;
}

.yith-wapo-addon-type-nutrition .addon-header {
  padding: 16px 16px 8px;
}

.yith-wapo-addon-type-nutrition .options {
  padding: 0 !important;
  gap: 0 !important;
}

.yith-wapo-addon-type-nutrition .yith-wapo-option {
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
}

.yith-wapo-addon-type-nutrition .nutrition-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 16px;
  border-bottom: 1px solid #eee;
  font-size: 14px;
  color: #333;
}

.yith-wapo-addon-type-nutrition .yith-wapo-option:nth-child(even) .nutrition-row {
  background: #f9f9f9;
}

.yith-wapo-addon-type-nutrition .yith-wapo-option:last-child .nutrition-row {
  border-bottom: none;
}

.yith-wapo-addon-type-nutrition .nutrition-name {
  flex: 1;
}

.yith-wapo-addon-type-nutrition .nutrition-value {
  text-align: right;
  white-space: nowrap;
  font-weight: 500;
}

/* Mobile responsive for quantity */
@media (max-width: 768px) {
  .yith-wapo-addon-type-quantity .qty-label-price .yith-wapo-addon-label {
    font-size: 14px;
  }
  
  .yith-wapo-addon-type-quantity .qty-btn {
    width: 32px;
    height: 32px;
    font-size: 18px;
  }
}
