:root {
  --night: #0d0a24;
  --panel: #17133d;
  --panel-2: #211a50;
  --purple: #8b7cff;
  --mint: #a7f3d0;
  --gold: #ffd66b;
  --pink: #ff9fd7;
  --text: #f8f7ff;
  --muted: #c9c5e6;
  --ink: #211d3d;
  --paper: #fbfaff;
  --line: #dcd7f2;
  --ok: #267855;
  --warn: #955f0a;
  --radius: 20px;
  --shadow: 0 20px 60px rgba(16, 10, 52, .14);
}

* { box-sizing: border-box; }
html { color-scheme: light; scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background:
    radial-gradient(circle at 10% 0%, rgba(139,124,255,.16), transparent 28rem),
    radial-gradient(circle at 100% 20%, rgba(167,243,208,.2), transparent 25rem),
    var(--paper);
  font-family: Pretendard, "Noto Sans KR", system-ui, -apple-system, "Segoe UI", sans-serif;
  line-height: 1.65;
}

a { color: #5546bf; }
button, input, select { font: inherit; }
button, .button {
  min-height: 46px;
  border: 0;
  border-radius: 13px;
  padding: .78rem 1.05rem;
  color: #fff;
  background: linear-gradient(135deg, #6958de, #8b7cff);
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .4rem;
}
button:hover, .button:hover { filter: brightness(1.06); transform: translateY(-1px); }
button:disabled { opacity: .5; cursor: not-allowed; transform: none; }
.button.secondary, button.secondary { background: #fff; color: #5146a6; border: 1px solid var(--line); }
:focus-visible { outline: 3px solid var(--gold); outline-offset: 3px; }

.skip { position: absolute; top: -100px; left: 1rem; z-index: 30; padding: .6rem; background: #fff; }
.skip:focus { top: 1rem; }
.site-header { background: rgba(13,10,36,.96); color: #fff; }
.header-inner, main, .footer-inner { width: min(1120px, calc(100% - 32px)); margin: auto; }
.header-inner { min-height: 70px; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brand { color: #fff; font-size: 1.15rem; font-weight: 900; text-decoration: none; white-space: nowrap; }
.brand span { color: var(--gold); }
nav ul { display: flex; list-style: none; gap: .2rem; margin: 0; padding: 0; flex-wrap: wrap; }
nav a { color: #e9e7ff; text-decoration: none; padding: .6rem .7rem; border-radius: 9px; font-size: .92rem; }
nav a:hover, nav a[aria-current="page"] { background: rgba(255,255,255,.1); color: #fff; }

main { padding: 2rem 0 4rem; }
.hero {
  border-radius: 28px;
  padding: clamp(2rem, 6vw, 4.5rem);
  color: var(--text);
  background:
    radial-gradient(circle at 85% 15%, rgba(255,214,107,.22), transparent 12rem),
    radial-gradient(circle at 10% 100%, rgba(167,243,208,.15), transparent 14rem),
    var(--night);
  box-shadow: var(--shadow);
  overflow: hidden;
}
.hero.compact { padding: clamp(1.8rem, 5vw, 3.3rem); }
.eyebrow { margin: 0 0 .4rem; color: var(--gold); font-weight: 850; letter-spacing: .04em; }
h1, h2, h3 { line-height: 1.3; color: #27204d; }
.hero h1 { color: #fff; font-size: clamp(2.25rem, 7vw, 4.2rem); letter-spacing: -.05em; margin: .15rem 0 .8rem; }
.hero.compact h1 { font-size: clamp(2rem, 6vw, 3.3rem); }
.lead { max-width: 760px; font-size: 1.08rem; }
.hero .lead { color: var(--muted); }
.privacy-chip { display: inline-flex; margin-top: .8rem; padding: .45rem .7rem; border-radius: 999px; color: var(--mint); background: rgba(167,243,208,.1); font-size: .9rem; font-weight: 750; }

.tool-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin: 1.4rem 0; }
.card, .tool-panel, .content-box, .result-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,.96);
  box-shadow: 0 12px 34px rgba(38,28,92,.08);
  padding: clamp(1rem, 4vw, 1.5rem);
}
.card { color: inherit; text-decoration: none; transition: .18s ease; }
.card:hover { transform: translateY(-3px); border-color: #b3a9ee; }
.card-icon { display: grid; place-items: center; width: 48px; height: 48px; border-radius: 15px; background: #eeeaff; font-size: 1.5rem; }
.card h2, .card h3 { margin: .8rem 0 .3rem; }
.card p { margin: 0; color: #68617e; }
.section-title { margin-top: 2.5rem; }

.tool-panel { margin-top: 1.2rem; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 1rem; }
.field { display: grid; gap: .38rem; }
.field.full { grid-column: 1 / -1; }
label, legend { font-weight: 800; color: #302759; }
input, select {
  width: 100%;
  min-height: 46px;
  border: 1px solid #bdb6d8;
  border-radius: 12px;
  background: #fff;
  color: var(--ink);
  padding: .72rem .8rem;
}
.hint { margin: 0; color: #716a84; font-size: .88rem; }
.actions { display: flex; gap: .65rem; flex-wrap: wrap; align-items: center; margin-top: 1rem; }

.result-shell { margin-top: 1.3rem; }
.result-card {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 90% 10%, rgba(255,214,107,.28), transparent 9rem),
    linear-gradient(145deg, #151038, #29205e);
  color: var(--text);
  border: 0;
}
.result-card::after { content: "✦"; position: absolute; right: 1.5rem; top: .8rem; font-size: 3.5rem; color: rgba(255,255,255,.12); }
.result-card h2, .result-card h3 { color: #fff; }
.result-kicker { color: var(--mint); font-weight: 850; }
.result-title { font-size: clamp(1.7rem, 5vw, 2.7rem); margin: .25rem 0 .45rem; }
.result-summary { color: #dedaf8; max-width: 760px; }
.result-card[hidden] { display: none; }

.traits, .metrics, .lucky-grid { display: grid; gap: .75rem; }
.traits { grid-template-columns: repeat(3, 1fr); margin: 1rem 0; }
.trait, .lucky-item { padding: .85rem; border-radius: 14px; background: rgba(255,255,255,.08); }
.trait strong, .lucky-item strong { display: block; color: var(--gold); }
.metrics { grid-template-columns: repeat(4, 1fr); margin: 1rem 0; }
.metric { padding: .85rem; border-radius: 14px; background: rgba(255,255,255,.08); }
.metric span { display: block; color: #cbc6ef; font-size: .88rem; }
.metric strong { font-size: 1.45rem; color: #fff; }
.meter { height: 7px; margin-top: .45rem; border-radius: 10px; background: rgba(255,255,255,.12); overflow: hidden; }
.meter i { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--mint), var(--gold)); }
.lucky-grid { grid-template-columns: repeat(4, 1fr); }
.result-list { padding-left: 1.2rem; }
.result-list li { margin: .4rem 0; color: #e7e4fb; }
.disclaimer { font-size: .85rem; color: #a9a3ca; }

.ad-slot { margin: 2rem 0; min-height: 84px; border: 1px dashed #bcb5db; border-radius: 15px; display: grid; place-items: center; color: #77708e; background: rgba(255,255,255,.55); }

.card-picker { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin-top: 1.2rem; }
.mystery-card {
  min-height: 230px;
  padding: 1rem;
  border: 1px solid #6f62c8;
  background:
    radial-gradient(circle, rgba(255,214,107,.24) 1px, transparent 2px) 0 0/24px 24px,
    linear-gradient(145deg, #17133d, #302668);
  color: #fff;
  font-size: 2.7rem;
  box-shadow: var(--shadow);
}
.mystery-card span { display: block; margin-top: .6rem; font-size: .95rem; color: #d7d2f7; }
.mystery-card.revealed { background: linear-gradient(145deg, #5543b5, #7e6fea); }

.zodiac-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.zodiac-item { border-left: 5px solid #8b7cff; }
.zodiac-item h2 { margin-top: 0; }
.tag { display: inline-block; padding: .2rem .55rem; margin: .15rem .2rem .15rem 0; border-radius: 999px; background: #eeeaff; color: #4d42a1; font-size: .83rem; font-weight: 750; }
.prose { max-width: 850px; }
.prose h1 { font-size: clamp(2rem, 6vw, 3.4rem); }
.prose h2 { margin-top: 2.2rem; }
.notice { border-left: 5px solid var(--purple); padding: .8rem 1rem; background: #f0edff; border-radius: 10px; }
.site-footer { color: #d8d4ef; background: var(--night); }
.footer-inner { min-height: 130px; display: flex; justify-content: space-between; gap: 1rem; align-items: center; }
.footer-links { display: flex; flex-wrap: wrap; gap: .8rem; }
.site-footer a { color: #e6e2ff; }

@media (max-width: 860px) {
  .tool-grid, .zodiac-grid { grid-template-columns: repeat(2, 1fr); }
  .metrics, .lucky-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 620px) {
  .header-inner { align-items: flex-start; flex-direction: column; padding: .8rem 0; }
  nav ul { gap: 0; }
  nav a { padding: .5rem .55rem; }
  main { padding-top: 1rem; }
  .hero { border-radius: 20px; padding: 1.45rem; }
  .tool-grid, .zodiac-grid, .form-grid, .traits, .card-picker { grid-template-columns: 1fr; }
  .field.full { grid-column: auto; }
  .footer-inner { align-items: flex-start; flex-direction: column; padding: 2rem 0; }
  .mystery-card { min-height: 150px; }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; transition: none !important; }
}

