/* ============================================================
   TECH PREMIUM — Paleta Profesional
   Azul Profundo · Plateado · Cyan Eléctrico
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=IBM+Plex+Mono:wght@300;400;500&family=Outfit:wght@300;400;500;600&display=swap');

:root {
  /* ── Fondos ── */
  --bg:        #03050f;
  --bg2:       #060a18;
  --bg3:       #0a0f20;
  --card:      #080c1a;

  /* ── Acento principal: Cyan eléctrico ── */
  --cyan:      #00c8ff;
  --cyan2:     #38d8ff;
  --cyan-g:    rgba(0, 200, 255, .08);
  --cyan-glow: rgba(0, 200, 255, .18);

  /* ── Plateado / Blanco ── */
  --white:     #eef2f8;
  --white2:    #9aa5be;
  --dim:       #48536b;

  /* ── Azul acento secundario ── */
  --blue:      #1a56ff;
  --blue2:     #3d72ff;

  /* ── Verde estado ── */
  --green:     #00e5a0;

  /* ── Bordes ── */
  --border:    rgba(255,255,255,.05);
  --border2:   rgba(255,255,255,.09);
  --border3:   rgba(0,200,255,.18);

  /* ── Tipografías ── */
  --mono:      'IBM Plex Mono', monospace;
  --display:   'Syne', sans-serif;
  --body:      'Outfit', sans-serif;

  --ease:      cubic-bezier(.4,0,.2,1);
}

/* ── Reset ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; }

body {
  background: var(--bg);
  color: var(--white);
  font-family: var(--body);
  overflow-x: hidden;
  cursor: none;
}

/* ── Textura de ruido sutil ── */
.noise-overlay {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  background-size: 180px;
  opacity: .25;
}

#bgCanvas { position:fixed; inset:0; z-index:0; pointer-events:none; }

/* ── Scrollbar ── */
::-webkit-scrollbar { width:2px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--cyan); border-radius:2px; }

/* ══════════════════════════════════════════
   CURSOR PERSONALIZADO
══════════════════════════════════════════ */
.cursor-dot, .cursor-ring {
  position:fixed; border-radius:50%; pointer-events:none; z-index:9999;
  top:0; left:0; transition:transform .08s; will-change:transform;
}
.cursor-dot {
  width:6px; height:6px; background:var(--cyan);
  box-shadow: 0 0 8px var(--cyan);
}
.cursor-ring {
  width:26px; height:26px;
  border:1px solid rgba(0,200,255,.45);
  transition:transform .16s, width .22s var(--ease), height .22s var(--ease), border-color .22s;
}
.cursor-ring.expand {
  width:40px; height:40px; border-color:rgba(0,200,255,.85);
}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
nav {
  position: fixed; top:0; left:0; right:0; z-index: 200;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 2.5rem; height: 62px;
  background: rgba(3,5,15,.90);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(28px) saturate(1.6);
  transition: border-color .3s;
}
nav.scrolled { border-bottom-color: rgba(0,200,255,.18); }

.logo {
  font-family: var(--display);
  font-size: 1.55rem; letter-spacing:.04em; font-weight:800;
  color: var(--white); text-decoration: none;
  display: flex; align-items: baseline; gap: 2px;
  line-height: 1;
}
.logo em { color:var(--cyan); font-style:normal; }
.logo sup {
  font-family: var(--mono); font-size:.45rem;
  color: var(--dim); margin-left:4px; font-weight:400; letter-spacing:.12em;
}

.nav-links { display:flex; gap:2.5rem; list-style:none; }
.nav-links a {
  font-family: var(--mono); font-size:.66rem; letter-spacing:.14em;
  text-transform: uppercase; color: var(--dim); text-decoration: none;
  transition: color .2s;
}
.nav-links a:hover { color:var(--cyan); }

.nav-right { display:flex; align-items:center; gap:.9rem; }

.nav-wa {
  display: flex; align-items: center; gap:6px;
  font-family: var(--mono); font-size:.63rem; letter-spacing:.08em;
  text-transform: uppercase; color: var(--green);
  text-decoration: none; border: 1px solid rgba(0,229,160,.2);
  padding:.3rem .85rem; border-radius:3px;
  transition: background .2s, border-color .2s;
}
.nav-wa:hover { background:rgba(0,229,160,.07); border-color:rgba(0,229,160,.4); }

