body{

font-family:'Poppins',sans-serif;
background:#f5f7fb;
color:#222;

}

/* TOPBAR */

.topbar{

background:#0f4ba8;
color:#fff;
padding:8px 0;
font-size:14px;

}

/* HEADER */

.header-main{

background:#fff;
padding:18px 0;
box-shadow:0 2px 8px rgba(0,0,0,.06);

}

.logo{

font-size:28px;
font-weight:700;
color:#0f4ba8;
text-decoration:none;

}

.logo:hover{
color:#d91e26;
}

/* SEARCH */

.search-box{

height:50px;

}

.search-box input{

border-radius:12px 0 0 12px;
border:2px solid #0f4ba8;

}

.btn-search{

background:#d91e26;
color:#fff;
border:none;
border-radius:0 12px 12px 0;
padding:0 24px;

}

.btn-search:hover{

background:#b1161d;
color:#fff;

}

/* ICONS */

.header-icons{

display:flex;
justify-content:flex-end;
gap:25px;

}

.header-icons a{

color:#222;
font-weight:500;
text-decoration:none;

}

.header-icons i{

font-size:18px;
margin-right:6px;
color:#0f4ba8;

}

/* MENU */

.main-menu{

background:#fff;
border-top:1px solid #eee;
border-bottom:1px solid #eee;

}

.categories-btn{

background:#0f4ba8;
color:#fff;
padding:14px 22px;
font-weight:600;
margin-right:25px;
cursor:pointer;

}

.menu-list{

display:flex;
gap:28px;
list-style:none;
margin:0;
padding:0;

}

.menu-list li{

padding:14px 0;

}

.menu-list a{

text-decoration:none;
color:#333;
font-weight:500;

}

.menu-list a:hover{

color:#d91e26;

}

/* FOOTER */

.footer{

background:#fff;
margin-top:60px;
padding:50px 0;

}

.footer h5{

font-weight:600;
margin-bottom:18px;

}

.footer ul{

list-style:none;
padding:0;

}

.footer ul li{

margin-bottom:8px;

}

.footer a{

text-decoration:none;
color:#444;

}

.socials{

display:flex;
gap:18px;
font-size:22px;

}

.copy{

text-align:center;
margin-top:25px;
color:#777;

}
/* HERO */

/* HERO LAYOUT FULL */

.hero-section{

margin-top:25px;

}

.hero-section .container{

max-width:100%;
padding-left:25px;
padding-right:25px;

}

.hero-section .row{

display:flex;
align-items:stretch;

}

.sidebar-categories{

height:100%;

}
.sidebar-categories{

background:#fff;
border-radius:16px;
padding:20px;
box-shadow:0 3px 10px rgba(0,0,0,.05);

}

.sidebar-categories h5{

margin-bottom:20px;
font-weight:600;

}

.sidebar-categories ul{

list-style:none;
padding:0;
margin:0;

}

.sidebar-categories li{

padding:12px 0;
border-bottom:1px solid #eee;

}

.sidebar-categories a{

text-decoration:none;
color:#333;

}

.hero-banner{

height:420px;
border-radius:20px;
background-size:cover;
background-position:center;
position:relative;
overflow:hidden;

}

.hero-overlay{

position:absolute;
inset:0;
background:linear-gradient(
90deg,
rgba(7,17,29,.88),
rgba(7,17,29,.45)
);

display:flex;
align-items:center;
padding:55px;
color:#fff;

}

.hero-content{

max-width:520px;

}

.hero-content h1{

font-size:52px;
font-weight:700;
margin-bottom:15px;

}

.hero-content p{

font-size:18px;
margin-bottom:25px;

}

.hero-content h1{

font-size:48px;
font-weight:700;

}

.hero-content p{

font-size:18px;
margin:15px 0 25px;

}

.btn-hero{

background:#d91e26;
color:#fff;
padding:14px 28px;
border-radius:12px;

}

.btn-hero:hover{

background:#b3151c;
color:#fff;

}

/* SECTION */

.section-title{

margin:50px 0 25px;

}

.section-title h2{

font-weight:700;

}

/* CAT CARDS */

.cat-card{

background:#fff;
padding:35px;
border-radius:18px;
text-align:center;
box-shadow:0 3px 12px rgba(0,0,0,.05);
transition:.3s;

}

.cat-card:hover{

transform:translateY(-5px);

}

.cat-card i{

font-size:42px;
color:#0f4ba8;
margin-bottom:15px;

}

/* PRODUCTS */

.product-card{

background:#fff;
padding:18px;
border-radius:18px;
box-shadow:0 3px 12px rgba(0,0,0,.05);
position:relative;
transition:.3s;

}

.product-card:hover{

transform:translateY(-6px);

}

