/* ═══════════════════════════════════════════════════════
   Stock propio · estilos compartidos (Fase 1)
   Reutiliza vars de assets/bc-dark.css cuando aplican; agrega lo que es propio.
   ═══════════════════════════════════════════════════════ */

:root{
  --sp-bg:    #111418;
  --sp-sf:    #1e2228;
  --sp-sf2:   #252b35;
  --sp-bd:    #2d3545;
  --sp-tx:    #f0f4fa;
  --sp-tx2:   #c8d4e0;
  --sp-tx3:   #8899aa;
  --sp-g:     #7DC242;
  --sp-g2:    #5fa832;
  --sp-rd:    #f87171;
  --sp-yw:    #fbbf24;
  --sp-cy:    #38bdf8;
  --sp-pp:    #a78bfa;
  --sp-radius:12px;
  --sp-shadow:0 2px 12px rgba(0,40,100,.06);
}

*{box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--sp-bg);color:var(--sp-tx);margin:0;padding:0;min-height:100vh}
a{color:var(--sp-g);text-decoration:none}
a:hover{color:var(--sp-g2)}

/* ── Layout ── */
.sp-wrap{max-width:1280px;margin:0 auto;padding:24px 20px 60px}
.sp-breadcrumb{font-size:13px;color:var(--sp-tx3);margin-bottom:10px}
.sp-breadcrumb a{color:var(--sp-tx3);font-weight:500}
.sp-breadcrumb a:hover{color:var(--sp-g)}
.sp-breadcrumb .sep{margin:0 6px;color:var(--sp-bd)}
.sp-breadcrumb .curr{color:var(--sp-tx2);font-weight:600}

.sp-page-head{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:16px;margin-bottom:24px}
.sp-page-head h1{font-size:1.7rem;font-weight:800;margin:0 0 4px;color:var(--sp-tx)}
.sp-page-head .sub{font-size:14px;color:var(--sp-tx3)}

/* ── Botones ── */
.sp-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 16px;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;border:1px solid var(--sp-bd);background:var(--sp-sf2);color:var(--sp-tx);transition:all .15s;text-decoration:none}
.sp-btn:hover{border-color:var(--sp-g);color:var(--sp-g)}
.sp-btn-primary{background:linear-gradient(135deg,var(--sp-g),var(--sp-g2));border:none;color:#fff}
.sp-btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 14px rgba(125,194,66,.35);color:#fff}
.sp-btn-ghost{background:transparent}
.sp-btn-sm{padding:6px 10px;font-size:12px}
.sp-btn-danger{border-color:rgba(248,113,113,.4);color:var(--sp-rd)}
.sp-btn-danger:hover{background:rgba(248,113,113,.1);border-color:var(--sp-rd);color:var(--sp-rd)}

/* ── Cards / stats ── */
.sp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
@media(max-width:760px){.sp-stats{grid-template-columns:repeat(2,1fr)}}
.sp-stat{background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:var(--sp-radius);padding:18px;text-align:center;box-shadow:var(--sp-shadow)}
.sp-stat-val{font-size:2rem;font-weight:800;color:var(--sp-g);line-height:1.1}
.sp-stat-lbl{font-size:12px;color:var(--sp-tx3);margin-top:6px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}

.sp-card{background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:var(--sp-radius);padding:22px;margin-bottom:16px;box-shadow:var(--sp-shadow)}
.sp-card-title{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--sp-tx3);margin:0 0 14px;display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--sp-bd);padding-bottom:10px}

/* ── Toolbar ── */
.sp-toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:16px}
.sp-toolbar .grow{flex:1}
.sp-search{flex:1;min-width:200px;background:var(--sp-sf2);border:1px solid var(--sp-bd);border-radius:8px;padding:10px 14px;color:var(--sp-tx);font-size:14px;font-family:inherit;outline:none}
.sp-search:focus{border-color:var(--sp-g)}
.sp-select{background:var(--sp-sf2);border:1px solid var(--sp-bd);border-radius:8px;padding:9px 12px;color:var(--sp-tx);font-size:14px;font-family:inherit;outline:none;cursor:pointer}
.sp-select:focus{border-color:var(--sp-g)}

