/* --- RESET POPUP DIALOGS --- */
dialog.cv-reset-popup {
    position: fixed; 
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(1.08); 
    background-color: var(--wp--preset--color--base-2); 
    border: 1px solid var(--wp--preset--color--contrast-3);
    border-radius: 12px;
    box-shadow: 0 10px 50px rgba(0,0,0,0.3);
    width: 90%;
    max-width: 380px;
    flex-direction: column;
    z-index: 10000;
    overflow: hidden;
    opacity: 0;
    padding: 0;
    margin: 0;
    pointer-events: none;
}

dialog.cv-reset-popup:not([open]) {
    display: none;
}

dialog.cv-reset-popup[open] {
    display: flex;
}

dialog.cv-reset-popup.is-visible {
    pointer-events: auto;
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
    animation: cvZoomOutEntry 0.2s cubic-bezier(0.2, 0, 0.2, 1) forwards;
}

dialog.cv-reset-popup.is-closing {
    pointer-events: none;
    opacity: 1;
    animation: cvZoomInExit 0.2s cubic-bezier(0.2, 0, 0.2, 1) forwards;
}

@keyframes cvZoomOutEntry {
    from { opacity: 0; transform: translate(-50%, -50%) scale(1.08); }
    to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

@keyframes cvZoomInExit {
    from { opacity: 1; transform: translate(-50%, -50%) scale(1); }
    to   { opacity: 0; transform: translate(-50%, -50%) scale(1.08); }
}

dialog.cv-reset-popup::backdrop {
    background-color: rgba(0,0,0,0);
}

dialog.cv-reset-popup.is-visible::backdrop {
    animation: cvBackdropIn 0.2s forwards;
}

dialog.cv-reset-popup.is-closing::backdrop {
    animation: cvBackdropOut 0.2s forwards;
}

@keyframes cvBackdropIn {
    from { background-color: rgba(0,0,0,0); }
    to { background-color: rgba(0,0,0,0.6); }
}

@keyframes cvBackdropOut {
    from { background-color: rgba(0,0,0,0.6); }
    to { background-color: rgba(0,0,0,0); }
}

.cv-reset-content {
    padding: 24px;
}

.cv-reset-title {
    margin: 0 0 12px 0;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--wp--preset--color--contrast);
    user-select: none;
}

.cv-reset-msg {
    font-size: 0.95rem;
    color: var(--wp--preset--color--contrast);
    opacity: 0.9;
    line-height: 1.5;
    user-select: none;
}

.cv-reset-actions {
    display: flex;
    gap: 12px;
    padding: 16px 24px;
    background-color: var(--wp--preset--color--base);
    border-top: 1px solid var(--wp--preset--color--contrast-3);
}


/* --- SELECTION DROPDOWNS --- */
.centra-dropdown-wrapper { position: relative; font-family: inherit; width: 100%; max-width: 360px; }

.centra-dropdown-trigger {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 12px; border: 1px solid rgba(0,0,0,0.1); border-bottom: 1px solid rgba(0,0,0,0.3);
  border-radius: 4px; background: rgba(255,255,255,0.05); cursor: default;
  transition: background 0.1s; outline: none; min-height: 18px;
}
.centra-dropdown-trigger:hover { background: rgba(0,0,0,0.04); }
.centra-dropdown-trigger:active, .centra-dropdown-trigger:focus { background: rgba(0,0,0,0.08); border: 1px solid var(--wp--preset--color--contrast); }

html[data-theme="dark"] .centra-dropdown-trigger { border: 1px solid rgba(255,255,255,0.1); border-bottom: 1px solid rgba(255,255,255,0.3);}
html[data-theme="dark"] .centra-dropdown-trigger:hover { background: rgba(255,255,255,0.05); }
html[data-theme="dark"] .centra-dropdown-trigger:focus { border: 1px solid var(--wp--preset--color--contrast); }

.centra-dropdown-text { font-size: 14px; font-weight: 500; }
.centra-dropdown-arrow { padding-left: 8px; opacity: 0.8; transition: transform 0.2s ease; }
.centra-dropdown-menu.open + .centra-dropdown-trigger .centra-dropdown-arrow { transform: rotate(180deg); }

.centra-dropdown-menu {
  position: absolute; left: 0; top: 0; background: var(--wp--preset--color--base);
  border: 1px solid var(--wp--preset--color--contrast-3); border-radius: 4px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5); padding: 4px; min-width: 100%; width: max-content;
  max-width: 300px; max-height: 80vh; overflow-y: auto; z-index: 10000;
  display: none; opacity: 0; pointer-events: none;
  --clip-top: 50%; --clip-bottom: 50%;
  clip-path: inset(var(--clip-top) 0 var(--clip-bottom) 0 round 2px); transition: opacity 0.2s ease;
}

.centra-dropdown-menu.is-mounted { display: block; }
.centra-dropdown-menu.is-visible {
  pointer-events: auto; opacity: 1; clip-path: inset(0% 0% 0% 0% round 4px);
  transition: opacity 0.05s linear, clip-path 0.3s cubic-bezier(0.1, 0.9, 0.2, 1);
}

.centra-dropdown-trigger:focus-visible, .centra-dropdown-option:focus-visible { outline: 2px solid var(--wp--preset--color--contrast); outline-offset: -2px; }
.centra-dropdown-menu::-webkit-scrollbar { width: 4px; }
.centra-dropdown-menu::-webkit-scrollbar-thumb { background: var(--wp--preset--color--contrast-3); border-radius: 4px; }
.centra-dropdown-menu.align-right { left: auto; right: -1px; }

.centra-dropdown-option { padding: 6px 14px; margin: 2px 0; border-radius: 4px; cursor: default; display: flex; align-items: center; white-space: nowrap; font-size: 14px; }
.centra-dropdown-option:hover { background: color-mix(in srgb, var(--wp--preset--color--contrast) 4%, transparent); color: var(--wp--preset--color--contrast); }
.centra-dropdown-option.selected { background: color-mix(in srgb, var(--wp--preset--color--accent) 6%, transparent); font-weight: 600; }
.centra-dropdown-option.selected::before { content: ''; display: block; width: 4px; height: 20px; background: var(--wp--preset--color--accent); border-radius: 2px; margin-left: -14px; margin-right: 10px; }

.centra-dropdown-overlay { position: fixed; inset: 0; background: transparent; z-index: 9998; display: none; }
.centra-dropdown-overlay.active { display: block; }


/* --- RANGE SLIDERS --- */
.cv-slider-wrapper { display: flex; align-items: center; gap: 15px; max-width: 300px; padding: 10px 0; }

input[type=range].cv-slider {
  -webkit-appearance: none; 
  width: 100%; 
  background: transparent !important;
  background-image: none !important;
  cursor: pointer; 
  height: 24px; 
  position: relative; 
  border: none !important; 
  box-shadow: none !important; 
  padding: 0 !important; 
  outline: none !important;
  --thumb-size: 20px;
  --thumb-border: 5px;
  --thumb-border-hover: 3px;
  --thumb-border-drag: 6px;
  --track-height: 4px;
  --fill-color: var(--wp--preset--color--accent); 
  --base-color: var(--wp--preset--color--contrast-3, #e0e0e0);
}

input[type=range].cv-slider:focus { 
  outline: none !important; 
  background-color: transparent !important; 
  background-image: none !important;
  animation: none !important;
}

input[type=range].cv-slider:focus-visible::-webkit-slider-thumb {
  outline: 2px solid var(--wp--preset--color--contrast); outline-offset: 2px;
}
input[type=range].cv-slider:focus-visible::-moz-range-thumb {
  outline: 2px solid var(--wp--preset--color--contrast); outline-offset: 2px;
}

input[type=range].cv-slider::-webkit-slider-runnable-track {
  width: 100%; height: var(--track-height); border-radius: var(--track-height);
  background: linear-gradient(to right, var(--fill-color) 0%, var(--fill-color) var(--val), var(--base-color) var(--val), var(--base-color) 100%);
}

input[type=range].cv-slider::-webkit-slider-thumb {
  -webkit-appearance: none; 
  height: var(--thumb-size); width: var(--thumb-size); 
  border-radius: 50%;
  background: var(--fill-color); 
  border: var(--thumb-border) solid var(--wp--preset--color--base-2);
  box-sizing: border-box;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15), 0 0 0 1px rgba(0,0,0,0.05);
  margin-top: calc((var(--track-height) - var(--thumb-size)) / 2);
  transition: border-width 0.2s cubic-bezier(0.2, 0, 0, 1), transform 0.1s ease;
}

input[type=range].cv-slider:hover::-webkit-slider-thumb,
input[type=range].cv-slider:active::-webkit-slider-thumb,
input[type=range].cv-slider:focus::-webkit-slider-thumb {
  border-width: var(--thumb-border-hover); 
}

input[type=range].cv-slider:active::-webkit-slider-thumb {
  border-width: var(--thumb-border-drag); 
}

input[type=range].cv-slider::-moz-range-track { 
  width: 100%; height: var(--track-height); border-radius: var(--track-height); background: var(--base-color); 
}
input[type=range].cv-slider::-moz-range-progress { 
  background-color: var(--fill-color); height: var(--track-height); border-radius: var(--track-height); 
}
input[type=range].cv-slider::-moz-range-thumb {
  height: var(--thumb-size); width: var(--thumb-size); border-radius: 50%;
  background: var(--fill-color); 
  border: var(--thumb-border) solid var(--wp--preset--color--base-2);
  box-sizing: border-box;
  box-shadow: 0 1px 4px rgba(0,0,0,0.15), 0 0 0 1px rgba(0,0,0,0.05);
  transition: border-width 0.2s cubic-bezier(0.2, 0, 0, 1), transform 0.1s ease;
}

input[type=range].cv-slider:hover::-moz-range-thumb,
input[type=range].cv-slider:active::-moz-range-thumb,
input[type=range].cv-slider:focus::-moz-range-thumb { 
  border-width: var(--thumb-border-hover); 
}
input[type=range].cv-slider:active::-moz-range-thumb {
  border-width: var(--thumb-border-drag); 
}


/* --- TOGGLE SWITCHES & CHECKBOXES --- */
.cv-push-action { 
  display: flex; align-items: center; justify-content: flex-end; gap: 16px; font-family: inherit; width: 100%;
  cursor: pointer;
  user-select: none;
  -webkit-tap-highlight-color: transparent;
}
.cv-push-status-label { 
  font-size: 0.95rem; font-weight: 500; color: var(--wp--preset--color--contrast); min-width: 75px; text-align: right; 
}

@media screen and (max-width: 640px) {
  .cv-push-action { justify-content: space-between; }
  .cv-push-status-label { text-align: left; }
}

.cv-switch { position: relative; display: inline-block; width: 38px; height: 20px; flex-shrink: 0; }
.cv-switch input { opacity: 0; width: 0; height: 0; position: absolute; }

.cv-toggle { 
  position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; 
  box-shadow: 0px 0px 0px 1px var(--wp--preset--color--contrast-2) inset; 
  background-color: transparent; 
  transition: background-color 0.3s ease, box-shadow 0.3s ease; 
}

.cv-toggle:before { 
  position: absolute; content: ""; 
  height: 12px; width: 12px; 
  left: 4px; bottom: 4px; 
  background-color: var(--wp--preset--color--contrast-2); 
  transition: all 0.3s cubic-bezier(0.2, 0.8, 0.2, 1); 
}

.cv-switch:hover .cv-toggle:before { height: 14px; width: 14px; left: 3px; bottom: 3px; }
.cv-switch:active .cv-toggle:before { width: 20px; }

.cv-switch input:checked + .cv-toggle { background-color: var(--wp--preset--color--accent); box-shadow: none; }
.cv-switch input:focus-visible + .cv-toggle { outline: 2px solid var(--wp--preset--color--contrast); outline-offset: 2px; }

.cv-switch input:checked + .cv-toggle:before { transform: translateX(18px); background-color: var(--wp--preset--color--base-2); }
.cv-switch:active input:checked + .cv-toggle:before { transform: translateX(12px); }

