
:root{
  --ink:#14181f; --ink-2:#39434f; --muted:#6b7684;
  --line:#e7ebf1; --line-2:#eef1f6; --canvas:#f5f6f9; --surface:#ffffff;
  --blue:#0059ff; --blue-d:#0044c2; --wash:#eef3ff;
  --green:#17a558; --green-d:#128a49; --amber:#f5a623;
  --e:cubic-bezier(.2,.8,.2,1);
  --sh-1:0 1px 2px rgba(20,24,31,.04), 0 12px 30px -18px rgba(20,24,31,.22);
  --sh-2:0 30px 70px -34px rgba(20,24,31,.4);
  --max:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Mulish',sans-serif;color:var(--ink);background:var(--surface);line-height:1.62;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4,.d{font-family:'Montserrat',sans-serif;letter-spacing:-.025em;line-height:1.06;font-weight:800}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{width:100%;max-width:var(--max);margin:0 auto;padding:0 24px}
.kicker{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--blue)}
.kicker .ln{width:26px;height:1px;background:var(--blue);opacity:.5}
.mono-n{font-family:'Montserrat';font-weight:800;font-variant-numeric:tabular-nums}
.center{text-align:center}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:11px;font-weight:800;font-size:15.5px;padding:14px 22px;border-radius:12px;border:0;cursor:pointer;transition:transform .35s var(--e),background .3s,box-shadow .35s var(--e),color .3s;white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn svg{width:17px;height:17px}
.btn.full{width:100%}
.btn-green{background:var(--green);color:#fff;box-shadow:var(--sh-1)}
.btn-green:hover{background:var(--green-d)}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:var(--blue-d)}
.btn-ink{background:var(--ink);color:#fff}
.btn-ink:hover{background:#000}
.btn-line{background:transparent;color:var(--ink);border:1.5px solid var(--line)}
.btn-line:hover{border-color:var(--ink)}
.btn-white{background:#fff;color:var(--blue-d)}
.btn-white:hover{background:var(--wash)}
.arrow-link{display:inline-flex;align-items:center;gap:9px;font-weight:800;color:var(--blue);font-size:15px}
.arrow-link svg{width:16px;height:16px;transition:transform .4s var(--e)}
.arrow-link:hover svg{transform:translateX(5px)}

/* NAV */
header.top{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.72);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-bottom:1px solid transparent;transition:border-color .4s,box-shadow .4s}
header.top.stuck{border-color:var(--line);box-shadow:0 8px 30px -22px rgba(20,24,31,.5)}
.bar{display:flex;align-items:center;gap:16px;height:70px}
.logo{font-family:'Montserrat';font-weight:900;font-size:22px;letter-spacing:-.04em;margin-right:auto;display:inline-flex;align-items:center}
.logo b{color:var(--blue)}
.logo img{height:26px;width:auto;display:block}
footer .logo img{height:30px}
.nav-links{display:flex;gap:2px}
.nav-links a{font-weight:700;font-size:14.5px;color:var(--ink-2);padding:9px 13px;border-radius:9px;transition:color .25s,background .25s}
.nav-links a:hover,.nav-links a.active{color:var(--ink);background:var(--line-2)}
.cart-btn{position:relative;width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:#fff;display:grid;place-items:center;cursor:pointer}
.cart-btn svg{width:19px;height:19px;color:var(--ink)}
.cart-count{position:absolute;top:-7px;right:-7px;min-width:20px;height:20px;padding:0 5px;border-radius:10px;background:var(--blue);color:#fff;font-size:11px;font-weight:800;display:grid;place-items:center}
.cart-count:empty,.cart-count[data-n="0"]{display:none}
.nav-cta{display:inline-flex;align-items:center;gap:9px;background:var(--ink);color:#fff;font-weight:800;font-size:14.5px;padding:11px 16px;border-radius:11px;transition:background .3s}
.nav-cta:hover{background:#000}
.nav-cta svg{width:16px;height:16px}
.hburg{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:#fff;cursor:pointer;align-items:center;justify-content:center}
.hburg i{width:19px;height:2px;background:var(--ink);border-radius:2px;transition:transform .4s var(--e),opacity .3s}
body.mo .hburg i:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.mo .hburg i:nth-child(2){opacity:0}
body.mo .hburg i:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.msheet{position:fixed;inset:70px 0 0;z-index:55;background:#fff;padding:26px 24px;display:flex;flex-direction:column;gap:4px;opacity:0;pointer-events:none;transform:translateY(-8px);transition:opacity .35s var(--e),transform .35s var(--e);overflow:auto}
body.mo .msheet{opacity:1;pointer-events:auto;transform:none}
.msheet a{font-family:'Montserrat';font-weight:800;font-size:23px;padding:13px 0;border-bottom:1px solid var(--line-2)}

/* HERO */
.hero{position:relative;padding:60px 0 40px}
.hero-grid{display:grid;grid-template-columns:1.08fr .92fr;gap:52px;align-items:center}
.h1{font-size:clamp(38px,5.4vw,64px);font-weight:900;color:var(--ink)}
.h1 .inl{display:inline-flex;align-items:center;vertical-align:middle;height:.86em;margin:0 .12em;padding:4px;background:var(--canvas);border:1px solid var(--line);border-radius:16px;transform:rotate(-3deg);box-shadow:var(--sh-1)}
.h1 .inl img{height:100%;width:auto;border-radius:11px;object-fit:contain}
.h1 .blue{color:var(--blue)}
.hero p.sub{color:var(--ink-2);font-size:clamp(16px,1.7vw,19px);max-width:520px;margin:22px 0 28px}
.hero-actions{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.hero-note{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:13.5px;font-weight:600}
.live{width:8px;height:8px;border-radius:50%;background:var(--green);position:relative}
.live::after{content:"";position:absolute;inset:-5px;border-radius:50%;border:1px solid var(--green);animation:pulse 2.2s var(--e) infinite}
@keyframes pulse{0%{transform:scale(.6);opacity:.9}100%{transform:scale(1.5);opacity:0}}
.hero-media{position:relative}
.stage{position:relative;border-radius:28px;overflow:hidden;background:linear-gradient(155deg,#f0f3f8,#e4e9f2);border:1px solid #eaeef4;aspect-ratio:4/4.4}
.stage::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 30% 22%,rgba(0,89,255,.10),transparent 55%)}
.stage img{position:absolute;inset:0;margin:auto;width:82%;height:82%;object-fit:contain;filter:drop-shadow(0 40px 50px rgba(20,24,31,.28))}
.stage .grid-tex{position:absolute;inset:0;background-image:linear-gradient(rgba(20,24,31,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(20,24,31,.045) 1px,transparent 1px);background-size:34px 34px;-webkit-mask-image:linear-gradient(160deg,#000,transparent 60%);mask-image:linear-gradient(160deg,#000,transparent 60%)}
.spec{position:absolute;left:18px;bottom:18px;right:18px;display:flex;gap:9px;flex-wrap:wrap}
.spec .chip{background:rgba(255,255,255,.9);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.7);border-radius:11px;padding:8px 12px;font-size:12.5px;font-weight:700;color:var(--ink);box-shadow:var(--sh-1)}
.spec .chip b{color:var(--blue)}

/* SELECTOR */
.finder{margin-top:26px;border:1px solid var(--line);border-radius:20px;background:var(--surface);box-shadow:var(--sh-1);overflow:hidden}
.finder-top{display:flex;align-items:center;gap:10px;padding:16px 18px 0;flex-wrap:wrap}
.finder-top .t{font-family:'Montserrat';font-weight:800;font-size:15px}
.finder-top .h{font-size:12.5px;color:var(--muted);font-weight:600}
.segs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:6px;padding:12px 12px 0}
.seg{border:1.5px solid var(--line);background:#fff;border-radius:13px;padding:12px 8px;cursor:pointer;text-align:center;transition:border-color .3s var(--e),background .3s,transform .3s var(--e)}
.seg:hover{transform:translateY(-2px)}
.seg.on{border-color:var(--blue);background:var(--wash)}
.seg .lv{font-family:'Montserrat';font-weight:800;font-size:14.5px}
.seg .cap{display:block;font-size:11.5px;color:var(--muted);font-weight:600;margin-top:2px}
.finder-out{display:flex;align-items:center;gap:14px;padding:14px 16px 16px;margin-top:12px;border-top:1px solid var(--line-2);background:linear-gradient(180deg,#fbfcfe,#fff)}
.finder-out img{width:56px;height:56px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:12px;padding:5px;flex:0 0 auto}
.finder-out .info{flex:1;min-width:0}
.finder-out .rk{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.finder-out .rn{font-family:'Montserrat';font-weight:800;font-size:17px;margin:1px 0}
.finder-out .rd{font-size:12.5px;color:var(--ink-2)}

/* BRANDS */
.brands{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;margin-top:52px}
.brands .row{display:flex;align-items:center;gap:34px;flex-wrap:wrap;justify-content:space-between}
.brands .lab{font-size:12.5px;font-weight:700;color:var(--muted);max-width:190px}
.brands .imgs{display:flex;align-items:center;gap:34px;flex-wrap:wrap}
.brands img{height:30px;width:auto;filter:grayscale(1) contrast(.9);opacity:.5;transition:filter .3s,opacity .3s}
.brands img:hover{filter:none;opacity:1}

/* ZIG-ZAG */
.zig{padding:100px 0}
.sec-head{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:end;margin-bottom:52px}
.sec-head h2{font-size:clamp(30px,4.3vw,50px);color:var(--ink)}
.sec-head p{color:var(--ink-2);font-size:17px;max-width:440px}
.row-item{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:44px 0;border-top:1px solid var(--line)}
.row-item:nth-child(even) .media{order:2}
.row-item .idx{font-family:'Montserrat';font-weight:800;font-size:14px;color:var(--blue);letter-spacing:.1em}
.row-item h3{font-size:clamp(24px,3vw,34px);color:var(--ink);margin:10px 0 12px}
.row-item p{color:var(--ink-2);font-size:16px;max-width:440px;margin-bottom:18px}
.media{position:relative}
.media .frame{border-radius:26px;overflow:hidden;background:var(--canvas);border:1px solid var(--line);aspect-ratio:16/11;display:grid;place-items:center;transition:transform .6s var(--e)}
.media .frame img{width:74%;height:74%;object-fit:contain;transition:transform .7s var(--e)}
.row-item:hover .media .frame img{transform:scale(1.05) rotate(-1deg)}
.row-item:nth-child(3) .frame{border-radius:26px 26px 26px 90px}
.row-item:nth-child(5) .frame{border-radius:90px 26px 26px 26px}
.tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.tags span{font-size:12.5px;font-weight:700;color:var(--ink-2);background:var(--line-2);padding:6px 11px;border-radius:8px}

/* PROCESO */
.proc{background:var(--canvas);padding:100px 0}
.proc-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;margin-top:50px;position:relative}
.proc-grid::before{content:"";position:absolute;top:38px;left:8%;right:8%;height:2px;background:repeating-linear-gradient(90deg,var(--line) 0 10px,transparent 10px 20px)}
.pstep{position:relative;padding:0 22px}
.pstep .no{width:74px;height:74px;border-radius:50%;background:#fff;border:2px solid var(--blue);color:var(--blue);font-family:'Montserrat';font-weight:900;font-size:28px;display:grid;place-items:center;margin-bottom:22px;position:relative;z-index:1}
.pstep:nth-child(2) .no{background:var(--blue);color:#fff}
.pstep h3{font-size:20px;margin-bottom:8px}
.pstep p{color:var(--ink-2);font-size:15px;max-width:300px}

/* SERVICIO BAND */
.serv{position:relative;background:var(--ink);color:#fff;padding:104px 0;overflow:hidden}
.serv::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:44px 44px;-webkit-mask-image:radial-gradient(circle at 78% 30%,#000,transparent 70%);mask-image:radial-gradient(circle at 78% 30%,#000,transparent 70%)}
.serv::after{content:"";position:absolute;top:-25%;left:-8%;width:44vw;height:44vw;max-width:560px;max-height:560px;background:radial-gradient(circle,rgba(0,89,255,.35),transparent 62%)}
.serv .wrap{position:relative;z-index:1}
.serv-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.serv .kicker{color:#8fb3ff}.serv .kicker .ln{background:#8fb3ff}
.serv h2{font-size:clamp(28px,4vw,46px);margin:18px 0 16px}
.serv p.sub{color:#b8c2d0;font-size:17px;max-width:460px;margin-bottom:26px}
.serv-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.sv{background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.09);border-radius:16px;padding:18px}
.sv .ic{width:34px;height:34px;border-radius:10px;background:var(--blue);display:grid;place-items:center;margin-bottom:12px}
.sv .ic svg{width:17px;height:17px;color:#fff}
.sv b{font-size:15.5px}
.sv p{color:#a4afbe;font-size:13.5px;margin-top:3px}

/* NUMS */
.nums{padding:92px 0}
.nums-grid{display:grid;grid-template-columns:repeat(4,1fr)}
.nums .n{padding:6px 26px;border-left:1px solid var(--line)}
.nums .n:first-child{border-left:0;padding-left:0}
.nums .n b{display:block;font-family:'Montserrat';font-weight:900;font-size:clamp(38px,5vw,58px);color:var(--ink);line-height:1;letter-spacing:-.03em}
.nums .n b .u{color:var(--blue)}
.nums .n small{display:block;color:var(--muted);font-weight:700;font-size:13.5px;margin-top:12px;max-width:150px}

/* REVIEWS */
.revs{background:var(--canvas);padding:100px 0}
.rev-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px;margin-top:50px}
.q{background:#fff;border:1px solid var(--line);border-radius:22px;padding:28px;box-shadow:var(--sh-1)}
.q.big{grid-column:span 7}.q.sm{grid-column:span 5}
.q .mk{font-family:'Montserrat';font-weight:900;font-size:44px;color:var(--wash);line-height:.6;height:22px}
.q p{font-size:clamp(16px,1.7vw,19px);color:var(--ink);margin:10px 0 18px;font-weight:500}
.q.sm p{font-size:15.5px}
.q .who{display:flex;align-items:center;gap:12px}
.q .av{width:42px;height:42px;border-radius:12px;background:var(--ink);color:#fff;font-family:'Montserrat';font-weight:800;display:grid;place-items:center;font-size:15px}
.q .who b{display:block;font-size:14.5px}.q .who small{color:var(--muted);font-size:12.5px}

/* CLIENTS marquee */
.clients{padding:84px 0;text-align:center;overflow:hidden}
.clients h2{font-size:clamp(26px,3.4vw,40px);margin:14px auto 8px;max-width:620px}
.clients p{color:var(--ink-2);max-width:520px;margin:0 auto}
.mq{margin-top:40px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);overflow:hidden}
.mq-t{display:flex;gap:16px;width:max-content;animation:mq 40s linear infinite}
.clients:hover .mq-t{animation-play-state:paused}
.cl{flex:0 0 auto;width:200px;height:92px;border:1px solid var(--line);border-radius:16px;display:grid;place-items:center;color:#a3adba;font-weight:800;font-size:13px;background:#fff}
@keyframes mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ALLY */
.ally{padding:40px 0 100px}
.ally-box{position:relative;overflow:hidden;border-radius:30px;background:var(--blue);color:#fff;padding:56px;display:grid;grid-template-columns:1.25fr .75fr;gap:34px;align-items:center}
.ally-box::after{content:"";position:absolute;right:-6%;top:-40%;width:46%;height:180%;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 62%)}
.ally-box::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:40px 40px;-webkit-mask-image:linear-gradient(120deg,#000,transparent 55%);mask-image:linear-gradient(120deg,#000,transparent 55%)}
.ally-box>div{position:relative;z-index:1}
.ally .kicker{color:#cfe0ff}.ally .kicker .ln{background:#cfe0ff}
.ally-box h2{font-size:clamp(26px,3.4vw,42px);margin:16px 0 14px}
.ally-box p{color:rgba(255,255,255,.9);font-size:16px;max-width:540px}
.ally-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:20px}
.ally-chips span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);padding:8px 14px;border-radius:10px;font-size:13.5px;font-weight:700}
.ally-box .cta{display:flex;justify-content:flex-end}

/* FAQ */
.faq{padding:100px 0}
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:56px;align-items:start}
.faq-left{position:sticky;top:100px}
.faq-left h2{font-size:clamp(28px,3.6vw,42px);margin:14px 0 14px}
.faq-left p{color:var(--ink-2);max-width:300px}
.faq-left .btn{margin-top:22px}
.qa{border-bottom:1px solid var(--line)}
.qa summary{list-style:none;cursor:pointer;padding:22px 0;font-family:'Montserrat';font-weight:700;font-size:17.5px;display:flex;justify-content:space-between;gap:16px;align-items:center}
.qa summary::-webkit-details-marker{display:none}
.qa .pl{position:relative;width:22px;height:22px;flex:0 0 auto}
.qa .pl::before,.qa .pl::after{content:"";position:absolute;background:var(--blue);border-radius:2px;transition:transform .4s var(--e)}
.qa .pl::before{top:10px;left:0;width:22px;height:2px}
.qa .pl::after{left:10px;top:0;width:2px;height:22px}
.qa[open] .pl::after{transform:rotate(90deg)}
.qa .ans{padding:0 0 22px;color:var(--ink-2);font-size:15.5px;max-width:640px}

/* FINAL CTA */
.final{padding:20px 0 100px}
.final-box{position:relative;overflow:hidden;background:var(--ink);color:#fff;border-radius:30px;padding:72px 40px;text-align:center}
.final-box::after{content:"";position:absolute;bottom:-40%;left:50%;transform:translateX(-50%);width:70%;height:120%;background:radial-gradient(circle,rgba(0,89,255,.3),transparent 60%)}
.final-box>*{position:relative;z-index:1}
.final-box h2{font-size:clamp(30px,4.4vw,52px);max-width:680px;margin:16px auto 16px}
.final-box p{color:#b8c2d0;font-size:18px;max-width:520px;margin:0 auto 30px}
.final-row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* FOOTER */
footer{background:#0b0e13;color:#8b97a7;padding:64px 0 30px}
.f-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
footer .logo{color:#fff;font-size:24px}
footer .about{font-size:14px;max-width:280px;margin-top:12px}
footer h4{color:#fff;font-family:'Montserrat';font-weight:700;font-size:13px;letter-spacing:.04em;margin-bottom:14px;text-transform:uppercase}
footer .col a{display:block;font-size:14px;margin-bottom:10px;color:#8b97a7;transition:color .25s}
footer .col a:hover{color:#fff}
.f-bar{display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:44px;padding-top:22px;border-top:1px solid rgba(255,255,255,.07);font-size:13px}

/* WA FLOAT */
.wafloat{position:fixed;right:20px;bottom:20px;z-index:50;display:inline-flex;align-items:center;gap:10px;background:var(--green);color:#fff;font-weight:800;padding:14px 18px;border-radius:14px;box-shadow:0 18px 40px -14px rgba(23,165,88,.7);transition:transform .4s var(--e)}
.wafloat:hover{transform:translateY(-2px)}
.wafloat svg{width:22px;height:22px}

/* PAGE HERO (interior) */
.phero{padding:44px 0 10px}
.crumb{font-size:13px;color:var(--muted);font-weight:600;margin-bottom:14px}
.crumb a{color:var(--blue)}
.phero h1{font-size:clamp(30px,4.6vw,50px);color:var(--ink)}
.phero p{color:var(--ink-2);font-size:17px;max-width:560px;margin-top:14px}

/* CATALOG */
.catalog{padding:40px 0 100px}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin:26px 0 30px}
.filters button{border:1.5px solid var(--line);background:#fff;border-radius:10px;padding:9px 15px;font-weight:700;font-size:14px;color:var(--ink-2);cursor:pointer;transition:.25s}
.filters button.on,.filters button:hover{border-color:var(--blue);color:var(--blue);background:var(--wash)}
.pgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:22px}
.pcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff;box-shadow:var(--sh-1);transition:transform .5s var(--e),box-shadow .5s var(--e)}
.pcard:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.pcard .ph{position:relative;aspect-ratio:1;background:var(--canvas);display:grid;place-items:center;overflow:hidden}
.pcard .ph img{width:78%;height:78%;object-fit:contain;transition:transform .6s var(--e)}
.pcard:hover .ph img{transform:scale(1.06)}
.pcard .badge{position:absolute;top:12px;left:12px;background:var(--ink);color:#fff;font-size:11px;font-weight:800;padding:5px 10px;border-radius:8px;letter-spacing:.03em}
.pcard .pb{padding:18px;display:flex;flex-direction:column;flex:1}
.pcard .cat{font-size:11px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.pcard h3{font-size:18px;margin:5px 0 4px}
.pcard .desc{color:var(--ink-2);font-size:13.5px;flex:1}
.pcard .price{font-family:'Montserrat';font-weight:800;font-size:20px;color:var(--ink);margin:12px 0 12px}
.pcard .price small{font-weight:600;font-size:12px;color:var(--muted)}
.pcard .pactions{display:flex;gap:8px}
.pcard .pactions .btn{flex:1;padding:11px 12px;font-size:14px}

/* PRODUCT DETAIL */
.pd{padding:30px 0 90px}
.pd-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}
.pd-media{position:sticky;top:96px;border:1px solid var(--line);border-radius:26px;background:var(--canvas);aspect-ratio:1;display:grid;place-items:center;overflow:hidden}
.pd-media img{width:80%;height:80%;object-fit:contain;filter:drop-shadow(0 30px 40px rgba(20,24,31,.18))}
.pd-cat{font-size:12px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--blue)}
.pd h1{font-size:clamp(28px,3.8vw,42px);margin:8px 0 12px}
.pd .stars{color:var(--amber);letter-spacing:2px;font-size:15px;margin-bottom:14px}
.pd .stars small{color:var(--muted);font-weight:600;margin-left:6px}
.pd .lead{color:var(--ink-2);font-size:16.5px;margin-bottom:20px}
.pd .pricebox{display:flex;align-items:baseline;gap:12px;padding:18px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pd .pricebox .big{font-family:'Montserrat';font-weight:900;font-size:38px;color:var(--ink)}
.pd .pricebox small{color:var(--muted);font-weight:600}
.qty{display:flex;align-items:center;gap:0;border:1.5px solid var(--line);border-radius:12px;overflow:hidden;width:max-content}
.qty button{width:44px;height:46px;border:0;background:#fff;font-size:20px;cursor:pointer;color:var(--ink)}
.qty input{width:52px;height:46px;border:0;text-align:center;font-weight:800;font-family:'Montserrat';font-size:16px}
.pd-actions{display:flex;gap:12px;flex-wrap:wrap;margin:20px 0}
.pd-actions .btn{flex:1;min-width:180px}
.trust-row{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}
.trust-row .ti{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:700;color:var(--ink-2)}
.trust-row .ti svg{width:18px;height:18px;color:var(--green)}
.spectable{width:100%;border-collapse:collapse;margin-top:26px}
.spectable td{padding:12px 4px;border-bottom:1px solid var(--line);font-size:14.5px}
.spectable td:first-child{color:var(--muted);font-weight:700;width:45%}
.spectable td:last-child{font-weight:700}

/* FORMS */
.formsec{padding:40px 0 100px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:start}
.form-card{border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:var(--sh-1);padding:30px}
.campo{margin-bottom:16px}
.campo label{display:block;font-weight:700;font-size:13.5px;margin-bottom:7px}
.campo input,.campo textarea,.campo select{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 15px;font-family:inherit;font-size:15px;color:var(--ink);transition:border-color .25s}
.campo input:focus,.campo textarea:focus,.campo select:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,89,255,.1)}
.aviso{display:none;margin-top:14px;background:#e9f9ef;border:1px solid #bfe9cf;color:#12703e;border-radius:12px;padding:13px 15px;font-weight:700;font-size:14px}
.aviso.show{display:block}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line)}
.contact-info .ci .ic{width:44px;height:44px;border-radius:12px;background:var(--wash);display:grid;place-items:center;flex:0 0 auto}
.contact-info .ci .ic svg{width:20px;height:20px;color:var(--blue)}
.contact-info .ci b{font-size:15.5px}
.contact-info .ci p{color:var(--ink-2);font-size:14px}

/* CART */
.cartsec{padding:40px 0 100px}
.cart-grid{display:grid;grid-template-columns:1.5fr .8fr;gap:40px;align-items:start}
.cart-line{display:flex;gap:16px;align-items:center;padding:18px 0;border-bottom:1px solid var(--line)}
.cart-line img{width:76px;height:76px;object-fit:contain;background:var(--canvas);border:1px solid var(--line);border-radius:14px;padding:7px}
.cart-line .cl-info{flex:1}
.cart-line .cl-info b{font-size:16px;font-family:'Montserrat'}
.cart-line .cl-info small{display:block;color:var(--muted);font-size:12.5px}
.cart-line .cl-price{font-family:'Montserrat';font-weight:800;font-size:17px;white-space:nowrap}
.cart-line .rm{background:none;border:0;color:var(--muted);cursor:pointer;font-size:13px;font-weight:700;text-decoration:underline;margin-top:4px}
.cart-empty{text-align:center;padding:60px 0;color:var(--muted)}
.summary{border:1px solid var(--line);border-radius:22px;background:#fff;box-shadow:var(--sh-1);padding:26px;position:sticky;top:96px}
.summary h3{font-size:20px;margin-bottom:16px}
.sumrow{display:flex;justify-content:space-between;padding:9px 0;font-size:15px;color:var(--ink-2)}
.sumrow.tot{border-top:1px solid var(--line);margin-top:8px;padding-top:16px;font-family:'Montserrat';font-weight:800;font-size:20px;color:var(--ink)}
.paylist{display:flex;flex-direction:column;gap:8px;margin:16px 0}
.paylist .pi{display:flex;gap:10px;align-items:center;font-size:13.5px;color:var(--ink-2);font-weight:600}
.paylist .pi svg{width:16px;height:16px;color:var(--green)}

/* BLOG */
.blogsec{padding:40px 0 100px}
.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px;margin-top:30px}
.post{border:1px solid var(--line);border-radius:22px;overflow:hidden;background:#fff;box-shadow:var(--sh-1);transition:transform .5s var(--e),box-shadow .5s var(--e);display:flex;flex-direction:column}
.post:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.post .ph{aspect-ratio:16/9;background:var(--canvas);display:grid;place-items:center;overflow:hidden}
.post .ph img{width:70%;height:70%;object-fit:contain}
.post .pb{padding:22px;display:flex;flex-direction:column;flex:1}
.post .tag{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}
.post h3{font-size:19px;margin:8px 0 8px}
.post p{color:var(--ink-2);font-size:14px;flex:1}
.article{max-width:760px;margin:0 auto;padding:30px 0 90px}
.article h1{font-size:clamp(30px,4.4vw,46px);margin:14px 0 16px}
.article .meta{color:var(--muted);font-size:14px;margin-bottom:24px}
.article .cover{border-radius:22px;overflow:hidden;background:var(--canvas);aspect-ratio:16/8;display:grid;place-items:center;margin-bottom:28px}
.article .cover img{width:60%;height:80%;object-fit:contain}
.article h2{font-size:26px;margin:32px 0 12px}
.article p{font-size:17px;color:var(--ink-2);margin-bottom:16px}
.article ul{margin:0 0 16px 20px;color:var(--ink-2);font-size:17px}
.article li{margin-bottom:8px}
.article .cta-in{background:var(--canvas);border:1px solid var(--line);border-radius:20px;padding:26px;margin-top:30px;text-align:center}

/* LEGAL */
.legal{max-width:800px;margin:0 auto;padding:30px 0 90px}
.legal h2{font-size:24px;margin:30px 0 10px}
.legal p,.legal li{color:var(--ink-2);font-size:15.5px;margin-bottom:10px}
.legal ul{margin-left:20px}

.rv{opacity:0;transform:translateY(24px);transition:opacity .8s var(--e),transform .8s var(--e)}
.rv.in{opacity:1;transform:none}

@media(max-width:940px){
  .hero-grid,.serv-grid,.faq-grid,.pd-grid,.form-grid,.cart-grid{grid-template-columns:1fr;gap:36px}
  .sec-head{grid-template-columns:1fr;gap:14px;align-items:start}
  .row-item{grid-template-columns:1fr;gap:26px;padding:36px 0}
  .row-item:nth-child(even) .media{order:0}
  .proc-grid{grid-template-columns:1fr;gap:34px}.proc-grid::before{display:none}.pstep{padding:0}
  .nums-grid{grid-template-columns:1fr 1fr;gap:26px 0}.nums .n{padding:6px 20px}.nums .n:nth-child(3){border-left:0;padding-left:0}
  .rev-grid{grid-template-columns:1fr}.q.big,.q.sm{grid-column:auto}
  .serv-list{grid-template-columns:1fr}
  .ally-box{grid-template-columns:1fr;padding:38px}.ally-box .cta{justify-content:flex-start}
  .faq-left,.pd-media,.summary{position:static}
}
@media(max-width:720px){
  .nav-links,.nav-cta{display:none}.hburg{display:flex}
  .brands .row{justify-content:center;text-align:center}.brands .lab{max-width:none}
  .h1 .inl{height:.7em}
  .pd-actions .btn{min-width:100%}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto!important;transition:none!important}
  .rv{opacity:1;transform:none}.mq-t{animation:none!important}.mq{overflow-x:auto}
}

/* ===== limpieza (menos apariencia tech) + accesibilidad ===== */
.serv::before{display:none}
.serv::after{opacity:.45}
.ally-box::before{display:none}
.stage::before{opacity:.55}
.final-box{background:linear-gradient(135deg,#0044c2,#0064ff)}
.final-box::after{opacity:.35}
.skip{position:absolute;left:-999px;top:0;background:var(--blue);color:#fff;padding:11px 18px;border-radius:0 0 12px 0;z-index:100;font-weight:800}
.skip:focus{left:0}
:focus-visible{outline:3px solid rgba(0,89,255,.55);outline-offset:2px;border-radius:6px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.price.cotizar{color:var(--blue);font-size:16px}
.price.cotizar small{color:var(--muted);font-weight:600;font-size:12px;display:block}
.badge.nueva{background:var(--blue)}
/* hero limpio */
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.hero-badges .hb{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:9px 15px;font-weight:700;font-size:13.5px;box-shadow:var(--sh-1)}
.hero-badges .hb svg{width:16px;height:16px;color:var(--green)}
.cap-strip{position:absolute;left:16px;right:16px;bottom:16px;display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--line);border-radius:16px;padding:12px 16px;box-shadow:var(--sh-1)}
.cap-strip .dot2{width:10px;height:10px;border-radius:50%;background:var(--green);flex:0 0 auto}
.cap-strip b{font-size:14px;display:block}.cap-strip small{color:var(--muted);font-size:12.5px}
/* categorías */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px}
.catc{display:flex;flex-direction:column;gap:5px;padding:24px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:var(--sh-1);transition:transform .5s var(--e),box-shadow .5s var(--e)}
.catc:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.catc .ci{width:48px;height:48px;border-radius:14px;background:var(--wash);display:grid;place-items:center;margin-bottom:8px}
.catc .ci svg{width:23px;height:23px;color:var(--blue)}
.catc b{font-family:'Montserrat';font-size:16.5px}
.catc small{color:var(--ink-2);font-size:13px;flex:1}
.catc .go{color:var(--blue);font-weight:800;font-size:13.5px;margin-top:8px}
/* herramientas */
.tools-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:34px}
.tool{padding:24px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:var(--sh-1);transition:transform .5s var(--e)}
.tool:hover{transform:translateY(-5px)}
.tool .ic{width:46px;height:46px;border-radius:13px;background:var(--wash);display:grid;place-items:center;margin-bottom:12px}
.tool .ic svg{width:22px;height:22px;color:var(--blue)}
.tool b{font-family:'Montserrat';font-size:16.5px;display:block;margin-bottom:4px}
.tool p{color:var(--ink-2);font-size:13.5px;margin-bottom:12px}
/* finder section */
.finder-sec{background:var(--canvas);padding:88px 0}
.finder-wrap{max-width:560px;margin:26px auto 0}
@media(max-width:940px){.cats,.tools-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.cats,.tools-grid{grid-template-columns:1fr}.cap-strip{position:static;margin-top:12px}}

/* ===== cintillo promocional ===== */
.promo{background:var(--ink);color:#fff;font-size:13.5px;font-weight:600;text-align:center;padding:9px 40px 9px 16px;position:relative}
.promo a{color:#8fd6ac;font-weight:800;text-decoration:underline}
.promo b{color:#fff}
.promo .x{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:0;color:#9fb0c6;cursor:pointer;font-size:18px;line-height:1;padding:4px}
body.promo-off .promo{display:none}
/* ===== cookies ===== */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:70;max-width:520px;background:#fff;border:1px solid var(--line);border-radius:18px;box-shadow:var(--sh-2);padding:20px 22px;display:none}
.cookie.show{display:block}
.cookie{max-width:560px}
.cookie p{font-size:13.5px;color:var(--ink-2);margin-bottom:14px}
.cookie .row{display:flex;gap:10px;flex-wrap:wrap}
.cookie .row .btn{padding:11px 16px;font-size:14px}
/* modal preferencias */
.cc-ov{position:fixed;inset:0;z-index:80;background:rgba(11,14,19,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:20px}
.cc-ov.show{display:flex}
.cc-panel{position:relative;background:#fff;border-radius:22px;max-width:480px;width:100%;padding:30px;box-shadow:var(--sh-2);max-height:88vh;overflow:auto}
.cc-panel h3{font-size:22px;margin-bottom:8px}
.cc-panel .cc-lead{color:var(--ink-2);font-size:14px;margin-bottom:18px}
.cc-panel .x{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:var(--line-2);border:0;color:var(--ink);font-size:18px;cursor:pointer}
.cc-cat{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0;border-bottom:1px solid var(--line-2)}
.cc-cat b{font-size:15px;display:block}
.cc-cat small{color:var(--muted);font-size:12.5px}
.switch{position:relative;flex:0 0 auto;width:46px;height:26px;border-radius:999px;background:var(--line);transition:background .25s;cursor:pointer}
.switch input{position:absolute;inset:0;opacity:0;margin:0;cursor:pointer}
.switch i{position:absolute;top:3px;left:3px;width:20px;height:20px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:transform .25s var(--e)}
.switch:has(input:checked){background:var(--blue)}
.switch:has(input:checked) i{transform:translateX(20px)}
.switch.locked{background:var(--blue);opacity:.55;cursor:not-allowed}
.switch.locked i{transform:translateX(20px)}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.cc-actions .btn{flex:1;min-width:150px;justify-content:center}
.linklike{background:none;border:0;color:inherit;text-decoration:underline;cursor:pointer;font:inherit;padding:0}
.linklike:hover{color:#fff}
.f-bar a{color:inherit;text-decoration:underline}
/* ===== popup ===== */
.pop-ov{position:fixed;inset:0;z-index:75;background:rgba(11,14,19,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .35s var(--e)}
.pop-ov.show{display:flex;opacity:1}
.pop{position:relative;background:#fff;border-radius:24px;max-width:440px;width:100%;overflow:hidden;box-shadow:var(--sh-2);transform:translateY(14px);transition:transform .4s var(--e)}
.pop-ov.show .pop{transform:none}
.pop .top{background:linear-gradient(135deg,#0044c2,#0064ff);color:#fff;padding:26px 26px 22px}
.pop .top .kicker{color:#cfe0ff}.pop .top .kicker .ln{background:#cfe0ff}
.pop .top h3{font-size:24px;margin-top:10px}
.pop .bd{padding:22px 26px 26px}
.pop .bd p{color:var(--ink-2);font-size:15px;margin-bottom:16px}
.pop .x{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.2);border:0;color:#fff;font-size:18px;cursor:pointer;z-index:1}
/* ===== galería producto ===== */
.gallery{position:sticky;top:96px}
.gal-main{border:1px solid var(--line);border-radius:26px;background:var(--canvas);aspect-ratio:1;display:grid;place-items:center;overflow:hidden}
.gal-main img{width:80%;height:80%;object-fit:contain;filter:drop-shadow(0 30px 40px rgba(20,24,31,.18));transition:opacity .3s}
.gal-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:12px}
.gth{border:1.5px solid var(--line);border-radius:14px;background:var(--canvas);aspect-ratio:1;display:grid;place-items:center;cursor:pointer;overflow:hidden;transition:border-color .3s}
.gth.on{border-color:var(--blue)}
.gth img{width:74%;height:74%;object-fit:contain}
.gth .soon{color:#a3adba;font-size:10.5px;font-weight:700;text-align:center;padding:4px}
/* ===== descargas ===== */
.downloads{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:22px}
.dl{display:flex;align-items:center;gap:13px;border:1px solid var(--line);border-radius:16px;padding:15px;background:#fff;transition:border-color .3s,transform .3s var(--e)}
.dl:hover{border-color:var(--blue);transform:translateY(-2px)}
.dl .ic{width:40px;height:40px;border-radius:11px;background:#fdecec;display:grid;place-items:center;flex:0 0 auto}
.dl .ic svg{width:20px;height:20px;color:#d64545}
.dl b{font-size:14.5px;display:block}.dl small{color:var(--muted);font-size:12px}
/* ===== recomendados ===== */
.reco-sec{background:var(--canvas);padding:80px 0;margin-top:60px}
/* ===== servicios ===== */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:30px}
.svc{border:1px solid var(--line);border-radius:20px;background:#fff;padding:24px;box-shadow:var(--sh-1);transition:transform .5s var(--e),box-shadow .5s var(--e)}
.svc:hover{transform:translateY(-5px);box-shadow:var(--sh-2)}
.svc .ic{width:48px;height:48px;border-radius:14px;background:var(--wash);display:grid;place-items:center;margin-bottom:14px}
.svc .ic svg{width:23px;height:23px;color:var(--blue)}
.svc h3{font-size:18px;margin-bottom:6px}
.svc p{color:var(--ink-2);font-size:14px}
.svc.dark{background:var(--ink);color:#fff;border-color:transparent}
.svc.dark .ic{background:rgba(122,166,255,.16)}.svc.dark .ic svg{color:#8fb3ff}
.svc.dark p{color:#a4afbe}
/* ===== tools dark (dinamismo) ===== */
.tools-dark{background:var(--ink);color:#fff;border-radius:30px;padding:52px;position:relative;overflow:hidden;margin-top:34px}
.tools-dark::after{content:"";position:absolute;top:-30%;right:-6%;width:40%;height:170%;background:radial-gradient(circle,rgba(0,89,255,.32),transparent 62%)}
.tools-dark>*{position:relative;z-index:1}
.tools-dark .tools-grid{margin-top:26px}
.tools-dark .tool{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.1)}
.tools-dark .tool .ic{background:rgba(122,166,255,.16)}.tools-dark .tool .ic svg{color:#8fb3ff}
.tools-dark .tool b{color:#fff}.tools-dark .tool p{color:#a4afbe}
.tools-dark .tool .arrow-link{color:#8fb3ff}
/* ===== mapa ===== */
.map{border:1px solid var(--line);border-radius:20px;overflow:hidden;height:320px;margin-top:20px}
.map iframe{width:100%;height:100%;border:0;display:block}
/* ===== compara ===== */
.ctable-wrap{overflow-x:auto;margin-top:34px;border:1px solid var(--line);border-radius:20px}
.ctable{width:100%;border-collapse:collapse;min-width:640px}
.ctable th,.ctable td{padding:16px;text-align:left;border-bottom:1px solid var(--line);font-size:14.5px}
.ctable thead th{background:var(--canvas);font-family:'Montserrat';font-size:15px}
.ctable thead th.best{background:var(--wash);color:var(--blue-d)}
.ctable td.best{background:rgba(0,89,255,.04);font-weight:700}
.ctable td:first-child,.ctable th:first-child{color:var(--muted);font-weight:700}
.ctable .ck{color:var(--green);font-weight:800}
/* ===== faq compacto por sección ===== */
.faq-mini{max-width:820px;margin:34px auto 0}
/* ===== CTAs por servicio ===== */
.svc{display:flex;flex-direction:column}
.svc .svc-cta{margin-top:auto;display:inline-flex;align-items:center;gap:8px;font-weight:800;font-size:14px;color:var(--green-d);padding-top:16px;border-top:1px solid var(--line);transition:gap .3s var(--e)}
.svc .svc-cta:hover{gap:12px}
.svc .svc-cta svg{width:16px;height:16px}
.svc.dark .svc-cta{color:#7fe0a6;border-top-color:rgba(255,255,255,.12)}
.svc.urgent{border-color:#f0b45f;background:#fff8ef}
.svc.urgent .ic{background:#fbe4c4}.svc.urgent .ic svg{color:#d98218}
.svc-ctas{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto;padding-top:16px;border-top:1px solid #f2ddba}
.svc-ctas .btn{flex:1;min-width:120px;padding:12px 14px;font-size:14px}
.badge-urgent{display:inline-block;background:#d98218;color:#fff;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase;padding:4px 9px;border-radius:7px;margin-bottom:10px}
/* ===== intención rápida (chips) ===== */
.intent-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:26px}
.intent-chips a{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:11px 17px;font-weight:700;font-size:14px;color:var(--ink);box-shadow:var(--sh-1);transition:border-color .3s,transform .3s var(--e)}
.intent-chips a:hover{border-color:var(--blue);transform:translateY(-2px)}
.intent-chips a svg{width:16px;height:16px;color:var(--blue)}
/* ===== formulario solicitud servicio ===== */
.svc-req{background:var(--canvas);padding:88px 0}
.svc-req-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
@media(max-width:940px){.svc-req-grid{grid-template-columns:1fr;gap:32px}}
/* ===== auditoría UI/UX: accesibilidad + interacción ===== */
html{scroll-padding-top:96px}
[id]{scroll-margin-top:96px}
*{-webkit-tap-highlight-color:transparent}
a,button,summary,input,select,textarea,.seg,.gth,.pcard,.filters button{-webkit-tap-highlight-color:transparent}
.filters button{min-height:44px}
.nav-links a{padding:11px 13px}
.qa summary{min-height:44px}
.arrow-link{padding:4px 0}
.campo input,.campo select,.campo textarea{font-size:16px}
label .req{color:#d64545;margin-left:2px}
.form-note{font-size:12.5px;color:var(--muted);margin:2px 0 14px}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
/* ===== tarjeta producto: enlace extendido + acciones reales (a11y) ===== */
.pcard{position:relative;cursor:pointer}
.pcard-link{color:inherit;text-decoration:none}
.pcard-link::after{content:"";position:absolute;inset:0;z-index:1}
.pcard .pactions{position:relative;z-index:2}
.pcard .badge{z-index:2}
.pcard .pactions .btn{cursor:pointer}
.pcard h3 a:focus-visible{outline:3px solid rgba(0,89,255,.55);outline-offset:3px;border-radius:6px}
/* ===== buscador en nav ===== */
.nav-search{width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:#fff;display:grid;place-items:center}
.nav-search svg{width:19px;height:19px;color:var(--ink)}
.nav-search:hover{border-color:var(--blue)}
.nav-search:hover svg{color:var(--blue)}
@media(max-width:720px){.nav-search{display:none}}
/* ===== volver arriba ===== */
.totop{position:fixed;left:20px;bottom:20px;z-index:49;width:46px;height:46px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--ink);display:grid;place-items:center;cursor:pointer;box-shadow:var(--sh-1);opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity .35s var(--e),transform .35s var(--e),background .25s}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop:hover{background:var(--wash);border-color:var(--blue);color:var(--blue)}
.totop svg{width:20px;height:20px}
/* ===== sellos de confianza ===== */
.trust-bar{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--canvas);padding:22px 0}
.tb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.tb{display:flex;align-items:center;gap:12px;justify-content:center}
.tb-ic{width:40px;height:40px;border-radius:11px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;flex:0 0 auto}
.tb-ic svg{width:20px;height:20px;color:var(--blue)}
.tb span{font-weight:700;font-size:13.5px;color:var(--ink-2)}
@media(max-width:820px){.tb-grid{grid-template-columns:1fr 1fr}.tb{justify-content:flex-start}}
/* ===== barra móvil de compra/cotización (fichas) ===== */
.pd-bar{position:fixed;left:0;right:0;bottom:0;z-index:46;display:none;align-items:center;gap:12px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));background:rgba(255,255,255,.94);backdrop-filter:blur(12px);border-top:1px solid var(--line);box-shadow:0 -10px 30px -18px rgba(20,24,31,.4)}
.pd-bar .pb-price{flex:0 0 auto}
.pd-bar .pb-price b{display:block;font-family:'Montserrat';font-weight:800;font-size:17px;line-height:1}
.pd-bar .pb-price small{color:var(--muted);font-size:11.5px}
.pd-bar .btn{flex:1;justify-content:center}
@media(max-width:720px){.pd-bar{display:flex}body.has-pdbar .wafloat{display:none}.totop{bottom:78px}}
/* ===== buscador página ===== */
.searchbox{position:relative;max-width:640px;margin:8px 0 4px}
.searchbox input{width:100%;border:1.5px solid var(--line);border-radius:14px;padding:16px 16px 16px 48px;font-size:16px;font-family:inherit}
.searchbox input:focus{outline:0;border-color:var(--blue);box-shadow:0 0 0 4px rgba(0,89,255,.1)}
.searchbox .sic{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--muted)}
.search-empty{padding:50px 0;text-align:center;color:var(--muted)}
/* ===== Guías: hub de contenido ===== */
.guide-featured{position:relative;display:grid;grid-template-columns:1.05fr .95fr;gap:0;align-items:stretch;border:1px solid var(--line);border-radius:26px;overflow:hidden;background:#fff;box-shadow:var(--sh-1);margin-top:26px;transition:box-shadow .5s var(--e),transform .5s var(--e)}
.guide-featured:hover{box-shadow:var(--sh-2);transform:translateY(-3px)}
.guide-featured .gf-img{background:var(--canvas);display:grid;place-items:center;min-height:260px;overflow:hidden}
.guide-featured .gf-img img{width:72%;height:72%;object-fit:contain;transition:transform .6s var(--e)}
.guide-featured:hover .gf-img img{transform:scale(1.05)}
.guide-featured .gf-body{padding:38px}
.guide-featured .gf-flag{display:inline-block;background:var(--ink);color:#fff;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;padding:5px 11px;border-radius:8px;margin-bottom:14px}
.guide-featured h3{font-size:clamp(22px,2.8vw,30px);margin-bottom:12px}
.guide-featured p{color:var(--ink-2);font-size:16px;margin-bottom:18px}
.guide-featured .stretch::after{content:"";position:absolute;inset:0}
@media(max-width:820px){.guide-featured{grid-template-columns:1fr}.guide-featured .gf-img{min-height:200px}.guide-featured .gf-body{padding:26px}}
.topic-chips{display:flex;gap:9px;flex-wrap:wrap;margin:26px 0 8px}
.topic-chips button{border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:10px 17px;font-weight:700;font-size:14px;color:var(--ink-2);cursor:pointer;min-height:44px;transition:.25s}
.topic-chips button.on,.topic-chips button:hover{border-color:var(--blue);color:var(--blue);background:var(--wash)}
.post .meta-row{display:flex;align-items:center;gap:10px;margin-top:auto;padding-top:12px;color:var(--muted);font-size:12.5px;font-weight:600}
.subscribe{position:relative;overflow:hidden;border-radius:28px;background:linear-gradient(135deg,#0044c2,#0064ff);color:#fff;padding:44px;text-align:center;margin-top:20px}
.subscribe::after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 80% 20%,rgba(255,255,255,.16),transparent 60%)}
.subscribe>*{position:relative;z-index:1}
.subscribe h2{font-size:clamp(24px,3.2vw,36px);margin-bottom:10px}
.subscribe p{color:rgba(255,255,255,.9);max-width:520px;margin:0 auto 22px}
.dl-details{border:1px solid var(--line);border-radius:18px;background:#fff;padding:4px 22px;margin-top:18px}
.dl-details>summary{cursor:pointer;padding:18px 0;font-family:'Montserrat';font-weight:700;font-size:16.5px;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px;min-height:44px}
.dl-details>summary::-webkit-details-marker{display:none}
.dl-details>summary .pl{position:relative;width:22px;height:22px;flex:0 0 auto}
.dl-details>summary .pl::before,.dl-details>summary .pl::after{content:"";position:absolute;background:var(--blue);border-radius:2px;transition:transform .4s var(--e)}
.dl-details>summary .pl::before{top:10px;left:0;width:22px;height:2px}
.dl-details>summary .pl::after{left:10px;top:0;width:2px;height:22px}
.dl-details[open]>summary .pl::after{transform:rotate(90deg)}
.dl-details .dl-inner{padding:6px 0 20px}
.dl-inner h4{font-family:'Montserrat';font-size:15px;margin:14px 0 10px;color:var(--ink-2)}
.article .article-related{margin-top:40px;padding-top:26px;border-top:1px solid var(--line)}
.post{position:relative}
