:root {
  --bg: #0e0a06;
  --surface: #0f172a;
  --surface-2: #111827;
  --text: #e5e7eb;
  --muted: #94a3b8;
  --primary: #f59e0b;
  --primary-2: #f97316;
  --success: #22c55e;
  --danger: #ef4444;
  --ring: color-mix(in oklab, var(--primary) 30%, white 0%);
  --container: 1160px;
}

* { box-sizing: border-box; }
html, body { height: 100%; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji", "Segoe UI Emoji";
  color: var(--text);
  background: radial-gradient(1200px 800px at 15% 10%, rgba(249,115,22,0.10), transparent 60%),
              radial-gradient(1000px 700px at 85% 0%, rgba(245,158,11,0.08), transparent 60%),
              radial-gradient(1400px 900px at 50% 120%, rgba(234,88,12,0.06), transparent 60%),
              var(--bg);
  line-height: 1.6;
}

/* Logo wordmark */
.logo-text { font-family: Comfortaa, Inter, system-ui, sans-serif; font-weight: 700; letter-spacing: .5px; font-size: 28px; line-height: 1; display: inline-block; padding: 6px 10px; border-radius: 12px; position: relative; color: #e5e7eb; background: linear-gradient(90deg, rgba(124,58,237,.2), rgba(34,211,238,.2)); border: 1px solid rgba(148,163,184,0.18); text-transform: lowercase; }
.logo-text::after { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 45%, rgba(255,255,255,.25) 50%, transparent 55%); transform: translateX(-120%); }
.logo-text:hover::after { animation: shine 1.2s ease; }
.logo-text.sm { font-size: 22px; padding: 4px 8px; border-radius: 10px; }
@keyframes shine { to { transform: translateX(120%); } }

img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }

.container { width: min(100% - 2rem, var(--container)); margin-inline: auto; }
.max-640 { max-width: 640px; margin-inline: auto; }
.center { text-align: center; }

.section { padding: 96px 0; position: relative; }
.display { font-size: clamp(28px, 5vw, 52px); line-height: 1.1; margin: 0 0 16px; letter-spacing: -0.02em; }
.lead { font-size: clamp(16px, 2.5vw, 18px); color: var(--muted); margin: 0 0 24px; }
.muted { color: var(--muted); }

.btn { display: inline-flex; align-items: center; justify-content: center; gap: 10px; padding: 12px 18px; border-radius: 12px; border: 1px solid transparent; background: var(--surface); color: var(--text); transition: transform .15s ease, background .2s ease, border-color .2s ease; cursor: pointer; }
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-primary { background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: #06131a; font-weight: 700; }
.btn-ghost { background: transparent; border-color: rgba(148,163,184,.3); color: var(--text); }
.btn-sm { padding: 8px 12px; border-radius: 10px; }
.btn-block { width: 100%; }

.grid-2 { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 40px; align-items: center; }
@media (max-width: 960px) { .grid-2 { grid-template-columns: 1fr; } }

/* Header */
.site-header { position: sticky; top: 0; z-index: 50; backdrop-filter: saturate(140%) blur(10px); background: linear-gradient(to bottom, rgba(2,6,23,0.85), rgba(2,6,23,0.65)); border-bottom: 1px solid rgba(148,163,184,0.12); }
.header-inner { display: flex; height: 64px; align-items: center; justify-content: space-between; }
.brand img { filter: drop-shadow(0 1px 0 rgba(255,255,255,0.06)); }

.nav-list { display: flex; gap: 18px; align-items: center; list-style: none; padding: 0; margin: 0; }
.nav-list a { padding: 10px 12px; border-radius: 10px; color: var(--muted); }
.nav-list a:hover { color: var(--text); background: rgba(148,163,184,0.08); }

/* Language switcher */
.lang-switch { position: relative; }
.lang-current { display: inline-flex; align-items: center; gap: 8px; background: transparent; color: var(--text); border: 1px solid rgba(148,163,184,0.18); padding: 8px 10px; border-radius: 10px; cursor: pointer; }
.lang-current .dot { width: 8px; height: 8px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), var(--primary-2)); box-shadow: 0 0 8px rgba(249,115,22,0.6); }
.lang-current .flag { width: 18px; height: 12px; border-radius: 2px; background-size: cover; background-position: center; display: inline-block; box-shadow: 0 0 0 1px rgba(0,0,0,0.25); }
.lang-current .code { font-weight: 700; font-size: 12px; letter-spacing: .06em; color: var(--muted); }
.lang-menu { position: absolute; right: 0; top: calc(100% + 8px); min-width: 120px; background: var(--surface); border: 1px solid rgba(148,163,184,0.14); border-radius: 12px; padding: 6px; list-style: none; margin: 0; display: grid; gap: 4px; opacity: 0; transform: translateY(-6px); pointer-events: none; transition: .18s ease; z-index: 55; }
.lang-menu button { width: 100%; text-align: left; background: transparent; color: var(--text); border: 0; padding: 8px 10px; border-radius: 8px; cursor: pointer; display: flex; align-items: center; gap: 8px; }
.lang-menu .flag { width: 18px; height: 12px; border-radius: 2px; background-size: cover; background-position: center; display: inline-block; box-shadow: 0 0 0 1px rgba(0,0,0,0.25); }

