/* ------------------------------------
 * Mobile helpers
 * ------------------------------------ */
@media (max-width: 767px) {
    .reverse-mobile {
        flex-direction: column-reverse;
    }
}

/* CoralBay – Ultra-compact BUY NOW button */
body.page-id-all-coralbay-uk .woocommerce a.button,
body.page-id-all-coralbay-uk .woocommerce .add_to_cart_button {
    font-size: 11px;
    padding: 3px 8px;
    line-height: 1;
    min-height: unset;
    border-radius: 4px;
}

/* Remove underline from all Divi buttons */
.et_pb_button,
.et_pb_button:link,
.et_pb_button:visited {
  text-decoration: none !important;
}

/* Remove underline on hover too */
.et_pb_button:hover {
  text-decoration: none !important;
}




body {
  font-family: 'Inter', sans-serif;
  font-size: 17px;
  line-height: 1.65;
  color: #333;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  letter-spacing: -0.2px;
}

/* ------------------------------------
   CoralBay homepage text layout
------------------------------------ */

.cb-more{
    margin-bottom:0;
}

.cb-more summary{
    display:inline-grid;
    cursor:pointer;
    text-decoration:underline;
    list-style:none;
    vertical-align:top;
    margin-bottom:1px;
}

.cb-more summary::-webkit-details-marker{
    display:none;
}

.cb-more summary::marker{
    content:"";
}

.cb-more .cb-open,
.cb-more .cb-close{
    grid-area:1 / 1;
}

.cb-more .cb-close{
    visibility:hidden;
}

.cb-more[open] .cb-open{
    visibility:hidden;
}

.cb-more[open] .cb-close{
    visibility:visible;
}

/* control paragraph spacing inside the expanded section */

.cb-more p{
    margin-top:0;
}

.cb-more p:first-of-type{
    margin-top:0;
}

/* Add a CSS override for single community coral listing pages */

.single-coral_listing #main-content .container,
.single-coral_listing #content-area,
.single-coral_listing #left-area {
  width: 100%;
  max-width: 100%;
}

.single-coral_listing #left-area {
  float: none;
  padding-right: 0 !important;
  width: 100% !important;
}

.single-coral_listing #sidebar {
  display: none !important;
}


/* ------------------------------------
 * Woo / Shop tweaks
 * ------------------------------------ */
.page-id-1179 .et_pb_shop ul.products li.product img {
    max-width: 120px !important;
    width: 120px !important;
}

.woocommerce-breadcrumb a {
    font-weight: 600;
}




/* ------------------------------------
 * Buttons â€“ /all-coralbay-uk/
 * ------------------------------------ */
body.page-id-all-coralbay-uk .woocommerce a.button,
body.page-id-all-coralbay-uk .woocommerce button.button,
body.page-id-all-coralbay-uk .woocommerce .add_to_cart_button {
    font-size: 13px;
    line-height: 1.2;
    border-radius: 6px;
    padding: 6px 12px;
    min-height: unset;
    letter-spacing: 0.3px;
}

body.page-id-all-coralbay-uk .woocommerce a.button:hover {
    opacity: 0.9;
}

/* =========================================
   CoralBay vendor directory cards
   For [cb_vendor_list]
   ========================================= */

.cb-vendor-directory {
  margin: 14px 0 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
}

.cb-vendor-card {
  display: block;
  padding: 16px 18px;
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: 14px;
  box-shadow: 0 6px 18px rgba(0,0,0,0.06);
  text-decoration: none !important;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.cb-vendor-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 24px rgba(0,0,0,0.10);
  border-color: rgba(18, 76, 124, 0.18);
  text-decoration: none !important;
}

.cb-vendor-card__name {
  font-size: 28px;
  line-height: 1.15;
  font-weight: 700;
  color: #1d1d1d;
  margin: 0 0 8px;
}

.cb-vendor-card__meta {
  font-size: 15px;
  line-height: 1.35;
  color: #666;
  opacity: 1;
}

/* Keep links inside these cards clean */
.cb-vendor-card,
.cb-vendor-card:link,
.cb-vendor-card:visited,
.cb-vendor-card:hover,
.cb-vendor-card:active {
  text-decoration: none !important;
}