.product-card img{
    width:100%;
    height:260px;
    object-fit:cover;
    display:block;
}

.product-card h5{

font-weight:600;
min-height:48px;

}

.product-badge{

position:absolute;
top:15px;
left:15px;
background:#d91e26;
color:#fff;
padding:6px 12px;
border-radius:8px;
font-size:12px;
font-weight:600;

}

.price{

margin:15px 0;

}

.old{

text-decoration:line-through;
color:#888;
margin-right:10px;

}

.new{

font-size:24px;
font-weight:700;
color:#0f4ba8;

}

.product-buttons{

display:flex;
gap:10px;

}

.btn-cart{

flex:1;
background:#0f4ba8;
color:#fff;
border-radius:10px;

}

.btn-buy{

flex:1;
background:#d91e26;
color:#fff;
border-radius:10px;

}

.btn-cart:hover,
.btn-buy:hover{

opacity:.9;
color:#fff;

}
/* CATALOGO */

.catalogo-page{

padding:40px 0;

}

/* PRODUCTO */

.producto-page{

padding:50px 0;

}

.product-main-image{

background:#fff;
padding:20px;
border-radius:18px;
box-shadow:0 3px 12px rgba(0,0,0,.05);

}

.producto-page h1{

font-size:38px;
font-weight:700;
margin-bottom:15px;

}

.product-desc{

color:#666;
margin-bottom:25px;

}

.product-actions{

display:flex;
gap:12px;
margin-top:20px;

}
/* CARRITO */

.carrito-page{

padding:50px 0;

}

.cart-total{

text-align:right;
margin-top:30px;

}
/* PRODUCTO PRO */

.product-main-box{

background:#fff;
padding:25px;
border-radius:22px;
box-shadow:0 5px 20px rgba(0,0,0,.05);

}

.thumb-gallery{

display:flex;
gap:10px;
margin-top:15px;
flex-wrap:wrap;

}

.thumb-img{

width:90px;
height:90px;
object-fit:cover;
border-radius:12px;
cursor:pointer;
border:2px solid #eee;
transition:.3s;

}

.thumb-img:hover{

border-color:#0f4ba8;

}

.premium-select{

height:54px;
border-radius:14px;

}

.stock-box{

background:#eef6ee;
padding:12px 16px;
border-radius:12px;
color:#2c7a2c;
font-weight:600;
display:inline-block;

}
/* FILTROS */

.catalog-filters{

background:#fff;
padding:20px;
border-radius:18px;
box-shadow:0 5px 20px rgba(0,0,0,.05);

}
/* CHECKOUT PREMIUM */

.checkout-premium{

padding:60px 0;

}

.checkout-card,
.checkout-summary{

background:#fff;
padding:35px;
border-radius:24px;
box-shadow:0 5px 20px rgba(0,0,0,.05);

}

.checkout-card h2{

font-weight:700;

}

.checkout-card label{

font-weight:500;
margin-bottom:8px;

}

.checkout-card .form-control{

border-radius:14px;
padding:14px;

}

.summary-item{

display:flex;
justify-content:space-between;
gap:15px;
margin-bottom:18px;
align-items:center;

}

.summary-total{

display:flex;
justify-content:space-between;
font-size:28px;
font-weight:700;

}
/* WISHLIST */

.wishlist-top{

margin-bottom:20px;

}

.wishlist-btn{

width:52px;
height:52px;
border-radius:50%;
background:#fff;
display:flex;
align-items:center;
justify-content:center;
font-size:22px;
color:#d62839;
text-decoration:none;
box-shadow:0 5px 18px rgba(0,0,0,.08);

}
.site-logo{

height:55px;
width:auto;
display:block;

}
/* CONTACTO */

.contact-page{

padding:70px 0;

}

.contact-info-card,
.contact-form-card{

background:#fff;
padding:35px;
border-radius:26px;
box-shadow:0 8px 28px rgba(0,0,0,.05);

}

.contact-info-card h2{

font-weight:700;
margin-bottom:15px;

}

.contact-item{

display:flex;
gap:16px;
align-items:flex-start;
margin-top:28px;

}

.contact-item i{

width:52px;
height:52px;
border-radius:16px;
background:#f5efe3;
display:flex;
align-items:center;
justify-content:center;
color:#a88655;
font-size:20px;

}

.contact-form-card .form-control{

border-radius:14px;
padding:14px;

}
/* MI CUENTA */

.mi-cuenta-page{

padding:70px 0;

}

.account-header{

margin-bottom:35px;

}

.account-header h2{

font-size:40px;
font-weight:700;

}

.account-header p{

color:#7c8798;

}

