/* ========================================
   STUDIO DE PERSONNALISATION - PENTEE
   CSS ORIGINAL SANS MODIFICATIONS MOBILES
   ======================================== */

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: #333;
    overflow: hidden;
    height: 100vh;
}

/* Header */
.studio-header {
    background: #fff;
    border-bottom: 2px solid #e0e0e0;
    padding: 15px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 70px;
    position: relative;
    z-index: 100;
}

.header-left {
    display: flex;
    align-items: center;
    gap: 20px;
}

.btn-back {
    padding: 8px 16px;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    text-decoration: none;
    color: #333;
    font-weight: 600;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s;
}

.btn-back:hover {
    border-color: #ff006e;
    color: #ff006e;
}

.product-info-header {
    display: flex;
    flex-direction: column;
}

.product-code {
    font-size: 11px;
    color: #999;
    font-weight: 600;
    letter-spacing: 0.5px;
}

.product-name-header {
    font-size: 16px;
    font-weight: 700;
    color: #000;
}

.header-right {
    display: flex;
    gap: 15px;
}

/* Bouton Panier */
.btn-cart {
    padding: 10px 20px;
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-weight: 700;
    color: #333;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: all 0.3s;
    text-decoration: none;
    font-size: 14px;
    position: relative;
}

.btn-cart:hover {
    border-color: #ff006e;
    color: #ff006e;
    background: rgba(255, 0, 110, 0.04);
}

.cart-badge {
    background: linear-gradient(90deg, #ff006e, #8338ec);
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    min-width: 20px;
    height: 20px;
    border-radius: 99px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
    margin-left: 2px;
    animation: badge-pop 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

.cart-badge.hidden { display: none; }

@keyframes badge-pop {
    0% { transform: scale(0); }
    100% { transform: scale(1); }
}

.btn-save {
    padding: 12px 30px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border: none;
    border-radius: 8px;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 14px;
}

.btn-save:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(255, 0, 110, 0.3);
}
}

.btn-order {
    padding: 12px 30px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border: none;
    border-radius: 8px;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    transition: all 0.3s;
    font-size: 14px;
}

.btn-order:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(255, 0, 110, 0.3);
}

/* Studio Container - GRID 3 COLONNES */
.studio-container {
    display: grid;
    grid-template-columns: 320px 1fr 300px;
    height: calc(100vh - 70px);
    background: #f5f5f5;
}

/* Left Sidebar */
.studio-sidebar {
    background: #fff;
    border-right: 2px solid #e0e0e0;
    overflow-y: auto;
    padding: 20px;
}

.sidebar-section {
    margin-bottom: 30px;
}

.sidebar-section h3 {
    font-size: 14px;
    font-weight: 700;
    color: #000;
    margin-bottom: 15px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Masquer éléments mobiles sur desktop */
.mobile-tools-btn,
.mobile-details-btn,
.mobile-close-btn,
.mobile-overlay {
    display: none !important;
}

.tool-buttons {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.tool-btn {
    padding: 15px 10px;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 10px;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    transition: all 0.3s;
    position: relative;
}

.tool-btn i {
    font-size: 24px;
    color: #666;
}

.tool-btn span {
    font-size: 12px;
    font-weight: 600;
    color: #333;
}

.tool-btn:hover {
    border-color: #ff006e;
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.05), rgba(131, 56, 236, 0.05));
}

.tool-btn.active {
    border-color: #ff006e;
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.1), rgba(131, 56, 236, 0.1));
}

.tool-btn.active i {
    background: linear-gradient(90deg, #ff006e, #8338ec);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.badge-ia {
    position: absolute;
    top: 5px;
    right: 5px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    color: #fff;
    padding: 2px 6px;
    border-radius: 10px;
    font-size: 9px;
    font-weight: 700;
}

/* Tool Panels */
.tool-panel {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 2px solid #e0e0e0;
}

.tool-panel.hidden {
    display: none;
}

.tool-panel h4 {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 15px;
    color: #000;
}

.panel-description {
    font-size: 12px;
    color: #666;
    margin-bottom: 15px;
}

/* Upload Zone */
.upload-zone {
    border: 2px dashed #e0e0e0;
    border-radius: 10px;
    padding: 30px 20px;
    text-align: center;
    background: #f8f9fa;
    transition: all 0.3s;
    cursor: pointer;
}

.upload-zone:hover {
    border-color: #ff006e;
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.05), rgba(131, 56, 236, 0.05));
}

.upload-zone.dragover {
    border-color: #ff006e;
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.1), rgba(131, 56, 236, 0.1));
}

.upload-zone i {
    font-size: 48px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-bottom: 10px;
}

.upload-zone p {
    font-size: 14px;
    color: #333;
    font-weight: 600;
    margin-bottom: 5px;
}

.upload-hint {
    font-size: 12px !important;
    color: #999 !important;
    font-weight: 400 !important;
}

.btn-browse {
    margin-top: 15px;
    padding: 10px 25px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
}

.btn-browse:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(255, 0, 110, 0.3);
}

.upload-formats {
    margin-top: 15px;
}

.upload-formats p {
    font-size: 11px;
    color: #999;
    margin: 3px 0;
}

.uploaded-images-list {
    margin-top: 15px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.uploaded-image-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px solid #e0e0e0;
}

.uploaded-image-thumb {
    width: 40px;
    height: 40px;
    object-fit: cover;
    border-radius: 5px;
}

.uploaded-image-info {
    flex: 1;
    font-size: 12px;
    min-width: 0;
    overflow: hidden;
}

.uploaded-image-name {
    font-weight: 600;
    color: #333;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100px;
}

.uploaded-image-size {
    color: #999;
    font-size: 11px;
}

.btn-remove-upload {
    background: none;
    border: none;
    color: #dc2626;
    cursor: pointer;
    font-size: 18px;
    padding: 5px;
}

/* Text Controls */
.text-input-group {
    margin-bottom: 20px;
}

.text-input-group label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: #333;
    margin-bottom: 8px;
}

.text-input-group textarea {
    width: 100%;
    padding: 12px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    resize: vertical;
    font-family: inherit;
}

.text-input-group textarea:focus {
    outline: none;
    border-color: #ff006e;
}

.btn-add-text {
    width: 100%;
    padding: 12px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 10px;
    transition: all 0.3s;
}

.btn-add-text:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(255, 0, 110, 0.3);
}

.text-controls {
    margin-top: 20px;
}

.text-controls label {
    display: block;
    font-size: 12px;
    font-weight: 600;
    color: #333;
    margin: 15px 0 8px;
}

.control-select {
    width: 100%;
    padding: 10px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    cursor: pointer;
    font-family: inherit;
}

.control-select:focus {
    outline: none;
    border-color: #ff006e;
}

.size-control {
    display: flex;
    align-items: center;
    gap: 10px;
}

.size-control input[type="range"] {
    flex: 1;
    height: 6px;
    border-radius: 3px;
    background: #e0e0e0;
    outline: none;
    -webkit-appearance: none;
}

.size-control input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 18px;
    height: 18px;
    border-radius: 50%;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    cursor: pointer;
}

.size-control span {
    font-size: 14px;
    font-weight: 600;
    min-width: 30px;
}

