/* ============================================================
   MODULA LAB — catalog.css
   Catálogo por categoría · equipo · formulario · piezas insignia
   ============================================================ */

/* index label colors (cycle triad across all sections) */
.serv:nth-child(6) .serv-n{color:var(--blue);}

/* ---------- PROMO BAR + ADMIN ---------- */
:root{--promo-h:44px;}
.promo-bar{display:none;}
body.promo-on .promo-bar{display:flex;align-items:center;justify-content:center;gap:16px;position:fixed;top:0;left:0;right:0;z-index:801;height:var(--promo-h);padding:0 44px;background:linear-gradient(90deg,var(--red),var(--blue));color:#fff;text-align:center;}
.promo-txt{font-family:var(--mono);font-size:12px;letter-spacing:0.04em;line-height:1.25;}
.promo-txt strong{font-weight:700;}
.promo-close{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;color:#fff;font-size:22px;line-height:1;cursor:pointer;opacity:.85;padding:4px 8px;}
.promo-close:hover{opacity:1;}
body.promo-on .nav{top:var(--promo-h);}
@media(max-width:560px){:root{--promo-h:58px;}.promo-txt{font-size:11px;}}

.promo-admin-t{font-size:11px;letter-spacing:0.14em;text-transform:uppercase;color:var(--yellow);font-weight:700;}
.pa-check,.pa-field{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.06em;color:var(--cream-dim);text-transform:uppercase;}
.pa-field input,.pa-field select{font-family:var(--mono);font-size:13px;color:var(--cream);background:var(--bg-2);border:1px solid var(--line);border-radius:6px;padding:7px 10px;}
.pa-field input{width:84px;}
.pa-check input{width:16px;height:16px;accent-color:var(--blue);cursor:pointer;}

/* discount badge on product cards */
.vprod-disc{position:absolute;top:12px;right:12px;font-family:var(--mono);font-size:12px;font-weight:700;letter-spacing:0.03em;color:#fff;background:var(--red);padding:6px 11px;border-radius:100px;box-shadow:0 4px 14px rgba(0,0,0,0.4);z-index:3;}

/* per-product discount control (edit mode) */
.prod-disc-row{display:flex;align-items:center;gap:8px;padding:10px 15px 13px;border-top:1px solid var(--line);}
.pdr-l{font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--cream-faint);margin-right:auto;}
.pdr-val{width:74px;font-family:var(--mono);font-size:13px;color:var(--cream);background:var(--bg);border:1px solid var(--line);border-radius:5px;padding:6px 9px;}
.pdr-type{font-family:var(--mono);font-size:13px;color:var(--cream);background:var(--bg);border:1px solid var(--line);border-radius:5px;padding:6px 8px;}
.serv--feature{position:relative;background:linear-gradient(150deg,rgba(239,187,22,0.13),rgba(15,99,207,0.06)) !important;border:1px solid rgba(239,187,22,0.35);}
.serv--feature::before{background:var(--yellow) !important;}
.serv-badge{display:inline-block;align-self:flex-start;font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--bg);background:var(--yellow);padding:5px 10px;border-radius:100px;margin-bottom:14px;font-weight:700;}
.serv--feature .serv-n{margin-bottom:auto;}
main > section:nth-of-type(2) .index{color:var(--red);}
main > section:nth-of-type(3) .index{color:var(--yellow);}
main > section:nth-of-type(4) .index{color:var(--blue);}
main > section:nth-of-type(5) .index{color:var(--red);}
main > section:nth-of-type(6) .index{color:var(--yellow);}
main > section:nth-of-type(7) .index{color:var(--blue);}
main > section:nth-of-type(8) .index{color:var(--red);}
main > section:nth-of-type(9) .index{color:var(--yellow);}

/* ---------- PIEZAS INSIGNIA (curated) ---------- */
.insignia-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,20px);}
.ins{position:relative;border:1px solid var(--line);border-radius:4px;overflow:hidden;background:var(--bg-2);display:flex;flex-direction:column;}
.ins-img{position:relative;aspect-ratio:4/5;overflow:hidden;display:flex;align-items:center;justify-content:center;background:radial-gradient(120% 90% at 50% 30%,rgba(255,255,255,0.05),transparent 70%);}
.ins-img img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.ins:hover .ins-img img{transform:scale(1.06);}
.ins-cap{padding:18px 20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:4px;}
.ins-name{font-weight:700;font-size:18px;letter-spacing:0.04em;}
.ins-meta{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:0.13em;color:var(--cream-dim);}
.ins-tag{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:9px;letter-spacing:0.18em;text-transform:uppercase;color:var(--cream);background:rgba(13,13,12,0.6);backdrop-filter:blur(6px);padding:5px 9px;border-radius:100px;border:1px solid var(--line);}
@media(max-width:900px){.insignia-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.insignia-grid{grid-template-columns:1fr;}}

