/* ========== ADMIN CMS STYLES ========== */
.admin-login-modal .modal{max-width:400px}
.admin-login-modal .modal h3{text-align:center;margin-bottom:16px}

/* Admin tab (hidden by default) */
.tab.admin-tab{display:none}
.admin-on .tab.admin-tab{display:inline-flex}

/* Admin floating bar */
.admin-bar{display:none;position:fixed;bottom:24px;left:50%;transform:translateX(-50%);z-index:1500;background:var(--surface);border:1px solid var(--gold);border-radius:100px;padding:8px 12px;box-shadow:0 8px 32px rgba(0,0,0,.3);gap:8px;align-items:center;backdrop-filter:blur(16px);font-size:13px;font-weight:600;color:var(--dim);white-space:nowrap}
.admin-on .admin-bar{display:flex}
.admin-bar button{padding:8px 16px;font-size:12px;font-weight:600;border-radius:100px;cursor:pointer;border:1px solid var(--border);background:var(--surface-2);color:var(--dim);font-family:'Sora';transition:all .2s}
.admin-bar button:hover{border-color:var(--gold);color:var(--gold)}
.admin-bar button.edit-active{background:var(--gold);color:var(--btn-on-accent);border-color:var(--gold)}
.admin-bar .admin-user{color:var(--gold);font-weight:700;font-size:11px;letter-spacing:.3px}

