/* =============================================
   M2M BOOKS — ADDITIONAL CSS (v2.7)
   WordPress admin > Appearance > Customize > Additional CSS
   ============================================= */

/* ─────────────────────────────────────────────
   HEADING STYLES — Montserrat (body font)
   ───────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Montserrat', system-ui, sans-serif;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #6B6B6B;
}

h1 {
  font-size: 2.5rem;
  line-height: 1.2;
  margin-bottom: 1.5rem;
}

h2 {
  font-size: 2rem;
  line-height: 1.3;
  margin-bottom: 1.25rem;
}

h3 {
  font-size: 1.5rem;
  line-height: 1.4;
  margin-bottom: 1rem;
}

h4 {
  font-size: 1.25rem;
  line-height: 1.5;
  margin-bottom: 0.75rem;
}

h5, h6 {
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 0.5rem;
}

/* ─────────────────────────────────────────────
   PAGE TITLE — Playfair Display
   ───────────────────────────────────────────── */
.page-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: #888780;
  text-transform: uppercase;
}

/* Hide first/top page title on bookshop page */
.page-template-default .page-title:first-of-type,
.woocommerce .page-title:first-of-type,
.archive .page-title:first-of-type {
  display: none !important;
}

/* ─────────────────────────────────────────────
   BODY TEXT — Montserrat
   ───────────────────────────────────────────── */
body,
p {
  font-family: 'Montserrat', system-ui, sans-serif;
}

/* ─────────────────────────────────────────────
   BUTTON STYLES — Playfair Display, Uppercase
   ───────────────────────────────────────────── */
button,
input[type="submit"],
.wp-block-button__link,
.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product .add_to_cart_button,
.single-product form.cart input[type="submit"],
.single-product form.cart button[type="submit"],
.single-product form.cart .single_add_to_cart_button,
.woocommerce-account .woocommerce form button,
.woocommerce-account .woocommerce form input[type="submit"],
.buddypress button,
.buddypress input[type="submit"],
.buddypress .generic-button,
.buddypress a.button,
.buddypress a.bp-button,
#aw-whats-new-submit {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
}

.buddypress button,
.buddypress input[type="submit"],
.buddypress a.button,
.buddypress a.bp-button,
#aw-whats-new-submit {
  padding: 12px 24px !important;
  border-radius: 4px !important;
  font-size: 0.95rem !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
  white-space: nowrap !important;
  display: inline-block !important;
  line-height: 1 !important;
}

.buddypress button:hover,
.buddypress input[type="submit"]:hover,
.buddypress a.button:hover,
.buddypress a.bp-button:hover {
  opacity: 0.9 !important;
}

/* ─────────────────────────────────────────────
   WOOCOMMERCE SPACING
   ───────────────────────────────────────────── */
.woocommerce ul.products,
.woocommerce div.product,
.page-title,
.woocommerce-result-count,
.woocommerce-ordering {
  margin-left: 2rem;
  margin-right: 2rem;
}

/* ─────────────────────────────────────────────
   WOOCOMMERCE RESULTS + SORT
   ───────────────────────────────────────────── */
.woocommerce-result-count {
  display: block !important;
  margin: 2rem 2rem 1.5rem 2rem !important;
  padding: 0 !important;
  font-size: 0.95rem !important;
  color: #6B6B6B !important;
  line-height: 1.4;
}

.woocommerce-ordering {
  display: block !important;
  margin: 0 2rem 2rem 2rem !important;
  padding: 0 !important;
  text-align: right;
}

.woocommerce-ordering select {
  padding: 0.5rem 0.75rem !important;
  margin: 0 !important;
  border: 1px solid #ddd !important;
  border-radius: 3px !important;
  font-family: 'Montserrat', system-ui, sans-serif !important;
  font-size: 0.9rem !important;
  background-color: #fff !important;
  color: #6B6B6B !important;
  cursor: pointer !important;
}

.woocommerce-ordering select:hover {
  border-color: #999 !important;
}

.woocommerce-ordering select:focus {
  outline: none !important;
  border-color: #1a3026 !important;
  box-shadow: 0 0 3px rgba(26, 48, 38, 0.2) !important;
}