.color-picker-group {
    display: flex;
    align-items: center;
    gap: 10px;
}

.color-picker-group input[type="color"] {
    width: 50px;
    height: 40px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    cursor: pointer;
}

.color-picker-group span {
    font-size: 12px;
    font-weight: 600;
    color: #333;
}

.text-style-buttons {
    display: flex;
    gap: 8px;
    margin-top: 15px;
}

.style-btn {
    flex: 1;
    padding: 10px;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    cursor: pointer;
    font-size: 18px;
    transition: all 0.3s;
}

.style-btn:hover {
    border-color: #ff006e;
}

.style-btn.active {
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.1), rgba(131, 56, 236, 0.1));
    border-color: #ff006e;
}

/* Designs Grid */
.designs-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}

.design-item {
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 10px;
    font-size: 32px;
    cursor: pointer;
    transition: all 0.3s;
}

.design-item:hover {
    border-color: #ff006e;
    transform: scale(1.05);
}

/* AI Panel */
#aiPrompt {
    width: 100%;
    padding: 12px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    resize: vertical;
    font-family: inherit;
    margin-bottom: 15px;
}

.btn-generate-ai {
    width: 100%;
    padding: 12px;
    background: linear-gradient(90deg, #667eea, #764ba2);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.3s;
}

.btn-generate-ai:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(102, 126, 234, 0.3);
}

.ai-note {
    margin-top: 10px;
    font-size: 11px;
    color: #999;
    text-align: center;
}

.size-info {
    padding: 15px;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px solid #e0e0e0;
}

.size-info p {
    font-size: 13px;
    color: #666;
}

/* Center - Canvas Area */
.studio-canvas-area {
    display: flex;
    flex-direction: column;
    background: #fff;
}

.canvas-toolbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 20px;
    border-bottom: 2px solid #e0e0e0;
    background: #fff;
}

.view-selector {
    display: flex;
    gap: 10px;
}

.view-btn {
    padding: 8px 16px;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 600;
    color: #666;
    transition: all 0.3s;
}

.view-btn:hover {
    border-color: #ff006e;
}

.view-btn.active {
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.1), rgba(131, 56, 236, 0.1));
    border-color: #ff006e;
    color: #ff006e;
}

.canvas-tools {
    display: flex;
    gap: 8px;
}

.canvas-tool-btn {
    width: 36px;
    height: 36px;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    color: #666;
    transition: all 0.3s;
}

.canvas-tool-btn:hover {
    border-color: #ff006e;
    color: #ff006e;
}

.canvas-container {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px;
    overflow: hidden;
    position: relative;
}

.canvas-wrapper {
    position: relative;
    max-width: 800px;
    max-height: 100%;
    width: 100%;
    aspect-ratio: 1;
}

.product-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    pointer-events: none;
}

.canvas-design-area {
    position: absolute;
    top: 15%;
    left: 14%;
    width: 72%;
    height: 65%;
    border: 2px dashed rgba(255, 0, 110, 0.3);
    pointer-events: none;
}

.design-element {
    position: absolute;
    cursor: move;
    pointer-events: auto;
}

.design-element.selected {
    outline: 2px solid #ff006e;
    outline-offset: 2px;
    box-shadow: 0 0 0 4px rgba(255, 0, 110, 0.2);
}

.design-element img {
    width: 100%;
    height: 100%;
    display: block;
    pointer-events: none;
}

.design-element.text-element {
    white-space: nowrap;
    padding: 5px;
    user-select: none;
}

.resize-handle {
    position: absolute;
    width: 14px;
    height: 14px;
    background: #ff006e;
    border: 3px solid #fff;
    border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
    z-index: 100;
    cursor: pointer;
    display: none;
}

.design-element.selected .resize-handle {
    display: block;
}

.resize-handle.top-left {
    top: -7px;
    left: -7px;
    cursor: nwse-resize;
}

.resize-handle.top-right {
    top: -7px;
    right: -7px;
    cursor: nesw-resize;
}

.resize-handle.bottom-left {
    bottom: -7px;
    left: -7px;
    cursor: nesw-resize;
}

.resize-handle.bottom-right {
    bottom: -7px;
    right: -7px;
    cursor: nwse-resize;
}

.express-badge {
    position: absolute;
    bottom: 20px;
    right: 20px;
    background: linear-gradient(135deg, #ff006e, #8338ec);
    color: #fff;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 6px;
    letter-spacing: 1px;
    pointer-events: none;
}

/* Object Controls */
.object-controls {
    position: absolute;
    top: 20px;
    right: 20px;
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 10px;
    padding: 8px;
    display: flex;
    gap: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.object-controls.hidden {
    display: none;
}

.control-btn {
    width: 36px;
    height: 36px;
    background: #f8f9fa;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    color: #666;
    transition: all 0.3s;
}

.control-btn:hover {
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.1), rgba(131, 56, 236, 0.1));
    color: #ff006e;
}

/* Right Sidebar - Details */
.studio-details {
    background: #fff;
    border-left: 2px solid #e0e0e0;
    overflow-y: auto;
    padding: 20px;
}

.details-card {
    background: #f8f9fa;
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px;
}

.product-rating-studio {
    margin-bottom: 15px;
}

.stars {
    font-size: 16px;
    margin-bottom: 5px;
}

.rating-link {
    font-size: 12px;
    color: #666;
    text-decoration: none;
}

.rating-link:hover {
    color: #ff006e;
}

.btn-change-product {
    width: 100%;
    padding: 12px;
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-weight: 600;
    color: #333;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-bottom: 15px;
    transition: all 0.3s;
}

.btn-change-product:hover {
    border-color: #ff006e;
    color: #ff006e;
}

.btn-details-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px;
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    text-decoration: none;
    color: #333;
    font-weight: 600;
    transition: all 0.3s;
}

.btn-details-link:hover {
    border-color: #ff006e;
    color: #ff006e;
}

.instructions-card {
    background: #f8f9fa;
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px;
}

.instructions-card h4 {
    font-size: 14px;
    font-weight: 700;
    margin-bottom: 15px;
    color: #000;
}

.instructions-list {
    list-style: none;
}

.instructions-list li {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    font-size: 13px;
    color: #666;
}

.instructions-list i {
    color: #10b981;
    font-size: 16px;
}

.price-card {
    background: linear-gradient(135deg, rgba(255, 0, 110, 0.05), rgba(131, 56, 236, 0.05));
    border-radius: 10px;
    padding: 20px;
    margin-bottom: 20px;
}

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

.price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
}

.price-label {
    font-size: 12px;
    color: #999;
    flex: 1;
}

.price-value {
    font-size: 14px;
    font-weight: 700;
    color: #333;
    white-space: nowrap;
}

.price-row + .price-row {
    border-top: 1px solid rgba(0,0,0,0.06);
    padding-top: 8px;
}

.price-row.price-total {
    border-top: 2px solid rgba(255, 0, 110, 0.2);
    padding-top: 10px;
    margin-top: 4px;
}

.price-row.price-total .price-label {
    font-size: 13px;
    font-weight: 700;
    color: #333;
}

.price-value-total {
    font-size: 22px;
    font-weight: 800;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    white-space: nowrap;
}

