@import url('https://fonts.googleapis.com/css2?family=Roboto+Mono:wght@400;500;600;700&display=swap');

/* Product Customizer - Front styles. Fuente: Roboto Mono */

.pc-wrap, .pc-modal { font-family: 'Roboto Mono', ui-monospace, SFMono-Regular, Menlo, monospace; }
.pc-wrap *, .pc-modal * { font-family: inherit; box-sizing: border-box; }

.pc-ico{width:18px;height:18px;display:inline-block;vertical-align:middle;flex-shrink:0}

.pc-wrap{margin:18px 0;padding:14px 16px;border:1px solid #e5e7eb;border-radius:12px;background:#fafaf9}
.pc-open-btn{display:inline-flex;align-items:center;gap:10px;padding:12px 22px;font-weight:600;letter-spacing:.02em;border-radius:999px;border:0;cursor:pointer;background:#111827;color:#fff;transition:transform .18s ease, background .18s ease;font-size:14px}
.pc-open-btn:hover{background:#1f2937;transform:translateY(-1px);color:#fff}
.pc-zone-hint{margin-top:10px;font-size:12px;color:#4b5563}
.pc-pill{display:inline-block;padding:3px 9px;margin:2px;background:#fff;border:1px solid #e5e7eb;border-radius:999px;font-size:11px;color:#111827}

/* Modal */
.pc-modal{position:fixed;inset:0;display:none;z-index:99999}
.pc-modal.open{display:block}
.pc-modal-backdrop{position:absolute;inset:0;background:rgba(15,23,42,.72);backdrop-filter:blur(6px)}
.pc-modal-dialog{position:absolute;inset:24px;background:#ffffff;border-radius:16px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.pc-modal-header{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid #eef2f7;background:#fff;flex-shrink:0}
.pc-modal-header h3{margin:0;font-size:16px;font-weight:600;color:#0f172a;letter-spacing:.01em}
.pc-icon-btn{background:transparent;border:0;cursor:pointer;font-size:26px;line-height:1;color:#475569;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;font-family:inherit}
.pc-icon-btn:hover{background:#f1f5f9}

.pc-modal-body{flex:1;display:grid;grid-template-columns:300px 1fr;min-height:0;overflow:hidden}
.pc-sidebar{border-right:1px solid #eef2f7;background:#fafafa;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}

.pc-panel-title{padding:14px 18px 8px;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:#64748b;font-weight:700;border-bottom:1px solid #eef2f7;background:#fff}
.pc-panel{padding:18px}
.pc-help{font-size:12px;color:#64748b;margin:0 0 14px;line-height:1.5}

.pc-btn-file{display:flex;align-items:center;justify-content:center;gap:8px;padding:24px 14px;border:2px dashed #cbd5e1;border-radius:10px;cursor:pointer;color:#475569;font-size:13px;transition:all .15s;background:#fff;text-align:center;margin:0}
.pc-btn-file:hover{border-color:#0f172a;background:#f8fafc;color:#0f172a}
.pc-btn-file input{display:none}
.pc-btn-file > span{display:inline-flex;align-items:center;gap:8px;flex-direction:column}
.pc-upload-status{font-size:11px;color:#0f172a;margin-top:10px;min-height:16px;word-break:break-word}

.pc-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.pc-row-stack{flex-direction:column;align-items:stretch;gap:6px}
.pc-row-btns{flex-wrap:wrap;gap:6px}
.pc-mini{font-size:11px;color:#475569;font-weight:500;text-transform:uppercase;letter-spacing:.05em}

.pc-mini-btn{flex:1 1 calc(50% - 3px);padding:8px 6px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:11px;color:#0f172a;font-weight:500;transition:all .15s;font-family:inherit;text-transform:uppercase;letter-spacing:.04em}
.pc-mini-btn:hover{background:#0f172a;color:#fff;border-color:#0f172a}
.pc-mini-btn.pc-danger-btn:hover{background:#dc2626;border-color:#dc2626;color:#fff}

input[type="range"]{width:100%;accent-color:#0f172a}

.pc-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 18px;border-radius:10px;font-size:13px;font-weight:600;border:0;cursor:pointer;transition:all .15s;text-decoration:none;font-family:inherit;letter-spacing:.02em}
.pc-btn-primary{background:#0f172a;color:#fff}
.pc-btn-primary:hover{background:#1e293b;color:#fff}
.pc-btn-primary:disabled{opacity:.6;cursor:wait}
.pc-btn-ghost{background:transparent;color:#475569;border:1px solid #d1d5db}
.pc-btn-ghost:hover{background:#f1f5f9}

.pc-object-tools{padding:14px 18px 18px;border-top:1px solid #eef2f7;margin-top:auto;background:#fff}

/* Canvas area */
.pc-canvas-area{display:flex;flex-direction:column;background:#f1f5f9;overflow:hidden;min-width:0}

.pc-variants{display:flex;flex-wrap:wrap;gap:18px;padding:12px 16px;border-bottom:1px solid #e2e8f0;background:#fff;flex-shrink:0}
.pc-variant-group{display:flex;flex-direction:column;gap:6px;min-width:0}
.pc-variant-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b;font-weight:600}
.pc-variant-label strong{color:#0f172a;text-transform:none;letter-spacing:0;font-weight:600;margin-left:4px}
.pc-color-row{display:flex;gap:6px;flex-wrap:wrap}
.pc-color-swatch{width:30px;height:30px;border-radius:50%;border:2px solid #e2e8f0;cursor:pointer;padding:0;position:relative;transition:transform .15s, border-color .15s;flex-shrink:0}
.pc-color-swatch:hover{transform:scale(1.1);border-color:#94a3b8}
.pc-color-swatch.active{border-color:#0f172a;box-shadow:0 0 0 3px rgba(15,23,42,.12)}
.pc-color-check{position:absolute;inset:0;display:none;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:700;text-shadow:0 0 3px rgba(0,0,0,.5)}
.pc-color-swatch.active .pc-color-check{display:flex}
.pc-size-row{display:flex;gap:6px;flex-wrap:wrap}
.pc-size-chip{padding:6px 14px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;font-size:12px;color:#0f172a;font-weight:600;font-family:inherit;letter-spacing:.02em;transition:all .15s;min-width:42px}
.pc-size-chip:hover{border-color:#94a3b8}
.pc-size-chip.active{background:#0f172a;color:#fff;border-color:#0f172a}

.pc-zone-switcher{display:flex;gap:6px;padding:12px 16px;border-bottom:1px solid #e2e8f0;background:#fff;overflow-x:auto;flex-wrap:wrap;flex-shrink:0}
.pc-zone-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:999px;cursor:pointer;font-size:12px;color:#475569;transition:all .15s;white-space:nowrap;font-weight:500;font-family:inherit}
.pc-zone-btn:hover{border-color:#0f172a;color:#0f172a}
.pc-zone-btn.active{background:#0f172a;color:#fff;border-color:#0f172a}
.pc-zone-btn.used::after{content:"●";color:#10b981;margin-left:4px;font-size:10px}
.pc-zone-price{font-size:11px;opacity:.7}

.pc-canvas-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:20px;overflow:auto;min-height:0}
.pc-stage{position:relative;width:500px;height:500px;max-width:100%;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 10px 30px rgba(15,23,42,.12)}
.pc-mockup-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;display:block;pointer-events:none;background:#fff}
.pc-stage .canvas-container{position:absolute !important;left:0 !important;top:0 !important;width:500px !important;height:500px !important;display:block !important;visibility:visible !important;opacity:1 !important;background:transparent !important}
.pc-stage canvas{position:absolute !important;left:0 !important;top:0 !important;display:block !important;visibility:visible !important;opacity:1 !important;max-width:none !important;max-height:none !important}

/* Footer */
.pc-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;border-top:1px solid #eef2f7;background:#fafafa;gap:16px;flex-wrap:wrap;flex-shrink:0}
.pc-summary{font-size:13px;color:#475569}
.pc-summary strong{color:#0f172a;font-size:15px;margin-left:6px}
.pc-actions{display:flex;gap:10px}

@media (max-width: 900px){
  .pc-modal-dialog{inset:0;border-radius:0}
  .pc-modal-body{grid-template-columns:1fr;grid-template-rows:auto 1fr}
  .pc-sidebar{border-right:0;border-bottom:1px solid #eef2f7;max-height:35vh}
}
