/* ============================================================
   Medicsino.com — Hospital Detail Pages
   Shared styles for hospital profile pages
   ============================================================ */

/* --- Hero Section --- */
.hospital-hero {
  background: linear-gradient(135deg, #0B1A3B 0%, #12295B 50%, #0B1A3B 100%);
  color: #fff;
  padding: calc(var(--header-height) + var(--spacing-3xl)) 0 var(--spacing-2xl);
  position: relative;
  overflow: hidden;
}
.hospital-hero::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -20%;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(37,99,235,0.15) 0%, transparent 70%);
  border-radius: 50%;
}
.hospital-hero .container { position: relative; z-index: 1; }
.hospital-hero-breadcrumb { display: flex; gap: 8px; align-items: center; margin-bottom: var(--spacing-lg); font-size: 0.875rem; color: rgba(255,255,255,0.65); }
.hospital-hero-breadcrumb a { color: rgba(255,255,255,0.85); text-decoration: none; }
.hospital-hero-breadcrumb a:hover { color: #fff; text-decoration: underline; }
.hospital-hero-breadcrumb .sep { color: rgba(255,255,255,0.4); }

.hospital-hero-main { display: grid; grid-template-columns: 1fr 360px; gap: var(--spacing-2xl); align-items: center; }
.hospital-hero-badge { display: inline-flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.18); border-radius: 100px; padding: 6px 16px; font-size: 0.8rem; font-weight: 600; color: rgba(255,255,255,0.9); margin-bottom: var(--spacing-md); letter-spacing: 0.05em; text-transform: uppercase; }
.hospital-hero h1 { font-size: 2.75rem; font-weight: 900; line-height: 1.15; margin-bottom: var(--spacing-md); letter-spacing: -0.02em; }
.hospital-hero-subtitle { font-size: 1.1rem; color: rgba(255,255,255,0.78); line-height: 1.6; margin-bottom: var(--spacing-lg); max-width: 560px; }
.hospital-hero-meta { display: flex; flex-wrap: wrap; gap: var(--spacing-lg); }
.hospital-hero-meta-item { display: flex; align-items: center; gap: 8px; font-size: 0.9rem; color: rgba(255,255,255,0.7); }
.hospital-hero-meta-item .icon { font-size: 1.2rem; }