/* ---------- EQUIPO / TALLER ---------- */
.equipo-inner{display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(30px,5vw,72px);align-items:center;}
.equipo-stage{position:relative;display:flex;align-items:center;justify-content:center;min-height:380px;border:1px solid var(--line);border-radius:6px;background:radial-gradient(80% 70% at 50% 40%,rgba(15,99,207,0.16),transparent 70%),var(--bg-2);overflow:hidden;}
.equipo-stage::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:radial-gradient(70% 70% at 50% 45%,#000,transparent 78%);mask-image:radial-gradient(70% 70% at 50% 45%,#000,transparent 78%);opacity:.5;}
.equipo-img{position:relative;width:78%;max-width:360px;filter:drop-shadow(0 30px 40px rgba(0,0,0,0.55));animation:floatY 6s ease-in-out infinite;}
@keyframes floatY{0%,100%{transform:translateY(-8px);}50%{transform:translateY(8px);}}
.equipo-badge{position:absolute;bottom:18px;left:18px;font-family:var(--mono);font-size:10px;letter-spacing:0.16em;text-transform:uppercase;color:var(--cream-dim);background:rgba(13,13,12,0.55);padding:6px 11px;border:1px solid var(--line);border-radius:100px;backdrop-filter:blur(6px);}
.equipo-name{font-weight:700;font-size:clamp(28px,3.6vw,44px);letter-spacing:-0.02em;margin:10px 0 8px;}
.equipo-name span{color:var(--blue);}
.equipo-lead{color:var(--cream-dim);font-size:16px;line-height:1.65;max-width:46ch;margin-bottom:30px;}
.equipo-specs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden;}
.espec{background:var(--bg);padding:18px 20px;display:flex;flex-direction:column;gap:5px;}
.espec-k{font-family:var(--mono);font-size:10px;letter-spacing:0.13em;text-transform:uppercase;color:var(--cream-dim);}
.espec-v{font-weight:600;font-size:17px;letter-spacing:-0.01em;}
@media(max-width:860px){.equipo-inner{grid-template-columns:1fr;}.equipo-stage{min-height:320px;}}

