/* ============================================================
   BARIPANEL — public site styles
   ============================================================ */

/* ---------- Top contact strip ---------- */
.topbar {
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  font-family: var(--font-mono);
  font-size: .74rem; letter-spacing: .04em;
  color: var(--ink-mute);
}
.topbar .container { display: flex; align-items: center; justify-content: space-between; height: 38px; gap: 18px; }
.topbar a { display: inline-flex; align-items: center; gap: 7px; color: var(--ink-soft); }
.topbar a:hover { color: var(--blue-ink); }
.topbar .tb-left { display: flex; gap: 26px; overflow: hidden; white-space: nowrap; }
.topbar svg { width: 14px; height: 14px; color: var(--accent); }
.topbar .tb-right { display: flex; gap: 16px; }
@media (max-width: 820px){ .topbar .tb-left a:not(:first-child){ display:none; } }

/* ---------- Header ---------- */
.header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(13,14,16,.86);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}
.header .container { display: flex; align-items: center; gap: 30px; height: 76px; }
.brand { display: flex; align-items: center; gap: 12px; }
.brand img { height: 26px; width: auto; }
.brand .lb, .foot-brand .lb { display: none; }
[data-theme="light"] .brand .lw, [data-theme="light"] .foot-brand .lw { display: none; }
[data-theme="light"] .brand .lb, [data-theme="light"] .foot-brand .lb { display: block; }
.brand .reg { font-family: var(--font-mono); font-size:.6rem; color: var(--ink-faint); align-self:flex-start; }
.nav { display: flex; align-items: center; gap: 4px; margin-left: auto; }
.nav a {
  font-family: var(--font-display); font-weight: 600; font-size: .92rem;
  text-transform: uppercase; letter-spacing: .02em;
  color: var(--ink-soft); padding: 10px 14px; border-radius: var(--r);
  position: relative; transition: color .15s;
}
.nav a:hover { color: var(--ink); }
.nav a::after {
  content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px;
  background: var(--accent); transform: scaleX(0); transform-origin:left; transition: transform .2s;
}
.nav a:hover::after { transform: scaleX(1); }
.header .btn { padding: 11px 18px; font-size: .82rem; }
.menu-toggle { display:none; margin-left:auto; background:none; border:1px solid var(--line-2); color:var(--ink); padding:9px; border-radius: var(--r); }
.menu-toggle svg { width:22px; height:22px; display:block; }
@media (max-width: 1000px){
  .nav, .header .btn { display: none; }
  .menu-toggle { display: inline-flex; }
}

/* mobile menu */
.mobile-menu { position: fixed; inset: 0; z-index: 60; background: rgba(8,9,10,.97); display:flex; flex-direction:column; padding: 28px; }
.mobile-menu a { font-family: var(--font-display); font-weight:700; font-size:1.5rem; text-transform:uppercase; padding:14px 0; border-bottom:1px solid var(--line); }
.mobile-menu .mm-close { align-self:flex-end; background:none;border:none;color:var(--ink); }
.mobile-menu .mm-close svg { width:30px;height:30px; }

/* ---------- HERO ---------- */
.hero { position: relative; overflow: hidden; background: var(--bg); border-bottom: 1px solid var(--line); }
.hero-bg { position:absolute; inset:0; }
.hero-bg img { width:100%; height:100%; object-fit: cover; opacity: var(--hero-img-opacity); }
.hero-bg::after { content:""; position:absolute; inset:0; }
.hero-grid {
  position:absolute; inset:0; opacity:.5;
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 80% 70% at 70% 30%, #000 40%, transparent 100%);
}

/* style: split (default) */
.hero.split .hero-inner { display:grid; grid-template-columns: 1.05fr .95fr; min-height: 600px; }
.hero.split .hero-copy { padding: 86px 0 86px; display:flex; flex-direction:column; justify-content:center; }
.hero.split .hero-visual { position:relative; border-left: 1px solid var(--line); }
.hero.split .hero-visual::before { content:""; position:absolute; left:0; top:0; bottom:0; width:4px; background: var(--accent); }
.hero.split .hero-visual img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero.split .hv-overlay { position:absolute; inset:0; background: linear-gradient(120deg, rgba(13,14,16,.6), rgba(13,14,16,0) 50%); }

.hero-eyebrow { margin-bottom: 22px; }
.hero h1 { font-size: clamp(2.6rem, 5.4vw, 5rem); font-weight: 900; text-transform: uppercase; letter-spacing: -.02em; }
.hero h1 .blue { color: var(--blue-ink); }
.hero-text { color: var(--ink-soft); font-size: 1.18rem; max-width: 38ch; margin: 24px 0 34px; }
.hero-actions { display:flex; gap: 14px; flex-wrap: wrap; }

/* slider dots + count */
.hero-foot { display:flex; align-items:center; gap: 22px; margin-top: 44px; }
.hero-dots { display:flex; gap: 10px; }
.hero-dots button { width: 34px; height: 4px; background: var(--surface-3); border:none; border-radius:2px; padding:0; transition: background .2s; }
.hero-dots button.on { background: var(--accent); }
.hero-index { font-family: var(--font-mono); font-size:.8rem; color: var(--ink-mute); }
.hero-index b { color: var(--ink); }

/* style: stack (full-bleed image, copy bottom-left) */
.hero.stack .hero-inner { min-height: 640px; display:flex; align-items:flex-end; padding: 0 0 70px; }
.hero.stack .hero-bg img { opacity:.42; }
.hero.stack .hero-copy { max-width: 760px; }
.hero.stack h1 { font-size: clamp(2.8rem, 6.5vw, 6rem); }
.hero.stack::after { content:""; position:absolute; inset:0; background: linear-gradient(0deg, rgba(13,14,16,.92), rgba(13,14,16,.3) 60%, rgba(13,14,16,.6)); }
.hero.stack .hero-inner { position:relative; z-index:2; }

/* style: frame (centered, bordered frame, mono coordinates) */
.hero.frame .hero-inner { min-height: 660px; display:flex; align-items:center; justify-content:center; text-align:center; position:relative; z-index:2; padding: 90px 0; }
.hero.frame .hero-copy { max-width: 900px; display:flex; flex-direction:column; align-items:center; }
.hero.frame .hero-text { max-width: 56ch; }
.hero.frame h1 { font-size: clamp(2.8rem, 6vw, 5.6rem); }
.hero.frame .corner { position:absolute; width:26px; height:26px; border:2px solid var(--accent); z-index:3; }
.hero.frame .corner.tl{ top:26px; left:26px; border-right:none;border-bottom:none;}
.hero.frame .corner.tr{ top:26px; right:26px; border-left:none;border-bottom:none;}
.hero.frame .corner.bl{ bottom:26px; left:26px; border-right:none;border-top:none;}
.hero.frame .corner.br{ bottom:26px; right:26px; border-left:none;border-top:none;}
.hero.frame .hero-actions { justify-content:center; }

@media (max-width: 900px){
  .hero.split .hero-inner { grid-template-columns: 1fr; }
  .hero.split .hero-visual { min-height: 320px; border-left:none; border-top:1px solid var(--line); }
  .hero.split .hero-copy { padding: 60px 0 50px; }
}

