/* ============================================================
   GMC Comment Picker — homepage layout (EN + MN)
   ============================================================ */

section { padding: 90px 0; position: relative; }
.section-head { max-width: 760px; margin: 0 0 48px; }
.section-title {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 4.4vw, 46px); line-height: 1.08; letter-spacing: -0.03em;
  margin: 16px 0 16px;
}
.section-lead { font-size: clamp(17px, 2vw, 20px); color: var(--ink-soft); max-width: 640px; }
.section-title .pop { color: var(--teal); }
@media (prefers-color-scheme: dark) { .section-title .pop { color: var(--mint); } }

/* ---------------- HERO ---------------- */
.hero { padding: 64px 0 40px; }
.hero-grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center;
}
@media (max-width: 940px) { .hero-grid { grid-template-columns: 1fr; gap: 36px; text-align: center; } }

.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--teal); background: var(--mint-soft); padding: 7px 14px; border-radius: var(--radius-pill);
  font-weight: 700; margin-bottom: 22px;
}
@media (prefers-color-scheme: dark) { .hero-tag { color: var(--mint); } }
.hero-tag .live { width: 8px; height: 8px; border-radius: 50%; background: var(--coral); box-shadow: 0 0 0 0 var(--coral); animation: pulse 1.8s infinite; }
@keyframes pulse { 0%{ box-shadow: 0 0 0 0 rgba(255,111,94,0.6);} 70%{ box-shadow: 0 0 0 9px rgba(255,111,94,0);} 100%{ box-shadow:0 0 0 0 rgba(255,111,94,0);} }

.hero h1 {
  font-family: var(--font-display); font-weight: 800;
  font-size: clamp(38px, 6vw, 66px); line-height: 1.02; letter-spacing: -0.035em;
  margin: 0 0 22px;
}
.hero h1 .grad {
  background: var(--grad-hot); -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.hero .lead { font-size: clamp(17px, 2.1vw, 21px); color: var(--ink-soft); max-width: 540px; margin: 0 0 30px; }
@media (max-width: 940px) { .hero .lead { margin-inline: auto; } }
.hero-ctas { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 18px; }
@media (max-width: 940px) { .hero-ctas { justify-content: center; } }
.hero-meta { font-family: var(--font-mono); font-size: 13px; color: var(--ink-soft); display: flex; gap: 16px; flex-wrap: wrap; }
@media (max-width: 940px) { .hero-meta { justify-content: center; } }
.hero-meta span { display: inline-flex; align-items: center; gap: 6px; }
.hero-meta b { color: var(--teal); }
@media (prefers-color-scheme: dark) { .hero-meta b { color: var(--mint); } }

/* interactive wheel */
.wheel-stage { position: relative; display: grid; place-items: center; }
.wheel-wrap { position: relative; width: min(440px, 86vw); aspect-ratio: 1; }
.wheel-svg { width: 100%; height: 100%; display: block; transform-origin: 50% 50%; filter: drop-shadow(0 26px 50px rgba(0,95,84,0.32)); transition: transform 5s cubic-bezier(0.13, 0.7, 0.06, 1); }
.wheel-pointer {
  position: absolute; top: -6px; left: 50%; transform: translateX(-50%);
  width: 0; height: 0; border-left: 17px solid transparent; border-right: 17px solid transparent;
  border-top: 30px solid var(--coral); z-index: 4; filter: drop-shadow(0 4px 4px rgba(0,0,0,0.2));
}
.wheel-hub {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 27%; height: 27%; border-radius: 50%; background: var(--card);
  box-shadow: 0 8px 22px rgba(0,0,0,0.18), inset 0 0 0 4px var(--mint-soft);
  display: grid; place-items: center; z-index: 3; text-align: center;
}
.wheel-hub b { font-family: var(--font-display); font-weight: 700; font-size: clamp(11px, 2.4vw, 14px); color: var(--teal); line-height: 1.1; padding: 0 6px; }
@media (prefers-color-scheme: dark) { .wheel-hub b { color: var(--mint); } }
.wheel-spin {
  margin-top: 26px; min-width: 200px;
}
.wheel-result {
  position: absolute; inset: auto auto -6px 50%; transform: translate(-50%, 130%);
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius-pill);
  padding: 10px 20px; font-weight: 700; box-shadow: var(--shadow); white-space: nowrap;
  opacity: 0; transition: opacity 0.4s, transform 0.5s var(--ease-spring); font-size: 15px;
}
.wheel-result.show { opacity: 1; transform: translate(-50%, 120%); }
.wheel-result .crown { color: var(--gold); }
.wheel-caption { margin-top: 14px; font-family: var(--font-mono); font-size: 12px; color: var(--ink-soft); letter-spacing: 0.04em; }

