/* =====================================================================
   UK Top Websites - directory theme enhancements (site-wide)
   Loaded on EVERY page after style.css / responsive.css (see head.php)
   Visual direction inspired by modern directory templates (uListing):
   clean white cards, teal accent, rounded corners, soft shadows, hover lift.
   ===================================================================== */

:root {
  --dir-primary: #5b8def;        /* Aqua accent blue */
  --dir-primary-dark: #2f5bd0;
  --dir-primary-soft: #e6effe;
  --dir-accent: #ffb400;         /* amber (premium badges / stars) */
  --dir-ink: #1e2a37;            /* headings / dark text */
  --dir-body: #54616e;           /* body text */
  --dir-muted: #6d7d8d;
  --dir-bg: #e9eef6;             /* Aqua ground */
  --dir-card: #ffffff;
  --dir-border: #e2e8f1;
  --dir-radius: 18px;
  --dir-radius-sm: 12px;
  --dir-shadow: 8px 8px 20px rgba(31,45,71,.09), -8px -8px 20px rgba(255,255,255,.95);
  --dir-shadow-hover: 10px 10px 26px rgba(31,45,71,.13), -10px -10px 26px rgba(255,255,255,.97);
}

/* ---------- Base ---------- */
body {
  background: var(--dir-bg);
  color: var(--dir-body);
  -webkit-font-smoothing: antialiased;
}
body.item, body.search, body.home { background: var(--dir-bg); }

h1, h2, h3 { color: var(--dir-ink); }

a { color: var(--dir-primary-dark); }
a:hover { color: var(--dir-primary); }

/* ---------- Site-wide accent normalisation (theme blue -> teal, all pages) ---------- */
input:focus, select:focus, textarea:focus,
input:active, select:active, textarea:active {
  border-color: var(--dir-primary) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(59,130,246, .15);
}
button, .btn { background: var(--dir-primary); }
body .qq-upload-button { background: var(--dir-primary) !important; }
.doublebutton a.active,
.paginate span.searchPaginationSelected,
.paginate a.current {
  background: var(--dir-primary) !important;
  border-color: var(--dir-primary) !important;
  color: #fff !important;
}
.paginate a:hover { border-color: var(--dir-primary) !important; color: var(--dir-primary-dark) !important; }
header .nav a:hover { border-color: var(--dir-primary) !important; }
#related-searches a { border-color: var(--dir-border) !important; color: var(--dir-primary-dark) !important; }
#related-searches a:hover { border-color: var(--dir-primary) !important; }
.item-photos .thumbs img:hover { border-color: var(--dir-primary) !important; }
.btn.btn-secondary { border: 2px solid var(--dir-border); color: var(--dir-ink); }
.btn.btn-secondary:hover, a.btn.btn-secondary:hover { border-color: var(--dir-primary); color: var(--dir-primary-dark); }
/* misc theme accents */
.mark_as:focus, .comment-leave-rating .fill, .fa-star.fill { color: var(--dir-accent); }
#breadcrumb a, .breadcrumb a { color: var(--dir-primary-dark); }
.flashmessage-ok, .flash-message.ok { border-color: var(--dir-primary); }

/* ---------- Buttons ---------- */
.btn {
  border-radius: 40px;
  font-weight: 700;
  transition: transform .15s ease, box-shadow .15s ease, background-color .15s ease, color .15s ease;
}
.btn:hover { transform: translateY(-1px); }

.btn-primary,
button.btn-primary,
.btn.btn-primary {
  background: var(--dir-primary) !important;
  border-color: var(--dir-primary) !important;
  color: #fff !important;
  box-shadow: 0 6px 16px rgba(59,130,246, .28);
}
.btn-primary:hover,
button.btn-primary:hover,
.btn.btn-primary:hover {
  background: var(--dir-primary-dark) !important;
  border-color: var(--dir-primary-dark) !important;
}

.btn-secondary,
.btn.btn-secondary {
  background: #fff !important;
  border: 1px solid var(--dir-border) !important;
  color: var(--dir-ink) !important;
}
.btn-secondary:hover,
.btn.btn-secondary:hover {
  border-color: var(--dir-primary) !important;
  color: var(--dir-primary-dark) !important;
}

