/* Aurion Hosting — global polish: smooth scroll, transitions, reveal, page transitions */
html {
  scroll-behavior: smooth;
}

/* Smoother link and button feedback */
a {
  transition: color 0.2s ease, opacity 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

/* ----- Page transition (out): controlled by aurion.js ----- */
body.aurion-page-leaving {
  opacity: 0;
  transition: opacity 0.2s ease-out;
  pointer-events: none;
}

/* ----- Card hover (GPU-friendly: transform + box-shadow) ----- */
.card,
.game-card,
.why-item,
.t-card,
.infra-item,
.result-box {
  transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.2s ease, border-color 0.2s ease;
}
.card:hover,
.game-card:hover,
.why-item:hover,
.t-card:hover,
.infra-item:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.35);
}
.game-card:hover {
  transform: translateY(-8px);
}

/* ----- Game plan cards: Most Popular badge (used on gamehost subpages) ----- */
.game-card {
  position: relative;
  overflow: hidden;
}
.game-card .badge {
  position: absolute;
  top: 12px;
  right: 12px;
  background: rgba(0, 0, 0, 0.45);
  color: #fff;
  font-weight: 800;
  font-size: 0.7rem;
  padding: 0.35rem 0.65rem;
  border-radius: 999px;
  letter-spacing: 0.04em;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.3);
  z-index: 2;
}
.game-card.popular {
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
}
.game-card.popular:hover {
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.35);
}

/* ----- Buttons: micro scale on hover ----- */
.btn-primary,
.btn-outline,
.card a,
.game-card .btn,
.game-card .btn-primary,
.cta a,
.login-btn,
.btn-buy {
  transition: transform 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
}
.btn-primary:hover,
.btn-outline:hover,
.card a:hover,
.game-card .btn:hover,
.game-card .btn-primary:hover,
.cta a:hover,
.login-btn:hover,
.btn-buy:hover {
  transform: scale(1.03);
}

/* ----- Logo micro-animation ----- */
a.logo {
  transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}
a.logo:hover {
  transform: scale(1.02);
  opacity: 0.95;
}

/* ----- Reveal on scroll (initial state) ----- */
.aurion-reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.4s ease-out, transform 0.4s ease-out;
}
.aurion-reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* Stagger children (optional, small delay for grids) */
.aurion-reveal-item {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.35s ease-out, transform 0.35s ease-out;
}
.aurion-reveal.visible .aurion-reveal-item {
  opacity: 1;
  transform: translateY(0);
}
.aurion-reveal.visible .aurion-reveal-item:nth-child(1) { transition-delay: 0.05s; }
.aurion-reveal.visible .aurion-reveal-item:nth-child(2) { transition-delay: 0.1s; }
.aurion-reveal.visible .aurion-reveal-item:nth-child(3) { transition-delay: 0.15s; }
.aurion-reveal.visible .aurion-reveal-item:nth-child(4) { transition-delay: 0.2s; }
.aurion-reveal.visible .aurion-reveal-item:nth-child(5) { transition-delay: 0.25s; }
.aurion-reveal.visible .aurion-reveal-item:nth-child(6) { transition-delay: 0.3s; }
.aurion-reveal.visible .aurion-reveal-item:nth-child(7) { transition-delay: 0.35s; }

/* ----- Fade-in on first load (hero / first section) ----- */
.hero,
section:first-of-type {
  animation: aurion-fade-in 0.4s ease-out;
}
@keyframes aurion-fade-in {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Slightly softer focus for keyboard nav */
a:focus-visible,
button:focus-visible {
  outline: 2px solid currentColor;
  outline-offset: 2px;
}

/* ----- Skeleton loading ----- */
.skeleton {
  background: linear-gradient(
    90deg,
    rgba(255,255,255,.06) 0%,
    rgba(255,255,255,.12) 50%,
    rgba(255,255,255,.06) 100%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1s ease-in-out infinite;
  border-radius: 6px;
}
@keyframes skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-line { height: 1em; margin-bottom: 0.5rem; }
.skeleton-line:last-child { margin-bottom: 0; }
.skeleton-line.short { width: 40%; }
.skeleton-line.medium { width: 70%; }
.skeleton-line.long { width: 100%; }
.result-box.loading .skeleton-loading { display: block; }
.result-box.loading .status,
.result-box.loading .msg { visibility: hidden; }
.result-box .skeleton-loading {
  display: none;
  padding: 0;
  pointer-events: none;
}
.result-box { position: relative; }
.result-box .skeleton-loading .skeleton-line { margin-left: 0; margin-right: 0; }

/* ----- FAQ accordion ----- */
.faq-list { max-width: 720px; margin: 0 auto; }
.faq-item {
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 12px;
  margin-bottom: 0.75rem;
  overflow: hidden;
}
.faq-item summary {
  padding: 1rem 1.25rem;
  font-weight: 700;
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  transition: background 0.2s ease;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-size: 1.25rem;
  opacity: 0.7;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item summary:hover { background: rgba(255,255,255,.06); }
.faq-item .faq-answer {
  padding: 0 1.25rem 1.25rem;
  color: rgba(255,255,255,.85);
  font-size: 0.95rem;
  line-height: 1.6;
}
.faq-item .faq-answer p { margin: 0 0 0.5rem; }
.faq-item .faq-answer p:last-child { margin-bottom: 0; }
