/* 14-print.css — Print Button Styles and @media print Rules */

/* ══════════════════════════════════════
   PRINT / PDF EXPORT
══════════════════════════════════════ */
.btn-print {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  background: var(--cobalt-pale); border: 1px solid var(--cobalt-light);
  color: var(--cobalt); border-radius: 6px;
  font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500;
  cursor: pointer; transition: background 0.15s, border-color 0.15s;
  margin-top: 10px; width: 100%;
}
.btn-print:hover { background: var(--cobalt-pale); border-color: var(--cobalt); }

@media print {
  /* Hide all chrome */
  .sidebar,
  .topbar,
  .workbook-overlay,
  .onboarding,
  .modal-overlay,
  .coming-soon-toast,
  .next-phase-cta,
  .btn-toolkit-online,
  .btn-toolkit-download,
  .btn-download,
  .btn-print,
  .toolkit-choice-card,
  .toolkit-card,
  .side-card,
  .jt-panel,
  .emo-callout,
  .wb-gate-warning,
  .wb-gate-toast,
  .back-to-top-btn,
  .preview-banner { display: none !important; }

  /* Reset layout for print */
  html, body { height: auto !important; overflow: visible !important; background: white !important; }
  .portal-shell { display: block !important; height: auto !important; overflow: visible !important; }
  .main { margin: 0 !important; padding: 0 !important; height: auto !important; overflow: visible !important; width: 100% !important; }
  .content-scroll { overflow: visible !important; height: auto !important; padding: 20px 40px !important; }

  /* Show only the active phase */
  .phase-content { display: none !important; }
  .phase-content.active { display: block !important; }

  /* Phase header */
  .phase-header {
    background: white !important;
    border-bottom: 2px solid #1C3A56 !important;
    padding: 20px 0 16px !important;
    margin-bottom: 24px !important;
    page-break-after: avoid;
  }
  .phase-header h1 { font-size: 22pt !important; color: #1C3A56 !important; }
  .phase-header-phase-num { font-size: 10pt !important; color: #5C4A38 !important; letter-spacing: 0.08em; text-transform: uppercase; margin-bottom: 6px; }
  .phase-header-sub { font-size: 10pt !important; color: #5C4A38 !important; }
  .phase-meta { display: flex; flex-wrap: wrap; gap: 16px; margin-top: 12px; }
  .phase-meta-label { font-size: 8pt; color: #8C7A68; text-transform: uppercase; letter-spacing: 0.08em; }
  .phase-meta-value { font-size: 10pt; color: #1C3A56; font-weight: 600; }

  /* Body layout — stack columns */
  .phase-body { display: block !important; }
  .phase-body > div { display: block !important; }
  .phase-body > div > * { margin-bottom: 20px; }

  /* Cards */
  .overview-card,
  .pathway-briefing-card,
  .insight-box {
    border: 1px solid #ddd !important;
    padding: 16px !important;
    border-radius: 0 !important;
    page-break-inside: avoid;
    background: white !important;
    box-shadow: none !important;
  }
  .card-title { font-size: 10pt !important; font-weight: 700 !important; color: #1C3A56 !important; margin-bottom: 8px; text-transform: uppercase; letter-spacing: 0.06em; }
  .overview-text { font-size: 10pt !important; line-height: 1.6 !important; color: #2A1F14 !important; }
  .insight-label { font-size: 10pt !important; text-transform: uppercase; letter-spacing: 0.08em; color: #B8924A !important; font-weight: 700; margin-bottom: 4px; }
  .insight-text { font-size: 10pt !important; color: #5C4A38 !important; font-style: italic; }

  /* Task list */
  .task-list { list-style: none; padding: 0; margin: 0; }
  .task-item {
    display: flex; align-items: flex-start; gap: 10px;
    padding: 8px 0; border-bottom: 1px solid #eee;
    page-break-inside: avoid;
  }
  .task-check {
    width: 14px; height: 14px; flex-shrink: 0;
    border: 1.5px solid #1C3A56; border-radius: 3px; margin-top: 2px;
  }
  .task-item.done .task-check::after { content: "\2713"; font-size: 10px; color: #1C3A56; display: block; text-align: center; line-height: 14px; }
  .task-text { font-size: 10pt !important; color: #2A1F14 !important; flex: 1; line-height: 1.5; }
  .task-tag { font-size: 8pt !important; padding: 2px 6px; border-radius: 3px; flex-shrink: 0; }

  /* Doc checklist */
  .doc-category-title { font-size: 11pt !important; font-weight: 700 !important; color: #1C3A56 !important; margin: 16px 0 8px; }
  .doc-item { padding: 6px 0; border-bottom: 1px solid #eee; page-break-inside: avoid; }
  .doc-item-name { font-size: 10pt !important; color: #2A1F14 !important; }
  .doc-item-detail { font-size: 9pt !important; color: #5C4A38 !important; }

  /* Print footer */
  @page {
    margin: 0.75in;
    @bottom-center { content: "GEO Expedition Portal \2014 Italy  \00B7  geo-italy.com  \00B7  Page " counter(page) " of " counter(pages); font-size: 8pt; color: #8C7A68; }
  }

  /* Page break helpers */
  h2, h3 { page-break-after: avoid; }
  .overview-card, .phase-body > div > div { page-break-inside: avoid; }
}

/* Workbook gate toast */
.wb-gate-warning {
  display: none;
  margin-top: 10px;
  padding: 10px 14px;
  background: #fff8f0;
  border: 1px solid var(--terracotta);
  border-left: 3px solid var(--terracotta);
  color: var(--terracotta);
  font-size: 11px;
  font-family: 'DM Sans', sans-serif;
  line-height: 1.5;
  letter-spacing: 0.02em;
}
.wb-gate-warning.visible { display: block; }

.wb-gate-toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  background: var(--cobalt); border: 1px solid var(--terracotta);
  color: white; padding: 12px 22px; font-family: 'DM Sans', sans-serif;
  font-size: 12px; letter-spacing: 0.05em; z-index: 9999;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s;
  white-space: nowrap;
}
.wb-gate-toast.show { opacity: 1; pointer-events: auto; }