.price-unit {
    font-size: 13px;
    color: #666;
    font-weight: 600;
}

.btn-add-instructions {
    width: 100%;
    padding: 12px;
    background: #fff;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-weight: 600;
    color: #333;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.3s;
}

.btn-add-instructions:hover {
    border-color: #ff006e;
    color: #ff006e;
}

/* Modal */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2000;
}

.modal.hidden {
    display: none;
}

.modal-content {
    background: #fff;
    border-radius: 15px;
    padding: 30px;
    max-width: 500px;
    width: 90%;
    position: relative;
}

.modal-close {
    position: absolute;
    top: 15px;
    right: 15px;
    background: none;
    border: none;
    font-size: 24px;
    color: #999;
    cursor: pointer;
    transition: color 0.3s;
}

.modal-close:hover {
    color: #ff006e;
}

.modal-content h3 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 20px;
    color: #000;
}

.modal-content textarea {
    width: 100%;
    padding: 12px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 14px;
    resize: vertical;
    font-family: inherit;
    margin-bottom: 20px;
}

.btn-save-instructions {
    width: 100%;
    padding: 12px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    color: #fff;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;

}

/* Modal de sauvegarde */
.saving-modal-content {
    text-align: center;
    padding: 40px 35px 35px;
    max-width: 400px;
}