.account-grid{

display:grid;
grid-template-columns:repeat(4,1fr);
gap:24px;

}

.account-card{

background:#fff;
padding:30px;
border-radius:24px;
box-shadow:0 8px 28px rgba(0,0,0,.05);
transition:.25s;

}

.account-card:hover{

transform:translateY(-5px);

}

.account-icon{

width:58px;
height:58px;
border-radius:18px;
background:#f5efe3;
display:flex;
align-items:center;
justify-content:center;
font-size:22px;
color:#a88655;
margin-bottom:18px;

}

.account-card h3{

font-size:34px;
font-weight:700;
margin-top:10px;

}

.account-card a{

text-decoration:none;
font-weight:600;
color:#0f4ba8;

}

.logout-card{

background:#fff5f5;

}

@media(max-width:992px){

.account-grid{

grid-template-columns:1fr 1fr;

}

}

@media(max-width:768px){

.account-grid{

grid-template-columns:1fr;

}

}
/* FLASH OFFER */

.flash-sale{
    margin-top:25px;
    margin-bottom:25px;
}
.flash-wrapper{
    background: linear-gradient(135deg,#1f5fbf,#c02b6f);
    border-radius:25px;
    padding:25px;
    margin:25px 0;
    box-shadow:0 10px 30px rgba(0,0,0,.15);
}

.flash-tag{

display:inline-block;
background:#fff;
color:#d62839;
padding:10px 18px;
border-radius:40px;
font-weight:700;
margin-bottom:18px;

}

.flash-wrapper h2{
    font-size:2rem;
    color:#fff;
    margin-bottom:10px;
}

.flash-wrapper p{
    color:#fff;
    opacity:.9;
}
.flash-price{

margin:20px 0;

}

.flash-price .old{
    color:rgba(255,255,255,.6);
}

.flash-price .new{
    font-size:2.2rem;
    font-weight:700;
    color:#fff;
}

.flash-timer{

display:inline-block;
background:#fff;
color:#07111d;
padding:14px 26px;
border-radius:16px;
font-size:30px;
font-weight:700;
margin-bottom:25px;

}

.btn-flash{

background:#fff;
color:#0f4ba8;
border-radius:16px;
padding:14px 28px;
font-weight:700;

}

.flash-img{
    width:100%;
    height:260px;
    object-fit:cover;
    border-radius:20px;
}
.footer-instagram{

margin-top:25px;

}

.footer-instagram h5{

margin-bottom:15px;
font-weight:600;

}

.insta-feed{

width:100%;
height:170px;
border:none;
border-radius:18px;
overflow:hidden;

}
/* INSTAGRAM TAB */

.ig-tab{

position:fixed;
right:0;
top:55%;
transform:translateY(-50%);
width:54px;
height:140px;
background:linear-gradient(
180deg,
#833ab4,
#fd1d1d,
#fcb045
);
border-radius:18px 0 0 18px;
display:flex;
align-items:center;
justify-content:center;
color:#fff;
font-size:28px;
cursor:pointer;
z-index:99999;
box-shadow:0 8px 25px rgba(0,0,0,.25);

}

.ig-drawer{

position:fixed;
right:-360px;
top:50%;
transform:translateY(-50%);
width:340px;
background:#fff;
border-radius:24px 0 0 24px;
box-shadow:0 15px 45px rgba(0,0,0,.18);
z-index:99998;
transition:.35s;
overflow:hidden;

}

.ig-drawer.open{

right:0;

}

.ig-top{

background:#f6f6f6;
padding:18px 22px;
display:flex;
justify-content:space-between;
align-items:center;
font-weight:700;

}

#igClose{

cursor:pointer;
font-size:22px;

}

.ig-content{

padding:28px;

}
/* TIKTOK TAB */

.tt-tab{

position:fixed;
right:0;
top:72%;
transform:translateY(-50%);
width:54px;
height:140px;
background:#000;
border-radius:18px 0 0 18px;
display:flex;
align-items:center;
justify-content:center;
color:#fff;
font-size:26px;
cursor:pointer;
z-index:99997;
box-shadow:0 8px 25px rgba(0,0,0,.25);

}

.tt-drawer{

position:fixed;
right:-360px;
top:50%;
transform:translateY(-50%);
width:340px;
background:#fff;
border-radius:24px 0 0 24px;
box-shadow:0 15px 45px rgba(0,0,0,.18);
z-index:99996;
transition:.35s;
overflow:hidden;

}

.tt-drawer.open{

right:0;

}

.tt-top{

background:#111;
color:#fff;
padding:18px 22px;
display:flex;
justify-content:space-between;
align-items:center;
font-weight:700;

}

#ttClose{

cursor:pointer;
font-size:22px;

}