/* ---------------- STAT STRIP ---------------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
@media (max-width: 760px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stat {
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius);
  padding: 26px 22px; text-align: center; box-shadow: var(--shadow-sm);
  transition: transform 0.25s var(--ease-spring), box-shadow 0.25s;
}
.stat:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.stat .num { font-family: var(--font-display); font-weight: 800; font-size: clamp(30px, 5vw, 44px); line-height: 1; letter-spacing: -0.03em; background: var(--grad-hot); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.stat .lbl { margin-top: 8px; font-size: 14px; color: var(--ink-soft); }

/* ---------------- STEPS ---------------- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 820px) { .steps { grid-template-columns: 1fr; } }
.step {
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius-lg);
  padding: 30px 28px; position: relative; box-shadow: var(--shadow-sm);
}
.step-n {
  width: 46px; height: 46px; border-radius: 14px; background: var(--grad-hot); color: #fff;
  font-family: var(--font-display); font-weight: 800; font-size: 20px;
  display: grid; place-items: center; margin-bottom: 18px; box-shadow: var(--shadow-sm);
}
.step h3 { font-family: var(--font-display); font-weight: 700; font-size: 21px; margin: 0 0 8px; letter-spacing: -0.01em; }
.step p { margin: 0; color: var(--ink-soft); font-size: 16px; }
.step-arrow { position: absolute; top: 44px; right: -22px; color: var(--mint); font-size: 26px; z-index: 2; }
@media (max-width: 820px) { .step-arrow { display: none; } }

/* ---------------- FEATURES ---------------- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
@media (max-width: 880px) { .features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) { .features { grid-template-columns: 1fr; } }
.feature {
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius-lg);
  padding: 30px 28px; box-shadow: var(--shadow-sm);
  transition: transform 0.28s var(--ease-spring), box-shadow 0.28s, border-color 0.28s;
}
.feature:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: var(--mint); }
.feature:hover .feat-ico { transform: rotate(-8deg) scale(1.08); }
.feat-ico {
  width: 52px; height: 52px; border-radius: 15px; display: grid; place-items: center;
  font-size: 24px; margin-bottom: 18px; background: var(--mint-soft);
  transition: transform 0.3s var(--ease-spring);
}
.feature h3 { font-family: var(--font-display); font-weight: 700; font-size: 20px; margin: 0 0 9px; letter-spacing: -0.01em; }
.feature p { margin: 0; color: var(--ink-soft); font-size: 15.5px; }

/* ---------------- ANIMATION SHOWCASE ---------------- */
.showcase {
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius-lg);
  padding: 30px; display: grid; grid-template-columns: 260px 1fr; gap: 30px; box-shadow: var(--shadow-sm);
}
@media (max-width: 820px) { .showcase { grid-template-columns: 1fr; } }
.show-tabs { display: flex; flex-direction: column; gap: 10px; }
@media (max-width: 820px) { .show-tabs { flex-direction: row; flex-wrap: wrap; } }
.show-tab {
  display: flex; align-items: center; gap: 12px; text-align: left; cursor: pointer;
  background: transparent; border: 1.5px solid var(--line); border-radius: 14px;
  padding: 14px 16px; font-family: var(--font-body); font-weight: 700; font-size: 15px; color: var(--ink);
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
}
.show-tab:hover { transform: translateX(3px); }
.show-tab.active { border-color: var(--teal); background: var(--mint-soft); }
.show-tab .emo { font-size: 20px; }
.show-tab small { display: block; font-weight: 500; color: var(--ink-soft); font-size: 12.5px; margin-top: 2px; }
.show-stage {
  border-radius: 18px; min-height: 320px; display: grid; place-items: center; position: relative; overflow: hidden;
  background: radial-gradient(circle at 50% 40%, var(--mint-soft), transparent 70%), var(--cream-2);
  border: 1.5px solid var(--line);
}
.show-panel { display: none; text-align: center; }
.show-panel.active { display: block; animation: popin 0.5s var(--ease-spring); }
@keyframes popin { from { opacity: 0; transform: scale(0.9); } to { opacity: 1; transform: none; } }
.show-panel h4 { font-family: var(--font-display); font-weight: 700; font-size: 20px; margin: 16px 0 4px; }
.show-panel p { margin: 0; color: var(--ink-soft); font-size: 15px; max-width: 340px; }