@media (max-width: 768px) {
  .woocommerce-result-count {
    margin: 1.5rem 1rem 1rem 1rem !important;
  }

  .woocommerce-ordering {
    margin: 0 1rem 1.5rem 1rem !important;
    text-align: left;
  }

  .woocommerce-ordering select {
    width: 100% !important;
  }
}

/* ─────────────────────────────────────────────
   BODY TEXT COLOUR — #6B6B6B
   ───────────────────────────────────────────── */
body,
p,
span,
li,
td,
th,
label,
input,
textarea,
select,
.entry-content,
.widget-content,
.post-content,
.comment-content,
.woocommerce-account .woocommerce,
.woocommerce-page .woocommerce,
.woocommerce div.product p,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce .products .product-title,
.woocommerce-loop-product__title,
.product_meta,
.product_title,
.woocommerce-breadcrumb,
.woocommerce-result-count,
.buddypress .activity-content,
.buddypress .activity-header,
.buddypress .user-nicename,
.buddypress .comment-content {
  color: #6B6B6B !important;
}

/* Form inputs */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
input[type="url"],
input[type="number"],
textarea,
select {
  color: #6B6B6B !important;
}

input::placeholder,
textarea::placeholder {
  color: #999999 !important;
  opacity: 1 !important;
}

/* ─────────────────────────────────────────────
   LINKS — Maroon #8B1538 (except header nav)
   ───────────────────────────────────────────── */
a {
  color: #8B1538 !important;
  text-decoration: none;
  font-weight: 400;
  transition: font-weight 0.15s ease;
}

a:hover {
  font-weight: 500;
}

a:visited {
  color: #7A1A2E;
}

/* ─────────────────────────────────────────────
   FOOTER SOCIAL ICONS — White Circles, Grey Icons
   ───────────────────────────────────────────── */
.wp-block-social-links .wp-social-link {
  background-color: white !important;
  border-radius: 50% !important;
  width: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.wp-block-social-links .wp-social-link svg {
  fill: #6B6B6B !important;
  color: #6B6B6B !important;
  width: 24px !important;
  height: 24px !important;
}

footer .wp-block-social-links .wp-social-link {
  margin: 0.5rem;
}

/* ─────────────────────────────────────────────
   THE EVENTS CALENDAR
   ───────────────────────────────────────────── */
.post-type-archive-tribe_events button,
.post-type-archive-tribe_events button span,
.post-type-archive-tribe_events input[type="button"],
.post-type-archive-tribe_events input[type="submit"],
.post-type-archive-tribe_events a.button,
.tribe-common-c-btn,
.tribe-common-c-btn span,
.tribe-events-view--list button,
.tribe-events-view--list button span,
.tribe-events-view--month button,
.tribe-events-view--month button span {
  color: white !important;
  text-shadow: none !important;
}

.single-tribe_events {
  padding: 2rem !important;
}

.single-tribe_events .tribe-events-single {
  padding: 2rem !important;
  margin: 2rem !important;
}

.single-tribe_events .tribe-events-single-event-title {
  margin: 1.5rem 0 !important;
  padding: 0 !important;
}

.single-tribe_events .tribe-events-single-event-description {
  margin: 2rem 0 !important;
  padding: 0 !important;
}

.single-tribe_events .tribe-events-meta-group,
.single-tribe_events .tribe-events-meta-group-details {
  margin: 2rem 0 !important;
  padding: 1.5rem !important;
}

.single-tribe_events .tribe-events-cal-links {
  margin: 2rem 0 !important;
}

.single-tribe_events article {
  margin: 2rem 0 !important;
  padding: 2rem !important;
}

/* ─────────────────────────────────────────────
   SITE HEADER + LOGO (v1.4)
   Layout: logo + nav side-by-side, single row
   ───────────────────────────────────────────── */

/* Make header background white */
.site-header {
  background: #ffffff !important;
  flex-wrap: nowrap !important;
  padding: 12px 24px !important;
  gap: 24px !important;
}

/* Logo column */
.site-branding {
  flex: 0 0 auto !important;
  display: flex !important;
  align-items: center !important;
}

/* Force logo 2x size */
.custom-logo {
  max-width: 120px !important;
  width: 120px !important;
  height: auto !important;
  margin: 0 !important;
}

.custom-logo img {
  max-width: 100% !important;
  width: 100% !important;
  height: auto !important;
  display: block !important;
}

/* Nav menu column — center */
.main-navigation {
  flex: 1 1 auto !important;
  padding: 0 !important;
  text-align: center !important;
  margin: 0 !important;
}

.main-navigation ul {
  justify-content: center !important;
}

/* Responsive: stack on mobile */
@media (max-width: 768px) {
  .site-header {
    flex-wrap: wrap !important;
    gap: 16px !important;
  }
  
  .main-navigation {
    flex: 1 1 100% !important;
    text-align: center !important;
    order: 2 !important;
  }
  
  .main-navigation ul {
    justify-content: center !important;
  }
  
  .custom-logo {
    max-width: 100px !important;
    width: 100px !important;
  }
}

@media (max-width: 480px) {
  .custom-logo {
    max-width: 80px !important;
    width: 80px !important;
  }
}

/* ─────────────────────────────────────────────
   DROPDOWN MENU — Main Navigation
   ───────────────────────────────────────────── */

/* Main menu list styling */
.main-navigation ul {
  position: relative;
}

.main-navigation li {
  position: relative;
}

/* Arrow ONLY on parents with children */
.main-navigation li:has(> ul) > a::after {
  content: ' ▼';
  font-size: 0.65rem;
  margin-left: 6px;
  transition: transform 0.2s ease;
}

/* Rotate arrow on hover */
.main-navigation li:hover > a::after {
  transform: rotate(-180deg);
}

/* Nested submenu (ul within li) */
.main-navigation li > ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #ffffff;
  border: 1px solid #e0dcd5;
  border-radius: 4px;
  padding: 8px 0;
  min-width: 200px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  z-index: 1000;
  margin: 0;
  list-style: none;
}

