/**
 * SNF Compare - Shared Card Styles
 * Single source of truth for card components across all pages
 */

/* ============================================
   FACILITY LIST GRID
   ============================================ */
.facility-list { max-width:1400px; margin:0 auto; padding:0 20px 200px; display:grid; grid-template-columns:1fr; gap:12px; }
@media (min-width:768px) { .facility-list { grid-template-columns:repeat(2,1fr); gap:16px; } }
@media (min-width:1200px) { .facility-list { grid-template-columns:repeat(3,1fr); } }

/* ============================================
   BASE CARD STRUCTURE
   ============================================ */
.facility-card { position:relative; background:white; border-radius:14px; border:1px solid #e5e7eb; box-shadow:0 1px 3px rgba(0,0,0,.04); transition:all .2s; cursor:pointer; overflow:hidden; }
.facility-card:hover { border-color:#d1d5db; box-shadow:0 4px 12px rgba(0,0,0,.08); transform:translateY(-2px); }
.facility-card:active { transform:translateY(0) scale(.995); }

/* Selection States */
.facility-card.selected-family { border-color:#60a5fa; box-shadow:0 0 0 3px rgba(59,130,246,.15),0 4px 12px rgba(59,130,246,.1); background:#eff6ff; }
.facility-card.selected-pro { border-color:#2dd4bf; box-shadow:0 0 0 3px rgba(45,212,191,.15),0 4px 12px rgba(20,184,166,.1); background:#f0fdfa; }

/* Selection Indicator Bar */
.selection-indicator { position:absolute; top:0; left:0; right:0; height:3px; background:transparent; transition:all .2s; }
.facility-card.selected-family .selection-indicator { background:linear-gradient(90deg,#3b82f6,#60a5fa); }
.facility-card.selected-pro .selection-indicator { background:linear-gradient(90deg,#14b8a6,#2dd4bf); }

/* Selection Checkbox */
.selection-checkbox { position:absolute; top:12px; right:12px; width:22px; height:22px; border-radius:6px; border:2px solid #d1d5db; background:white; display:flex; align-items:center; justify-content:center; z-index:10; transition:all .15s; }
.facility-card:hover .selection-checkbox { border-color:#9ca3af; }
.facility-card.selected-family .selection-checkbox { background:#3b82f6; border-color:#3b82f6; }
.facility-card.selected-pro .selection-checkbox { background:#14b8a6; border-color:#14b8a6; }
.selection-checkbox svg { width:14px; height:14px; color:white; opacity:0; transition:opacity .15s; }
.facility-card.selected-family .selection-checkbox svg, .facility-card.selected-pro .selection-checkbox svg { opacity:1; }

/* ============================================
   CARD CONTENT LAYOUT
   ============================================ */
.card-content { padding:14px; }
.card-header { display:flex; align-items:center; gap:14px; margin-bottom:12px; }

/* ============================================
   RATING BADGE
   ============================================ */
.rating-badge { width:52px; height:52px; border-radius:12px; display:flex; flex-direction:column; align-items:center; justify-content:center; flex-shrink:0; position:relative; box-shadow:0 2px 8px rgba(0,0,0,.15); }
.rating-badge.rating-5 { background:linear-gradient(135deg,#10b981,#059669); }
.rating-badge.rating-4 { background:linear-gradient(135deg,#22c55e,#16a34a); }
.rating-badge.rating-3 { background:linear-gradient(135deg,#f59e0b,#d97706); }
.rating-badge.rating-2 { background:linear-gradient(135deg,#f97316,#ea580c); }
.rating-badge.rating-1 { background:linear-gradient(135deg,#ef4444,#dc2626); }
.rating-badge .rating-label { color:white; font-size:9px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; line-height:1; text-shadow:0 1px 2px rgba(0,0,0,.25); }
.rating-badge .rating-value { color:white; font-weight:700; font-size:16px; text-shadow:0 1px 2px rgba(0,0,0,.2); line-height:1.1; }
.rating-badge::after { content:'★'; position:absolute; bottom:-3px; right:-3px; font-size:9px; color:white; background:#111827; width:18px; height:18px; border-radius:5px; display:flex; align-items:center; justify-content:center; box-shadow:0 1px 3px rgba(0,0,0,.2); }

/* ============================================
   CARD TITLE SECTION
   ============================================ */
.card-title-section { flex:1; min-width:0; padding-right:28px; }
.card-title-section h3 { font-weight:600; color:#111827; font-size:15px; line-height:1.3; margin-bottom:2px; white-space:nowrap; overflow:hidden; text-transform:none; mask-image:linear-gradient(to right, black 85%, transparent); -webkit-mask-image:linear-gradient(to right, black 85%, transparent); }
.card-title-section .contact-info { font-size:11px; color:#6b7280; display:flex; flex-direction:column; gap:1px; }
.card-title-section .contact-row { display:flex; align-items:center; gap:5px; line-height:1.4; }
.card-title-section .contact-row svg { width:12px; height:12px; flex-shrink:0; opacity:0.5; }
.card-title-section .contact-row.phone a { color:#0d9488; text-decoration:none; font-weight:500; }
.card-title-section .contact-row.phone a:hover { text-decoration:underline; }

/* ============================================
   METRICS ROW
   ============================================ */
.metrics-row { display:flex; gap:4px; margin-bottom:10px; }

/* ============================================
   METRIC CHIP
   ============================================ */
.metric-chip { display:inline-flex; flex-direction:column; align-items:center; padding:4px 8px; background:#f8fafc; border-radius:6px; font-size:11px; border:1px solid #f1f5f9; min-width:0; flex:1; position:relative; }
.metric-chip .metric-value { font-weight:700; font-size:13px; line-height:1.2; }
.metric-chip .metric-label { color:#6b7280; font-weight:500; font-size:9px; text-transform:uppercase; letter-spacing:0.02em; }

/* Metric Chip Color Variants */
.metric-chip.rating-5 { background:#ecfdf5; border-color:#d1fae5; }
.metric-chip.rating-5 .metric-value { color:#059669; }
.metric-chip.rating-4 { background:#f0fdfa; border-color:#ccfbf1; }
.metric-chip.rating-4 .metric-value { color:#0d9488; }
.metric-chip.rating-3 { background:#fffbeb; border-color:#fef3c7; }
.metric-chip.rating-3 .metric-value { color:#d97706; }
.metric-chip.rating-2, .metric-chip.rating-1 { background:#fef2f2; border-color:#fecaca; }
.metric-chip.rating-2 .metric-value, .metric-chip.rating-1 .metric-value { color:#dc2626; }

.metric-chip.wage { background:linear-gradient(135deg,#ecfdf5,#d1fae5); border-color:#a7f3d0; }
.metric-chip.wage .metric-value { color:#047857; font-size:14px; }

.metric-chip.good { background:#ecfdf5; border-color:#d1fae5; }
.metric-chip.good .metric-value { color:#059669; }
.metric-chip.warning { background:#fffbeb; border-color:#fef3c7; }
.metric-chip.warning .metric-value { color:#d97706; }
.metric-chip.danger { background:#fef2f2; border-color:#fecaca; }
.metric-chip.danger .metric-value { color:#dc2626; }

.metric-chip.has-info { position:relative; }

/* ============================================
   INFO TIP (Tooltip)
   ============================================ */
.info-tip { position:absolute; top:2px; right:2px; width:14px; height:14px; display:flex; align-items:center; justify-content:center; cursor:pointer; background:rgba(0,0,0,0.08); border-radius:50%; transition:all .15s; }
.info-tip:hover { background:rgba(0,0,0,0.15); }
.info-tip svg { width:10px; height:10px; stroke:#6b7280; }
.info-tip .tip { position:absolute; bottom:calc(100% + 6px); left:50%; transform:translateX(-50%); background:#111827; color:#e5e7eb; padding:8px 11px; border-radius:6px; font-size:11px; font-weight:400; line-height:1.4; width:max-content; max-width:190px; text-align:left; opacity:0; visibility:hidden; transition:all .12s; z-index:100; box-shadow:0 2px 10px rgba(0,0,0,0.25); pointer-events:none; }
.info-tip .tip::after { content:''; position:absolute; top:100%; left:50%; transform:translateX(-50%); border:5px solid transparent; border-top-color:#111827; }
.info-tip.tip-left .tip { left:0; transform:none; }
.info-tip.tip-left .tip::after { left:8px; transform:none; }
.info-tip.tip-right .tip { left:auto; right:0; transform:none; }
.info-tip.tip-right .tip::after { left:auto; right:8px; transform:none; }
.info-tip:hover .tip, .info-tip:focus .tip, .info-tip.active .tip { opacity:1; visibility:visible; }

/* ============================================
   CARD FOOTER
   ============================================ */
.card-footer { display:flex; align-items:center; justify-content:space-between; font-size:11px; padding-top:6px; border-top:1px solid #f3f4f6; gap:8px; }
.footer-left { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

/* ============================================
   DEF BADGE
   ============================================ */
.def-badge { display:inline-flex; align-items:center; gap:4px; padding:3px 8px; border-radius:5px; font-weight:500; font-size:11px; }
.def-badge.good { background:#ecfdf5; color:#059669; }
.def-badge.warning { background:#fffbeb; color:#d97706; }
.def-badge.danger { background:#fef2f2; color:#dc2626; }
.def-badge svg { width:12px; height:12px; }

/* ============================================
   TAG PILLS
   ============================================ */
.tag-pill { display:inline-flex; align-items:center; gap:3px; padding:3px 8px; border-radius:5px; font-size:10px; font-weight:600; text-transform:uppercase; letter-spacing:0.02em; }
.tag-pill svg { width:10px; height:10px; }
.tag-pill.medicaid { background:#eff6ff; color:#2563eb; }
.tag-pill.medicare { background:#f0fdf4; color:#16a34a; }
.tag-pill.rejected { background:#fef2f2; color:#dc2626; }
.tag-pill.service { background:#f5f3ff; color:#7c3aed; }

/* Service Tag Colors */
.tag-pill.svc-nursing { background:#dbeafe; color:#1d4ed8; }
.tag-pill.svc-pt { background:#d1fae5; color:#047857; }
.tag-pill.svc-ot { background:#fef3c7; color:#b45309; }
.tag-pill.svc-speech { background:#fce7f3; color:#be185d; }
.tag-pill.svc-social { background:#e0e7ff; color:#4338ca; }
.tag-pill.svc-aide { background:#f3e8ff; color:#7c3aed; }

/* ============================================
   RESIDENTS INFO
   ============================================ */
.residents-info { display:flex; align-items:center; gap:4px; color:#9ca3af; font-size:11px; white-space:nowrap; }
.residents-info svg { width:14px; height:14px; }

/* ============================================
   VIEW LINK
   ============================================ */
.view-link { display:inline-flex; align-items:center; gap:3px; color:#6b7280; font-size:10px; font-weight:500; text-decoration:none; margin-top:8px; transition:all .15s; }
.card-footer .view-link { margin-top:0; }
.view-link:hover { color:#111827; }
.view-link.pro { color:#6b7280; }
.view-link.pro:hover { color:#111827; }
.view-link svg { width:12px; height:12px; }

/* ============================================
   STAR RATING ROW
   ============================================ */
.star-row { display:flex; align-items:center; gap:3px; }
.star-row svg { width:12px; height:12px; }
.star-row svg.filled { color:#fbbf24; }
.star-row svg.empty { color:#e5e7eb; }
.star-row .rating-label { font-size:11px; color:#6b7280; margin-right:2px; }

/* ============================================
   DEF MODAL
   ============================================ */
.def-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.5); z-index:1000; display:flex; align-items:center; justify-content:center; opacity:0; visibility:hidden; transition:all .2s; }
.def-modal-overlay.visible { opacity:1; visibility:visible; }
.def-modal { background:white; border-radius:12px; box-shadow:0 20px 50px rgba(0,0,0,0.3); max-width:360px; width:90%; max-height:80vh; overflow:hidden; transform:scale(0.95); transition:transform .2s; }
.def-modal-overlay.visible .def-modal { transform:scale(1); }
.def-modal-header { padding:16px 20px; border-bottom:1px solid #e5e7eb; display:flex; align-items:center; justify-content:space-between; }
.def-modal-header h3 { margin:0; font-size:16px; font-weight:600; color:#111827; }
.def-modal-close { width:28px; height:28px; border-radius:6px; border:none; background:#f3f4f6; color:#6b7280; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:18px; }
.def-modal-close:hover { background:#e5e7eb; color:#374151; }
.def-modal-body { padding:20px; }
.def-stat-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:16px; }
.def-stat { background:#f9fafb; border-radius:8px; padding:12px; text-align:center; }
.def-stat-value { font-size:24px; font-weight:700; color:#111827; line-height:1; }
.def-stat-label { font-size:11px; color:#6b7280; margin-top:4px; text-transform:uppercase; letter-spacing:0.03em; }
.def-stat.warning .def-stat-value { color:#d97706; }
.def-stat.danger .def-stat-value { color:#dc2626; }
.def-stat.good .def-stat-value { color:#059669; }
.def-explain { font-size:12px; color:#6b7280; line-height:1.5; padding:12px; background:#f9fafb; border-radius:8px; }
.def-explain strong { color:#374151; }

/* ============================================
   LOAD MORE
   ============================================ */
.load-more-container { grid-column:1/-1; padding:20px; text-align:center; }
.load-more-btn { padding:12px 32px; border-radius:10px; font-size:14px; font-weight:600; border:1px solid #e5e7eb; background:white; color:#374151; cursor:pointer; transition:all .2s; }
.load-more-btn:hover { background:#f9fafb; border-color:#d1d5db; box-shadow:0 2px 8px rgba(0,0,0,.05); }

/* ============================================
   RESULTS COUNT
   ============================================ */
.results-count { max-width:1400px; margin:0 auto; padding:8px 20px 12px; font-size:13px; color:#6b7280; }
.results-count strong { color:#111827; font-weight:600; }
