/* ── Heladero panel: Doc upload, doc list, tier badges, CTA, premium forms, admin forms ── */

/* ── Heladero documentation submit ── */
.doc-upload-area{border:2px dashed var(--border);border-radius:12px;padding:20px;text-align:center;
  cursor:pointer;transition:border-color .2s;margin-bottom:12px}
.doc-upload-area:hover{border-color:var(--teal)}
.doc-upload-area input[type=file]{display:none}
.doc-list{display:flex;flex-direction:column;gap:8px}
.doc-item{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--smoke);border-radius:8px;font-size:12px}
.doc-item .doc-name{flex:1;color:var(--navy);font-weight:500}
.doc-item .doc-status{font-size:11px;padding:2px 8px;border-radius:10px}

/* ── Field tier indicators ── */
.tier-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:6px;
  font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;vertical-align:middle;margin-left:6px}
.tier-free{background:var(--color-role-shop-bg);color:var(--color-role-shop-text)}
.tier-review{background:var(--color-role-editor-bg);color:var(--color-gold-dark)}
.tier-locked{background:var(--color-role-admin-bg);color:var(--color-error-dark)}
.tier-info-bar{display:flex;gap:8px;padding:10px 14px;background:var(--smoke);border-radius:10px;
  margin-bottom:14px;font-size:11px;color:var(--gray);align-items:center;flex-wrap:wrap}
.tier-info-bar span{display:inline-flex;align-items:center;gap:3px}
.doc-pending{background:var(--color-role-editor-bg);color:var(--color-gold-dark)}
.doc-approved{background:var(--color-role-shop-bg);color:var(--color-role-shop-text)}
.doc-rejected{background:var(--color-role-admin-bg);color:var(--color-error-dark)}

/* ── Editorial review queue badge ── */
.review-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:6px;
  font-size:11px;font-weight:600}
.review-badge.needs-review{background:var(--color-role-editor-bg);color:var(--color-gold-dark)}
.review-badge.approved{background:var(--color-role-shop-bg);color:var(--color-role-shop-text)}

/* ── HELADERO PANEL MODAL ── */
.hp-modal{background:var(--color-white);border-radius:var(--radius-xl);width:min(860px,96vw);max-height:90vh;
  overflow-y:auto;box-shadow:var(--sh-lg);position:relative;animation:modalIn .25s cubic-bezier(.2,0,.2,1)}
