/* ── PLUSEVO OLP+ — CSS ───────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#ffffff;--off:#f8f9fc;--off2:#f2f3f8;
  --border:#e4e5ef;--border2:#ededf5;
  --ink:#0c0c1e;--ink2:#3a3a52;
  --muted:#7a7b96;--muted2:#a9aabe;
  --blue:#104E8B;--blue-light:#EEF4FB;--blue-border:#C2D6EE;
  --wa:#25D366;--gold:#b07d3a;
  --r:12px;--r-sm:8px;--r-lg:20px;
  --max:1160px;
  --sh:0 1px 3px rgba(0,0,0,.06),0 4px 16px rgba(0,0,0,.05);
  --sh-lg:0 4px 24px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
}
html{scroll-behavior:smooth;scroll-padding-top:72px;overflow-x:hidden}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--white);color:var(--ink);overflow-x:hidden;line-height:1.65;font-size:16px;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{cursor:pointer;font-family:inherit}

/* ── NAV ── */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;height:72px;display:flex;align-items:center;gap:1.5rem;padding:0 2.5rem;background:rgba(255,255,255,0.92);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border2)}
.nav-logo-badge{font-size:.58rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:var(--blue-light);color:var(--blue);border:1px solid var(--blue-border);padding:3px 8px;border-radius:20px}
.nav-links{display:flex;gap:1.8rem;list-style:none;margin-left:.5rem}
.nav-links a{font-size:.82rem;font-weight:500;color:var(--muted);transition:color .2s}
.nav-links a:hover{color:var(--ink)}
.nav-r{margin-left:auto;display:flex;gap:8px;align-items:center}
.cart-badge{position:absolute;top:-6px;right:-6px;width:18px;height:18px;background:var(--blue);color:#fff;font-size:.62rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center}

/* ── BOTONES ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-size:.84rem;font-weight:600;letter-spacing:.03em;padding:12px 22px;border-radius:var(--r-sm);border:none;transition:all .2s;cursor:pointer;white-space:nowrap}
.btn svg{width:17px;height:17px;fill:currentColor;flex-shrink:0}
.btn-blue{background:var(--blue);color:#fff}
.btn-blue:hover{background:#0D4180;transform:translateY(-1px);box-shadow:0 6px 20px rgba(16,78,139,.3)}
.btn-outline{background:transparent;color:var(--ink);border:1.5px solid var(--border);position:relative}
.btn-outline:hover{border-color:var(--blue-border);color:var(--blue)}
.btn-ecom{display:inline-flex;align-items:center;gap:9px;width:100%;justify-content:center;background:var(--blue);color:#fff;font-family:'Space Grotesk',sans-serif;font-size:.9rem;font-weight:700;letter-spacing:.04em;padding:15px 20px;border-radius:var(--r-sm);transition:all .2s;cursor:pointer;border:none;text-decoration:none}
.btn-ecom:hover{background:#0D4180;transform:translateY(-1px);box-shadow:0 6px 20px rgba(16,78,139,.3)}
.btn-ecom-outline{display:inline-flex;align-items:center;gap:9px;width:100%;justify-content:center;background:#fff;color:var(--blue);border:1.5px solid var(--blue-border);font-family:'Space Grotesk',sans-serif;font-size:.84rem;font-weight:700;letter-spacing:.04em;padding:13px 20px;border-radius:var(--r-sm);transition:all .2s;cursor:pointer;text-decoration:none}
.btn-ecom-outline:hover{background:var(--blue-light);border-color:var(--blue)}
.btn-danger{background:#dc2626;color:#fff;border:none;padding:8px 14px;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer}
.btn-danger:hover{background:#b91c1c}
.btn-sm{padding:8px 14px;font-size:.78rem}

/* ── SECTIONS ── */
.sec{padding:88px 2.5rem}
.sec.alt{background:var(--off)}
.sec.alt2{background:var(--off2)}
.sec-inner{max-width:var(--max);margin:0 auto}
.sec-eye{display:flex;align-items:center;gap:8px;font-size:.68rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--blue);margin-bottom:.7rem}
.sec-h{font-family:'DM Serif Display',serif;font-size:clamp(2rem,3.5vw,2.8rem);font-weight:400;line-height:1.15;letter-spacing:-.015em;color:var(--ink);margin-bottom:1rem}
.sec-h em{font-style:italic;color:var(--blue)}
.sec-lead{font-size:1rem;line-height:1.8;color:var(--ink2);max-width:640px}
.eyeline{display:inline-block;width:28px;height:2px;background:var(--blue);border-radius:1px}

