/* ============================================
   DARK MYSTERIOUS THEME - sora8888.com
   ============================================ */

* { margin: 0; padding: 0; box-sizing: border-box; }
body { font-family: 'Astra', sans-serif; background: #000000; color: #D4D4D4; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 20px; }

/* Trust Bar */
.trust-bar { background: #000000; color: #C9A86C; padding: 12px 0; text-align: center; font-size: 14px; }
.trust-bar span { margin: 0 20px; }
.trust-bar span::before { margin-right: 6px; }

/* Hero */
.hero {
  background: linear-gradient(rgba(10,10,10,0.75), rgba(10,10,10,0.75)),
    url('https://sora8888.com/wp-content/uploads/2026/04/hero-slide-1.png') center/cover;
  color: #fff; text-align: center; padding: 120px 20px;
}
.hero h1 { font-size: 56px; font-weight: 300; letter-spacing: 4px; margin-bottom: 16px; }
.hero p { font-size: 20px; margin-bottom: 32px; opacity: 0.9; }
.hero .cta {
  display: inline-block; background: #C9A86C; color: #000000;
  padding: 14px 40px; text-decoration: none; font-weight: 600;
  letter-spacing: 2px; transition: background 0.3s;
}
.hero .cta:hover { background: #b8975a; }

/* Section titles */
.section-title { text-align: center; padding: 60px 0 40px; }
.section-title h2 { font-size: 36px; font-weight: 300; color: #E8E8E8; margin-bottom: 10px; }
.section-title p { color: #888; font-size: 16px; }

/* Five Elements */
.five-elements { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
.element-card {
  position: relative; overflow: hidden;  cursor: pointer;
  aspect-ratio: 1;
}
.element-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.3s; }
.element-card:hover img { transform: scale(1.05); }
.element-card .overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(10,10,10,0.9));
  color: #fff; padding: 40px 16px 16px; text-align: center;
}
.element-card .overlay h3 { font-size: 18px; font-weight: 600; letter-spacing: 2px; }
.element-card .overlay p { font-size: 12px; opacity: 0.8; margin-top: 4px; }

/* Top Products Grid */
.top-products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.product-card { background: #000000;  overflow: hidden; box-shadow: 0 2px 12px rgba(0,0,0,0.5); border: none; }
.product-card img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.product-card .info { padding: 16px; text-align: center; }
.product-card .info h3 { font-size: 14px; color: #D4D4D4; margin-bottom: 8px; }
.product-card .info .price { color: #C9A86C; font-size: 18px; font-weight: 600; }
.product-card .info .rating { color: #888; font-size: 12px; margin-top: 4px; }

/* Series Section */
.series-section { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; }
.series-img { width: 100%; border-radius: 12px; }
.series-text h3 { font-size: 28px; color: #E8E8E8; margin-bottom: 16px; }
.series-text p { color: #999; line-height: 1.8; margin-bottom: 24px; }
.series-text .series-list { list-style: none; }
.series-text .series-list li { padding: 8px 0; border-bottom: 1px solid #222; color: #999; font-size: 15px; }
.series-text .series-list li::before { content: '◆ '; color: #C9A86C; margin-right: 8px; }

/* Buy Beads Section */
.beads-section { background: #000000; padding: 60px 0; }
.beads-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 0; }
.bead-item { text-align: center; }
.bead-item img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; border: 3px solid #333; margin-bottom: 8px; }
.bead-item span { font-size: 11px; color: #888; }

/* Zodiac Section */
.zodiac-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; }
.zodiac-card { text-align: center; }
.zodiac-card img { width: 100%; aspect-ratio: 1; object-fit: cover;  margin-bottom: 8px; border: none; }
.zodiac-card span { font-size: 13px; color: #999; font-weight: 500; }

/* Service Section */
.service-section { background: #000000; color: #fff; padding: 60px 0; text-align: center; }
.service-section h2 { font-size: 28px; font-weight: 300; margin-bottom: 30px; }
.service-section h2 span { color: #C9A86C; }
.services { display: flex; justify-content: center; gap: 40px; flex-wrap: wrap; }
.service-item { text-align: center; }
.service-item .icon { font-size: 32px; margin-bottom: 10px; }
.service-item h4 { color: #C9A86C; margin-bottom: 6px; }
.service-item p { font-size: 13px; opacity: 0.7; }

/* Footer */
footer { background: #000000; color: #666; padding: 40px 0 20px; }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; margin-bottom: 30px; }
.footer-col h4 { color: #C9A86C; margin-bottom: 16px; font-size: 14px; }
.footer-col ul { list-style: none; }
.footer-col ul li { margin-bottom: 8px; }
.footer-col ul li a { color: #666; text-decoration: none; font-size: 13px; }
.footer-col ul li a:hover { color: #C9A86C; }
.footer-bottom { border-top: 1px solid #000000; padding-top: 20px; text-align: center; font-size: 12px; }

/* Section spacing */
.section { padding: 60px 0; }
.section.alt-bg { background: #000000; }

/* Material Grid */
.material-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 16px; }
.material-card {
  text-align: center; cursor: pointer; padding: 20px 8px;
   border: none; transition: transform 0.3s, border-color 0.3s;
  background: #000000;
}
.material-card:hover { transform: translateY(-4px); border-color: #C9A86C; }
.material-icon { font-size: 36px; margin-bottom: 10px; }
.material-card .name { font-size: 14px; color: #D4D4D4; font-weight: 500; }
.material-card .cn { font-size: 11px; color: #666; margin-top: 4px; }

/* Meaning Grid */
.meaning-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 16px; }
.meaning-card {
  text-align: center; cursor: pointer; padding: 16px 8px;
   border: none; transition: transform 0.3s, border-color 0.3s;
  background: #000000;
}
.meaning-card:hover { transform: translateY(-4px); border-color: #C9A86C; }
.meaning-icon { font-size: 32px; margin-bottom: 8px; }
.meaning-card .name { font-size: 13px; color: #D4D4D4; font-weight: 500; }
.meaning-card .cn { font-size: 11px; color: #666; margin-top: 3px; }

@media (max-width: 768px) {
  .material-grid, .meaning-grid { grid-template-columns: repeat(3, 1fr); }
  .five-elements { grid-template-columns: repeat(3, 1fr); }
  .top-products { grid-template-columns: repeat(2, 1fr); }
}