/* ---------- Header / nav ---------- */
header { box-shadow: 0 1px 0 rgba(22, 50, 79, .06); }
header .nav a { color: var(--dir-ink); }
header .nav a:hover { color: var(--dir-primary-dark); }
header .nav a.publish {
  background: var(--dir-primary);
  color: #fff;
  border-radius: 40px;
  padding: 9px 20px;
}
header .nav a.publish:hover { background: var(--dir-primary-dark); color:#fff; }

/* ---------- Search hero ---------- */
.home-search {
  background: linear-gradient(135deg, #123a5f 0%, #3b82f6 100%);
}
.home-search h1 { color: #fff; }
.home-search .home-search-sub {
  margin: 6px 0 18px;
  font-size: 17px;
  color: rgba(255, 255, 255, .92);
  text-align: center;
}
.home-search .search.box {
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
}
.home-search .btn-primary { border-radius: var(--dir-radius-sm); }

/* ---------- Home introduction section ---------- */
.home-intro { padding: 50px 0 24px; }
.home-intro .wrapper { max-width: 1140px; margin: 0 auto; }
.home-intro .intro-head { text-align: center; max-width: 820px; margin: 0 auto 34px; }
.home-intro .intro-head h2 { font-size: 30px; line-height: 1.2; margin: 0 0 14px; }
.home-intro .intro-head p { font-size: 17px; line-height: 1.7; color: var(--dir-muted); margin: 0; }

.home-intro .intro-features { display: flex; flex-wrap: wrap; gap: 22px; justify-content: center; }
.home-intro .feature {
  flex: 1 1 260px;
  max-width: 340px;
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  padding: 30px 24px;
  text-align: center;
  transition: transform .18s ease, box-shadow .18s ease;
}
.home-intro .feature:hover { transform: translateY(-4px); box-shadow: var(--dir-shadow-hover); }
.home-intro .feature-icon {
  width: 64px; height: 64px; margin: 0 auto 16px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 25px; color: #fff;
  background: linear-gradient(135deg, var(--dir-primary), #2563eb);
}
.home-intro .feature h3 { margin: 0 0 8px; font-size: 19px; }
.home-intro .feature p { margin: 0; color: var(--dir-muted); line-height: 1.6; font-size: 15px; }
.home-intro .intro-cta { text-align: center; margin-top: 34px; }
.home-intro .intro-cta .btn { font-size: 17px; padding: 13px 34px; }

/* ---------- Home category tiles ---------- */
#home-cats h2, #home-regs h2 {
  font-size: 22px; margin-bottom: 18px;
  padding-bottom: 10px; border-bottom: 2px solid var(--dir-border);
}
#home-cats { background: transparent !important; padding: 0 !important; }
#home-cats .wrap {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 14px;
}
#home-cats .wrap > a {
  float: none !important;
  width: auto !important;
  height: auto !important;
  margin: 0 !important;
  padding: 24px 14px !important;
  background: var(--dir-card) !important;
  border: 1px solid var(--dir-border) !important;
  border-radius: 20px !important;
  box-shadow: 8px 8px 20px rgba(31,45,71,.10), -8px -8px 20px rgba(255,255,255,.96) !important;
  text-align: center;
  display: flex !important;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  transition: transform .16s ease, box-shadow .16s ease;
  color: var(--dir-ink);
}
#home-cats .wrap > a:hover {
  transform: translateY(-4px);
  box-shadow: 13px 13px 30px rgba(31,45,71,.15), -13px -13px 30px rgba(255,255,255,.98) !important;
}
#home-cats .wrap > a .icon {
  width: 58px !important; height: 58px !important;
  margin: 0 auto 14px !important;
  border-radius: 18px;
  display: flex !important; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #eef3fc, #dfe9fb) !important;
  color: #5b8def !important;
  box-shadow: 4px 4px 10px rgba(31,45,71,.08), -4px -4px 10px rgba(255,255,255,.9);
}
#home-cats .wrap > a .icon i { font-size: 22px !important; line-height: 1 !important; }
#home-cats .wrap > a.is-empty { opacity: .62; }
#home-cats .wrap > a.is-empty:hover { opacity: 1; }
#home-cats .wrap > a strong {
  width: 100% !important;
  max-height: none !important;
  display: block;
  color: var(--dir-ink);
  font-size: 15px;
  line-height: 1.3;
  margin-bottom: 8px;
}
#home-cats .wrap > a .cat-count {
  display: inline-block;
  font-size: 12px;
  color: var(--dir-primary-dark);
  background: var(--dir-primary-soft);
  padding: 2px 10px;
  border-radius: 20px;
}