/* Mobile */
@media (max-width: 767px) {
  .cb-vendor-directory {
    grid-template-columns: 1fr;
    gap: 12px;
  }

  .cb-vendor-card {
    padding: 14px 16px;
  }

  .cb-vendor-card__name {
    font-size: 22px;
  }

  .cb-vendor-card__meta {
    font-size: 14px;
  }
}

/* =========================================
   CoralBay vendor directory cards
   For [cb_vendor_list]	END
   ========================================= */


/* View product and Add to basket buttons styling for product tiles */

.cbvsb-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.cbvsb-card-body {
  display: flex;
  flex-direction: column;
  flex: 1;
}

.cbvsb-card-actions {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: auto;
  padding-top: 12px;
}
/* View product and Add to basket buttons styling for product tiles END */


/* === CoralBay Vendor Cards — Compact Clean Version === */

.cb-vendor-directory {
  display: grid !important;
  grid-template-columns: 1fr;
  gap: 14px;
}

@media (min-width: 768px) {
  .cb-vendor-directory {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 980px) {
  .cb-vendor-directory {
    grid-template-columns: repeat(3, 1fr);
  }
}

.cb-vendor-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px !important;
  min-height: 80px !important;
  border-radius: 14px;
}

/* Thumbnail — balanced size */
.cb-vendor-card__media {
  flex: 0 0 56px;
  width: 56px;
  height: 56px;
}

.cb-vendor-card__photo,
.cb-vendor-card__placeholder {
  width: 56px !important;
  height: 56px !important;
  border-radius: 10px;
  object-fit: cover;
}

/* Name */
.cb-vendor-card__name {
  font-size: 20px !important;
  line-height: 1.1;
  margin-bottom: 2px;
}

/* Hide bio for compact look */
.cb-vendor-card__bio {
  display: none !important;
}

/* Meta */
.cb-vendor-card__meta {
  font-size: 13px;
  opacity: 0.8;
  margin-top: 2px;
}

/* === Vendor card hover CTA === */

.cb-vendor-card {
  position: relative;
  overflow: hidden;
}

/* CTA element (hidden by default) */
.cb-vendor-card::after {
  content: "View Stock →";
  position: absolute;
  bottom: 10px;
  right: 12px;

  font-size: 13px;
  font-weight: 600;
  color: #1a1a1a;

  opacity: 0;
  transform: translateY(6px);
  transition: all 0.2s ease;
}

/* Show on hover */
.cb-vendor-card:hover::after {
  opacity: 1;
  transform: translateY(0);
}

/* Slight visual feedback */
.cb-vendor-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 20px rgba(0,0,0,0.08);
}

/* REMOVE WOOCOMMERCE BREADCRUMB */
.woocommerce-breadcrumb {
  display: none !important;
}






/* =========================================
   CoralBay Homepage Buttons (Divi)
   ========================================= */

/* Base button style (ALL homepage buttons) */
.home .et_pb_button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 50px;
  padding: 12px 22px;
  border-radius: 12px;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none !important;
  box-shadow: 0 6px 16px rgba(0,0,0,0.14);
  transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
}

/* Hover */
.home .et_pb_button:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 22px rgba(0,0,0,0.18);
  opacity: 0.96;
}

/* =========================================
   Individual button colours (by URL)
   ========================================= */

/* #c9321e Reef shops */
.home .et_pb_button[href*="/reef-shops/"] {
  background: #c9321e;
  color: #fff !important;
}

/* 🟠 Community corals */
.home .et_pb_button[href*="/community-corals/"] {
  background: #ff7a1a;
  color: #fff !important;
}

/* ⚫ Other seller */
.home .et_pb_button[href*="/other-sellers/"] {
  background: #1f2937;
  color: #fff !important;
}

/* #59abe8 Sell your corals */
.home .et_pb_button[href*="sell-corals"] {
  background: #59abe8;
  color: #fff !important;
}

/* #64b138 Main shop (optional) */
.home .et_pb_button[href*="/berghia-nudibranch/"] {
  background: #64b138;
  color: #fff !important;
}


/* =========================================
   Mobile improvements
   ========================================= */