/* ---------- CATÁLOGO ---------- */
.cat-head{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap;}
.cat-total{display:block;font-size:11px;letter-spacing:0.14em;color:var(--cream-faint);margin-top:14px;}
/* admin controls — hidden from public, shown only in owner (admin) mode */
.cat-head-actions{display:none;gap:10px;align-items:center;margin-top:6px;flex-wrap:wrap;}
body.admin .cat-head-actions{display:flex;}
.promo-admin{display:none;}
body.admin .catalogo.editing .promo-admin{display:flex;flex-wrap:wrap;align-items:center;gap:14px 18px;margin:20px 0 4px;padding:16px 18px;border:1px dashed rgba(239,187,22,0.4);border-radius:8px;background:rgba(239,187,22,0.06);}
.cat-editbtn,.cat-exportbtn{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:0.12em;background:var(--bg-2);border:1px solid var(--line);border-radius:100px;padding:9px 15px;cursor:pointer;transition:color .2s,border-color .2s,background .2s;}
.cat-editbtn{color:var(--cream-dim);}
.cat-editbtn:hover{color:var(--cream);border-color:var(--cream-faint);}
.cat-editbtn.on{color:#fff;background:var(--blue);border-color:var(--blue);}
.cat-exportbtn{display:none;color:var(--bg);background:var(--yellow);border-color:var(--yellow);font-weight:700;}
.cat-exportbtn:hover{filter:brightness(1.08);}
.catalogo.editing .cat-exportbtn{display:inline-flex;}
.cat-dl-ready{display:none;align-items:center;gap:8px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:#fff;background:var(--blue);border:1px solid var(--blue);border-radius:100px;padding:11px 18px;cursor:pointer;animation:dlpulse 1.4s ease-in-out infinite;}
.cat-dl-ready:hover{filter:brightness(1.1);}
@keyframes dlpulse{0%,100%{box-shadow:0 0 0 0 rgba(15,99,207,0.5)}60%{box-shadow:0 0 0 10px rgba(15,99,207,0)}}

/* +400 models banner */
.cat-more{margin-top:clamp(30px,4vw,48px);border:1px solid var(--line);border-radius:10px;background:linear-gradient(120deg,var(--bg-2),var(--bg-3));padding:clamp(26px,3.5vw,40px);display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;position:relative;overflow:hidden;}
.cat-more::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(var(--red),var(--yellow),var(--blue));}
.cat-more-txt{flex:1;min-width:260px;}
.cat-more-txt strong{display:block;font-weight:700;font-size:clamp(20px,2.6vw,30px);letter-spacing:-0.02em;line-height:1.15;margin-bottom:10px;}
.cat-more-txt strong span{color:var(--yellow);}
.cat-more-txt p{color:var(--cream-dim);font-size:15px;line-height:1.6;max-width:60ch;}
.cat-more-btn{flex:0 0 auto;}
@media(max-width:600px){.cat-more{flex-direction:column;align-items:flex-start;}.cat-more-btn{width:100%;}}

/* category rail */
.cat-railwrap{position:relative;margin:clamp(26px,4vw,40px) 0 clamp(22px,3vw,32px);}
.cat-tabs{display:flex;flex-wrap:wrap;gap:8px;padding:2px;}
.cat-tab{display:inline-flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:0.1em;color:var(--cream-dim);background:var(--bg-2);border:1px solid var(--line);border-radius:100px;padding:10px 16px;cursor:pointer;white-space:nowrap;transition:color .2s,background .2s,border-color .2s,transform .2s;}
.cat-tab:hover{color:var(--cream);border-color:var(--cream-faint);transform:translateY(-1px);}
.cat-tab.on{color:#fff;background:var(--blue);border-color:var(--blue);box-shadow:0 6px 20px rgba(15,99,207,0.3);}
.cat-count{font-style:normal;font-size:9px;background:rgba(255,255,255,0.16);color:#fff;border-radius:100px;min-width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;}
.cat-tab:not(.on) .cat-count{background:var(--bg-3);color:var(--cream-dim);}

/* active category header */
.cat-activewrap{display:flex;align-items:baseline;gap:16px;margin-bottom:clamp(20px,3vw,30px);padding-bottom:18px;border-bottom:1px solid var(--line);}
.cat-active{font-weight:700;font-size:clamp(26px,4.2vw,46px);letter-spacing:-0.02em;line-height:1;}
.cat-activen{font-size:11px;letter-spacing:0.14em;color:var(--blue);white-space:nowrap;}

/* product grid */
.cat-products{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px);}
@media(max-width:1000px){.cat-products{grid-template-columns:repeat(3,1fr);}}
@media(max-width:760px){.cat-products{grid-template-columns:repeat(2,1fr);}}
@media(max-width:460px){.cat-products{grid-template-columns:1fr;}}

/* ---- VIEW (client) card ---- */
.vprod{position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--bg-2);display:flex;flex-direction:column;transition:transform .35s var(--ease),border-color .25s,box-shadow .35s;}
.vprod:hover{transform:translateY(-5px);border-color:var(--cream-faint);box-shadow:0 22px 46px rgba(0,0,0,0.45);}
.vprod-media{position:relative;aspect-ratio:1/1;overflow:hidden;background:radial-gradient(120% 90% at 50% 25%,rgba(255,255,255,0.06),transparent 70%);}
.vprod-media.noimg::after{content:"MODULA LAB";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;letter-spacing:0.28em;color:var(--cream-faint);background:repeating-linear-gradient(45deg,rgba(236,230,218,0.04) 0 1px,transparent 1px 11px);}
.vprod-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s var(--ease);}
.vprod:hover .vprod-img{transform:scale(1.07);}
.vprod-count{position:absolute;top:12px;left:12px;font-size:9px;letter-spacing:0.13em;text-transform:uppercase;color:var(--cream);background:rgba(13,13,12,0.6);backdrop-filter:blur(6px);padding:5px 9px;border-radius:100px;border:1px solid var(--line);}
.vprod-dots{position:absolute;bottom:12px;left:0;right:0;display:flex;justify-content:center;gap:6px;z-index:2;}
.vdot{width:7px;height:7px;border-radius:100px;border:none;background:rgba(255,255,255,0.4);cursor:pointer;padding:0;transition:background .2s,transform .2s;}
.vdot:hover{transform:scale(1.3);}
.vdot.on{background:#fff;}
.vprod-body{display:flex;align-items:center;justify-content:space-between;gap:10px 12px;flex-wrap:wrap;padding:16px 18px;border-top:1px solid var(--line);}
.vprod-name{flex:1 1 auto;min-width:0;overflow-wrap:anywhere;font-weight:600;font-size:16px;letter-spacing:-0.01em;line-height:1.25;}
.vprod-cta{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:0.1em;color:#fff;background:var(--blue);border-radius:100px;padding:9px 14px;transition:background .25s,transform .2s;}
.vprod-cta:hover{background:var(--red);transform:translateY(-1px);}

/* view empty state */
.cat-empty{grid-column:1/-1;border:1px solid var(--line);border-radius:8px;background:var(--bg-2);padding:clamp(40px,6vw,72px) 30px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:22px;}
.cat-empty p{font-size:clamp(18px,2.4vw,26px);font-weight:500;letter-spacing:-0.01em;color:var(--cream-dim);max-width:30ch;}
.cat-empty strong{color:var(--cream);font-weight:600;}

/* ---- EDIT card (owner only) ---- */
.prod{border:1px solid var(--line);border-radius:6px;background:var(--bg-2);display:flex;flex-direction:column;overflow:hidden;transition:border-color .25s;}
.prod.drag{border-color:var(--blue);box-shadow:0 0 0 2px rgba(15,99,207,0.35);}
.prod-imgs{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px;background:var(--bg-3);}
.prod-imgs:has(.pslot:only-child){grid-template-columns:1fr;}
.pslot{position:relative;aspect-ratio:1/1;border-radius:3px;overflow:hidden;background:var(--bg);display:flex;align-items:center;justify-content:center;}
.pslot.filled img{width:100%;height:100%;object-fit:cover;display:block;}
.pslot-del{position:absolute;top:5px;right:5px;width:22px;height:22px;border-radius:100px;border:none;background:rgba(13,13,12,0.7);color:#fff;font-size:15px;line-height:1;cursor:pointer;opacity:0;transition:opacity .2s,background .2s;display:flex;align-items:center;justify-content:center;}
.pslot:hover .pslot-del{opacity:1;}
.pslot-del:hover{background:var(--red);}
.pslot.empty{cursor:pointer;flex-direction:column;gap:2px;border:1.5px dashed var(--cream-faint);color:var(--cream-dim);transition:border-color .2s,color .2s,background .2s;}
.pslot.empty span{font-size:22px;font-weight:300;line-height:1;}
.pslot.empty em{font-family:var(--mono);font-size:9px;letter-spacing:0.12em;text-transform:uppercase;font-style:normal;}
.pslot.empty:hover,.pslot.empty.drag{border-color:var(--blue);color:var(--cream);background:rgba(15,99,207,0.08);}
.prod-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:13px 15px;border-top:1px solid var(--line);}
.prod-drag{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;color:var(--cream-faint);background:none;border:none;cursor:grab;border-radius:4px;transition:color .2s,background .2s;}
.prod-drag:hover{color:var(--cream);background:var(--bg);}
.prod-drag:active{cursor:grabbing;}
.prod.dragging{opacity:.45;}
.prod.over{border-color:var(--blue);box-shadow:0 0 0 2px rgba(15,99,207,0.45);}
.prod-add.over{border-color:var(--blue);background:rgba(15,99,207,0.12);}
.prod-name{font-weight:600;font-size:15px;letter-spacing:-0.01em;outline:none;flex:1;min-width:0;border-radius:3px;padding:2px 4px;margin:-2px -4px;transition:background .2s;}
.prod-name:focus{background:var(--bg);box-shadow:inset 0 0 0 1px var(--cream-faint);}
.prod-del{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:0.1em;color:var(--cream-faint);background:none;border:none;cursor:pointer;transition:color .2s;white-space:nowrap;}
.prod-del:hover{color:var(--red);}

.prod-add{cursor:pointer;border:1.5px dashed var(--cream-faint);background:transparent;align-items:center;justify-content:center;min-height:220px;transition:border-color .25s,background .25s,transform .2s;}
.prod-add:hover,.prod-add.drag{border-color:var(--blue);background:rgba(15,99,207,0.06);transform:translateY(-2px);}
.prod-add-in{display:flex;flex-direction:column;align-items:center;gap:7px;text-align:center;padding:20px;pointer-events:none;}
.prod-add .plus{width:44px;height:44px;border-radius:100px;border:1.5px solid currentColor;color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:300;line-height:1;}
.prod-add strong{font-weight:600;font-size:15px;color:var(--cream);}
.prod-add em{font-family:var(--mono);font-size:10px;letter-spacing:0.08em;font-style:normal;color:var(--cream-dim);}

/* editing-mode hint banner */
.catalogo.editing .cat-activewrap::after{content:"Modo edición — arrastra fotos, añade productos y edita nombres";font-family:var(--mono);font-size:10px;letter-spacing:0.08em;text-transform:uppercase;color:var(--yellow);margin-left:auto;text-align:right;max-width:30ch;line-height:1.5;}
@media(max-width:600px){.catalogo.editing .cat-activewrap::after{display:none;}}

/* ---------- CONTACT FORM ---------- */
.contacto-cols{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(34px,5vw,72px);align-items:start;text-align:left;width:100%;margin-bottom:clamp(40px,6vw,64px);}
.cform{display:flex;flex-direction:column;gap:16px;}
.cform-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.cfield{display:flex;flex-direction:column;gap:7px;}
.cfield label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:0.13em;color:var(--cream-dim);}
.cfield input,.cfield textarea{width:100%;font-family:var(--display);font-size:15px;color:var(--cream);background:var(--bg-2);border:1px solid var(--line);border-radius:4px;padding:13px 15px;outline:none;transition:border-color .2s,background .2s;resize:vertical;}
.cfield input:focus,.cfield textarea:focus{border-color:var(--blue);background:var(--bg-3);}
.cform .btn{align-self:flex-start;border:none;cursor:pointer;}
.cform-note{font-family:var(--mono);font-size:10px;letter-spacing:0.04em;color:var(--cream-faint);line-height:1.6;}
.contacto-side{display:flex;flex-direction:column;}
.contacto-side{gap:16px;}
.contacto-side .btn{width:100%;margin-bottom:8px;}
.contacto-side .contacto-grid{grid-template-columns:1fr;width:100%;}
@media(max-width:860px){.contacto-cols{grid-template-columns:1fr;}.cform-row{grid-template-columns:1fr;}}