/* ── Tabla ── */
.sp-table-wrap{overflow-x:auto;border:1px solid var(--sp-bd);border-radius:var(--sp-radius);background:var(--sp-sf)}
.sp-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:auto}
.sp-table th{padding:8px 8px;text-align:left;font-size:10.5px;font-weight:700;color:var(--sp-tx3);text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--sp-bd);background:var(--sp-sf2);white-space:nowrap}
.sp-table td{padding:8px 8px;border-top:1px solid var(--sp-bd);color:var(--sp-tx2);font-size:13px}
.sp-table .sp-pill{padding:2px 7px;font-size:10.5px}
/* Stock-interno tabla — viewports chicos: ocultar 'Entrega' y 'Pie %' (info en ficha).
   Las columnas Actualizado + Días fueron fusionadas en una sola 'Última actualización'. */
@media (max-width: 1200px){
  #sp-table th:nth-child(7), #sp-table td:nth-child(7),
  #sp-table th:nth-child(8), #sp-table td:nth-child(8){display:none}
}
.sp-table tr:hover td{background:rgba(125,194,66,.04)}
.sp-table .row-actions{display:flex;gap:6px;justify-content:flex-end}
.sp-table tbody tr:hover{background:rgba(125,194,66,.04)}
.sp-row-link{color:var(--sp-tx);font-weight:700;text-decoration:none}
.sp-row-link:hover{color:var(--sp-g)}
.sp-icon-btn{background:transparent;border:1px solid var(--sp-bd);border-radius:6px;padding:5px 8px;color:var(--sp-tx3);cursor:pointer;font-size:14px;line-height:1}
.sp-icon-btn:hover{border-color:var(--sp-g);color:var(--sp-g)}
.sp-icon-btn.danger:hover{border-color:var(--sp-rd);color:var(--sp-rd)}

.sp-empty{padding:60px 20px;text-align:center;color:var(--sp-tx3)}
.sp-empty h3{color:var(--sp-tx2);font-weight:600;margin:0 0 6px;font-size:16px}
.sp-empty p{margin:0;font-size:14px}

/* ── Pill / Badge ── */
.sp-pill{display:inline-block;padding:2px 9px;border-radius:11px;font-size:11px;font-weight:700;letter-spacing:.4px}
.sp-pill-green{background:rgba(125,194,66,.15);color:var(--sp-g)}
.sp-pill-red{background:rgba(248,113,113,.15);color:var(--sp-rd)}
.sp-pill-amber{background:rgba(251,191,36,.15);color:var(--sp-yw)}
.sp-pill-grey{background:rgba(136,153,170,.15);color:var(--sp-tx3)}
.sp-pill-blue{background:rgba(96,165,250,.15);color:#60a5fa}

/* ── Sortable headers ── */
.sp-th-sort{position:relative;transition:background .12s}
.sp-th-sort:hover{background:rgba(125,194,66,.06)}
.sp-th-sort-active{color:var(--sp-g)}
.sp-sort-ind{display:inline-block;margin-left:4px;font-size:10px;color:var(--sp-g);min-width:8px}

/* ── Form (proyecto.html) ── */
.sp-tabs{display:flex;flex-wrap:wrap;gap:2px;border-bottom:2px solid var(--sp-bd);margin-bottom:20px}
.sp-tab{padding:10px 16px;background:none;border:none;color:var(--sp-tx3);font-size:14px;cursor:pointer;border-bottom:3px solid transparent;white-space:nowrap;font-family:inherit;font-weight:600;transition:all .15s}
.sp-tab.on{color:var(--sp-g);border-bottom-color:var(--sp-g)}
.sp-tab:hover:not(.on){color:var(--sp-tx2)}
.sp-tab.disabled{color:var(--sp-bd);cursor:not-allowed;opacity:.5}
.sp-tab .badge{margin-left:5px;font-size:9px;padding:1px 5px;border-radius:6px;background:var(--sp-bd);color:var(--sp-tx3);vertical-align:middle}

.sp-tab-content{display:none}
.sp-tab-content.on{display:block}

.sp-form-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px;align-items:start}
@media(max-width:900px){.sp-form-grid{grid-template-columns:minmax(0,1fr)}}

