/* AZ Shirt Customizer — Macorner-inspired panel */
.azshirt-wrap{font-family:-apple-system,Segoe UI,Roboto,sans-serif;margin:14px 0}
.azshirt-panel{border:1px solid #e1e5eb;border-radius:12px;padding:18px;background:#f7f8fa}
.azshirt-panel-head{font-weight:800;font-size:14px;letter-spacing:1px;color:#1a1a1a;text-align:center;margin-bottom:8px}
.azshirt-guide{display:block;text-align:center;font-size:12px;color:#2563eb;text-decoration:none;margin-bottom:16px}
.azshirt-guide:hover{text-decoration:underline}

.azshirt-field{margin-bottom:14px}
.azshirt-label{display:block;font-weight:700;font-size:13px;color:#1a1a1a;margin-bottom:8px}
.azshirt-req{color:#ef4444}

.azshirt-count-row{display:flex;gap:6px;flex-wrap:nowrap;justify-content:flex-start}
.azshirt-count-btn{flex:1;min-width:0;max-width:56px;width:auto;height:40px;border:1.5px solid #d1d5db;border-radius:6px;background:#fff;font-size:15px;font-weight:700;color:#1a1a1a;cursor:pointer;transition:all .15s;padding:0}
.azshirt-count-btn:hover{border-color:#f97316;color:#f97316}
.azshirt-count-btn.is-active{border-color:#f97316;color:#f97316;background:#fff7ed;box-shadow:0 0 0 1px #f97316 inset}

.azshirt-slots{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:10px}
.azshirt-slot{position:relative;aspect-ratio:1/1;border:1.5px dashed #d1d5db;border-radius:10px;background:#fff;cursor:pointer;overflow:hidden;display:flex;align-items:center;justify-content:center;transition:border-color .15s}
.azshirt-slot:hover{border-color:#f97316}
.azshirt-slot.is-filled{border-style:solid;border-color:#10b981;cursor:default}
.azshirt-slot.is-extra{opacity:.55}
.azshirt-slot.is-extra:hover{opacity:1}

/* Background variant swatches (v0.7.0) */
.azshirt-bg-swatches{display:grid;grid-template-columns:repeat(auto-fill,minmax(64px,1fr));gap:8px}
.azshirt-bg-swatch{position:relative;aspect-ratio:1/1;border:2px solid #e5e7eb;border-radius:8px;padding:0;background:#fff;cursor:pointer;overflow:hidden;transition:all .15s}
.azshirt-bg-swatch:hover{border-color:#f97316}
.azshirt-bg-swatch.is-active{border-color:#f97316;box-shadow:0 0 0 2px #fff7ed inset}
.azshirt-bg-swatch img{width:100%;height:100%;object-fit:cover;display:block}

/* Text input field (v0.7.0) */
.azshirt-textfield .azshirt-label{display:flex;align-items:center;justify-content:space-between}
.azshirt-textfield-count{font-size:11px;color:#6b7280;font-weight:500;margin-left:6px}
.azshirt-text-input{width:100%;padding:10px 12px;border:1.5px solid #d1d5db;border-radius:8px;font-size:14px;background:#fff;box-sizing:border-box;font-family:inherit}
.azshirt-text-input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 2px #fff7ed}
.azshirt-slot.is-processing{border-color:#f97316}
.azshirt-slot-icon{font-size:24px;color:#9ca3af}
.azshirt-slot-label{position:absolute;bottom:4px;font-size:11px;color:#6b7280;font-weight:600}
.azshirt-slot img{width:100%;height:100%;object-fit:cover}
.azshirt-slot .azshirt-slot-spinner{position:absolute;inset:0;background:rgba(255,255,255,.8);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:4px;font-size:10px;color:#f97316;font-weight:700}
.azshirt-slot .azshirt-slot-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.65);color:#fff;border:none;cursor:pointer;font-size:12px;line-height:20px;padding:0;z-index:2}
.azshirt-slot .azshirt-slot-remove:hover{background:#ef4444}

.azshirt-btn{padding:12px 16px;border-radius:8px;border:none;background:#f97316;color:#fff;font-weight:700;cursor:pointer;font-size:14px;width:100%}
.azshirt-btn:hover{background:#ea580c}
.azshirt-btn-ghost{background:#fff;color:#f97316;border:1.5px solid #f97316}
.azshirt-btn-ghost:hover{background:#fff7ed}

.azshirt-hidden{display:none!important}

/* LIVE inline editor (sits where gallery was) */
.azshirt-gallery-hidden{display:none!important}
.azshirt-live{position:relative;max-width:620px;margin:0 auto 20px}
.azshirt-live-canvas-holder{position:relative;border-radius:8px;background:#fff}
.azshirt-live-canvas-holder .canvas-container{margin:0 auto;max-width:100%}
.azshirt-live-canvas-holder .canvas-container canvas{max-width:100%;height:auto!important}
.azshirt-live-toolbar{display:flex;gap:8px;justify-content:center;margin-top:10px;flex-wrap:wrap}
.azshirt-tool{width:38px;height:38px;border-radius:6px;border:1px solid #e5e7eb;background:#f3f4f6;color:#374151;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.azshirt-tool:hover{background:#e5e7eb;color:#111;border-color:#9ca3af}
.azshirt-tool:active{transform:scale(.95)}
.azshirt-live-hint{font-size:13px;color:#6b7280;text-align:center;margin:12px 0 0;line-height:1.5}

/* Modal (preview-only, v0.4) */
.azshirt-modal{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:999999;display:flex;align-items:center;justify-content:center;padding:20px}
.azshirt-modal-inner{background:#fff;border-radius:12px;padding:24px;max-width:860px;width:100%;max-height:92vh;overflow:auto;position:relative}
.azshirt-modal-inner h3{margin:0 0 14px;font-size:18px}
.azshirt-modal-close{position:absolute;top:8px;right:12px;width:36px;height:36px;border:none;background:transparent;font-size:28px;cursor:pointer;color:#6b7280;line-height:1}
.azshirt-modal-close:hover{color:#1a1a1a}

.azshirt-modal-preview{text-align:center;max-width:680px;padding:32px 28px}
.azshirt-modal-title{margin:0 0 6px;font-size:20px;font-weight:800;color:#1a1a1a}
.azshirt-modal-sub{margin:0 0 18px;font-size:13px;color:#6b7280}
.azshirt-preview-img-wrap{margin:0 auto 20px;max-width:520px}
.azshirt-preview-img-wrap img{display:block;width:100%;height:auto;border-radius:8px}
.azshirt-btn-addtocart{letter-spacing:1px;font-size:16px;padding:14px 32px;width:auto;min-width:200px}

.azshirt-canvas-holder{position:relative;border-radius:10px;overflow:hidden;background:#f7f8fa;aspect-ratio:1/1;max-width:720px;margin:0 auto}
.azshirt-overlay{position:absolute;inset:0;background:rgba(255,255,255,.85);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;z-index:10}
.azshirt-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top-color:#f97316;border-radius:50%;animation:azsspin .9s linear infinite}
@keyframes azsspin{to{transform:rotate(360deg)}}
.azshirt-overlay-text{font-size:14px;color:#374151;font-weight:700}
.azshirt-hint{font-size:12px;color:#6b7280;margin:10px 0 0;text-align:center}

/* Prominent hint ABOVE the canvas so users see it first */
.azshirt-hint-top{background:#fff7ed;border:1px solid #fed7aa;border-radius:8px;padding:10px 14px;font-size:13px;color:#9a3412;text-align:left;margin:0 0 14px;line-height:1.4}
.azshirt-hint-top .azshirt-hint-icon{font-size:18px;margin-right:6px;display:inline-block;transform:translateY(2px)}
.azshirt-hint-top strong{color:#9a3412}

/* Toolbar under canvas */
.azshirt-toolbar{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:12px}
.azshirt-btn-mini{padding:7px 12px;border-radius:6px;background:#fff;border:1px solid #d1d5db;font-size:12px;color:#374151;cursor:pointer;font-weight:600;transition:all .15s}
.azshirt-btn-mini:hover{border-color:#f97316;color:#f97316;background:#fff7ed}

/* v0.8.0 � AI Remix */
.azshirt-btn-remix{background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff;margin-top:8px;border:none}
.azshirt-btn-remix:hover{opacity:.92;transform:translateY(-1px)}
.azshirt-modal-remix{max-width:920px;text-align:center}
.azshirt-remix-presets{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:12px 0 8px;padding:10px;background:#f8fafc;border-radius:10px}
.azshirt-remix-preset{background:#fff;border:2px solid #e5e7eb;border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;color:#374151;cursor:pointer;transition:all .15s;display:inline-flex;align-items:center;gap:6px;line-height:1.3}
.azshirt-remix-preset:hover{border-color:#f97316;background:#fff7ed}
.azshirt-remix-preset.is-active{background:linear-gradient(135deg,#f97316,#ec4899);color:#fff;border-color:transparent;box-shadow:0 4px 12px rgba(249,115,22,.35)}
.azshirt-remix-preset .em{font-size:15px}
.azshirt-remix-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 20px;min-height:200px}
.azshirt-remix-loading p{margin:0;font-size:15px;color:#6b7280;line-height:1.6}
.azshirt-remix-compare{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:12px}
.azshirt-remix-card{border:2px solid #e5e7eb;border-radius:10px;padding:14px;transition:border-color .15s;background:#fafbff}
.azshirt-remix-card[data-pick=ai]{background:linear-gradient(135deg,#faf5ff,#fdf2f8)}
.azshirt-remix-card:hover{border-color:#f97316}
.azshirt-remix-img{aspect-ratio:1/1;background:repeating-conic-gradient(#f3f4f6 0 25%,#fff 0 50%) 50%/20px 20px;border-radius:6px;overflow:hidden;margin-bottom:10px;display:flex;align-items:center;justify-content:center}
.azshirt-remix-img img{max-width:100%;max-height:100%;object-fit:contain}
.azshirt-remix-card h4{margin:0 0 8px;font-size:15px;font-weight:700}
.azshirt-btn-pick{width:100%;font-size:13px;padding:10px;background:#1a1a1a;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700}
.azshirt-btn-pick:hover{opacity:.9}
.azshirt-btn-pick-ai{background:linear-gradient(135deg,#8b5cf6,#ec4899)}
.azshirt-remix-error{padding:40px 20px;text-align:center}
.azshirt-remix-error p{font-size:15px;color:#1a1a1a}
.azshirt-btn-link{background:none;border:none;color:#f97316;cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}
.azshirt-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:#1a1a1a;color:#fff;padding:12px 20px;border-radius:8px;font-size:14px;z-index:9999999;box-shadow:0 8px 24px rgba(0,0,0,.3)}
@media (max-width:640px){.azshirt-remix-compare{grid-template-columns:1fr}}
