/*
 * ========================================================================
 * ANALYTIC ENDEAVORS - GUIDE PAGE COMPONENTS
 * Reusable component styles shared across guide pages
 * Copyright (c) 2024-2025 Analytic Endeavors Inc. All Rights Reserved.
 * ========================================================================
 *
 * Provides: callout boxes, pro-tips, tip-items, gotcha-cards,
 *           demo-boxes, footnotes.
 *
 * Load order: After guide-layout.css, before presentation.css
 */

/* ===== CALLOUT BOXES ===== */
.callout {
  background: rgba(0, 88, 124, 0.15);
  border: 1px solid var(--blue);
  border-left: 4px solid var(--blue);
  border-radius: 10px;
  padding: 1rem 1.25rem;
  margin-top: 1.5rem;
  font-size: 0.9rem;
  color: var(--text-secondary);
  line-height: 1.5;
}

.callout--teal {
  background: rgba(0, 153, 153, 0.1);
  border-color: var(--teal);
  border-left-color: var(--teal);
}

.callout--orange {
  background: rgba(255, 140, 66, 0.1);
  border-color: var(--orange);
  border-left-color: var(--orange);
}

.callout--danger {
  background: rgba(255, 107, 107, 0.08);
  border-color: var(--danger);
  border-left-color: var(--danger);
}

.callout strong { color: var(--text-primary); }

[data-theme="light"] .callout {
  background: rgba(0, 88, 124, 0.05);
  border-color: rgba(0, 88, 124, 0.2);
}

[data-theme="light"] .callout--teal {
  background: rgba(0, 153, 153, 0.05);
  border-color: rgba(0, 153, 153, 0.2);
  border-left-color: var(--teal);
}

[data-theme="light"] .callout--orange {
  background: rgba(255, 140, 66, 0.05);
  border-color: rgba(255, 140, 66, 0.2);
  border-left-color: var(--orange);
}

[data-theme="light"] .callout--danger {
  background: rgba(255, 107, 107, 0.04);
  border-color: rgba(255, 107, 107, 0.2);
  border-left-color: var(--danger);
}

/* ===== PRO-TIPS SECTION ===== */
.pro-tips {
  background: linear-gradient(135deg, var(--card-bg), var(--card-surface));
  border-radius: 20px;
  padding: 3rem;
  margin-top: 2rem;
  border: 1px solid var(--border);
}

.pro-tips h3 {
  font-size: 1.5rem;
  margin-bottom: 2rem;
  text-align: center;
  color: var(--text-primary);
}

.tip-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  max-width: 1100px;
  margin: 0 auto;
}

/* Step pass-through: flex-stretch so tip-items fill equal height
   (margin-bottom: 0 handled by general rule in guide-layout.css) */
.tip-grid > .step {
  display: flex;
}
.tip-grid > .step > .tip-item {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.tip-item {
  background: var(--card-bg);
  border-radius: 12px;
  padding: 1.5rem;
  border-left: 3px solid var(--teal);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.tip-item:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.tip-item:nth-child(even) { border-left-color: var(--blue); }
.tip-item h4 { font-size: 1rem; margin-bottom: 0.5rem; color: var(--text-primary); }
.tip-item p { color: var(--text-secondary); font-size: 0.9rem; line-height: 1.6; }

[data-theme="light"] .pro-tips { background: var(--card-bg); border: none; }
[data-theme="light"] .tip-item { background: var(--card-bg); }

/* ===== GOTCHA CARDS ===== */
.gotcha-card {
  background: var(--card-surface);
  border-radius: 12px;
  padding: 1.5rem;
  border: 1px solid var(--border);
  border-left: 3px solid var(--orange);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.gotcha-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 10px 30px rgba(255, 140, 66, 0.15);
}

.gotcha-card h4 {
  color: var(--orange);
  font-size: 1rem;
  margin-bottom: 0.5rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.gotcha-card p {
  color: var(--text-secondary);
  font-size: 0.9rem;
  line-height: 1.6;
}

[data-theme="light"] .gotcha-card { background: var(--card-bg); }

/* ===== DEMO BOXES ===== */
.demo-box {
  background: var(--card-bg);
  border-radius: 10px;
  padding: 1.25rem;
  border: 1px solid var(--border);
  margin-top: 1rem;
}

.demo-box-title {
  font-size: 0.8rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 0.75rem;
}

.demo-output {
  background: var(--card-surface);
  border-radius: 6px;
  padding: 1rem;
  text-align: center;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text-primary);
}

[data-theme="light"] .demo-box { background: var(--card-bg); }
[data-theme="light"] .demo-output { background: var(--card-bg); }

/* ===== FOOTNOTES ===== */
.footnote {
  font-size: 0.75rem;
  color: var(--text-muted);
  margin-top: 0.5rem;
  font-style: italic;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .tip-grid { grid-template-columns: 1fr; }
  .pro-tips { padding: 1.5rem; }
}