.cv-push-action:hover .cv-switch input:checked + .cv-toggle {
  background-color: color-mix(in srgb, var(--wp--preset--color--accent) 85%, transparent);
}

.cv-toggle.round { border-radius: 24px; }
.cv-toggle.round:before { border-radius: 24px; }
.cv-switch input:disabled + .cv-toggle { opacity: 0.4; cursor: not-allowed; }

.cv-checkbox {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  flex-shrink: 0;
}

.cv-checkbox input { opacity: 0; width: 0; height: 0; position: absolute; }

.cv-checkmark {
  position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  background-color: transparent;
  box-shadow: 0px 0px 0px 1px var(--wp--preset--color--contrast-2) inset;
  border-radius: 4px;
  transition: all 0.2s cubic-bezier(0.2, 0.8, 0.2, 1);
  display: flex; align-items: center; justify-content: center;
}

.cv-push-action:hover .cv-checkmark {
  box-shadow: 0px 0px 0px 1px color-mix(in srgb, var(--wp--preset--color--contrast-2) 70%, var(--wp--preset--color--contrast)) inset;
}

.cv-push-action:active .cv-checkmark {
  box-shadow: 0px 0px 0px 1px color-mix(in srgb, var(--wp--preset--color--contrast-2) 40%, transparent) inset;
  background-color: color-mix(in srgb, var(--wp--preset--color--contrast-3) 10%, transparent);
}

.cv-checkmark svg {
  width: 14px; height: 14px;
  color: var(--wp--preset--color--base-2);
}

.cv-checkmark svg polyline {
  stroke-dasharray: 24; 
  stroke-dashoffset: 24; 
  transition: stroke-dashoffset 0.3s cubic-bezier(0.65, 0, 0.45, 1) 0.1s; 
}

.cv-checkbox input:checked + .cv-checkmark {
  background-color: var(--wp--preset--color--accent);
  box-shadow: none;
}

.cv-push-action:hover .cv-checkbox input:checked + .cv-checkmark {
  background-color: color-mix(in srgb, var(--wp--preset--color--accent) 85%, transparent);
}

.cv-checkbox input:checked + .cv-checkmark svg polyline {
  stroke-dashoffset: 0;
}

.cv-checkbox input:focus-visible + .cv-checkmark {
  outline: 2px solid var(--wp--preset--color--contrast);
  outline-offset: 2px;
}

.cv-checkbox input:disabled + .cv-checkmark {
  opacity: 0.4; cursor: not-allowed;
}


/* --- ACCENT COLOR PICKERS --- */
.cv-color-picker-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    width: 100%;
    padding: 4px;
}

.cv-color-swatch {
    width: 42px;
    height: 42px;
    flex-shrink: 0;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    
    outline: 2px solid transparent;
    outline-offset: 2px;
    transition: transform 0.1s ease, outline-color 0.2s ease, outline-offset 0.2s ease;
}

.cv-color-swatch:hover {
    transform: scale(0.95);
    outline: 2px solid var(--wp--preset--color--contrast-3) !important;
    outline-offset: 2px !important;
}

.cv-color-swatch:focus-visible {
    transform: scale(0.95);
    outline: 2px solid var(--wp--preset--color--contrast) !important;
    outline-offset: 4px !important; 
}

.cv-color-swatch.selected {
    transform: scale(0.85); 
    outline: 2px solid var(--wp--preset--color--contrast) !important; 
    outline-offset: 2px !important;
}

.cv-color-check {
    width: 20px;
    height: 20px;
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.2s cubic-bezier(0.175, 0.885, 0.32, 1.275); 
    filter: drop-shadow(0px 1px 2px rgba(0,0,0,0.6));
}

.cv-color-swatch.selected .cv-color-check {
    opacity: 1;
    transform: scale(1);
}


/* --- DEVICE ID DEBUG WIDGET --- */
.cv-device-id-wrapper {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--wp--preset--color--base-2);
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: var(--wp--preset--font-size--medium);
}


