:root{
  /* Palette clinique premium (bleu + teal + blanc) */
  --brand: #0b5ed7;
  --teal: #0aa2c0;
  --deep: #0b1b2b;

  --bg: #f5f7fb;
  --card: #ffffff;

  --ink: #0f172a;
  --muted: #64748b;

  --stroke: rgba(15,23,42,.10);
  --shadow: 0 18px 48px rgba(15,23,42,.10);
  --shadow-soft: 0 10px 30px rgba(15,23,42,.08);
  --radius: 18px;

  --ring: rgba(11,94,215,.18);
}

/* Base */
.public-body{
  background: var(--bg);
  color: var(--ink);
}

.container-xxl{
  max-width: 1220px;
}

/* Topbar */
.topbar{
  background: #fff;
  border-bottom: 1px solid rgba(15,23,42,.06);
}
.topbar-link{
  color: var(--muted);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}
.topbar-link:hover{ color: var(--ink); }

/* Navbar */
.nav-main{
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(15,23,42,.08);
}

.brand-logo{
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(11,94,215,.12), rgba(10,162,192,.12));
  border: 1px solid rgba(15,23,42,.08);
  color: var(--deep);
}
.brand-logo-sm{ width: 36px; height: 36px; border-radius: 12px; }
.brand-title{ display:block; font-weight: 800; letter-spacing: .2px; }
.brand-sub{ display:block; font-size: .82rem; color: var(--muted); margin-top: -2px; }

.navbar .nav-link{
  border-radius: 12px;
  padding: .55rem .85rem;
  color: var(--ink);
}
.navbar .nav-link:hover{
  background: rgba(11,94,215,.06);
}
.btn-cta{
  border-radius: 999px;
  padding: .70rem 1.0rem;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(135deg, var(--brand), var(--teal));
  border: none;
  box-shadow: 0 10px 22px rgba(11,94,215,.18);
}
.btn-cta:hover{ filter: brightness(.98); color:#fff; }

/* Hero section (style “international medical center”) */
.hero{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(1200px 700px at 10% 0%, rgba(11,94,215,.22), transparent 60%),
    radial-gradient(900px 600px at 90% 20%, rgba(10,162,192,.20), transparent 55%),
    linear-gradient(135deg, #071827, #0b1b2b);
  color: #fff;
}

/* optional: image overlay look (you can replace url) */
.hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, rgba(7,24,39,.70), rgba(7,24,39,.20)),
    url("https://images.unsplash.com/photo-1580281657527-47f249e8f1df?auto=format&fit=crop&w=1600&q=60");
  background-size: cover;
  background-position: center;
  opacity: .32;
  pointer-events: none;
}

.hero-inner{
  position: relative;
  z-index: 2;
  padding: 52px 0;
}

.hero-title{
  font-size: clamp(2rem, 3vw, 3rem);
  font-weight: 900;
  letter-spacing: .2px;
}
.hero-sub{
  color: rgba(255,255,255,.78);
  font-size: 1.03rem;
}

.hero-badges .chip{
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .55rem .80rem;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.16);
  font-weight: 600;
  color: rgba(255,255,255,.92);
}

/* Sections / cards */
.section{
  padding: 44px 0;
}

.cardx{
  background: var(--card);
  border: 1px solid rgba(15,23,42,.08);
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
}

.cardx-header{
  display:flex;
  justify-content: space-between;
  align-items: start;
  gap: 1rem;
  margin-bottom: 14px;
}

.kicker{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  font-size: .85rem;
  font-weight: 800;
  color: rgba(11,94,215,.95);
  background: rgba(11,94,215,.10);
  border: 1px solid rgba(11,94,215,.14);
  padding: .35rem .60rem;
  border-radius: 999px;
}

/* Form elements */
.form-label{ font-weight: 700; color: #111827; }
.form-control, .form-select{
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.12);
  padding: .78rem .90rem;
}
.form-control:focus, .form-select:focus{
  border-color: rgba(11,94,215,.55);
  box-shadow: 0 0 0 .25rem var(--ring);
}

/* Slot cards */
.slot{
  border-radius: 16px;
  border: 1px solid rgba(15,23,42,.10);
  background: #fff;
  padding: .80rem .95rem;
  cursor:pointer;
  transition: transform .08s ease, box-shadow .08s ease, border-color .08s ease;
  user-select:none;
  display:flex; align-items:center; justify-content:space-between;
  gap:.75rem;
}
.slot:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(15,23,42,.10);
  border-color: rgba(11,94,215,.30);
}
.slot.active{
  border-color: rgba(11,94,215,.70);
  box-shadow: 0 0 0 .25rem var(--ring);
}
.slot .time{ font-weight: 900; letter-spacing:.2px; }
.slot .meta{ color: var(--muted); font-size: .9rem; }

/* Skeleton */
.skeleton{
  height: 56px;
  border-radius: 16px;
  background: linear-gradient(90deg, rgba(15,23,42,.06), rgba(15,23,42,.11), rgba(15,23,42,.06));
  background-size: 200% 100%;
  animation: shimmer 1.2s infinite;
  border:1px solid rgba(15,23,42,.06);
}
@keyframes shimmer{
  0%{ background-position: 200% 0; }
  100%{ background-position: -200% 0; }
}

/* Right column info blocks */
.icon-row{
  display:flex;
  gap: .9rem;
  padding: .55rem 0;
}
.icon-bubble{
  width: 42px;
  height: 42px;
  display:grid;
  place-items:center;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(11,94,215,.10), rgba(10,162,192,.10));
  border: 1px solid rgba(15,23,42,.08);
  color: var(--deep);
}

.btn-soft{
  background: rgba(11,94,215,.08);
  border: 1px solid rgba(11,94,215,.14);
  color: var(--deep);
  border-radius: 14px;
  font-weight: 800;
}
.btn-soft:hover{ background: rgba(11,94,215,.12); }

/* Specialty cards */
.grid-cards{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
@media (max-width: 991px){
  .grid-cards{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575px){
  .grid-cards{ grid-template-columns: 1fr; }
}
.spec-card{
  background:#fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 18px;
  padding: 16px;
  box-shadow: var(--shadow-soft);
}
.spec-card:hover{
  border-color: rgba(11,94,215,.22);
}
.spec-title{ font-weight: 900; }
.spec-desc{ color: var(--muted); font-size: .92rem; margin: 0; }

/* Footer */
.footer{
  background: #fff;
  border-top: 1px solid rgba(15,23,42,.08);
}
.footer-list .footer-item{
  display:flex;
  align-items:center;
  gap:.6rem;
  color: var(--muted);
  margin-bottom: .45rem;
}
.link-muted{
  color: var(--muted);
  text-decoration: none;
}
.link-muted:hover{
  color: var(--ink);
  text-decoration: underline;
}