/* ---------- Home locations ---------- */
#home-regs .wrap > div a {
  display: flex; align-items: center; gap: 8px;
  padding: 9px 12px;
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius-sm);
  background: var(--dir-card);
  margin-bottom: 8px;
  color: var(--dir-body);
}
#home-regs .wrap > div a:hover { border-color: var(--dir-primary); color: var(--dir-primary-dark); }
#home-regs .wrap i { color: var(--dir-primary); }
#home-regs .wrap em { color: var(--dir-muted); font-style: normal; margin-left: auto; }

/* ---------- Listing cards ---------- */
.listing-card-list { list-style: none; margin: 0; padding: 0; }

.listing-card .title,
.listing-card a.title {
  color: var(--dir-ink);
  font-weight: 700;
  font-size: 17px;
  line-height: 1.3;
}
.listing-card a.title:hover { color: var(--dir-primary-dark); }
.listing-card .listing-details { color: var(--dir-muted); font-size: 13px; }
.listing-card .listing-details .category {
  display: inline-block;
  background: var(--dir-primary-soft);
  color: var(--dir-primary-dark);
  padding: 3px 10px;
  border-radius: 20px;
  font-weight: 600;
  margin-bottom: 6px;
}
.listing-card .desc { color: var(--dir-body); font-size: 14px; line-height: 1.6; }

/* Thumbnail: always shows a coloured letter tile; screenshot layers on top. */
.listing-card .listing-thumb {
  position: relative;
  display: block;
  overflow: hidden;
  background: linear-gradient(135deg, #eef3fc, #dfe9fb);
}
.listing-card .listing-thumb .thumb-letter {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #7f9dd6;
  font-weight: 800;
  font-size: 40px;
  z-index: 1;
}
.listing-card .listing-thumb img {
  position: relative;
  z-index: 2;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}
.listing-card:hover .listing-thumb img { transform: scale(1.04); }

/* GRID view — full reset of the theme's table/float layout into real cards */
.listing-card-list.listing-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: 20px;
  width: auto !important;
  margin: 0 !important;
}
.listing-grid .listing-card {
  width: auto !important;
  margin: 0 !important;
  padding: 8px !important;              /* frame around the thumbnail */
  float: none !important;
  display: flex !important;
  flex-direction: column;
  background: var(--dir-card);
  border: 1px solid var(--dir-border) !important;
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  overflow: hidden;
  transition: transform .16s ease, box-shadow .16s ease;
}
.listing-grid .listing-card:hover { transform: translateY(-4px); box-shadow: var(--dir-shadow-hover); }
.listing-grid .listing-card .listing-thumb {
  float: none !important;
  width: 100% !important;
  height: 150px;
  border-radius: var(--dir-radius-sm);   /* framed, rounded thumbnail */
  overflow: hidden;
}
.listing-grid .listing-card .listing-thumb img { width: 100% !important; height: 100% !important; }
.listing-grid .listing-card,
.listing-grid .listing-card * { box-sizing: border-box; }
.listing-grid .listing-card .listing-detail,
.listing-grid .listing-card .listing-cell,
.listing-grid .listing-card .listing-data,
.listing-grid .listing-card .listing-basicinfo { display: block !important; width: 100% !important; max-width: 100% !important; margin: 0 !important; float: none !important; padding: 0 !important; }
.listing-grid .listing-card .listing-detail { padding: 12px 8px 6px !important; }
/* Title: wrap and stay inside the card instead of a single overflowing line */
.listing-grid .listing-card .listing-basicinfo a.title,
.listing-grid .listing-card a.title {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  white-space: normal !important;
  overflow: hidden;
  text-overflow: ellipsis;
  word-wrap: break-word;
  overflow-wrap: anywhere;
  line-height: 1.3;
  margin: 0 0 8px 0 !important;
}
.listing-grid .listing-card .listing-details,
.listing-grid .listing-card .listing-details span { max-width: 100%; word-wrap: break-word; }