/* mini demos */
.mini-wheel { width: 150px; height: 150px; border-radius: 50%; margin: 0 auto;
  background: conic-gradient(var(--teal) 0 90deg, var(--amber) 90deg 180deg, var(--mint) 180deg 270deg, var(--coral) 270deg 360deg);
  box-shadow: inset 0 0 0 6px #fff, var(--shadow); animation: spin360 3.2s linear infinite; }
@keyframes spin360 { to { transform: rotate(360deg); } }
.mini-slot { display: flex; gap: 10px; justify-content: center; }
.mini-slot .reel { width: 56px; height: 80px; border-radius: 12px; background: var(--card); border: 1.5px solid var(--line); overflow: hidden; box-shadow: var(--shadow-sm); }
.mini-slot .reel .strip { font-size: 34px; line-height: 80px; animation: roll 1.6s linear infinite; }
.mini-slot .reel:nth-child(2) .strip { animation-duration: 2.1s; }
.mini-slot .reel:nth-child(3) .strip { animation-duration: 2.6s; }
/* strip holds 8 emojis (640px); duplicated in markup for a seamless loop */
@keyframes roll { from { transform: translateY(0);} to { transform: translateY(-640px);} }
.mini-cards { position: relative; height: 120px; width: 200px; margin: 0 auto; }
.mini-cards i {
  position: absolute; top: 0; left: 50%; width: 70px; height: 100px; border-radius: 10px;
  background: var(--card); border: 1.5px solid var(--line); box-shadow: var(--shadow-sm);
  animation: shuffle 2.6s var(--ease-spring) infinite;
}
.mini-cards i:nth-child(1){ animation-delay: 0s; } .mini-cards i:nth-child(2){ animation-delay: 0.3s; } .mini-cards i:nth-child(3){ animation-delay: 0.6s; }
@keyframes shuffle { 0%,100%{ transform: translateX(-50%) rotate(0); } 30%{ transform: translateX(-130%) rotate(-12deg);} 60%{ transform: translateX(30%) rotate(10deg);} }
.mini-confetti { font-size: 64px; animation: party 1.8s var(--ease-spring) infinite; }
@keyframes party { 0%,100%{ transform: scale(1) rotate(-6deg);} 50%{ transform: scale(1.15) rotate(8deg);} }
@media (prefers-reduced-motion: reduce) {
  .mini-wheel, .mini-slot .reel span, .mini-cards i, .mini-confetti, .hero-tag .live { animation: none !important; }
}

/* ---------------- COMPARE ---------------- */
.compare { border: 1.5px solid var(--line); border-radius: var(--radius-lg); overflow: hidden; background: var(--card); box-shadow: var(--shadow-sm); }
.compare-scroll { overflow-x: auto; }
.compare table { width: 100%; border-collapse: collapse; font-size: 14.5px; min-width: 640px; }
.compare th, .compare td { padding: 15px 18px; text-align: left; border-bottom: 1px solid var(--line); }
.compare thead th { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink-soft); background: var(--cream); font-weight: 700; }
.compare thead th.us { background: var(--teal); color: #fff; }
.compare td.us { background: var(--mint-soft); font-weight: 700; }
.compare .yes { color: var(--teal); font-weight: 800; }
@media (prefers-color-scheme: dark) { .compare .yes { color: var(--mint); } }
.compare .no { color: var(--coral); font-weight: 700; }
.compare tr:last-child td { border-bottom: 0; }

/* ---------------- PRICING ---------------- */
.pricing { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; align-items: stretch; }
@media (max-width: 940px) { .pricing { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .pricing { grid-template-columns: 1fr; } }
.tier {
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius-lg);
  padding: 30px 26px; display: flex; flex-direction: column; position: relative; box-shadow: var(--shadow-sm);
  transition: transform 0.25s var(--ease-spring), box-shadow 0.25s;
}
.tier:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
.tier-best { border-color: var(--teal); box-shadow: var(--shadow-pop); }
.tier-best::before { content: ""; position: absolute; inset: 0; border-radius: inherit; padding: 1.5px;
  background: var(--grad-hot); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none; }
.tier-badge {
  position: absolute; top: -13px; left: 50%; transform: translateX(-50%);
  background: var(--grad-hot); color: #fff; font-family: var(--font-mono); font-size: 11px; font-weight: 700;
  letter-spacing: 0.05em; text-transform: uppercase; padding: 5px 13px; border-radius: var(--radius-pill);
  white-space: nowrap; box-shadow: var(--shadow-sm);
}
.tier h3 { font-family: var(--font-display); font-weight: 700; font-size: 19px; margin: 4px 0 6px; }
.tier .price { font-family: var(--font-display); font-weight: 800; font-size: 40px; line-height: 1; letter-spacing: -0.03em; }
.tier .price .per { font-size: 15px; color: var(--ink-soft); font-weight: 500; font-family: var(--font-body); }
.tier .note { color: var(--ink-soft); font-size: 13.5px; margin: 12px 0 18px; min-height: 38px; }
.tier ul { list-style: none; padding: 0; margin: 0 0 22px; font-size: 14.5px; flex: 1; }
.tier ul li { padding: 7px 0; display: flex; gap: 9px; }
.tier ul li::before { content: "✦"; color: var(--mint); font-weight: 800; }
.tier .cta { margin-top: auto; }

/* ---------------- FAQ ---------------- */
.faq { max-width: 800px; }
.faq details {
  background: var(--card); border: 1.5px solid var(--line); border-radius: var(--radius);
  padding: 4px 22px; margin-bottom: 12px; transition: box-shadow 0.25s, border-color 0.25s;
}
.faq details[open] { box-shadow: var(--shadow-sm); border-color: var(--mint); }
.faq summary {
  font-family: var(--font-display); font-weight: 700; font-size: 17px; cursor: pointer;
  list-style: none; padding: 16px 0; display: flex; justify-content: space-between; align-items: center; gap: 16px;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary .tog { color: var(--teal); font-size: 26px; line-height: 1; transition: transform 0.3s var(--ease-spring); flex: none; }
@media (prefers-color-scheme: dark) { .faq summary .tog { color: var(--mint); } }
.faq details[open] summary .tog { transform: rotate(135deg); }
.faq details p { margin: 0 0 16px; color: var(--ink-soft); font-size: 16px; }
.faq details ul { margin: 0 0 16px; color: var(--ink-soft); font-size: 15px; }

/* ---------------- FINAL CTA ---------------- */
.cta-band {
  background: var(--grad-hot); border-radius: var(--radius-lg); padding: 60px 40px; text-align: center;
  color: #fff; position: relative; overflow: hidden; box-shadow: var(--shadow-pop);
}
.cta-band h2 { font-family: var(--font-display); font-weight: 800; font-size: clamp(28px, 4.5vw, 44px); margin: 0 0 14px; letter-spacing: -0.03em; }
.cta-band p { font-size: 18px; margin: 0 0 28px; opacity: 0.92; max-width: 540px; margin-inline: auto; }
.cta-band .btn-amber { font-size: 16px; }
.cta-spark { position: absolute; font-size: 40px; opacity: 0.35; }
.cta-spark.s1 { top: 18px; left: 8%; animation: float 9s ease-in-out infinite; }
.cta-spark.s2 { bottom: 14px; right: 10%; animation: float 11s ease-in-out infinite reverse; }
.cta-spark.s3 { top: 40%; right: 6%; font-size: 28px; animation: float 7s ease-in-out infinite; }
@media (prefers-reduced-motion: reduce) { .cta-spark { animation: none !important; } }
