/* ================================================================
   PP-Lovable Blog Styles
   Restyles the OceanWP blog (listing, single, search, sidebar) to
   match the pp-lovable design system used by the site header/footer.

   Strategy:
   - Loaded ONLY on blog contexts (see sl_pp_blog_styles() enqueue).
   - Selectors are scoped under #content-wrap / #primary / #right-sidebar
     (specificity 100+) and colour kills use !important so they reliably
     override OceanWP's customizer CSS (primary colour #e2344b — the red).
   - Tokens mirror lovable-upload-header-footer.css.
   ================================================================ */

:root {
  --ppb-bg:            #f7f8fb;
  --ppb-card:          #ffffff;
  --ppb-radius:        18px;
  --ppb-radius-sm:     12px;
  --ppb-radius-xs:     10px;
  --ppb-shadow:        0 2px 24px rgba(0, 0, 0, 0.07);
  --ppb-shadow-hover:  0 10px 30px rgba(0, 0, 0, 0.12);

  --ppb-accent:        oklch(0.72 0.16 70);      /* gold */
  --ppb-accent-light:  oklch(0.78 0.16 70);
  --ppb-accent-ink:    oklch(0.18 0.02 250);     /* dark text on gold */
  --ppb-warm:          #e07b30;                  /* orange titles/accents */
  --ppb-warm-soft:     #fff7ef;
  --ppb-warm-border:   #f0d4b0;
  --ppb-warm-hover:    #c96820;
  --ppb-navy:          oklch(0.24 0.02 250);

  --ppb-text:          #1a1a1a;
  --ppb-muted:         #5a5a5a;
  --ppb-muted-2:       #8a8f9a;
  --ppb-border:        rgba(20, 24, 40, 0.08);

  --ppb-font: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ================================================================
   1. Layout — content column + sidebar spacing
   ================================================================ */
#content-wrap {
  font-family: var(--ppb-font);
}
#content-wrap .entries,
#content-wrap #blog-entries {
  margin-bottom: 8px;
}

/* ================================================================
   2. Blog listing — each entry becomes a white card
   ================================================================ */
#blog-entries .blog-entry {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border) !important;
  border-radius: var(--ppb-radius);
  box-shadow: var(--ppb-shadow);
  padding: 26px 28px;
  margin-bottom: 26px;
  transition: box-shadow 200ms ease, transform 200ms ease;
  overflow: hidden;
}
#blog-entries .blog-entry:hover {
  box-shadow: var(--ppb-shadow-hover);
  transform: translateY(-2px);
}
/* kill OceanWP's default dividing borders / inner padding */
#blog-entries .blog-entry .blog-entry-inner {
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Featured image */
#blog-entries .blog-entry .thumbnail,
#blog-entries .blog-entry .blog-entry-media {
  border-radius: var(--ppb-radius-sm);
  overflow: hidden;
  margin-bottom: 18px;
}
#blog-entries .blog-entry .thumbnail img,
#blog-entries .blog-entry .blog-entry-media img {
  border-radius: var(--ppb-radius-sm);
  display: block;
}

/* Category — gold pill instead of red text */
#blog-entries .blog-entry-category {
  margin-bottom: 12px;
}
#blog-entries .blog-entry-category a {
  display: inline-flex;
  align-items: center;
  background: var(--ppb-warm-soft) !important;
  color: var(--ppb-warm) !important;
  border: 1px solid var(--ppb-warm-border);
  border-radius: 9999px;
  padding: 4px 12px;
  margin: 0 6px 6px 0;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.4;
  transition: filter 150ms;
}
#blog-entries .blog-entry-category a:hover {
  filter: brightness(0.95);
  color: var(--ppb-warm-hover) !important;
}

/* Title */
#blog-entries .blog-entry-header .entry-title,
#blog-entries .blog-entry-title {
  margin: 0 0 12px;
}
#blog-entries .blog-entry-header .entry-title a,
#blog-entries .blog-entry-title a {
  font-family: var(--ppb-font);
  font-weight: 800;
  color: var(--ppb-text) !important;
  letter-spacing: -0.2px;
  transition: color 150ms;
}
#blog-entries .blog-entry-header .entry-title a:hover,
#blog-entries .blog-entry-title a:hover {
  color: var(--ppb-warm) !important;
}

/* Excerpt / summary */
#blog-entries .blog-entry-summary,
#blog-entries .blog-entry-summary p {
  color: var(--ppb-muted) !important;
  font-size: 15px;
  line-height: 1.7;
}

/* Bottom meta row (date / comments) */
#blog-entries .blog-entry-bottom {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--ppb-border);
}
#blog-entries .blog-entry-bottom .blog-entry-date,
#blog-entries .blog-entry-bottom .blog-entry-comments,
#blog-entries .blog-entry-bottom .blog-entry-date a,
#blog-entries .blog-entry-bottom .blog-entry-comments a,
#blog-entries .blog-entry-readmore + * {
  color: var(--ppb-muted-2) !important;
  font-size: 12.5px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
#blog-entries .blog-entry-bottom a:hover {
  color: var(--ppb-warm) !important;
}
#blog-entries .blog-entry-bottom .owp-icon use {
  stroke: var(--ppb-accent) !important;
}

/* ================================================================
   3. Read-more / pill buttons (listing + single + comments + search)
   ================================================================ */
#content-wrap .blog-entry-readmore a,
#content-wrap .button,
#content-wrap input[type="submit"],
#content-wrap button[type="submit"],
#content-wrap .wp-block-search__button,
#right-sidebar .wp-block-search__button,
#right-sidebar input[type="submit"],
#right-sidebar button[type="submit"],
#right-sidebar .button {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--ppb-accent) !important;
  background-image: none !important;
  color: var(--ppb-accent-ink) !important;
  border: none !important;
  border-radius: 9999px !important;
  padding: 11px 22px !important;
  font-family: var(--ppb-font);
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  line-height: 1.2;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.15);
  transition: transform 150ms, filter 150ms;
  cursor: pointer;
  text-shadow: none;
}
#content-wrap .blog-entry-readmore a:hover,
#content-wrap .button:hover,
#content-wrap input[type="submit"]:hover,
#content-wrap button[type="submit"]:hover,
#content-wrap .wp-block-search__button:hover,
#right-sidebar .wp-block-search__button:hover,
#right-sidebar input[type="submit"]:hover,
#right-sidebar button[type="submit"]:hover,
#right-sidebar .button:hover {
  filter: brightness(1.08);
  transform: translateY(-1px);
  color: var(--ppb-accent-ink) !important;
  border-color: transparent !important;
}
#content-wrap .blog-entry-readmore a .owp-icon use {
  stroke: var(--ppb-accent-ink) !important;
}
#content-wrap .blog-entry-readmore {
  margin-top: 18px;
}

/* ================================================================
   4. Pagination
   ================================================================ */
#content-wrap .oceanwp-pagination .page-numbers,
#content-wrap .pagination .page-numbers,
#content-wrap nav.navigation .nav-links a,
#content-wrap nav.navigation .nav-links span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  height: 40px;
  padding: 0 12px;
  background: var(--ppb-card) !important;
  border: 1px solid var(--ppb-border) !important;
  border-radius: var(--ppb-radius-xs);
  color: var(--ppb-text) !important;
  font-weight: 700;
  font-size: 13px;
  box-shadow: var(--ppb-shadow);
  transition: all 150ms;
}
#content-wrap .oceanwp-pagination .page-numbers.current,
#content-wrap .pagination .page-numbers.current,
#content-wrap nav.navigation .nav-links span.current {
  background: var(--ppb-accent) !important;
  color: var(--ppb-accent-ink) !important;
  border-color: transparent !important;
}
#content-wrap .oceanwp-pagination a.page-numbers:hover,
#content-wrap .pagination a.page-numbers:hover {
  border-color: var(--ppb-accent) !important;
  color: var(--ppb-warm) !important;
}

/* ================================================================
   5. Single post — content card + typography
   ================================================================ */
body.single-post #primary > article,
body.single-post #primary > .entry {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border);
  border-radius: var(--ppb-radius);
  box-shadow: var(--ppb-shadow);
  padding: 34px 38px;
  margin-bottom: 28px;
  overflow: hidden;
}

body.single-post .entry-title,
body.single-post .single-post-title,
body.single-post .ocean-single-post-header .single-post-title {
  font-family: var(--ppb-font) !important;
  font-weight: 900 !important;
  color: var(--ppb-text) !important;
  letter-spacing: -0.4px !important;
}

/* Single featured image */
body.single-post .single-featured-image,
body.single-post .post-thumbnail,
body.single-post .entry-media img {
  border-radius: var(--ppb-radius-sm);
  overflow: hidden;
}

/* Single meta row */
body.single-post ul.meta,
body.single-post .ocean-single-post-header ul.meta-item {
  font-family: var(--ppb-font);
}
body.single-post ul.meta li,
body.single-post ul.meta li a,
body.single-post .meta-item li,
body.single-post .meta-item li a {
  color: var(--ppb-muted-2) !important;
  font-weight: 600;
}
body.single-post ul.meta li a:hover,
body.single-post .meta-item li a:hover {
  color: var(--ppb-warm) !important;
}
body.single-post ul.meta li .owp-icon use,
body.single-post .meta-item li .owp-icon use {
  stroke: var(--ppb-accent) !important;
}

/* Article body content */
#content-wrap .entry-content {
  font-family: var(--ppb-font);
  color: var(--ppb-text);
  font-size: 16px;
  line-height: 1.8;
}
#content-wrap .entry-content a {
  color: var(--ppb-warm) !important;
  text-decoration: underline;
  text-decoration-color: var(--ppb-warm-border);
  text-underline-offset: 2px;
  transition: color 150ms;
}
#content-wrap .entry-content a:hover {
  color: var(--ppb-warm-hover) !important;
  text-decoration-color: var(--ppb-warm);
}
#content-wrap .entry-content h1,
#content-wrap .entry-content h2,
#content-wrap .entry-content h3,
#content-wrap .entry-content h4 {
  font-family: var(--ppb-font);
  color: var(--ppb-text);
  font-weight: 800;
  letter-spacing: -0.2px;
}
#content-wrap .entry-content blockquote {
  border-left: 4px solid var(--ppb-accent) !important;
  background: var(--ppb-warm-soft);
  border-radius: 0 var(--ppb-radius-xs) var(--ppb-radius-xs) 0;
  padding: 16px 20px;
  margin: 22px 0;
  color: var(--ppb-text);
}
#content-wrap .entry-content blockquote p { color: var(--ppb-text); }

/* Tags */
#content-wrap .post-tags a,
#content-wrap .entry-tags a,
#content-wrap .tagcloud a {
  display: inline-flex;
  align-items: center;
  background: var(--ppb-warm-soft) !important;
  color: var(--ppb-warm) !important;
  border: 1px solid var(--ppb-warm-border) !important;
  border-radius: 9999px;
  padding: 5px 14px;
  margin: 0 6px 8px 0;
  font-size: 11.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: filter 150ms;
}
#content-wrap .post-tags a:hover,
#content-wrap .entry-tags a:hover,
#content-wrap .tagcloud a:hover {
  filter: brightness(0.96);
  color: var(--ppb-warm-hover) !important;
}

/* Next / previous navigation */
#content-wrap nav.post-navigation,
#content-wrap .single nav.post-navigation {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border);
  border-radius: var(--ppb-radius);
  box-shadow: var(--ppb-shadow);
  padding: 18px 24px;
  margin-bottom: 28px;
}
#content-wrap nav.post-navigation .title {
  color: var(--ppb-warm) !important;
  font-weight: 700;
}
#content-wrap nav.post-navigation a:hover .post-title,
#content-wrap nav.post-navigation a:hover {
  color: var(--ppb-warm) !important;
}
#content-wrap nav.post-navigation .owp-icon use {
  stroke: var(--ppb-accent) !important;
}

/* Author bio */
#content-wrap .author-bio,
#content-wrap .author-box {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border);
  border-radius: var(--ppb-radius);
  box-shadow: var(--ppb-shadow);
  padding: 24px 28px;
  margin-bottom: 28px;
}

/* Related posts */
#content-wrap .related-post-wrap,
#content-wrap .related-post {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border);
  border-radius: var(--ppb-radius-sm);
  box-shadow: var(--ppb-shadow);
  padding: 16px;
  transition: box-shadow 200ms ease, transform 200ms ease;
}
#content-wrap .related-post:hover {
  box-shadow: var(--ppb-shadow-hover);
  transform: translateY(-2px);
}
#content-wrap .related-post-title a,
#content-wrap .related-posts-title {
  color: var(--ppb-text) !important;
  font-family: var(--ppb-font);
  font-weight: 800;
}
#content-wrap .related-post-title a:hover {
  color: var(--ppb-warm) !important;
}
#content-wrap .related-post .thumbnail,
#content-wrap .related-post img {
  border-radius: var(--ppb-radius-xs);
  overflow: hidden;
}

/* ================================================================
   6. Comments
   ================================================================ */
#content-wrap #comments,
#content-wrap .comments-area {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border);
  border-radius: var(--ppb-radius);
  box-shadow: var(--ppb-shadow);
  padding: 28px 32px;
  margin-bottom: 28px;
}
#content-wrap .comment-reply-title,
#content-wrap #comments .comments-title {
  font-family: var(--ppb-font);
  font-weight: 800;
  color: var(--ppb-text);
}
#content-wrap .comment-author .comment-meta .comment-reply-link,
#content-wrap #cancel-comment-reply-link {
  color: var(--ppb-warm) !important;
}
#content-wrap #respond input[type="text"],
#content-wrap #respond input[type="email"],
#content-wrap #respond input[type="url"],
#content-wrap #respond textarea {
  border-radius: var(--ppb-radius-xs) !important;
  border: 1px solid var(--ppb-border) !important;
}
#content-wrap #respond input:focus,
#content-wrap #respond textarea:focus {
  border-color: var(--ppb-accent) !important;
  box-shadow: 0 0 0 3px oklch(0.78 0.16 70 / 0.18) !important;
}

/* ================================================================
   7. Sidebar widgets  (incl. the search box — "search in article")
   ================================================================ */
#right-sidebar .sidebar-box {
  background: var(--ppb-card);
  border: 1px solid var(--ppb-border);
  border-radius: var(--ppb-radius);
  box-shadow: var(--ppb-shadow);
  padding: 22px 24px;
  margin-bottom: 24px;
}
#right-sidebar .widget-title {
  font-family: var(--ppb-font);
  font-size: 12px !important;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ppb-text) !important;
  border: none !important;
  margin-bottom: 16px;
  padding-bottom: 12px;
  position: relative;
}
#right-sidebar .widget-title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 32px;
  height: 2px;
  background: var(--ppb-accent);
  border-radius: 2px;
}

/* Search field
   OceanWP renders the block-search "button-outside" layout:
     .wp-block-search > label
                      > .wp-block-search__inside-wrapper > input
                      > button
   so the input must stretch its wrapper, and the wrapper + block must be
   full width — otherwise the field collapses to its intrinsic (tiny) size. */
#right-sidebar .wp-block-search,
#right-sidebar .searchform,
#right-sidebar form[role="search"] {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%;
  max-width: 100%;
}
#right-sidebar .wp-block-search__inside-wrapper {
  display: flex;
  flex: 1 1 100%;
  width: 100%;
  min-width: 0;
  border: none !important; /* wrappers shouldn't add a red box */
}
#right-sidebar .wp-block-search__input,
#right-sidebar .searchform input[type="search"],
#right-sidebar .searchform input[type="text"],
#right-sidebar form[role="search"] input[type="search"] {
  border: 1px solid var(--ppb-border) !important;
  border-radius: 9999px !important;
  padding: 10px 16px !important;
  background: #f7f8fb !important;
  color: var(--ppb-text) !important;
  font-family: var(--ppb-font);
  flex: 1 1 auto;
  width: 100% !important;
  min-width: 0;
}
#right-sidebar .wp-block-search__input:focus,
#right-sidebar .searchform input[type="search"]:focus {
  border-color: var(--ppb-accent) !important;
  box-shadow: 0 0 0 3px oklch(0.78 0.16 70 / 0.18) !important;
  outline: none;
}

/* Recent entries / generic widget links */
#right-sidebar .sidebar-box a {
  color: var(--ppb-text) !important;
  transition: color 150ms;
}
#right-sidebar .sidebar-box a:hover {
  color: var(--ppb-warm) !important;
}
#right-sidebar .widget_recent_entries li,
#right-sidebar .sidebar-box li {
  border-color: var(--ppb-border) !important;
}

/* ================================================================
   8. Global red-kill safety net (anything we missed in blog context)
   ================================================================ */
#content-wrap a:hover,
#right-sidebar a:hover {
  color: var(--ppb-warm);
}
#content-wrap .owp-icon use {
  /* leave non-overridden icons inheriting; accent handled per-section */
}

/* Breadcrumbs (if shown above content) */
#content-wrap .site-breadcrumbs,
#content-wrap .site-breadcrumbs a {
  color: var(--ppb-muted-2) !important;
  font-family: var(--ppb-font);
}
#content-wrap .site-breadcrumbs a:hover {
  color: var(--ppb-warm) !important;
}

/* Archive / page header title in orange brand colour */
#content-wrap .page-header .page-header-title,
.archive .page-header .page-header-title {
  font-family: var(--ppb-font);
  color: var(--ppb-text) !important;
}

/* ================================================================
   9. Responsive
   ================================================================ */
@media (max-width: 768px) {
  #blog-entries .blog-entry {
    padding: 20px 18px;
    margin-bottom: 20px;
  }
  body.single-post #primary > article,
  body.single-post #primary > .entry {
    padding: 24px 20px;
  }
  #content-wrap #comments,
  #content-wrap .comments-area {
    padding: 22px 18px;
  }
  #right-sidebar .sidebar-box {
    padding: 18px 18px;
  }
}