.cart-btn {
  position: relative; background: var(--cyan); color:#000;
  border: none; width:40px; height:36px; border-radius:3px;
  cursor: none; display: flex; align-items:center; justify-content:center;
  transition: transform .15s var(--ease), box-shadow .2s;
  box-shadow: 0 0 14px rgba(0,200,255,.3);
}
.cart-btn:hover { transform:scale(1.05); box-shadow:0 0 22px rgba(0,200,255,.5); }
.cnt {
  position: absolute; top:-7px; right:-7px;
  background: var(--bg); color: var(--cyan);
  font-family: var(--mono); font-size:.55rem; font-weight:700;
  width:16px; height:16px; border-radius:50%;
  display: flex; align-items:center; justify-content:center;
  border: 1px solid var(--cyan);
}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero {
  position: relative; z-index: 2;
  min-height: 100vh; display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  padding: 80px 2.5rem 2rem;
  max-width: 1320px; margin: 0 auto;
  gap: 2.5rem;
  overflow: hidden;
}

.hero-bg-text {
  position: absolute; left: -2%; top:50%; z-index:0;
  transform: translateY(-52%);
  font-family: var(--display);
  font-size: clamp(14rem, 22vw, 22rem);
  color: rgba(0,200,255,.018);
  user-select: none; pointer-events:none;
  letter-spacing: -.02em; line-height:1; font-weight:800;
}

.hero-content { position:relative; z-index:1; padding-top: 1rem; }

.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size:.6rem; letter-spacing:.16em;
  text-transform: uppercase; color: var(--cyan);
  border: 1px solid rgba(0,200,255,.22);
  background: rgba(0,200,255,.04);
  padding:.3rem .95rem; border-radius:3px;
  margin-bottom: 1.8rem;
  animation: fadein .8s var(--ease) both;
}
.pulse-dot {
  width:5px; height:5px; border-radius:50%; background:var(--cyan);
  flex-shrink:0;
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse {
  0%,100%{box-shadow:0 0 0 0 rgba(0,200,255,.7)}
  50%{box-shadow:0 0 0 6px rgba(0,200,255,0)}
}

.hero-title {
  font-family: var(--display);
  font-size: clamp(4.2rem, 9vw, 8.5rem);
  line-height: .93; letter-spacing: .01em; font-weight:800;
  margin-bottom: 2rem;
}
.line { display:block; }
.l1 {
  color: var(--white2);
  animation: slidein .7s var(--ease) .1s both;
}
.l2 {
  color: var(--cyan);
  animation: slidein .7s var(--ease) .2s both;
}
.l2 em { color:var(--white); font-style:normal; }
.l3 {
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(0,200,255,.14);
  animation: slidein .7s var(--ease) .3s both;
}

@keyframes slidein {
  from{opacity:0; transform:translateY(40px)}
  to{opacity:1; transform:translateY(0)}
}
@keyframes fadein {
  from{opacity:0; transform:translateY(12px)}
  to{opacity:1; transform:translateY(0)}
}

.hero-sub-wrap {
  display: flex; gap: 1rem; align-items: flex-start;
  margin-bottom: 2.2rem;
  animation: fadein .8s var(--ease) .4s both;
}
.hero-sub-line {
  width:2px; background: linear-gradient(to bottom, var(--cyan), transparent);
  flex-shrink:0; align-self: stretch; min-height:100%;
}
.hero-sub {
  font-size:.95rem; color:var(--white2); line-height:1.82; font-weight:300;
}

.hero-ctas {
  display: flex; gap: .85rem; flex-wrap: wrap;
  margin-bottom: 2.5rem;
  animation: fadein .8s var(--ease) .5s both;
}

.cta-main {
  display: inline-flex; align-items: center; gap:.6rem;
  background: var(--cyan); color: #000;
  font-family: var(--display); font-size:1rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  padding:.7rem 1.8rem; border-radius:3px;
  text-decoration: none; border:none; cursor:none;
  transition: transform .18s var(--ease), box-shadow .2s;
  box-shadow: 0 0 24px rgba(0,200,255,.35);
  position: relative; overflow:hidden;
}
.cta-main::after {
  content:''; position:absolute; inset:0;
  background: rgba(255,255,255,.14);
  transform: translateX(-101%); transition:transform .3s var(--ease);
}
.cta-main:hover::after { transform:translateX(0); }
.cta-main:hover { transform:translateY(-2px); box-shadow:0 0 36px rgba(0,200,255,.55); }

.cta-ghost {
  display: inline-flex; align-items: center; gap:.6rem;
  font-family: var(--mono); font-size:.66rem; letter-spacing:.1em;
  text-transform: uppercase; color:var(--white2);
  text-decoration: none; border:1px solid var(--border2);
  padding:.7rem 1.4rem; border-radius:3px;
  transition: border-color .2s, color .2s, transform .18s var(--ease);
}
.cta-ghost:hover { border-color:var(--cyan); color:var(--cyan); transform:translateY(-2px); }

.trust-bar {
  display: flex; align-items: center; gap:1.5rem;
  font-family: var(--mono); font-size:.62rem; letter-spacing:.08em;
  text-transform: uppercase; color:var(--dim);
  animation: fadein .8s var(--ease) .6s both;
}
.trust-item { display:flex; align-items:center; gap:.4rem; }
.trust-icon { color:var(--green); }
.trust-sep { width:1px; height:14px; background:var(--border2); }

/* ── Hero visual frame ── */
.hero-visual {
  position: relative; z-index:1;
  display: flex; justify-content:center; align-items:center;
  animation: fadein 1s var(--ease) .3s both;
}

.hv-outer { width:100%; max-width:560px; }

.hv-frame {
  position: relative;
  border: 1px solid var(--border3); border-radius:4px; overflow:hidden;
  background: var(--bg3);
  box-shadow: 0 0 60px rgba(0,200,255,.08), 0 0 0 1px rgba(0,200,255,.06);
}

.hv-corner {
  position:absolute; width:14px; height:14px; z-index:4;
  border-color:var(--cyan); border-style:solid;
}
.hv-corner.tl { top:-1px; left:-1px; border-width:2px 0 0 2px; }
.hv-corner.tr { top:-1px; right:-1px; border-width:2px 2px 0 0; }
.hv-corner.bl { bottom:-1px; left:-1px; border-width:0 0 2px 2px; }
.hv-corner.br { bottom:-1px; right:-1px; border-width:0 2px 2px 0; }

.hv-img {
  width:100%; height:440px; object-fit:cover; display:block;
  filter:saturate(1.1) contrast(1.06) brightness(.96);
}
.hv-gradient {
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(3,5,15,.82) 0%, transparent 58%);
  pointer-events:none;
}
.hv-scan {
  position:absolute; left:0; right:0; z-index:3;
  height:1px; background:linear-gradient(90deg, transparent, var(--cyan), transparent);
  animation: scan 3.5s ease-in-out infinite; opacity:.6;
}
@keyframes scan { 0%{top:0;opacity:.8} 88%{top:100%;opacity:.1} 100%{top:100%;opacity:0} }