/* --- PREFERENCES ACCORDION CARDS --- */
.cv-submenu-toggle {
    background-color: var(--wp--preset--color--base-2);
    border: 1px solid var(--wp--preset--color--contrast-3);
    border-radius: 8px;
    overflow: hidden;
    transition: all 0.3s ease;
    margin-bottom: 1.5rem;
}

.cv-submenu-toggle > .cv-submenu-header {
    position: relative;
    padding: 12px 44px 12px 16px;
    cursor: pointer;
    user-select: none;
    outline: none;
    list-style: none;
    transition: background-color 0.2s ease;
}

.cv-submenu-toggle > .cv-submenu-header:hover {
    background-color: rgba(255, 255, 255, 0.02);
}

.cv-submenu-toggle > .cv-submenu-header::after {
    content: '';
    position: absolute;
    right: 20px;
    top: 50%;
    width: 7px;
    height: 7px;
    border-right: 1px solid var(--wp--preset--color--contrast-2);
    border-bottom: 1px solid var(--wp--preset--color--contrast-2);
    transform: translateY(calc(-50% - 2px)) rotate(45deg);
    transition: transform 0.3s ease, border-color 0.2s ease;
}

.cv-submenu-toggle.is-open > .cv-submenu-header::after {
    transform: translateY(calc(-50% + 2px)) rotate(225deg);
    border-color: var(--wp--preset--color--contrast);
}

.cv-submenu-toggle > .cv-submenu-content {
    border-top: 1px solid transparent; 
    display: grid;
    grid-template-rows: 0fr;
    transition: grid-template-rows 0.3s ease, border-color 0.3s ease;
}

.cv-submenu-toggle > .cv-submenu-content > * {
    min-height: 0;
    overflow: hidden;
    padding: 0 20px;
}

.cv-submenu-toggle.is-open > .cv-submenu-content {
    border-top-color: var(--wp--preset--color--contrast-3);
    grid-template-rows: 1fr;
}

.cv-submenu-toggle.is-open > .cv-submenu-content > * {
    padding-top: 16px;
    padding-bottom: 20px;
}


/* --- TOOLTIPS ADJUSTMENTS --- */
.cv-info-tooltip.dynamic-tooltip {
    position: fixed !important;
    z-index: 99999 !important;
    width: max-content;
    max-width: 85vw;
    text-align: center;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity 0.2s cubic-bezier(0.2, 0, 0.2, 1);
    margin: 0 !important;
    left: 50%;
    transform: none !important;
}

.cv-info-tooltip.dynamic-tooltip.is-visible {
    opacity: 1 !important;
    visibility: visible !important;
}

.cv-info-tooltip.dynamic-tooltip.align-center {
    transform: translateX(-50%) !important;
}

.cv-info-tooltip.dynamic-tooltip::after,
.cv-info-tooltip.dynamic-tooltip::before {
    content: '';
    position: absolute;
    left: var(--arrow-x, 50%);
    border-style: solid;
    border-color: transparent;
    margin: 0 !important;
    transform: translateX(-50%);
    transition: left 0.1s ease;
}

.cv-info-tooltip.dynamic-tooltip.pos-top::after,
.cv-info-tooltip.dynamic-tooltip.pos-top::before {
    bottom: auto;
}

.cv-info-tooltip.dynamic-tooltip.pos-top::after {
    top: 100%;
    border-width: 6px;
    border-color: var(--wp--preset--color--base-2) transparent transparent transparent;
}

.cv-info-tooltip.dynamic-tooltip.pos-top::before {
    top: 100%;
    border-width: 7px;
    border-color: var(--wp--preset--color--contrast-3) transparent transparent transparent;
}

.cv-info-tooltip.dynamic-tooltip.pos-bottom::after,
.cv-info-tooltip.dynamic-tooltip.pos-bottom::before {
    top: auto;
}

.cv-info-tooltip.dynamic-tooltip.pos-bottom::after {
    bottom: 100%;
    border-width: 6px;
    border-color: transparent transparent var(--wp--preset--color--base-2) transparent;
}

.cv-info-tooltip.dynamic-tooltip.pos-bottom::before {
    bottom: 100%;
    border-width: 7px;
    border-color: transparent transparent var(--wp--preset--color--contrast-3) transparent;
}