.sp-section{background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:var(--sp-radius);padding:20px;margin-bottom:16px;box-shadow:var(--sp-shadow)}
.sp-section-title{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--sp-tx3);margin:0 0 14px;border-bottom:1px solid var(--sp-bd);padding-bottom:8px}

.sp-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px;position:relative}
.sp-field label{font-size:12px;font-weight:600;color:var(--sp-tx2);display:flex;align-items:center;gap:5px}
.sp-field label .req{color:var(--sp-rd)}
.sp-field input[type=text],
.sp-field input[type=number],
.sp-field input[type=url],
.sp-field select,
.sp-field textarea{
  background:var(--sp-sf2);border:1px solid var(--sp-bd);border-radius:8px;
  padding:9px 12px;color:var(--sp-tx);font-size:14px;font-family:inherit;outline:none;
  transition:border-color .15s;width:100%;
}
.sp-field input:focus,.sp-field select:focus,.sp-field textarea:focus{border-color:var(--sp-g)}
.sp-field input::placeholder,.sp-field textarea::placeholder{color:var(--sp-tx3)}
.sp-field textarea{resize:vertical;min-height:90px;font-family:inherit}
.sp-field.invalid input,.sp-field.invalid select,.sp-field.invalid textarea{border-color:var(--sp-rd)}
.sp-field.valid input,.sp-field.valid select,.sp-field.valid textarea{border-color:var(--sp-g)}
.sp-field .hint{font-size:11px;color:var(--sp-tx3);margin-top:2px}
.sp-field .err{font-size:11px;color:var(--sp-rd);margin-top:2px;display:none}
.sp-field.invalid .err{display:block}
.sp-field .counter{font-size:11px;color:var(--sp-tx3);text-align:right;margin-top:2px}

.sp-row-2{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:12px}
.sp-row-3{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) minmax(0,1fr);gap:12px}
@media(max-width:560px){.sp-row-2,.sp-row-3{grid-template-columns:minmax(0,1fr)}}

/* Multi-select chips */
.sp-chips{display:flex;flex-wrap:wrap;gap:6px;padding:6px;background:var(--sp-sf2);border:1px solid var(--sp-bd);border-radius:8px;min-height:42px;align-items:flex-start}
.sp-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(125,194,66,.15);color:var(--sp-g);padding:4px 4px 4px 10px;border-radius:6px;font-size:12px;font-weight:600}
.sp-chip button{background:none;border:none;color:var(--sp-g);cursor:pointer;font-size:14px;padding:0 4px;line-height:1}
.sp-chips input{flex:1;min-width:120px;background:transparent;border:none;outline:none;color:var(--sp-tx);font-size:13px;font-family:inherit;padding:4px 6px}

/* Mapa */
.sp-map{height:240px;border-radius:8px;border:1px solid var(--sp-bd);background:var(--sp-sf2);overflow:hidden;margin-top:6px}
.sp-coords{font-size:11px;color:var(--sp-tx3);margin-top:4px;font-family:'Courier New',monospace}

/* Sticky save */
.sp-save-bar{
  position:sticky;bottom:0;left:0;right:0;
  background:rgba(17,20,24,.96);backdrop-filter:blur(10px);
  border-top:1px solid var(--sp-bd);
  padding:12px 20px;margin:24px -20px -60px;
  display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
  z-index:50;
}
.sp-save-status{font-size:12px;color:var(--sp-tx3);display:flex;align-items:center;gap:6px}
.sp-save-status.ok{color:var(--sp-g)}
.sp-save-status.dirty{color:var(--sp-yw)}
.sp-save-status.error{color:var(--sp-rd)}

/* Toast */
.sp-toast{position:fixed;bottom:30px;right:30px;padding:14px 20px;border-radius:10px;background:var(--sp-sf2);border:1px solid var(--sp-bd);color:var(--sp-tx);box-shadow:0 8px 24px rgba(0,0,0,.4);font-size:14px;font-weight:500;z-index:2000;animation:sp-toast-in .2s ease-out;max-width:360px}
.sp-toast.ok{border-color:var(--sp-g);color:var(--sp-g)}
.sp-toast.err{border-color:var(--sp-rd);color:var(--sp-rd)}
@keyframes sp-toast-in{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Modal genérico */
.sp-modal-bd{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(4px);z-index:1500;display:flex;align-items:center;justify-content:center;padding:20px}
.sp-modal{background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:14px;padding:24px;max-width:500px;width:100%;box-shadow:0 16px 40px rgba(0,0,0,.5)}
.sp-modal h3{margin:0 0 12px;font-size:18px;font-weight:700;color:var(--sp-tx)}
.sp-modal .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}

