/* PoolPace 웹사이트 공유 스타일 — 앱 LaneTheme 톤(네이비 배경 + 민트 액센트) */
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css");

:root {
  --bg: #0b1620;
  --bg-grad-top: #0e1b27;
  --surface: #1a2738;
  --hairline: #1e2d3d;
  --brand: #6ae3d0;
  --brand-soft: rgba(106, 227, 208, 0.12);
  --ink: #eef3f7;
  --ink-secondary: #a8b5c2;
  --ink-muted: #6f7f8e;
  --maxw: 960px;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo",
    "Segoe UI", Roboto, sans-serif;
  background: linear-gradient(180deg, var(--bg-grad-top) 0%, var(--bg) 38%);
  background-attachment: fixed;
  color: var(--ink);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--brand); text-decoration: none; }
a:hover { text-decoration: underline; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }

/* 헤더 */
header.site {
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(12px);
  background: rgba(11, 22, 32, 0.72);
  border-bottom: 1px solid var(--hairline);
}
header.site .wrap {
  display: flex; align-items: center; justify-content: space-between;
  height: 60px;
}
.brand-mark { display: flex; align-items: center; gap: 10px; font-weight: 800; font-size: 18px; color: var(--ink); }
.brand-mark .dot { width: 22px; height: 22px; border-radius: 7px; background: linear-gradient(135deg, var(--brand), #4cc9b8); }
header.site nav { display: flex; gap: 22px; font-size: 14px; }
header.site nav a { color: var(--ink-secondary); }
@media (max-width: 640px) { header.site nav { display: none; } }

/* 히어로 */
.hero { padding: 88px 0 72px; text-align: center; }
.eyebrow {
  display: inline-block; font-size: 13px; font-weight: 700; letter-spacing: 0.08em;
  color: var(--brand); font-style: italic; margin-bottom: 18px;
}
.hero h1 { font-size: clamp(32px, 6vw, 56px); font-weight: 800; line-height: 1.15; letter-spacing: -0.02em; }
.hero h1 .accent { color: var(--brand); }
.hero p.lead { margin: 22px auto 0; max-width: 560px; font-size: 18px; color: var(--ink-secondary); }
.cta-row { margin-top: 34px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.badge-soon {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 22px; border-radius: 14px; font-weight: 700; font-size: 15px;
  background: var(--brand); color: var(--bg);
}
.badge-ghost {
  display: inline-flex; align-items: center; padding: 13px 22px; border-radius: 14px;
  font-weight: 600; font-size: 15px; color: var(--ink); border: 1px solid var(--hairline);
}

/* 섹션 */
section.block { padding: 56px 0; border-top: 1px solid var(--hairline); }
section.block h2 { font-size: clamp(24px, 4vw, 34px); font-weight: 800; letter-spacing: -0.01em; text-align: center; }
section.block .sub { text-align: center; color: var(--ink-secondary); margin-top: 10px; }

.features { margin-top: 42px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; }
@media (max-width: 640px) { .features { grid-template-columns: 1fr; } }
.feature {
  background: var(--surface); border: 1px solid var(--hairline);
  border-radius: 18px; padding: 24px;
}
.feature .ico { width: 40px; height: 40px; border-radius: 11px; background: var(--brand-soft);
  display: grid; place-items: center; font-size: 20px; margin-bottom: 14px; }
.feature h3 { font-size: 17px; font-weight: 700; }
.feature p { margin-top: 8px; color: var(--ink-secondary); font-size: 15px; }

/* 가격 */
.plans { margin-top: 40px; display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; max-width: 620px; margin-left: auto; margin-right: auto; }
@media (max-width: 560px) { .plans { grid-template-columns: 1fr; } }
.plan { background: var(--surface); border: 1px solid var(--hairline); border-radius: 18px; padding: 26px; text-align: center; position: relative; }
.plan.best { border-color: var(--brand); }
.plan .tag { position: absolute; top: -11px; left: 50%; transform: translateX(-50%); background: var(--brand); color: var(--bg); font-size: 11px; font-weight: 800; padding: 3px 12px; border-radius: 99px; }
.plan .price { font-size: 30px; font-weight: 800; margin: 6px 0; }
.plan .per { color: var(--ink-muted); font-size: 14px; }
.plan .note { color: var(--brand); font-size: 13px; margin-top: 10px; }
.trial-line { text-align: center; color: var(--ink-secondary); font-size: 14px; margin-top: 22px; }

/* 문서(개인정보/약관/고객지원) */
.doc { padding: 48px 0 72px; }
.doc h1 { font-size: 30px; font-weight: 800; }
.doc .meta { color: var(--ink-muted); font-size: 14px; margin: 8px 0 32px; }
.doc h2 { font-size: 20px; font-weight: 700; margin: 36px 0 12px; color: var(--ink); }
.doc h3 { font-size: 16px; font-weight: 700; margin: 22px 0 8px; color: var(--ink-secondary); }
.doc p, .doc li { color: var(--ink-secondary); font-size: 15px; }
.doc ul, .doc ol { margin: 10px 0 10px 22px; }
.doc li { margin: 5px 0; }
.doc table { width: 100%; border-collapse: collapse; margin: 14px 0; font-size: 14px; }
.doc th, .doc td { border: 1px solid var(--hairline); padding: 9px 12px; text-align: left; vertical-align: top; }
.doc th { background: var(--surface); color: var(--ink); font-weight: 700; }
.doc strong { color: var(--ink); }
.todo { background: rgba(255, 196, 84, 0.16); color: #ffd479; padding: 1px 7px; border-radius: 5px; font-weight: 700; font-size: 0.92em; }

/* 푸터 */
footer.site { border-top: 1px solid var(--hairline); padding: 40px 0; margin-top: 40px; }
footer.site .wrap { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 20px; }
footer.site .links { display: flex; gap: 20px; flex-wrap: wrap; font-size: 14px; }
footer.site .links a { color: var(--ink-secondary); }
footer.site .biz { color: var(--ink-muted); font-size: 13px; line-height: 1.8; }
footer.site .copyright { color: var(--ink-muted); font-size: 13px; width: 100%; }
