/* ==========================================================================
   Blue Ceramic — Magnet Customizer
   Delft Blue palette: beige ceramic + ink blue
   ========================================================================== */

:root {
    --bc-bg:          #EDE0C8;
    --bc-ink:         #1A4A8A;
    --bc-ink-light:   #3A6AAA;
    --bc-ink-faint:   #D6E4F7;
    --bc-border:      #C8B89A;
    --bc-border-dark: #A0906E;
    --bc-white:       #FFFFFF;
    --bc-radius:      8px;
    --bc-gap:         12px;
}

/* --------------------------------------------------------------------------
   Layout
   -------------------------------------------------------------------------- */
.bc-customizer {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    align-items: start;
    margin-bottom: 24px;
    font-family: inherit;
}

@media ( max-width: 768px ) {
    .bc-customizer {
        grid-template-columns: 1fr;
    }
    .bc-customizer__preview {
        order: -1;
    }
}

.bc-customizer__controls {
    display: flex;
    flex-direction: column;
    gap: 20px;
}

.bc-customizer__section {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.bc-customizer__label {
    margin: 0;
    font-size: 0.85rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--bc-ink);
}

/* --------------------------------------------------------------------------
   Shape selector
   -------------------------------------------------------------------------- */
.bc-shape-selector {
    display: flex;
    flex-wrap: wrap;
    gap: var(--bc-gap);
}

.bc-shape-selector__card {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 76px;
    padding: 10px 8px 8px;
    background: var(--bc-white);
    border: 2px solid var(--bc-border);
    border-radius: var(--bc-radius);
    cursor: pointer;
    color: var(--bc-border-dark);
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    font-size: 0.72rem;
    line-height: 1.2;
    text-align: center;
}

.bc-shape-selector__card:hover {
    border-color: var(--bc-ink-light);
    color: var(--bc-ink);
}

.bc-shape-selector__card.selected {
    border-color: var(--bc-ink);
    background: var(--bc-ink-faint);
    color: var(--bc-ink);
}

.bc-shape-selector__icon {
    display: block;
    width: 40px;
    height: 28px;
    flex-shrink: 0;
}

.bc-shape-selector__icon svg {
    width: 100%;
    height: 100%;
}

.bc-shape-selector__name {
    font-weight: 500;
}

/* --------------------------------------------------------------------------
   Size selector
   -------------------------------------------------------------------------- */
.bc-size-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.bc-size-selector__chip {
    padding: 6px 14px;
    background: var(--bc-white);
    border: 2px solid var(--bc-border);
    border-radius: 100px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--bc-border-dark);
    font-weight: 500;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    white-space: nowrap;
}

.bc-size-selector__chip:hover:not(:disabled) {
    border-color: var(--bc-ink-light);
    color: var(--bc-ink);
}

.bc-size-selector__chip.selected {
    border-color: var(--bc-ink);
    background: var(--bc-ink-faint);
    color: var(--bc-ink);
}

.bc-size-selector__chip.out-of-stock,
.bc-size-selector__chip:disabled {
    opacity: 0.4;
    cursor: not-allowed;
}

/* --------------------------------------------------------------------------
   Mounting selector (same chip style as size)
   -------------------------------------------------------------------------- */
.bc-mounting-selector {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.bc-mounting-selector__chip {
    padding: 6px 14px;
    background: var(--bc-white);
    border: 2px solid var(--bc-border);
    border-radius: 100px;
    cursor: pointer;
    font-size: 0.85rem;
    color: var(--bc-border-dark);
    font-weight: 500;
    transition: border-color 0.15s, background 0.15s, color 0.15s;
    white-space: nowrap;
}

.bc-mounting-selector__chip:hover {
    border-color: var(--bc-ink-light);
    color: var(--bc-ink);
}

.bc-mounting-selector__chip.selected {
    border-color: var(--bc-ink);
    background: var(--bc-ink-faint);
    color: var(--bc-ink);
}

/* --------------------------------------------------------------------------
   Upload area
   -------------------------------------------------------------------------- */
.bc-upload-area {
    padding: 16px;
    background: var(--bc-white);
    border: 2px dashed var(--bc-border);
    border-radius: var(--bc-radius);
    text-align: center;
    transition: border-color 0.15s, background 0.15s;
}

.bc-upload-area.drag-over {
    border-color: var(--bc-ink);
    background: var(--bc-ink-faint);
}

.bc-upload-area__hint {
    margin: 0 0 10px;
    font-size: 0.78rem;
    color: #888;
    line-height: 1.4;
}

.bc-upload-area__button {
    display: inline-block;
    padding: 7px 18px;
    background: var(--bc-ink);
    color: var(--bc-white);
    border-radius: 100px;
    font-size: 0.82rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
    user-select: none;
}

.bc-upload-area__button:hover {
    background: var(--bc-ink-light);
}

.bc-upload-area__clear {
    display: inline-block;
    margin-left: 8px;
    padding: 7px 14px;
    background: transparent;
    color: var(--bc-border-dark);
    border: 1px solid var(--bc-border);
    border-radius: 100px;
    font-size: 0.82rem;
    cursor: pointer;
    transition: color 0.15s, border-color 0.15s;
}

.bc-upload-area__clear:hover {
    color: #c0392b;
    border-color: #c0392b;
}

/* --------------------------------------------------------------------------
   Text controls (textarea)
   -------------------------------------------------------------------------- */
.bc-text-controls__input {
    width: 100%;
    padding: 9px 12px;
    border: 2px solid var(--bc-border);
    border-radius: var(--bc-radius);
    font-size: 0.9rem;
    color: #333;
    background: var(--bc-white);
    transition: border-color 0.15s;
    box-sizing: border-box;
    resize: vertical;
    min-height: 72px;
    font-family: inherit;
    line-height: 1.5;
}

.bc-text-controls__input:focus {
    outline: none;
    border-color: var(--bc-ink);
}

/* --------------------------------------------------------------------------
   Preview canvas
   -------------------------------------------------------------------------- */
.bc-customizer__preview {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: 16px 0;
    position: sticky;
    top: 80px;
}

#bc-magnet-canvas {
    max-width: 100%;
    height: auto;
    border-radius: 4px;
    box-shadow: 0 4px 20px rgba(26, 74, 138, 0.15), 0 1px 4px rgba(0,0,0,0.08);
    background: var(--bc-bg);
    display: block;
    cursor: default;
    touch-action: none;
}

#bc-magnet-canvas.has-image {
    cursor: grab;
}

/* --------------------------------------------------------------------------
   Image drag/scale controls (shown after upload)
   -------------------------------------------------------------------------- */
.bc-image-controls {
    margin-top: 10px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    align-items: center;
    width: 100%;
}

.bc-image-controls__hint {
    font-size: 0.75rem;
    color: var(--bc-border-dark);
    text-align: center;
}

.bc-image-controls__scale {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.8rem;
    color: var(--bc-ink);
    width: 100%;
    max-width: 300px;
}

.bc-image-controls__scale input[type="range"] {
    flex: 1;
    accent-color: var(--bc-ink);
}

/* --------------------------------------------------------------------------
   Hide native WooCommerce variation dropdowns when customizer is active
   -------------------------------------------------------------------------- */
#bc-magnet-customizer ~ .variations_form table.variations,
#bc-magnet-customizer ~ form.cart table.variations,
.bc-customizer ~ .variations_form table.variations {
    display: none !important;
}

#bc-magnet-customizer ~ .woocommerce-variation-price,
.bc-customizer ~ .woocommerce-variation-price {
    display: none !important;
}