@media(max-width:900px){.hp-modal{width:min(720px,92vw)}}
@media(max-width:640px){.hp-modal{width:96vw;max-height:95vh;border-radius:16px 16px 0 0;margin-top:auto}}
.hp-hdr{padding:20px 24px;background:linear-gradient(135deg,var(--navy) 0%,#1A3350 100%);border-radius:var(--radius-xl) var(--radius-xl) 0 0;
  display:flex;align-items:center;gap:14px;color:var(--color-white)}
.hp-hdr h2{font-family:'Playfair Display',serif;font-size:22px;flex:1;letter-spacing:-.01em}
.hp-hdr .hp-close{background:rgba(255,255,255,.1);border:none;color:rgba(255,255,255,.6);font-size:18px;cursor:pointer;
  width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:var(--transition)}
.hp-hdr .hp-close:hover{background:rgba(255,255,255,.2);color:var(--color-white)}

/* ── Tab bar — Stripe-style (WO-UX-012) ── */
.hp-tabs{display:flex;padding:0 8px;background:var(--color-white);border-bottom:1px solid var(--border);overflow-x:hidden}
.hp-tab{flex:1;text-align:center;padding:12px 4px;font-size:12px;font-weight:500;cursor:pointer;
  white-space:nowrap;color:var(--gray);transition:color .15s;border:none;background:none;
  font-family:'DM Sans',sans-serif;border-bottom:2px solid transparent;margin-bottom:-1px;
  display:flex;align-items:center;justify-content:center;gap:5px;line-height:1}
.hp-tab:hover{color:var(--navy)}
.hp-tab.active{color:var(--teal);font-weight:600;border-bottom:2px solid var(--teal)}
.hp-tab-locked{opacity:.6;position:relative}
.hp-tab-locked:hover{opacity:.8;color:var(--navy)}

.hp-body{padding:20px 24px}

.hp-sabor-card{background:var(--color-white);border:1px solid var(--border);border-radius:12px;padding:12px;display:flex;gap:12px;align-items:flex-start;transition:box-shadow .2s,border-color .2s;position:relative}
.hp-sabor-card:hover{border-color:var(--teal);box-shadow:0 2px 12px rgba(0,0,0,.06)}
.hp-sabor-card.unavailable{opacity:.5}
.hp-sabor-card .sc-img,.hp-sabor-card .sc-img-wrap{width:52px;height:52px;min-width:52px;border-radius:10px;object-fit:cover;flex-shrink:0;cursor:pointer;transition:opacity .15s}
.hp-sabor-card .sc-img:hover,.hp-sabor-card .sc-img-wrap:hover{opacity:.75}
.hp-sabor-card .sc-img-wrap img{width:100%;height:100%;object-fit:cover;border-radius:inherit}
.hp-sabor-card .sc-body{flex:1;min-width:0}
.hp-sabor-card .sc-name{font-weight:600;font-size:14px;color:var(--navy);margin-bottom:2px;display:flex;align-items:center;gap:6px}
.hp-sabor-card .sc-desc{font-size:12px;color:var(--mid);margin-bottom:6px;line-height:1.4}
.hp-sabor-card .sc-stats{font-size:11px;color:var(--mid);display:flex;gap:8px;align-items:center;margin-bottom:6px}
.hp-sabor-card .sc-stats .stars{color:var(--color-gold)}
.hp-sabor-card .sc-toggles{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.hp-sabor-card .sc-toggle{font-size:11px;padding:5px 10px;border-radius:8px;border:1px solid var(--border);cursor:pointer;background:var(--smoke);transition:all .15s;user-select:none}
.hp-sabor-card .sc-toggle.active{border-color:var(--teal);background:#E0F7FA;color:#00695C;font-weight:600}
.hp-sabor-card .sc-toggle:hover{border-color:var(--teal)}
.hp-sabor-card .sc-actions{position:absolute;top:8px;right:8px;display:flex;gap:4px}
.hp-sabor-card .sc-actions button{background:none;border:none;cursor:pointer;font-size:14px;padding:4px 6px;border-radius:6px;color:var(--mid)}
.hp-sabor-card .sc-actions button:hover{background:var(--smoke);color:var(--red)}
.hp-sabor-card .sc-drag{cursor:grab;color:var(--mid);font-size:16px;display:flex;align-items:center;padding:0 4px}
.hp-sabor-card .sc-drag:active{cursor:grabbing}
.hp-sabor-card .sc-tag{font-size:11px;padding:2px 6px;border-radius:6px;display:inline-flex;align-items:center;gap:2px}

.hp-sabor-picker{background:var(--color-white);border:1px solid var(--border);border-radius:12px;padding:16px;margin-top:12px;max-height:400px;overflow-y:auto}
.hp-sabor-picker .sp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin-top:10px}
.hp-sabor-picker .sp-item{border:1px solid var(--border);border-radius:12px;padding:10px;text-align:center;cursor:pointer;transition:all .15s}
.hp-sabor-picker .sp-item:hover{border-color:var(--teal);background:#F0FDFA;transform:scale(1.02)}
.hp-sabor-picker .sp-item.added{opacity:.5}
.hp-sabor-picker .sp-item.added .sp-name,.hp-sabor-picker .sp-item.added img{pointer-events:none}
.hp-sabor-picker .sp-item img,.hp-sabor-picker .sp-item .sabor-card-img{width:48px;height:48px;border-radius:10px;margin:0 auto 6px}
.hp-sabor-picker .sp-name{font-size:12px;font-weight:600;color:var(--navy)}
.hp-sabor-picker .sp-desc{font-size:11px;color:var(--mid);margin-top:2px;line-height:1.4}
.hp-sabor-picker .sp-search{width:100%;padding:9px 12px;border:1px solid var(--border);border-radius:10px;font-size:13px;margin-bottom:8px;box-sizing:border-box}
.hp-sabor-picker .sp-search:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.1);outline:none}
.hp-sabor-picker .sp-families{display:flex;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.hp-sabor-picker .sp-fam{font-size:11px;padding:5px 12px;border-radius:8px;border:1px solid var(--border);cursor:pointer;background:var(--smoke);transition:all .15s}
.hp-sabor-picker .sp-fam.active{background:var(--teal);color:var(--color-white);border-color:var(--teal)}
.hp-sabor-picker .sp-fam:hover:not(.active){border-color:var(--teal);color:var(--teal)}

.hp-sabor-row{display:flex;align-items:center;gap:8px;margin-bottom:8px;padding:6px 8px;
  border-radius:10px;background:#FAFAFA;border:1px solid var(--border)}
.hp-sabor-row .sabor-card-img{flex-shrink:0}

.hp-section{margin-bottom:20px}
.hp-section h3{font-family:'Playfair Display',serif;font-size:16px;color:var(--navy);margin-bottom:12px;
  display:flex;align-items:center;gap:8px}

.hp-field{margin-bottom:12px}
.hp-field label{display:block;font-size:12px;font-weight:500;color:var(--gray);margin-bottom:4px;line-height:1.4}
.hp-field input,.hp-field textarea,.hp-field select{width:100%;padding:10px 12px;border:1px solid var(--border);
  border-radius:10px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--navy);
  background:var(--color-white);transition:border-color .15s,box-shadow .15s;box-sizing:border-box;min-height:44px}
.hp-field input:focus,.hp-field textarea:focus,.hp-field select:focus{
  border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.1);outline:none}
.hp-field input.error,.hp-field textarea.error{border-color:var(--color-error-dark);box-shadow:0 0 0 3px rgba(153,27,27,.08)}
.hp-field textarea{min-height:80px;resize:vertical}
.hp-field-hint{display:block;font-size:11px;color:var(--mid);margin-top:4px;font-style:italic;line-height:1.5}

.hp-btn{padding:11px 20px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;
  border:none;transition:all .15s;font-family:'DM Sans',sans-serif;min-height:44px}
.hp-btn-primary{background:var(--teal);color:var(--color-white)}
.hp-btn-primary:hover{background:var(--teal2)}
.hp-btn-primary:active{transform:scale(.98)}
.hp-btn-secondary{background:var(--smoke);color:var(--navy);border:1px solid var(--border)}
.hp-btn-secondary:hover{background:#E5E7EB;border-color:var(--teal);color:var(--teal)}
.hp-btn-secondary:active{transform:scale(.98)}

.hp-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.hp-stat{background:var(--smoke);border-radius:12px;padding:14px;text-align:center}
.hp-stat-val{font-family:'Playfair Display',serif;font-size:24px;color:var(--teal)}
.hp-stat-label{font-size:11px;color:var(--gray);margin-top:2px;line-height:1.4}

/* ── Premium fields in heladero panel (hp- prefix avoids conflict with panels.css .prem-section) ── */
.hp-prem-section{margin-bottom:16px}
.hp-prem-section-title{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);font-weight:700;margin-bottom:10px;padding-bottom:4px;border-bottom:1px solid var(--border)}
.prem-field{margin-bottom:10px}
.prem-field label{display:block;font-size:12px;color:var(--mid);margin-bottom:4px;font-weight:600}
.prem-field input,.prem-field textarea,.prem-field select{width:100%;padding:10px 12px;border-radius:8px;border:1.5px solid var(--border);font-size:13px;font-family:'DM Sans',sans-serif;box-sizing:border-box;min-height:44px;transition:border-color .15s,box-shadow .15s}
.prem-field input:focus,.prem-field textarea:focus,.prem-field select:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.1);outline:none}
.prem-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.prem-grid-full{grid-column:1/-1}

