feat(back-end): shop ui implementation
This commit is contained in:
@@ -1,72 +1,339 @@
|
||||
.wip-section {
|
||||
.shop-page {
|
||||
--shop-hero-bg: #f8f3e5;
|
||||
background:
|
||||
radial-gradient(circle at top right, rgba(250, 207, 10, 0.24), transparent 22%),
|
||||
linear-gradient(180deg, #faf7ef 0%, #f6f2e8 24%, var(--color-bg) 24%);
|
||||
}
|
||||
|
||||
.shop-hero {
|
||||
position: relative;
|
||||
padding: var(--space-12) 0;
|
||||
background-color: var(--color-bg);
|
||||
overflow: hidden;
|
||||
padding: 4.75rem 0 3.5rem;
|
||||
background: transparent;
|
||||
}
|
||||
|
||||
.wip-card {
|
||||
max-width: 760px;
|
||||
margin: 0 auto;
|
||||
padding: clamp(1.4rem, 3vw, 2.4rem);
|
||||
border: 1px solid var(--color-border);
|
||||
border-radius: var(--radius-xl);
|
||||
background: rgba(255, 255, 255, 0.95);
|
||||
box-shadow: var(--shadow-lg);
|
||||
text-align: center;
|
||||
.shop-hero-grid {
|
||||
display: grid;
|
||||
gap: var(--space-8);
|
||||
align-items: end;
|
||||
grid-template-columns: minmax(0, 1.4fr) minmax(280px, 0.8fr);
|
||||
}
|
||||
|
||||
.wip-eyebrow {
|
||||
display: inline-block;
|
||||
margin-bottom: var(--space-3);
|
||||
padding: 0.3rem 0.7rem;
|
||||
border-radius: 999px;
|
||||
border: 1px solid rgba(16, 24, 32, 0.14);
|
||||
font-size: 0.78rem;
|
||||
letter-spacing: 0.12em;
|
||||
.hero-copy {
|
||||
display: grid;
|
||||
gap: var(--space-4);
|
||||
}
|
||||
|
||||
.hero-highlights {
|
||||
display: grid;
|
||||
gap: var(--space-4);
|
||||
}
|
||||
|
||||
.highlight-card {
|
||||
display: grid;
|
||||
gap: 0.2rem;
|
||||
padding: 1.15rem 1.2rem;
|
||||
border-radius: 1rem;
|
||||
border: 1px solid rgba(16, 24, 32, 0.08);
|
||||
background: rgba(255, 255, 255, 0.78);
|
||||
box-shadow: 0 12px 28px rgba(16, 24, 32, 0.08);
|
||||
backdrop-filter: blur(8px);
|
||||
}
|
||||
|
||||
.highlight-card strong {
|
||||
font-size: 1.35rem;
|
||||
line-height: 1.1;
|
||||
}
|
||||
|
||||
.highlight-label {
|
||||
color: var(--color-text-muted);
|
||||
text-transform: uppercase;
|
||||
letter-spacing: 0.08em;
|
||||
font-size: 0.72rem;
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.shop-layout {
|
||||
display: grid;
|
||||
gap: var(--space-8);
|
||||
align-items: start;
|
||||
grid-template-columns: minmax(270px, 320px) minmax(0, 1fr);
|
||||
padding-bottom: var(--space-12);
|
||||
}
|
||||
|
||||
.shop-sidebar {
|
||||
position: sticky;
|
||||
top: var(--space-6);
|
||||
display: grid;
|
||||
gap: var(--space-5);
|
||||
}
|
||||
|
||||
.panel-head {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
gap: var(--space-4);
|
||||
margin-bottom: var(--space-4);
|
||||
}
|
||||
|
||||
.panel-kicker {
|
||||
margin: 0 0 var(--space-1);
|
||||
font-size: 0.72rem;
|
||||
letter-spacing: 0.1em;
|
||||
text-transform: uppercase;
|
||||
color: var(--color-secondary-600);
|
||||
background: rgba(250, 207, 10, 0.28);
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
h1 {
|
||||
font-size: clamp(1.7rem, 4vw, 2.5rem);
|
||||
margin-bottom: var(--space-4);
|
||||
.panel-title {
|
||||
margin: 0;
|
||||
font-size: 1.1rem;
|
||||
}
|
||||
|
||||
.category-list {
|
||||
display: grid;
|
||||
gap: 0.4rem;
|
||||
}
|
||||
|
||||
.category-link {
|
||||
--depth: 0;
|
||||
display: flex;
|
||||
width: 100%;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
gap: var(--space-3);
|
||||
padding: 0.8rem 0.95rem 0.8rem calc(0.95rem + (var(--depth) * 0.95rem));
|
||||
border: 1px solid transparent;
|
||||
border-radius: 0.9rem;
|
||||
background: transparent;
|
||||
color: var(--color-text);
|
||||
text-align: left;
|
||||
cursor: pointer;
|
||||
transition:
|
||||
background-color 0.18s ease,
|
||||
border-color 0.18s ease,
|
||||
transform 0.18s ease;
|
||||
}
|
||||
|
||||
.wip-subtitle {
|
||||
max-width: 60ch;
|
||||
margin: 0 auto var(--space-8);
|
||||
.category-link:hover,
|
||||
.category-link.active {
|
||||
background: rgba(250, 207, 10, 0.14);
|
||||
border-color: rgba(250, 207, 10, 0.34);
|
||||
transform: translateX(1px);
|
||||
}
|
||||
|
||||
.category-link small {
|
||||
color: var(--color-text-muted);
|
||||
}
|
||||
|
||||
.wip-actions {
|
||||
display: flex;
|
||||
.cart-card {
|
||||
display: block;
|
||||
}
|
||||
|
||||
.panel-empty,
|
||||
.catalog-state {
|
||||
margin: 0;
|
||||
padding: 1rem;
|
||||
border-radius: 0.9rem;
|
||||
background: rgba(16, 24, 32, 0.04);
|
||||
color: var(--color-text-muted);
|
||||
}
|
||||
|
||||
.catalog-state-error {
|
||||
background: rgba(239, 68, 68, 0.08);
|
||||
color: var(--color-danger-600);
|
||||
}
|
||||
|
||||
.text-action,
|
||||
.line-remove {
|
||||
padding: 0;
|
||||
border: 0;
|
||||
background: transparent;
|
||||
color: var(--color-text-muted);
|
||||
font: inherit;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.cart-lines {
|
||||
display: grid;
|
||||
gap: var(--space-4);
|
||||
justify-content: center;
|
||||
flex-wrap: wrap;
|
||||
margin-bottom: var(--space-5);
|
||||
}
|
||||
|
||||
.wip-note {
|
||||
margin: var(--space-4) auto 0;
|
||||
max-width: 62ch;
|
||||
font-size: 0.95rem;
|
||||
color: var(--color-secondary-600);
|
||||
.cart-line {
|
||||
display: grid;
|
||||
gap: var(--space-3);
|
||||
padding-bottom: var(--space-4);
|
||||
border-bottom: 1px solid var(--color-border);
|
||||
}
|
||||
|
||||
.wip-return-later {
|
||||
margin: var(--space-6) 0 0;
|
||||
.cart-line:last-child {
|
||||
padding-bottom: 0;
|
||||
border-bottom: 0;
|
||||
}
|
||||
|
||||
.cart-line-copy {
|
||||
display: grid;
|
||||
gap: 0.25rem;
|
||||
}
|
||||
|
||||
.cart-line-copy strong {
|
||||
font-size: 0.96rem;
|
||||
}
|
||||
|
||||
.cart-line-meta,
|
||||
.cart-line-color {
|
||||
color: var(--color-text-muted);
|
||||
font-size: 0.86rem;
|
||||
}
|
||||
|
||||
.cart-line-color {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: 0.4rem;
|
||||
}
|
||||
|
||||
.color-dot {
|
||||
width: 0.8rem;
|
||||
height: 0.8rem;
|
||||
border-radius: 50%;
|
||||
border: 1px solid rgba(16, 24, 32, 0.12);
|
||||
}
|
||||
|
||||
.cart-line-controls {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
gap: var(--space-4);
|
||||
}
|
||||
|
||||
.qty-control {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: 0.4rem;
|
||||
padding: 0.2rem;
|
||||
border-radius: 999px;
|
||||
border: 1px solid var(--color-border);
|
||||
background: rgba(255, 255, 255, 0.68);
|
||||
}
|
||||
|
||||
.qty-control button {
|
||||
width: 1.9rem;
|
||||
height: 1.9rem;
|
||||
border: 0;
|
||||
border-radius: 50%;
|
||||
background: rgba(16, 24, 32, 0.06);
|
||||
color: var(--color-text);
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.qty-control span {
|
||||
min-width: 1.4rem;
|
||||
text-align: center;
|
||||
font-weight: 600;
|
||||
color: var(--color-secondary-600);
|
||||
}
|
||||
|
||||
@media (max-width: 640px) {
|
||||
.wip-section {
|
||||
padding: var(--space-10) 0;
|
||||
.line-total {
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.cart-totals {
|
||||
display: grid;
|
||||
gap: 0.55rem;
|
||||
margin-bottom: var(--space-5);
|
||||
padding-top: var(--space-4);
|
||||
border-top: 1px solid var(--color-border);
|
||||
}
|
||||
|
||||
.cart-total-row {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
justify-content: space-between;
|
||||
gap: var(--space-3);
|
||||
color: var(--color-text-muted);
|
||||
}
|
||||
|
||||
.cart-total-row-final {
|
||||
color: var(--color-text);
|
||||
font-size: 1.02rem;
|
||||
}
|
||||
|
||||
.catalog-content {
|
||||
display: grid;
|
||||
gap: var(--space-6);
|
||||
}
|
||||
|
||||
.featured-strip,
|
||||
.catalog-panel {
|
||||
display: grid;
|
||||
gap: var(--space-5);
|
||||
}
|
||||
|
||||
.section-title {
|
||||
margin: 0;
|
||||
font-size: clamp(1.5rem, 1vw + 1.2rem, 2rem);
|
||||
}
|
||||
|
||||
.catalog-head {
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: end;
|
||||
gap: var(--space-4);
|
||||
}
|
||||
|
||||
.catalog-counter {
|
||||
color: var(--color-text-muted);
|
||||
font-size: 0.9rem;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.featured-grid,
|
||||
.product-grid {
|
||||
display: grid;
|
||||
gap: var(--space-5);
|
||||
grid-template-columns: repeat(2, minmax(0, 1fr));
|
||||
}
|
||||
|
||||
.skeleton-card {
|
||||
min-height: 400px;
|
||||
border-radius: 1.1rem;
|
||||
background:
|
||||
linear-gradient(
|
||||
110deg,
|
||||
rgba(255, 255, 255, 0.7) 8%,
|
||||
rgba(238, 235, 226, 0.95) 18%,
|
||||
rgba(255, 255, 255, 0.7) 33%
|
||||
);
|
||||
background-size: 220% 100%;
|
||||
animation: skeleton 1.35s linear infinite;
|
||||
}
|
||||
|
||||
@keyframes skeleton {
|
||||
to {
|
||||
background-position-x: -220%;
|
||||
}
|
||||
}
|
||||
|
||||
@media (max-width: 1080px) {
|
||||
.shop-hero-grid,
|
||||
.shop-layout {
|
||||
grid-template-columns: 1fr;
|
||||
}
|
||||
|
||||
.wip-actions {
|
||||
.shop-sidebar {
|
||||
position: static;
|
||||
}
|
||||
}
|
||||
|
||||
@media (max-width: 760px) {
|
||||
.featured-grid,
|
||||
.product-grid {
|
||||
grid-template-columns: 1fr;
|
||||
}
|
||||
|
||||
.catalog-head,
|
||||
.cart-line-controls,
|
||||
.panel-head {
|
||||
align-items: start;
|
||||
flex-direction: column;
|
||||
align-items: stretch;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user