:root {
  --red:      #C8181E;
  --red-dark: #A01218;
  --red-lt:   #F5E6E7;
  --black:    #111111;
  --steel:    #1E2830;
  --ink:      #222222;
  --mid:      #555555;
  --muted:    #888888;
  --rule:     #E2E2E2;
  --bg:       #F4F2EF;
  --surface:  #FFFFFF;
  --surface2: #EDEAE6;
  --green:    #1E7A3C;
  --wa:       #25D366;
  --fd:       'Fjalla One', sans-serif;
  --fb:       'DM Sans', sans-serif;
  --r: 2px;
  --r-card: 14px;
  --t: 0.2s ease;
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.06);
  --shadow-md: 0 6px 24px rgba(0,0,0,0.10);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.14);
  --shadow-hover: 0 20px 56px rgba(0,0,0,0.18);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--bg);color:var(--ink);overflow-x:hidden;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--red)}

/* TOPBAR */
.topbar{background:var(--steel);padding:8px 48px;display:flex;justify-content:space-between;align-items:center}
.topbar-info{display:flex;gap:24px;font-size:12px;color:#aaa}
.topbar-info a{color:#aaa;text-decoration:none}
.topbar-info a:hover{color:var(--red)}

/* NAV */
nav{position:sticky;top:0;z-index:200;background:var(--surface);border-bottom:4px solid var(--red);box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.nav-inner{width:100%;max-width:none;margin:0;padding:0 48px;height:88px;display:flex;align-items:center;justify-content:space-between;position:relative}
.nav-logo{display:flex;align-items:center;gap:16px;cursor:pointer;margin-right:24px}
.nav-toggle{display:none;align-items:center;justify-content:center;width:46px;height:46px;border:none;background:transparent;cursor:pointer;padding:8px;margin-right:0;font-size:28px;line-height:1;color:var(--ink)}
.nav-toggle:hover{color:var(--red)}
.nav-toggle.open{color:var(--red)}
.logo-img{height:150px;width:auto;display:block;filter:drop-shadow(0 1px 4px rgba(0,0,0,0.12))}
.logo-fallback{background:var(--red);color:#fff;font-family:var(--fd);font-size:22px;padding:6px 18px;border-radius:40px;border:2px solid var(--black);box-shadow:2px 2px 0 var(--black);letter-spacing:1px;display:none}
.logo-divider{font-size:18px;color:var(--mid);font-weight:700}
.logo-sub{font-size:15px;font-weight:800;color:var(--muted);letter-spacing:0.5px;text-transform:uppercase;line-height:1.3;max-width:130px}
.nav-links{display:flex;align-items:center;gap:4px;flex:1;justify-content:space-between;flex-wrap:wrap}
.nav-link{flex:1 1 0;min-width:0;font-size:13px;font-weight:500;color:var(--mid);padding:8px 14px;background:none;border:none;cursor:pointer;border-radius:var(--r);transition:color var(--t),background var(--t);white-space:nowrap;font-family:var(--fb);text-align:center}
.nav-link:hover{color:var(--red);background:var(--red-lt)}
.nav-div{width:1px;height:20px;background:var(--rule);margin:0 8px}
.nav-cta-acceso{display:flex;align-items:center;background:#1a1a2e!important;color:#fff!important}
.nav-cta-acceso:hover{background:#2d2d44!important}
.nav-cta{background:var(--red);color:#fff;font-family:var(--fb);font-size:13px;font-weight:600;padding:10px 22px;border:none;border-radius:var(--r);cursor:pointer;transition:background var(--t),transform var(--t);white-space:nowrap}
.nav-cta:hover{background:var(--red-dark);transform:translateY(-1px)}

/* SLIDER */
.slider{position:relative;overflow:hidden;min-height:520px;height:520px;background-color:#111;
  background-image:linear-gradient(135deg,rgba(0,0,0,0.72) 0%,rgba(0,0,0,0.55) 50%,rgba(0,0,0,0.68) 100%),
  url('https://t4.ftcdn.net/jpg/03/45/30/91/360_F_345309168_CUjVAnWZtUDjwjxVomepAhbtkd.jpg');
  background-size:cover;background-position:center}
.slider::before{content:'';position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg,rgba(200,24,30,0.07) 0%,transparent 40%,transparent 60%,rgba(0,0,0,0.3) 100%);
  pointer-events:none}
.slider-bar{position:absolute;left:0;top:0;bottom:0;width:6px;background:var(--red);z-index:10}
.slide{position:absolute;min-height:520px;inset:0;display:flex;align-items:center;opacity:0;transition:opacity 0.8s ease;pointer-events:none}
.slide.active{opacity:1;pointer-events:auto}
.slide-inner{max-width:1280px;margin:0 auto;padding:0 72px;width:100%;display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;column-gap:48px;row-gap:16px;align-items:start;position:relative;z-index:2}
.slide-text{grid-column:1;grid-row:1;display:flex;flex-direction:column;gap:16px}
.slide-tag{display:inline-flex;align-items:center;gap:8px;font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--red)}
.slide-tag::before{content:'';width:20px;height:2px;background:var(--red);flex-shrink:0}
.slide-title{font-family:var(--fd);font-size:clamp(28px,3.2vw,46px);line-height:1.08;color:#fff;text-transform:uppercase;letter-spacing:0.5px}
.slide-title em{font-style:normal;color:var(--red)}
.slide-body{font-size:15px;font-weight:300;color:rgba(255,255,255,0.82);line-height:1.7;max-width:400px}
.slide-actions{grid-column:1;grid-row:2;display:flex;gap:12px;flex-wrap:wrap}
.slide-img-wrap{grid-column:2;grid-row:1/3;display:flex;align-items:center;justify-content:center;height:360px;position:relative}
.slide-img-inner{display:flex;align-items:center;justify-content:center;width:100%;height:100%;position:relative;z-index:1}
.slide-img{width:100%;height:100%;max-height:480px;object-fit:contain;
  filter:drop-shadow(0 12px 40px rgba(0,0,0,0.5));
  transform:translateX(30px) scale(0.96);
  transition:transform 1.1s cubic-bezier(0.22,1,0.36,1),opacity 0.8s ease;opacity:0}
.slide.active .slide-img{transform:translateX(0) scale(1);opacity:1}
.slide.active .slide-img.slide-img--large{transform:translateX(0) scale(1.3)}
.slider-dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:10}
.slider-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.25);border:none;cursor:pointer;padding:0;transition:background var(--t),transform var(--t)}
.slider-dot.active{background:var(--red);transform:scale(1.2)}
.slider-progress{position:absolute;bottom:0;left:0;height:3px;background:var(--red);z-index:10;width:0;transition:width linear}
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:#fff;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:18px;transition:background var(--t)}
.slider-arrow:hover{background:var(--red);border-color:var(--red)}
.slider-arrow.prev{left:20px}
.slider-arrow.next{right:20px}

/* STATS BAR */
.stats-bar{background:var(--black);position:relative}
.stats-bar::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(200,24,30,0.6),transparent)}
.stats-inner{max-width:1280px;margin:0 auto;padding:0 48px;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{padding:32px 36px;display:flex;flex-direction:column;gap:8px;position:relative;border-right:1px solid rgba(255,255,255,0.05);transition:background var(--t)}
.stat-item:last-child{border-right:none}
.stat-item:hover{background:rgba(255,255,255,0.03)}
.stat-item::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease}
.stat-item:hover::after{transform:scaleX(1)}
.stat-n{font-family:var(--fd);font-size:52px;color:var(--red);line-height:1;letter-spacing:-1px}
.stat-l{font-size:11px;font-weight:500;color:#555;letter-spacing:1.5px;text-transform:uppercase}

/* BUTTONS */
.btn-primary{background:var(--red);color:#fff;font-family:var(--fb);font-size:14px;font-weight:600;padding:13px 28px;border:none;border-radius:var(--r);cursor:pointer;transition:background var(--t),transform var(--t)}
.btn-primary:hover{background:var(--red-dark);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:#fff;font-family:var(--fb);font-size:14px;font-weight:500;padding:13px 28px;border:1px solid rgba(255,255,255,0.2);border-radius:var(--r);cursor:pointer;transition:border-color var(--t),color var(--t)}
.btn-ghost:hover{border-color:var(--red);color:var(--red)}
.btn-wa{display:flex;align-items:center;justify-content:center;gap:10px;background:var(--wa);color:#fff;font-family:var(--fb);font-size:14px;font-weight:600;padding:15px 24px;border:none;border-radius:var(--r);cursor:pointer;transition:background var(--t),transform var(--t)}
.btn-wa:hover{background:#1fb055;transform:translateY(-1px)}

/* STRIP */
.strip{background:var(--red);padding:16px 48px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.strip-text{font-size:15px;font-weight:500;color:#fff}
.strip-btn{background:#fff;color:var(--red);font-family:var(--fb);font-size:13px;font-weight:700;padding:10px 22px;border:none;border-radius:var(--r);cursor:pointer;white-space:nowrap;transition:background var(--t)}
.strip-btn:hover{background:#f0f0f0}

/* SECTION */
.section{max-width:1280px;margin:0 auto;padding:72px 48px}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid var(--rule)}
.section-label{font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--red);margin-bottom:8px;display:flex;align-items:center;gap:8px}
.section-label::before{content:'';width:16px;height:2px;background:var(--red)}
.section-title{font-family:var(--fd);font-size:clamp(26px,3vw,38px);color:var(--black);line-height:1.1}

/* SEARCH */
.search-wrap{display:flex;align-items:center;gap:16px}
.search-box{position:relative;display:flex;align-items:center}
.search-icon{position:absolute;left:14px;font-size:15px;color:var(--muted);pointer-events:none;line-height:1}
.search-input{padding:11px 16px 11px 40px;border:1.5px solid var(--rule);border-radius:40px;font-size:14px;font-family:var(--fb);width:260px;outline:none;transition:border-color 0.2s ease,box-shadow 0.2s ease;background:var(--surface);color:var(--ink)}
.search-input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(200,24,30,0.08)}
.search-input::placeholder{color:var(--muted)}
.search-clear{position:absolute;right:12px;background:none;border:none;cursor:pointer;font-size:16px;color:var(--muted);line-height:1;display:none;padding:2px}
.search-clear.visible{display:block}
.search-clear:hover{color:var(--red)}

/* CATEGORY GRID */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.cat-card{background:var(--surface);border-radius:var(--r-card);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform 0.3s cubic-bezier(0.34,1.56,0.64,1), box-shadow 0.3s ease;position:relative;display:flex;flex-direction:column;overflow:hidden;opacity:0;animation:fadeUp 0.45s ease forwards;border:1px solid rgba(0,0,0,0.04)}
.cat-card:hover{transform:translateY(-6px) scale(1.01);box-shadow:var(--shadow-hover)}
.cat-img-wrap{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;background:var(--surface2)}
.cat-img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s cubic-bezier(0.25,0.46,0.45,0.94);display:block}
.cat-card:hover .cat-img{transform:scale(1.08)}
.cat-img-wrap::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom, transparent 50%, rgba(0,0,0,0.35) 100%);opacity:0;transition:opacity 0.3s ease}
.cat-card:hover .cat-img-wrap::after{opacity:1}
.cat-tag{position:absolute;top:10px;right:10px;background:var(--red);color:#fff;font-size:10px;font-weight:600;letter-spacing:0.8px;padding:3px 9px;border-radius:40px;opacity:0;transform:translateY(-4px);transition:opacity 0.2s ease,transform 0.2s ease;z-index:2;pointer-events:none}
.cat-card:hover .cat-tag{opacity:1;transform:translateY(0)}
.cat-body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px;flex:1}
.cat-name{font-size:16px;font-weight:600;color:var(--ink);line-height:1.3}
.cat-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:10px}
.cat-count{font-size:12px;color:var(--muted)}
.cat-arrow-btn{width:28px;height:28px;border-radius:50%;background:var(--red-lt);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--red);transition:background 0.2s,transform 0.2s}
.cat-card:hover .cat-arrow-btn{background:var(--red);color:#fff;transform:rotate(45deg)}

/* HOW IT WORKS */
.steps-bg{background:var(--black)}
.steps-inner{max-width:1280px;margin:0 auto;padding:72px 48px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,0.06)}
.step{background:var(--black);padding:40px 36px;position:relative}
.step-num{font-family:var(--fd);font-size:64px;color:rgba(200,24,30,0.12);line-height:1;position:absolute;top:28px;right:28px;user-select:none}
.step-icon{font-size:28px;margin-bottom:20px}
.step-title{font-family:var(--fd);font-size:20px;color:#fff;margin-bottom:12px}
.step-body{font-size:14px;color:#777;line-height:1.7}

/* PRODUCT GRID */
.prod-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--rule);border:1px solid var(--rule);border-radius:var(--r);overflow:hidden}
.prod-card{background:var(--surface);cursor:pointer;transition:background var(--t)}
.prod-card:hover{background:var(--surface2)}
.prod-img-wrap{height:260px;background:var(--surface2);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--rule);position:relative;overflow:hidden}
.prod-real-img{width:100%;height:100%;object-fit:contain;padding:16px;transition:transform 0.3s ease}
.prod-card:hover .prod-real-img{transform:scale(1.04)}
.prod-avail{position:absolute;top:12px;left:12px;font-size:10px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--green);background:rgba(30,122,60,0.1);border:1px solid rgba(30,122,60,0.25);padding:3px 10px;border-radius:40px}
.prod-body{padding:20px 24px 24px}
.prod-name{font-family:var(--fd);font-size:17px;color:var(--black);margin-bottom:6px;line-height:1.2}
.prod-variantes{display:flex;flex-wrap:wrap;gap:5px;margin:8px 0 12px}
.prod-variante-tag{display:inline-block;padding:3px 10px;background:var(--surface2);border:1px solid var(--rule);border-radius:20px;font-size:11px;color:var(--muted);white-space:nowrap}
.prod-desc{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:16px}
.prod-footer{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--rule)}
.prod-link{font-size:12px;font-weight:600;color:var(--red);display:flex;align-items:center;gap:4px;transition:gap var(--t)}

/* PAGE HEADER */
.page-header{background:var(--surface);border-bottom:1px solid var(--rule)}
.page-header-inner{max-width:1280px;margin:0 auto;padding:36px 48px}
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin-bottom:12px}
.breadcrumb span{cursor:pointer;transition:color var(--t)}
.breadcrumb span:hover{color:var(--red)}
.bc-sep{color:var(--rule)}
.page-h1{font-family:var(--fd);font-size:clamp(32px,4vw,52px);color:var(--black);line-height:1.05}
.page-h1 em{font-style:normal;color:var(--red)}
.cat-title-row{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.cat-home-btn{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:56px;height:calc(1em * 1.05);font-size:clamp(32px,4vw,52px);align-self:center;background:#C8181E;border-radius:10px;text-decoration:none;transition:background .2s,transform .15s}
.cat-home-btn:hover{background:#a51217;transform:translateX(-3px)}
/* ── BOTÓN VOLVER FLOTANTE ── */
.cat-home-btn-float{position:fixed;top:96px;left:0;z-index:998;width:56px;height:calc(1em * 1.05);font-size:clamp(32px,4vw,52px);background:#C8181E;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 16px rgba(200,24,30,0.35);opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .25s,transform .25s}
.cat-home-btn-float.visible{opacity:1;pointer-events:auto;transform:translateY(0)}
.cat-home-btn-float:hover{background:#a51217}
@media (max-width:768px){.cat-home-btn-float{top:70px;width:48px;height:48px;font-size:32px}}

/* DETAIL */
.detail-layout{max-width:1280px;margin:0 auto;padding:48px 48px 80px;display:grid;grid-template-columns:572px 1fr;gap:56px;align-items:start}
.gallery{position:sticky;top:88px}
.gallery-main{background:var(--surface);border:1px solid var(--rule);aspect-ratio:5/4;display:flex;align-items:center;justify-content:center;margin-bottom:10px;position:relative;overflow:hidden;transition:opacity 0.15s ease}
.gallery-real-img{width:100%;height:100%;object-fit:contain;padding:16px}
.gallery-avail{position:absolute;top:14px;left:14px;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--green);background:rgba(30,122,60,0.08);border:1px solid rgba(30,122,60,0.2);padding:4px 12px;border-radius:40px}
.thumbs{display:flex;gap:8px}
.thumb{width:72px;height:56px;background:var(--surface);border:1.5px solid var(--rule);border-radius:var(--r);cursor:pointer;overflow:hidden;transition:border-color var(--t);flex-shrink:0}
.thumb img{width:100%;height:100%;object-fit:cover}
.thumb:hover{border-color:var(--muted)}
.thumb.active{border-color:var(--red)}
.prod-cat-tag{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--red);margin-bottom:12px}
.prod-cat-tag::before{content:'';width:14px;height:2px;background:var(--red)}
.detail-title{font-family:var(--fd);font-size:38px;color:var(--black);line-height:1.05;margin-bottom:16px}
.detail-desc{font-size:15px;color:var(--mid);line-height:1.75;margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--rule)}
.specs-title{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.specs-table{width:100%;border-collapse:collapse;margin-bottom:28px}
.specs-table tr{border-bottom:1px solid var(--rule)}
.specs-table tr:last-child{border-bottom:none}
.specs-table td{padding:11px 0;font-size:14px}
.specs-table td:first-child{color:var(--muted);width:48%}
.specs-table td:last-child{color:var(--ink);font-weight:500}
.avail-row{display:flex;align-items:center;gap:8px;padding:12px 14px;background:rgba(30,122,60,0.06);border:1px solid rgba(30,122,60,0.2);border-radius:var(--r);margin-bottom:16px}
.avail-dot{width:8px;height:8px;background:var(--green);border-radius:50%;flex-shrink:0;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.8)}}
.avail-text{font-size:13px;color:var(--green);font-weight:500}
.cta-stack{display:flex;flex-direction:column;gap:10px}

/* CLIENTES */
.clientes-section{background:var(--surface);border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:56px 0;overflow:hidden}
.clientes-head{max-width:1280px;margin:0 auto 36px;padding:0 48px}
.clientes-track-wrap{position:relative;overflow:hidden}
.clientes-track-wrap::before,.clientes-track-wrap::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.clientes-track-wrap::before{left:0;background:linear-gradient(to right,var(--surface),transparent)}
.clientes-track-wrap::after{right:0;background:linear-gradient(to left,var(--surface),transparent)}
.clientes-track{display:flex;gap:0;width:max-content;animation:scrollClients 32s linear infinite}
.clientes-track:hover{animation-play-state:paused}
@keyframes scrollClients{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.cliente-logo{display:flex;align-items:center;justify-content:center;width:220px;height:100px;margin:0 16px;background:var(--surface);border:1.5px solid var(--rule);border-radius:10px;padding:14px 24px;flex-shrink:0;transition:border-color 0.2s ease,box-shadow 0.2s ease,transform 0.2s ease;cursor:default}
.cliente-logo:hover{border-color:var(--red);box-shadow:0 4px 16px rgba(200,24,30,0.1);transform:translateY(-2px)}
.cliente-logo-text{font-family:var(--fd);font-size:18px;color:var(--muted);letter-spacing:1px;user-select:none;transition:color 0.2s;text-align:center}
.cliente-logo:hover .cliente-logo-text{color:var(--red)}
.cliente-logo-sub{font-size:10px;color:var(--rule);text-transform:uppercase;letter-spacing:1px;margin-top:2px;text-align:center}
.cliente-logo-img{max-width:172px;max-height:72px;width:auto;height:auto;object-fit:contain;filter:grayscale(0%);opacity:1;transition:transform 0.2s ease}
.cliente-logo:hover .cliente-logo-img{transform:scale(1.05)}

/* CONDICIONES */
.condiciones-section{background:var(--black);padding:80px 0}
.condiciones-inner{max-width:1280px;margin:0 auto;padding:0 48px}
.condiciones-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:20px;margin-top:40px}
.cond-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:12px;padding:28px 24px;transition:background 0.25s ease,border-color 0.25s ease,transform 0.25s ease;position:relative;overflow:hidden}
.cond-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease}
.cond-card:hover{background:rgba(255,255,255,0.07);border-color:rgba(200,24,30,0.3);transform:translateY(-3px)}
.cond-card:hover::before{transform:scaleX(1)}
.cond-icon{font-size:28px;margin-bottom:16px;display:block}
.cond-title{font-family:var(--fd);font-size:17px;color:#fff;margin-bottom:10px}
.cond-items{list-style:none;display:flex;flex-direction:column;gap:8px}
.cond-items li{font-size:13px;color:#888;line-height:1.5;display:flex;gap:8px;align-items:flex-start}
.cond-items li::before{content:'›';color:var(--red);font-weight:700;flex-shrink:0;margin-top:0.5px}
.condiciones-cta{margin-top:40px;text-align:center}
.condiciones-note{font-size:13px;color:#555;margin-top:12px}
.cond-card--highlight{border:1.5px solid var(--red)}
.cond-badge{display:inline-block;background:var(--red);color:#fff;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:3px 10px;border-radius:20px;margin-bottom:12px}

/* FOOTER */
.footer{background:var(--black);color:#aaa}
.footer-top{max-width:1280px;margin:0 auto;padding:56px 48px 40px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-logo-text{font-family:var(--fd);font-size:24px;color:#fff;margin-bottom:12px}
.footer-logo-text em{font-style:normal;color:var(--red)}
.footer-desc{font-size:13px;color:#666;line-height:1.7;max-width:260px}
.footer-map-wrap{display:block;position:relative;width:100%;max-width:260px;height:130px;margin-top:16px;border-radius:8px;overflow:hidden;border:1px solid rgba(255,255,255,0.1);cursor:pointer;transition:border-color 0.2s}
.footer-map-wrap:hover{border-color:var(--red)}
.footer-map{width:100%;height:100%;pointer-events:none;display:block}
.footer-map-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:6px;background:rgba(0,0,0,0.35);color:#fff;font-size:12px;font-weight:600;letter-spacing:0.5px;opacity:0;transition:opacity 0.2s}
.footer-map-wrap:hover .footer-map-overlay{opacity:1}
.footer-col-title{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#fff;margin-bottom:16px}
.footer-links{list-style:none}
.footer-links li{margin-bottom:8px}
.footer-links a{font-size:13px;color:#666;text-decoration:none;cursor:pointer;transition:color var(--t)}
.footer-links a:hover{color:var(--red)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.07);padding:20px 48px;max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.footer-copy{font-size:12px;color:#444}

/* WA FLOAT */
.wa-float{position:fixed;bottom:28px;right:28px;z-index:999;width:56px;height:56px;background:var(--wa);border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 20px rgba(37,211,102,0.35);cursor:pointer;transition:transform var(--t),box-shadow var(--t)}
.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 28px rgba(37,211,102,0.5)}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.page-h1{opacity:0;animation:fadeUp 0.5s 0.05s ease forwards}
.cat-card:nth-child(1){animation-delay:0.04s}
.cat-card:nth-child(2){animation-delay:0.08s}
.cat-card:nth-child(3){animation-delay:0.12s}
.cat-card:nth-child(4){animation-delay:0.16s}
.cat-card:nth-child(5){animation-delay:0.20s}
.cat-card:nth-child(6){animation-delay:0.24s}
.cat-card:nth-child(7){animation-delay:0.28s}
.cat-card:nth-child(8){animation-delay:0.32s}
.cat-card:nth-child(9){animation-delay:0.36s}
.cat-card:nth-child(10){animation-delay:0.40s}

/* RESPONSIVE */
@media (max-width:1024px){
  .topbar{padding:8px 24px}
  .nav-inner{padding:0 24px;height:72px}
  .logo-img{height:110px}
  .section{padding:56px 24px}
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .steps-inner{padding:56px 24px}
  .prod-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{padding:48px 24px 32px;gap:32px}
  .footer-bottom{padding:20px 24px}
  .strip{padding:14px 24px}
  .stats-inner{padding:0 24px}
  .stat-item{padding:24px 20px}
  .condiciones-inner{padding:0 24px}
  .clientes-head{padding:0 24px}
}
@media (max-width:768px){
  .topbar{padding:8px 16px;flex-direction:column;gap:4px;text-align:center}
  .topbar-info{flex-wrap:wrap;justify-content:center;gap:10px;font-size:11px}
  .nav-inner{padding:0 16px;height:auto;flex-wrap:wrap;gap:8px;padding-top:12px;padding-bottom:12px}
  .nav-toggle{display:flex;order:1}
  .nav-logo{flex:1;order:2;margin-right:0;justify-content:flex-end}
  .logo-img{height:80px}
  .nav-links{width:100%;display:none;flex-wrap:wrap;justify-content:center;gap:8px;position:absolute;top:100%;left:0;right:0;background:var(--surface);padding:16px;box-shadow:0 10px 30px rgba(0,0,0,0.08);z-index:210}
  .nav-links.open{display:flex}
  .nav-link{font-size:12px;padding:10px 12px;flex:1 1 calc(50% - 8px);min-width:140px;max-width:220px;text-align:center}
  .nav-cta-acceso{display:flex;align-items:center;background:#1a1a2e!important;color:#fff!important}
.nav-cta-acceso:hover{background:#2d2d44!important}
.nav-cta{font-size:12px;padding:10px 14px;flex:1 1 100%;width:100%}
  .nav-div{display:none}
  .slider{height:auto;min-height:480px}
  .slide{position:relative;display:none;opacity:1;pointer-events:auto}
  .slide.active{display:flex}
  .slide-inner{display:flex;flex-direction:column;padding:32px 20px 48px;gap:0;text-align:center}
  .slide-text{order:1;margin-bottom:20px}
  .slide-img-wrap{order:2;height:220px;width:100%;margin-bottom:20px}
  .slide-actions{order:3;justify-content:center;grid-column:unset;grid-row:unset}
  .slide-img{max-height:200px;transform:none!important;opacity:1!important}
  .slider-arrow{display:none}
  .stats-inner{grid-template-columns:1fr 1fr;padding:0 16px}
  .stat-item{padding:20px 16px}
  .stat-n{font-size:32px}
  .strip{flex-direction:column;padding:16px;gap:12px;text-align:center}
  .strip-btn{width:100%}
  .section{padding:40px 16px}
  .section-head{flex-direction:column;align-items:flex-start;gap:16px}
  .search-input{width:100%}
  .search-box{flex:1}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .steps-inner{grid-template-columns:1fr;padding:40px 16px;gap:1px}
  .step{padding:32px 24px}
  .prod-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;padding:40px 16px 24px;gap:24px}
  .footer-bottom{flex-direction:column;gap:8px;text-align:center;padding:16px}
  .detail-layout{grid-template-columns:1fr;padding:24px 16px 48px;gap:28px}
  .gallery{position:static}
  .detail-title{font-size:28px}
  .wa-float{bottom:20px;right:16px;width:50px;height:50px}
  .condiciones-inner{padding:0 16px}
  .condiciones-grid{grid-template-columns:1fr 1fr;gap:14px}
  .clientes-head{padding:0 16px}
}
@media (max-width:480px){
  .stat-n{font-size:26px}
  .footer-top{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr 1fr;gap:12px}
  .condiciones-grid{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:1fr 1fr}
}

/* Nav links como anchor */
a.nav-link{display:flex;align-items:center;justify-content:center;text-decoration:none}
a.nav-logo{display:flex;align-items:center;gap:16px;cursor:pointer;margin-right:24px}

/* ── FIXES v2 ─────────────────────────────────────────────── */

/* Grid de herramientas con más aire y sin huecos grises */
.prod-grid {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)) !important;
  gap: 28px !important;
  background: transparent !important;
  border: none !important;
}
.prod-card {
  border-radius: var(--r-card) !important;
  border: 1px solid var(--rule) !important;
  box-shadow: var(--shadow-sm) !important;
  overflow: hidden;
}
.prod-img-wrap {
  height: 240px !important;
  background: #fff !important;
  border-bottom: 1px solid var(--rule) !important;
}
.prod-img-wrap img {
  object-fit: contain !important;
  padding: 16px !important;
}
/* Galería de herramienta: thumbs más pequeños */
.thumb{width:64px;height:64px;}
.prod-body {
  padding: 20px 22px 24px !important;
}

/* Categorías: imagen representativa desde meta URL */
.cat-img-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Logo size fix */
.logo-img { height: 70px !important; width: auto !important; }

/* Mobile nav fix - hamburger y logo en misma línea */
@media (max-width: 768px) {
  .nav-inner {
    flex-wrap: nowrap !important;
    flex-direction: row !important;
    height: 70px !important;
    padding: 0 16px !important;
    align-items: center !important;
  }
  .nav-toggle {
    order: 1 !important;
    flex-shrink: 0 !important;
  }
  .nav-logo {
    order: 2 !important;
    flex: 1 !important;
    justify-content: flex-start !important;
    margin-left: 8px !important;
    gap: 8px !important;
  }
  .logo-img {
    height: 50px !important;
  }
  .logo-sub {
    display: none !important;
  }
  .logo-divider {
    display: none !important;
  }
  .nav-links {
    top: 70px !important;
  }
}

/* Mobile nav - mantener texto pero más pequeño */
@media (max-width: 768px) {
  .logo-sub {
    display: block !important;
    font-size: 10px !important;
    max-width: 80px !important;
    line-height: 1.2 !important;
  }
  .logo-divider {
    display: block !important;
    font-size: 14px !important;
  }
}

/* Móvil: texto arriba, imagen medio, botones abajo */
@media (max-width: 768px) {
  .slide-inner {
    grid-template-columns: 1fr !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    padding: 32px 20px 60px !important;
    text-align: center !important;
  }
  .slide-tag { justify-content: center !important; }
  .slide-title { font-size: clamp(22px,6vw,32px) !important; }
  .slide-body { max-width: 100% !important; }
  .slide-text {
    order: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
  }
  .slide-actions {
    order: 3 !important;
    justify-content: center !important;
  }
  .slide-img-wrap {
    order: 2 !important;
    height: 180px !important;
  }
}




/* ── VARIANTES DE PRODUCTO ────────────────────────────────── */
.variantes-section { margin-bottom: 20px; }
.variantes-grid {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 10px; margin-bottom: 10px;
}
.variante-btn {
  padding: 10px 16px; border: 1.5px solid var(--rule);
  border-radius: var(--r); background: var(--surface);
  cursor: pointer; font-family: var(--fb); font-size: 13px;
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  transition: all 0.2s; text-align: center;
}
.variante-btn:hover { border-color: var(--red); color: var(--red); }
.variante-btn.active {
  border-color: var(--red); background: var(--red-lt);
  color: var(--red);
}
.variante-nombre { font-weight: 600; }
.variante-specs { font-size: 11px; color: var(--muted); }
.variante-btn.active .variante-specs { color: var(--red-dark); }
.variante-selected-info {
  font-size: 13px; color: var(--muted);
  padding: 8px 0; border-top: 1px solid var(--rule);
}

/* Botón outline rojo */
.btn-outline-red {
  background: transparent; color: var(--red);
  font-family: var(--fb); font-size: 14px; font-weight: 500;
  padding: 13px 28px; border: 1.5px solid var(--red);
  border-radius: var(--r); cursor: pointer;
  transition: background var(--t), color var(--t);
}
.btn-outline-red:hover { background: var(--red-lt); }

/* ── CAT GRID FIX: imagen completa sin cortar ─────────────── */
.cat-img { object-fit: contain !important; background: var(--surface2) !important; }

/* Fondo blanco en cards de categoría */
.cat-img-wrap { background: #ffffff !important; }
.cat-img { background: #ffffff !important; }

/* ── BUSCADOR EN CATEGORÍA ── */
.cat-search-wrap{display:flex;align-items:center;gap:16px;margin-bottom:28px;flex-wrap:wrap}
.cat-search-box{display:flex;align-items:center;gap:10px;background:#fff;border:1.5px solid var(--rule);border-radius:40px;padding:10px 18px;flex:1;max-width:480px;transition:border-color .2s}
.cat-search-box:focus-within{border-color:#C8181E}
.cat-search-box svg{color:var(--muted);flex-shrink:0}
.cat-search-box input{border:none;outline:none;font-size:14px;width:100%;background:transparent;color:var(--black)}
.cat-search-box input::placeholder{color:var(--muted)}
.cat-search-box button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:14px;padding:0;line-height:1;flex-shrink:0}
.cat-search-box button:hover{color:var(--black)}
.cat-search-count{font-size:13px;color:var(--muted)}

/* ── FLECHAS GALERÍA ── */
.g-arrow{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,0.92);border:1px solid var(--rule);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;transition:background .2s,box-shadow .2s;box-shadow:0 2px 8px rgba(0,0,0,0.10)}
.g-arrow:hover{background:#fff;box-shadow:0 4px 16px rgba(0,0,0,0.15)}
.g-arrow svg{color:#222}
.g-prev{left:12px}
.g-next{right:12px}
.thumbs{display:flex;gap:8px;overflow-x:auto;scroll-behavior:smooth;padding-bottom:4px}
.thumbs::-webkit-scrollbar{height:4px}
.thumbs::-webkit-scrollbar-thumb{background:var(--rule);border-radius:4px}

/* ── SUBTÍTULO VARIANTE ACTIVA ── */
.detail-variante-active{display:flex;align-items:center;gap:10px;margin:-4px 0 16px;flex-wrap:wrap}
.detail-variante-active span{font-size:15px;font-weight:500;color:var(--red)}
.detail-variante-specs{font-size:13px;color:var(--muted);font-weight:400}
