/*
 * hwang.pmm.kr — designed after ElevenLabs DESIGN.md
 * (workspace/design-guides/design-md/elevenlabs/DESIGN.md)
 *
 * Editorial print-magazine vibe. Off-white canvas, warm near-black ink,
 * gradient orbs as the only "color" moments. Light-weight display serif.
 */

:root {
  /* Canvas & ink */
  --canvas: #f5f5f5;
  --canvas-soft: #fafafa;
  --canvas-deep: #0c0a09;
  --surface-card: #ffffff;
  --surface-strong: #f0efed;
  --ink: #0c0a09;
  --ink-primary: #292524;
  --body: #4e4e4e;
  --muted: #777169;
  --muted-soft: #a8a29e;
  --on-primary: #ffffff;

  /* Hairlines */
  --hairline: #e7e5e4;
  --hairline-soft: #f0efed;
  --hairline-strong: #d6d3d1;

  /* Atmospheric gradient orbs (the only "color") */
  --orb-mint: #a7e5d3;
  --orb-peach: #f4c5a8;
  --orb-lavender: #c8b8e0;
  --orb-sky: #a8c8e8;
  --orb-rose: #e8b8c4;

  --semantic-err: #dc2626;

  /* Type families */
  --serif: 'Fraunces', 'Noto Serif KR', 'Nanum Myeongjo', 'Apple SD Gothic Neo', serif;
  --sans:  'Inter', 'Pretendard', 'Noto Sans KR', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Radii */
  --r-sm: 6px;
  --r-md: 8px;
  --r-lg: 12px;
  --r-xl: 16px;
  --r-xxl: 24px;
  --r-pill: 9999px;

  font-family: var(--sans);
  font-size: 16px;
  color-scheme: light;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  background: var(--canvas);
  color: var(--body);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0.01em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

a { color: var(--ink); text-decoration: none; }
a:hover { text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 3px; }

/* ─────────────────── Atmospheric gradient orbs ─────────────────── */
body::before, body::after {
  content: "";
  position: fixed;
  pointer-events: none;
  z-index: -1;
  filter: blur(80px);
  opacity: 0.55;
  border-radius: 50%;
}
body::before {
  width: 520px; height: 520px;
  background: radial-gradient(circle, var(--orb-peach) 0%, transparent 60%);
  top: -120px; right: -120px;
}
body::after {
  width: 600px; height: 600px;
  background: radial-gradient(circle, var(--orb-sky) 0%, transparent 60%);
  bottom: -160px; left: -160px;
}

/* ─────────────────── Top nav ─────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 32px;
  background: rgba(245, 245, 245, 0.85);
  backdrop-filter: saturate(140%) blur(12px);
  -webkit-backdrop-filter: saturate(140%) blur(12px);
  border-bottom: 1px solid var(--hairline);
}
.site-header .brand {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 20px;
  letter-spacing: -0.01em;
  color: var(--ink);
}
.site-header nav { display: flex; gap: 28px; align-items: center; }
.site-header nav a {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: 0;
}
.site-header nav a.cta {
  display: inline-flex;
  align-items: center;
  height: 40px;
  padding: 0 20px;
  background: var(--ink-primary);
  color: var(--on-primary);
  border-radius: var(--r-pill);
  font-weight: 500;
  transition: background 120ms ease;
}
.site-header nav a.cta:hover {
  background: var(--canvas-deep);
  text-decoration: none;
}

/* ─────────────────── Main layout ─────────────────── */
main {
  max-width: 1100px;
  margin: 0 auto;
  padding: 64px 32px 96px;
}

/* ─────────────────── Hero band ─────────────────── */
.hero { padding: 64px 0 80px; }
.hero h1 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin: 0 0 24px;
  max-width: 14ch;
}
.hero .lead {
  font-size: 18px;
  line-height: 1.55;
  color: var(--body);
  max-width: 52ch;
  margin: 0;
}
.hero .lead a {
  color: var(--ink);
  border-bottom: 1px solid var(--hairline-strong);
}

/* ─────────────────── Banner (CMS or static fallback) ─────────────────── */
.banner {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-xxl);
  border: 1px solid var(--hairline);
  background: var(--surface-card);
  margin-bottom: 64px;
}
.banner img {
  display: block;
  width: 100%;
  height: 360px;
  object-fit: cover;
  filter: grayscale(8%) contrast(0.96);
}
.banner-body {
  padding: 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.banner-body .badge {
  display: inline-block;
  align-self: flex-start;
  padding: 4px 10px;
  border-radius: var(--r-pill);
  background: var(--surface-strong);
  color: var(--ink);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.banner-body h2 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 32px;
  line-height: 1.13;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0;
}
.banner-body p {
  margin: 0;
  font-size: 16px;
  color: var(--body);
}
.banner-body p a {
  color: var(--ink);
  border-bottom: 1px solid var(--hairline-strong);
}
.banner-body .credit {
  margin-top: 8px;
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.banner-body .credit a { color: var(--muted); border-bottom: 1px dotted var(--hairline-strong); }

/* ─────────────────── Pros / Cons section ─────────────────── */
.pros-cons {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
  margin: 64px 0;
}
.pros-cons .card {
  background: var(--surface-card);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  padding: 32px;
  border-left-width: 1px;
}
.pros-cons .card h2 {
  font-family: var(--sans);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin: 0 0 16px;
}
.pros-cons .card ul {
  list-style: none;
  margin: 0; padding: 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--body);
}
.pros-cons .card li {
  padding: 8px 0;
  border-bottom: 1px solid var(--hairline-soft);
}
.pros-cons .card li:last-child { border-bottom: none; }
.pros-cons .pros::before, .pros-cons .cons::before {
  content: "";
  display: block;
  width: 32px; height: 32px;
  border-radius: 50%;
  filter: blur(8px);
  margin-bottom: 8px;
  opacity: 0.7;
}
.pros-cons .pros::before { background: var(--orb-mint); }
.pros-cons .cons::before { background: var(--orb-peach); }

/* ─────────────────── Generic card grid ─────────────────── */
.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 24px;
  margin-top: 64px;
}
.card {
  background: var(--surface-card);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  padding: 24px;
}
.card h2 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 0 0 8px;
}
.card p {
  margin: 0;
  font-size: 15px;
  color: var(--body);
}
.card a { color: var(--ink); border-bottom: 1px solid var(--hairline-strong); }