/* Coming soon placeholder for non-Phase 1 tabs */
.sp-placeholder{padding:80px 20px;text-align:center;background:var(--sp-sf);border:1px dashed var(--sp-bd);border-radius:var(--sp-radius);color:var(--sp-tx3)}
.sp-placeholder h3{color:var(--sp-tx2);font-size:18px;font-weight:600;margin:0 0 6px}
.sp-placeholder p{margin:0;font-size:14px}
.sp-placeholder .phase{display:inline-block;margin-top:12px;padding:4px 12px;border-radius:11px;background:rgba(125,194,66,.1);color:var(--sp-g);font-size:12px;font-weight:700}

/* No-access screen */
.sp-noaccess{text-align:center;padding:80px 20px;color:var(--sp-tx2)}
.sp-noaccess h2{color:var(--sp-rd);margin:0 0 10px;font-weight:700}
.sp-noaccess p{color:var(--sp-tx3);margin:0 0 20px}

/* ═══════════════════════════════════════════════════════════
   PROYECTO VISTA (read-only)
   ═══════════════════════════════════════════════════════════ */

/* HERO */
.pv-hero{display:grid;grid-template-columns:minmax(0,360px) minmax(0,1fr);gap:24px;margin-bottom:24px;background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:var(--sp-radius);padding:20px;box-shadow:var(--sp-shadow)}
@media(max-width:780px){.pv-hero{grid-template-columns:minmax(0,1fr)}}
.pv-hero-photo{position:relative;aspect-ratio:4/3;border-radius:10px;overflow:hidden;background:var(--sp-sf2);border:1px solid var(--sp-bd)}
.pv-hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.pv-photo-placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:48px;color:var(--sp-tx3);opacity:.4}
.pv-hero-info{display:flex;flex-direction:column;gap:8px;min-width:0}
.pv-hero-info h1{margin:0;font-size:28px;font-weight:800;color:var(--sp-tx);line-height:1.15;letter-spacing:-.02em}
.pv-sub{font-size:14px;color:var(--sp-tx2);margin-top:-2px}
.pv-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:4px}
.pv-tag{display:inline-block;padding:3px 9px;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border-radius:11px;background:var(--sp-sf2);border:1px solid var(--sp-bd);color:var(--sp-tx2)}
.pv-tag-activo{background:rgba(125,194,66,.18);color:var(--sp-g);border-color:rgba(125,194,66,.5);font-weight:800}
.pv-tag-inactivo{background:rgba(148,163,184,.18);color:#94a3b8;border-color:rgba(148,163,184,.4);font-weight:800}
.pv-tag-estado{background:rgba(168,139,250,.15);color:#a78bfa;border-color:rgba(168,139,250,.4)}
.pv-tag-modalidad{background:rgba(96,165,250,.13);color:#60a5fa;border-color:rgba(96,165,250,.4)}
.pv-tag-disp{background:rgba(125,194,66,.13);color:var(--sp-g);border-color:rgba(125,194,66,.4)}
.pv-tag-nodisp{background:rgba(148,163,184,.13);color:#94a3b8;border-color:rgba(148,163,184,.35)}
/* Toggle pill (listado) — para indicar que se puede clickear */
.sp-toggle{cursor:pointer;border:none;font-family:inherit;font-size:11px;padding:3px 11px;transition:opacity .15s}
.sp-toggle:hover{opacity:.75}
.pv-quick{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:8px;color:var(--sp-tx2);font-size:13px}
.pv-quick-i{display:inline-flex;align-items:center;gap:4px}
.pv-quick-i b{color:var(--sp-tx);font-weight:600;margin-left:2px}
.pv-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}

/* GRID 2 cols vista general */
.pv-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;align-items:start}
@media(max-width:900px){.pv-grid{grid-template-columns:minmax(0,1fr)}}

/* CARD genérica */
.pv-card{background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:var(--sp-radius);padding:18px 20px;margin-bottom:14px;box-shadow:var(--sp-shadow)}
.pv-card-title{font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--sp-tx3);margin:0 0 12px;border-bottom:1px solid var(--sp-bd);padding-bottom:8px}

/* Tabla key-value */
.pv-kv{width:100%;border-collapse:collapse}
.pv-kv tr{border-bottom:1px solid rgba(255,255,255,.04)}
.pv-kv tr:last-child{border-bottom:none}
.pv-kv td{padding:8px 0;font-size:14px;vertical-align:top}
.pv-kv-k{color:var(--sp-tx3);width:45%}
.pv-kv-v{color:var(--sp-tx);font-weight:600;text-align:right;word-break:break-word}

/* Texto descripción */
.pv-text{font-size:14px;line-height:1.6;color:var(--sp-tx2);white-space:pre-wrap}

/* Listas (equipamiento, áreas, entorno) */
.pv-list{margin:0;padding-left:18px;font-size:13px;color:var(--sp-tx2);line-height:1.65;columns:1}
.pv-list li{margin-bottom:2px}

/* Promociones */
.pv-promo{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.pv-promo:last-child{border-bottom:none}
.pv-promo-k{font-size:12px;font-weight:700;color:var(--sp-g);margin-bottom:4px}
.pv-promo-v{font-size:13px;color:var(--sp-tx2);line-height:1.5;white-space:pre-wrap}

/* Ubicación */
.pv-loc-row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.04);font-size:14px}
.pv-loc-row:last-of-type{border-bottom:none}
.pv-loc-k{color:var(--sp-tx3)}
.pv-loc-v{color:var(--sp-tx);font-weight:600;text-align:right}
.pv-empty-inline{color:var(--sp-tx3);font-style:italic}

/* Notas */
/* Notas a ancho completo, igual que las demás secciones (antes max-width:820px centrado) */
.pv-notas{font-size:14px;line-height:1.7;color:var(--sp-tx2)}
.pv-notas h1,.pv-notas h2,.pv-notas h3,.pv-notas h4{color:var(--sp-tx);margin:18px 0 8px;font-weight:700;line-height:1.3}
.pv-notas h1{font-size:20px}.pv-notas h2{font-size:18px}.pv-notas h3{font-size:16px}.pv-notas h4{font-size:14px;text-transform:uppercase;letter-spacing:.05em;color:var(--sp-g)}
.pv-notas p{margin:8px 0}
.pv-notas ul,.pv-notas ol{padding-left:22px;margin:6px 0}
.pv-notas li{margin-bottom:4px}
.pv-notas b,.pv-notas strong{color:var(--sp-tx);font-weight:700}
.pv-notas a{color:var(--sp-g)}

/* Tab count badge */
.pv-tab-count{font-size:11px;color:var(--sp-tx3);font-weight:500;margin-left:4px}

/* CHIPS de filtro (fotos por categoría) */
.pv-fotos-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.pv-chip{background:var(--sp-sf2);border:1px solid var(--sp-bd);color:var(--sp-tx2);padding:6px 14px;border-radius:18px;font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s}
.pv-chip:hover{border-color:var(--sp-g);color:var(--sp-tx)}
.pv-chip.on{background:var(--sp-g);color:#0a1010;border-color:var(--sp-g);font-weight:700}

/* STOCK actions bar */
.pv-stock-actions{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin:14px 0 4px;padding:14px 16px;background:var(--sp-sf);border:1px solid var(--sp-bd);border-radius:var(--sp-radius)}
.pv-stock-meta{font-size:12px;color:var(--sp-tx3);margin-left:auto}

/* DOCUMENTOS */
.pv-docs{display:flex;flex-direction:column;gap:8px}
.pv-doc{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--sp-sf2);border:1px solid var(--sp-bd);border-radius:10px;text-decoration:none;color:var(--sp-tx);transition:border-color .15s,transform .12s}
.pv-doc:hover{border-color:var(--sp-g);transform:translateX(3px)}
.pv-doc-icon{font-size:24px;flex-shrink:0;width:38px;text-align:center}
.pv-doc-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.pv-doc-name{font-size:14px;font-weight:600;color:var(--sp-tx);text-overflow:ellipsis;overflow:hidden;white-space:nowrap}
.pv-doc-meta{font-size:12px;color:var(--sp-tx3)}
.pv-doc-action{font-size:13px;color:var(--sp-g);font-weight:600;flex-shrink:0}