@media (max-width: 767px) {
  .home .et_pb_button {
    width: 100%;
    max-width: 100%;
  }
}

.home .et_pb_button {
  letter-spacing: 0.2px;
  border: 1px solid rgba(255,255,255,0.08);
}
/* =========================================
   Individual button colours (by URL) END
   ========================================= */



/* /all-coralbay-uk/ — align top breadcrumb row and category pills on desktop */
.page-id-13895 .cbvsb-category-pills.sitewide-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 10px;
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* If Divi / wrapper adds left indent, kill it */
.page-id-13895 .cbvsb-category-pills.sitewide-toolbar,
.page-id-13895 .cbvsb-category-pills.sitewide-toolbar ul,
.page-id-13895 .cbvsb-category-pills.sitewide-toolbar .et_pb_module_inner {
  margin-left: 0 !important;
  padding-left: 0 !important;
}

/* Desktop only: keep same left edge as the breadcrumb row */
@media (min-width: 981px) {
  .page-id-13895 .cbvsb-context-switch,
  .page-id-13895 .cbvsb-category-pills.sitewide-toolbar {
    max-width: none !important;
  }
}



/* Footer email text */
.cb-footer-contact {
    text-align: center;
    font-size: 14px;
    color: #666;
    line-height: 1.5;
}

.cb-footer-email {
    display: inline-block;
    margin-top: 8px;
    padding: 10px 16px;              /* ↓ reduced padding */
    background: #2d6fa3;             /* slightly deeper, softer blue */
    color: #fff !important;
    border-radius: 8px;
    text-decoration: none;
    font-weight: 600;
    font-size: 15px;
    letter-spacing: 0.3px;
    box-shadow: 0 3px 10px rgba(0,0,0,0.12);
}

.cb-footer-email:hover {
    background: #1e5a88;
    transform: translateY(-1px);
}
/* Footer email text END */

/* HOME ICON IN TOP MENU ON MOBILE */
.cb-home-icon-fixed {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #2ea3f2;
    text-decoration: none;
    line-height: 1;
}

.cb-home-icon-fixed svg {
    display: block;
    width: 24px;
    height: 24px;
}
/* HOME ICON IN TOP MENU ON MOBILE END */

/* Ask seller
* 👉 to sit between Add to basket and Make an offer
*/

.cbvsb-contact-trigger {
    margin: 0px 0 10px 0;
}

.cbvsb-contact-btn {
    background: #fff;
    border: 1px solid #d7d7d7;
    padding: 6px 14px;
    font-size: 13px;
    line-height: 1;
    border-radius: 999px;
    cursor: pointer;
    color: #2ea3f2;
    box-shadow: none;
}

.cbvsb-contact-btn:hover {
    background: #f8fbff;
}

/* Ask seller
* 👉 to sit between Add to basket and Make an offer END
*/

/* Reduce gap under Add to basket */
.single-product .cart {
    margin-bottom: 0px !important;
/*	margin-top: 3px !important; */
}

/* Optional: tighten button spacing */
.single-product .single_add_to_cart_button {
    margin-bottom: 0px !important;
/*	margin-top: 3px !important; */
}


/* Divi header with home icon */

.cb-header-home-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  color: #2ea3f2;
  line-height: 1;
}

.cb-header-home-link svg {
  display: block;
}

@media (min-width: 981px) {
  .cb-header-home-link {
    display: none !important;
  }
}

@media (max-width: 980px) {
  .cb-header-wrap {
    position: relative;
  }

  .cb-header-home-link {
    position: absolute;
    left: 22px;
    top: 22px;
    transform: translateY(-50%);
    z-index: 5;
  }

  .cb-header-wrap .et_pb_search {
    margin-left: 42px;
  }
}
/* Divi header with home icon END */


/* ==================================================
   CoralBay Menu Styling
   Classes:
   cb-menu       = standard styled menu item
   cb-menu-btn   = button-style item
   cb-menu-map   = highlighted map CTA
================================================== */

/* =========================
   DESKTOP
========================= */