/* ─────────────────── Editorial list (Bali 10) ─────────────────── */
.editorial {
  position: relative;
  margin: 80px 0 64px;
  padding: 56px 48px 64px;
  background: var(--surface-card);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xxl);
  overflow: hidden;
}
.editorial::before {
  content: "";
  position: absolute;
  top: -120px; right: -100px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--orb-mint) 0%, transparent 60%);
  filter: blur(70px);
  opacity: 0.55;
  pointer-events: none;
}
.editorial::after {
  content: "";
  position: absolute;
  bottom: -160px; left: -80px;
  width: 320px; height: 320px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--orb-lavender) 0%, transparent 60%);
  filter: blur(70px);
  opacity: 0.45;
  pointer-events: none;
}
.editorial-head {
  position: relative;
  max-width: 60ch;
  margin: 0 0 48px;
}
.editorial-head .kicker {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 16px;
}
.editorial-head h2 {
  font-family: var(--serif);
  font-weight: 300;
  font-size: clamp(32px, 4.6vw, 56px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  margin: 0 0 20px;
}
.editorial-head .dek {
  font-size: 17px;
  line-height: 1.6;
  color: var(--body);
  margin: 0;
}

.bali-grid {
  position: relative;
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
}
.bali-card {
  display: flex;
  flex-direction: column;
  background: var(--surface-card);
  border: 1px solid var(--hairline);
  border-radius: var(--r-xl);
  overflow: hidden;
  transition: transform 220ms ease, box-shadow 220ms ease;
}
.bali-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 18px 40px -28px rgba(12, 10, 9, 0.35);
}
.bali-card-media {
  position: relative;
  margin: 0;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: var(--surface-strong);
}
.bali-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(6%) contrast(0.97);
  transition: transform 600ms ease;
}
.bali-card:hover .bali-card-media img {
  transform: scale(1.04);
}
.bali-card-media .num {
  position: absolute;
  top: 16px;
  left: 18px;
  font-family: var(--serif);
  font-weight: 300;
  font-size: 36px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--on-primary);
  text-shadow: 0 2px 16px rgba(12, 10, 9, 0.45);
}
.bali-card-body {
  padding: 22px 24px 26px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.bali-card-body .region {
  margin: 0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--muted);
}
.bali-card-body h3 {
  font-family: var(--serif);
  font-weight: 400;
  font-size: 22px;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin: 2px 0 6px;
}
.bali-card-body h3 em {
  display: block;
  font-family: var(--serif);
  font-style: italic;
  font-weight: 300;
  font-size: 14px;
  color: var(--muted);
  margin-top: 2px;
  letter-spacing: 0;
}
.bali-card-body p {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--body);
}
.editorial-foot {
  position: relative;
  margin: 40px 0 0;
  padding-top: 24px;
  border-top: 1px solid var(--hairline);
  font-size: 14px;
  color: var(--muted);
  line-height: 1.7;
}
.editorial-foot em {
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  color: var(--ink-primary);
  letter-spacing: -0.005em;
}
.editorial-foot.credit-line {
  margin-top: 12px;
  padding-top: 0;
  border-top: none;
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.editorial-foot.credit-line a {
  color: var(--muted);
  border-bottom: 1px dotted var(--hairline-strong);
}

/* ─────────────────── Footer ─────────────────── */
.site-footer {
  border-top: 1px solid var(--hairline);
  padding: 48px 32px;
  text-align: center;
  color: var(--muted);
  font-size: 14px;
  background: var(--canvas);
}
.site-footer small { letter-spacing: 0.02em; }

/* ─────────────────── Responsive ─────────────────── */
@media (max-width: 860px) {
  .editorial { padding: 40px 28px 48px; }
  .bali-grid { grid-template-columns: 1fr; gap: 20px; }
  .bali-card-media .num { font-size: 30px; }
}
@media (max-width: 640px) {
  main { padding: 32px 20px 64px; }
  .site-header { padding: 0 20px; }
  .hero { padding: 32px 0 48px; }
  .banner img { height: 240px; }
  .banner-body { padding: 24px; }
  .editorial { padding: 32px 20px 40px; border-radius: var(--r-xl); }
  .editorial-head { margin-bottom: 32px; }
  .bali-card-body { padding: 20px 20px 24px; }
  .bali-card-body h3 { font-size: 20px; }
}