/* ── Admin forms ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fld{display:flex;flex-direction:column;gap:5px}
.fld label{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);line-height:1.4}
.fld input,.fld select,.fld textarea{padding:10px 12px;border-radius:8px;border:1.5px solid var(--border);
  font-size:13px;font-family:'DM Sans',sans-serif;outline:none;background:var(--color-white);color:var(--navy);
  min-height:44px;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}
.fld input:focus,.fld select:focus,.fld textarea:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.1)}
.fld textarea{resize:vertical;min-height:60px}
.fld.span2{grid-column:span 2}
.form-actions{display:flex;gap:8px;margin-top:18px;padding-top:14px;border-top:1px solid var(--border)}
.btn-save{flex:1;padding:12px;border-radius:10px;border:none;background:var(--teal);color:var(--color-white);
  font-size:13px;font-family:'DM Sans',sans-serif;font-weight:600;cursor:pointer;min-height:44px;transition:all .15s}
.btn-save:hover{background:var(--teal2)}
.btn-save:active{transform:scale(.98)}

/* ── Table utilities ── */
.tbl-search{width:100%;margin-bottom:12px;padding:10px 12px;border-radius:8px;
  border:1.5px solid var(--border);font-size:13px;font-family:'DM Sans',sans-serif;outline:none;box-sizing:border-box;min-height:44px;transition:border-color .15s,box-shadow .15s}
.tbl-search:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(13,148,136,.1)}
.tbl-action{padding:7px 12px;border-radius:8px;border:1.5px solid var(--border);
  background:var(--color-white);font-size:12px;font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .15s;min-height:36px}