.hv-chip {
  position:absolute; z-index:3;
  font-family:var(--mono); font-size:.62rem; letter-spacing:.07em;
  display:flex; align-items:center; gap:6px;
  background:rgba(3,5,15,.92); border:1px solid var(--border3);
  padding:.28rem .75rem; border-radius:3px;
}
.chip-tl { top:14px; left:14px; color:var(--green); }
.chip-br { bottom:18px; right:14px; color:var(--white2); }
.chip-dot { width:5px; height:5px; border-radius:50%; background:var(--green); animation:pulse 2s ease-in-out infinite; }

.hv-stats {
  display:flex; align-items:center; justify-content:space-around;
  padding:1.2rem 1.5rem;
  border:1px solid var(--border3); border-top:none;
  background:var(--bg2);
}
.hv-stat { display:flex; flex-direction:column; align-items:center; gap:.2rem; }
.hv-n {
  font-family:var(--display); font-size:2.1rem; line-height:1; color:var(--white);
  font-weight:700;
}
.hv-n sup { font-size:.9rem; color:var(--cyan); }
.hv-l { font-family:var(--mono); font-size:.57rem; letter-spacing:.1em; color:var(--dim); text-transform:uppercase; }
.hv-stat-div { width:1px; height:36px; background:var(--border2); }