/* GALERÍA */
.pv-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.pv-gal-item{position:relative;aspect-ratio:1/1;background:var(--sp-sf2);border:1px solid var(--sp-bd);border-radius:10px;overflow:hidden;cursor:pointer;padding:0;font:inherit;color:inherit;transition:transform .12s ease,border-color .15s}
.pv-gal-item:hover{transform:scale(1.02);border-color:var(--sp-g)}
.pv-gal-item img{width:100%;height:100%;object-fit:cover;display:block}
.pv-gal-cap{position:absolute;left:0;right:0;bottom:0;padding:6px 8px;background:linear-gradient(transparent,rgba(0,0,0,.75));color:#fff;font-size:11px;text-align:left;line-height:1.3}
.pv-gal-wrap{position:relative}
.pv-gal-star{position:absolute;top:6px;right:6px;width:30px;height:30px;border-radius:50%;background:rgba(0,0,0,.65);border:1.5px solid rgba(255,255,255,.4);color:rgba(255,255,255,.55);font-size:16px;cursor:pointer;padding:0;display:flex;align-items:center;justify-content:center;transition:all .15s;z-index:2;backdrop-filter:blur(4px)}
.pv-gal-star:hover{background:rgba(0,0,0,.85);border-color:#facc15;color:#facc15}
.pv-gal-star.on{background:rgba(250,204,21,.95);border-color:#facc15;color:#1a1f27;font-weight:900}
.pv-gal-star:disabled{opacity:.5;cursor:wait}
.pv-gal-badge{position:absolute;top:6px;left:6px;background:#facc15;color:#1a1f27;font-size:9.5px;font-weight:900;padding:3px 7px;border-radius:5px;letter-spacing:.6px;z-index:2}

/* LIGHTBOX */
.pv-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:2000;display:flex;align-items:center;justify-content:center;padding:30px}
.pv-lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:8px;box-shadow:0 16px 60px rgba(0,0,0,.7)}
.pv-lb-close,.pv-lb-prev,.pv-lb-next{position:absolute;background:rgba(0,0,0,.55);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:50%;width:42px;height:42px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.pv-lb-close:hover,.pv-lb-prev:hover,.pv-lb-next:hover{background:rgba(0,0,0,.85)}
.pv-lb-close{top:20px;right:20px}
.pv-lb-prev{left:20px;top:50%;transform:translateY(-50%);width:48px;height:48px;font-size:26px}
.pv-lb-next{right:20px;top:50%;transform:translateY(-50%);width:48px;height:48px;font-size:26px}
.pv-lb-caption{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);color:#fff;font-size:13px;background:rgba(0,0,0,.55);padding:6px 14px;border-radius:14px;max-width:80vw;text-align:center}

/* ── Tab Modelos ──────────────────────────────────────── */
.pv-modelos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin-top:8px}
.pv-mod-card{background:var(--sp-bg2);border:1px solid var(--sp-br);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}
.pv-mod-plano-wrap{aspect-ratio:4/3;background:var(--sp-bg3);display:flex;align-items:center;justify-content:center;cursor:zoom-in;overflow:hidden;position:relative}
.pv-mod-plano{width:100%;height:100%;object-fit:contain;background:#fff}
.pv-mod-plano-ph{color:var(--sp-tx3);font-size:14px;text-align:center;padding:20px}
.pv-mod-info{padding:14px 16px;display:flex;flex-direction:column;gap:6px}
.pv-mod-name{font-size:18px;font-weight:700;color:var(--sp-tx1)}
.pv-mod-tip{font-size:13px;color:var(--sp-tx2);font-weight:500}
.pv-mod-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--sp-tx2);margin-top:4px}
.pv-mod-stats span{background:var(--sp-bg3);padding:3px 8px;border-radius:6px}
.pv-mod-reqs{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.pv-mod-req{font-size:11px;color:var(--sp-tx3);background:var(--sp-bg3);padding:2px 6px;border-radius:4px}