/* LIST view — keep the theme's horizontal layout, just enlarge/round the thumb */
.listing-list .listing-card {
  background: var(--dir-card);
  border: 1px solid var(--dir-border) !important;
  border-radius: var(--dir-radius) !important;
  box-shadow: var(--dir-shadow);
  padding: 12px 14px !important;
  margin-bottom: 14px !important;
  transition: transform .16s ease, box-shadow .16s ease;
}
.listing-list .listing-card:hover { transform: translateY(-3px); box-shadow: var(--dir-shadow-hover); }
.listing-list .listing-card .listing-thumb { width: 120px; height: 92px; border-radius: var(--dir-radius-sm); overflow: hidden; margin-right: 6px; }
.listing-list .listing-card .listing-detail { margin-left: 146px !important; }

/* ---------- Search page ---------- */
.search-title, .search h1 { color: var(--dir-ink); }
#search-top, .list-header, .listing-header {
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
}
#sidebar .widget-box,
#sidebar .search-box,
.search-sidebar .box {
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
}

/* ---------- Search page toolbar (phplistings-style) ---------- */
.search .list-header,
.list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  padding: 14px 18px;
  margin-bottom: 20px;
}
.list-header .search-title,
.list-header h1 { font-size: 20px; margin: 0; }
.list-header .sort-by select,
.list-header select {
  border-radius: var(--dir-radius-sm);
  border: 1px solid var(--dir-border);
  padding: 8px 12px;
}
.list-header .doublebutton { display: inline-flex; gap: 6px; }
.list-header .doublebutton .btn {
  width: 40px; height: 40px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0; border-radius: var(--dir-radius-sm);
}
.list-header .doublebutton .btn.active {
  background: var(--dir-primary) !important;
  border-color: var(--dir-primary) !important;
  color: #fff !important;
}

/* Search sidebar filter card */
.search #sidebar .widget-box,
.search #sidebar .box,
.search-sidebar .box {
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  padding: 18px;
  margin-bottom: 20px;
}
.search #sidebar h2,
.search #sidebar h3 {
  font-size: 16px;
  padding-bottom: 10px;
  margin-bottom: 12px;
  border-bottom: 1px solid var(--dir-border);
}
.search .empty {
  background: var(--dir-card);
  border: 1px dashed var(--dir-border);
  border-radius: var(--dir-radius);
  padding: 30px;
  text-align: center;
  color: var(--dir-muted);
}

/* ---------- Item detail page ---------- */
#item-content > h1 { font-size: 30px; margin-bottom: 10px; }
#item-content {
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  padding: 26px 28px;
}
.item-header { color: var(--dir-muted); font-size: 14px; }
#item-content .item-photos img { border-radius: var(--dir-radius); }
#description .desc { color: var(--dir-body); font-size: 16px; line-height: 1.75; }
#description .desc p { margin: 0 0 14px; }
.item-hook, #custom_fields { margin-top: 12px; }

/* Website preview (detail) — override the theme's float/gallery layout */
.item-photos.website-preview {
  float: none !important;
  width: 100% !important;
  clear: both !important;
  display: block !important;
  margin: 0 0 22px 0 !important;
}
.item-photos.website-preview .main-photo {
  float: none !important;
  width: 100% !important;
  max-width: 560px;              /* keep the preview a sensible size, not full-bleed */
  height: 260px;                 /* definite height so object-fit can clip cleanly */
  position: relative;
  display: block;
  border-radius: var(--dir-radius);
  overflow: hidden;
  box-shadow: var(--dir-shadow);
  border: 1px solid var(--dir-border);
}
.item-photos.website-preview .main-photo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
  object-position: top center;
  display: block;
}
.item-photos.website-preview .preview-label {
  position: absolute; left: 12px; bottom: 12px;
  background: rgba(16, 50, 79, .9); color: #fff;
  font-size: 13px; font-weight: 600; padding: 6px 12px; border-radius: 20px;
  z-index: 3;
}
/* keep the article clearly below the preview, inside the content card */
#item-content #description { clear: both !important; }
#item-content #description .desc { margin-top: 6px; }

@media (max-width: 767px) {
  .item-photos.website-preview .main-photo { height: 180px; }
}

