body { font-family: Arial, sans-serif; color:#111; }
.header { text-align:center; margin: 10px 0 20px; }
.header h1 { margin:0; font-size: 20px; }
.header p { margin:4px 0; font-size: 12px; color:#555; }
.branding { margin: 0 0 8px; font-size: 13px; color:#274c77; }
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 10px; }
.card { border:1px solid #ccc; border-radius:6px; padding:10px; }
.name { font-weight:600; color:#183661; display:flex; align-items:center; gap:8px; }
.icons { display:flex; gap:6px; align-items:center; }
.icons img { width:18px; height:18px; vertical-align:middle; }
.meta { font-size: 12px; color:#333; margin-top: 4px; }
.footer { margin-top: 16px; font-size: 11px; color:#888; text-align:center; }
/* Ensure partner logos render on white regardless of page background */
.print-partner-banner .ppb-left img { background:#fff; padding:2pt; border-radius:2pt; }
/* Centralized PDF header/footer styles used by print_teachers_nm */
.pdfx-header { background: linear-gradient(135deg, #183661 0%, #fd7e14 100%); color: #fff; padding: 12px; margin-bottom: 6pt; }
.pdfx-header-content { display: flex; justify-content: space-between; align-items: center; }
.pdfx-pmtnm-logo { font-size: 20pt; font-weight: 700; letter-spacing: 2px; }
.pdfx-tagline { font-size: 9pt; margin-top: 2px; opacity: 0.9; }
.pdfx-document-type { font-size: 12pt; font-weight: 700; text-align: right; }
.pdfx-footer { position: fixed; bottom: 0; left: 0; right: 0; background: #183661; color: #fff; padding: 8px 16px; font-size: 8pt; }
.pdfx-footer-content { display: flex; justify-content: space-between; align-items: center; }
.pdfx-footer-left, .pdfx-footer-right { line-height: 1.3; }
.pdfx-footer-right { text-align: right; }
@media print {
  .no-print, 
  .no-print *,
  div.no-print,
  div.no-print * { 
    display: none !important; 
    visibility: hidden !important;
  }
  body { margin: 0.25in; }
  .grid { grid-template-columns: repeat(3, 1fr); }
  .pdfx-header { background: #183661 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .pdfx-footer { background: #183661 !important; -webkit-print-color-adjust: exact; }
  .pdfx-header, .pdfx-header * { color: #fff !important; }
  .pdfx-footer, .pdfx-footer * { color: #fff !important; }
}

@media (max-width: 768px) {
  .grid { grid-template-columns: 1fr; }
  .contact-preferences-display { justify-content: center; }
}

@media (max-width: 600px) {
  .contact-preference-icon {
    width: 18px;
    height: 18px;
    font-size: 10px;
  }
}
.no-print a { color:#183661; text-decoration:none; }
.badge { color:#0a7; font-weight:600; font-size: 12px; }
.links { font-size: 12px; }

/* Contact preference icons */
.contact-preferences-display {
    display: flex;
    flex-wrap: wrap;
    gap: 4px;
    margin-top: 6px;
}

.contact-preference-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    font-size: 11px;
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid;
    transition: transform 0.2s ease;
    cursor: help;
}

.contact-preference-icon:hover {
    transform: scale(1.2);
}


/* Partner banner base styles */
.print-partner-banner { margin-top: 4pt; }
.print-partner-banner .ppb-name { color: #111; }
.print-partner-banner .ppb-partnership { color: #111; }

@media print {
  .print-partner-banner img { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
}