.hospital-hero-rank { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: 20px; padding: var(--spacing-xl); text-align: center; }
.hospital-hero-rank-number { font-size: 4rem; font-weight: 900; background: linear-gradient(135deg, #60A5FA, #93C5FD); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; line-height: 1; }
.hospital-hero-rank-label { font-size: 0.85rem; color: rgba(255,255,255,0.65); margin-top: 4px; }
.hospital-hero-scores { margin-top: var(--spacing-md); display: grid; gap: 6px; }
.hospital-hero-score-row { display: flex; justify-content: space-between; align-items: center; font-size: 0.8rem; }
.hospital-hero-score-row .label { color: rgba(255,255,255,0.6); }
.hospital-hero-score-row .value { font-weight: 700; color: #93C5FD; font-family: 'JetBrains Mono', monospace; }

/* --- Quick Stats Bar --- */
.stats-bar { background: var(--color-bg); border-bottom: 1px solid var(--slate-200); position: sticky; top: 72px; z-index: 50; }
.stats-bar-inner { display: flex; gap: var(--spacing-2xl); padding: var(--spacing-md) 0; overflow-x: auto; }
.stats-bar-item { display: flex; align-items: center; gap: 10px; white-space: nowrap; flex-shrink: 0; }
.stats-bar-item .stat-icon { width: 40px; height: 40px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.2rem; flex-shrink: 0; }
.stats-bar-item .stat-icon.blue { background: var(--blue-50); color: var(--blue-600); }
.stats-bar-item .stat-icon.green { background: var(--emerald-50); color: var(--emerald-600); }
.stats-bar-item .stat-icon.amber { background: #FFFBEB; color: var(--amber-600); }
.stats-bar-item .stat-icon.purple { background: #F5F3FF; color: #7C3AED; }
.stats-bar-item .stat-num { font-weight: 800; font-size: 1.1rem; color: var(--color-text); font-family: 'JetBrains Mono', monospace; }
.stats-bar-item .stat-label { font-size: 0.75rem; color: var(--color-text-secondary); }

/* --- Section Layout --- */
.hospital-section { padding: var(--spacing-3xl) 0; }
.hospital-section:nth-child(even) { background: var(--color-bg-secondary); }
.hospital-section-title { font-size: 1.75rem; font-weight: 800; margin-bottom: var(--spacing-xs); color: var(--color-text); }
.hospital-section-desc { color: var(--color-text-secondary); margin-bottom: var(--spacing-2xl); font-size: 1rem; line-height: 1.6; max-width: 640px; }

/* --- Scorecard Visual --- */
.scorecard-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--spacing-xl); margin-top: var(--spacing-xl); }
.scorecard-item { background: var(--color-bg); border: 1px solid var(--slate-200); border-radius: 16px; padding: var(--spacing-lg); }
.scorecard-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.scorecard-label { font-weight: 700; font-size: 0.95rem; }
.scorecard-value { font-weight: 900; font-size: 1.5rem; font-family: 'JetBrains Mono', monospace; }
.scorecard-value.high { color: var(--emerald-600); }
.scorecard-value.mid { color: var(--amber-600); }
.scorecard-value.low { color: var(--slate-500); }
.scorecard-bar { height: 6px; background: var(--slate-100); border-radius: 3px; overflow: hidden; margin-bottom: 4px; }
.scorecard-bar-fill { height: 100%; border-radius: 3px; transition: width 1s ease; }
.scorecard-bar-fill.high { background: linear-gradient(90deg, var(--emerald-500), var(--emerald-600)); }
.scorecard-bar-fill.mid { background: linear-gradient(90deg, var(--amber-500), var(--amber-600)); }
.scorecard-bar-fill.low { background: linear-gradient(90deg, var(--slate-400), var(--slate-500)); }
.scorecard-weight { font-size: 0.75rem; color: var(--slate-400); }

/* --- Specialty Grid --- */
.specialty-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--spacing-lg); }
.specialty-card { background: var(--color-bg); border: 1px solid var(--slate-200); border-radius: 16px; padding: var(--spacing-lg); display: flex; gap: var(--spacing-md); transition: box-shadow 0.2s; }
.specialty-card:hover { box-shadow: var(--shadow-md); }
.specialty-icon { width: 48px; height: 48px; border-radius: 12px; display: flex; align-items: center; justify-content: center; font-size: 1.4rem; flex-shrink: 0; }
.specialty-icon.blue { background: var(--blue-50); }
.specialty-icon.green { background: var(--emerald-50); }
.specialty-icon.amber { background: #FFFBEB; }
.specialty-info h4 { font-size: 1rem; font-weight: 700; margin-bottom: 4px; }
.specialty-info p { font-size: 0.85rem; color: var(--color-text-secondary); line-height: 1.5; }
.specialty-info .tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; }

/* --- Timeline --- */
.timeline { position: relative; padding-left: 32px; }
.timeline::before { content: ''; position: absolute; left: 11px; top: 0; bottom: 0; width: 2px; background: var(--slate-200); }
.timeline-item { position: relative; padding-bottom: var(--spacing-xl); }
.timeline-item:last-child { padding-bottom: 0; }
.timeline-dot { position: absolute; left: -32px; top: 2px; width: 24px; height: 24px; border-radius: 50%; border: 3px solid var(--blue-600); background: #fff; }
.timeline-item h4 { font-size: 1rem; font-weight: 700; margin-bottom: 4px; }
.timeline-item p { font-size: 0.9rem; color: var(--color-text-secondary); }

/* --- Package Card --- */
.package-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--spacing-lg); }
.package-card { background: var(--color-bg); border: 1px solid var(--slate-200); border-radius: 16px; padding: var(--spacing-lg); transition: border-color 0.2s, box-shadow 0.2s; }
.package-card:hover { border-color: var(--blue-300); box-shadow: var(--shadow-md); }
.package-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--spacing-md); }
.package-card-type { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: var(--blue-600); }
.package-card h4 { font-size: 1.05rem; font-weight: 700; margin-bottom: 4px; }
.package-card-price { font-family: 'JetBrains Mono', monospace; font-weight: 800; font-size: 1.5rem; color: var(--emerald-600); }
.package-card-price span { font-size: 0.8rem; font-weight: 500; color: var(--slate-400); }
.package-card-details { list-style: none; padding: 0; margin-bottom: var(--spacing-md); }
.package-card-details li { font-size: 0.85rem; color: var(--color-text-secondary); padding: 4px 0; padding-left: 20px; position: relative; }
.package-card-details li::before { content: '\2713'; position: absolute; left: 0; color: var(--emerald-600); font-weight: 700; }