.hero-scroll-hint {
  position:absolute; bottom:2rem; left:2.5rem; z-index:2;
  display:flex; align-items:center; gap:.6rem;
  font-family:var(--mono); font-size:.6rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--dim);
  animation: fadein 1s var(--ease) 1s both;
}
.scroll-track {
  width:30px; height:1px; background:var(--dim); position:relative; overflow:hidden;
}
.scroll-thumb {
  position:absolute; left:0; top:0; width:10px; height:100%;
  background:var(--cyan); animation:scrollt 1.8s ease-in-out infinite;
}
@keyframes scrollt { 0%{left:0} 50%{left:20px} 100%{left:0} }

/* ══════════════════════════════════════════
   TICKER
══════════════════════════════════════════ */
.ticker-bar {
  position:relative; z-index:2;
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  background:var(--bg2); overflow:hidden; padding:.55rem 0;
}
.ticker-track {
  display:flex; align-items:center; gap:1.5rem; width:max-content;
  animation:tick 30s linear infinite;
}
.ticker-track:hover { animation-play-state:paused; }
.ticker-track span {
  font-family:var(--display); font-size:.92rem; font-weight:600;
  letter-spacing:.16em; text-transform:uppercase; color:var(--dim); white-space:nowrap;
}
.tick-dot { color:var(--cyan) !important; font-size:.5rem !important; }
@keyframes tick { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ══════════════════════════════════════════
   LAYOUT
══════════════════════════════════════════ */
.wrap { max-width:1200px; margin:0 auto; padding:0 2.5rem; }

.catalog-section { position:relative; z-index:2; padding:6rem 0; }

.section-head {
  display:flex; justify-content:space-between; align-items:flex-end;
  margin-bottom:2rem;
}
.s-tag {
  font-family:var(--mono); font-size:.64rem; letter-spacing:.16em;
  text-transform:uppercase; color:var(--cyan); margin-bottom:.5rem;
}
.s-title {
  font-family:var(--display); font-size:clamp(2.6rem,5vw,4.2rem);
  font-weight:800; line-height:.95; letter-spacing:.01em;
}
.s-title em { color:var(--cyan); font-style:normal; }
.s-count {
  font-family:var(--mono); font-size:.64rem; letter-spacing:.1em;
  color:var(--dim); text-transform:uppercase; align-self:flex-end;
}

/* ── Filtros ── */
.filters {
  display:flex; flex-wrap:wrap; gap:.45rem;
  margin-bottom:2.5rem; padding-bottom:1.5rem;
  border-bottom:1px solid var(--border);
}
.filt {
  font-family:var(--mono); font-size:.64rem; letter-spacing:.1em;
  text-transform:uppercase;
  background:transparent; border:1px solid var(--border);
  color:var(--dim); padding:.38rem .95rem; border-radius:3px;
  cursor:none; transition:all .2s;
}
.filt:hover { border-color:var(--border3); color:var(--white2); }
.filt.active {
  background: rgba(0,200,255,.12);
  border-color:var(--cyan);
  color:var(--cyan); font-weight:500;
}

/* ══════════════════════════════════════════
   PRODUCT GRID
══════════════════════════════════════════ */
.pgrid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px,1fr));
  gap:1px; border:1px solid var(--border);
  background:var(--border);
}

.pcard {
  background:var(--card); cursor:none;
  overflow:hidden; position:relative;
  transition:background .25s var(--ease);
}
.pcard::before {
  content:''; position:absolute; inset:0;
  background: linear-gradient(135deg, rgba(0,200,255,.05), transparent 60%);
  opacity:0; transition:opacity .35s; pointer-events:none; z-index:0;
}
.pcard:hover { background:var(--bg3); }
.pcard:hover::before { opacity:1; }

.pcard-img {
  position:relative; height:220px; overflow:hidden; background:var(--bg3);
}
.pcard-img img {
  width:100%; height:100%; object-fit:cover;
  transition:transform .55s var(--ease); filter:saturate(.9);
}
.pcard:hover .pcard-img img { transform:scale(1.07); filter:saturate(1.15); }