.tbl-action:hover{border-color:var(--teal);color:var(--teal);background:#F0FDFA}
.pagination{display:flex;align-items:center;justify-content:space-between;margin-top:12px;font-size:13px;color:var(--mid)}
.pg-btn{padding:7px 14px;border-radius:8px;border:1.5px solid var(--border);
  background:var(--color-white);font-size:12px;font-family:'DM Sans',sans-serif;cursor:pointer;transition:all .15s;min-height:36px}
.pg-btn:hover:not(:disabled){border-color:var(--teal);color:var(--teal);background:#F0FDFA}
.pg-btn:disabled{opacity:.4;cursor:default}

/* ── Premium glow effect ── */
.hp-premium-glow{position:relative}
.hp-premium-glow::before{content:'';position:absolute;inset:-1px;border-radius:inherit;
  background:linear-gradient(135deg,rgba(13,148,136,.1),rgba(217,119,6,.1));
  opacity:0;transition:opacity .3s}
.hp-premium-glow:hover::before{opacity:1}

/* ── Accordion card arrows ── */
.hp-card-arrow{transition:transform .2s ease}
.hp-card-open{transform:rotate(180deg)}

/* ── Select dropdown enhancement ── */
.hp-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}

/* ── WO-UX-012: Subsección headers dentro de Perfil y Clientes ── */
.hp-subsec h3{font-family:'DM Sans',sans-serif !important;font-size:13px !important;
  font-weight:600;color:var(--navy);display:flex;align-items:center;gap:7px}
.hp-subsec h3::after{content:'';flex:1;height:1px;background:var(--border);margin-left:4px}
.hp-subsec+.hp-subsec{border-top:1px solid var(--border);padding-top:16px;margin-top:4px}
/* Header autónomo de subsección (usado cuando h3 lo reemplaza el gate card) */
.hp-subsec-hdr{font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;color:var(--navy);
  display:flex;align-items:center;gap:7px;margin-bottom:12px}
.hp-subsec-hdr::after{content:'';flex:1;height:1px;background:var(--border);margin-left:4px}

/* ── WO-UX-012: Premium gate mejorado ── */
.hp-gate{background:linear-gradient(150deg,var(--color-bg-cream,#FAF5EB),var(--smoke));
  border:1px solid var(--border);border-radius:14px;padding:20px 18px;cursor:pointer;
  text-align:center;position:relative;overflow:hidden;transition:box-shadow .2s}
.hp-gate:hover{box-shadow:0 4px 16px rgba(0,0,0,.08)}
.hp-gate::before{content:'';position:absolute;top:-20px;right:-20px;width:100px;height:100px;
  border-radius:50%;background:var(--prof-glow-gold,radial-gradient(circle,rgba(251,191,36,.18),transparent 70%));
  pointer-events:none}
.hp-gate-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;
  background:linear-gradient(135deg,var(--color-gold,#F59E0B),#D97706);color:#fff;
  font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px;
  box-shadow:0 2px 8px rgba(245,158,11,.3)}
.hp-gate-title{font-family:'DM Sans',sans-serif;font-size:14px;font-weight:600;color:var(--navy);margin-bottom:6px}
.hp-gate-desc{font-size:12px;color:var(--mid);margin-bottom:14px;line-height:1.5}
.hp-gate-preview{filter:blur(3px);opacity:.55;pointer-events:none;position:relative;
  border-radius:8px;overflow:hidden;margin-bottom:14px}
.hp-gate-preview::after{content:'';position:absolute;inset:0;
  background:linear-gradient(to bottom,transparent 40%,var(--color-bg-cream,#FAF5EB))}
.hp-gate-cta{display:inline-flex;align-items:center;gap:6px;padding:10px 22px;border-radius:10px;
  background:linear-gradient(135deg,var(--color-primary,#0B1F38),var(--color-primary-mid,#162D4A));
  color:#fff;font-size:13px;font-weight:600;pointer-events:none}

/* ── WO-UX-012: Stats KPI cards mejoradas ── */
.hp-stat{background:linear-gradient(160deg,var(--smoke),var(--color-white));
  border:1px solid var(--border);border-radius:12px;padding:14px;text-align:center;
  transition:transform .15s,box-shadow .15s}
.hp-stat:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.07)}
.hp-stat-ico{font-size:15px;line-height:1;margin-bottom:4px}
.hp-stat-val{font-family:'Playfair Display',serif;font-size:24px;color:var(--teal);font-weight:700}
.hp-stat-label{font-size:11px;color:var(--mid);margin-top:2px;line-height:1.4}

/* ── WO-UX-012: Skeleton shimmer para Stats loading ── */
@keyframes hp-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.hp-skeleton{background:linear-gradient(90deg,var(--smoke) 25%,#e8e8e8 50%,var(--smoke) 75%);
  background-size:200% 100%;animation:hp-shimmer 1.5s infinite linear;border-radius:8px}
.hp-skel-card{height:78px;border-radius:12px}
.hp-skel-line{height:12px;width:80%;margin:8px auto 0;border-radius:6px}
.hp-skel-line.lg{height:14px;width:60%}
.hp-skel-line.sm{height:10px;width:50%;margin-top:4px}