/* ---------- Marquee / capabilities strip ---------- */
.strip { background: var(--blue); color:#fff; border-block: 1px solid rgba(0,0,0,.25); overflow:hidden; }
.strip-track { display:flex; gap: 0; white-space:nowrap; animation: scroll 32s linear infinite; }
.strip-track span { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size:1.05rem; letter-spacing:.04em; padding: 16px 0; display:inline-flex; align-items:center; }
.strip-track span::after { content:"✦"; margin: 0 30px; color: rgba(255,255,255,.55); font-size:.8rem; }
@keyframes scroll { to { transform: translateX(-50%); } }

/* ---------- Section scaffold ---------- */
.section { padding: 96px 0; position: relative; }
.section.alt { background: var(--bg-2); border-block: 1px solid var(--line); }
.sec-head { display:flex; align-items:flex-end; justify-content:space-between; gap: 30px; margin-bottom: 52px; }
.sec-head .sh-l { max-width: 640px; }
.sec-head h2 { font-size: clamp(2rem, 3.6vw, 3.1rem); text-transform: uppercase; margin-top: 16px; }
.sec-head p { color: var(--ink-soft); margin-top: 16px; font-size: 1.08rem; }
@media (max-width: 760px){ .sec-head { flex-direction:column; align-items:flex-start; } }

/* ---------- About + stats ---------- */
.about-grid { display:grid; grid-template-columns: 1.1fr .9fr; gap: 60px; align-items:center; }
.about-copy h2 { font-size: clamp(1.9rem, 3.4vw, 2.9rem); text-transform:uppercase; margin: 16px 0 22px; max-width: 16ch; }
.about-copy p { color: var(--ink-soft); font-size: 1.1rem; }
.about-visual { position:relative; }
.about-visual img { width:100%; aspect-ratio: 4/5; object-fit:cover; border-radius: var(--r); }
.about-visual .badge { position:absolute; bottom:-22px; left:-22px; background: var(--accent); color:#fff; padding: 18px 24px; border-radius: var(--r); box-shadow: var(--shadow); }
.about-visual .badge b { font-family: var(--font-display); font-size: 2.6rem; display:block; line-height:1; font-weight: 900; }
.about-visual .badge span { font-family: var(--font-mono); font-size:.72rem; letter-spacing:.12em; text-transform:uppercase; }
@media (max-width: 860px){ .about-grid { grid-template-columns:1fr; gap:40px; } }

.stats { display:grid; grid-template-columns: repeat(4,1fr); gap: 1px; background: var(--line); border:1px solid var(--line); margin-top: 80px; }
.stat { background: var(--bg); padding: 34px 26px; }
.stat b { font-family: var(--font-display); font-weight:900; font-size: 3rem; color: var(--ink); display:block; line-height:1; }
.stat b .u { color: var(--accent); }
.stat span { font-family: var(--font-mono); font-size:.74rem; letter-spacing:.1em; text-transform:uppercase; color: var(--ink-mute); margin-top:12px; display:block; }
@media (max-width: 760px){ .stats { grid-template-columns: repeat(2,1fr); } }

/* ---------- Product category tabs ---------- */
.tabs { display:flex; gap:8px; flex-wrap:wrap; margin-bottom: 38px; }
.tab {
  font-family: var(--font-display); font-weight:700; font-size:.86rem; text-transform:uppercase; letter-spacing:.03em;
  padding: 11px 18px; background: var(--surface); border:1px solid var(--line); color: var(--ink-mute); border-radius: var(--r);
  display:inline-flex; align-items:center; gap:9px; transition: all .15s;
}
.tab svg { width:17px; height:17px; }
.tab:hover { color: var(--ink); border-color: var(--line-2); }
.tab.on { background: var(--accent); color:#fff; border-color: var(--accent); }
.tab .cnt { font-family: var(--font-mono); font-size:.7rem; opacity:.7; }

/* product cards */
.cards { display:grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
@media (max-width: 980px){ .cards { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 600px){ .cards { grid-template-columns: 1fr; } }
.pcard {
  background: var(--surface); border:1px solid var(--line); border-radius: var(--r); overflow:hidden;
  display:flex; flex-direction:column; transition: border-color .18s, transform .18s;
  cursor: pointer;
}
.pcard:hover { border-color: var(--line-2); transform: translateY(-4px); }
.pcard:hover .pcard-media img { transform: scale(1.05); }
.pcard-media { position:relative; aspect-ratio: 4/3; overflow:hidden; background: var(--bg-2); }
.pcard-media img { width:100%; height:100%; object-fit:cover; transition: transform .4s ease; }
.pcard-cat { position:absolute; top:12px; left:12px; font-family:var(--font-mono); font-size:.64rem; letter-spacing:.1em; text-transform:uppercase; background: rgba(13,14,16,.82); color: var(--blue-ink); padding:5px 9px; border-radius:2px; border:1px solid var(--line); }
.pcard-star { position:absolute; top:12px; right:12px; color: var(--accent); }
.pcard-star svg { width:18px;height:18px; fill: var(--accent); }
.pcard-body { padding: 20px; display:flex; flex-direction:column; flex:1; }
.pcard-body h3 { font-size: 1.28rem; text-transform:uppercase; }
.pcard-tag { font-family: var(--font-mono); font-size:.72rem; color: var(--ink-mute); margin-top: 7px; letter-spacing:.04em; }
.pcard-body p { color: var(--ink-soft); font-size:.96rem; margin: 14px 0 0; flex:1;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.pcard-foot { display:flex; align-items:center; gap:8px; margin-top: 18px; font-family:var(--font-display); font-weight:700; text-transform:uppercase; font-size:.82rem; color: var(--accent); }
.pcard-foot svg { width:16px;height:16px; transition: transform .2s; }
.pcard:hover .pcard-foot svg { transform: translateX(4px); }

/* ---------- Product modal ---------- */
.modal-scrim { position:fixed; inset:0; z-index:80; background: rgba(6,7,8,.78); backdrop-filter: blur(4px); display:flex; align-items:flex-start; justify-content:center; padding: 40px 20px; overflow:auto; }
.modal { background: var(--surface); border:1px solid var(--line-2); border-radius: var(--r-2); max-width: 1000px; width:100%; overflow:hidden; box-shadow: var(--shadow); }
.modal-grid { display:grid; grid-template-columns: 1fr 1fr; }
.modal-media { position:relative; min-height: 360px; background: var(--bg-2); }
.modal-media img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.modal-media .pcard-cat { font-size:.7rem; }
.modal-body { padding: 38px; }
.modal-body h2 { font-size: 2.1rem; text-transform:uppercase; }
.modal-tag { font-family: var(--font-mono); color: var(--blue-ink); font-size:.8rem; letter-spacing:.06em; margin-top:8px; }
.modal-body > p { color: var(--ink-soft); margin: 18px 0 24px; }
.spec-table { border-top:1px solid var(--line); }
.spec-row { display:grid; grid-template-columns: 40% 60%; gap:14px; padding: 11px 0; border-bottom:1px solid var(--line); }
.spec-row dt { font-family:var(--font-mono); font-size:.78rem; letter-spacing:.04em; color: var(--ink-mute); text-transform:uppercase; }
.spec-row dd { margin:0; font-size:.95rem; color: var(--ink); }
.chips { display:flex; flex-wrap:wrap; gap:8px; margin-top: 20px; }
.chip { font-family: var(--font-mono); font-size:.72rem; padding:6px 11px; border:1px solid var(--line-2); border-radius: 100px; color: var(--ink-soft); }
.modal-actions { display:flex; gap:12px; margin-top: 28px; }
.modal-close { position:absolute; top:16px; right:16px; z-index:3; background: rgba(13,14,16,.7); border:1px solid var(--line-2); color:#fff; border-radius: var(--r); padding:8px; }
.modal-close svg { width:20px; height:20px; display:block; }
@media (max-width: 800px){ .modal-grid { grid-template-columns:1fr; } .modal-media{ min-height: 240px; } }

/* ---------- Feature section (módulos / barihome) ---------- */
.feature { display:grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items:center; }
.feature.rev .feature-media { order: 2; }
.feature-media { position:relative; }
.feature-media img { width:100%; aspect-ratio: 5/4; object-fit:cover; border-radius: var(--r); }
.feature-media .tagblk { position:absolute; bottom:18px; left:18px; background: rgba(13,14,16,.85); border:1px solid var(--line-2); padding:14px 18px; border-radius: var(--r); }
.feature-media .tagblk .mono { color: var(--blue-ink); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; }
.feature-media .tagblk b { font-family: var(--font-display); font-size: 1.3rem; display:block; }
.feature h2 { font-size: clamp(1.9rem, 3.4vw, 2.9rem); text-transform:uppercase; margin: 16px 0 20px; }
.feature p { color: var(--ink-soft); font-size: 1.08rem; }
.feature ul { list-style:none; padding:0; margin: 26px 0 30px; display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.feature li { display:flex; align-items:center; gap:10px; font-size:.96rem; color: var(--ink-soft); }
.feature li::before { content:""; width:8px;height:8px; background: var(--accent); flex:none; }
.modlist { display:grid; grid-template-columns: repeat(3,1fr); gap:18px; margin-top: 44px; }
@media (max-width: 880px){ .feature { grid-template-columns:1fr; gap:36px; } .feature.rev .feature-media{ order:0; } .modlist{ grid-template-columns:1fr; } }

/* ---------- Banner CTA ---------- */
.banner { position:relative; overflow:hidden; border-block:1px solid var(--line); background:#0b1422; min-height:420px; display:flex; align-items:flex-end; }
.banner-bg { position:absolute; inset:0; z-index:0; }
.banner-bg img { width:100%; height:100%; object-fit:cover; opacity:1; display:block; }
/* Velo concentrado abajo-izquierda (tras el texto); el resto de la foto queda limpio. */
.banner::before { content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:
    linear-gradient(180deg, transparent 0%, transparent 42%, rgba(6,14,26,.62) 100%),
    linear-gradient(80deg, rgba(6,14,26,.74) 0%, rgba(6,14,26,.34) 28%, transparent 54%); }
/* Retícula de puntos sutil, difuminada hacia la derecha. */
.banner::after { content:""; position:absolute; inset:0; z-index:2; pointer-events:none;
  background-image: radial-gradient(rgba(120,170,235,.16) 1px, transparent 1.6px); background-size:24px 24px;
  -webkit-mask-image: linear-gradient(105deg,#000,transparent 42%); mask-image: linear-gradient(105deg,#000,transparent 42%); }
.banner .container { position:relative; z-index:3; padding: 66px 28px 58px; }
.banner .kicker { color:#7fc4ff; text-shadow:0 1px 10px rgba(0,0,0,.5); }
.banner .kicker::before { background:#5fb0ff; }
.banner h2 { font-size: clamp(2.2rem, 4.6vw, 3.6rem); text-transform:uppercase; max-width: 20ch; color:#fff; text-shadow:0 2px 22px rgba(4,12,24,.6); margin-top:14px; }
.banner p { color:#eaf0f8; font-size: 1.15rem; max-width: 48ch; margin: 18px 0 30px; text-shadow:0 1px 14px rgba(4,12,24,.7); }
.banner-actions { display:flex; flex-wrap:wrap; gap:12px; align-items:center; }
.banner .btn--blue { background:#1559a8; border-color:#1559a8; color:#fff; box-shadow:0 14px 30px -12px rgba(21,89,168,.8); }
.banner .btn--ghost-light { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.55); color:#fff; }
.banner .btn--ghost-light:hover { background:rgba(255,255,255,.18); border-color:#fff; box-shadow:none; }
@media (max-width:760px){ .banner { min-height:340px; } .banner .container{ padding:48px 22px 40px; } .banner p{ font-size:1.02rem; } }
@media (prefers-reduced-motion:reduce){ .banner::after{ -webkit-mask-image:none; mask-image:none; } }

/* ---------- Cotización form ---------- */
.quote-grid { display:grid; grid-template-columns: .85fr 1.15fr; gap: 56px; }
.quote-aside h2 { font-size: clamp(1.9rem,3.4vw,2.8rem); text-transform:uppercase; margin:16px 0 18px; }
.quote-aside p { color: var(--ink-soft); }
.quote-aside .qlist { margin-top: 28px; display:flex; flex-direction:column; gap: 16px; }
.quote-aside .qlist div { display:flex; gap: 14px; align-items:flex-start; }
.quote-aside .qlist svg { width:22px;height:22px; color: var(--accent); flex:none; margin-top:2px; }
.quote-aside .qlist b { display:block; font-family:var(--font-display); text-transform:uppercase; font-size:.92rem; }
.quote-aside .qlist span { color: var(--ink-mute); font-size:.92rem; }
.form { background: var(--surface); border:1px solid var(--line); border-radius: var(--r-2); padding: 34px; }
.frow { display:grid; grid-template-columns:1fr 1fr; gap: 16px; }
.field { margin-bottom: 16px; display:flex; flex-direction:column; gap:7px; }
.field label { font-family: var(--font-mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase; color: var(--ink-mute); }
.field input, .field select, .field textarea {
  background: var(--bg); border:1px solid var(--line-2); border-radius: var(--r); color: var(--ink);
  font-family: var(--font-body); font-size: 1rem; padding: 12px 14px; width:100%;
}
.field textarea { resize: vertical; min-height: 110px; }
.field input:focus, .field select:focus, .field textarea:focus { outline:none; border-color: var(--blue-2); box-shadow: 0 0 0 3px rgba(47,127,209,.18); }
.form .btn { width:100%; justify-content:center; margin-top: 8px; }
.form-ok { text-align:center; padding: 40px 20px; }
.form-ok .okmark { width:64px;height:64px;border-radius:50%; background: rgba(34,160,90,.16); color:#3fcf7f; display:flex;align-items:center;justify-content:center; margin: 0 auto 18px; }
.form-ok .okmark svg { width:34px;height:34px; }
.form-ok h3 { font-size:1.5rem; text-transform:uppercase; }
.form-ok p { color: var(--ink-soft); margin-top:10px; }
@media (max-width: 860px){ .quote-grid { grid-template-columns:1fr; gap:36px; } .frow{ grid-template-columns:1fr; } }

/* ---------- Contact ---------- */
.contact-grid { display:grid; grid-template-columns: 1fr 1fr; gap: 0; border:1px solid var(--line); border-radius: var(--r-2); overflow:hidden; }
.contact-info { padding: 44px; background: var(--surface); }
.contact-info h3 { font-size: 1.6rem; text-transform:uppercase; margin-bottom: 22px; }
.cinfo { display:flex; gap:14px; padding: 16px 0; border-bottom:1px solid var(--line); }
.cinfo:last-child { border-bottom:none; }
.cinfo svg { width:22px;height:22px;color:var(--accent);flex:none; margin-top:2px; }
.cinfo .mono { font-family:var(--font-mono); font-size:.7rem; letter-spacing:.1em; text-transform:uppercase; color: var(--ink-mute); }
.cinfo b { display:block; font-size:1.02rem; margin-top:3px; }
.contact-map { position:relative; min-height: 360px; background: var(--bg-2); }
.contact-map iframe { position:absolute; inset:0; width:100%; height:100%; border:0; filter: grayscale(1) invert(.9) contrast(.9); }
@media (max-width: 800px){ .contact-grid { grid-template-columns:1fr; } }

/* ---------- Footer ---------- */
.footer { background: var(--bg-2); border-top: 1px solid var(--line); padding: 64px 0 0; }
.foot-grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 50px; }
.foot-brand img { height: 28px; margin-bottom: 18px; }
.foot-brand p { color: var(--ink-mute); font-size:.95rem; max-width: 34ch; }
.foot-col h4 { font-family: var(--font-mono); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color: var(--ink-faint); margin-bottom: 18px; }
.foot-col a, .foot-col p { display:block; color: var(--ink-soft); font-size:.96rem; padding: 5px 0; }
.foot-col a:hover { color: var(--blue-ink); }
.foot-social { display:flex; gap:10px; margin-top: 6px; }
.foot-social a { width:38px;height:38px;border:1px solid var(--line-2); border-radius:var(--r); display:flex;align-items:center;justify-content:center; color: var(--ink-soft); }
.foot-social a:hover { background: var(--accent); color:#fff; border-color: var(--accent); }
.foot-social svg { width:18px;height:18px; }
.foot-bar { border-top:1px solid var(--line); padding: 20px 0; display:flex; align-items:center; justify-content:space-between; gap: 16px; }
.foot-bar p { font-family: var(--font-mono); font-size:.74rem; color: var(--ink-faint); letter-spacing:.04em; }
.foot-bar a { font-family: var(--font-mono); font-size:.74rem; color: var(--ink-mute); }
.foot-bar a:hover { color: var(--blue-ink); }
@media (max-width: 860px){ .foot-grid { grid-template-columns: 1fr 1fr; } }

/* whatsapp float */
.wa-float { position: fixed; right: 22px; bottom: 22px; z-index: 80; width: 58px; height: 58px; border-radius: 50%;
  background: #25d366; color:#fff; display:flex; align-items:center; justify-content:center;
  border: 2px solid rgba(255,255,255,.95);
  box-shadow: 0 10px 26px -6px rgba(11,61,32,.5), 0 0 0 6px rgba(37,211,102,.18); transition: transform .18s, box-shadow .18s; }
.wa-float:hover { transform: scale(1.08); box-shadow: 0 14px 30px -6px rgba(11,61,32,.55), 0 0 0 8px rgba(37,211,102,.22); }
.wa-float svg { width: 30px; height: 30px; display:block; }
@media (max-width: 600px){ .wa-float { right: 16px; bottom: calc(16px + env(safe-area-inset-bottom)); width: 54px; height: 54px; } .wa-float svg { width: 28px; height: 28px; } }

/* admin entry pill */
.admin-pill { position: fixed; left: 22px; bottom: 22px; z-index: 70; font-family: var(--font-mono); font-size:.72rem; letter-spacing:.08em; text-transform:uppercase;
  background: var(--surface-2); border:1px solid var(--line-2); color: var(--ink-mute); padding: 9px 14px; border-radius: 100px; display:flex; align-items:center; gap:8px; }
.admin-pill:hover { color: var(--ink); border-color: var(--ink-mute); }
.admin-pill svg { width:15px;height:15px; }

/* ---------- Light-theme chrome overrides ---------- */
[data-theme="light"] .header { background: rgba(255,255,255,.86); }
[data-theme="light"] .pcard-cat,
[data-theme="light"] .feature-media .tagblk,
[data-theme="light"] .modal-close { background: rgba(255,255,255,.86); }
[data-theme="light"] .mobile-menu { background: rgba(255,255,255,.97); }
[data-theme="light"] .modal-scrim { background: rgba(16,40,72,.45); }
[data-theme="light"] .contact-map iframe { filter: grayscale(.3) contrast(1.02); }
/* keep hero text legible when it overlays an image (stack / frame styles) */
[data-theme="light"] .hero.stack .hero-copy,
[data-theme="light"] .hero.frame .hero-copy { --ink:#ffffff; --ink-soft:#dfe5ee; }
[data-theme="light"] .hero.stack::after { background: linear-gradient(0deg, rgba(8,16,28,.82), rgba(8,16,28,.15) 60%, rgba(8,16,28,.45)); }

/* reveal on scroll */
.reveal { opacity:0; transform: translateY(22px); transition: opacity .6s ease, transform .6s ease; }
.reveal.in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity:1; transform:none; } .strip-track{ animation:none; } }

/* ============================================================
   Catalog page + product landing pages
   ============================================================ */

/* page hero band */
.pagehero { position: relative; overflow: hidden; background: var(--bg-2); border-bottom: 1px solid var(--line); }
.pagehero .hero-grid { opacity: .5; }
.pagehero .container { position: relative; z-index: 2; padding: 56px 28px 50px; }
.breadcrumb { font-family: var(--font-mono); font-size: .74rem; letter-spacing: .05em; color: var(--ink-mute); display: flex; gap: 9px; align-items: center; margin-bottom: 20px; flex-wrap: wrap; }
.breadcrumb a:hover { color: var(--blue-ink); }
.breadcrumb .sep { color: var(--ink-faint); }
.breadcrumb b { color: var(--ink-soft); font-weight: 500; }
.pagehero h1 { font-size: clamp(2.3rem, 5vw, 3.9rem); text-transform: uppercase; }
.pagehero .lead { color: var(--ink-soft); max-width: 60ch; margin-top: 16px; font-size: 1.12rem; }
.pagehero .ph-meta { display: flex; gap: 26px; margin-top: 26px; flex-wrap: wrap; }
.pagehero .ph-meta div { font-family: var(--font-mono); font-size: .76rem; color: var(--ink-mute); letter-spacing: .04em; }
.pagehero .ph-meta b { display: block; font-family: var(--font-display); font-size: 1.5rem; color: var(--ink); }

/* sticky category nav */
.catnav { position: sticky; top: 76px; z-index: 20; background: rgba(13,14,16,.92); backdrop-filter: blur(12px); border-bottom: 1px solid var(--line); }
[data-theme="light"] .catnav { background: rgba(255,255,255,.92); }
.catnav .container { display: flex; gap: 8px; overflow-x: auto; padding-block: 12px; scrollbar-width: none; }
.catnav .container::-webkit-scrollbar { display: none; }
.catnav button { white-space: nowrap; font-family: var(--font-display); font-weight: 700; font-size: .8rem; text-transform: uppercase; letter-spacing: .02em; padding: 9px 15px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); color: var(--ink-mute); display: flex; gap: 8px; align-items: center; transition: all .14s; }
.catnav button:hover { color: var(--ink); border-color: var(--line-2); }
.catnav button.on { background: var(--accent); border-color: var(--accent); color: #fff; }
.catnav button svg { width: 16px; height: 16px; }

/* catalog category section */
.catsec { padding: 60px 0; border-bottom: 1px solid var(--line); scroll-margin-top: 130px; }
.catsec:nth-child(even) { background: var(--bg-2); }
.catsec-head { display: flex; gap: 18px; align-items: flex-start; margin-bottom: 34px; }
.catsec-head .cic { width: 54px; height: 54px; border: 1px solid var(--line-2); border-radius: var(--r); display: flex; align-items: center; justify-content: center; color: var(--blue-ink); flex: none; background: var(--surface); }
.catsec-head .cic svg { width: 27px; height: 27px; }
.catsec-head .csh-t h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); text-transform: uppercase; }
.catsec-head .csh-t p { color: var(--ink-soft); margin-top: 6px; max-width: 60ch; }
.catsec-head .cnt { margin-left: auto; font-family: var(--font-mono); font-size: .78rem; color: var(--ink-mute); white-space: nowrap; padding-top: 8px; }
.subgroup { margin-bottom: 38px; }
.subgroup:last-child { margin-bottom: 0; }
.sub-h { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; font-size: 1.05rem; text-transform: uppercase; letter-spacing: .04em; color: var(--ink-soft); }
.sub-h span { font-family: var(--font-mono); font-weight: 600; font-size: .82rem; }
.sub-h i { flex: 1; height: 1px; background: var(--line); }

/* catalog search + filters */
.fchip { font-family: var(--font-mono); font-size: .82rem; font-weight: 500; padding: 8px 15px; background: var(--bg-2); border: 1px solid var(--line); color: var(--ink-soft); border-radius: 100px; transition: all .14s; }
.fchip:hover { border-color: var(--ink-mute); color: var(--ink); }
.fchip.on { background: var(--accent); border-color: var(--accent); color: #fff; }

/* header search trigger */
.icon-btn { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: var(--r); background: transparent; border: 1px solid var(--line-2); color: var(--ink-soft); transition: all .15s; }
.icon-btn:hover { color: var(--ink); border-color: var(--ink-mute); background: var(--surface-2); }
@media (max-width: 1000px){ .search-trigger { display: none; } }

/* search overlay */
.search-scrim { position: fixed; inset: 0; z-index: 90; background: rgba(8,12,18,.55); backdrop-filter: blur(5px); display: flex; justify-content: center; align-items: flex-start; padding: 0 20px; }
[data-theme="light"] .search-scrim { background: rgba(16,30,52,.42); }
.search-panel { width: 100%; max-width: 720px; margin-top: 11vh; background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--r-2); box-shadow: var(--shadow); overflow: hidden; animation: searchIn .22s cubic-bezier(.2,.8,.3,1); }
@keyframes searchIn { from { transform: translateY(-14px); } }
.search-bar { display: flex; align-items: center; gap: 13px; padding: 16px 18px; border-bottom: 1px solid var(--line); }
.search-bar > .icn { color: var(--accent); flex: none; }
.search-bar input { flex: 1; background: none; border: none; outline: none; color: var(--ink); font-family: var(--font-body); font-size: 1.18rem; }
.search-bar input::placeholder { color: var(--ink-faint); }
.search-bar .sp-x { background: none; border: none; color: var(--ink-mute); display: flex; padding: 4px; flex: none; }
.search-bar .sp-x:hover { color: var(--accent); }
.search-bar .sp-close { flex: none; font-family: var(--font-mono); font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-mute); background: none; border: 1px solid var(--line-2); border-radius: var(--r); padding: 8px 12px; }
.search-bar .sp-close:hover { color: var(--ink); border-color: var(--ink-mute); }
.search-body { max-height: 56vh; overflow-y: auto; overflow-x: hidden; padding: 18px; }
.search-hint .eyebrow { display: block; margin-bottom: 12px; }
.sp-suggs { display: flex; flex-wrap: wrap; gap: 9px; }
.sp-count { font-family: var(--font-mono); font-size: .76rem; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 12px; }
.sp-results { display: flex; flex-direction: column; gap: 8px; }
.sp-item { display: flex; align-items: center; gap: 14px; padding: 10px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r); text-align: left; transition: border-color .14s, transform .14s; }
.sp-item:hover { border-color: var(--blue-2); }
.sp-item img { width: 60px; height: 46px; object-fit: cover; border-radius: 3px; flex: none; background: var(--surface-2); }
.sp-item-main { flex: 1; min-width: 0; }
.sp-item-main b { display: block; font-size: 1.02rem; }
.sp-item-main span { font-family: var(--font-mono); font-size: .74rem; color: var(--ink-mute); }
.sp-item .sp-cat { font-family: var(--font-mono); font-size: .66rem; letter-spacing: .06em; text-transform: uppercase; color: var(--blue-ink); border: 1px solid var(--line-2); border-radius: 100px; padding: 4px 10px; white-space: nowrap; flex: none; }
.sp-item > .icn { color: var(--ink-mute); flex: none; }
.search-empty { text-align: center; padding: 44px 20px; color: var(--ink-mute); }
.search-empty > .icn { color: var(--ink-faint); display: inline-flex; margin-bottom: 12px; }
.search-empty b { color: var(--ink); }
@media (max-width: 560px){ .search-panel { margin-top: 0; max-width: none; height: 100%; border-radius: 0; } .search-body { max-height: none; } .sp-item .sp-cat { display: none; } }

/* ---------- Product landing page ---------- */
.pp-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center; }
.pp-media { position: relative; border: 1px solid var(--line); border-radius: var(--r-2); overflow: hidden; background: var(--bg-2); aspect-ratio: 4/3; }
.pp-media img { width: 100%; height: 100%; object-fit: cover; }
.pp-media .pcard-star { top: 16px; right: 16px; }
.pp-media-wrap { align-self: center; }
.pp-thumbs { display: flex; gap: 10px; margin-top: 12px; flex-wrap: wrap; }
.pp-thumb { width: 76px; height: 60px; border-radius: var(--r); overflow: hidden; border: 1px solid var(--line-2); background: var(--bg-2); padding: 0; cursor: pointer; transition: border-color .15s; }
.pp-thumb img { width: 100%; height: 100%; object-fit: cover; }
.pp-thumb:hover { border-color: var(--ink-mute); }
.pp-thumb.on { border-color: var(--accent); box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent) 35%, transparent); }
.pp-cat { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: .72rem; letter-spacing: .1em; text-transform: uppercase; color: var(--blue-ink); }
.pp-cat svg { width: 16px; height: 16px; }
.pp-info h1 { font-size: clamp(2.1rem, 4vw, 3.3rem); text-transform: uppercase; margin: 14px 0 0; }
.pp-info .pp-tagline { font-family: var(--font-mono); color: var(--ink-mute); margin-top: 12px; font-size: .92rem; letter-spacing: .04em; }
.pp-info .pp-lead { color: var(--ink-soft); font-size: 1.12rem; margin: 22px 0 28px; }
.pp-actions { display: flex; gap: 12px; flex-wrap: wrap; }
.pp-docs { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; margin: 4px 0 26px; }
.pp-doc { display: flex; align-items: center; gap: 12px; padding: 13px 15px; border: 1px solid var(--line-2); border-radius: var(--r); background: var(--surface); transition: border-color .15s, transform .15s; }
.pp-doc:hover { border-color: var(--accent); transform: translateY(-2px); }
.pp-doc-ic { width: 40px; height: 40px; border-radius: var(--r); background: color-mix(in srgb, var(--accent) 15%, transparent); color: var(--accent); display: flex; align-items: center; justify-content: center; flex: none; }
.pp-doc-t { flex: 1; min-width: 0; }
.pp-doc-t b { display: block; font-family: var(--font-display); text-transform: uppercase; font-size: .84rem; letter-spacing: .02em; line-height: 1.15; }
.pp-doc-t span { font-family: var(--font-mono); font-size: .66rem; color: var(--ink-mute); letter-spacing: .04em; }
.pp-doc > .icn:last-child { color: var(--ink-mute); flex: none; }
.pp-doc.disabled .pp-doc-ic { background: var(--surface-3); color: var(--ink-mute); }
@media (max-width: 560px){ .pp-docs { grid-template-columns: 1fr; } }
@media (max-width: 880px){ .pp-grid { grid-template-columns: 1fr; gap: 32px; } }

.pp-body { padding: 80px 0; }
.pp-cols { display: grid; grid-template-columns: 1.3fr 1fr; gap: 56px; align-items: start; }
.pp-cols h3 { font-size: 1.5rem; text-transform: uppercase; margin-bottom: 18px; }
.spec-table.big .spec-row { padding: 14px 0; grid-template-columns: 38% 62%; }
.spec-table.big dt { font-size: .82rem; }
.spec-table.big dd { font-size: 1rem; }
.pp-side { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-2); padding: 28px; position: sticky; top: 100px; }
.pp-side .eyebrow { margin-bottom: 14px; }
.pp-side .chips { margin-top: 0; }
.pp-side .pp-cta { margin-top: 26px; padding-top: 24px; border-top: 1px solid var(--line); display: flex; flex-direction: column; gap: 10px; }
.pp-side .pp-cta .btn { justify-content: center; }
@media (max-width: 880px){ .pp-cols { grid-template-columns: 1fr; gap: 36px; } .pp-side { position: static; } }

.pp-related { border-top: 1px solid var(--line); }

/* youtube videos on product page */
.media-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 760px){ .media-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .media-grid { grid-template-columns: 1fr; } }
.media-photo { display: block; aspect-ratio: 4/3; border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; background: var(--bg-2); }
.media-photo img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.media-photo:hover img { transform: scale(1.05); }
.yt-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 760px){ .yt-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px){ .yt-grid { grid-template-columns: 1fr; } }
.yt-facade { position: relative; width: 100%; aspect-ratio: 16/9; border: 1px solid var(--line); border-radius: var(--r-2); background-size: cover; background-position: center; cursor: pointer; overflow: hidden; padding: 0; }
.yt-facade::after { content: ""; position: absolute; inset: 0; background: rgba(8,12,20,.28); transition: background .15s; }
.yt-facade:hover::after { background: rgba(8,12,20,.12); }
.yt-play { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; z-index: 2; }
.yt-play .icn { width: 66px; height: 66px; border-radius: 50%; background: var(--accent); color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: 0 12px 32px -8px rgba(0,0,0,.55); transition: transform .15s; }
.yt-facade:hover .yt-play .icn { transform: scale(1.08); }
.yt-frame { position: relative; width: 100%; aspect-ratio: 16/9; border-radius: var(--r-2); overflow: hidden; border: 1px solid var(--line); background: #000; }
.yt-frame iframe { width: 100%; height: 100%; display: block; border: 0; }

/* reveal on scroll (kept below new rules) */

/* ============================================================
   Landing individual por producto (.pl-) — sección ampliada
   ============================================================ */
.pl { position: relative; padding: 96px 0 0; background: var(--bg-2); border-top: 1px solid var(--line); overflow: hidden; }
.pl-grid-bg { position: absolute; inset: 0; pointer-events: none; opacity: .55;
  background-image: linear-gradient(var(--line) 1px, transparent 1px), linear-gradient(90deg, var(--line) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(120% 70% at 50% 0%, #000 0%, transparent 72%);
          mask-image: radial-gradient(120% 70% at 50% 0%, #000 0%, transparent 72%); }
.pl .container { position: relative; z-index: 1; }
.pl-head { max-width: 780px; }
.pl-head h2 { font-size: clamp(2rem, 3.8vw, 3.2rem); text-transform: uppercase; margin-top: 16px; }
.pl-head .pl-hl { color: var(--accent); }
.pl-head p { color: var(--ink-mute); margin-top: 16px; font-family: var(--font-mono); font-size: .76rem; letter-spacing: .1em; text-transform: uppercase; }

/* franja de especificaciones clave */
.pl-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); margin-top: 48px; }
.pl-stat { background: var(--surface); padding: 30px 26px; position: relative; }
.pl-stat::before { content: ""; position: absolute; top: 0; left: 0; width: 34px; height: 3px; background: var(--accent); }
.pl-stat-k { display: block; font-family: var(--font-mono); font-size: .7rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-mute); }
.pl-stat b { display: block; font-family: var(--font-display); font-weight: 900; font-size: clamp(1.35rem, 2.4vw, 2.1rem); color: var(--ink); margin-top: 12px; line-height: 1.05; }

/* bloques internos */
.pl-block { margin-top: 72px; }
.pl-block-h { margin-bottom: 28px; }
.pl-block-h h3 { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: clamp(1.5rem, 2.6vw, 2.1rem); margin-top: 12px; }

/* aplicaciones */
.pl-apps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.pl-app { display: flex; align-items: center; gap: 14px; padding: 18px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); transition: border-color .15s ease, transform .15s ease; }
.pl-app:hover { border-color: var(--accent); transform: translateY(-3px); }
.pl-app-ic { width: 42px; height: 42px; flex: none; display: flex; align-items: center; justify-content: center; border-radius: var(--r); background: color-mix(in srgb, var(--accent) 13%, transparent); color: var(--accent); }
.pl-app > span:last-child { font-family: var(--font-display); font-weight: 600; text-transform: uppercase; font-size: .82rem; letter-spacing: .02em; line-height: 1.15; }
@media (max-width: 860px) { .pl-apps { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .pl-apps { grid-template-columns: 1fr; } }

/* por qué baripanel */
.pl-why { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.pl-why-item { padding: 26px 22px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r); }
.pl-why-ic { width: 48px; height: 48px; display: flex; align-items: center; justify-content: center; border-radius: var(--r); background: color-mix(in srgb, var(--blue) 14%, transparent); color: var(--blue-ink); margin-bottom: 16px; }
.pl-why-item b { display: block; font-family: var(--font-display); text-transform: uppercase; font-size: 1rem; }
.pl-why-item p { color: var(--ink-soft); font-size: .95rem; margin: 8px 0 0; }
@media (max-width: 860px) { .pl-why { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .pl-why { grid-template-columns: 1fr; } }

/* CTA con imagen del producto */
.pl-cta { margin-top: 84px; position: relative; background-size: cover; background-position: center; border-top: 1px solid var(--line); }
.pl-cta::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(11,18,30,.95), rgba(11,18,30,.58)); }
.pl-cta-in { position: relative; z-index: 1; padding: 84px 28px; }
.pl-cta-in .kicker { color: #7fb4f0; }
.pl-cta-in .kicker::before { background: #7fb4f0; }
.pl-cta-in h3 { font-family: var(--font-display); font-weight: 900; color: #fff; text-transform: uppercase; font-size: clamp(1.8rem, 4vw, 3.2rem); margin-top: 14px; max-width: 22ch; }
.pl-cta-in p { color: rgba(255,255,255,.82); font-size: 1.1rem; max-width: 54ch; margin: 18px 0 30px; }
.pl-cta-btns { display: flex; flex-wrap: wrap; gap: 14px; }
.pl-cta-btns .pl-ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.pl-cta-btns .pl-ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; box-shadow: none; }

/* ============================================================
   Cotizador en modal (.qz-)
   ============================================================ */
.qz-scrim { position: fixed; inset: 0; z-index: 95; background: rgba(8,12,18,.55); backdrop-filter: blur(5px); display: flex; justify-content: center; align-items: flex-start; padding: 0 20px; }
[data-theme="light"] .qz-scrim { background: rgba(16,30,52,.42); }
.qz-panel { width: 100%; max-width: 560px; margin-top: 8vh; margin-bottom: 8vh; background: var(--surface); border: 1px solid var(--line-2); border-radius: var(--r-2); box-shadow: var(--shadow); overflow: hidden; display: flex; flex-direction: column; max-height: 84vh; animation: searchIn .22s cubic-bezier(.2,.8,.3,1); }
.qz-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 20px 22px; border-bottom: 1px solid var(--line); }
.qz-head b { display: block; font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: 1.15rem; margin-top: 8px; line-height: 1.1; }
.qz-x { background: none; border: 1px solid var(--line-2); border-radius: var(--r); color: var(--ink-mute); display: flex; padding: 7px; flex: none; }
.qz-x:hover { color: var(--accent); border-color: var(--ink-mute); }
.qz-body { padding: 22px; overflow-y: auto; }
.qz-step { display: flex; flex-direction: column; }
.qz-block-t { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--ink-mute); margin: 4px 0 14px; }
.qz-client { padding-bottom: 18px; margin-bottom: 18px; border-bottom: 1px dashed var(--line-2); }
.qz-prod { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: 1.05rem; color: var(--accent); padding: 10px 14px; background: color-mix(in srgb, var(--accent) 9%, transparent); border: 1px solid var(--line); border-radius: var(--r); margin-bottom: 16px; }

/* campos */
.qz-f { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.qz-f > span { font-family: var(--font-mono); font-size: .7rem; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-mute); }
.qz-f input, .qz-f select { width: 100%; background: var(--bg-2); border: 1px solid var(--line-2); border-radius: var(--r); color: var(--ink); font-family: var(--font-body); font-size: 1rem; padding: 11px 13px; outline: none; transition: border-color .14s; }
.qz-f input:focus, .qz-f select:focus { border-color: var(--accent); }
.qz-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 480px) { .qz-grid { grid-template-columns: 1fr; } }

/* errores */
.qz-err { color: var(--red); font-size: .88rem; min-height: 0; margin-bottom: 6px; }
.qz-err:not(:empty) { min-height: 20px; }

/* acciones */
.qz-actions { display: flex; flex-wrap: wrap; gap: 10px; justify-content: flex-end; margin-top: 8px; }
.qz-btn { display: inline-flex; align-items: center; justify-content: center; gap: .55em; font-family: var(--font-display); font-weight: 700; font-size: .86rem; letter-spacing: .02em; text-transform: uppercase; padding: 12px 18px; border-radius: var(--r); border: 1px solid transparent; transition: transform .14s ease, background .14s, box-shadow .14s; }
.qz-btn:hover { transform: translateY(-2px); }
.qz-btn.primary { background: var(--blue); color: #fff; border-color: var(--blue); }
.qz-btn.ghost { background: transparent; color: var(--ink); border-color: var(--line-2); }
.qz-btn.ghost:hover { background: var(--surface-2); transform: none; }
.qz-btn.wa { background: #25d366; color: #07301a; border-color: #25d366; flex: 1; }
.qz-btn.wa:hover { box-shadow: 0 12px 24px -10px rgba(37,211,102,.6); }
.qz-btn.mail { background: var(--blue); color: #fff; border-color: var(--blue); flex: 1; }

/* resumen / carrito */
.qz-cart { display: flex; flex-direction: column; gap: 10px; margin-bottom: 18px; }
.qz-item { display: flex; align-items: flex-start; gap: 12px; padding: 13px 14px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r); }
.qz-item-main { flex: 1; min-width: 0; }
.qz-item-main b { display: block; font-family: var(--font-display); text-transform: uppercase; font-size: .95rem; }
.qz-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }
.qz-chip { font-family: var(--font-mono); font-size: .68rem; padding: 4px 9px; border: 1px solid var(--line-2); border-radius: 100px; color: var(--ink-soft); }
.qz-rm { background: none; border: 1px solid var(--line-2); border-radius: var(--r); color: var(--ink-mute); padding: 7px; display: flex; flex: none; }
.qz-rm:hover { color: var(--red); border-color: var(--red); }
.qz-cart-recap .qz-item { background: var(--surface-2); }
.qz-ask { font-family: var(--font-display); font-weight: 700; text-transform: uppercase; font-size: 1.05rem; margin: 4px 0 14px; }
.qz-note { color: var(--ink-soft); font-size: .92rem; margin: 0 0 16px; }
.qz-send { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 14px; }

/* buscador interno */
.qz-searchbar input { width: 100%; background: var(--bg-2); border: 1px solid var(--line-2); border-radius: var(--r); color: var(--ink); font-size: 1.04rem; padding: 13px 15px; outline: none; }
.qz-searchbar input:focus { border-color: var(--accent); }
.qz-results { display: flex; flex-direction: column; gap: 8px; margin: 14px 0; max-height: 40vh; overflow-y: auto; }
.qz-result { display: flex; align-items: center; gap: 12px; padding: 9px; background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--r); text-align: left; transition: border-color .14s; }
.qz-result:hover { border-color: var(--blue-2); }
.qz-result img { width: 52px; height: 40px; object-fit: cover; border-radius: 3px; flex: none; background: var(--surface-2); }
.qz-result-main { flex: 1; min-width: 0; }
.qz-result-main b { display: block; font-size: .96rem; }
.qz-result-main span { font-family: var(--font-mono); font-size: .72rem; color: var(--ink-mute); }
.qz-result > svg { color: var(--ink-mute); flex: none; }
.qz-nores { text-align: center; color: var(--ink-mute); padding: 26px 10px; }

/* confirmación */
.qz-done { align-items: center; text-align: center; padding: 16px 6px; }
.qz-ok { width: 60px; height: 60px; border-radius: 50%; background: color-mix(in srgb, #25d366 22%, transparent); color: #1aa251; display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.qz-done h3 { font-family: var(--font-display); text-transform: uppercase; font-size: 1.5rem; }
.qz-done p { color: var(--ink-soft); margin: 12px 0 18px; max-width: 38ch; }

@media (max-width: 560px) { .qz-panel { margin: 0; max-width: none; height: 100%; max-height: 100%; border-radius: 0; } }

/* pop-up "más información" — control empresa/particular */
.qz-panel--sm { max-width: 440px; }
.qz-seg { display: flex; gap: 8px; }
.qz-seg-b { flex: 1; padding: 11px; border: 1px solid var(--line-2); border-radius: var(--r); background: var(--bg-2); color: var(--ink-soft); font-family: var(--font-display); font-weight: 600; text-transform: uppercase; font-size: .82rem; letter-spacing: .02em; transition: background .14s, color .14s, border-color .14s; }
.qz-seg-b.on { background: var(--blue); color: #fff; border-color: var(--blue); }
.qz-seg-b:not(.on):hover { border-color: var(--ink-mute); color: var(--ink); }

/* ============================================================
   v2 "Product story" (.ps-) — landing con efectos al scrollear
   ============================================================ */
.ps { position: relative; background: var(--bg-2); border-top: 1px solid var(--line); padding: 0 0 0; overflow: clip; }
.ps .container { padding-top: 92px; }

/* barra de progreso de la sección (sticky arriba) */
.ps-progress { position: sticky; top: 0; left: 0; display: block; height: 3px; width: 100%; background: var(--line); z-index: 6; }
.ps-progress i { display: block; height: 100%; width: 0; background: var(--accent); transition: width .08s linear; }

.ps-head { max-width: 760px; margin-bottom: 56px; }
.ps-head h2 { font-size: clamp(2.2rem, 5vw, 4rem); text-transform: uppercase; margin-top: 16px; line-height: .98; }
.ps-sub { color: var(--ink-mute); margin-top: 16px; font-family: var(--font-mono); font-size: .8rem; letter-spacing: .1em; text-transform: uppercase; }

/* split: imagen sticky + capítulos */
.ps-split { display: grid; grid-template-columns: minmax(0, 0.92fr) 1.08fr; gap: 56px; align-items: start; padding-bottom: 96px; }
.ps-sticky { position: sticky; top: 96px; }
.ps-media { position: relative; margin: 0; border-radius: var(--r-2); overflow: hidden; box-shadow: var(--shadow); }
.ps-media img { width: 100%; aspect-ratio: 4/5; object-fit: cover; transition: transform 1.1s cubic-bezier(.2,.8,.2,1); }
.ps-media.in img { transform: scale(1); }
.ps-media:not(.in) img { transform: scale(1.12); }
.ps-media figcaption { position: absolute; left: 16px; bottom: 16px; right: 16px; background: rgba(11,18,30,.72); backdrop-filter: blur(6px); border: 1px solid rgba(255,255,255,.14); border-radius: var(--r); padding: 12px 16px; }
.ps-media figcaption .mono { display: block; color: #8fc0f5; font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; }
.ps-media figcaption b { font-family: var(--font-display); color: #fff; text-transform: uppercase; font-size: 1.15rem; line-height: 1.1; }
.ps-media-star { position: absolute; top: 14px; right: 14px; color: #fff; background: var(--accent); width: 34px; height: 34px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.ps-media-star svg { fill: #fff; }

/* capítulos */
.ps-chapters { display: flex; flex-direction: column; gap: 22px; }
.ps-chapter { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-2); padding: 38px 36px; position: relative; }
.ps-ch-top { display: flex; align-items: center; gap: 16px; margin-bottom: 14px; }
.ps-ch-n { font-family: var(--font-display); font-weight: 900; font-size: 2.2rem; line-height: 1; color: color-mix(in srgb, var(--accent) 32%, transparent); letter-spacing: -.02em; }
.ps-chapter h3 { font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: clamp(1.5rem, 2.6vw, 2.1rem); }

/* especificaciones (lista con entrada escalonada) */
.ps-specs { margin: 22px 0 0; border-top: 1px solid var(--line); }
.ps-spec { display: grid; grid-template-columns: 42% 58%; gap: 16px; padding: 15px 0; border-bottom: 1px solid var(--line); }
.ps-spec dt { font-family: var(--font-mono); font-size: .76rem; letter-spacing: .05em; text-transform: uppercase; color: var(--ink-mute); margin: 0; }
.ps-spec dd { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: 1.1rem; color: var(--ink); }

/* aplicaciones */
.ps-apps { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
.ps-app { display: inline-flex; align-items: center; gap: 9px; padding: 10px 15px; border: 1px solid var(--line-2); border-radius: 100px; font-family: var(--font-display); font-weight: 600; text-transform: uppercase; font-size: .8rem; letter-spacing: .02em; color: var(--ink-soft); transition: border-color .15s, color .15s, transform .15s; }
.ps-app svg { width: 18px; height: 18px; color: var(--accent); }
.ps-app:hover { border-color: var(--accent); color: var(--ink); transform: translateY(-2px); }

/* respaldo */
.ps-why { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 22px; }
.ps-why-item { display: flex; gap: 14px; align-items: flex-start; }
.ps-why-ic { width: 44px; height: 44px; flex: none; display: flex; align-items: center; justify-content: center; border-radius: var(--r); background: color-mix(in srgb, var(--blue) 13%, transparent); color: var(--blue-ink); }
.ps-why-item b { display: block; font-family: var(--font-display); text-transform: uppercase; font-size: .96rem; }
.ps-why-item p { color: var(--ink-soft); font-size: .9rem; margin: 5px 0 0; }

/* entrada escalonada de los hijos cuando el capítulo entra */
.ps-spec, .ps-app, .ps-why-item { opacity: 0; transform: translateY(16px); transition: opacity .55s ease, transform .55s ease; transition-delay: calc(var(--i, 0) * 70ms); }
.ps-chapter.in .ps-spec, .ps-chapter.in .ps-app, .ps-chapter.in .ps-why-item { opacity: 1; transform: none; }

/* CTA con parallax */
.ps-cta { position: relative; overflow: hidden; border-top: 1px solid var(--line); min-height: 360px; display: flex; align-items: center; }
.ps-cta-bg { position: absolute; left: 0; right: 0; top: -14%; height: 128%; background-size: cover; background-position: center; will-change: transform; }
.ps-cta::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(11,18,30,.94), rgba(11,18,30,.55)); }
.ps-cta-in { position: relative; z-index: 1; padding: 78px 28px; }
.ps-cta-in .kicker { color: #8fc0f5; }
.ps-cta-in .kicker::before { background: #8fc0f5; }
.ps-cta-in h3 { font-family: var(--font-display); font-weight: 900; color: #fff; text-transform: uppercase; font-size: clamp(1.9rem, 4.4vw, 3.4rem); margin-top: 14px; max-width: 22ch; }
.ps-cta-in p { color: rgba(255,255,255,.85); font-size: 1.1rem; max-width: 54ch; margin: 18px 0 30px; }
.ps-cta-btns { display: flex; flex-wrap: wrap; gap: 14px; }
.ps-cta-btns .ps-ghost { color: #fff; border-color: rgba(255,255,255,.4); }
.ps-cta-btns .ps-ghost:hover { background: rgba(255,255,255,.12); border-color: #fff; box-shadow: none; }

@media (max-width: 900px) {
  .ps-split { grid-template-columns: 1fr; gap: 28px; }
  .ps-sticky { position: static; }
  .ps-media img { aspect-ratio: 16/10; }
  .ps-chapter { padding: 28px 22px; }
  .ps-why { grid-template-columns: 1fr; }
}
@media (prefers-reduced-motion: reduce) {
  .ps-spec, .ps-app, .ps-why-item { opacity: 1; transform: none; transition: none; }
  .ps-media:not(.in) img, .ps-media.in img { transform: none; transition: none; }
  .ps-cta-bg { top: 0; height: 100%; }
}

/* ============================================================
   Landing enriquecida v1.5 — aplicaciones numeradas, ventajas,
   despiece y selector de acabados
   ============================================================ */
/* aplicaciones numeradas */
.pl-anum { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 24px; }
.pl-anum-card { display: flex; gap: 18px; align-items: flex-start; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-2); padding: 24px 26px; transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease; }
.pl-anum-card:hover { transform: translateY(-3px); border-color: var(--line-2); box-shadow: var(--shadow); }
.pl-anum-n { font-family: var(--font-display); font-weight: 900; font-size: 1.6rem; line-height: 1; color: #f5a623; flex: none; }
.pl-anum-t { font-family: var(--font-display); text-transform: uppercase; font-size: 1.05rem; color: var(--ink); padding-top: 3px; line-height: 1.2; }
@media (max-width: 680px) { .pl-anum { grid-template-columns: 1fr; } }

/* ventajas (sección oscura) */
.plv { position: relative; background: #0c1626; color: #fff; padding: 92px 0; overflow: hidden; border-top: 1px solid var(--line); }
.plv-glow { position: absolute; width: 820px; height: 820px; left: 50%; top: -320px; transform: translateX(-50%); background: radial-gradient(circle, rgba(33,99,178,.5), transparent 62%); pointer-events: none; }
.plv .container { position: relative; z-index: 1; }
.plv .kicker { color: #f5a623; }
.plv .kicker::before { background: #f5a623; }
.plv h2 { font-size: clamp(2rem, 4vw, 3.2rem); text-transform: uppercase; color: #fff; margin-top: 14px; max-width: 22ch; }
.plv h2 span { color: #5b9be6; }
.plv-sub { color: rgba(255,255,255,.7); max-width: 60ch; margin: 18px 0 46px; font-size: 1.06rem; }
.plv-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.plv-card { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); border-radius: var(--r-2); padding: 28px 24px; transition: transform .18s ease, border-color .18s ease, background .18s ease; }
.plv-card:hover { transform: translateY(-4px); border-color: rgba(91,155,230,.55); background: rgba(255,255,255,.06); }
.plv-ic { width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; border-radius: 13px; background: linear-gradient(135deg, #1559a8, #2f7fd1); color: #fff; margin-bottom: 18px; }
.plv-card b { display: block; font-family: var(--font-display); font-size: 1.12rem; text-transform: uppercase; color: #fff; }
.plv-card p { color: rgba(255,255,255,.66); font-size: .94rem; margin: 9px 0 0; }
@media (max-width: 900px) { .plv-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .plv-grid { grid-template-columns: 1fr; } }

/* banda destacada de despiece */
.pld { background: var(--bg-2); border-top: 1px solid var(--line); padding: 58px 0; }
.pld-in { display: flex; align-items: center; gap: 30px; }
.pld-ic { width: 74px; height: 74px; flex: none; border-radius: 18px; background: linear-gradient(135deg, #f5a623, #e8403f); color: #fff; display: flex; align-items: center; justify-content: center; box-shadow: 0 16px 34px -14px rgba(245,166,35,.6); }
.pld-t { flex: 1; min-width: 0; }
.pld-t h3 { font-family: var(--font-display); text-transform: uppercase; font-size: clamp(1.4rem, 2.6vw, 2rem); margin-top: 8px; }
.pld-t p { color: var(--ink-soft); margin: 10px 0 0; max-width: 64ch; }
.pld-btn { flex: none; }
@media (max-width: 820px) { .pld-in { flex-direction: column; align-items: flex-start; gap: 20px; } }

/* selector de acabados */
.plf { padding: 92px 0; }
.plf-head { max-width: 680px; margin-bottom: 42px; }
.plf-head h2 { font-size: clamp(1.9rem, 3.6vw, 2.9rem); text-transform: uppercase; margin-top: 14px; }
.plf-head p { color: var(--ink-soft); margin-top: 14px; }
.plf-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: stretch; }
.plf-list { display: flex; flex-direction: column; gap: 12px; justify-content: center; }
.plf-opt { display: flex; align-items: center; gap: 16px; padding: 16px 18px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-2); text-align: left; transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease; }
.plf-opt:hover { transform: translateX(3px); border-color: var(--line-2); }
.plf-opt.on { border-color: var(--blue); box-shadow: 0 0 0 3px color-mix(in srgb, var(--blue) 16%, transparent); }
.plf-sw { width: 46px; height: 46px; border-radius: 12px; flex: none; box-shadow: inset 0 0 0 1px rgba(0,0,0,.08); }
.plf-opt-t b { display: block; font-family: var(--font-display); font-size: 1.05rem; }
.plf-opt-t span { font-family: var(--font-mono); font-size: .74rem; color: var(--ink-mute); }
.plf-preview { background: #0c1626; border-radius: var(--r-2); padding: 46px 30px; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; min-height: 320px; }
.plf-prev-sw { width: 124px; height: 124px; border-radius: 26px; margin-bottom: 26px; box-shadow: 0 22px 44px -16px rgba(0,0,0,.6), inset 0 0 0 1px rgba(255,255,255,.14); transition: background .35s ease; }
.plf-preview h3 { font-family: var(--font-display); color: #fff; text-transform: uppercase; font-size: 2rem; }
.plf-preview p { color: rgba(255,255,255,.72); margin-top: 12px; max-width: 30ch; }
@media (max-width: 760px) { .plf-wrap { grid-template-columns: 1fr; } .plf-preview { min-height: 240px; } }
