/* ============================================
   integrated — v1 톤 + v2 카드 정리
   ============================================ */

.page {
  max-width: 920px;
  margin: 0 auto;
  padding: 0 28px 96px;
}

/* ===== STRIP ===== */
.strip {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid var(--rule-strong);
  margin-bottom: var(--gap-12);
  flex-wrap: wrap;
  gap: var(--gap-3);
}
.strip-l, .strip-r { display: flex; gap: var(--gap-4); flex-wrap: wrap; align-items: center; }
.strip-r a { color: var(--ink); text-decoration: none; }
.strip-r a:hover { text-decoration: underline; }

/* ===== HERO ===== */
.hero { margin-bottom: var(--gap-12); }

.hero-eyebrow {
  margin: 0 0 14px;
  color: var(--muted);
}

.hero-headline {
  font-family: var(--font-kr);
  font-size: var(--t-h1);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 700;
  margin: 0 0 10px;
  color: var(--ink);
  max-width: 22ch;
}
body[data-lang="en"] .hero-headline { font-family: var(--font-en); letter-spacing: -0.025em; max-width: 28ch; }

.hero-voice {
  margin: 0 0 var(--gap-8);
  color: var(--muted);
  letter-spacing: 0.02em;
}

.hero-sub {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 64ch;
  margin-bottom: var(--gap-8);
}
.hero-sub p {
  margin: 0;
  font-size: var(--t-body);
  line-height: 1.55;
  color: var(--ink-soft);
}
.hero-sub b { color: var(--ink); font-weight: 600; }
.hero-side { margin-top: 4px !important; color: var(--ink-soft); }

.howiwork {
  margin-top: var(--gap-8);
  border-top: 1px solid var(--rule-strong);
  padding-top: 18px;
}
.howiwork-h {
  margin: 0 0 var(--gap-3);
  color: var(--muted);
  font-size: var(--t-meta);
  font-weight: 600;
  letter-spacing: 0.06em;
}

.manifesto {
  list-style: none;
  margin: 0 0 var(--gap-4);
  padding: 0;
  border-top: 1px solid var(--rule);
}
.manifesto li {
  display: grid;
  grid-template-columns: 44px 1fr;
  gap: var(--gap-3);
  align-items: baseline;
  padding: 14px 0;
  border-bottom: 1px solid var(--rule);
  font-size: var(--t-body);
  line-height: 1.5;
  color: var(--ink-soft);
}
.manifesto .num { padding-top: 4px; color: var(--muted); }

/* ===== HR ===== */
.rule { border: 0; border-top: 1px solid var(--rule-strong); margin: var(--gap-12) 0; height: 0; }

/* ===== SECTION HEAD ===== */
.section-h {
  font-family: var(--font-kr);
  font-size: var(--t-h2);
  font-weight: 700;
  letter-spacing: -0.01em;
  margin: 0 0 var(--gap-6);
  color: var(--ink);
}
body[data-lang="en"] .section-h { font-family: var(--font-en); }

/* ===== BOX DETAIL ===== */
.box-detail {
  margin-bottom: var(--gap-8);
  background: var(--bg-card);
  border: 1px solid var(--ink);
}
.box-detail.box-prev {
  border: 1px solid var(--rule-strong);
  background: transparent;
}
.box-head {
  display: flex;
  align-items: center;
  gap: var(--gap-3);
  padding: 14px 18px;
  border-bottom: 1px solid var(--ink);
  background: var(--ink);
  color: var(--bg);
  flex-wrap: wrap;
}
.box-head-prev {
  background: transparent;
  color: var(--ink);
  border-bottom: 1px solid var(--rule-strong);
}
.box-head-prev .box-tag,
.box-head-prev .box-meta { color: var(--muted); opacity: 1; }
.box-head-prev .box-h { color: var(--ink); font-size: var(--t-body); font-weight: 600; }
.box-tag { color: var(--bg); opacity: 0.7; }
.box-h {
  margin: 0;
  font-family: var(--font-kr);
  font-size: var(--t-h3);
  font-weight: 600;
  letter-spacing: -0.01em;
  flex: 1;
  min-width: 0;
}
body[data-lang="en"] .box-h { font-family: var(--font-en); }
.box-meta { color: var(--bg); opacity: 0.8; }

.box-body { padding: 22px 18px 18px; }
.box-body > p {
  margin: 0 0 14px;
  font-size: var(--t-body);
  line-height: var(--leading-body);
  color: var(--ink-soft);
}
.box-body > p:last-of-type { margin-bottom: 18px; }
.box-body b { color: var(--ink); font-weight: 600; }
.box-body p.muted { color: var(--muted); font-size: var(--t-meta); margin-top: -6px; }

/* ===== ENGAGEMENT HEAD ===== */
.engagements-h {
  margin: 6px 0 6px;
  font-size: var(--t-meta);
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
  color: var(--muted);
  text-transform: uppercase;
  font-weight: 600;
}

/* ===== CHECKLIST ===== */
.checklist {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--rule);
}
.checklist li {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--gap-3);
  padding: 12px 0;
  border-bottom: 1px solid var(--rule);
  font-size: var(--t-body);
  color: var(--ink);
  align-items: baseline;
}
.checklist .lbl { color: var(--muted); }
.key-tag {
  display: inline-block;
  background: var(--ink);
  color: var(--bg);
  padding: 1px 6px;
  border-radius: 3px;
  margin-right: 6px;
  vertical-align: 1px;
  font-size: 10px;
  letter-spacing: 0.06em;
}

/* ===== PRODUCT CARD ===== */
.product-card {
  border-top: 1px solid var(--rule);
  padding: 18px 0;
}
.product-card:first-of-type { border-top: 0; padding-top: 0; }
.product-card.past { opacity: 0.85; }

.product-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--gap-3);
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.product-h {
  margin: 0;
  font-family: var(--font-kr);
  font-size: var(--t-h3);
  font-weight: 600;
  letter-spacing: -0.01em;
}
body[data-lang="en"] .product-h { font-family: var(--font-en); }
.product-meta { color: var(--muted); }

.product-card p {
  margin: 6px 0;
  font-size: var(--t-body);
  line-height: var(--leading-body);
  color: var(--ink-soft);
}

.stack-row {
  list-style: none;
  margin: 10px 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 0;
}
.stack-row li {
  display: inline-block;
  padding: 3px 8px;
  border: 1px solid var(--rule-strong);
  margin-right: 6px;
  margin-bottom: 4px;
  font-size: var(--t-mono);
  color: var(--ink);
}

.bullets {
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
}
.bullets li {
  position: relative;
  padding-left: 16px;
  margin-bottom: 4px;
  font-size: var(--t-meta);
  line-height: 1.5;
  color: var(--ink-soft);
}
.bullets li::before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--muted);
}

.prod-link { margin: 6px 0 0 !important; }
.prod-link a {
  color: var(--ink);
  text-decoration: none;
  font-size: var(--t-mono);
  letter-spacing: 0.02em;
}
.prod-link a:hover { text-decoration: underline; }

/* ===== HARNESS ROWS ===== */
.harness-rows {
  list-style: none;
  margin: 16px 0 0;
  padding: 0;
  border-top: 1px solid var(--rule);
}
.harness-rows > li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--gap-4);
  padding: 16px 0;
  border-bottom: 1px solid var(--rule);
  align-items: start;
}
.harness-rows .lbl { color: var(--muted); padding-top: 2px; }
.harness-rows h4 {
  margin: 0 0 4px;
  font-size: var(--t-body);
  font-weight: 600;
  color: var(--ink);
}
body[data-lang="en"] .harness-rows h4 { font-family: var(--font-en); }
.harness-rows p {
  margin: 0;
  font-size: var(--t-meta);
  color: var(--ink-soft);
  line-height: 1.55;
}