/* Show submenu on parent hover */
.main-navigation li:hover > ul {
  display: block;
}

/* Submenu items */
.main-navigation li > ul li {
  padding: 0;
  margin: 0;
  position: relative;
}

.main-navigation li > ul li a {
  display: block;
  padding: 10px 16px;
  color: #6B6B6B;
  font-size: 0.9rem;
  text-decoration: none;
  transition: all 0.2s ease;
}

.main-navigation li > ul li a:hover {
  background: #f0ebe2;
  color: #8B1538;
  font-weight: 500;
  padding-left: 20px;
}

/* Remove link styling override for dropdown items */
.main-navigation li > ul li a,
.main-navigation li > ul li a:visited {
  color: #6B6B6B !important;
}

.main-navigation li > ul li a:hover {
  color: #8B1538 !important;
}

/* Multi-level support (submenu of submenu) */
.main-navigation li > ul li > ul {
  display: none;
  position: absolute;
  top: 0;
  left: 100%;
  margin-left: 4px;
}

.main-navigation li > ul li:hover > ul {
  display: block;
}

/* Hide HOME link text only on homepage */
.home .main-navigation > ul > li:first-of-type > a {
  font-size: 0 !important;
  width: 0 !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
}

.home .main-navigation > ul > li:first-of-type {
  width: auto;
  display: inline-block;
}

/* ─────────────────────────────────────────────
   HEADER NAVIGATION LINKS — OVERRIDE GLOBAL
   Apply AFTER global 'a' rule for proper cascading
   ───────────────────────────────────────────── */

.main-navigation a {
  color: #6B6B6B !important;
}

.main-navigation a:visited {
  color: #7A1A2E !important;
}

.main-navigation a:hover {
  color: #8B1538 !important;
}

/* ─────────────────────────────────────────────
   JOURNAL POSTS — Limit to 4 in Footer
   ───────────────────────────────────────────── */

/* Hide journal items 5 and beyond */
.footer-journal-posts li:nth-child(n+5) {
  display: none !important;
}

/* Journal post titles — left aligned */
.footer-journal-posts li a {
  text-align: left !important;
  display: block;
}

.footer-journal-posts li {
  text-align: left !important;
}

/* Journal section headings — left aligned */
.footer-journal-heading,
.footer-archives-heading {
  text-align: left !important;
}
