[IMP] website_sale_aplicoop: mejora card producto (placeholder, responsive móvil, accesibilidad y estilo profesional)
This commit is contained in:
parent
828278573d
commit
1d4971c803
1 changed files with 118 additions and 49 deletions
|
|
@ -5,38 +5,44 @@
|
|||
*/
|
||||
|
||||
.product-card {
|
||||
background-color: white;
|
||||
background-color: #fff;
|
||||
border: 1px solid #e0e0e0;
|
||||
border-radius: 8px;
|
||||
border-radius: 12px;
|
||||
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
|
||||
transition: all 0.3s ease;
|
||||
transition: box-shadow 0.3s, transform 0.2s;
|
||||
display: flex;
|
||||
flex-direction: column;
|
||||
padding: 0.5rem 0.5rem 0.5rem 0.5rem;
|
||||
padding: 0.5rem;
|
||||
height: 100%;
|
||||
overflow: hidden;
|
||||
outline: none;
|
||||
}
|
||||
|
||||
.product-card:hover {
|
||||
transform: translateY(-5px);
|
||||
box-shadow: 0 10px 20px rgba(0, 0, 0, 0.12);
|
||||
}
|
||||
|
||||
.product-card:hover,
|
||||
.product-card:focus-within {
|
||||
outline: 3px solid var(--primary-color);
|
||||
transform: translateY(-4px) scale(1.01);
|
||||
box-shadow: 0 8px 24px rgba(0, 0, 0, 0.13);
|
||||
outline: 2px solid var(--primary-color, #007bff);
|
||||
outline-offset: 2px;
|
||||
}
|
||||
|
||||
.product-card .product-image {
|
||||
height: 150px;
|
||||
height: 120px;
|
||||
width: 100%;
|
||||
object-fit: cover;
|
||||
border-radius: 8px 8px 0 0;
|
||||
background: #f3f3f3;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.product-img-cover {
|
||||
max-height: 160px;
|
||||
max-height: 120px;
|
||||
width: 100%;
|
||||
object-fit: cover;
|
||||
border-radius: 8px;
|
||||
box-shadow: 0 2px 8px rgba(40, 39, 39, 0.9);
|
||||
border-radius: 8px 8px 0 0;
|
||||
box-shadow: 0 2px 8px rgba(40, 39, 39, 0.09);
|
||||
background: #f3f3f3;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.product-card .card-body {
|
||||
|
|
@ -44,105 +50,168 @@
|
|||
flex-direction: column;
|
||||
height: 100%;
|
||||
flex-grow: 1;
|
||||
padding: 0.75rem;
|
||||
padding: 0.6rem 0.7rem 0.7rem 0.7rem;
|
||||
position: relative;
|
||||
background: linear-gradient(135deg, rgba(0, 123, 255, 0.12) 0%, rgba(0, 123, 255, 0.08) 100%);
|
||||
transition: all 0.3s ease;
|
||||
background: linear-gradient(135deg, rgba(0, 123, 255, 0.07) 0%, rgba(0, 123, 255, 0.04) 100%);
|
||||
transition: background 0.3s;
|
||||
}
|
||||
|
||||
.product-card:hover .card-body {
|
||||
.product-card:hover .card-body,
|
||||
.product-card:focus-within .card-body {
|
||||
background: linear-gradient(
|
||||
135deg,
|
||||
rgba(108, 117, 125, 0.1) 0%,
|
||||
rgba(108, 117, 125, 0.08) 100%
|
||||
rgba(108, 117, 125, 0.13) 0%,
|
||||
rgba(108, 117, 125, 0.09) 100%
|
||||
);
|
||||
}
|
||||
|
||||
.product-card .card-title {
|
||||
flex-grow: 1;
|
||||
margin: 0;
|
||||
margin-bottom: 0.2rem;
|
||||
margin: 0 0 0.15rem 0;
|
||||
min-height: auto;
|
||||
display: block;
|
||||
word-wrap: break-word;
|
||||
overflow-wrap: break-word;
|
||||
font-size: 1.2rem !important;
|
||||
line-height: 1;
|
||||
font-size: 1.08rem !important;
|
||||
line-height: 1.1;
|
||||
text-align: center;
|
||||
font-weight: 600;
|
||||
color: #2d3748;
|
||||
color: #1a202c;
|
||||
letter-spacing: 0.01em;
|
||||
}
|
||||
|
||||
.product-card .card-text {
|
||||
margin-bottom: 0.15rem;
|
||||
margin-bottom: 0.12rem;
|
||||
text-align: center;
|
||||
font-size: 1rem;
|
||||
}
|
||||
|
||||
.product-card .card-text strong {
|
||||
display: block;
|
||||
margin-bottom: 0.15rem;
|
||||
font-size: 1.2rem;
|
||||
color: #667eea;
|
||||
margin-bottom: 0.1rem;
|
||||
font-size: 1.15rem;
|
||||
color: #3b82f6;
|
||||
}
|
||||
|
||||
.product-card .product-supplier {
|
||||
text-align: center;
|
||||
color: #4a5568;
|
||||
font-weight: 400;
|
||||
margin-bottom: 0.15rem;
|
||||
font-size: 0.9rem !important;
|
||||
margin-bottom: 0.12rem;
|
||||
font-size: 0.92rem !important;
|
||||
}
|
||||
|
||||
.product-tags {
|
||||
text-align: center;
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 0.2rem;
|
||||
gap: 0.18rem;
|
||||
justify-content: center;
|
||||
font-weight: 400;
|
||||
font-size: 1.4rem !important;
|
||||
font-size: 1.1rem !important;
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
.badge-km {
|
||||
background-color: var(--primary-color) !important;
|
||||
color: white !important;
|
||||
background-color: var(--primary-color, #007bff) !important;
|
||||
color: #fff !important;
|
||||
font-weight: 600 !important;
|
||||
padding: 0.2rem !important;
|
||||
font-size: 0.6rem !important;
|
||||
border-radius: 0.2rem;
|
||||
padding: 0.18rem 0.32rem !important;
|
||||
font-size: 0.68rem !important;
|
||||
border-radius: 0.22rem;
|
||||
display: inline-block;
|
||||
border: 1px solid;
|
||||
border: 1px solid #007bff;
|
||||
white-space: nowrap;
|
||||
margin-right: 0.1rem;
|
||||
margin-bottom: 0.1rem;
|
||||
margin-right: 0.08rem;
|
||||
margin-bottom: 0.08rem;
|
||||
}
|
||||
|
||||
.card-body p.card-text {
|
||||
text-align: center;
|
||||
margin-bottom: 0.8rem;
|
||||
min-height: 2rem;
|
||||
margin-bottom: 0.6rem;
|
||||
min-height: 1.7rem;
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
background-color: var(--primary-color);
|
||||
color: white;
|
||||
background-color: var(--primary-color, #007bff);
|
||||
color: #fff;
|
||||
border-radius: 0.18rem;
|
||||
font-size: 1.05rem;
|
||||
}
|
||||
|
||||
.card-body p.card-text strong {
|
||||
display: inline;
|
||||
font-size: 1.4rem !important;
|
||||
color: var(--primary-color);
|
||||
font-size: 1.18rem !important;
|
||||
color: var(--primary-color, #007bff);
|
||||
margin-bottom: 0;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.product-img-fixed {
|
||||
object-fit: cover;
|
||||
height: 100px;
|
||||
height: 120px;
|
||||
width: 100%;
|
||||
border-radius: 8px 8px 0 0;
|
||||
background: #f3f3f3;
|
||||
display: block;
|
||||
}
|
||||
|
||||
.product-img-placeholder {
|
||||
height: 100px;
|
||||
height: 120px;
|
||||
width: 100%;
|
||||
object-fit: cover;
|
||||
border-radius: 8px 8px 0 0;
|
||||
background: #f3f3f3
|
||||
url('data:image/svg+xml;utf8,<svg width="120" height="120" xmlns="http://www.w3.org/2000/svg"><rect width="100%25" height="100%25" fill="%23f3f3f3"/><text x="50%25" y="50%25" dominant-baseline="middle" text-anchor="middle" fill="%23cccccc" font-size="16">Sin imagen</text></svg>')
|
||||
no-repeat center center;
|
||||
display: block;
|
||||
}
|
||||
|
||||
/* Responsive: mejorar altura y espaciado en móvil */
|
||||
@media (max-width: 600px) {
|
||||
.product-card {
|
||||
padding: 0.25rem;
|
||||
border-radius: 8px;
|
||||
}
|
||||
.product-card .product-image,
|
||||
.product-img-cover,
|
||||
.product-img-fixed,
|
||||
.product-img-placeholder {
|
||||
height: 70px;
|
||||
max-height: 70px;
|
||||
min-height: 70px;
|
||||
border-radius: 6px 6px 0 0;
|
||||
}
|
||||
.product-card .card-body {
|
||||
padding: 0.4rem 0.4rem 0.5rem 0.4rem;
|
||||
}
|
||||
.product-card .card-title {
|
||||
font-size: 0.98rem !important;
|
||||
margin-bottom: 0.08rem;
|
||||
}
|
||||
.product-card .card-text {
|
||||
font-size: 0.92rem;
|
||||
}
|
||||
.badge-km {
|
||||
font-size: 0.58rem !important;
|
||||
padding: 0.13rem 0.22rem !important;
|
||||
}
|
||||
.product-tags {
|
||||
font-size: 0.95rem !important;
|
||||
}
|
||||
.card-body p.card-text {
|
||||
min-height: 1.1rem;
|
||||
font-size: 0.95rem;
|
||||
margin-bottom: 0.3rem;
|
||||
}
|
||||
.product-card .product-supplier {
|
||||
font-size: 0.82rem !important;
|
||||
}
|
||||
}
|
||||
|
||||
/* Accesibilidad: focus visible */
|
||||
.product-card:focus-visible {
|
||||
outline: 2.5px solid var(--primary-color, #007bff);
|
||||
outline-offset: 2px;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue