/*
Theme Name: M2M Books
Theme URI: https://m2mbooks.com
Author: Margin to Margin Books
Author URI: https://m2mbooks.com
Description: Custom theme for Margin to Margin Books.
Version: 1.4.1
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: m2m-books
*/

/* =============================================
   1. CSS CUSTOM PROPERTIES
   ============================================= */

:root {
  /* M2M Books palette */
  --green:        #1A3026;
  --green-mid:    #254537;
  --parchment:    #F5F2ED;
  --parchment-dk: #EAE6DF;
  --border:       rgba(26, 48, 38, 0.12);
  --text:         #1a1a1a;
  --text-muted:   #666;
  --red-link:     #8B1A1A;

  /* Hub palette */
  --hub-blue:   #2563eb;
  --hub-border: #e8e8e8;
  --hub-border-lt: #f2f2f2;
  --hub-text:   #111;
  --hub-muted:  #999;
  --hub-hint:   #bbb;
  --hub-orange: #ea580c;

  /* Typography */
  --font-heading: 'Playfair Display', Georgia, serif;
  --font-body:    'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:    'Courier New', monospace;
}

/* =============================================
   2. RESET & BASE
   ============================================= */

*, *::before, *::after { box-sizing: border-box; }

html { font-size: 16px; }

body {
  margin: 0;
  padding: 0;
  background: var(--parchment);
  color: var(--text);
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.7;
  animation: m2mFadeIn 1.5s ease forwards;
}

@keyframes m2mFadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}

/* Selection */
::selection      { background: var(--green); color: var(--parchment); }
::-moz-selection { background: var(--green); color: var(--parchment); }

/* Scoped image reset — not global to avoid breaking WC carousels */
.entry-content img,
.post-card img,
.hero-bg { display: block; max-width: 100%; height: auto; }

a { color: var(--red-link); text-decoration: none; }
a:hover { opacity: 0.75; }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  color: var(--green);
  line-height: 1.3;
  margin: 0 0 1rem;
  font-weight: 700;
}

p { margin: 0 0 1.2rem; }

/* =============================================
   3. ADMIN BAR OFFSET
   ============================================= */

/* Prevent sticky header from hiding behind WP admin bar */
.admin-bar .site-header { top: 32px; }
@media screen and (max-width: 782px) {
  .admin-bar .site-header { top: 46px; }
}

/* =============================================
   4. SITE LAYOUT
   ============================================= */

#page    { min-height: 100vh; display: flex; flex-direction: column; }
#content { flex: 1; }

.site-inner {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 24px;
}

/* =============================================
   5. HEADER & NAVIGATION
   ============================================= */

.site-header {
  background: var(--parchment);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 200;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  padding: 12px 24px;
  gap: 16px;
}

.site-branding {
  flex: 0 0 auto;
  padding: 0;
}

.site-title {
  font-family: var(--font-heading);
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--green);
  letter-spacing: 0.02em;
  display: inline;
}

.site-title a { color: inherit; }

.main-navigation {
  flex: 1 1 100%;
  padding: 0;
  text-align: center;
}

.main-navigation ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.main-navigation li { display: inline; }

.main-navigation a {
  font-family: var(--font-body);
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--green);
  padding: 4px 10px;
  display: inline-block;
  transition: opacity 0.2s ease;
}

.main-navigation a:hover { opacity: 0.6; }

/* =============================================
   6. HERO
   ============================================= */

.hero {
  position: relative;
  width: 100%;
  min-height: 300px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  background: var(--green);
}

.hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  opacity: 0.6;
}

.hero-title {
  position: relative;
  z-index: 2;
  font-family: var(--font-heading);
  font-size: clamp(1.8rem, 4.5vw, 3rem);
  font-weight: 700;
  color: #fff;
  text-align: center;
  padding: 40px 32px;
  line-height: 1.35;
  text-shadow: 0 1px 4px rgba(0,0,0,0.45);
  margin: 0;
}

/* =============================================
   7. ENTRY HEADER (pages & posts without hero)
   ============================================= */

.entry-header {
  text-align: center;
  padding: 40px 24px 0;
}

.entry-title {
  font-family: var(--font-heading);
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--green);
  margin: 0 0 12px;
}

.entry-header-rule {
  width: 60px;
  border: none;
  border-top: 1px solid var(--border);
  margin: 0 auto 40px;
}

/* =============================================
   8. PAGE / POST CONTENT
   ============================================= */

.entry-content {
  max-width: 720px;
  margin: 0 auto 60px;
  padding: 0 24px;
}

/* Drop cap — opt-in via Gutenberg paragraph block toggle only */
.has-drop-cap::first-letter {
  font-family: var(--font-heading);
  font-size: 4rem;
  float: left;
  line-height: 0.8;
  margin: 0.1em 0.1em 0 0;
  color: var(--green);
}

/* =============================================
   9. BLOG / JOURNAL POST CARDS
   ============================================= */

.posts-list {
  max-width: 720px;
  margin: 40px auto;
  padding: 0 24px;
}

.post-card {
  position: relative;
  margin-bottom: 32px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border);
  display: block;
  text-decoration: none;
}

.post-card-image {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
}

/* Fallback when no image */
.post-card-no-image {
  background: var(--green);
  min-height: 120px;
}

.post-card-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, transparent 55%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
}

.post-card-title {
  font-family: var(--font-heading);
  font-size: 1.4rem;
  font-weight: 700;
  color: #fff;
  margin: 0 0 6px;
  line-height: 1.25;
}

.post-card-excerpt {
  font-size: 0.88rem;
  color: rgba(255,255,255,0.85);
  margin: 0 0 8px;
  line-height: 1.5;
}

.post-card-date {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  color: rgba(255,255,255,0.65);
  font-style: italic;
}

/* Post navigation */
.post-nav {
  max-width: 720px;
  margin: 40px auto;
  padding: 0 24px;
  display: flex;
  justify-content: space-between;
  font-family: var(--font-body);
  font-size: 0.85rem;
  border-top: 1px solid var(--border);
  padding-top: 20px;
}

.post-nav a { color: var(--red-link); }

/* Post meta (date on single) */
.entry-meta {
  text-align: center;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 2rem;
}

/* Pagination */
.pagination {
  text-align: center;
  margin: 32px 0;
  font-family: var(--font-body);
}

.pagination a, .pagination span {
  display: inline-block;
  padding: 6px 12px;
  margin: 0 2px;
  color: var(--green);
  border: 1px solid var(--border);
  border-radius: 4px;
  font-size: 0.88rem;
}

.pagination .current { background: var(--green); color: var(--parchment); border-color: var(--green); }

/* =============================================
   10. PULLQUOTE
   ============================================= */

.wp-block-pullquote {
  border-top: 1px solid var(--green) !important;
  border-bottom: 1px solid var(--green) !important;
  padding: 30px 10px !important;
  border-left: none !important;
  border-right: none !important;
}

.wp-block-pullquote blockquote p {
  font-family: var(--font-heading) !important;
  font-size: 1.6rem !important;
  line-height: 1.4 !important;
  color: var(--green) !important;
  font-style: italic !important;
  font-weight: 700 !important;
}

@media (max-width: 600px) {
  .wp-block-pullquote blockquote p { font-size: 1.3rem !important; }
}

/* =============================================
   11. BUTTONS — M2M BOOKS
   ============================================= */

button:not(.search-submit):not([class*="wc-"]):not([class*="woocommerce"]),
input[type="submit"]:not(.search-submit),
.wp-block-button__link,
.wp-block-jetpack-subscriptions-button {
  background-color: var(--green) !important;
  color: var(--parchment) !important;
  border: 1px solid var(--green) !important;
  border-radius: 50px !important;
  padding: 14px 30px !important;
  font-family: var(--font-heading) !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-size: 0.9rem !important;
  transition: all 0.2s ease !important;
  cursor: pointer !important;
  display: inline-block;
}

button:not(.search-submit):hover,
.wp-block-button__link:hover {
  background-color: transparent !important;
  color: var(--green) !important;
}

/* Focus states */
:focus {
  outline: 2px solid var(--green) !important;
  outline-offset: 3px !important;
}

button:focus,
input:focus,
select:focus,
textarea:focus,
.wp-block-button__link:focus {
  box-shadow: 0 0 0 2px var(--parchment), 0 0 0 4px var(--green) !important;
}

a:focus {
  background-color: rgba(26, 48, 38, 0.08) !important;
  text-decoration: underline !important;
  color: var(--green) !important;
}

/* =============================================
   12. IMAGES (scoped)
   ============================================= */

.entry-content .wp-block-image img,
.featured-image img,
.post-thumbnail img {
  border-radius: 12px !important;
  border: 1px solid var(--border);
}

/* =============================================
   13. SUBSCRIPTION SECTION
   ============================================= */

.wp-block-jetpack-subscriptions {
  padding: 60px 20px !important;
  background-color: var(--parchment) !important;
  text-align: center;
}

.m2m-inner-circle-heading {
  font-family: var(--font-heading) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.15em !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: var(--green) !important;
  margin-bottom: 20px !important;
}

.m2m-award-text {
  font-family: var(--font-mono) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.1em !important;
  color: var(--green);
  opacity: 0.8;
  text-transform: uppercase;
  display: block;
  margin-bottom: 20px;
}

.m2m-award-logo img,
.wp-block-jetpack-subscriptions img {
  max-width: 150px !important;
  height: auto !important;
  margin: 0 auto 20px !important;
  display: block !important;
  border-radius: 8px;
}

/* =============================================
   14. PUBLICATION DETAILS CARD
   ============================================= */

.entry-content .pub-details {
  max-width: 520px;
  border: 1px solid #d9d3cb;
  padding: 1.5rem 2rem;
  margin: 1.5rem auto;
}

.entry-content .pub-details * { margin: 0 !important; padding: 0 !important; line-height: 1.3 !important; }
.entry-content .pub-details .pub-title    { font-family: Georgia, serif !important; font-size: 1.4rem !important; font-weight: 400 !important; color: #1a1a1a !important; display: block !important; margin-bottom: 0.15rem !important; }
.entry-content .pub-details .pub-subtitle { font-family: Georgia, serif !important; font-style: italic !important; font-size: 0.9rem !important; color: #555 !important; display: block !important; margin-bottom: 0.6rem !important; }
.entry-content .pub-details hr { border: none !important; border-top: 1px solid #e0dbd4 !important; }
.entry-content .pub-details .pub-label    { font-size: 0.62rem !important; font-weight: 500 !important; letter-spacing: 0.12em !important; text-transform: uppercase !important; color: #999 !important; display: block !important; padding-top: 0.5rem !important; padding-bottom: 0.1rem !important; }
.entry-content .pub-details .pub-value    { font-size: 0.88rem !important; color: #1a1a1a !important; display: block !important; }
.entry-content .pub-details .pub-tags     { display: flex !important; gap: 0.5rem !important; padding-top: 0.1rem !important; padding-bottom: 0.3rem !important; }
.entry-content .pub-details .pub-tag      { font-size: 0.72rem !important; font-weight: 500 !important; letter-spacing: 0.06em !important; padding: 0.2rem 0.6rem !important; border: 1px solid #d9d3cb !important; color: #555 !important; text-transform: uppercase !important; }
.entry-content .pub-details .pub-note     { font-family: Georgia, serif !important; font-style: italic !important; font-size: 0.8rem !important; color: #777 !important; line-height: 1.4 !important; display: block !important; }

/* =============================================
   15. JETPACK CONTACT FORM
   ============================================= */

.wp-block-jetpack-contact-form .grunion-field-wrap,
.wp-block-jetpack-contact-form [class*="grunion-field-width"] {
  width: 100% !important; max-width: 100% !important; display: block !important;
  margin-top: 0 !important; margin-bottom: 0.5rem !important;
  padding: 0 !important; flex: 0 0 100% !important;
}

.wp-block-jetpack-label,
.grunion-field-label,
.wp-block-jetpack-contact-form label {
  font-size: 0.9rem !important; font-weight: 500 !important; color: #444 !important;
  display: block !important; margin-bottom: 0.25rem !important; line-height: 1.4 !important;
  font-style: normal !important; letter-spacing: 0 !important; text-transform: none !important;
  white-space: normal !important; word-break: normal !important;
}

.wp-block-jetpack-contact-form input[type="text"],
.wp-block-jetpack-contact-form input[type="email"],
.wp-block-jetpack-contact-form select {
  background: #fff !important; color: #1a1a1a !important;
  border: 1px solid #d9d3cb !important; border-radius: 4px !important;
  padding: 10px 14px !important; font-size: 1rem !important;
  width: 100% !important; box-sizing: border-box !important; display: block !important;
}

.wp-block-jetpack-contact-form textarea {
  background: #fff !important; color: #1a1a1a !important;
  border: 1px solid #d9d3cb !important; border-radius: 4px !important;
  padding: 10px 14px !important; font-size: 1rem !important;
  width: 100% !important; box-sizing: border-box !important;
  min-height: 80px !important; resize: vertical !important;
}

.wp-block-jetpack-contact-form input[type="text"]:focus,
.wp-block-jetpack-contact-form input[type="email"]:focus,
.wp-block-jetpack-contact-form textarea:focus,
.wp-block-jetpack-contact-form select:focus {
  border: 1px solid var(--green) !important; outline: none !important; box-shadow: none !important;
}

.wp-block-jetpack-contact-form input[type="submit"] {
  background-color: var(--green) !important; color: var(--parchment) !important;
  border: 1px solid var(--green) !important; border-radius: 50px !important;
  padding: 14px 30px !important; font-family: var(--font-heading) !important;
  font-weight: 700 !important; letter-spacing: 0.05em !important;
  text-transform: uppercase !important; font-size: 0.9rem !important;
  transition: all 0.2s ease !important; cursor: pointer !important;
  width: auto !important; margin-top: 0.75rem !important;
}

/* =============================================
   16. WOOCOMMERCE — SHOP ARCHIVE
   ============================================= */

.woocommerce-main { padding: 40px 0; }

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  text-transform: none !important;
  font-family: var(--font-heading) !important;
  font-size: 1.1rem !important;
  font-weight: 700 !important;
  color: #1a1a1a !important;
  letter-spacing: 0 !important;
}

.woocommerce ul.products li.product a.button,
.woocommerce ul.products li.product .add_to_cart_button {
  background: var(--green) !important;
  color: var(--parchment) !important;
  border: 1px solid var(--green) !important;
  border-radius: 50px !important;
  padding: 10px 24px !important;
  font-family: var(--font-heading) !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-size: 0.8rem !important;
  display: inline-block !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-decoration: none !important;
}

.woocommerce ul.products li.product a.button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
  background: transparent !important;
  color: var(--green) !important;
}

/* =============================================
   17. WOOCOMMERCE — SINGLE PRODUCT
   ============================================= */

.single-product form.cart input,
.single-product form.cart select {
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-family: inherit !important;
  font-weight: 400 !important;
  border-radius: 4px !important;
  padding: 8px 12px !important;
  width: auto !important;
  font-size: 1rem !important;
}

.single-product form.cart input[type="submit"],
.single-product form.cart button[type="submit"],
.single-product form.cart .single_add_to_cart_button {
  background: var(--green) !important;
  color: var(--parchment) !important;
  border: 1px solid var(--green) !important;
  border-radius: 50px !important;
  padding: 14px 30px !important;
  font-family: var(--font-heading) !important;
  font-weight: 700 !important;
  letter-spacing: 0.05em !important;
  text-transform: uppercase !important;
  font-size: 0.9rem !important;
  width: auto !important;
  display: inline-block !important;
}

/* Hide unnecessary elements */
.single-product form.cart label abbr,
.single-product form.cart abbr[title],
.single-product .nyp-minimum,
.single-product .nyp-tip,
.single-product .nyp-description,
.single-product .nyp .form-row > p { display: none !important; }

/* Express payment layout */
.single-product .wc-block-components-express-payment {
  margin: 0 !important; padding: 0 !important;
}

.single-product .wc-block-components-express-payment__event-buttons {
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
  margin: 0 !important; padding: 0 !important;
}

.single-product .wc-block-components-express-payment__event-buttons > * {
  margin: 0 !important; padding: 0 !important;
}

/* =============================================
   18. WOOCOMMERCE — MY ACCOUNT
   ============================================= */

.woocommerce-account .woocommerce form input[type="text"],
.woocommerce-account .woocommerce form input[type="email"],
.woocommerce-account .woocommerce form input[type="password"] {
  background: #fff !important; color: #1a1a1a !important;
  border: 1px solid #d9d3cb !important; border-radius: 4px !important;
  padding: 8px 12px !important; font-size: 0.9rem !important;
  font-weight: 400 !important; letter-spacing: 0 !important;
  text-transform: none !important; width: 100% !important;
  box-sizing: border-box !important; display: block !important;
}

.woocommerce-account .woocommerce form label {
  font-size: 0.8rem !important; font-weight: 500 !important;
  letter-spacing: 0 !important; text-transform: none !important;
  color: #555 !important; display: block !important;
  margin-bottom: 0.3rem !important; white-space: normal !important;
  word-break: normal !important; font-style: normal !important;
}

.woocommerce-account .woocommerce form input[type="submit"],
.woocommerce-account .woocommerce form button[type="submit"] {
  background: var(--green) !important; color: var(--parchment) !important;
  border: 1px solid var(--green) !important; border-radius: 50px !important;
  padding: 14px 30px !important; font-family: var(--font-heading) !important;
  font-weight: 700 !important; letter-spacing: 0.05em !important;
  text-transform: uppercase !important; font-size: 0.9rem !important;
  width: auto !important; display: inline-block !important;
  cursor: pointer !important; position: static !important;
}

/* Hide search form that appears on account pages */
.woocommerce-account form.search-form,
.woocommerce-account form[role="search"],
.woocommerce-account input.search-submit {
  display: none !important; visibility: hidden !important;
  width: 0 !important; height: 0 !important;
  overflow: hidden !important; position: absolute !important;
  clip: rect(0, 0, 0, 0) !important;
}

/* =============================================
   19. CONTENT LAYOUT UTILS
   ============================================= */

.entry-content .wp-block-html { text-align: center; }
.entry-content iframe[src*="substack.com"] { display: block; margin: 0 auto; }

/* =============================================
   20. FOOTER — M2M BOOKS
   ============================================= */

.site-footer {
  background: var(--parchment);
  border-top: 1px solid var(--border);
  font-family: Georgia, serif;
  font-size: 0.88rem;
  color: var(--text-muted);
}

/* Subscribe strip */
.footer-subscribe {
  background: var(--parchment-dk);
  padding: 40px 24px;
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.footer-subscribe-widget { max-width: 640px; margin: 0 auto; }

/* Main footer body */
.footer-body {
  max-width: 960px;
  margin: 0 auto;
  padding: 36px 24px 24px;
}

.footer-press-info {
  margin-bottom: 20px;
  line-height: 1.7;
  text-align: left;
}

.footer-press-info strong { color: var(--text); }
.footer-press-info a { color: var(--red-link); }

/* Footer nav */
.footer-nav { text-align: center; margin-bottom: 16px; }

.footer-nav-list {
  list-style: none; margin: 0; padding: 0; display: inline;
}

.footer-nav-list li { display: inline; }

.footer-nav-list li::after {
  content: ' · ';
  color: var(--text-muted);
}

.footer-nav-list li:last-child::after { content: ''; }

.footer-nav-list a {
  font-size: 0.82rem;
  color: var(--red-link);
}

/* Footer body widgets */
.footer-body-widget { margin-bottom: 20px; }
.footer-body-widget.footer-body-widget-custom_html { font-size: 0.88rem; line-height: 1.6; }
.footer-widget-title { font-family: var(--font-heading); font-weight: 700; color: var(--green); font-size: 1rem; margin: 0 0 12px; padding: 0; }

/* Footer social */
.footer-social {
  text-align: center;
  margin-bottom: 28px;
}

.footer-social-list {
  list-style: none; margin: 0; padding: 0;
  display: flex; justify-content: center; gap: 10px; flex-wrap: wrap;
}

.footer-social-list li { display: inline; }

.footer-social-list a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--green);
  color: var(--parchment);
  font-size: 0.72rem;
  font-family: var(--font-mono);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0;
  opacity: 1;
  transition: opacity 0.2s;
}

.footer-social-list a:hover { opacity: 0.75; }

/* Footer journal */
.footer-journal { margin-top: 24px; border-top: 1px solid var(--border); padding-top: 20px; }

.footer-journal-heading {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-align: center;
  margin-bottom: 12px;
}

.footer-journal-posts {
  list-style: none; padding: 0; margin: 0 0 20px;
  text-align: center;
}

.footer-journal-posts li { margin-bottom: 4px; }
.footer-journal-posts a { color: var(--red-link); font-size: 0.85rem; }

.footer-archives-heading {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
  text-align: center;
  margin-bottom: 8px;
}

.footer-archives select {
  display: block;
  margin: 0 auto;
  font-size: 0.88rem;
  padding: 6px 10px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--parchment);
  color: var(--text);
  font-family: Georgia, serif;
}

/* =============================================
   21. SKIP LINK (accessibility)
   ============================================= */

.skip-link {
  position: absolute;
  top: -40px;
  left: 0;
  background: var(--parchment);
  color: var(--green);
  padding: 8px 16px;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  border: 1px solid var(--green);
  z-index: 9999;
  transition: top 0.2s;
}

.skip-link:focus { top: 0; }

/* =============================================
   22. SEARCH & 404
   ============================================= */

.search-form { max-width: 480px; margin: 0 auto 40px; display: flex; gap: 8px; }
.search-field { flex: 1; padding: 10px 14px; border: 1px solid var(--border); border-radius: 4px; font-size: 1rem; font-family: Georgia, serif; }
.search-submit { padding: 10px 20px; background: var(--green); color: var(--parchment); border: none; border-radius: 50px; font-family: var(--font-heading); font-weight: 700; font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.05em; cursor: pointer; }

.not-found { text-align: center; padding: 80px 24px; }
.not-found .entry-title { font-size: 4rem; opacity: 0.15; }

/* =============================================
   23. HEADER WIDGET AREA
   ============================================= */

.header-right {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
}

.header-right-widget {
  display: flex;
  align-items: center;
}

.header-right-widget form {
  display: flex;
  gap: 4px;
}

.header-right-widget .search-field {
  width: 200px;
  padding: 8px 12px;
  font-size: 0.9rem;
  border: 1px solid var(--border);
  border-radius: 4px;
}

.header-right-widget .search-submit {
  padding: 8px 16px;
  font-size: 0.75rem;
  background: var(--green);
  color: var(--parchment);
  border: none;
  border-radius: 4px;
  cursor: pointer;
}

/* Additional styles follow in section 9 */

/* =============================================
   9. ADDITIONAL STYLES
   Incorporated from Additional CSS v2.7
   Source: WordPress Customizer > Additional CSS
   Override scope: Text colors, headings, buttons, navigation, forms
   ============================================= */

/* ─────────────────────────────────────────────
   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 or focus (touch devices) */
.main-navigation li:hover > ul,
.main-navigation li:focus-within > 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;
}