.meta-note {
  margin: var(--gap-6) 0 0;
  padding: 14px 16px;
  border: 1px solid var(--ink);
  background: var(--hl);
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: var(--gap-3);
  align-items: baseline;
}
.meta-note .lbl { color: var(--muted); }
.meta-note p {
  margin: 0;
  font-size: var(--t-meta);
  color: var(--ink);
  line-height: 1.55;
}

/* ===== STACK GRID ===== */
.stack-grid {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px var(--gap-8);
  margin: 0;
}
.stack-grid dt {
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: var(--t-mono);
  letter-spacing: 0.04em;
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}
.stack-grid dd {
  margin: 0;
  font-size: var(--t-body);
  line-height: 1.6;
  color: var(--ink);
  padding-top: 12px;
  border-top: 1px solid var(--rule);
}

/* ===== TIMELINE ===== */
.time-list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--rule);
}
.time-list li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--gap-3);
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
  font-size: var(--t-body);
  color: var(--ink);
  align-items: baseline;
}
.time-list .date { color: var(--ink); }

/* ===== CREDS ===== */
.creds-list { list-style: none; margin: 0; padding: 0; }
.creds-list > li {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--gap-4);
  padding: 18px 0;
  border-top: 1px solid var(--rule);
  font-size: var(--t-body);
  color: var(--ink);
  align-items: baseline;
}
.creds-list > li:last-child { border-bottom: 1px solid var(--rule); }
.creds-list .lbl { color: var(--muted); padding-top: 4px; }

.creds-sub {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.creds-sub > li {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 4px 12px;
  padding-bottom: 8px;
  border-bottom: 1px dashed var(--rule);
}
.creds-sub > li:last-child { border-bottom: 0; padding-bottom: 0; }
.creds-meta { color: var(--muted); margin-left: auto; white-space: nowrap; }

/* ===== CONTACT ===== */
.contact-list {
  list-style: none; margin: 0; padding: 0;
}
.contact-list li {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: var(--gap-3);
  padding: 10px 0;
  border-bottom: 1px solid var(--rule);
  font-size: var(--t-meta);
}
.contact-list .lbl { color: var(--muted); }
.contact-list a { color: var(--ink); text-decoration: none; }
.contact-list a:hover { text-decoration: underline; }

/* ===== FOOTER ===== */
.foot { margin-top: var(--gap-16); display: flex; justify-content: space-between; align-items: baseline; gap: var(--gap-4); flex-wrap: wrap; }
.foot p { margin: 0; color: var(--muted); }
.foot-back a { color: var(--ink); text-decoration: none; }
.foot-back a:hover { text-decoration: underline; }
.foot-voice { color: var(--ink-soft) !important; letter-spacing: 0.02em; }

/* ===== MOBILE ===== */
@media (max-width: 768px) {
  .page { padding: 0 18px 64px; }
  .strip { padding: 14px 0; }

  .manifesto li {
    grid-template-columns: 32px 1fr;
    font-size: var(--t-body);
    padding: 11px 0;
  }

  .checklist li { grid-template-columns: 1fr; gap: 4px; }
  .harness-rows > li { grid-template-columns: 1fr; gap: 4px; }
  .harness-rows .lbl { padding-top: 0; }
  .meta-note { grid-template-columns: 1fr; gap: 4px; }
  .time-list li { grid-template-columns: 1fr; gap: 4px; }
  .contact-list li { grid-template-columns: 1fr; gap: 4px; }
  .creds-list > li { grid-template-columns: 1fr; gap: 8px; }
  .creds-meta { margin-left: 0; }
  .stack-grid { grid-template-columns: 1fr; gap: 4px var(--gap-2); }
  .stack-grid dt { padding-top: 14px; }
  .stack-grid dd { border-top: 0; padding-top: 4px; padding-bottom: 4px; }

  .box-head { padding: 12px 14px; }
  .box-body { padding: 16px 14px; }
}

@media (max-width: 480px) {
  .lang-toggle { top: 12px; right: 12px; }
  .product-head { flex-direction: column; align-items: flex-start; gap: 4px; }
}
