/* ============================================================
   POLICY PAGES — Terms, Cancellation, Privacy
   Condortrekk Theme v1.8.2
   ============================================================ */

/* Policy nav sticky */
.policy-nav {
  background: var(--color-primary);
  position: sticky;
  top: 0;
  z-index: 90;
  border-bottom: 2px solid var(--color-accent);
}
.policy-nav__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0;
  overflow-x: auto;
}
.policy-nav__list a {
  display: block;
  padding: 0.75rem 1.25rem;
  color: rgba(255,255,255,0.75);
  text-decoration: none;
  font-size: 0.85rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
  transition: color 0.2s, background 0.2s;
}
.policy-nav__list a:hover {
  color: #fff;
  background: rgba(255,255,255,0.1);
}

/* Content layout */
.policy-content__wrap {
  max-width: 860px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}
.policy-content__intro {
  font-size: 1.1rem;
  line-height: 1.7;
  margin-bottom: 0.5rem;
}
.policy-content__meta {
  font-size: 0.8rem;
  color: var(--color-text-light);
  margin-bottom: 3rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-border);
}

/* Policy sections */
.policy-section {
  margin-bottom: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--color-border);
  scroll-margin-top: 80px;
}
.policy-section:last-child {
  border-bottom: none;
}
.policy-section__title {
  font-size: 1.5rem;
  color: var(--color-primary);
  margin-bottom: 1.5rem;
  padding-bottom: 0.5rem;
  border-bottom: 3px solid var(--color-accent);
  display: inline-block;
}
.policy-section h3 {
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
  margin: 1.5rem 0 0.5rem;
}
.policy-section p,
.policy-section li {
  font-size: 0.95rem;
  line-height: 1.75;
  color: var(--color-text);
}
.policy-section ul {
  padding-left: 1.5rem;
  margin-bottom: 1rem;
}
.policy-section li {
  margin-bottom: 0.4rem;
}
.policy-section a {
  color: var(--color-accent);
  text-decoration: underline;
}

/* Cancellation table */
.policy-table-wrap {
  overflow-x: auto;
  margin: 1.5rem 0;
  border-radius: 8px;
  border: 1px solid var(--color-border);
}
.policy-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}
.policy-table th {
  background: var(--color-primary);
  color: #fff;
  padding: 0.75rem 1rem;
  text-align: left;
  font-weight: 600;
}
.policy-table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--color-border);
}
.policy-table tr:last-child td {
  border-bottom: none;
}
.policy-table tr:nth-child(even) td {
  background: var(--color-bg-light, #f9f9f9);
}
.policy-table__good { color: #2a9d2a; font-weight: 600; }
.policy-table__warn { color: #c97d00; font-weight: 600; }
.policy-table__bad  { color: #c0392b; font-weight: 600; }

.policy-note {
  font-size: 0.85rem;
  background: #fff8e1;
  border-left: 4px solid #f0c040;
  padding: 0.75rem 1rem;
  border-radius: 0 4px 4px 0;
  margin-top: 0.5rem;
}

/* ============================================================
   RESPONSIVE — Tablet & Mobile
   ============================================================ */
@media (max-width: 768px) {
  .policy-nav__list a {
    padding: 0.6rem 0.85rem;
    font-size: 0.78rem;
  }
  .policy-content__wrap {
    padding: 2rem 1rem;
  }
  .policy-section__title {
    font-size: 1.25rem;
  }
  .policy-table th,
  .policy-table td {
    padding: 0.6rem 0.75rem;
    font-size: 0.82rem;
  }
}

@media (max-width: 480px) {
  .policy-table th:nth-child(3),
  .policy-table td:nth-child(3) {
    display: none; /* hide "fee" column on very small screens, keep refund % */
  }
}

/* Policy list — bullets visibles */
.policy-section ul,
.policy-section .policy-list {
  list-style-type: disc !important;
  padding-left: 2rem !important;
  margin: 1rem 0 1.5rem !important;
}
.policy-section ul li,
.policy-section .policy-list li {
  display: list-item !important;
  list-style: disc outside !important;
  margin-bottom: 0.5rem;
  line-height: 1.6;
  color: var(--color-gray-700);
}