/* ── HERO ── */
.hero{padding:120px 2.5rem 80px;background:var(--white);position:relative;overflow:hidden}
.hero-blobs{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.hero-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.35}
.hero-blob-1{width:600px;height:600px;right:-200px;top:-200px;background:radial-gradient(circle,#dceaf6,#f0f5fb)}
.hero-blob-2{width:400px;height:400px;left:-100px;bottom:-100px;background:radial-gradient(circle,#e8f2fb,#f5f8fc)}
.hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 420px;gap:5rem;align-items:center;position:relative;z-index:2}
.hero-badge{display:inline-flex;align-items:center;gap:8px;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--blue);background:var(--blue-light);border:1px solid var(--blue-border);padding:6px 14px;border-radius:20px;margin-bottom:1.6rem}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}
.hero-h{font-family:'DM Serif Display',serif;font-size:clamp(2.4rem,3.8vw,3.8rem);font-weight:400;line-height:1.06;letter-spacing:-.02em;color:var(--ink);margin-bottom:1.4rem}
.hero-h em{font-style:italic;color:var(--blue)}
.hero-sub{font-size:1.05rem;line-height:1.8;color:var(--ink2);max-width:500px;margin-bottom:1.8rem}
.hero-quote{font-family:'DM Serif Display',serif;font-style:italic;font-size:1.15rem;color:var(--ink2);line-height:1.5;padding:1rem 1.4rem;background:#f8f9fc;border-left:3px solid var(--blue);border-radius:0 var(--r-sm) var(--r-sm) 0;margin-bottom:2rem}
.hero-btns{display:flex;gap:10px;flex-wrap:wrap}
.hero-stats{display:flex;flex-direction:column;gap:12px}
.hstat{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r);padding:1.2rem 1.4rem;display:flex;align-items:center;gap:14px;box-shadow:var(--sh);transition:border-color .2s,box-shadow .2s}
.hstat:hover{border-color:var(--blue-border);box-shadow:var(--sh-lg)}
.hstat-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hstat-num{font-family:'DM Serif Display',serif;font-size:1.8rem;color:var(--ink);line-height:1}
.hstat-lbl{font-size:.78rem;color:var(--muted);line-height:1.4;margin-top:2px}

/* ── PRODUCTOS GRID ── */
.productos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:3rem}
.prod-card{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r-lg);padding:2rem;box-shadow:var(--sh);transition:box-shadow .2s,border-color .2s,transform .2s;display:flex;flex-direction:column}
.prod-card:hover{box-shadow:var(--sh-lg);transform:translateY(-3px)}
.prod-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.prod-card-badge{font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 12px;border-radius:20px}
.prod-card-img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:var(--r);margin-bottom:1.2rem;background:var(--off)}
.prod-card-name{font-family:'DM Serif Display',serif;font-size:1.4rem;font-weight:400;line-height:1.1;margin-bottom:.35rem}
.prod-card-tagline{font-family:'DM Serif Display',serif;font-style:italic;font-size:.9rem;color:var(--muted);line-height:1.4;margin-bottom:1rem}
.prod-card-price{font-family:'Space Grotesk',sans-serif;font-size:1.5rem;font-weight:700;margin-bottom:1.2rem}
.prod-card-actions{display:flex;flex-direction:column;gap:8px;margin-top:auto}

/* ── PRODUCTO DETALLE ── */
.prod{padding:80px 2.5rem;border-bottom:1px solid var(--border2)}
.prod:nth-child(even){background:var(--off)}
.prod-wrap{max-width:var(--max);margin:0 auto;display:flex;gap:4.5rem;align-items:start}
.prod-gallery{display:flex;flex-direction:column;gap:10px;flex-shrink:0;width:440px;position:sticky;top:80px}
.prod-main-img{border-radius:var(--r-lg);overflow:hidden;border:1.5px solid var(--border);background:var(--pbg,#f8f9fc);aspect-ratio:4/3;position:relative;display:flex;align-items:center;justify-content:center}
.prod-main-img img{width:100%;height:100%;object-fit:cover}
.prod-area-badge{position:absolute;top:14px;left:14px;font-size:.65rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ptxt,#333);background:var(--pbg,#EEF4FB);border:1px solid var(--ppill,#ddd);padding:4px 12px;border-radius:20px}
.prod-content{flex:1;min-width:0}
.prod-eyebrow{display:flex;align-items:center;gap:7px;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--pdot,var(--blue));margin-bottom:.7rem}
.pdot{width:8px;height:8px;border-radius:50%;background:var(--pdot,var(--blue));flex-shrink:0}
.prod-name{font-family:'DM Serif Display',serif;font-size:2.2rem;font-weight:400;letter-spacing:-.015em;color:var(--ink);line-height:1.1;margin-bottom:.5rem}
.prod-tagline{font-family:'DM Serif Display',serif;font-style:italic;font-size:1.1rem;color:var(--pdot,var(--blue));margin-bottom:1rem;line-height:1.4}
.prod-body{font-size:.93rem;line-height:1.8;color:var(--ink2);margin-bottom:1.4rem}
.micro-pill-card{background:var(--pbg,#EEF4FB);border:1.5px solid var(--ppill,#C2D6EE);border-radius:var(--r);padding:1.2rem 1.4rem;margin-bottom:1.2rem}
.micro-tag{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--pdot,var(--blue))}
.micro-compound{font-family:'Space Grotesk',sans-serif;font-size:.95rem;font-weight:700;margin-bottom:.4rem}
.micro-body{font-size:.84rem;color:var(--ink2);line-height:1.7}

/* product price card */
.product-price-card{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;background:#0c1a2e;color:#fff;border-radius:14px;padding:1.15rem 1.35rem;margin:0 0 1.35rem;box-shadow:0 10px 28px rgba(12,26,46,.12)}
.price-kicker{font-size:.64rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.48);margin-bottom:.15rem}
.price-value{font-family:'DM Serif Display',serif;font-size:2.15rem;font-weight:400;line-height:1;color:#fff;letter-spacing:-.02em}
.price-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.45rem;text-align:right;min-width:180px}
.price-badge{display:inline-flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:rgba(255,255,255,.62);border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);border-radius:999px;padding:.22rem .75rem;white-space:nowrap}

/* prod dl */
.prod-dl{display:flex;flex-direction:column}
.prod-dl-row{display:flex;gap:1rem;padding:.75rem 0;border-bottom:1px solid var(--border2);align-items:flex-start}
.prod-dl-row:last-child{border:none}
.prod-dl-row dt{font-size:.67rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted2);flex-shrink:0;width:90px;margin-top:2px}
.prod-dl-row dd{font-size:.86rem;color:var(--ink2);line-height:1.55}

/* ── CARRITO ── */
.cart-wrap{max-width:920px;margin:0 auto;display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
.cart-table{width:100%;border-collapse:collapse}
.cart-table th{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:.75rem 1rem;border-bottom:2px solid var(--border);text-align:left}
.cart-table td{padding:.9rem 1rem;border-bottom:1px solid var(--border2);vertical-align:middle}
.cart-qty{display:flex;align-items:center;gap:6px}
.cart-qty button{width:28px;height:28px;border-radius:6px;border:1.5px solid var(--border);background:var(--off);font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:border-color .2s}
.cart-qty button:hover{border-color:var(--blue)}
.cart-qty span{width:32px;text-align:center;font-size:.9rem;font-weight:600}
.cart-summary{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--sh);position:sticky;top:88px}
.cart-summary-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0;border-bottom:1px solid var(--border2);font-size:.9rem}
.cart-summary-row:last-child{border:none}
.cart-summary-total{font-size:1.2rem;font-weight:700;color:var(--ink)}
.cart-empty{text-align:center;padding:5rem 2rem}

