/**
 * Bombaro Gravir Editor v2.7.8 - Brand Styles
 * Brand color: #4b5320
 * High specificity to override Woodmart theme
 * Canvas: 420x400 (21:20 ratio = 21cm x 20cm)
 */

/* ===== CSS Variables ===== */
:root {
    --bpa-brand: #4b5320;
    --bpa-brand-hover: #3d4419;
    --bpa-brand-light: #5c6628;
}

/* ===== Main Wrapper ===== */
.bpa-ge-wrapper {
    background: #fafaf8 !important;
    border: 1px solid #e5e5e0 !important;
    border-radius: 10px !important;
    padding: 15px !important;
    max-width: min(480px, calc(100vw - 40px)) !important;
    margin: 0 auto !important;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

/* Info text above canvas - PROMINENT */
.bpa-ge-wrapper .bpa-ge-info {
    background: linear-gradient(135deg, #fff9e6 0%, #fff3cc 100%) !important;
    border: 2px solid #f0c040 !important;
    border-radius: 10px !important;
    padding: 14px 16px !important;
    margin-bottom: 14px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    color: #5a4a00 !important;
    text-align: center !important;
    box-shadow: 0 2px 8px rgba(240, 192, 64, 0.25) !important;
}

.bpa-ge-wrapper .bpa-ge-info strong {
    display: block !important;
    font-size: 15px !important;
    margin-bottom: 4px !important;
    color: #4a3c00 !important;
}

/* ===== Canvas Area ===== */
.bpa-ge-wrapper .bpa-ge-canvas-area {
    position: relative !important;
    background: #2a2a28 !important;
    border-radius: 8px !important;
    padding: 10px !important;
    margin-bottom: 15px !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
    min-height: 280px !important;
    overflow: hidden !important;
    max-width: 100% !important;
}

.bpa-ge-wrapper .bpa-ge-canvas-area canvas {
    border-radius: 4px !important;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25) !important;
}

.bpa-ge-wrapper .bpa-ge-canvas-area .canvas-container {
    margin: 0 auto !important;
    position: relative !important;
    z-index: 1 !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

/* Hint text */
.bpa-ge-wrapper .bpa-ge-hint {
    position: absolute !important;
    bottom: 18px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    background: rgba(255, 255, 255, 0.92) !important;
    color: #4b5320 !important;
    padding: 6px 14px !important;
    border-radius: 16px !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.12) !important;
    pointer-events: none !important;
    z-index: 10 !important;
    white-space: nowrap !important;
}

/* ===== Action Buttons Container ===== */
.bpa-ge-wrapper .bpa-ge-actions {
    display: flex !important;
    gap: 8px !important;
    flex-wrap: wrap !important;
    align-items: center !important;
}

/* ===== Base Button Style - High Specificity ===== */
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    padding: 10px 16px !important;
    border: none !important;
    border-radius: 6px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    cursor: pointer !important;
    transition: all 0.15s ease !important;
    background: #4b5320 !important;
    color: white !important;
    text-decoration: none !important;
    line-height: 1.2 !important;
    box-shadow: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    height: auto !important;
    min-height: 42px !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn:hover {
    background: #3d4419 !important;
    color: white !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn:active {
    transform: scale(0.98) !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn:disabled {
    opacity: 0.4 !important;
    cursor: not-allowed !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn svg {
    flex-shrink: 0 !important;
    width: 18px !important;
    height: 18px !important;
    display: block !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn span {
    white-space: nowrap !important;
    display: inline !important;
}

/* ===== Primary Buttons - Text & Image ===== */
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text,
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn {
    flex: 1 1 auto !important;
    min-width: 100px !important;
    max-width: 220px !important;
    background: #4b5320 !important;
    border: none !important;
    border-radius: 6px !important;
}

/* Handle long button text (e.g. Hungarian) */
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text span,
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn span {
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    max-width: 100% !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text:hover,
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn:hover {
    background: #3d4419 !important;
}

/* ===== Secondary Buttons - Undo & Delete (icon only) ===== */
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-secondary,
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-danger {
    flex: 0 0 42px !important;
    width: 42px !important;
    min-width: 42px !important;
    max-width: 42px !important;
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    background: transparent !important;
    border: 1px solid #d1d1c7 !important;
    border-radius: 6px !important;
    color: #666 !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-secondary:hover {
    background: #f0f0eb !important;
    border-color: #bbb !important;
    color: #333 !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-danger {
    color: #a33 !important;
    border-color: #e5d5d5 !important;
}

.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-danger:hover {
    background: #fef5f5 !important;
    border-color: #d99 !important;
    color: #922 !important;
}

/* Hide text on secondary buttons */
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-secondary span,
.bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-danger span {
    display: none !important;
}

/* ===== Mobile Responsive ===== */
@media (max-width: 600px) {
    .bpa-ge-wrapper {
        padding: 10px !important;
        border-radius: 8px !important;
        max-width: 100% !important;
        width: 100% !important;
        margin: 0 !important;
        overflow: hidden !important;
        box-sizing: border-box !important;
    }

    .bpa-ge-wrapper .bpa-ge-info {
        padding: 10px 12px !important;
        font-size: 12px !important;
        margin-bottom: 10px !important;
        max-width: 100% !important;
        word-wrap: break-word !important;
    }

    .bpa-ge-wrapper .bpa-ge-canvas-area {
        padding: 6px !important;
        min-height: 180px !important;
        margin-bottom: 10px !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    /* Force Fabric.js canvas-container to respect parent width */
    .bpa-ge-wrapper .bpa-ge-canvas-area .canvas-container,
    .bpa-ge-wrapper .canvas-container,
    .bpa-gravir-editor-container .canvas-container,
    .bpa-accordion-content .canvas-container {
        max-width: 100% !important;
        width: auto !important;
        overflow: hidden !important;
    }

    /* Force canvas elements to not exceed container */
    .bpa-ge-wrapper .bpa-ge-canvas-area canvas,
    .bpa-ge-wrapper canvas,
    .bpa-gravir-editor-container canvas,
    .bpa-accordion-content canvas {
        max-width: 100% !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions {
        gap: 6px !important;
        flex-wrap: nowrap !important;
    }

    /* All buttons on mobile */
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn {
        padding: 8px 10px !important;
        font-size: 11px !important;
        border-radius: 6px !important;
        height: 42px !important;
        min-height: 42px !important;
    }

    /* Primary buttons on mobile - equal width with text */
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn {
        flex: 1 1 0 !important;
        min-width: 0 !important;
        max-width: none !important;
    }

    /* FORCE text visible on mobile - handle long translations */
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text span,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn span {
        display: inline !important;
        font-size: 10px !important;
        visibility: visible !important;
        opacity: 1 !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        white-space: nowrap !important;
        max-width: calc(100% - 24px) !important;
    }

    /* Icon buttons on mobile - square */
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-secondary,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-danger {
        flex: 0 0 42px !important;
        width: 42px !important;
        min-width: 42px !important;
        max-width: 42px !important;
        height: 42px !important;
        padding: 0 !important;
    }

    .bpa-ge-wrapper .bpa-ge-hint {
        font-size: 11px !important;
        padding: 5px 10px !important;
        bottom: 14px !important;
        white-space: normal !important;
        max-width: calc(100% - 20px) !important;
        text-align: center !important;
    }
}

/* ===== Extra Small Screens ===== */
@media (max-width: 400px) {
    .bpa-ge-wrapper {
        padding: 8px !important;
        border-radius: 6px !important;
        max-width: 100% !important;
        width: 100% !important;
        overflow: hidden !important;
    }

    .bpa-ge-wrapper .bpa-ge-canvas-area {
        padding: 4px !important;
        min-height: 180px !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions {
        gap: 4px !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn {
        padding: 6px 8px !important;
        font-size: 10px !important;
        height: 40px !important;
        min-height: 40px !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text span,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn span {
        font-size: 9px !important;
        max-width: calc(100% - 20px) !important;
    }

    /* On very small screens, hide text and show only icons */
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn {
        min-width: 42px !important;
        max-width: none !important;
        flex: 1 1 auto !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-secondary,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-danger {
        flex: 0 0 40px !important;
        width: 40px !important;
        min-width: 40px !important;
        height: 40px !important;
        min-height: 40px !important;
    }
}

/* ===== Very Small Screens - Icons Only ===== */
@media (max-width: 340px) {
    /* Hide button text completely, show only icons */
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text span,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn span {
        display: none !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn {
        flex: 0 0 44px !important;
        width: 44px !important;
        min-width: 44px !important;
        max-width: 44px !important;
        padding: 0 !important;
        justify-content: center !important;
    }

    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-add-text svg,
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-upload-btn svg {
        margin: 0 !important;
    }
}

/* ===== Touch-friendly controls ===== */
@media (hover: none) and (pointer: coarse) {
    .bpa-ge-wrapper .bpa-ge-actions .bpa-ge-action-btn {
        min-height: 44px !important;
    }

    .bpa-ge-wrapper .bpa-ge-canvas-area {
        touch-action: none !important;
    }
}

/* ===== Fabric.js overrides ===== */
.bpa-ge-wrapper .bpa-ge-canvas-area .upper-canvas {
    cursor: default !important;
}

.bpa-ge-wrapper .bpa-ge-canvas-area .canvas-container {
    border-radius: 4px !important;
    overflow: hidden !important;
}

/* ===== Print styles ===== */
@media print {
    .bpa-ge-wrapper {
        display: none !important;
    }
}