.pcard-badges {
  position:absolute; top:12px; left:12px; right:12px;
  display:flex; justify-content:space-between; align-items:flex-start; z-index:2;
}
.pcard-cat {
  font-family:var(--mono); font-size:.57rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--dim);
  background:rgba(3,5,15,.88); border:1px solid var(--border);
  padding:.18rem .5rem;
}
.pcard-stock {
  font-family:var(--mono); font-size:.57rem; letter-spacing:.06em;
  display:flex; align-items:center; gap:4px;
  background:rgba(3,5,15,.92); padding:.18rem .52rem;
}
.pcard-stock.ok { color:var(--green); border:1px solid rgba(0,229,160,.2); }
.pcard-stock.out { color:#ff5c5c; border:1px solid rgba(255,92,92,.2); }
.sdot { width:5px; height:5px; border-radius:50%; }
.ok .sdot { background:var(--green); }
.out .sdot { background:#ff5c5c; }

.pcard-overlay {
  position:absolute; inset:0; z-index:3;
  display:flex; align-items:center; justify-content:center;
  background:rgba(3,5,15,.5);
  opacity:0; transition:opacity .3s;
}
.pcard:hover .pcard-overlay { opacity:1; }
.pcard-overlay span {
  font-family:var(--display); font-size:.95rem; font-weight:700;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--cyan); border:1px solid var(--cyan);
  padding:.38rem 1.2rem;
  box-shadow: 0 0 20px rgba(0,200,255,.25);
}

.pcard-body { padding:1.1rem 1.25rem 1.3rem; position:relative; z-index:1; }
.pcard-name {
  font-family:var(--display); font-size:1.15rem; font-weight:700;
  letter-spacing:.02em; margin-bottom:.35rem; line-height:1.15;
}
.pcard-desc {
  font-family:var(--mono); font-size:.67rem; color:var(--dim);
  line-height:1.65; margin-bottom:1rem;
}
.pcard-foot {
  display:flex; align-items:center; justify-content:space-between; gap:.75rem;
}
.pcard-price {
  font-family:var(--display); font-size:1.65rem; font-weight:700;
  color:var(--cyan); letter-spacing:.01em; line-height:1;
}
.pcard-price small { font-size:.78rem; font-weight:400; color:var(--dim); font-family:var(--mono); }

.add-btn {
  background: var(--cyan); color:#000;
  font-family:var(--display); font-size:.88rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  border:none; padding:.42rem 1rem; border-radius:3px;
  cursor:none; white-space:nowrap;
  transition:transform .15s var(--ease), box-shadow .2s;
  box-shadow: 0 0 12px rgba(0,200,255,.25);
}
.add-btn:hover { transform:scale(1.05); box-shadow:0 0 20px rgba(0,200,255,.45); }
.add-btn:disabled { background:var(--border); color:var(--dim); cursor:not-allowed; transform:none; box-shadow:none; }

/* ══════════════════════════════════════════
   FEATURES
══════════════════════════════════════════ */
.features-section {
  position:relative; z-index:2;
  padding:4rem 0 6rem;
  border-top:1px solid var(--border);
}
.features-grid {
  display:grid; grid-template-columns:repeat(auto-fit, minmax(230px,1fr));
  gap:1px; border:1px solid var(--border); background:var(--border);
}
.feat-card {
  background:var(--card); padding:2rem 1.75rem;
  transition:background .25s;
}
.feat-card:hover { background:var(--bg3); }
.feat-icon {
  width:44px; height:44px; border:1px solid var(--border2);
  display:flex; align-items:center; justify-content:center;
  margin-bottom:1.25rem; color:var(--cyan);
  transition:border-color .2s, background .2s, box-shadow .2s;
}
.feat-card:hover .feat-icon {
  border-color:rgba(0,200,255,.4);
  background:var(--cyan-g);
  box-shadow: 0 0 14px rgba(0,200,255,.15);
}
.feat-card h3 {
  font-family:var(--display); font-size:1.2rem; font-weight:700;
  letter-spacing:.04em; margin-bottom:.6rem;
}
.feat-card p {
  font-family:var(--mono); font-size:.68rem; color:var(--dim);
  line-height:1.7; letter-spacing:.02em;
}

/* ══════════════════════════════════════════
   ABOUT
══════════════════════════════════════════ */
.about-section {
  position:relative; z-index:2; padding:6rem 0;
  border-top:1px solid var(--border);
}
.about-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start;
}
.about-p {
  color:var(--white2); line-height:1.85; margin-bottom:1.5rem; font-size:.95rem;
  font-weight:300;
}
.about-feats { list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.about-feats li {
  display:flex; gap:.7rem; align-items:center;
  font-family:var(--mono); font-size:.72rem; color:var(--white2);
  letter-spacing:.03em; padding:.5rem 0;
  border-bottom:1px solid var(--border);
}
.af-icon { color:var(--cyan); font-size:.5rem; flex-shrink:0; }

.about-stats { display:flex; flex-direction:column; }
.astat {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.6rem 0; border-bottom:1px solid var(--border);
  transition:padding-left .3s;
}
.astat:first-child { border-top:1px solid var(--border); }
.astat:hover { padding-left:.5rem; }
.astat-n {
  font-family:var(--display); font-size:3.1rem; color:var(--cyan);
  line-height:1; letter-spacing:.02em; font-weight:800;
}
.astat-n sup { font-size:1.2rem; }
.astat-l {
  font-family:var(--mono); font-size:.64rem; letter-spacing:.1em;
  text-transform:uppercase; color:var(--dim); text-align:right;
  max-width:140px; line-height:1.5;
}

/* ══════════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════════ */
.testimonials-section {
  position:relative; z-index:2; padding:6rem 0;
  border-top:1px solid var(--border);
}
.testi-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1px; background:var(--border); border:1px solid var(--border);
  margin-top:2.5rem;
}
.testi-card {
  background:var(--card); padding:2rem 1.75rem;
  display:flex; flex-direction:column; gap:1rem;
  transition:background .25s;
}
.testi-card:hover { background:var(--bg3); }
.testi-stars { color:var(--cyan); letter-spacing:.1em; font-size:.85rem; }
.testi-card > p {
  font-size:.93rem; color:var(--white2); line-height:1.78;
  flex:1; font-style:italic; font-weight:300;
}
.testi-author {
  display:flex; align-items:center; gap:.85rem;
  padding-top:1rem; border-top:1px solid var(--border);
}
.testi-avatar {
  width:38px; height:38px; border-radius:3px;
  background:var(--cyan-g); border:1px solid rgba(0,200,255,.25);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:.72rem; color:var(--cyan); font-weight:700;
  flex-shrink:0;
}
.testi-author strong {
  display:block; font-family:var(--display); font-size:.95rem;
  letter-spacing:.04em; font-weight:700;
}
.testi-author span {
  font-family:var(--mono); font-size:.62rem; color:var(--dim); letter-spacing:.06em;
}

