
:root{
  --bg:#0A0F14; --card:#0F1720; --text:#E7F0EA; --muted:#A8C0B2; --brand:#10d07f; --brand-2:#0abf72;
  --border:#1e2a36; --danger:#ef4444;
  --section-pad-mobile:32px; --section-pad-desktop:48px;
  --section-gap-mobile:64px; --section-gap-desktop:96px;
  --btn-sm-width:140px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;line-height:1.5}
img{max-width:100%;display:block}
a{color:var(--text);text-decoration:none;transition:color .2s ease, text-underline-offset .2s ease}
a:not(.btn):hover{color:#fff;text-decoration:underline;text-underline-offset:3px}
.container{max-width:1200px;margin:0 auto;padding:0 16px}

.site-header{position:sticky;top:0;z-index:20;background:rgba(10,15,20,.9);backdrop-filter:blur(6px);border-bottom:1px solid var(--border)}
.site-header .inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;gap:10px;align-items:center}
.brand-logo{width:28px;height:28px}
.brand-name{font-weight:700;letter-spacing:.3px}
.site-nav a{margin-left:18px;padding:8px 10px;border-radius:10px;transition:background .2s, transform .2s}
.site-nav a:hover{background:rgba(255,255,255,.06);transform:translateY(-1px)}

/* Mobile nav toggle */
.nav-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:10px;border:1px solid var(--brand);
  background:transparent;color:var(--brand);cursor:pointer;
  transition:background .2s, transform .12s, color .2s;
  margin-left:10px;
}
.nav-toggle svg{width:22px;height:22px}
.nav-toggle:hover{background:var(--brand);color:#000;transform:translateY(-1px)}
@media(min-width:900px){ .nav-toggle{display:none} }
/* Mobile menu */
@media(max-width:899px){
  .site-header{position:sticky;top:0}
  .site-nav{display:none;position:absolute;left:0;right:0;top:100%;
    background:var(--card);border-bottom:1px solid var(--border);
    padding:12px;z-index:30;flex-direction:column;gap:6px}
  .site-header.nav-open .site-nav{display:flex}
  .site-nav a{margin:0;padding:10px 12px;border-radius:10px}
}

.btn, .btn.secondary, .btn.link{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 16px;border-radius:12px;border:1px solid transparent;
  background:var(--brand);color:#032015;font-weight:600;cursor:pointer;
  transition:transform .12s ease, box-shadow .2s ease, background .2s;
}
.btn:hover, .btn.secondary:hover, .btn.link:hover{transform:translateY(-1px);box-shadow:0 10px 24px rgba(16,208,127,.25);background:var(--brand-2)}
/* Consistent button text color */
.btn, .btn:hover, .btn:focus, .btn:active,
.btn.secondary, .btn.secondary:hover, .btn.secondary:focus, .btn.secondary:active,
.btn.link, .btn.link:hover, .btn.link:focus, .btn.link:active { color:#032015 !important; }

/* Smaller CTAs and fixed width for banner & split sections */
.home-split .content .btn{align-self:flex-start;padding:6px 12px;font-size:.9rem;line-height:1.1;border-radius:10px;width:var(--btn-sm-width);min-width:var(--btn-sm-width);max-width:var(--btn-sm-width);white-space:nowrap;justify-content:center;text-align:center}
.home-banner .banner-content .btn{padding:6px 12px;font-size:.9rem;line-height:1.1;border-radius:10px;width:var(--btn-sm-width);min-width:var(--btn-sm-width);max-width:var(--btn-sm-width);white-space:nowrap;justify-content:center;text-align:center}

.opening{position:relative;padding:var(--section-pad-mobile) 0;border-bottom:1px solid var(--border);background-size:cover;background-position:center;background-repeat:no-repeat;overflow:hidden}
.opening::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg, rgba(8,12,16,.65), rgba(8,12,16,.35) 45%, rgba(8,12,16,0) 70%)}
.opening .container{position:relative;z-index:1}
.opening h1{font-size:40px;margin:0 0 8px}
.opening p{margin:0;color:var(--muted)}
@media(min-width:900px){ .opening{padding:var(--section-pad-desktop) 0} }

.opening-home{background-image:url('../img/opening-home.webp'); background-position:60% center}
.opening-nosotros{background-image:url('../img/opening-nosotros.webp'); background-position:center center}
.opening-productos{background-image:url('../img/opening-productos.webp'); background-position:center center}
.opening-contacto{background-image:url('../img/opening-contacto.webp'); background-position:40% 45%}
.opening-carrito{background-image:url('../img/opening-carrito.webp'); background-position:center 55%}

