/* legal.css - Shared styles for terms.html and privacy.html */

/* Fade-in transition on page load */
.legal-content {
  max-width: 900px;
  margin: 0 auto;
  padding: 100px 20px 40px;
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
}

.legal-content.loaded {
  opacity: 1;
}

.legal-content h1 {
  font-size: 32px;
  margin-bottom: 10px;
  color: var(--text-primary);
}

.legal-content .version {
  color: var(--text-secondary);
  font-size: 14px;
  margin-bottom: 30px;
}

.legal-content h2 {
  font-size: 24px;
  margin-top: 40px;
  margin-bottom: 16px;
  color: var(--text-primary);
  border-bottom: 2px solid var(--border-color);
  padding-bottom: 8px;
}

.legal-content h3 {
  font-size: 18px;
  margin-top: 24px;
  margin-bottom: 12px;
  color: var(--text-primary);
}

.legal-content p {
  line-height: 1.7;
  margin-bottom: 16px;
  color: var(--text-primary);
}

.legal-content ul {
  line-height: 1.7;
  margin-bottom: 16px;
  padding-left: 24px;
  color: var(--text-primary);
}

.legal-content li {
  margin-bottom: 8px;
}

.legal-content a {
  color: var(--primary-color);
}

/* Back link */
.back-link {
  display: inline-block;
  margin-bottom: 20px;
  color: var(--primary-color);
  text-decoration: none;
}

.back-link:hover {
  text-decoration: underline;
}

/* Section icon (SVG in headings) */
.legal-icon {
  width: 24px;
  height: 24px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 8px;
}

/* Footer separator and links */
.legal-separator {
  margin: 40px 0;
  border: none;
  border-top: 1px solid var(--border-color);
}

.legal-footer {
  text-align: center;
  color: var(--text-secondary);
  font-size: 14px;
}

.legal-footer a {
  color: var(--primary-color);
}

/* Beta notice (terms.html) */
.beta-notice {
  background-color: var(--warning-bg, #fff3cd);
  border: 1px solid var(--warning-border, #ffc107);
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 30px;
}

.beta-notice h2 {
  margin-top: 0;
  font-size: 20px;
  color: var(--warning-text, #856404);
  border-bottom: none;
}

.beta-notice p {
  margin-bottom: 8px;
  color: var(--warning-text, #856404);
}

.beta-notice strong {
  font-weight: 600;
}

/* Privacy highlight (privacy.html) */
.privacy-highlight {
  background-color: var(--success-bg, #d4edda);
  border: 1px solid var(--success-border, #28a745);
  border-radius: 8px;
  padding: 20px;
  margin-bottom: 30px;
}

.privacy-highlight h2 {
  margin-top: 0;
  font-size: 20px;
  color: var(--success-text, #155724);
  border-bottom: none;
}

.privacy-highlight p {
  margin-bottom: 8px;
  color: var(--success-text, #155724);
}

.privacy-highlight ul {
  margin-bottom: 0;
  color: var(--success-text, #155724);
}

/* Data table (privacy.html) */
.data-table {
  width: 100%;
  border-collapse: collapse;
  margin: 20px 0;
}

.data-table th,
.data-table td {
  padding: 12px;
  text-align: left;
  border: 1px solid var(--border-color);
}

.data-table th {
  background-color: var(--card-bg);
  font-weight: 600;
  color: var(--text-primary);
}

.data-table td {
  color: var(--text-primary);
}

/* Dark mode */
.dark .legal-content h1,
.dark .legal-content h2,
.dark .legal-content h3,
.dark .legal-content p,
.dark .legal-content ul,
.dark .legal-content li {
  color: var(--dark-text);
}

.dark .legal-content .version {
  color: var(--dark-text-secondary);
}

.dark .legal-content h2 {
  border-bottom-color: var(--dark-border);
}

.dark .back-link {
  color: var(--dark-primary);
}

.dark .legal-separator {
  border-top-color: var(--dark-border);
}

.dark .legal-footer {
  color: var(--dark-text-secondary);
}

.dark .beta-notice {
  background-color: rgba(255, 193, 7, 0.15);
  border-color: rgba(255, 193, 7, 0.3);
}

.dark .beta-notice h2,
.dark .beta-notice p,
.dark .beta-notice ul,
.dark .beta-notice li {
  color: #ffc107;
}

.dark .privacy-highlight {
  background-color: rgba(40, 167, 69, 0.15);
  border-color: rgba(40, 167, 69, 0.3);
}

.dark .privacy-highlight h2,
.dark .privacy-highlight p,
.dark .privacy-highlight ul {
  color: #4caf50;
}
