@charset "UTF-8";
/* ============================================================
   ALGOMONG · 공통 컴포넌트 라이브러리
   colors.css 위에 얹는 컴포넌트 스타일 (버튼·카드·네비·뱃지·
   글래스모피즘·성능카드·네온글로우). 모든 페이지가 공유한다.
   ============================================================ */
@import url("colors.css");

/* ---------- layout helpers ---------- */
.am-wrap { width: 100%; max-width: 1200px; margin: 0 auto; padding: 0 32px; }
.am-section { padding: clamp(64px, 9vw, 140px) 0; position: relative; }
.am-eyebrow {
  font-family: var(--am-font-mono);
  font-size: 13px; font-weight: 600;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--am-violet-500);
  display: inline-flex; align-items: center; gap: 10px;
}
.am-eyebrow::before {
  content: ""; width: 26px; height: 2px; border-radius: 2px;
  background: var(--am-grad-aurora);
}
.am-h1 { font-size: clamp(40px, 6vw, 76px); font-weight: 800; line-height: 1.05; letter-spacing: -0.03em; margin: 0; }
.am-h2 { font-size: clamp(30px, 4vw, 52px); font-weight: 800; line-height: 1.1; letter-spacing: -0.025em; margin: 0; }
.am-h3 { font-size: clamp(20px, 2vw, 26px); font-weight: 700; line-height: 1.25; letter-spacing: -0.01em; margin: 0; }
.am-lead { font-size: clamp(16px, 1.4vw, 20px); color: var(--fg-2); line-height: 1.7; }
.am-serif { font-family: var(--am-font-serif); font-weight: 600; }
.am-roman { font-family: var(--am-font-roman); letter-spacing: 0.04em; }
.am-mono { font-family: var(--am-font-mono); }

/* ---------- buttons ---------- */
.am-btn {
  --btn-bg: var(--am-violet-500);
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--am-font-sans); font-weight: 700; font-size: 15px;
  padding: 14px 26px; border-radius: var(--am-radius-pill);
  border: 0; cursor: pointer; text-decoration: none;
  color: #fff; background: var(--btn-bg);
  transition: transform var(--am-dur) var(--am-ease),
              box-shadow var(--am-dur) var(--am-ease),
              filter var(--am-dur) var(--am-ease);
  box-shadow: 0 8px 22px -8px rgba(110,74,255,0.6);
}
.am-btn:hover { transform: translateY(-2px); box-shadow: var(--am-glow-violet); }
.am-btn:active { transform: translateY(0); }
.am-btn--aurora { background: var(--am-grad-aurora); background-size: 180% 100%; }
.am-btn--aurora:hover { filter: brightness(1.06); box-shadow: 0 0 28px rgba(110,74,255,0.5), 0 0 28px rgba(33,224,255,0.3); }
.am-btn--ghost {
  background: transparent; color: var(--am-violet-600);
  box-shadow: inset 0 0 0 1.5px var(--am-violet-200);
}
.am-btn--ghost:hover { box-shadow: inset 0 0 0 1.5px var(--am-violet-400); background: var(--am-violet-50); }
.am-btn--dark { background: rgba(255,255,255,0.08); color: #fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.2); }
.am-btn--dark:hover { background: rgba(255,255,255,0.16); box-shadow: var(--am-glow-cyan); }
.am-btn--lg { font-size: 17px; padding: 17px 34px; }
.am-btn--sm { font-size: 13px; padding: 9px 16px; }

/* ---------- glass card / surfaces ---------- */
.am-card {
  background: var(--surface); border-radius: var(--am-radius-lg);
  box-shadow: var(--am-shadow-md); padding: 28px;
  border: 1px solid rgba(255,255,255,0.6);
  transition: transform var(--am-dur) var(--am-ease), box-shadow var(--am-dur) var(--am-ease);
}
.am-card--hover:hover { transform: translateY(-6px); box-shadow: var(--am-shadow-lg); }
.am-glass {
  background: rgba(255,255,255,0.55);
  backdrop-filter: blur(18px) saturate(1.4);
  -webkit-backdrop-filter: blur(18px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.7);
  border-radius: var(--am-radius-lg);
  box-shadow: var(--am-shadow-md);
}
.am-glass--dark {
  background: rgba(26,15,61,0.45);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(110,74,255,0.25);
  border-radius: var(--am-radius-lg);
  color: #fff;
}

/* ---------- badges / chips / pills ---------- */
.am-chip {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 13px; font-weight: 600; line-height: 1;
  padding: 7px 13px; border-radius: var(--am-radius-pill);
  background: var(--am-violet-50); color: var(--am-violet-700);
  border: 1px solid var(--am-violet-100);
  cursor: pointer; transition: all var(--am-dur) var(--am-ease);
}
.am-chip:hover { background: var(--am-violet-100); }
.am-chip[aria-selected="true"], .am-chip.is-active {
  background: var(--am-violet-500); color: #fff; border-color: var(--am-violet-500);
  box-shadow: 0 6px 16px -6px rgba(110,74,255,0.6);
}
.am-tag {
  font-family: var(--am-font-mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.08em; padding: 4px 9px; border-radius: 6px;
  background: rgba(33,224,255,0.12); color: #0c8aa3;
  border: 1px solid rgba(33,224,255,0.3);
}
.am-dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.am-dot--live { background: var(--am-success); box-shadow: 0 0 0 0 rgba(43,243,180,0.6); animation: am-blink 2s infinite; }
@keyframes am-blink { 0%,100%{ box-shadow: 0 0 0 0 rgba(43,243,180,0.5);} 50%{ box-shadow: 0 0 0 6px rgba(43,243,180,0);} }

/* ---------- glow / neon helpers ---------- */
.am-neon-ring {
  border-radius: var(--am-radius-lg);
  box-shadow: var(--am-glow-violet);
}
.am-orb {
  width: 64px; height: 64px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff 0%, var(--am-cyan-500) 35%, var(--am-violet-500) 100%);
  box-shadow: var(--am-glow-cyan);
  display: grid; place-items: center; color: #fff; font-weight: 800;
  font-family: var(--am-font-mono); font-size: 18px;
  animation: am-pulse-orb 3.4s ease-in-out infinite;
}

/* ---------- performance / spec card (게임 능력치 카드 무드) ---------- */
.am-spec {
  position: relative; overflow: hidden;
  background: linear-gradient(160deg, rgba(26,15,61,0.92), rgba(10,6,37,0.96));
  border: 1px solid rgba(110,74,255,0.35);
  border-radius: var(--am-radius-lg);
  padding: 26px; color: #fff;
  box-shadow: 0 24px 56px -20px rgba(10,6,37,0.7);
}
.am-spec::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(120% 90% at 100% 0%, rgba(33,224,255,0.16), transparent 55%),
              radial-gradient(120% 90% at 0% 100%, rgba(255,61,210,0.14), transparent 55%);
  pointer-events: none;
}
.am-spec > * { position: relative; }
.am-spec__bar { height: 8px; border-radius: 99px; background: rgba(255,255,255,0.1); overflow: hidden; }
.am-spec__fill { height: 100%; border-radius: 99px; background: var(--am-grad-aurora); background-size: 200% 100%; animation: am-grad-pan 5s linear infinite; }