/* ══════════════════════════════════════════
   CONTACTO
══════════════════════════════════════════ */
.contact-section { position:relative; z-index:2; padding:7rem 0; }
.contact-inner-wrap {
  background:var(--bg2); border-top:1px solid var(--border);
  border-bottom:1px solid var(--border); position:relative; overflow:hidden;
}
.contact-bg-text {
  position:absolute; right:-3%; top:50%;
  transform:translateY(-52%);
  font-family:var(--display);
  font-size:clamp(12rem,18vw,18rem);
  color:rgba(0,200,255,.022);
  user-select:none; pointer-events:none; letter-spacing:-.02em; font-weight:800;
}
.contact-inner {
  max-width:600px; text-align:center; margin:0 auto;
  padding:5rem 2rem;
}
.contact-sub {
  color:var(--white2); line-height:1.75; margin:1.25rem 0 2.5rem; font-size:.95rem;
  font-weight:300;
}
.cta-wa-big {
  display:inline-flex; align-items:center; gap:.75rem;
  background:#25d366; color:#000;
  font-family:var(--display); font-size:1.25rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  padding:.9rem 2.5rem; border-radius:3px; text-decoration:none;
  transition:transform .18s var(--ease), box-shadow .2s;
  box-shadow: 0 0 24px rgba(37,211,102,.2);
}
.cta-wa-big:hover { transform:translateY(-2px); box-shadow:0 0 36px rgba(37,211,102,.35); }

.contact-info-row {
  display:flex; align-items:center; justify-content:center; gap:2rem;
  margin-top:2.5rem; flex-wrap:wrap;
}
.contact-info-item {
  display:flex; flex-direction:column; align-items:center; gap:.25rem;
}
.ci-label {
  font-family:var(--mono); font-size:.58rem; letter-spacing:.12em;
  text-transform:uppercase; color:var(--dim);
}
.ci-val {
  font-family:var(--mono); font-size:.72rem; color:var(--white2);
  letter-spacing:.04em;
}
.contact-info-sep { width:1px; height:28px; background:var(--border2); }

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
footer {
  position:relative; z-index:2;
  border-top:1px solid var(--border);
  padding:1.6rem 0; background:var(--bg2);
}
.footer-inner {
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem;
}
.fcopy { font-family:var(--mono); font-size:.68rem; color:var(--dim); letter-spacing:.04em; }
.fsmall { opacity:.35; font-size:.62rem; }