/* Flags by data-code */
.flag[data-code="UZ"] { background-image: url('../assets/flags/uz.svg'); }
.flag[data-code="RU"] { background-image: url('../assets/flags/ru.svg'); }
.flag[data-code="EN"] { background-image: url('../assets/flags/gb.svg'); }
.lang-menu button:hover { background: rgba(148,163,184,0.08); }
.lang-switch.open .lang-menu { opacity: 1; transform: translateY(0); pointer-events: auto; }

.nav-toggle { display: none; flex-direction: column; gap: 6px; background: transparent; border: 0; padding: 8px; border-radius: 8px; }
.nav-toggle span { width: 24px; height: 2px; background: #cbd5e1; display: block; transition: transform .2s ease, opacity .2s ease; }

@media (max-width: 860px) {
  .nav-toggle { display: inline-flex; }
  .nav-list { position: fixed; inset: 64px 12px auto 12px; background: var(--surface); border: 1px solid rgba(148,163,184,0.14); border-radius: 14px; padding: 14px; gap: 8px; transform: translateY(-16px); opacity: 0; pointer-events: none; transition: .2s ease; flex-direction: column; align-items: stretch; }
  .nav.open #nav-list { transform: translateY(0); opacity: 1; pointer-events: auto; }
  .lang-switch { align-self: stretch; }
  .lang-menu { position: static; transform: none; opacity: 1; pointer-events: auto; box-shadow: none; }
}

/* Hero */
.hero { padding-top: 72px; }
.hero .cta { display: flex; gap: 12px; margin: 8px 0 16px; flex-wrap: wrap; }
.trust { list-style: none; padding: 0; margin: 8px 0 0; color: var(--muted); display: grid; gap: 8px; }
.check { display: inline-block; width: 18px; height: 18px; border-radius: 999px; background: radial-gradient(circle at 30% 30%, #10b981 0 35%, transparent 35% 100%), conic-gradient(from 220deg, transparent 0 70deg, #10b981 70deg 110deg, transparent 110deg 100%); box-shadow: 0 0 0 2px rgba(16,185,129,.15) inset; margin-right: 6px; vertical-align: -4px; }

.hero-art { position: relative; min-height: 360px; }
.orb { position: absolute; border-radius: 999px; filter: blur(20px) saturate(120%); opacity: 0.7; mix-blend-mode: screen; animation: float 8s ease-in-out infinite; }
.orb-1 { width: 220px; height: 220px; right: -20px; top: -10px; background: radial-gradient(circle at 40% 40%, #f59e0b, #c2410c 60%); animation-delay: .2s; }
.orb-2 { width: 300px; height: 300px; left: -30px; bottom: -20px; background: radial-gradient(circle at 60% 40%, #f97316, #7c2d12 60%); animation-delay: .6s; }

.device { position: relative; z-index: 1; display: grid; place-items: center; }
.card { background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(148,163,184,0.18); border-radius: 16px; padding: 20px; box-shadow: 0 30px 60px rgba(0,0,0,0.25); }
.card.float { animation: breathe 6s ease-in-out infinite; }
.card h3 { margin: 0 0 8px; }
.card .muted { margin: 0 0 14px; }
.stats { display: grid; grid-template-columns: repeat(2, minmax(120px, 1fr)); gap: 14px; }
.stats .num { font-size: 34px; font-weight: 800; background: linear-gradient(180deg, #fff, #9ca3af); -webkit-background-clip: text; background-clip: text; color: transparent; }
.stats .unit { margin-left: 4px; color: #fdba74; font-weight: 700; }
.stats p { margin: 6px 0 0; color: var(--muted); font-size: 13px; }

/* About */
.feature-list { display: grid; gap: 16px; }
.feature { display: grid; grid-template-columns: 40px 1fr; gap: 14px; align-items: start; background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); border: 1px solid rgba(148,163,184,0.16); padding: 14px; border-radius: 14px; }
.icon { width: 40px; height: 40px; border-radius: 12px; background: linear-gradient(135deg, rgba(249,115,22,.2), rgba(245,158,11,.2)); border: 1px solid rgba(148,163,184,0.18); position: relative; }
.icon.drop::after { content: ""; position: absolute; inset: 9px; background: radial-gradient(circle at 50% 30%, #f59e0b 0 45%, transparent 45% 100%), radial-gradient(7px 9px at 50% 60%, #f97316 0 100%); border-radius: 50% 50% 50% 50% / 60% 60% 40% 40%; }
.icon.shield::after { content: ""; position: absolute; inset: 8px 10px 10px; background: conic-gradient(from 180deg, #ea580c, #f59e0b); clip-path: polygon(50% 0, 100% 30%, 82% 100%, 18% 100%, 0 30%); }
.icon.leaf::after { content: ""; position: absolute; inset: 8px; background: radial-gradient(circle at 30% 30%, #22c55e, #16a34a); clip-path: ellipse(60% 40% at 50% 50%); transform: rotate(-20deg); }

/* How */
.steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 24px; }
.step { background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); border: 1px solid rgba(148,163,184,0.16); padding: 16px; border-radius: 14px; }
.step-num { display: inline-grid; place-items: center; width: 32px; height: 32px; border-radius: 10px; background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: #06131a; font-weight: 800; margin-bottom: 10px; }
/* Big bottom-right icons */
.step { position: relative; overflow: hidden; }
.step .step-ico {
  display: block; margin: 20px auto 0; width: 120px; height: 120px; object-fit: cover;
  border-radius: 16px; box-shadow: 0 6px 20px rgba(0,0,0,.3);
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.step:hover .step-ico {
  transform: translateY(-6px) scale(1.08);
  box-shadow: 0 12px 30px rgba(0,0,0,.4);
  transition: transform .2s ease, box-shadow .2s ease;
}
@media (max-width: 960px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .steps { grid-template-columns: 1fr; } }

/* Uses */
.cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-top: 16px; }
.cards .card { min-height: 150px; }
.cards .card .card-head { display: flex; align-items: center; gap: 16px; margin-bottom: 12px; }
.cards .card .card-head h3 { margin: 0; }
.cards .card .card-head i {
  width: 60px; height: 60px; border-radius: 16px; display: flex; align-items: center; justify-content: center;
  font-size: 28px; color: white; flex: 0 0 60px; box-shadow: 0 8px 24px rgba(0,0,0,0.3);
  transition: transform .2s ease, box-shadow .2s ease;
}
.cards .card:hover .card-head i {
  transform: translateY(-2px) scale(1.05);
  box-shadow: 0 12px 32px rgba(0,0,0,0.4);
}
.cards .card .i { width: 40px; height: 40px; border-radius: 12px; display: inline-block; position: relative; flex: 0 0 40px; box-shadow: 0 0 0 1px rgba(148,163,184,0.35), 0 6px 18px rgba(0,0,0,0.35); }
.cards .card .i::before { content: ""; position: absolute; inset: -6px; background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.18), transparent 60%); border-radius: 14px; filter: blur(2px); }

/* Font Awesome Icons Colors */
.cards .card .card-head i.fa-apple-whole {
  background: linear-gradient(135deg, #10b981, #059669);
  box-shadow: 0 8px 24px rgba(16, 185, 129, 0.4);
}
.cards .card .card-head i.fa-bread-slice {
  background: linear-gradient(135deg, #f59e0b, #d97706);
  box-shadow: 0 8px 24px rgba(245, 158, 11, 0.4);
}
.cards .card .card-head i.fa-pepper-hot {
  background: linear-gradient(135deg, #dc2626, #b91c1c);
  box-shadow: 0 8px 24px rgba(220, 38, 38, 0.4);
}
.cards .card .card-head i.fa-mug-hot {
  background: linear-gradient(135deg, #1d4ed8, #1e40af);
  box-shadow: 0 8px 24px rgba(29, 78, 216, 0.4);
}
.cards .card .card-head i.fa-drumstick-bite {
  background: linear-gradient(135deg, #db2777, #be185d);
  box-shadow: 0 8px 24px rgba(219, 39, 119, 0.4);
}

/* Hover effects for colored icons */
.cards .card:hover .card-head i.fa-apple-whole {
  box-shadow: 0 12px 32px rgba(16, 185, 129, 0.6);
}
.cards .card:hover .card-head i.fa-bread-slice {
  box-shadow: 0 12px 32px rgba(245, 158, 11, 0.6);
}
.cards .card:hover .card-head i.fa-pepper-hot {
  box-shadow: 0 12px 32px rgba(220, 38, 38, 0.6);
}
.cards .card:hover .card-head i.fa-mug-hot {
  box-shadow: 0 12px 32px rgba(29, 78, 216, 0.6);
}
.cards .card:hover .card-head i.fa-drumstick-bite {
  box-shadow: 0 12px 32px rgba(219, 39, 119, 0.6);
}

/* Dry fruits/veggies */
.i-dry { background: radial-gradient(circle at 30% 30%, #6ee7b7, #059669 60%); }
.i-dry::after { content: ""; position: absolute; inset: 9px; background:
  radial-gradient(circle at 55% 45%, #a7f3d0 0 30%, transparent 31% 100%),
  radial-gradient(circle at 42% 60%, #065f46 0 26%, transparent 27% 100%),
  radial-gradient(circle at 62% 68%, #10b981 0 22%, transparent 23% 100%);
  border-radius: 50%; }

/* Bakery */
.i-bread { background: radial-gradient(circle at 35% 35%, #fde68a, #f59e0b 60%); }
.i-bread::after { content: ""; position: absolute; inset: 9px 11px; background:
  radial-gradient(8px 10px at 50% 30%, #fff 0 99%, transparent 100%),
  linear-gradient(#78350f, #78350f);
  clip-path: polygon(50% 0, 92% 24%, 92% 62%, 8% 62%, 8% 24%);
  border-radius: 6px 6px 10px 10px; }

/* Spices */
.i-spice { background: radial-gradient(circle at 30% 30%, #fda4af, #dc2626 60%); }
.i-spice::after { content: ""; position: absolute; inset: 9px; background:
  radial-gradient(circle at 50% 30%, #7f1d1d 0 34%, transparent 35% 100%),
  radial-gradient(circle at 60% 65%, #fecaca 0 18%, transparent 19% 100%),
  radial-gradient(circle at 40% 60%, #fecaca 0 16%, transparent 17% 100%);
  filter: drop-shadow(0 1px 0 rgba(0,0,0,.2)); border-radius: 50%; }

/* Tea/Coffee */
.i-tea { background: radial-gradient(circle at 30% 30%, #93c5fd, #1d4ed8 60%); }
.i-tea::after { content: ""; position: absolute; inset: 9px; background:
  radial-gradient(circle at 50% 70%, #0c4a6e 0 40%, transparent 41% 100%),
  linear-gradient(#93c5fd, #93c5fd);
  clip-path: polygon(15% 70%, 85% 70%, 78% 30%, 22% 30%);
  border-radius: 4px; }

/* Meat/Fish */
.i-meat { background: radial-gradient(circle at 30% 30%, #f9a8d4, #db2777 60%); }
.i-meat::after { content: ""; position: absolute; inset: 9px; background:
  radial-gradient(12px 10px at 50% 45%, #fff 0 99%, transparent 100%),
  radial-gradient(circle at 60% 60%, #7f1d4f 0 26%, transparent 27% 100%);
  clip-path: ellipse(50% 40% at 50% 50%); }
@media (max-width: 1024px) { .cards { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .cards { grid-template-columns: 1fr; } }

/* Why */
.why .panel { background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border: 1px solid rgba(148,163,184,0.18); border-radius: 16px; padding: 18px; }
.benefits { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.benefits li { color: var(--muted); }

/* Composition */
.faq { display: grid; gap: 12px; margin-top: 14px; }
.faq details { background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); border: 1px solid rgba(148,163,184,0.16); border-radius: 14px; padding: 12px 14px; }
.faq summary { cursor: pointer; font-weight: 600; }
.faq .answer { color: var(--muted); margin-top: 8px; }

/* Contact */
.form { background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); border: 1px solid rgba(148,163,184,0.16); padding: 16px; border-radius: 16px; }
.field { display: grid; gap: 6px; margin-bottom: 12px; }
label { font-weight: 600; }
input, textarea { width: 100%; background: var(--surface-2); border: 1px solid rgba(148,163,184,0.18); border-radius: 12px; padding: 12px 14px; color: var(--text); outline: none; transition: border-color .2s ease, box-shadow .2s ease; }
input:focus, textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(249,115,22,0.15); }
.error { display: none; color: #fecaca; font-size: 12px; }
.field.invalid .error { display: block; }

.contact-list { list-style: none; padding: 0; margin: 10px 0 0; display: grid; gap: 8px; }
.contact-list li { display: flex; align-items: center; gap: 10px; }
.contact-list i { font-size: 16px; color: var(--primary); width: 20px; text-align: center; }
.contact-list a { color: #fdba74; text-decoration: none; }
.contact-list a:hover { color: var(--primary); }

.social-links { margin-top: 24px; }
.social-links h3 { font-size: 18px; margin: 0 0 12px; color: var(--text); }
.social-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 8px; }
.social-list li { display: flex; align-items: center; }
.social-list a { display: flex; align-items: center; gap: 10px; color: #fdba74; text-decoration: none; padding: 8px 12px; border-radius: 8px; transition: all 0.2s ease; }
.social-list a:hover { color: var(--primary); background: rgba(249, 115, 22, 0.1); }
.social-list i { font-size: 16px; color: var(--primary); width: 20px; text-align: center; }

/* Footer */
.site-footer { padding: 28px 0; border-top: 1px solid rgba(148,163,184,0.12); background: rgba(2,6,23,0.6); backdrop-filter: blur(6px); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.to-top { display: inline-grid; place-items: center; width: 36px; height: 36px; border-radius: 10px; background: linear-gradient(135deg, var(--primary), var(--primary-2)); color: #06131a; font-weight: 800; }

/* Image Modal */
.image-modal-content { max-width: 90vw; max-height: 90vh; }
.image-modal-image { text-align: center; }
.image-modal-image img {
  max-width: 100%; max-height: 70vh; object-fit: contain;
  border-radius: 20px; box-shadow: 0 10px 40px rgba(0,0,0,.5);
}

/* Progress bar */
.progress { position: fixed; inset: 0 0 auto 0; height: 3px; z-index: 60; }
.progress span { display: block; height: 100%; width: 0%; background: linear-gradient(90deg, var(--primary), var(--primary-2)); box-shadow: 0 0 16px rgba(249,115,22,0.6); transform-origin: left; }

/* Decorative blobs */
.decor { position: fixed; z-index: -1; filter: blur(45px) saturate(140%); opacity: 0.5; }
.deco-1 { width: 360px; height: 360px; left: -120px; top: -120px; background: radial-gradient(circle at 60% 40%, #f59e0b, transparent 60%); }
.deco-2 { width: 420px; height: 420px; right: -160px; bottom: -160px; background: radial-gradient(circle at 40% 60%, #f97316, transparent 60%); }

/* Reveal */
.reveal { opacity: 0; transform: translateY(18px) scale(0.98); filter: saturate(80%); transition: transform .8s cubic-bezier(.2,.8,.2,1), opacity .6s ease, filter .8s ease; }
.reveal.show { opacity: 1; transform: none; filter: saturate(110%); }

/* Animations */
@keyframes float { 0%, 100% { transform: translateY(0) } 50% { transform: translateY(-16px) } }
@keyframes breathe { 0%, 100% { transform: translateY(0) scale(1) } 50% { transform: translateY(-6px) scale(1.01) } }

/* Utilities */
.hidden { display: none !important; }

.particles { position: absolute; inset: 0; pointer-events: none; overflow: hidden; }
.particles::before, .particles::after { content: ""; position: absolute; width: 200%; height: 2px; left: -50%; background: linear-gradient(90deg, transparent, rgba(249,115,22,0.5), transparent); filter: blur(1px); animation: sweep 6s linear infinite; }
.particles::after { top: 20%; animation-duration: 9s; opacity: .6; }
@keyframes sweep { 0% { transform: translateX(-10%) } 100% { transform: translateX(10%) } }

/* Products */
.products .chips { margin-top: 12px; display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.chip { background: rgba(148,163,184,0.12); border: 1px solid rgba(148,163,184,0.24); color: var(--text); padding: 8px 12px; border-radius: 999px; cursor: pointer; font-weight: 600; }
.chip.active, .chip:hover { background: rgba(249,115,22,0.18); border-color: rgba(249,115,22,0.38); }

.toolbar { margin-top: 14px; display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.toolbar .search input { width: min(72vw, 360px); background: var(--surface-2); color: var(--text); border: 1px solid rgba(148,163,184,0.18); border-radius: 12px; padding: 10px 12px; outline: none; }
.toolbar .search input:focus { border-color: var(--primary); box-shadow: 0 0 0 4px rgba(249,115,22,0.15); }
.toolbar .sort select { background: var(--surface-2); color: var(--text); border: 1px solid rgba(148,163,184,0.18); border-radius: 12px; padding: 10px 12px; }
.product-grid { margin-top: 18px; display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; align-items: stretch; }
@media (max-width: 1024px) { .product-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .product-grid { grid-template-columns: 1fr; } }
.p-card { position: relative; overflow: hidden; border-radius: 16px; border: 1px solid rgba(148,163,184,0.18); background: linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); transform-style: preserve-3d; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease; display: grid; grid-template-rows: auto auto 1fr; isolation: isolate; }
.p-card::before { content: ""; position: absolute; inset: -2px; background: linear-gradient(120deg, rgba(124,58,237,.5), rgba(34,211,238,.5)); filter: blur(14px); opacity: .15; z-index: -1; }
.p-card:hover { border-color: rgba(34,211,238,0.45); box-shadow: 0 25px 60px rgba(2,6,23,0.6); }
.p-card .p-top { display: flex; justify-content: space-between; align-items: center; padding: 10px 12px 0 12px; }
.badge { display: inline-block; font-size: 12px; padding: 4px 8px; border-radius: 999px; color: #06131a; background: rgba(34,211,238,0.9); }
.badge.hot { background: rgba(124,58,237,0.9); color: #e5e7eb; }
.badge.new { background: rgba(34,197,94,0.9); color: #e5e7eb; }
.fav { background: rgba(2,6,23,0.5); border: 1px solid rgba(148,163,184,0.3); color: #e5e7eb; border-radius: 50%; width: 32px; height: 32px; display: grid; place-items: center; cursor: pointer; }
.fav.active { color: #f43f5e; border-color: rgba(244,63,94,.6); }
.p-card img { width: 100%; aspect-ratio: 4/3; object-fit: contain; padding: 16px; background: radial-gradient(circle at 30% 30%, rgba(34,211,238,.12), transparent 60%); }
.p-card .p-body { padding: 14px; display: grid; gap: 8px; }
.p-card .tags { display: flex; flex-wrap: wrap; gap: 6px; }
.p-card .tags span { font-size: 12px; color: var(--muted); border: 1px dashed rgba(148,163,184,0.3); padding: 2px 6px; border-radius: 6px; }
.p-card .meta { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.stars { --s: #fde047; position: relative; height: 18px; display: inline-flex; gap: 2px; }
.stars::before { content: "★★★★★"; letter-spacing: 2px; background: linear-gradient(90deg, var(--s) var(--fill), rgba(255,255,255,0.12) 0); -webkit-background-clip: text; background-clip: text; color: transparent; }
.p-card .price { color: #a7f3d0; font-weight: 700; }
.p-card .p-actions { display: flex; gap: 8px; margin-top: 6px; }
.p-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, transparent 40%, rgba(255,255,255,0.18) 50%, transparent 60%); transform: translateX(-100%); transition: transform .6s ease; }
.p-card:hover::after { transform: translateX(100%); }

/* Tilt depth for children */
.tilt img, .tilt .p-body { transform: translateZ(30px); }

/* Fancy section headings */
.section h2 { position: relative; }
.section h2::after { content: ""; position: absolute; left: 50%; transform: translateX(-50%); bottom: -10px; width: 120px; height: 3px; border-radius: 999px; background: linear-gradient(90deg, var(--primary), var(--primary-2)); box-shadow: 0 0 16px rgba(249,115,22,0.6); }

/* Modal Styles */
.modal { position: fixed; inset: 0; z-index: 1000; display: none; }
.modal.show { display: block; }
.modal-overlay { position: absolute; inset: 0; background: rgba(2,6,23,0.8); backdrop-filter: blur(8px); }
.modal-content { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) scale(0.9); width: min(90vw, 600px); max-height: 90vh; background: var(--surface); border: 1px solid rgba(148,163,184,0.18); border-radius: 20px; box-shadow: 0 25px 60px rgba(2,6,23,0.8); overflow: hidden; transition: transform .3s ease; }
.modal.show .modal-content { transform: translate(-50%, -50%) scale(1); }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 20px 24px; border-bottom: 1px solid rgba(148,163,184,0.14); background: linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); }
.modal-title { margin: 0; font-size: 20px; font-weight: 700; }
.modal-close { background: transparent; border: 0; color: var(--muted); font-size: 24px; cursor: pointer; width: 32px; height: 32px; display: grid; place-items: center; border-radius: 8px; transition: all .2s ease; }
.modal-close:hover { background: rgba(148,163,184,0.08); color: var(--text); }
.modal-body { padding: 24px; max-height: calc(90vh - 80px); overflow-y: auto; }
.product-detail-content { display: grid; gap: 20px; }
.product-detail-image { text-align: center; }
.product-detail-image img { max-width: 100%; max-height: 300px; border-radius: 12px; object-fit: contain; }
.product-detail-info h3 { margin: 0 0 12px; font-size: 24px; font-weight: 700; }
.product-detail-meta { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 12px; margin: 16px 0; }
.product-detail-meta .meta-item { background: rgba(148,163,184,0.08); padding: 12px; border-radius: 10px; text-align: center; }
.product-detail-meta .meta-label { font-size: 12px; color: var(--muted); margin-bottom: 4px; }
.product-detail-meta .meta-value { font-weight: 600; color: var(--text); }
.product-detail-description { color: var(--muted); line-height: 1.6; }
.product-detail-actions { display: flex; gap: 12px; margin-top: 20px; }
@media (max-width: 640px) { .modal-content { width: 95vw; margin: 20px; } .modal-header { padding: 16px 20px; } .modal-body { padding: 20px; } }

/* Order Form Styles */
.order-form { display: grid; gap: 24px; }
.order-product-info { background: rgba(148,163,184,0.08); padding: 16px; border-radius: 12px; display: flex; align-items: center; gap: 16px; }
.order-product-info img { width: 64px; height: 64px; object-fit: contain; border-radius: 8px; }
.order-product-details h4 { margin: 0 0 4px; font-size: 16px; font-weight: 600; }
.order-product-details p { margin: 0; font-size: 14px; color: var(--muted); }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.form-grid .field.full-width { grid-column: 1 / -1; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-weight: 600; font-size: 14px; }
.required { color: #ef4444; }
.field input, .field textarea { background: var(--surface-2); border: 1px solid rgba(148,163,184,0.18); border-radius: 10px; padding: 12px 14px; color: var(--text); outline: none; transition: border-color .2s ease, box-shadow .2s ease; }
.field input:focus, .field textarea:focus { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(249,115,22,0.15); }
.field .error { display: none; color: #fecaca; font-size: 12px; margin-top: 4px; }
.field.invalid .error { display: block; }
.field.invalid input, .field.invalid textarea { border-color: #ef4444; }
.form-actions { display: flex; gap: 12px; justify-content: flex-end; }
@media (max-width: 640px) { .form-grid { grid-template-columns: 1fr; } .form-actions { flex-direction: column; } }

/* Contact Form Validation */
.form .field.invalid input,
.form .field.invalid textarea {
  border-color: #ef4444;
}

.form .field .error {
  display: none;
  color: #ef4444;
  font-size: 12px;
  margin-top: 4px;
}

.form .field.invalid .error {
  display: block;
}

.form .required {
  color: #ef4444;
}

/* Alert Styles */
.alert {
  padding: 16px;
  border-radius: 12px;
  margin-top: 20px;
  border: 1px solid;
}

.alert-success {
  background: rgba(34, 197, 94, 0.1);
  border-color: rgba(34, 197, 94, 0.3);
  color: #22c55e;
}

.alert-error {
  background: rgba(239, 68, 68, 0.1);
  border-color: rgba(239, 68, 68, 0.3);
  color: #ef4444;
}

.alert ul {
  margin: 8px 0 0 0;
  padding-left: 20px;
}

.alert li {
  margin-bottom: 4px;
}