/* ── CHECKOUT ── */
.checkout-wrap{max-width:860px;margin:0 auto;display:grid;grid-template-columns:1fr 320px;gap:2rem;align-items:start}
.checkout-form{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r-lg);padding:2rem;box-shadow:var(--sh)}
.form-section{margin-bottom:2rem}
.form-section-title{font-family:'Space Grotesk',sans-serif;font-size:.78rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:1.2rem;padding-bottom:.6rem;border-bottom:1px solid var(--border2)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-full{grid-column:1/-1}
.form-group{display:flex;flex-direction:column;gap:.4rem}
.form-group label{font-size:.78rem;font-weight:600;color:var(--ink2)}
.form-group input,.form-group select{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--r-sm);font-family:inherit;font-size:.9rem;color:var(--ink);background:var(--white);transition:border-color .2s}
.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--blue)}
.form-group input.error,.form-group select.error{border-color:#dc2626}
.form-hint{font-size:.74rem;color:var(--muted);margin-top:2px}
.form-error{font-size:.74rem;color:#dc2626;margin-top:2px}
.checkout-order-summary{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r-lg);padding:1.8rem;box-shadow:var(--sh);position:sticky;top:88px}

/* ── ADMIN ── */
.admin-layout{display:flex;min-height:100vh}
.admin-sidebar{width:220px;background:#0c1a2e;padding:2rem 1.2rem;flex-shrink:0;position:fixed;top:0;left:0;bottom:0;overflow-y:auto}
.admin-content{margin-left:220px;padding:2.5rem;flex:1}
.admin-nav-title{font-family:'DM Serif Display',serif;font-size:1.1rem;color:#fff;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.08)}
.admin-nav-link{display:block;padding:.65rem .9rem;border-radius:8px;font-size:.86rem;font-weight:500;color:rgba(255,255,255,.55);transition:all .2s;margin-bottom:3px}
.admin-nav-link:hover,.admin-nav-link.active{background:rgba(255,255,255,.08);color:#fff}
.admin-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin-bottom:2rem}
.admin-kpi{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r);padding:1.4rem;box-shadow:var(--sh)}
.admin-kpi-val{font-family:'DM Serif Display',serif;font-size:1.8rem;color:var(--blue);line-height:1}
.admin-kpi-lbl{font-size:.76rem;color:var(--muted);margin-top:4px}
.admin-table-wrap{background:var(--white);border:1.5px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh)}
.admin-table{width:100%;border-collapse:collapse}
.admin-table th{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:.8rem 1.2rem;border-bottom:2px solid var(--border);text-align:left;background:var(--off)}
.admin-table td{padding:.85rem 1.2rem;border-bottom:1px solid var(--border2);font-size:.87rem;vertical-align:middle}
.admin-table tr:last-child td{border:none}
.admin-table tr:hover td{background:var(--off)}
.badge-estado{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:.04em}
.badge-pendiente{background:#FEF3C7;color:#D97706}
.badge-pagado{background:#D1FAE5;color:#059669}
.badge-enviado{background:#DBEAFE;color:#2563EB}
.badge-cancelado{background:#FEE2E2;color:#DC2626}

/* ── ESTADOS PAGO ── */
.pago-exito{text-align:center;padding:5rem 2rem;max-width:520px;margin:0 auto}
.pago-exito-icon{width:72px;height:72px;background:#D1FAE5;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.pago-fail{text-align:center;padding:5rem 2rem;max-width:520px;margin:0 auto}
.pago-fail-icon{width:72px;height:72px;background:#FEE2E2;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}

/* ── ALERTAS ── */
.alert{padding:12px 16px;border-radius:var(--r-sm);font-size:.88rem;margin-bottom:1.2rem}
.alert-error{background:#FEE2E2;color:#991B1B;border:1px solid #FECACA}
.alert-success{background:#D1FAE5;color:#065F46;border:1px solid #A7F3D0}
.alert-info{background:#DBEAFE;color:#1E40AF;border:1px solid #BFDBFE}

/* ── HAM MENU ── */
.ham-btn{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px}
.ham-btn span{width:22px;height:2px;background:var(--ink);border-radius:1px;transition:all .3s;display:block}
.mob-menu{display:none;position:fixed;top:72px;left:0;right:0;z-index:190;background:var(--white);border-bottom:1px solid var(--border2);padding:1rem 2rem;flex-direction:column;gap:.2rem;box-shadow:var(--sh-lg)}
.mob-menu.open{display:flex}
.mob-menu-link{padding:.75rem 0;font-size:.92rem;font-weight:500;color:var(--ink2);border-bottom:1px solid var(--border2)}
.mob-menu-link:last-child{border:none}
.mob-menu-overlay{display:none;position:fixed;inset:0;z-index:180;background:rgba(0,0,0,.3)}
.mob-menu-overlay.open{display:block}

/* ── CTA ── */
.cta-sec{background:linear-gradient(135deg,#104E8B 0%,#0D4180 100%);padding:88px 2.5rem;text-align:center;position:relative;overflow:hidden}
.cta-inner{max-width:600px;margin:0 auto;position:relative;z-index:2}
.cta-h{font-family:'DM Serif Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;line-height:1.15;color:#fff;margin-bottom:1rem}
.cta-h em{font-style:italic}
.cta-sub{font-size:1rem;color:rgba(255,255,255,.8);line-height:1.75;margin-bottom:2rem}

/* ── FOOTER ── */
footer{background:var(--ink);padding:3rem 2.5rem}

/* ── ANIMATIONS ── */
.fi{opacity:0;transform:translateY(22px);transition:opacity .65s ease,transform .65s ease}
.fi.v{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}

/* ── PAGE HEADER ── */
.page-header{padding:120px 2.5rem 48px;background:var(--white);border-bottom:1px solid var(--border2)}
.page-header-inner{max-width:var(--max);margin:0 auto}
.page-header h1{font-family:'DM Serif Display',serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;color:var(--ink);margin-bottom:.5rem}

/* ── RESPONSIVE ── */
@media(max-width:1040px){
  .hero-inner{grid-template-columns:1fr;gap:3rem}
  .hero-stats{flex-direction:row;flex-wrap:wrap}
  .hstat{flex:1;min-width:180px}
  .productos-grid{grid-template-columns:repeat(2,1fr)}
  .prod-wrap{flex-direction:column}
  .prod-gallery{width:100%;position:static}
  .cart-wrap,.checkout-wrap{grid-template-columns:1fr}
  .cart-summary,.checkout-order-summary{position:static}
  .admin-kpis{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-links{display:none}
  .ham-btn{display:flex}
  .sec{padding:60px 1.5rem}
  .hero{padding:100px 1.5rem 60px}
  .hero-inner{grid-template-columns:1fr}
  .productos-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .admin-sidebar{position:static;width:100%}
  .admin-content{margin-left:0}
  .admin-layout{flex-direction:column}
  .admin-kpis{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .admin-kpis{grid-template-columns:1fr}
  .cart-table th:nth-child(3),.cart-table td:nth-child(3){display:none}
}