/* Contact / owner sidebar box */
#sidebar #contact.widget-box {
  background: var(--dir-card);
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  padding: 22px;
}
#sidebar #contact h2 {
  font-size: 18px; margin: 0 0 14px;
  padding-bottom: 10px; border-bottom: 1px solid var(--dir-border);
}
.visit-website-btn, .btn.visit-website-btn { display: block; text-align: center; margin: 4px 0 10px; }
#sidebar .website.bld a { word-break: break-all; color: var(--dir-primary-dark); }
#useful_info {
  background: var(--dir-primary-soft);
  border-radius: var(--dir-radius);
  padding: 18px 20px; margin-top: 18px;
}
#useful_info h2 { font-size: 16px; margin: 0 0 10px; }
#useful_info ul { margin: 0; padding-left: 18px; }
#useful_info li { color: var(--dir-body); font-size: 13px; margin-bottom: 6px; }

/* ---------- Publish / edit form ---------- */
.form-container .header h1 { color: var(--dir-ink); }
#item-post fieldset, .form-horizontal fieldset { background: transparent; }
#item-post .box, #item-post > form > fieldset {
  background: var(--dir-card);
}
.control-group .help-text { display: block; margin-top: 6px; font-size: 13px; color: var(--dir-muted); }
.control-group.website-url .controls input { font-weight: 600; }
.word-count-wrap { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-top: 6px; flex-wrap: wrap; }
.word-counter { font-size: 13px; font-weight: 700; padding: 3px 12px; border-radius: 20px; background: #eef2f6; color: var(--dir-muted); white-space: nowrap; }
.word-counter.valid { background: #e7f7ee; color: #0f7a3d; }
.word-counter.invalid { background: #fdecec; color: #c0392b; }

/* form fields consistency */
#main input[type="text"],
#main input[type="email"],
#main input[type="tel"],
#main input[type="password"],
#main textarea,
#main select {
  border-radius: var(--dir-radius-sm);
  border: 1px solid var(--dir-border);
}
#main input[type="text"]:focus,
#main input[type="email"]:focus,
#main textarea:focus,
#main select:focus {
  border-color: var(--dir-primary);
  outline: none;
  box-shadow: 0 0 0 3px rgba(59,130,246, .15);
}

/* ---------- Pagination ---------- */
.paginate ul li a, .pagination ul li a, ul.pagination li span {
  border-radius: var(--dir-radius-sm) !important;
  border: 1px solid var(--dir-border);
}
.paginate ul li.selected a, .pagination ul li.active span, ul.pagination li.active span {
  background: var(--dir-primary) !important;
  border-color: var(--dir-primary) !important;
  color: #fff !important;
}

/* ---------- Footer (light) ---------- */
footer { background: transparent !important; color: var(--dir-body) !important; margin-top: 40px; }
footer .box > a,
footer a { color: var(--dir-primary-dark) !important; }
footer a:hover,
footer .box > a:hover { color: var(--dir-primary) !important; }
footer .copy,
footer .language,
footer .footer-about { color: var(--dir-muted) !important; }
footer .copy a,
footer .language a { color: var(--dir-primary-dark) !important; }
footer .copy a:hover,
footer .language a:hover { color: var(--dir-primary) !important; }
footer .copy { margin-top: 6px; }
footer .footer-brand {
  text-align: center;
  margin: 4px 0 8px;
}
footer .footer-brand a {
  color: var(--dir-ink) !important;
  font-size: 20px;
  font-weight: 800;
  letter-spacing: .5px;
  text-decoration: none;
}
footer .footer-brand a:hover { color: var(--dir-primary-dark) !important; }
footer .footer-about {
  max-width: 760px;
  margin: 6px auto 12px;
  text-align: center;
  font-size: 14px;
  line-height: 1.75;
}

/* ---------- Interactive UK map ---------- */
.home-map { padding: 44px 0 10px; }
.home-map .wrapper { max-width: 1140px; margin: 0 auto; }
.home-map > .wrapper > h2 { text-align: center; font-size: 28px; margin: 0 0 6px; }
.uktw-map-wrap { position: relative; }
.uktw-map {
  height: 560px;
  width: 100%;
  border-radius: var(--dir-radius);
  border: 1px solid var(--dir-border);
  box-shadow: var(--dir-shadow);
  overflow: hidden;
  z-index: 1;
}
.uktw-map-controls {
  display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  margin-bottom: 12px; min-height: 34px;
}
.uktw-map-hint { color: var(--dir-muted); }
.uktw-map-county { color: var(--dir-ink); font-size: 18px; }
.uktw-map-loading { color: var(--dir-primary-dark); font-size: 13px; }
.uktw-map-back {
  background: var(--dir-primary); color: #fff; border: none;
  padding: 8px 18px; border-radius: 40px; font-weight: 700; cursor: pointer;
  transition: background-color .15s ease;
}
.uktw-map-back:hover { background: var(--dir-primary-dark); }

.uktw-legend {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 14px; justify-content: center;
}
.uktw-legend-chip {
  display: inline-flex; align-items: center; gap: 7px;
  background: #fff; border: 1px solid var(--dir-border);
  border-radius: 20px; padding: 5px 12px; font-size: 13px; cursor: pointer;
  color: var(--dir-body); transition: border-color .15s ease, box-shadow .15s ease;
}
.uktw-legend-chip:hover { border-color: var(--dir-primary); }
.uktw-legend-chip.on { border-color: var(--dir-primary); box-shadow: 0 0 0 2px rgba(59,130,246,.18); font-weight: 700; }
.uktw-legend-chip .dot { width: 12px; height: 12px; border-radius: 50%; flex: 0 0 auto; }
.uktw-map .leaflet-popup-content a { color: var(--dir-primary-dark); font-weight: 700; text-decoration: none; }

@media (max-width: 767px) { .uktw-map { height: 400px; } }

/* ---------- React extensive search ---------- */
.home-extsearch { padding: 40px 0 20px; }
.home-extsearch .wrapper { max-width: 1140px; margin: 0 auto; }
.home-extsearch > .wrapper > h2 { text-align: center; font-size: 28px; margin: 0 0 6px; }
.home-extsearch-sub { text-align: center; color: var(--dir-muted); margin: 0 0 22px; }
.uktw-boot { text-align: center; color: var(--dir-muted); padding: 30px; }

/* one clean WHITE search card holding all the fields (moderate rounding) */
.uktw-search-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1px solid #cdd7de;
  border-radius: 14px;
  box-shadow: 0 6px 20px rgba(11,28,39,.10);
  padding: 6px;
}
.uktw-search-bar .uktw-field input,
.uktw-search-bar .uktw-field select { background: #fff !important; color: #0b1c27 !important; }
.uktw-field {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 200px;
  padding: 0 8px 0 14px;
  min-width: 0;
  background: #fff;
  border: none;
  border-radius: 0;
}
.uktw-field + .uktw-field { border-left: 1px solid #e2e8ed; }
.uktw-field i { color: var(--dir-primary); font-size: 15px; flex: 0 0 auto; }
.uktw-field input, .uktw-field select {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  width: 100%;
  padding: 10px 4px !important;
  font-size: 15px;
  background: #fff;
  color: #0b1c27;
}
.uktw-field input::placeholder { color: #5a6b76 !important; opacity: 1; }
.uktw-field select option { background: #fff; color: #0b1c27; }
.uktw-search-btn {
  flex: 0 0 auto;
  align-self: stretch;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  background: var(--dir-primary);
  color: #fff;
  font-weight: 700;
  padding: 0 30px;
  border-radius: 40px;
  cursor: pointer;
  transition: background-color .15s ease, transform .15s ease;
}
.uktw-search-btn:hover { background: var(--dir-primary-dark); transform: translateY(-1px); }

.uktw-pcinfo { text-align: center; color: var(--dir-primary-dark); font-size: 13px; margin: 10px 0 0; }
.uktw-meta { color: var(--dir-muted); font-size: 14px; margin: 16px 2px 12px; }

.uktw-results {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
  transition: opacity .2s ease;
}
.uktw-results.is-loading { opacity: .55; }

.uktw-card {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius);
  box-shadow: var(--dir-shadow);
  overflow: hidden;
  text-decoration: none;
  color: var(--dir-ink);
  transition: transform .18s ease, box-shadow .18s ease;
  animation: uktw-fade .3s ease both;
}
.uktw-card:hover { transform: translateY(-4px); box-shadow: var(--dir-shadow-hover); }
@keyframes uktw-fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

.uktw-card-thumb {
  position: relative;
  height: 150px;
  background: linear-gradient(135deg, #eef3fc, #dfe9fb);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.uktw-card-letter { color: #7f9dd6; font-size: 38px; font-weight: 800; z-index: 1; }
.uktw-card-thumb img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top center; z-index: 2; }
.uktw-badge {
  position: absolute; top: 10px; left: 10px; z-index: 3;
  background: var(--dir-accent); color: #3a2a00;
  font-size: 11px; font-weight: 800; text-transform: uppercase;
  padding: 3px 10px; border-radius: 20px; letter-spacing: .4px;
}
.uktw-card-body { padding: 14px 16px 16px; display: flex; flex-direction: column; gap: 4px; }
.uktw-card-cat {
  align-self: flex-start;
  background: var(--dir-primary-soft); color: var(--dir-primary-dark);
  font-size: 12px; font-weight: 600; padding: 2px 10px; border-radius: 20px; margin-bottom: 4px;
}
.uktw-card-title { font-size: 16px; line-height: 1.3; }
.uktw-card-loc { font-size: 13px; color: var(--dir-muted); }
.uktw-card-loc i { color: var(--dir-primary); margin-right: 4px; }

.uktw-empty { grid-column: 1 / -1; text-align: center; color: var(--dir-muted); padding: 34px; border: 1px dashed var(--dir-border); border-radius: var(--dir-radius); }
.uktw-more { text-align: center; margin: 24px 0 6px; }
.uktw-more-btn {
  border: 1px solid var(--dir-border); background: #fff; color: var(--dir-ink);
  font-weight: 700; padding: 12px 30px; border-radius: 40px; cursor: pointer;
  transition: border-color .15s ease, color .15s ease;
}
.uktw-more-btn:hover:not(:disabled) { border-color: var(--dir-primary); color: var(--dir-primary-dark); }
.uktw-more-btn:disabled { opacity: .6; cursor: default; }

@media (max-width: 767px) {
  .uktw-search-bar { border-radius: var(--dir-radius); flex-direction: column; padding: 10px; }
  .uktw-field + .uktw-field { border-left: none; border-top: 1px solid var(--dir-border); }
  .uktw-search-btn { padding: 12px; }
}

/* ---------- Featured badge on cards ---------- */
.listing-thumb { position: relative; }
.listing-badge {
  position: absolute; top: 10px; left: 10px; z-index: 3;
  background: var(--dir-accent); color: #3a2a00;
  font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: .4px;
  padding: 4px 10px; border-radius: 20px;
}
.listing-badge i { margin-right: 3px; }

/* ---------- Star ratings ---------- */
.listing-rating { display: inline-flex; align-items: center; gap: 2px; margin: 4px 0 6px; font-size: 13px; }
.listing-rating .fa-star, .listing-rating .fa-star-half-alt { color: var(--dir-accent); }
.listing-rating .far.fa-star { color: rgba(255,255,255,.3); }
.listing-rating em { font-style: normal; margin-left: 6px; color: rgba(217,228,232,.75); font-weight: 700; }
#item-content .item-rating { font-size: 18px; margin: 0 0 14px; }
#item-content .item-rating .fa-star, #item-content .item-rating .fa-star-half-alt { color: var(--dir-accent); }

/* ---------- Footer newsletter ---------- */
.footer-newsletter {
  max-width: 560px; margin: 6px auto 20px; text-align: center;
  background: #ffffff; border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius); padding: 22px 20px;
  box-shadow: 0 12px 30px rgba(31,45,71,.14), 0 3px 8px rgba(31,45,71,.07);
}
.footer-newsletter h3 { color: var(--dir-ink); margin: 0 0 4px; font-size: 20px; }
.footer-newsletter p { color: var(--dir-muted); margin: 0 0 14px; font-size: 14px; }
.newsletter-form { display: flex; gap: 8px; }
.newsletter-form input {
  flex: 1; border: none !important; border-radius: 40px !important;
  padding: 12px 18px !important; background: #ffffff !important; color: var(--dir-ink) !important;
  box-shadow: inset 3px 3px 7px rgba(31,45,71,.10), inset -3px -3px 7px rgba(255,255,255,.9);
}
.newsletter-form button {
  border: none; background: var(--dir-primary); color: #fff; font-weight: 700;
  padding: 0 26px; border-radius: 40px; cursor: pointer; transition: background-color .15s ease;
}
.newsletter-form button:hover { background: var(--dir-primary-dark); }

/* ---------- Back to top ---------- */
#uktw-top {
  position: fixed; right: 22px; bottom: 22px; z-index: 200;
  width: 46px; height: 46px; border-radius: 50%; border: none; cursor: pointer;
  background: var(--dir-primary); color: #fff; font-size: 16px;
  box-shadow: 0 10px 24px rgba(0,0,0,.35);
  opacity: 0; visibility: hidden; transform: translateY(12px);
  transition: opacity .2s ease, transform .2s ease, background-color .15s ease;
}
#uktw-top.show { opacity: 1; visibility: visible; transform: none; }
#uktw-top:hover { background: var(--dir-primary-dark); }

@media (max-width: 767px) { .newsletter-form { flex-direction: column; } }

/* ---------- Tag chips ---------- */
#custom_fields .meta-tags { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 10px; }
#custom_fields .meta-tags .tag-chips { display: inline-flex; flex-wrap: wrap; gap: 8px; }
.tag-chip {
  display: inline-block;
  background: var(--dir-primary);
  color: #fff !important;
  font-size: 13px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 20px;
  text-decoration: none;
  transition: background-color .15s ease, color .15s ease;
}
.tag-chip:hover { background: var(--dir-primary-dark); color: #fff !important; }

/* ---------- Free-listing upgrade note ---------- */
#sidebar .upgrade-note {
  background: #fff8e8;
  border: 1px dashed var(--dir-accent);
  border-radius: var(--dir-radius-sm);
  padding: 14px;
  margin: 6px 0 12px;
}
#sidebar .upgrade-note strong { display: block; color: #9a6a00; margin-bottom: 4px; }
#sidebar .upgrade-note p { margin: 0; font-size: 13px; color: var(--dir-body); }

/* ---------- Dynamic (live) search dropdown ---------- */
.dsearch-dropdown {
  position: absolute;
  z-index: 200;
  top: 100%;      /* fallback; JS place() pins it precisely under the input */
  left: 0;
  margin-top: 0;
  background: #fff;
  border: 1px solid var(--dir-border);
  border-radius: var(--dir-radius-sm);
  box-shadow: 0 16px 40px rgba(22, 50, 79, .18);
  overflow: hidden;
  max-height: 420px;
  overflow-y: auto;
  text-align: left;
}
.dsearch-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--dir-border);
  color: var(--dir-ink);
  text-decoration: none;
}
.dsearch-item:last-child { border-bottom: 0; }
.dsearch-item:hover,
.dsearch-item.active { background: var(--dir-primary-soft); color: var(--dir-ink); }
.dsearch-thumb {
  flex: 0 0 auto;
  width: 46px; height: 46px;
  border-radius: 8px;
  background-size: cover;
  background-position: center;
  background-color: var(--dir-primary-soft);
  display: flex; align-items: center; justify-content: center;
  color: var(--dir-primary);
}
.dsearch-text { display: flex; flex-direction: column; min-width: 0; }
.dsearch-title { font-weight: 700; font-size: 15px; line-height: 1.25; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dsearch-meta { font-size: 12px; color: var(--dir-muted); }
.dsearch-empty { padding: 14px; color: var(--dir-muted); font-size: 14px; text-align: center; }

/* keep the hero search cells anchored for the absolute dropdown */
.home-search .main-search .cell.c1 { position: relative; }

/* ---------- Progressive screenshot bg ---------- */
.listing-thumb img { background: var(--dir-primary-soft); }

/* ---------- Small screens ---------- */
@media (max-width: 767px) {
  .home-intro { padding: 30px 0 12px; }
  .home-intro .intro-head h2 { font-size: 24px; }
  .home-intro .feature { flex-basis: 100%; }
  #item-content { padding: 18px 16px; }
  .listing-grid { grid-template-columns: 1fr; }
}
