
/* Directory pages: home-like cards and clean search */
.directory-section{
  max-width:1280px;
  margin:0 auto;
  padding:28px;
}

.directory-shell{
  border:0!important;
  border-radius:0!important;
  background:transparent!important;
  box-shadow:none!important;
  padding:0!important;
}

.directory-top,
.directory-howto,
.directory-search-copy,
.directory-search-count,
.directory-stats{
  display:none!important;
}

.directory-search-panel{
  display:block!important;
  border:0!important;
  background:transparent!important;
  box-shadow:none!important;
  padding:0!important;
  margin:0 0 24px!important;
}

.directory-search-control{
  display:grid!important;
  grid-template-columns:auto minmax(0,1fr) auto!important;
  gap:10px!important;
  align-items:center!important;
  max-width:760px!important;
  min-height:54px!important;
  border:1px solid #dbe3ee!important;
  border-radius:14px!important;
  background:#fff!important;
  box-shadow:0 10px 24px rgba(15,23,42,.04)!important;
  padding:7px 8px 7px 14px!important;
}

.directory-search-icon{
  color:var(--primary);
  font-weight:950;
  font-size:18px;
}

.directory-search-control input{
  width:100%;
  border:0;
  outline:0;
  background:transparent;
  color:var(--navy);
  font-size:15px;
  font-weight:750;
}

.directory-search-control button{
  border:0!important;
  border-radius:8px!important;
  min-height:40px!important;
  padding:0 18px!important;
  background:var(--primary)!important;
  color:#fff!important;
  font-size:13px!important;
  font-weight:950!important;
  cursor:pointer!important;
}

.directory-featured,
.directory-all,
.directory-faq{
  margin-top:30px!important;
}

.directory-subhead{
  display:flex;
  justify-content:space-between;
  align-items:end;
  gap:24px;
  margin-bottom:18px;
}

.directory-subhead h2{
  font-size:clamp(26px,3vw,40px);
  line-height:1.04;
  letter-spacing:-.05em;
  color:#071426;
  margin:0 0 8px;
}

.directory-subhead p{
  max-width:760px;
  color:#526173;
  line-height:1.58;
  margin:0;
  font-size:15px;
}

.directory-card-grid{
  display:grid!important;
  grid-template-columns:repeat(4,minmax(0,1fr))!important;
  gap:14px!important;
  align-items:stretch!important;
}

.directory-card,
.directory-card.home-ux-card{
  overflow:hidden!important;
  text-decoration:none!important;
  color:inherit!important;
  padding:0!important;
  min-height:100%!important;
  display:flex!important;
  flex-direction:column!important;
  background:#fff!important;
  border:1px solid #e7edf5!important;
  border-radius:18px!important;
  box-shadow:0 10px 24px rgba(15,23,42,.04)!important;
  transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease!important;
}

.directory-card:hover{
  transform:translateY(-3px)!important;
  border-color:#d8e1ee!important;
  box-shadow:0 18px 34px rgba(15,23,42,.075)!important;
}

.directory-card[hidden]{
  display:none!important;
}

.directory-card-featured{
  border-color:#ddd6fe!important;
}

.directory-card-media,
.directory-card .home-ux-card-media{
  aspect-ratio:1/1!important;
  height:auto!important;
  background:#eef3f8!important;
  border-radius:18px 18px 0 0!important;
  overflow:hidden!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  border-bottom:0!important;
}

.directory-card-media img{
  width:100%!important;
  height:100%!important;
  object-fit:cover!important;
  display:block!important;
  filter:saturate(.95) contrast(1.02)!important;
}

.directory-card-placeholder span{
  font-size:26px;
  font-weight:950;
  color:rgba(15,23,42,.20);
}

.directory-card-body,
.directory-card .home-ux-card-body{
  padding:13px 13px 14px!important;
  display:block!important;
}

.directory-card-body h3,
.directory-card h3{
  margin:0 0 6px!important;
  font-size:15.5px!important;
  line-height:1.22!important;
  letter-spacing:-.02em!important;
  color:#0f172a!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  overflow:hidden!important;
}