.tt-content{

padding:28px;

}
/* HERO SLIDER PREMIUM */

.hero-slider{

position:relative;
height:420px;
border-radius:34px;
overflow:hidden;
width:100%;

}

.hero-slide{

position:absolute;
inset:0;
opacity:0;
transition:1.1s;
background-size:cover;
background-position:center;
pointer-events:none;

}

.hero-slide.active{

opacity:1;
pointer-events:auto;

}

.hero-slide{

animation:heroZoom 10s linear infinite;

}

@keyframes heroZoom{

from{

transform:scale(1);

}

to{

transform:scale(1.08);

}

}

.hero-overlay{

position:absolute;
inset:0;
background:linear-gradient(
90deg,
rgba(0,0,0,.55),
rgba(0,0,0,.18)
);
display:flex;
align-items:center;

}

.hero-content{

padding:45px;
max-width:470px;

}

@keyframes heroText{

from{

opacity:0;
transform:translateY(30px);

}

to{

opacity:1;
transform:none;

}

}

.hero-content h1{

font-size:44px;
line-height:1.1;

}
.hero-content p{

font-size:20px;
margin-bottom:28px;

}

.hero-nav{

position:absolute;
right:30px;
bottom:30px;
display:flex;
gap:12px;
z-index:9;

}

.hero-prev,
.hero-next{

width:52px;
height:52px;
background:rgba(255,255,255,.15);
backdrop-filter:blur(8px);
border-radius:50%;
display:flex;
align-items:center;
justify-content:center;
color:#fff;
cursor:pointer;
font-size:22px;
transition:.25s;

}

.hero-prev:hover,
.hero-next:hover{

background:#fff;
color:#07111d;

}
/* HERO FULL WIDTH */

.hero-slider{

position:relative;
width:100%;
height:420px;
border-radius:34px;
overflow:hidden;
min-width:0;

}

.hero-slide{

position:absolute;
inset:0;
opacity:0;
transition:1s;
background-size:cover;
background-position:center;
pointer-events:none;

}

.hero-slide.active{

opacity:1;
pointer-events:auto;

}

.hero-slide{

animation:heroZoom 10s linear infinite;

}

.hero-overlay{

position:absolute;
inset:0;
background:linear-gradient(
90deg,
rgba(0,0,0,.55),
rgba(0,0,0,.08)
);
display:flex;
align-items:center;

}

.hero-content{

padding:65px;
max-width:900px;
color:#fff;

}

.hero-content h1{

font-size:64px;
font-weight:700;
line-height:1.05;
margin-bottom:18px;

}

.hero-content p{

font-size:22px;
margin-bottom:30px;

}
/* WHATSAPP TAB */

.wp-tab{

position:fixed;
right:0;
top:88%;
transform:translateY(-50%);
width:54px;
height:140px;
background:#25D366;
border-radius:18px 0 0 18px;
display:flex;
align-items:center;
justify-content:center;
color:#fff;
font-size:30px;
cursor:pointer;
z-index:99995;
box-shadow:0 8px 25px rgba(0,0,0,.25);

}

.wp-drawer{

position:fixed;
right:-360px;
top:50%;
transform:translateY(-50%);
width:340px;
background:#fff;
border-radius:24px 0 0 24px;
box-shadow:0 15px 45px rgba(0,0,0,.18);
z-index:99994;
transition:.35s;
overflow:hidden;

}

.wp-drawer.open{

right:0;

}

.wp-top{

background:#25D366;
color:#fff;
padding:18px 22px;
display:flex;
justify-content:space-between;
align-items:center;
font-weight:700;

}

#wpClose{

cursor:pointer;
font-size:22px;

}

.wp-content{

padding:28px;

}
/* MENU NUEVO */

.main-menu{
background:#111;
}

.menu-list{
display:flex;
align-items:center;
gap:30px;
list-style:none;
margin:0;
padding:0;
}

.menu-list li{
position:relative;
}

.menu-list a{
color:#fff;
text-decoration:none;
font-weight:500;
padding:16px 0;
display:block;
}

.categorias-dropdown{
margin-left:auto;
}

.dropdown-menu-custom{
position:absolute;
top:100%;
right:0;
min-width:280px;
background:#fff;
border-radius:12px;
box-shadow:0 10px 30px rgba(0,0,0,.15);
padding:10px 0;
display:none;
z-index:9999;
max-height:500px;
overflow-y:auto;
}

.dropdown-menu-custom li{
list-style:none;
}

.dropdown-menu-custom a{
color:#222;
padding:10px 20px;
display:block;
}

.dropdown-menu-custom a:hover{
background:#f5f5f5;
}

.categorias-dropdown:hover .dropdown-menu-custom{
display:block;
}