/* --- Gallery --- */
.gallery-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; grid-template-rows: 200px 200px; gap: 12px; }
.gallery-item { border-radius: 12px; overflow: hidden; position: relative; background: var(--slate-200); }
.gallery-item:first-child { grid-row: span 2; }
.gallery-item img { display: block; transition: transform 0.4s ease; }
.gallery-item:hover img { transform: scale(1.03); }
.gallery-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--slate-100), var(--slate-200)); color: var(--slate-400); font-size: 0.85rem; }

/* --- Testimonial --- */
.testimonial-card { background: var(--color-bg); border: 1px solid var(--slate-200); border-radius: 16px; padding: var(--spacing-xl); }
.testimonial-quote { font-size: 1.05rem; line-height: 1.7; color: var(--color-text); font-style: italic; margin-bottom: var(--spacing-md); position: relative; padding-left: 28px; }
.testimonial-quote::before { content: '\201C'; position: absolute; left: 0; top: -4px; font-size: 2.5rem; color: var(--blue-300); font-style: normal; line-height: 1; }
.testimonial-author { display: flex; align-items: center; gap: 12px; }
.testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--blue-400), var(--blue-600)); display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 700; font-size: 1.1rem; }
.testimonial-name { font-weight: 700; font-size: 0.9rem; }
.testimonial-detail { font-size: 0.8rem; color: var(--color-text-secondary); }

/* --- CTA Block --- */
.hospital-cta { background: linear-gradient(135deg, var(--blue-600), var(--blue-800)); border-radius: 24px; padding: var(--spacing-2xl); color: #fff; text-align: center; margin-top: var(--spacing-2xl); }
.hospital-cta h3 { font-size: 1.75rem; font-weight: 800; margin-bottom: var(--spacing-sm); }
.hospital-cta p { color: var(--blue-200); margin-bottom: var(--spacing-xl); font-size: 1rem; }
.hospital-cta .btn { background: #fff; color: var(--blue-700); font-weight: 700; }
.hospital-cta .btn:hover { background: var(--blue-50); }

/* --- Responsive --- */
@media (max-width: 1024px) {
  .hospital-hero-main { grid-template-columns: 1fr; }
  .hospital-hero-rank { max-width: 320px; }
  .hospital-hero h1 { font-size: 2rem; }
  .scorecard-grid { grid-template-columns: repeat(2, 1fr); }
  .package-grid { grid-template-columns: repeat(2, 1fr); }
  .gallery-grid { grid-template-columns: 1fr 1fr; grid-template-rows: 200px 200px 200px; }
  .gallery-item:first-child { grid-row: span 1; grid-column: span 2; }
}
@media (max-width: 768px) {
  .stats-bar-inner { gap: var(--spacing-lg); }
  .scorecard-grid { grid-template-columns: 1fr; }
  .package-grid { grid-template-columns: 1fr; }
  .specialty-grid { grid-template-columns: 1fr; }
  .gallery-grid { grid-template-columns: 1fr; grid-template-rows: 200px 200px 200px 200px; }
  .gallery-item:first-child { grid-column: span 1; }
  .hospital-hero h1 { font-size: 1.6rem; }
}