.directory-card-body p,
.directory-card p{
  margin:0!important;
  color:#64748b!important;
  font-size:12px!important;
  line-height:1.38!important;
  display:-webkit-box!important;
  -webkit-line-clamp:2!important;
  -webkit-box-orient:vertical!important;
  overflow:hidden!important;
}

.directory-card-kicker,
.directory-card-meta,
.directory-card-action{
  display:none!important;
}

.directory-source-filters{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:0 0 15px;
}

.directory-source-filters a{
  display:inline-flex;
  align-items:center;
  min-height:34px;
  border-radius:999px;
  border:1px solid #e7edf5;
  background:#fff;
  padding:0 12px;
  color:#475569;
  font-size:12.5px;
  font-weight:900;
  text-decoration:none;
}

.directory-source-filters a.active,
.directory-source-filters a:hover{
  background:#f4f0ff;
  border-color:#ddd6fe;
  color:var(--primary);
}

.directory-cta{
  margin-top:34px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  border-radius:14px;
  padding:24px;
  background:linear-gradient(135deg,#fff 0%,#fbf9ff 100%);
  border:1px solid #ddd6fe;
  color:#0f172a;
  box-shadow:0 8px 22px rgba(15,23,42,.035);
}

.directory-cta h2{
  margin:0 0 8px;
  font-size:25px;
  line-height:1.12;
  letter-spacing:-.035em;
  color:#0f172a;
}

.directory-cta p{
  margin:0;
  color:#526173;
  max-width:760px;
  line-height:1.52;
  font-size:14px;
}

.directory-cta-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.directory-faq-list{
  display:grid;
  gap:10px;
}

.directory-faq-item{
  border:1px solid #e7edf5;
  border-radius:14px;
  background:#fff;
  padding:14px 16px;
}

.directory-faq-item summary{
  cursor:pointer;
  font-weight:950;
  color:#0f172a;
}

.directory-faq-item p{
  margin:10px 0 0;
  color:#526173;
  line-height:1.55;
}

@media(max-width:1100px){
  .directory-card-grid{
    grid-template-columns:repeat(3,minmax(0,1fr))!important;
  }
}

@media(max-width:760px){
  .directory-section{
    padding:20px 16px;
  }

  .directory-card-grid{
    grid-template-columns:repeat(2,minmax(0,1fr))!important;
    gap:10px!important;
  }

  .directory-search-control{
    min-height:50px!important;
    border-radius:14px!important;
    padding:7px!important;
  }

  .directory-search-control button{
    min-height:36px!important;
    padding:0 12px!important;
    border-radius:8px!important;
  }

  .directory-subhead{
    display:block;
    margin-bottom:14px;
  }

  .directory-subhead h2{
    font-size:24px;
    margin-bottom:0;
  }

  .directory-subhead p{
    display:none;
  }

  .directory-card,
  .directory-card.home-ux-card{
    border-radius:15px!important;
  }

  .directory-card-media,
  .directory-card .home-ux-card-media{
    border-radius:15px 15px 0 0!important;
  }

  .directory-card-body,
  .directory-card .home-ux-card-body{
    padding:9px 9px 10px!important;
  }

  .directory-card-body h3,
  .directory-card h3{
    font-size:13.2px!important;
    line-height:1.14!important;
    margin-bottom:4px!important;
  }

  .directory-card-body p,
  .directory-card p{
    font-size:10.8px!important;
    line-height:1.24!important;
    -webkit-line-clamp:1!important;
  }

  .directory-cta{
    display:block;
    padding:18px 16px;
  }

  .directory-cta-actions{
    justify-content:flex-start;
    margin-top:14px;
  }

  .directory-cta-actions .btn{
    width:100%;
  }
}


/* Minimal directory layout override */
.directory-search-control{
  max-width:none!important;
  width:100%!important;
}

.directory-all{
  margin-top:18px!important;
}

.directory-subhead,
.directory-cta,
.directory-faq{
  display:none!important;
}

.directory-card-grid{
  margin-top:0!important;
}