/* Base spacing for styled items */
.et_pb_menu .et-menu > li.cb-menu > a,
.et_pb_menu .et-menu > li.cb-menu-btn > a,
.et_pb_menu .et-menu > li.cb-menu-map > a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 14px !important;
  line-height: 1.2 !important;
  border-radius: 999px;
  transition: all 0.2s ease;
  text-decoration: none;
}

/* Standard styled menu items */
.et_pb_menu .et-menu > li.cb-menu > a {
  background: transparent;
  color: #23425f !important;
}

.et_pb_menu .et-menu > li.cb-menu > a:hover {
  background: rgba(46, 163, 242, 0.08);
  color: #1b6fd9 !important;
}

/* Button-style items */
.et_pb_menu .et-menu > li.cb-menu-btn > a {
  background: linear-gradient(135deg, #2a4f73, #1f3e5c);
  color: #ffffff !important;
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 4px 14px rgba(18, 76, 124, 0.16);
  font-weight: 600;
}

.et_pb_menu .et-menu > li.cb-menu-btn > a:hover {
  background: linear-gradient(135deg, #31618c, #234c71);
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.14);
  box-shadow: 0 6px 18px rgba(18, 76, 124, 0.22);
  transform: translateY(-1px);
}

/* Highlighted MAP buttons */
.et_pb_menu .et-menu > li.cb-menu-map > a {
  background: linear-gradient(135deg, #3db4ff, #2ea3f2);
  color: #fff !important;
  border: 1px solid transparent;
  box-shadow: 0 8px 22px rgba(46, 163, 242, 0.30);
  font-weight: 700;
}

.et_pb_menu .et-menu > li.cb-menu-map > a:hover {
  background: linear-gradient(135deg, #29a5f6, #1f8ee0);
  color: #fff !important;
  box-shadow: 0 10px 26px rgba(46, 163, 242, 0.36);
  transform: translateY(-1px);
}

/* Current desktop item */
.et_pb_menu .et-menu > li.current-menu-item.cb-menu > a {
  background: rgba(46, 163, 242, 0.10);
  color: #1b6fd9 !important;
  border-color: #c9e4fb;
}

.et_pb_menu .et-menu > li.current-menu-item.cb-menu-btn > a {
  background: linear-gradient(135deg, #31618c, #234c71);
  color: #ffffff !important;
  border-color: rgba(255,255,255,0.14);
}

.et_pb_menu .et-menu > li.current-menu-item.cb-menu-map > a {
  background: linear-gradient(135deg, #29a5f6, #1f8ee0);
  color: #fff !important;
}

/* Desktop submenu */
.et_pb_menu .et-menu li ul.sub-menu {
  background: #ffffff;
  border: 1px solid #e2e8ee;
  border-radius: 14px;
  padding: 8px 0;
  box-shadow: 0 10px 24px rgba(10, 20, 30, 0.12);
}

.et_pb_menu .et-menu li ul.sub-menu li {
  padding: 0;
}

.et_pb_menu .et-menu li ul.sub-menu li a {
  padding: 10px 16px !important;
  color: #23425f !important;
  background: transparent;
  border: 0;
  line-height: 1.3;
}

.et_pb_menu .et-menu li ul.sub-menu li a:hover {
  background: #f4f8fb;
  color: #1b6fd9 !important;
}

/* =========================
   MOBILE
========================= */
@media (max-width: 980px) {

  /* Menu panel */
.et_mobile_menu {
  text-align: center;
  padding: 16px 12px;
  background: linear-gradient(180deg, rgba(28, 39, 49, 0.60) 0%, rgba(18, 26, 34, 0.88) 100%);
  border-top: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.34);
}

  /* Remove default borders/shadows from wrappers */
  .et_mobile_menu ul,
  .et_mobile_menu li,
  .et_mobile_menu li ul,
  .et_mobile_menu li ul.sub-menu,
  .et_mobile_menu .sub-menu,
  .et_mobile_menu .menu-item-has-children,
  .et_mobile_menu .menu-item-has-children > ul {
    border: 0 !important;
    box-shadow: none !important;
  }

  /* Make submenu wrappers transparent */
  .et_mobile_menu .sub-menu,
  .et_mobile_menu li.menu-item-has-children > ul.sub-menu {
    display: block !important;
    background: transparent !important;
    background-color: transparent !important;
    padding: 0 !important;
    margin: 6px 0 0 0 !important;
  }

  .et_mobile_menu .sub-menu li,
  .et_mobile_menu li.menu-item-has-children .sub-menu li {
    background: transparent !important;
    background-color: transparent !important;
    margin: 9px 0 !important;
    padding: 0 !important;
    border-bottom: none !important;
  }

  /* Top-level items spacing */
  .et_mobile_menu > li {
    margin: 9px 0 !important;
    padding: 0 !important;
    border-bottom: none !important;
  }

/* All mobile links */
.et_mobile_menu li a {
  display: block !important;
  text-align: center !important;
  padding: 13px 16px !important;
  border-radius: 16px !important;
  background: #f8fafc !important;
  border: 1px solid #d7e0e7 !important;
  color: #162938 !important;
  font-weight: 600 !important;
  letter-spacing: 0.2px;
  line-height: 1.25 !important;
  box-shadow: 0 5px 14px rgba(5, 10, 20, 0.10) !important;
  width: auto !important;
}


/* Current / active page in mobile menu */
.et_mobile_menu .current-menu-item > a,
.et_mobile_menu .current_page_item > a,
.et_mobile_menu .current-menu-ancestor > a,
.et_mobile_menu .current_page_ancestor > a,
.et_mobile_menu .current_page_parent > a {
  background: linear-gradient(180deg, rgba(95, 100, 105, 0.92) 0%, rgba(60, 65, 70, 0.92) 100%) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  color: #ffffff !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08) !important;
}
.et_mobile_menu .current-menu-item > a {
  cursor: default;
  opacity: 0.95;
}
	
.et_mobile_menu .sub-menu li a {
  margin-left: 50px !important;
  margin-right: 50px !important;
  border-radius: 14px !important;
  padding: 11px 14px !important;
}
	
.et_mobile_menu li.cb-menu-map > a {
  background: linear-gradient(180deg, #fff8df 0%, #fff1bf 100%) !important;
  border: 1px solid #d4af37 !important;
  border-radius: 16px !important;
  color: #4a3710 !important;
  font-weight: 700 !important;
  box-shadow:
    0 5px 14px rgba(5, 10, 20, 0.10) !important,
    0 0 18px rgba(212, 175, 55, 0.45) !important;
}
/* Active/current MAP button = same active style as other active items */
.et_mobile_menu li.cb-menu-map.current-menu-item > a,
.et_mobile_menu li.cb-menu-map.current_page_item > a,
.et_mobile_menu li.cb-menu-map.current-menu-ancestor > a,
.et_mobile_menu li.cb-menu-map.current_page_ancestor > a,
.et_mobile_menu li.cb-menu-map.current_page_parent > a {
  background: linear-gradient(180deg, rgba(95, 100, 105, 0.92) 0%, rgba(60, 65, 70, 0.92) 100%) !important;
  border: 1px solid rgba(255,255,255,0.12) !important;
  color: #ffffff !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08) !important;
}


  .et_mobile_menu li a:hover,
  .et_mobile_menu li a:focus {
    background: #ffffff !important;
    border-color: #e6ebef !important;
    color: #1b2e40 !important;
  }

  /* Remove pseudo-elements/arrows */
  .et_mobile_menu li:before,
  .et_mobile_menu li:after,
  .et_mobile_menu li a:before,
  .et_mobile_menu li a:after,
  .et_mobile_menu .sub-menu li:before,
  .et_mobile_menu .sub-menu li:after,
  .et_mobile_menu .sub-menu li a:before,
  .et_mobile_menu .sub-menu li a:after {
    display: none !important;
    content: none !important;
  }
}

/* CoralBay Menu Styling END */

/* Smart Search backdrop was blocking clicks on dropdown results */
.smart-search-popup-backdrop {
  pointer-events: none !important;
}

/* Keep results clickable and above surrounding layout */
.ysm-search-results,
.ysm-search-results * {
  pointer-events: auto !important;
}

.ysm-search-results {
  z-index: 999999 !important;
}

/* Smart Search backdrop was blocking clicks on dropdown results END */