/* ---------- meter rows ---------- */
.am-meter { display: grid; grid-template-columns: 1fr auto; gap: 6px 12px; align-items: center; }
.am-meter__label { font-size: 13px; color: rgba(255,255,255,0.78); font-family: var(--am-font-mono); }
.am-meter__val { font-size: 13px; font-weight: 700; color: var(--am-cyan-glow); font-family: var(--am-font-mono); }

/* ---------- nav / header ---------- */
.am-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 32px;
  background: rgba(250,248,255,0.7);
  backdrop-filter: blur(16px) saturate(1.5);
  -webkit-backdrop-filter: blur(16px) saturate(1.5);
  border-bottom: 1px solid rgba(110,74,255,0.12);
}
.am-nav__links { display: flex; gap: 4px; align-items: center; }
.am-nav__link {
  font-size: 14px; font-weight: 600; color: var(--fg-2); text-decoration: none;
  padding: 8px 14px; border-radius: var(--am-radius-pill); transition: all var(--am-dur) var(--am-ease);
}
.am-nav__link:hover { color: var(--am-violet-600); background: var(--am-violet-50); }
.am-brandmark { display: flex; align-items: center; gap: 10px; font-weight: 800; font-size: 19px; letter-spacing: -0.02em; text-decoration: none; color: var(--fg); }
.am-brandmark__dot { width: 26px; height: 26px; border-radius: 9px; background: var(--am-grad-aurora); box-shadow: 0 4px 12px -3px rgba(110,74,255,0.6); }

/* ---------- floating consult button ---------- */
.am-float {
  position: fixed; right: 24px; bottom: 24px; z-index: 60;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 24px; border-radius: var(--am-radius-pill);
  background: var(--am-grad-aurora); background-size: 200% 100%;
  color: #fff; font-weight: 800; font-size: 15px; text-decoration: none; border: 0; cursor: pointer;
  box-shadow: 0 14px 34px -10px rgba(110,74,255,0.7);
  animation: am-grad-pan 6s linear infinite, am-float 3.6s ease-in-out infinite;
}
.am-float:hover { filter: brightness(1.07); transform: translateY(-2px); }
.am-float__pulse { width: 9px; height: 9px; border-radius: 50%; background: #fff; box-shadow: 0 0 0 0 rgba(255,255,255,0.7); animation: am-blink 1.8s infinite; }

/* ---------- divider / kicker ---------- */
.am-rule { height: 1px; background: linear-gradient(90deg, transparent, var(--am-violet-200), transparent); border: 0; margin: 0; }

/* ---------- utility ---------- */
.am-grid { display: grid; gap: 24px; }
.cols-2 { grid-template-columns: repeat(2, 1fr); }
.cols-3 { grid-template-columns: repeat(3, 1fr); }
.cols-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 900px){ .cols-3,.cols-4 { grid-template-columns: repeat(2,1fr);} }
@media (max-width: 620px){ .cols-2,.cols-3,.cols-4 { grid-template-columns: 1fr;} .am-wrap{ padding: 0 20px; } }
.am-center { text-align: center; }
.am-stack { display: flex; flex-direction: column; }
.am-row { display: flex; align-items: center; }
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}.gap-24{gap:24px}
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-32{margin-top:32px}.mt-48{margin-top:48px}
