/* ============================================================
   LEAF v3 — Policy Page Styles
   ============================================================ */

.policy-hero {
  min-height: 40vh;
  display: flex;
  align-items: flex-end;
  padding: 0 var(--gutter) clamp(48px, 8vw, 96px);
  background: var(--c-bg-2);
  border-bottom: 1px solid var(--c-border);
  padding-top: 120px;
}

.policy-hero-content {
  max-width: var(--max-w);
  margin: 0 auto;
  width: 100%;
}

.policy-section {
  padding: var(--sp-xl) 0 var(--sp-2xl);
  background: var(--c-bg);
}

.policy-inner {
  max-width: 760px;
  margin: 0 auto;
  padding: 0 var(--gutter);
  display: flex;
  flex-direction: column;
  gap: 48px;
}

.policy-intro {
  font-size: 15px;
  line-height: 2.2;
  color: var(--c-text-dim);
  padding-bottom: 48px;
  border-bottom: 1px solid var(--c-border);
}

.policy-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--c-border);
}

.policy-heading {
  font-family: var(--f-serif);
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 400;
  color: var(--c-white);
  line-height: 1.3;
}

.policy-block p {
  font-size: 14px;
  line-height: 2.2;
  color: var(--c-text-dim);
}

.policy-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.policy-list li {
  font-size: 14px;
  line-height: 1.8;
  color: var(--c-text-dim);
  padding-left: 20px;
  position: relative;
}

.policy-list li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 10px;
  width: 6px;
  height: 1px;
  background: var(--c-accent);
}

.policy-contact {
  margin-top: 8px;
  padding: 24px;
  border: 1px solid var(--c-border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.policy-contact p {
  font-size: 14px;
  color: var(--c-text-dim);
  margin: 0;
}

.policy-contact a {
  color: var(--c-accent);
  transition: opacity var(--t-fast);
}

.policy-contact a:hover {
  opacity: 0.7;
}

.policy-date {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.policy-date p {
  font-family: var(--f-sans);
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--c-text-mute);
}

.policy-back {
  padding-top: 16px;
}

.policy-back .btn {
  color: var(--c-white);
  border-color: var(--c-border-2);
}