/* ══════════════════════════════════════════
   CARRITO LATERAL
══════════════════════════════════════════ */
.cart-overlay {
  position:fixed; inset:0; z-index:299;
  background:rgba(0,0,0,.8); backdrop-filter:blur(10px);
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.cart-overlay.open { opacity:1; pointer-events:all; }

.cart-panel {
  position:fixed; top:0; right:0; bottom:0; z-index:300;
  width:min(420px,100vw); background:var(--bg2);
  border-left:1px solid var(--border3);
  display:flex; flex-direction:column;
  transform:translateX(100%);
  transition:transform .38s cubic-bezier(.4,0,.2,1);
  box-shadow: -8px 0 48px rgba(0,200,255,.06);
}
.cart-panel.open { transform:translateX(0); }

.cp-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.25rem 1.5rem; border-bottom:1px solid var(--border);
}
.cp-head h3 {
  font-family:var(--display); font-size:1.35rem; font-weight:700; letter-spacing:.04em;
}
.cp-close {
  background:none; border:1px solid var(--border); color:var(--dim);
  width:30px; height:30px; border-radius:3px; cursor:none; font-size:.82rem;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.cp-close:hover { border-color:var(--cyan); color:var(--cyan); }

.cp-items { flex:1; overflow-y:auto; padding:1rem 1.5rem; }
.cp-empty {
  display:flex; flex-direction:column; align-items:center; gap:1rem; margin-top:5rem;
  font-family:var(--mono); font-size:.72rem; color:var(--dim);
  letter-spacing:.08em; text-transform:uppercase;
}

.cp-item {
  display:flex; gap:12px; align-items:flex-start;
  padding:.9rem 0; border-bottom:1px solid var(--border);
}
.cp-item-img {
  width:58px; height:58px; border-radius:3px; object-fit:cover;
  background:var(--bg3); flex-shrink:0; border:1px solid var(--border);
}
.cp-item-info { flex:1; }
.cp-item-name {
  font-family:var(--display); font-size:.95rem; font-weight:700; letter-spacing:.02em; margin-bottom:.3rem;
}
.cp-item-price { font-family:var(--mono); font-size:.75rem; color:var(--cyan); }
.cp-item-qty {
  display:flex; align-items:center; gap:8px; margin-top:.5rem;
}
.qty-btn {
  background:var(--bg3); border:1px solid var(--border); color:var(--white);
  width:22px; height:22px; border-radius:3px; cursor:none; font-size:.82rem;
  display:flex; align-items:center; justify-content:center; transition:border-color .2s, color .2s;
}
.qty-btn:hover { border-color:var(--cyan); color:var(--cyan); }
.qty-num { font-family:var(--mono); font-size:.75rem; min-width:18px; text-align:center; }
.cp-rm {
  background:none; border:none; color:var(--dim); cursor:none; font-size:.72rem;
  padding:.25rem; transition:color .2s; flex-shrink:0;
}
.cp-rm:hover { color:#ff5c5c; }

.cp-foot { padding:1.25rem 1.5rem; border-top:1px solid var(--border); }
.cp-total-row {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:1rem; padding-bottom:1rem; border-bottom:1px solid var(--border);
  font-family:var(--mono); font-size:.72rem; color:var(--dim);
}
#cartTotal {
  font-family:var(--display); font-size:1.6rem; font-weight:700; color:var(--cyan);
}

.btn-wa-send {
  width:100%; background:#25d366; color:#000;
  font-family:var(--display); font-size:1rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  border:none; border-radius:3px; padding:.85rem;
  cursor:none; display:flex; align-items:center; justify-content:center; gap:.6rem;
  transition:transform .18s var(--ease), box-shadow .2s; margin-bottom:.75rem;
  box-shadow: 0 0 18px rgba(37,211,102,.18);
}
.btn-wa-send:hover { box-shadow:0 0 28px rgba(37,211,102,.32); transform:scale(1.01); }
.cp-note {
  font-family:var(--mono); font-size:.63rem; color:var(--dim);
  text-align:center; line-height:1.7; letter-spacing:.03em;
}

/* ══════════════════════════════════════════
   MODAL
══════════════════════════════════════════ */
.modal-overlay {
  position:fixed; inset:0; z-index:399;
  background:rgba(0,0,0,.88); backdrop-filter:blur(12px);
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.modal-overlay.open { opacity:1; pointer-events:all; }

.modal {
  position:fixed; top:50%; left:50%; z-index:400;
  transform:translate(-50%,-56%); opacity:0; pointer-events:none;
  transition:transform .32s var(--ease), opacity .32s;
  background:var(--bg2); border:1px solid var(--border3);
  box-shadow: 0 0 80px rgba(0,200,255,.1);
  width:min(640px,93vw); max-height:88vh; overflow-y:auto;
  border-radius:4px;
}
.modal.open { transform:translate(-50%,-50%); opacity:1; pointer-events:all; }

.modal-close {
  position:absolute; top:14px; right:14px; z-index:10;
  background:var(--bg3); border:1px solid var(--border); color:var(--dim);
  width:30px; height:30px; border-radius:3px; cursor:none; font-size:.82rem;
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.modal-close:hover { border-color:var(--cyan); color:var(--cyan); }

.m-img { width:100%; height:290px; object-fit:cover; display:block; }
.m-body { padding:1.75rem 2rem 2rem; }
.m-cat {
  font-family:var(--mono); font-size:.63rem; letter-spacing:.14em;
  text-transform:uppercase; color:var(--dim); margin-bottom:.5rem;
}
.m-name {
  font-family:var(--display); font-size:2.1rem; font-weight:800; letter-spacing:.02em;
  margin-bottom:.75rem; line-height:1.05;
}
.m-desc { color:var(--white2); line-height:1.78; margin-bottom:1.25rem; font-size:.93rem; font-weight:300; }
.m-price {
  font-family:var(--display); font-size:2.5rem; font-weight:800;
  color:var(--cyan); letter-spacing:.02em; margin-bottom:1.25rem; line-height:1;
}
.m-price small { font-size:.95rem; color:var(--dim); font-family:var(--mono); }
.m-feats { list-style:none; margin-bottom:1.75rem; }
.m-feats li {
  font-family:var(--mono); font-size:.72rem; color:var(--white2);
  padding:.42rem 0; border-bottom:1px solid var(--border);
  display:flex; align-items:center; gap:.6rem;
}
.m-feats li::before { content:'→'; color:var(--cyan); flex-shrink:0; }
.m-add {
  width:100%; background:var(--cyan); color:#000;
  font-family:var(--display); font-size:1.05rem; font-weight:700;
  letter-spacing:.08em; text-transform:uppercase;
  border:none; padding:.88rem; border-radius:3px; cursor:none;
  transition:transform .18s var(--ease), box-shadow .2s;
  box-shadow: 0 0 20px rgba(0,200,255,.3);
}
.m-add:hover { transform:scale(1.01); box-shadow:0 0 32px rgba(0,200,255,.5); }
.m-add:disabled { background:var(--border); color:var(--dim); cursor:not-allowed; transform:none; box-shadow:none; }

/* ══════════════════════════════════════════
   TOAST
══════════════════════════════════════════ */
.toast {
  position:fixed; bottom:2.5rem; left:50%;
  transform:translateX(-50%) translateY(70px);
  background:var(--cyan); color:#000;
  font-family:var(--display); font-size:.92rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  padding:.5rem 1.6rem; border-radius:3px; z-index:999; pointer-events:none;
  display:flex; align-items:center; gap:.5rem;
  transition:transform .32s var(--ease);
  box-shadow: 0 0 28px rgba(0,200,255,.4);
}
.toast.show { transform:translateX(-50%) translateY(0); }

/* ── Reveal on scroll ── */
.rv { opacity:0; transform:translateY(28px); transition:opacity .65s var(--ease), transform .65s var(--ease); }
.rv.in { opacity:1; transform:translateY(0); }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:960px){
  .hero { grid-template-columns:1fr; padding-top:88px; }
  .hero-visual { order:-1; }
  .hv-img { height:300px; }
  .about-inner { grid-template-columns:1fr; gap:3rem; }
  .nav-links, .nav-wa { display:none; }
  .hero-bg-text { display:none; }
}
@media(max-width:600px){
  .hero-visual { display:none; }
  .pgrid { grid-template-columns:1fr; }
  .footer-inner { flex-direction:column; align-items:flex-start; gap:.5rem; }
  .contact-info-row { gap:1rem; }
  .hero-title { font-size:clamp(3.8rem,14vw,5rem); }
}