.saving-icon {
    width: 70px;
    height: 70px;
    background: linear-gradient(135deg, #ff006e22, #8338ec22);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
    animation: saving-pulse 1.5s ease-in-out infinite;
}

.saving-icon i {
    font-size: 32px;
    background: linear-gradient(135deg, #ff006e, #8338ec);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

@keyframes saving-pulse {
    0%, 100% { transform: scale(1); opacity: 1; }
    50% { transform: scale(1.08); opacity: 0.85; }
}

.saving-modal-content h3 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 6px;
    color: #000;
}

.saving-subtitle {
    font-size: 13px;
    color: #888;
    margin-bottom: 24px;
    min-height: 18px;
    transition: opacity 0.3s;
}

.saving-progress-bar {
    width: 100%;
    height: 10px;
    background: #f0f0f0;
    border-radius: 99px;
    overflow: hidden;
    margin-bottom: 10px;
}

.saving-progress-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border-radius: 99px;
    transition: width 0.4s ease;
}

.saving-percent {
    font-size: 13px;
    font-weight: 700;
    color: #ff006e;
}

.btn-save-instructions:hover {
    transform: translateY(-2px);
    box-shadow: 0 5px 15px rgba(255, 0, 110, 0.3);
}

/* Scrollbar Styling */
.studio-sidebar::-webkit-scrollbar,
.studio-details::-webkit-scrollbar {
    width: 8px;
}

.studio-sidebar::-webkit-scrollbar-track,
.studio-details::-webkit-scrollbar-track {
    background: #f1f1f1;
}

.studio-sidebar::-webkit-scrollbar-thumb,
.studio-details::-webkit-scrollbar-thumb {
    background: #ddd;
    border-radius: 4px;
}

.studio-sidebar::-webkit-scrollbar-thumb:hover,
.studio-details::-webkit-scrollbar-thumb:hover {
    background: #ccc;
}

/* ==============================================
   MOBILE RESPONSIVE - VERSION DEFINITIVE
   N'affecte que les ecrans <= 768px
   Desktop (>768px) inchange
   ============================================== */

/* ── SLIDER TAILLE : cache partout sauf mobile ── */
.size-slider-mobile {
    display: none;
}

@media (max-width: 768px) {

    /* ─────────────────────────────────────────
       SCROLL & BODY
    ───────────────────────────────────────── */
    html {
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }
    body {
        overflow-x: hidden !important;
        overflow-y: auto !important;
        height: auto !important;
        min-height: 100vh;
        touch-action: pan-y;
    }

    /* ─────────────────────────────────────────
       HEADER
    ───────────────────────────────────────── */
    .studio-header {
        position: sticky !important;
        top: 0 !important;
        z-index: 300 !important;
        height: auto !important;
        flex-direction: column !important;
        padding: 8px 12px !important;
        gap: 6px !important;
        box-shadow: 0 2px 12px rgba(0,0,0,0.1) !important;
    }
    .header-left {
        width: 100% !important;
        gap: 8px !important;
        flex-wrap: nowrap !important;
    }
    .product-info-header h1 {
        font-size: 12px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        max-width: 180px !important;
    }
    .product-code { font-size: 10px !important; }
    .btn-back {
        padding: 7px 10px !important;
        font-size: 12px !important;
        flex-shrink: 0 !important;
        min-height: 40px !important;
    }
    .header-right {
        width: 100% !important;
        display: flex !important;
        gap: 8px !important;
        margin-top: 0 !important;
    }
    .btn-cart { display: none !important; }
    .btn-save {
        flex: 1 !important;
        padding: 9px 8px !important;
        font-size: 12px !important;
        min-height: 42px !important;
        justify-content: center !important;
    }
    .btn-order {
        flex: 1 !important;
        padding: 9px 8px !important;
        font-size: 12px !important;
        min-height: 42px !important;
    }

    /* ─────────────────────────────────────────
       LAYOUT : COLONNE VERTICALE
    ───────────────────────────────────────── */
    .studio-container {
        display: flex !important;
        flex-direction: column !important;
        height: auto !important;
        min-height: unset !important;
        overflow: visible !important;
        background: #f5f5f5 !important;
    }

    /* ─────────────────────────────────────────
       CANVAS - ZONE PRINCIPALE
    ───────────────────────────────────────── */
    .studio-canvas-area {
        order: 1 !important;
        width: 100% !important;
        height: 62vh !important;
        min-height: 360px !important;
        max-height: 540px !important;
        position: relative !important;
        overflow: hidden !important;
        background: #f0f0f0 !important;
    }
    .canvas-toolbar {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        flex-wrap: wrap !important;
        gap: 6px !important;
        padding: 8px 10px !important;
        background: #fff !important;
        border-bottom: 1px solid #e8e8e8 !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 20 !important;
    }
    .view-selector {
        display: flex !important;
        gap: 6px !important;
        margin-bottom: 0 !important;
    }
    .view-btn {
        padding: 7px 14px !important;
        font-size: 12px !important;
        min-height: 38px !important;
    }
    .canvas-tools {
        display: flex !important;
        gap: 6px !important;
    }
    .canvas-tool-btn {
        min-width: 38px !important;
        min-height: 38px !important;
        padding: 8px !important;
        font-size: 15px !important;
    }
    .canvas-container {
        height: calc(100% - 56px) !important;
        width: 100% !important;
        position: relative !important;
        overflow: hidden !important;
    }
    .canvas-wrapper {
        width: 100% !important;
        height: 100% !important;
        position: relative !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }
    .product-image {
        max-width: 86% !important;
        max-height: 86% !important;
        width: auto !important;
        height: auto !important;
        object-fit: contain !important;
        pointer-events: none !important;
        -webkit-user-drag: none !important;
        user-select: none !important;
    }
    .canvas-design-area {
        position: absolute !important;
        top: 0 !important; left: 0 !important;
        width: 100% !important; height: 100% !important;
        touch-action: none !important;
        -webkit-user-select: none !important;
        user-select: none !important;
        overflow: visible !important;
    }

    /* ─────────────────────────────────────────
       ELEMENTS DE DESIGN (images / textes)
    ───────────────────────────────────────── */
    .design-element {
        touch-action: none !important;
        -webkit-user-select: none !important;
        user-select: none !important;
        cursor: grab !important;
        will-change: transform !important;
    }
    .design-element:active { cursor: grabbing !important; }
    .design-element.selected {
        outline: 3px solid #ff006e !important;
        outline-offset: 3px !important;
        z-index: 50 !important;
    }
    .design-element img,
    .design-element span {
        pointer-events: none !important;
        -webkit-user-drag: none !important;
        user-select: none !important;
    }

    /* HANDLES DE RESIZE - Grands pour les doigts */
    .design-element .resize-handle {
        width: 46px !important;
        height: 46px !important;
        background: #ff006e !important;
        border: 3px solid #fff !important;
        border-radius: 50% !important;
        box-shadow: 0 2px 10px rgba(0,0,0,0.3) !important;
        opacity: 1 !important;
        touch-action: none !important;
        pointer-events: auto !important;
        z-index: 100 !important;
        transition: transform 0.1s !important;
    }
    .design-element .resize-handle:active {
        transform: scale(1.15) !important;
        background: #cc0058 !important;
    }
    .design-element .resize-handle.nw { top: -23px !important; left: -23px !important; }
    .design-element .resize-handle.ne { top: -23px !important; right: -23px !important; }
    .design-element .resize-handle.sw { bottom: -23px !important; left: -23px !important; }
    .design-element .resize-handle.se { bottom: -23px !important; right: -23px !important; }

    /* ─────────────────────────────────────────
       OBJECT CONTROLS FLOTTANTS (supprimer / dupliquer...)
    ───────────────────────────────────────── */
    .object-controls {
        position: fixed !important;
        bottom: 20px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        top: auto !important;
        right: auto !important;
        flex-direction: row !important;
        gap: 10px !important;
        background: rgba(10,10,10,0.88) !important;
        backdrop-filter: blur(12px) !important;
        -webkit-backdrop-filter: blur(12px) !important;
        padding: 10px 22px !important;
        border-radius: 50px !important;
        box-shadow: 0 6px 28px rgba(0,0,0,0.4) !important;
        z-index: 400 !important;
    }
    .object-controls.hidden { display: none !important; }
    .control-btn {
        width: 46px !important;
        height: 46px !important;
        font-size: 20px !important;
        background: transparent !important;
        color: #fff !important;
        border: 1px solid rgba(255,255,255,0.2) !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        cursor: pointer !important;
        transition: background 0.15s !important;
    }
    .control-btn:active {
        background: rgba(255,255,255,0.18) !important;
        transform: scale(0.9) !important;
    }

    /* ─────────────────────────────────────────
       SLIDER TAILLE MOBILE - visible + anime
    ───────────────────────────────────────── */
    .size-slider-mobile {
        display: block !important;
        position: fixed !important;
        bottom: 86px !important;
        left: 50% !important;
        transform: translateX(-50%) translateY(12px) !important;
        width: min(340px, 90vw) !important;
        background: rgba(255,255,255,0.97) !important;
        backdrop-filter: blur(14px) !important;
        -webkit-backdrop-filter: blur(14px) !important;
        padding: 14px 18px !important;
        border-radius: 18px !important;
        box-shadow: 0 4px 24px rgba(0,0,0,0.18), 0 1px 4px rgba(0,0,0,0.08) !important;
        z-index: 399 !important;
        opacity: 0 !important;
        pointer-events: none !important;
        transition: opacity 0.22s ease, transform 0.22s ease !important;
    }
    .size-slider-mobile.active {
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: translateX(-50%) translateY(0) !important;
    }
    .size-slider-mobile .slider-header {
        display: flex !important;
        align-items: center !important;
        justify-content: space-between !important;
        margin-bottom: 10px !important;
    }
    .size-slider-mobile .slider-label {
        font-size: 13px !important;
        font-weight: 600 !important;
        color: #222 !important;
        display: flex !important;
        align-items: center !important;
        gap: 6px !important;
    }
    .size-slider-mobile .slider-label i { color: #ff006e !important; font-size: 15px !important; }
    .size-slider-mobile .slider-value {
        font-size: 13px !important;
        font-weight: 700 !important;
        color: #ff006e !important;
        background: #fff0f7 !important;
        padding: 3px 10px !important;
        border-radius: 10px !important;
        min-width: 52px !important;
        text-align: center !important;
    }
    .size-slider-mobile .slider-container {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
    }
    .size-slider-mobile .slider-btn {
        width: 36px !important;
        height: 36px !important;
        border: none !important;
        background: #f2f2f2 !important;
        color: #333 !important;
        border-radius: 50% !important;
        font-size: 20px !important;
        cursor: pointer !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        flex-shrink: 0 !important;
        line-height: 1 !important;
        transition: background 0.15s !important;
    }
    .size-slider-mobile .slider-btn:active {
        background: #ff006e !important;
        color: #fff !important;
    }
    .size-slider-mobile input[type="range"] {
        -webkit-appearance: none !important;
        appearance: none !important;
        flex: 1 !important;
        height: 6px !important;
        border-radius: 10px !important;
        background: #e0e0e0 !important;
        outline: none !important;
        margin: 0 !important;
        min-width: 0 !important;
    }
    .size-slider-mobile input[type="range"]::-webkit-slider-thumb {
        -webkit-appearance: none !important;
        width: 28px !important;
        height: 28px !important;
        background: #ff006e !important;
        border: 3px solid #fff !important;
        border-radius: 50% !important;
        box-shadow: 0 2px 8px rgba(255,0,110,0.35) !important;
        cursor: pointer !important;
    }
    .size-slider-mobile input[type="range"]::-moz-range-thumb {
        width: 28px !important;
        height: 28px !important;
        background: #ff006e !important;
        border: 3px solid #fff !important;
        border-radius: 50% !important;
        cursor: pointer !important;
    }

    /* ─────────────────────────────────────────
       SIDEBAR GAUCHE (outils)
    ───────────────────────────────────────── */
    .studio-sidebar {
        order: 2 !important;
        width: 100% !important;
        height: auto !important;
        max-height: none !important;
        overflow-y: visible !important;
        overflow-x: hidden !important;
        border-right: none !important;
        border-top: 2px solid #e8e8e8 !important;
        padding: 0 !important;
    }
    .sidebar-section {
        padding: 14px 14px 0 !important;
        margin-bottom: 0 !important;
    }
    .sidebar-section h3 { font-size: 13px !important; margin-bottom: 10px !important; }
    .tool-buttons {
        display: grid !important;
        grid-template-columns: repeat(4, 1fr) !important;
        gap: 8px !important;
    }
    .tool-btn {
        padding: 12px 6px !important;
        min-height: 68px !important;
        font-size: 11px !important;
        gap: 5px !important;
    }
    .tool-btn i { font-size: 24px !important; }
    .tool-panel {
        margin-top: 0 !important;
        padding: 14px !important;
        border-top: 1px solid #eee !important;
    }
    .tool-panel h4 { font-size: 13px !important; margin-bottom: 12px !important; }
    .upload-zone {
        padding: 24px 14px !important;
        min-height: 140px !important;
    }
    .upload-zone i { font-size: 36px !important; }
    .upload-formats p { font-size: 11px !important; }
    .btn-browse {
        min-height: 46px !important;
        padding: 10px 20px !important;
        font-size: 14px !important;
    }
    /* font-size 16px = pas de zoom auto iOS sur focus input */
    .text-input-group textarea {
        font-size: 16px !important;
        padding: 10px !important;
        min-height: 80px !important;
    }
    .btn-add-text { min-height: 46px !important; font-size: 14px !important; }
    .control-select {
        font-size: 16px !important;
        padding: 10px !important;
        min-height: 46px !important;
    }
    .text-style-buttons { gap: 10px !important; }
    .style-btn { width: 48px !important; height: 48px !important; font-size: 20px !important; }
    input[type="color"] { width: 54px !important; height: 46px !important; }
    .designs-grid {
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 10px !important;
    }
    .design-item { font-size: 32px !important; padding: 18px !important; min-height: 72px !important; }

    /* ─────────────────────────────────────────
       SIDEBAR DROITE (details / prix)
    ───────────────────────────────────────── */
    .studio-details {
        order: 3 !important;
        width: 100% !important;
        height: auto !important;
        max-height: none !important;
        overflow-y: visible !important;
        border-left: none !important;
        border-top: 2px solid #e8e8e8 !important;
    }
    .details-card, .instructions-card, .price-card {
        padding: 12px 14px !important;
        margin: 0 !important;
        border-radius: 0 !important;
    }
    .btn-change-product, .btn-add-instructions {
        width: calc(100% - 28px) !important;
        margin: 10px 14px !important;
        min-height: 46px !important;
    }

    /* ─────────────────────────────────────────
       MODALS
    ───────────────────────────────────────── */
    .modal-content {
        width: 94vw !important;
        max-width: 460px !important;
        padding: 18px !important;
        margin: 24px auto !important;
    }
    .modal-close { width: 44px !important; height: 44px !important; font-size: 22px !important; }
    .saving-modal-content { padding: 28px 18px !important; }
}

/* ─────────────────────────────────────────
   TRES PETITS ECRANS (< 390px)
───────────────────────────────────────── */
@media (max-width: 390px) {
    .studio-canvas-area {
        height: 54vh !important;
        min-height: 320px !important;
    }
    .tool-buttons {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .designs-grid {
        grid-template-columns: repeat(2, 1fr) !important;
    }
    .object-controls {
        padding: 8px 16px !important;
        gap: 8px !important;
    }
    .control-btn {
        width: 42px !important;
        height: 42px !important;
        font-size: 18px !important;
    }
    .btn-save, .btn-order {
        font-size: 11px !important;
        padding: 8px 6px !important;
    }
    .size-slider-mobile input[type="range"] {
        min-width: 100px !important;
    }
}

/* ─────────────────────────────────────────
   TABLETTES (769 - 1024px) - desktop préservé
───────────────────────────────────────── */
@media (min-width: 769px) and (max-width: 1024px) {
    .studio-container {
        grid-template-columns: 260px 1fr 260px;
    }

    .canvas-wrapper {
        max-width: 700px;
    }

    .canvas-container {
        padding: 15px;
    }
}

/* Contenu de la modale */
.modal-content {
    background: #ffffff;
    padding: 30px;
    border-radius: 16px;
    max-width: 500px;
    width: 90%;
    margin: auto;
    position: relative;
    animation: fadeIn 0.3s ease;
}

/* Titre */
.modal-content h3 {
    text-align: center;
    margin-bottom: 25px;
    font-size: 22px;
    font-weight: 600;
}

/* Step container */
.step {
    display: flex;
    align-items: flex-start;
    gap: 15px;
    padding: 15px;
    border-radius: 12px;
    transition: all 0.3s ease;
}

.step:not(:last-child) {
    margin-bottom: 15px;
}

/* Effet hover */
.step:hover {
    background: #f8f9fa;
    transform: translateY(-2px);
}

/* Numéro */
.step-number {
    min-width: 40px;
    height: 40px;
    background: linear-gradient(135deg, #000000, #333333);
    color: #ffffff;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 16px;
}

/* Textes */
.step h4 {
    margin: 0;
    font-size: 16px;
    font-weight: 600;
}

.step p {
    margin: 5px 0 0 0;
    font-size: 14px;
    color: #666;
}

/* Animation */
@keyframes fadeIn {
    from {
        opacity: 0;
        transform: translateY(-10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Responsive */
@media (max-width: 480px) {
    .modal-content {
        padding: 20px;
    }

    .step {
        padding: 12px;
    }

    .step-number {
        min-width: 35px;
        height: 35px;
        font-size: 14px;
    }
}
/* ========================================
   COLOR SWITCHER (sidebar droite)
   ======================================== */

.color-switcher-card {
    background: #fff;
    border-radius: 12px;
    padding: 16px;
    border: 1px solid #e8e8e8;
    margin-bottom: 20px;
}

.color-switcher-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 14px;
}

.color-switcher-title {
    font-size: 12px;
    font-weight: 700;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.6px;
}

.color-switcher-active-name {
    font-size: 13px;
    font-weight: 700;
    color: #ff006e;
}

.color-swatch-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
}

.studio-color-swatch {
    width: 16px;
    height: 16px;
    border-radius: 50%;
    border: 2px solid transparent;
    cursor: pointer;
    flex-shrink: 0;
    box-shadow: 0 1px 4px rgba(0,0,0,0.2);
    transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
    outline: none;
    padding: 0;
}

.studio-color-swatch:hover {
    transform: scale(1.15);
    border-color: #8338ec;
    box-shadow: 0 2px 8px rgba(131,56,236,0.35);
}

.studio-color-swatch.active {
    border-color: #ff006e;
    transform: scale(1.2);
    box-shadow: 0 2px 10px rgba(255,0,110,0.4);
}

/* ========================================
   FIN COLOR SWITCHER
   ======================================== */

/* Handles plus petits sur mobile */
@media (max-width: 768px) {
    .resize-handle {
        width: 10px !important;
        height: 10px !important;
        border-width: 2px !important;
    }
    .resize-handle.top-left    { top: -5px !important;    left: -5px !important; }
    .resize-handle.top-right   { top: -5px !important;    right: -5px !important; }
    .resize-handle.bottom-left { bottom: -5px !important; left: -5px !important; }
    .resize-handle.bottom-right{ bottom: -5px !important; right: -5px !important; }
}

/* Aperçu de la police sélectionnée */
.font-preview {
    margin-top: 8px;
    padding: 10px 14px;
    background: #f8f8f8;
    border-radius: 8px;
    font-size: 20px;
    color: #111;
    text-align: center;
    border: 1px solid #eee;
    min-height: 46px;
    word-break: break-word;
    transition: font-family 0.15s ease;
}

#fontSelect optgroup {
    font-size: 11px;
    color: #aaa;
    font-style: normal;
    font-weight: 700;
}
/* ========================================
   WIDGET TAILLES/QUANTITÉS DANS LE STUDIO
   ======================================== */

.sizes-studio-card {
    background: #fff;
    border-radius: 12px;
    padding: 16px;
    border: 1px solid #e8e8e8;
    margin-bottom: 20px;
}

.sizes-studio-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
}

.sizes-studio-title {
    font-size: 12px;
    font-weight: 700;
    color: #999;
    text-transform: uppercase;
    letter-spacing: 0.6px;
}

.sizes-studio-total {
    font-size: 12px;
    font-weight: 700;
    color: #ff006e;
}

.sizes-studio-grid {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.size-studio-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 5px 0;
    border-bottom: 1px solid #f0f0f0;
}

.size-studio-row:last-child {
    border-bottom: none;
}

.size-studio-label {
    font-size: 13px;
    font-weight: 600;
    color: #333;
    min-width: 32px;
}

.size-studio-qty-control {
    display: flex;
    align-items: center;
    gap: 6px;
}

.size-studio-btn {
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 1.5px solid #e0e0e0;
    background: #f8f9fa;
    cursor: pointer;
    font-size: 14px;
    font-weight: 700;
    color: #555;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    transition: all 0.15s;
    padding: 0;
    flex-shrink: 0;
}

.size-studio-btn:hover {
    border-color: #ff006e;
    color: #ff006e;
    background: rgba(255,0,110,0.06);
}

.size-studio-input {
    width: 36px;
    text-align: center;
    border: 1.5px solid #e0e0e0;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 700;
    color: #333;
    padding: 2px 4px;
    background: #fff;
    -moz-appearance: textfield;
}

.size-studio-input::-webkit-outer-spin-button,
.size-studio-input::-webkit-inner-spin-button {
    -webkit-appearance: none;
}

.size-studio-input:focus {
    outline: none;
    border-color: #ff006e;
}

/* ========================================
   FIN WIDGET TAILLES
   ======================================== */

/* ========================================
   SUPPRESSION DE FOND
   ======================================== */

/* Bouton dans la liste des images uploadées */
.upload-item-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}

.btn-remove-bg {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 4px 8px;
    background: linear-gradient(90deg, rgba(255,0,110,0.08), rgba(131,56,236,0.08));
    border: 1.5px solid rgba(255,0,110,0.3);
    border-radius: 6px;
    font-size: 10px;
    font-weight: 700;
    color: #ff006e;
    cursor: pointer;
    transition: all 0.2s;
    white-space: nowrap;
}

.btn-remove-bg:hover {
    background: linear-gradient(90deg, rgba(255,0,110,0.15), rgba(131,56,236,0.15));
    border-color: #ff006e;
    transform: translateY(-1px);
}

.btn-remove-bg i { font-size: 11px; }

/* Panel suppression de fond */
.bg-remover-panel {
    margin-top: 16px;
    padding: 16px;
    background: #fff;
    border: 2px solid rgba(255,0,110,0.2);
    border-radius: 12px;
    animation: bgPanelIn 0.2s ease;
}

@keyframes bgPanelIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.bg-remover-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 12px;
    font-size: 13px;
    font-weight: 700;
    color: #000;
}

.bg-remover-header i {
    background: linear-gradient(90deg, #ff006e, #8338ec);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    margin-right: 5px;
}

.bg-remover-close {
    background: none;
    border: none;
    font-size: 18px;
    cursor: pointer;
    color: #999;
    padding: 0;
    line-height: 1;
    transition: color 0.15s;
}
.bg-remover-close:hover { color: #ff006e; }

/* Zone preview avec damier (fond transparent) */
.bg-remover-preview-wrap {
    position: relative;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #e0e0e0;
    margin-bottom: 14px;
    background: transparent;
}

.bg-remover-checker {
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(45deg, #d0d0d0 25%, transparent 25%),
        linear-gradient(-45deg, #d0d0d0 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, #d0d0d0 75%),
        linear-gradient(-45deg, transparent 75%, #d0d0d0 75%);
    background-size: 12px 12px;
    background-position: 0 0, 0 6px, 6px -6px, -6px 0px;
    background-color: #f0f0f0;
    z-index: 0;
}

.bg-remover-canvas {
    position: relative;
    z-index: 1;
    display: block;
    width: 100%;
    max-height: 200px;
    object-fit: contain;
}

/* Contrôles sliders */
.bg-remover-controls { margin-bottom: 14px; }

.bg-remover-label {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    font-weight: 700;
    color: #555;
    margin-bottom: 5px;
    text-transform: uppercase;
    letter-spacing: 0.4px;
}

.bg-remover-label span {
    color: #ff006e;
    font-weight: 800;
}

.bg-remover-slider {
    width: 100%;
    -webkit-appearance: none;
    appearance: none;
    height: 5px;
    border-radius: 10px;
    background: #e0e0e0;
    outline: none;
    margin-bottom: 4px;
}

.bg-remover-slider::-webkit-slider-thumb {
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    cursor: pointer;
    border: 2px solid #fff;
    box-shadow: 0 1px 4px rgba(0,0,0,0.2);
}

/* Boutons Aperçu / Appliquer */
.bg-remover-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    margin-bottom: 10px;
}

.bg-remover-btn-preview {
    padding: 9px 10px;
    background: #f8f9fa;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    color: #555;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    transition: all 0.2s;
}
.bg-remover-btn-preview:hover {
    border-color: #8338ec;
    color: #8338ec;
}

.bg-remover-btn-apply {
    padding: 9px 10px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border: none;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    transition: all 0.2s;
}
.bg-remover-btn-apply:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(255,0,110,0.35);
}
.bg-remover-btn-apply:disabled {
    opacity: 0.7;
    cursor: not-allowed;
    transform: none;
}

.bg-remover-hint {
    font-size: 10px;
    color: #aaa;
    text-align: center;
    line-height: 1.4;
}

/* ========================================
   FIN SUPPRESSION DE FOND
   ======================================== */

/* ========================================
   BIBLIOTHÈQUE D'IMAGES — MODALE
   ======================================== */

#libraryModal {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.55);
    backdrop-filter: blur(4px);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
}

#libraryModal.hidden { display: none; }

.library-modal-content {
    background: #fff;
    border-radius: 18px;
    width: 100%;
    max-width: 860px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0,0,0,0.25);
    animation: libModalIn 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes libModalIn {
    from { opacity: 0; transform: scale(0.94) translateY(10px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* Header */
.library-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 22px 14px;
    border-bottom: 2px solid #f0f0f0;
    flex-shrink: 0;
}

.library-title-wrap {
    display: flex;
    align-items: center;
    gap: 10px;
}

.library-title-wrap i {
    font-size: 22px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

.library-title-wrap h3 {
    font-size: 17px;
    font-weight: 800;
    color: #000;
    margin: 0;
}

.library-badge {
    background: linear-gradient(90deg, rgba(255,0,110,0.1), rgba(131,56,236,0.1));
    border: 1px solid rgba(255,0,110,0.25);
    color: #ff006e;
    font-size: 10px;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 20px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Barre de recherche */
.library-search-bar {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border-bottom: 1px solid #f0f0f0;
    flex-shrink: 0;
}

.library-search-bar i {
    color: #aaa;
    font-size: 15px;
    flex-shrink: 0;
}

.library-search-bar input {
    flex: 1;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    padding: 8px 12px;
    font-size: 13px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.2s;
}

.library-search-bar input:focus { border-color: #ff006e; }

.library-search-bar button {
    padding: 8px 18px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border: none;
    border-radius: 8px;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    white-space: nowrap;
    transition: opacity 0.2s;
}
.library-search-bar button:hover { opacity: 0.88; }

/* Thèmes */
.library-themes-wrap {
    padding: 12px 22px 10px;
    flex-shrink: 0;
    border-bottom: 1px solid #f0f0f0;
}

.library-themes-label {
    font-size: 10px;
    font-weight: 700;
    color: #aaa;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    margin-bottom: 8px;
}

.library-themes {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}

.theme-btn {
    padding: 5px 12px;
    border: 2px solid #e8e8e8;
    border-radius: 20px;
    background: #f8f9fa;
    font-size: 12px;
    font-weight: 600;
    color: #555;
    cursor: pointer;
    transition: all 0.18s;
    white-space: nowrap;
}

.theme-btn:hover {
    border-color: #8338ec;
    color: #8338ec;
    background: rgba(131,56,236,0.06);
}

.theme-btn.active {
    border-color: #ff006e;
    background: linear-gradient(90deg, rgba(255,0,110,0.1), rgba(131,56,236,0.1));
    color: #ff006e;
}

/* ── Thèmes Événements (orange) ── */
.theme-btn--new {
    border-color: #ff6b35;
    background: linear-gradient(90deg, rgba(255,107,53,0.07), rgba(255,0,110,0.07));
    color: #d94f00;
    position: relative;
}
.theme-btn--new::before {
    content: '✦';
    font-size: 7px;
    position: absolute;
    top: -3px;
    right: -2px;
    color: #ff006e;
}
.theme-btn--new:hover {
    border-color: #ff006e;
    background: rgba(255,107,53,0.15);
    color: #ff006e;
    transform: translateY(-1px);
    box-shadow: 0 3px 8px rgba(255,0,110,0.2);
}

/* ── Thèmes Vector & Design Moderne (violet/indigo) ── */
.theme-btn--vector {
    border-color: #7c3aed;
    background: linear-gradient(90deg, rgba(124,58,237,0.07), rgba(59,130,246,0.07));
    color: #5b21b6;
    position: relative;
    font-weight: 700;
}
.theme-btn--vector::before {
    content: '◈';
    font-size: 7px;
    position: absolute;
    top: -3px;
    right: -2px;
    color: #7c3aed;
}
.theme-btn--vector:hover {
    border-color: #7c3aed;
    background: linear-gradient(90deg, rgba(124,58,237,0.18), rgba(59,130,246,0.12));
    color: #5b21b6;
    transform: translateY(-1px);
    box-shadow: 0 3px 10px rgba(124,58,237,0.25);
}
.theme-btn--vector.active {
    border-color: #7c3aed;
    background: linear-gradient(90deg, rgba(124,58,237,0.18), rgba(59,130,246,0.15));
    color: #5b21b6;
}

/* Séparateur entre sections de thèmes */
.library-themes-divider {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    font-size: 10px;
    color: #aaa;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.8px;
    margin: 4px 0 2px;
    white-space: nowrap;
}
.library-themes-divider::before,
.library-themes-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: #e8e8e8;
}

/* Grille images */
.library-grid-wrap {
    flex: 1;
    overflow-y: auto;
    padding: 16px 22px 8px;
}

.library-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 12px;
}

/* Loader */
.library-loading {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 50px 20px;
    gap: 14px;
    color: #aaa;
    font-size: 13px;
}

.library-spinner {
    width: 36px;
    height: 36px;
    border: 3px solid #f0f0f0;
    border-top-color: #ff006e;
    border-radius: 50%;
    animation: libSpin 0.7s linear infinite;
}

@keyframes libSpin {
    to { transform: rotate(360deg); }
}

/* Empty state */
.library-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 50px 20px;
    color: #bbb;
}

.library-empty i {
    font-size: 36px;
    display: block;
    margin-bottom: 12px;
}

.library-empty p { font-size: 14px; }
.library-empty strong { color: #555; }

/* Item image */
.lib-img-item {
    cursor: pointer;
    border-radius: 10px;
    overflow: hidden;
    transition: transform 0.18s;
}

.lib-img-item:hover { transform: translateY(-3px); }

.lib-img-wrap {
    position: relative;
    aspect-ratio: 1;
    background: #f8f9fa;
    border-radius: 10px;
    overflow: hidden;
    border: 2px solid #efefef;
    transition: border-color 0.18s;
}

.lib-img-item:hover .lib-img-wrap { border-color: #ff006e; }

.lib-img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 0.2s;
}

.lib-img-item:hover .lib-img-wrap img { transform: scale(1.04); }

.lib-img-overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.18s;
}

.lib-img-item:hover .lib-img-overlay { opacity: 1; }

.lib-img-add-btn {
    padding: 8px 14px;
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border: none;
    border-radius: 8px;
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    display: flex;
    align-items: center;
    gap: 5px;
    transition: transform 0.15s;
}

.lib-img-add-btn:hover { transform: scale(1.06); }
.lib-img-add-btn:disabled { opacity: 0.7; cursor: not-allowed; }

.lib-img-tags {
    font-size: 10px;
    color: #888;
    padding: 5px 4px 0;
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
    text-align: center;
}

/* Pagination */
.library-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px 0 4px;
    flex-wrap: wrap;
}

.lib-page-btn {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    border: 2px solid #e0e0e0;
    background: #f8f9fa;
    font-size: 13px;
    font-weight: 700;
    color: #555;
    cursor: pointer;
    transition: all 0.15s;
}

.lib-page-btn:hover { border-color: #8338ec; color: #8338ec; }

.lib-page-btn.active {
    background: linear-gradient(90deg, #ff006e, #8338ec);
    border-color: transparent;
    color: #fff;
}

.lib-page-dots { color: #bbb; font-size: 13px; padding: 0 2px; }

.library-no-key {
    background: #fffbf0;
    border: 2px dashed #fbbf24;
    border-radius: 12px;
    padding: 30px 20px !important;
    color: #92400e !important;
}
.library-no-key i { color: #f59e0b; }
.library-no-key a { color: #ff006e; font-weight: 700; }
.library-no-key code {
    background: #fff3cd;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: 10px;
    font-family: monospace;
}

/* Crédit */
.library-credit {
    text-align: center;
    font-size: 10px;
    color: #bbb;
    padding: 8px 22px 14px;
    flex-shrink: 0;
    border-top: 1px solid #f0f0f0;
}

.library-credit a { color: #8338ec; text-decoration: none; }
.library-credit a:hover { text-decoration: underline; }

/* ========================================
   FIN BIBLIOTHÈQUE D'IMAGES
   ======================================== */

/* ══ ONGLETS BIBLIOTHEQUE ══ */
.lib-tabs { display:flex; border-bottom:2px solid #eee; margin:0 -24px; padding:0 24px; background:#fafafa; flex-shrink:0; }
#panelPixabay { display:flex; flex-direction:column; flex:1; min-height:0; overflow:hidden; }
.lib-tab { display:flex; align-items:center; gap:7px; padding:12px 18px; font-size:14px; font-weight:600; border:none; background:none; color:#aaa; cursor:pointer; border-bottom:3px solid transparent; margin-bottom:-2px; transition:all .2s; white-space:nowrap; }
.lib-tab:hover { color:#666; }
.lib-tab.lib-tab--active { color:#ff006e; border-bottom-color:#ff006e; }
.lib-tab-pill { font-size:10px; font-weight:700; background:linear-gradient(135deg,#ff006e,#8338ec); color:#fff; padding:2px 7px; border-radius:20px; }
.lib-tab-count { font-size:11px; font-weight:700; background:#8338ec; color:#fff; padding:2px 8px; border-radius:20px; }

/* ══ MA BIBLIOTHEQUE ══ */
#panelMyLib { padding-top: 10px; }
.mylib-cats-bar { padding:8px 0 12px; border-bottom:1px solid #eee; flex-shrink:0; }
.mylib-cats-list { display:flex; flex-wrap:wrap; gap:6px; }
.mylib-cat-btn { display:flex; align-items:center; gap:5px; padding:6px 13px; border-radius:20px; border:1.5px solid #e0e0ee; background:#f8f8ff; color:#555; font-size:13px; font-weight:600; cursor:pointer; transition:all .15s; }
.mylib-cat-btn:hover { border-color:#8338ec; color:#8338ec; background:#f0e8ff; }
.mylib-cat-btn.active { border-color:#8338ec; background:#8338ec; color:#fff; }
.mylib-cat-n { font-size:11px; background:rgba(0,0,0,.12); padding:1px 6px; border-radius:20px; }
.mylib-cat-btn.active .mylib-cat-n { background:rgba(255,255,255,.28); }
.mylib-grid-wrap { flex:1; overflow-y:auto; padding:12px 16px 16px; min-height:0; }
.mylib-grid-wrap { padding: 14px 0 8px; }
.mylib-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(130px,1fr)); gap:12px; }
.mylib-img-item { border-radius:10px; overflow:hidden; border:2px solid transparent; background:#fff; box-shadow:0 1px 6px rgba(0,0,0,.07); transition:all .2s; cursor:pointer; }
.mylib-img-item:hover { border-color:#ff006e; transform:translateY(-2px); box-shadow:0 5px 16px rgba(255,0,110,.14); }
.mylib-img-wrap { position:relative; width:100%; aspect-ratio:1; background:repeating-conic-gradient(#f0f0f0 0% 25%,#fff 0% 50%) 0 0/12px 12px; overflow:hidden; }
.mylib-img-wrap img { width:100%; height:100%; object-fit:contain; padding:6px; display:block; transition:transform .2s; }
.mylib-img-item:hover .mylib-img-wrap img { transform:scale(1.06); }
.mylib-img-overlay { position:absolute; inset:0; background:rgba(255,0,110,.78); display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity .2s; }
.mylib-img-item:hover .mylib-img-overlay { opacity:1; }
.mylib-add-btn { background:#fff; color:#ff006e; border:none; border-radius:7px; padding:7px 12px; font-size:13px; font-weight:700; cursor:pointer; display:flex; align-items:center; gap:5px; transition:transform .15s; }
.mylib-add-btn:hover { transform:scale(1.07); }
.mylib-add-btn:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.mylib-img-label { padding:5px 7px; font-size:10px; color:#999; text-align:center; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; border-top:1px solid #f0f0f0; }
.mylib-loader { grid-column:1/-1; text-align:center; padding:40px 0; color:#aaa; font-size:14px; }
.mylib-spinner { width:28px; height:28px; border:3px solid #eee; border-top-color:#8338ec; border-radius:50%; animation:mylibSpin .7s linear infinite; margin:0 auto 10px; }
@keyframes mylibSpin { to { transform:rotate(360deg); } }
.mylib-empty { grid-column:1/-1; text-align:center; padding:50px 20px; color:#bbb; }
.mylib-empty i { font-size:40px; display:block; margin-bottom:12px; }
.mylib-empty p { font-size:14px; line-height:1.6; }
.mylib-empty a { color:#8338ec; font-weight:600; text-decoration:none; }
.mylib-empty a:hover { text-decoration:underline; }

/* Pagination Ma Bibliotheque */
.mylib-pagination { display:flex; justify-content:center; align-items:center; gap:6px; padding:16px 0 8px; flex-wrap:wrap; }

/* ══ COLORIZE BUTTON ══ */
.control-btn--color { position: relative; overflow: hidden; background: linear-gradient(135deg, #ff006e, #8338ec) !important; color: #fff !important; border-color: transparent !important; }
.control-btn--color i { pointer-events: none; position: relative; z-index: 1; }
.control-btn--color:hover { transform: scale(1.1); box-shadow: 0 3px 12px rgba(131,56,236,.4); }
/* ══ FIX SCROLL MODAL BIBLIOTHÈQUE SUR MOBILE ══ */
@media (max-width: 768px) {
    #libraryModal {
        align-items: flex-start !important;
        padding: 0 !important;
        overflow: hidden !important;
    }
    .library-modal-content {
        width: 100% !important;
        max-width: 100% !important;
        max-height: 100vh !important;
        height: 100vh !important;
        border-radius: 0 !important;
        display: flex !important;
        flex-direction: column !important;
        overflow: hidden !important;
    }
    .library-modal-header { flex-shrink: 0 !important; }
    .lib-tabs { flex-shrink: 0 !important; }
    #panelPixabay:not([style*="display: none"]):not([style*="display:none"]) {
        flex: 1 1 auto !important; min-height: 0 !important;
        overflow: hidden !important; display: flex !important; flex-direction: column !important;
    }
    #panelMyLib:not([style*="display: none"]):not([style*="display:none"]) {
        flex: 1 1 auto !important; min-height: 0 !important;
        overflow: hidden !important; display: flex !important; flex-direction: column !important;
    }
    .library-search-bar { flex-shrink: 0 !important; }
    .library-themes-wrap {
        flex-shrink: 0 !important; max-height: 130px !important;
        overflow-y: auto !important; -webkit-overflow-scrolling: touch !important;
    }
    .library-grid-wrap {
        flex: 1 1 auto !important; overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important; overscroll-behavior: contain !important; min-height: 0 !important;
    }
    .mylib-cats-bar { flex-shrink: 0 !important; }
    .mylib-grid-wrap {
        flex: 1 1 auto !important; overflow-y: auto !important;
        -webkit-overflow-scrolling: touch !important; overscroll-behavior: contain !important; min-height: 0 !important;
    }
    .mylib-pagination, .library-pagination { flex-shrink: 0 !important; }
}

/* ══ BARRE RECHERCHE MA BIBLIOTHÈQUE — résultat vide ══ */
.mylib-search-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 50px 20px;
    color: #bbb;
}
.mylib-search-empty i { font-size: 36px; display: block; margin-bottom: 10px; }
.mylib-search-empty p { font-size: 14px; }