.grid-2{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:900px){.grid-2{grid-template-columns:repeat(2,1fr)}}

.card{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:22px;box-shadow:0 2px 10px rgba(0,0,0,.2)}
.equal-cards .card{display:flex;flex-direction:column;justify-content:space-between}
.text-center{text-align:center}

.product-grid{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:900px){.product-grid{grid-template-columns:repeat(4,1fr)}}
.product-card{background:var(--card);border:1px solid var(--border);border-radius:16px;overflow:hidden;display:flex;flex-direction:column}
.product-media{width:100%;aspect-ratio:1/1;background:#0b1219;display:block}
.product-media img{width:100%;height:100%;object-fit:cover}
.product-body{padding:14px;display:flex;flex-direction:column;gap:8px}
.product-body h3{font-size:16px;margin:0}
.product-desc{color:var(--muted);font-size:14px;min-height:40px}
.product-price{font-weight:700;font-size:18px;margin-top:6px}
.qty{display:flex;align-items:center;gap:8px}
.qty input{width:64px;min-width:64px;text-align:center;padding:10px;border-radius:10px;border:1px solid var(--border);background:#0a1218;color:var(--text);font-variant-numeric:tabular-nums}
@media(max-width:480px){ .qty input{width:56px;min-width:56px} }
.qty .step{width:36px;height:36px;border-radius:10px;border:1px solid transparent;background:var(--brand);color:#032015;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s, transform .12s}
.qty .step:hover{background:var(--brand-2);transform:translateY(-1px)}

/* Remove native number input spinners */
input[type=number]{-moz-appearance:textfield;appearance:textfield}
input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}

.footer-rich{border-top:1px solid var(--border);margin-top:var(--section-gap-mobile)}
@media(min-width:900px){ .footer-rich{ margin-top: var(--section-gap-desktop) } }
.footer-rich .container{display:grid;grid-template-columns:1fr;gap:20px;padding:24px 16px}
@media(min-width:900px){.footer-rich .container{grid-template-columns:2fr 1fr 1fr}}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.footer-meta{color:var(--muted)}
.footer-social{display:flex;align-items:center;gap:10px}
.footer-list{list-style:none;padding:0;margin:0}
.footer-list li{margin:8px 0}
.site-footer{border-top:1px solid var(--border);padding:12px 0;color:var(--muted);font-size:14px}

.fw-btn{position:fixed;right:18px;bottom:18px;z-index:25;background:#25D366;color:#08120c;width:56px;height:56px;border-radius:28px;display:flex;align-items:center;justify-content:center;box-shadow:0 12px 24px rgba(37,211,102,.3);transition:transform .12s}
.fw-btn:hover{transform:translateY(-2px)}

.form{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:20px;display:grid;gap:14px}
.form .row{display:grid;grid-template-columns:1fr;gap:14px}
@media(min-width:900px){.form .row{grid-template-columns:1fr 1fr}}
.input, textarea{background:#0b141b;border:1px solid var(--border);border-radius:12px;color:var(--text);padding:12px 14px;width:100%}
textarea{min-height:140px;resize:vertical}
label{font-size:14px;color:var(--muted)}

.cart-actions{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.cart-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.cart-table th,.cart-table td{padding:12px;border-bottom:1px solid var(--border);vertical-align:middle}
.cart-table th{background:#0e1620;text-align:left}
.cart-product{display:flex;align-items:center;gap:10px}
.cart-product img{width:56px;height:56px;object-fit:cover;border-radius:10px;border:1px solid var(--border)}
.cart-summary{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:16px}

.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:rgba(255,255,255,.06);font-size:12px;color:var(--muted)}
h2{margin:8px 0 16px;font-size:26px}

/* unified section vertical padding */
section{padding:var(--section-pad-mobile) 0}
@media(min-width:900px){ section{padding:var(--section-pad-desktop) 0} }
/* opening to first section gap */
main{margin-top:var(--section-gap-mobile) !important}
@media(min-width:900px){ main{margin-top:var(--section-gap-desktop) !important} }
/* unified section-to-section gap */
section + section{margin-top:var(--section-gap-mobile) !important}
@media(min-width:900px){ section + section{margin-top:var(--section-gap-desktop) !important} }

/* Home banner */
.home-banner .banner-inner{
  display:grid;grid-template-columns:1fr;gap:16px;
  background:var(--card);border:1px solid var(--border);border-radius:18px;
  padding:18px;
}
.home-banner .banner-content{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.home-banner .banner-media img{width:100%;height:auto;border-radius:14px;display:block}
@media(min-width:900px){
  .home-banner .banner-inner{grid-template-columns:1.2fr 1fr;align-items:center;padding:22px}
  .home-banner .banner-media img{aspect-ratio:16/9;object-fit:cover}
}

/* Home split sections */
.home-split{display:grid;grid-template-columns:1fr;gap:16px;align-items:center}
.home-split .content{display:flex;flex-direction:column;gap:10px}
.home-split .media{border:1px solid var(--border);border-radius:14px;overflow:hidden;background:#0b141b}
.home-split .media img{width:100%;display:block;aspect-ratio:4/3;object-fit:cover}
@media(min-width:900px){
  .home-split{grid-template-columns:1fr 1.4fr}
  .home-nosotros .home-split{grid-template-columns:1fr 1.4fr} /* image left */
  .home-productos .home-split{grid-template-columns:1fr 1.4fr} /* image left */
  .home-nosotros .home-split .media{justify-self:start; max-width:420px}
  .home-productos .home-split .media{justify-self:start; max-width:420px}
}

/* Social icons */
.footer-social .soc{
  width:44px;height:44px;border-radius:12px;border:1px solid var(--brand); background:transparent;
  display:inline-flex;align-items:center;justify-content:center; position:relative;
  transition:background .2s, transform .12s, box-shadow .2s;
  box-shadow:none;
}
.footer-social .soc::before{
  content:""; width:20px;height:20px; display:block; background:var(--brand);
  -webkit-mask: var(--icon) center/contain no-repeat;
  mask: var(--icon) center/contain no-repeat;
}
.footer-social .soc:hover{ background:var(--brand); transform:translateY(-2px); box-shadow:0 10px 24px rgba(16,208,127,.25) }
.footer-social .soc:hover::before{ background:#000 }
.footer-social .soc-wa{ --icon: url('../img/icon-whatsapp.svg') }
.footer-social .soc-ig{ --icon: url('../img/icon-instagram.svg') }
.footer-social .soc-fb{ --icon: url('../img/icon-facebook.svg') }
.footer-social .soc-mail{ --icon: url('../img/icon-mail.svg') }

@media(min-width:900px){ .footer-rich{ margin-top: var(--section-gap-desktop) } }

/* Benefit cards with image */
.benefit-card .media{border:1px solid var(--border);border-radius:12px;overflow:hidden;background:#0b141b;margin-bottom:10px}
.benefit-card .media img{width:100%;display:block;aspect-ratio:16/9;object-fit:cover}

.grid-3{display:grid;grid-template-columns:1fr;gap:20px}
@media(min-width:900px){ .grid-3{grid-template-columns:repeat(3,1fr)} }


/* Cart page: table wrapper to handle overflow on mobile */
.table-wrap{overflow:auto;border-radius:14px}
.table-wrap .cart-table{min-width:640px}

@media(min-width:900px){ .cart-actions{ margin-bottom:32px } }

/* cart mobile tweaks */
@media(max-width:600px){
  .cart-table th,.cart-table td{padding:10px 8px;font-size:14px}
  .cart-product img{width:44px;height:44px}
  .qty input{width:56px;min-width:56px;padding:8px}
  .qty .step{width:32px;height:32px}
}



/* Mobile cart list (column layout) */
.cart-list{display:none}
@media(max-width:600px){
  .table-wrap{display:none}
  .cart-list{display:grid;gap:12px}
}
.cart-card{background:var(--card);border:1px solid var(--border);border-radius:14px;padding:12px;display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:center}
.cart-card .media img{width:64px;height:64px;object-fit:cover;border-radius:10px;border:1px solid var(--border)}
.cart-card h4{margin:0 0 6px 0;font-size:16px}
.cart-card .meta{display:flex;justify-content:space-between;align-items:center;gap:10px;margin:6px 0}
.cart-card .meta .price{font-weight:700}
.cart-card .actions{display:flex;justify-content:space-between;align-items:center;gap:10px}
.cart-card .remove{margin-left:auto}



/* cart mobile column layout fix */
@media(max-width:768px){
  .table-wrap{display:none}
  .cart-list{display:grid;gap:12px}
  .cart-card{grid-template-columns:1fr}
  .cart-card .media img{width:100%;height:auto;aspect-ratio:16/9}
  .cart-card .meta{flex-direction:column;align-items:flex-start;gap:4px}
  .cart-card .actions{flex-direction:column;align-items:stretch;gap:8px}
  .cart-card .actions .qty{justify-content:flex-start}
  .cart-card .remove{align-self:flex-end}
}