/* Inline edit pencil buttons */
.edit-pencil{display:none;position:absolute;top:10px;right:10px;z-index:100;width:36px;height:36px;border-radius:50%;background:var(--gold);color:var(--btn-on-accent);border:none;cursor:pointer;font-size:16px;box-shadow:0 4px 16px rgba(0,0,0,.3);transition:all .2s;align-items:center;justify-content:center}
.edit-pencil:hover{transform:scale(1.1);box-shadow:0 6px 24px rgba(0,0,0,.4)}
.edit-mode .edit-pencil{display:flex}
.edit-wrap{position:relative}
/* Inline edit modal footer */
.ie-footer{display:flex;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
.ie-footer .btn{flex:1;justify-content:center}
/* Edit mode block hover feedback */
.edit-mode .edit-wrap{transition:outline .2s, background .2s;cursor:pointer}
.edit-mode .edit-wrap:hover{outline:2px solid rgba(212,168,69,.35);outline-offset:-2px}
/* Product detail edit modal elevation */
.modal-overlay.pd-edit-elevated{z-index:2500}
.modal-overlay.pd-edit-elevated .modal{z-index:2501}
/* Product image editor slots */
.pd-img-slots{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.pd-img-slot{display:flex;align-items:center;gap:16px;padding:12px;border:1px solid var(--border);border-radius:16px;background:var(--surface-2)}
.pd-img-slot.is-main{border-color:rgba(212,168,69,.3);background:linear-gradient(135deg,rgba(212,168,69,.05),rgba(212,168,69,.02))}
.pd-img-slot-label{min-width:80px;font-size:12px;font-weight:700;color:var(--dim);letter-spacing:.3px;text-transform:uppercase;flex-shrink:0}
.pd-img-slot.is-main .pd-img-slot-label{color:var(--gold)}
.pd-img-slot-preview{width:80px;height:80px;border-radius:10px;overflow:hidden;border:1px solid var(--border);flex-shrink:0;cursor:pointer;position:relative}
.pd-img-slot-preview:hover{border-color:var(--gold);box-shadow:0 2px 12px rgba(0,0,0,.1)}
.pd-img-slot-preview img{width:100%;height:100%;object-fit:cover}
.pd-img-slot-empty{width:80px;height:80px;border-radius:10px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--dim);font-size:24px;flex-shrink:0}
.pd-img-slot-actions{display:flex;gap:8px;align-items:center;flex:1;justify-content:flex-end}
.pd-img-slot-actions button{padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:11px;cursor:pointer;transition:all .2s;font-weight:600}
.pd-img-slot-actions button:hover{border-color:var(--gold);background:rgba(212,168,69,.08)}
.pd-img-slot-actions button.del{color:#e84393;border-color:rgba(232,67,147,.2)}
.pd-img-slot-actions button.del:hover{background:rgba(232,67,147,.08);border-color:#e84393}
/* Fullscreen image lightbox */
.img-lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);backdrop-filter:blur(12px);z-index:9999;align-items:center;justify-content:center;cursor:pointer}
.img-lightbox.open{display:flex}
.img-lightbox img{max-width:90vw;max-height:90vh;object-fit:contain;border-radius:12px;box-shadow:0 24px 80px rgba(0,0,0,.4)}
.img-lightbox-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.5);font-size:13px;pointer-events:none}
/* A+ block editor */
.aplus-block-ed{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:16px;margin-bottom:12px}
.aplus-block-ed h5{font-family:'Space Grotesk';font-size:13px;font-weight:700;margin:0 0 12px;letter-spacing:-.2px}
.aplus-block-row{display:flex;gap:16px;align-items:flex-start}
.aplus-img-thumb{width:72px;height:72px;border-radius:10px;overflow:hidden;border:1px solid var(--border);cursor:pointer;flex-shrink:0;transition:border-color .2s;position:relative}
.aplus-img-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.aplus-img-thumb:hover{border-color:var(--gold)}
.aplus-img-del{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:rgba(0,0,0,.55);color:#fff;cursor:pointer;font-size:13px;line-height:20px;text-align:center;padding:0;transition:background .2s;z-index:2}
.aplus-img-del:hover{background:#e84393}
.aplus-img-ph{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:22px;color:var(--dim);background:var(--surface)}
.aplus-block-fields{flex:1;min-width:0}
.aplus-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:3000;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px}
.aplus-preview-overlay img{max-width:85%;max-height:60vh;border-radius:12px;object-fit:contain}
.aplus-preview-close{position:absolute;top:20px;right:24px;width:40px;height:40px;border-radius:50%;border:none;background:rgba(255,255,255,.12);color:#fff;font-size:22px;cursor:pointer;transition:background .2s}
.aplus-preview-close:hover{background:rgba(255,255,255,.25)}
.aplus-preview-upload{padding:12px 28px;border-radius:100px;background:var(--gold);color:var(--btn-on-accent);font-size:13px;font-weight:600;cursor:pointer;font-family:'Sora';border:none;transition:filter .2s}
.aplus-preview-upload:hover{filter:brightness(1.1)}

/* Admin dashboard page */
.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:24px;padding:32px;margin-bottom:24px}
.admin-section h3{font-family:'Space Grotesk';font-size:20px;font-weight:700;letter-spacing:-.5px;margin-bottom:20px;display:flex;align-items:center;gap:10px}
.admin-section h3 .sec-icon{width:36px;height:36px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:18px;background:rgba(212,168,69,.08);flex-shrink:0}
.admin-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.admin-row.col3{grid-template-columns:1fr 1fr 1fr}
.admin-field{margin-bottom:16px}
.admin-field label{display:block;font-size:11px;font-weight:600;color:var(--light);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
.admin-field input,.admin-field textarea,.admin-field select{width:100%;padding:12px 16px;border:1px solid var(--border);border-radius:12px;font-family:'Sora';font-size:13px;color:var(--text);background:var(--surface-2);outline:none;transition:border .3s}
.admin-field input:focus,.admin-field textarea:focus{border-color:var(--gold)}
.admin-field textarea{resize:vertical;min-height:80px}
.admin-save{padding:10px 28px;font-size:13px;font-weight:600;border-radius:100px;cursor:pointer;border:none;background:var(--gold);color:var(--btn-on-accent);font-family:'Sora';transition:all .2s}
.admin-save:hover{filter:brightness(1.1);transform:translateY(-1px)}
.admin-save:disabled{opacity:.5;cursor:not-allowed;transform:none}
.admin-save-msg{display:inline-block;margin-left:12px;font-size:12px;font-weight:600}
.admin-save-msg.ok{color:var(--green)}
.admin-save-msg.err{color:#e84393}

/* Dynamic list editor (stats, cards, links, promo) */
.list-editor{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.list-item{background:var(--surface-2);border:1px solid var(--border);border-radius:16px;padding:16px;position:relative}
.list-item .remove-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--surface);color:var(--dim);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s}
.list-item .remove-btn:hover{border-color:#e84393;color:#e84393;background:rgba(232,67,147,.08)}
.add-item-btn{padding:10px 20px;font-size:12px;font-weight:600;border-radius:100px;cursor:pointer;border:1px dashed var(--border);background:transparent;color:var(--dim);font-family:'Sora';transition:all .2s;align-self:flex-start}
.add-item-btn:hover{border-color:var(--gold);color:var(--gold)}

/* Image upload field */
.img-upload{display:flex;align-items:center;gap:16px}
.img-upload .preview{width:80px;height:80px;border-radius:12px;border:1px solid var(--border);background:var(--surface-2);overflow:hidden;display:flex;align-items:center;justify-content:center}
.img-upload .preview img{width:100%;height:100%;object-fit:cover}
.img-upload .upload-btn{padding:10px 20px;font-size:12px;font-weight:600;border-radius:100px;cursor:pointer;border:1px solid var(--border);background:var(--surface-2);color:var(--dim);font-family:'Sora';transition:all .2s}
.img-upload .upload-btn:hover{border-color:var(--gold);color:var(--gold)}
.img-upload input[type=file]{display:none}