@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Montserrat:wght@700;800;900&display=swap');

/* ============================================================
   BODY FONT — Inter is the canonical body font for the theme.
   Every body-copy declaration references --font-body, so a
   future font change is a one-line edit to this rule.
   ============================================================ */
:root { --font-body: "Inter", sans-serif; }


/*
Theme Name: Hirzel Blog Theme
Theme URI: https://micondolaw.com
Author: Dan Gilroy Design
Author URI: https://dangilroy.com
Description: Shared blog theme for Hirzel Law blog properties (micondolaw.com, ilhoalaw.com). Matches the visual language of the main hirzel-law-theme.
Version: 2.0.0
License: Private
Text Domain: hirzel-blog-theme
*/

/* ============================================================
   HIRZEL LAW PLC - COLOR PALETTE
   ============================================================ */

/* Primary Blue: #2B3990 | rgb(43, 57, 144) */
/* Dark Orange: #F36F21 | rgb(243, 111, 33) */
/* Light Orange: #FC914D | rgb(252, 145, 77) */
/* White: #FFFFFF | rgb(255, 255, 255) */
/* Dark Grey: #333333 | rgb(51, 51, 51) */

/* ==========================================================================
   Base Styles
   ========================================================================== */

* { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
}

body { font-family: var(--font-body); font-weight: 400; font-style: normal; font-size: clamp(17px, 0.95rem + 0.3vw, 20px); line-height: 1.65; color: #333; background-color: #fff; }

img { max-width: 100%; height: auto; display: block; }

a { color: #2B3990; text-decoration: none; transition: color 0.2s ease; }
a:hover { color: #F36F21; }

*:focus { outline: none; }
*:focus-visible { outline: 3px solid #F36F21; outline-offset: 3px; }

ul, ol { list-style: none; }

/* ==========================================================================
   Typography
   ========================================================================== */

h1, h2, h3, h4, h5, h6 { font-family: "Montserrat", sans-serif; font-weight: 700; font-style: normal; line-height: 1.2; margin: 0 0 1rem; color: #2B3990; letter-spacing: -0.02em; }

h1 { font-size: clamp(2rem, 1.5rem + 2vw, 3rem); }
h2 { font-size: clamp(1.75rem, 1.35rem + 1.5vw, 2.5rem); }
h3 { font-size: clamp(0.95rem, 1.2rem + 1vw, 1.5rem); }
h4 { font-size: clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem); }
h5 { font-size: clamp(1.125rem, 1.05rem + 0.35vw, 1.25rem); }
h6 { font-size: clamp(1rem, 0.95rem + 0.25vw, 1.125rem); }

p { margin-bottom: 1.25rem; }
p:last-child { margin-bottom: 0; }
hr { margin-bottom: 20px; }

/* ==========================================================================
   Container — #7: reduced to 1280px
   ========================================================================== */

.container { position: relative; width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 40px; box-sizing: border-box; }

@media (max-width: 767px) {
    .container { padding: 0 20px; }
}

/* MAIN HEADER */
.blog-site-header { background: #ffffff; position: sticky; top: 0; z-index: 500; box-shadow: 0 2px 20px rgba(43, 57, 144, 0.10); }

/* TOP UTILITY BAR — left: phone | right: proposal + mobile toggle */
.blog-header-topbar { border-bottom: 1px solid #e4e6f0; padding: 10px 0; }
.blog-header-topbar .container { display: flex; align-items: center; justify-content: space-between; gap: 0; }
.blog-header-topbar-left { display: flex; align-items: center; gap: 0; }
.blog-header-topbar-right { display: flex; align-items: center; gap: 10px; }

/* Phone — bigger per Kevin feedback */
.blog-header-phone { display: flex; align-items: center; gap: 8px; white-space: nowrap; flex-shrink: 0; }
.blog-header-phone svg { color: #F36F21; flex-shrink: 0; }
.blog-header-phone-number { font-family: "Montserrat", sans-serif; font-weight: 700; font-size: 1.05rem; color: #F36F21; letter-spacing: 0.01em; transition: color 0.2s; }
.blog-header-phone-number:hover { color: #FC914D; }

/* Request a Proposal — bigger per Kevin feedback */
.blog-header-proposal { display: inline-block; background: #F36F21; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.8rem; font-weight: 700; letter-spacing: 0.07em; text-transform: uppercase; padding: 11px 22px; border-radius: 3px; white-space: nowrap; transition: background 0.2s ease, transform 0.15s ease; box-shadow: 0 2px 8px rgba(243, 111, 33, 0.28); }
.blog-header-proposal:hover { background: #FC914D; color: #ffffff; transform: translateY(-1px); }

/* Mobile hamburger */
.blog-mobile-toggle { display: none; background: none; border: 2px solid #F36F21; border-radius: 3px; cursor: pointer; padding: 7px; color: #2B3990; transition: background 0.2s, color 0.2s; }
.blog-mobile-toggle:hover { background: #F36F21; color: #ffffff; }
.blog-mobile-toggle svg { display: block; }

/* MASTHEAD — logo + divider + blog title */
.blog-header-identity { padding: 14px 0 12px; }
.blog-header-identity .container { display: flex; align-items: center; gap: 28px; }
.blog-logo { flex-shrink: 0; display: flex; align-items: center; }
.blog-logo a { display: block; line-height: 0; }
.blog-logo img { height: 70px; width: auto; }
.blog-header-divider { width: 1px; background: #d0d4e8; flex-shrink: 0; align-self: stretch; }
.blog-header-text-block { flex: 1; display: flex; flex-direction: column; gap: 5px; min-width: 0; }

/* Blog title — fills container width on desktop */
.blog-site-name { font-family: "Montserrat", sans-serif; font-size: clamp(1.0rem, 3.1vw, 2.2rem); font-weight: 700; color: #2B3990; line-height: 1.2; letter-spacing: -0.01em; display: block; }

/* Tagline */
.blog-header-tagline { font-family: var(--font-body); font-size: 0.78rem; color: #333; font-style: italic; }

/* CATEGORY NAV BAR — white editorial style */
.blog-category-nav { background: #ffffff; border-top: 1px solid #e4e6f0; border-bottom: 2px solid #e4e6f0; position: relative; z-index: 400; }
.blog-category-nav .container { display: flex; align-items: stretch; }
.blog-nav-menu { display: flex; align-items: stretch; list-style: none; margin: 0; padding: 0; justify-content: flex-start; }
.blog-nav-menu > li { position: relative; }
.blog-nav-menu > li > a { display: flex; align-items: center; justify-content: center; gap: 5px; font-family: "Montserrat", sans-serif; font-size: clamp(0.58rem, 0.48rem + 0.42vw, 0.72rem); font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: #2B3990; padding: 12px 20px 9px; white-space: nowrap; border-bottom: 3px solid transparent; background: transparent; transition: color 0.18s ease, border-bottom-color 0.18s ease; }
.blog-nav-menu > li:first-child > a { padding-left: 0; }
.blog-nav-menu > li > a:hover, .blog-nav-menu > li.current-menu-item > a, .blog-nav-menu > li.current-menu-parent > a, .blog-nav-menu > li.current-menu-ancestor > a { color: #F36F21; border-bottom-color: #F36F21; background: transparent; }
.blog-nav-menu > li.menu-item-has-children > a::after { content: ''; display: inline-block; width: 0; height: 0; border-left: 3.5px solid transparent; border-right: 3.5px solid transparent; border-top: 4.5px solid rgba(43,57,144,0.45); margin-left: 5px; transition: border-top-color 0.18s, transform 0.2s; }
.blog-nav-menu > li.menu-item-has-children:hover > a::after { border-top-color: #F36F21; transform: rotate(180deg); }
.blog-nav-menu .sub-menu { position: absolute; top: 100%; left: 0; background: #1e2a6e; min-width: 270px; z-index: 600; list-style: none; margin: 0; padding: 0; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease; box-shadow: 0 10px 30px rgba(0,0,0,0.22); border-top: 2px solid #F36F21; }
.blog-nav-menu > li:last-child > .sub-menu { left: auto; right: 0; }
.blog-nav-menu > li:hover > .sub-menu, .blog-nav-menu > li:focus-within > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.blog-nav-menu .sub-menu li a { display: block; font-family: "Montserrat", sans-serif; font-size: 0.7rem; font-weight: 600; letter-spacing: 0.02em; color: rgba(255,255,255,0.88); padding: 10px 18px 10px 16px; border-bottom: 1px solid rgba(255,255,255,0.06); border-left: 3px solid transparent; transition: background 0.14s, color 0.14s, border-left-color 0.14s, padding-left 0.14s; }
.blog-nav-menu .sub-menu li:last-child a { border-bottom: none; }
.blog-nav-menu .sub-menu li a:hover { background: rgba(255,255,255,0.06); color: #ffffff; border-left-color: #F36F21; padding-left: 20px; }

/* SEARCH-AND-FILTER BAR — keyword + topic dropdown, sits below the nav on every page */
.blog-search-bar { background: #f5f6fa; border-bottom: 1px solid #e4e6f0; padding: 18px 0; }
.blog-search-bar__inner { display: flex; align-items: center; gap: 18px; max-width: 980px; margin: 0 auto; }
.blog-search-bar__label { font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: #2B3990; white-space: nowrap; flex-shrink: 0; }
.blog-search-bar__form { display: flex; align-items: stretch; flex: 1; background: #ffffff; border: 1px solid #d8dce8; border-radius: 4px; overflow: hidden; box-shadow: 0 1px 3px rgba(43, 57, 144, 0.04); transition: border-color 0.2s, box-shadow 0.2s; }
.blog-search-bar__form:focus-within { border-color: #F36F21; box-shadow: 0 2px 12px rgba(243, 111, 33, 0.15); }
.blog-search-bar__input-wrap { flex: 1; display: flex; align-items: center; padding: 0 14px 0 16px; min-width: 0; }
.blog-search-bar__input-wrap svg { color: #2B3990; flex-shrink: 0; margin-right: 10px; }
.blog-search-bar__input { flex: 1; min-width: 0; border: none; outline: none; background: transparent; font-family: var(--font-body); font-size: 0.95rem; color: #333; padding: 12px 0; }
.blog-search-bar__input::placeholder { color: #999; }
.blog-search-bar__divider { width: 1px; background: #e4e6f0; align-self: stretch; flex-shrink: 0; }
.blog-search-bar__select-wrap { position: relative; flex-shrink: 0; display: flex; align-items: center; }
.blog-search-bar__select { appearance: none; -webkit-appearance: none; -moz-appearance: none; background: transparent; border: none; outline: none; font-family: "Montserrat", sans-serif; font-size: 0.75rem; font-weight: 600; color: #2B3990; padding: 0 36px 0 18px; cursor: pointer; max-width: 260px; line-height: 1.4; }
.blog-search-bar__select:hover { color: #F36F21; }
.blog-search-bar__select-wrap::after { content: ''; position: absolute; right: 16px; top: 50%; width: 0; height: 0; border-left: 4px solid transparent; border-right: 4px solid transparent; border-top: 5px solid #2B3990; transform: translateY(-50%); pointer-events: none; transition: transform 0.18s, border-top-color 0.18s; }
.blog-search-bar__select-wrap:hover::after { border-top-color: #F36F21; }
.blog-search-bar__submit { background: #2B3990; border: none; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 0 28px; cursor: pointer; white-space: nowrap; transition: background 0.2s; flex-shrink: 0; }
.blog-search-bar__submit:hover { background: #1e2a6e; }
.blog-search-bar__hint { font-family: var(--font-body); font-size: 0.78rem; color: #6a6f85; white-space: nowrap; flex-shrink: 0; }
.blog-search-bar__hint a { color: #2B3990; font-weight: 600; text-decoration: none; }
.blog-search-bar__hint a:hover { color: #F36F21; text-decoration: underline; }

/* MOBILE NAV — search/phone/proposal (older drawer UI elements; may be unused if template was updated to use .blog-mobile-contact-btn) */
.blog-mobile-search { margin-top: 24px; display: flex; }
.blog-mobile-search input[type="search"] { flex: 1; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25); border-right: none; color: #ffffff; font-family: var(--font-body); font-size: 0.875rem; padding: 12px 14px; border-radius: 3px 0 0 3px; outline: none; }
.blog-mobile-search input[type="search"]::placeholder { color: rgba(255,255,255,0.4); }
.blog-mobile-search button { background: #F36F21; border: 1px solid #F36F21; color: #ffffff; padding: 12px 14px; border-radius: 0 3px 3px 0; cursor: pointer; display: flex; align-items: center; }
.blog-mobile-proposal { display: block; background: #F36F21; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; text-align: center; padding: 14px 20px; text-decoration: none; border-radius: 3px; margin-top: 20px; }
.blog-mobile-proposal:hover { background: #FC914D; color: #ffffff; }
.blog-mobile-phone { display: flex; align-items: center; justify-content: center; gap: 8px; color: rgba(255,255,255,0.85); font-family: "Montserrat", sans-serif; font-size: 0.875rem; font-weight: 700; margin-top: 14px; }
.blog-mobile-phone svg { color: rgba(255,255,255,0.7); }
.blog-mobile-phone a { color: #FC914D; text-decoration: none; }
.blog-mobile-phone a:hover { color: #ffffff; }


/* ==========================================================================
   HOMEPAGE — FEATURED ARTICLES (6-post carousel)
   ========================================================================== */

.hp-featured { background: #ffffff; padding: 70px 0 20px; }

.hp-featured__stage { display: flex; align-items: center; gap: 16px; }
.hp-featured__viewport { flex: 1; min-width: 0; overflow: hidden; }
.hp-featured__track { display: flex; gap: 32px; transition: transform 0.45s cubic-bezier(0.4, 0, 0.2, 1); will-change: transform; }

.hp-featured__card { flex: 0 0 calc((100% - 64px) / 3); display: flex; flex-direction: column; background: #ffffff; border: 1px solid #e8e8e8; border-radius: 4px; overflow: hidden; transition: box-shadow 0.2s ease, transform 0.2s ease; }
.hp-featured__card:hover { box-shadow: 0 8px 32px rgba(43, 57, 144, 0.12); transform: translateY(-3px); }

.hp-featured__thumb-link { display: block; line-height: 0; overflow: hidden; }
.hp-featured__thumb { width: 100%; height: 200px; object-fit: cover; display: block; transition: transform 0.35s ease; }
.hp-featured__card:hover .hp-featured__thumb { transform: scale(1.03); }
.hp-featured__thumb-placeholder { width: 100%; height: 200px; background: #dde2f0; }

.hp-featured__body { padding: 22px 24px 24px; display: flex; flex-direction: column; flex: 1; }
.hp-featured__meta { font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 10px; }
.hp-featured__meta-sep { color: #ccc; margin: 0 8px; }
.hp-featured__meta-author { color: #2B3990; }
.hp-featured__title { font-family: "Montserrat", sans-serif; font-size: 1.05rem; font-weight: 700; color: #2B3990; line-height: 1.3; margin: 0 0 12px; }
.hp-featured__title a { color: inherit; text-decoration: none; }
.hp-featured__title a:hover { color: #F36F21; }
.hp-featured__excerpt { font-family: var(--font-body); font-size: 0.875rem; color: #555555; line-height: 1.7; flex: 1; margin-bottom: 18px; }
.hp-featured__readmore { display: inline-block; background: #2B3990; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; padding: 9px 18px; border-radius: 3px; text-decoration: none; align-self: flex-start; transition: background 0.2s; }
.hp-featured__readmore:hover { background: #1e2a6e; color: #ffffff; }

/* Carousel controls — prev/next arrows + pagination dots */
.hp-featured__controls { display: flex; align-items: center; justify-content: center; gap: 24px; margin-top: 36px; }
.hp-featured__arrow { width: 44px; height: 44px; border-radius: 50%; background: #ffffff; border: 2px solid #2B3990; color: #2B3990; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: background 0.2s, color 0.2s, border-color 0.2s, transform 0.15s; }
.hp-featured__arrow:hover:not(:disabled) { background: #2B3990; color: #ffffff; }
.hp-featured__arrow:disabled { opacity: 0.3; cursor: not-allowed; }
.hp-featured__arrow svg { display: block; }

/* Side-flanking arrow variant — flex children of .hp-featured__stage, sit outside the card row (no overlap), vertically centered on the full card height via align-items */
.hp-featured__arrow--side { flex: 0 0 auto; box-shadow: 0 4px 14px rgba(43, 57, 144, 0.18); }

.hp-featured__dots { display: flex; gap: 10px; }
.hp-featured__dot { width: 10px; height: 10px; border-radius: 50%; background: #d0d4e8; border: none; cursor: pointer; padding: 0; transition: background 0.2s, transform 0.2s; }
.hp-featured__dot.is-active { background: #F36F21; transform: scale(1.2); }
.hp-featured__dot:hover { background: #2B3990; }

/* ==========================================================================
   HOMEPAGE — WHO WE SERVE (compact navy/orange split banner)
   ========================================================================== */

.hp-scope { background: #ffffff; padding: 36px 0 48px; }

.hp-scope__banner { display: flex; align-items: stretch; border-radius: 4px; overflow: hidden; box-shadow: 0 6px 24px rgba(43, 57, 144, 0.12); }

.hp-scope__text { flex: 1; margin: 0; padding: 22px 32px; background: #2B3990; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 1rem; font-weight: 500; line-height: 1.5; }
.hp-scope__text strong { font-weight: 700; color: #ffffff; }
.hp-scope__text p  { margin: 0; }

.hp-scope__cta { flex: 0 0 auto; display: flex; align-items: center; gap: 10px; background: #F36F21; color: #ffffff; padding: 22px 32px; font-family: "Montserrat", sans-serif; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; text-decoration: none; white-space: nowrap; transition: background 0.2s; }
.hp-scope__cta:hover { background: #FC914D; color: #ffffff; }
.hp-scope__cta-arrow { flex: 0 0 auto; transition: transform 0.2s; }
.hp-scope__cta:hover .hp-scope__cta-arrow { transform: translateX(3px); }

/* ==========================================================================
   HOMEPAGE — BOOK PROMO
   ========================================================================== */

.hp-book { background: #2B3990; padding: 60px 0; }

.hp-book__inner { display: flex; align-items: center; gap: 56px; }

.hp-book__cover-link { display: block; flex-shrink: 0; line-height: 0; transition: transform 0.25s ease; }
.hp-book__cover-link:hover { transform: translateY(-4px) rotate(-1deg); }
.hp-book__cover { width: 200px; height: auto; border-radius: 3px; box-shadow: 0 16px 48px rgba(0,0,0,0.45); display: block; }

.hp-book__content { flex: 1; }
.hp-book__eyebrow { font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.6); margin-bottom: 10px; }
.hp-book__title { font-family: "Montserrat", sans-serif; font-size: clamp(1.5rem, 1rem + 2vw, 2.4rem); font-weight: 900; color: #ffffff; line-height: 1.1; margin: 0 0 6px; }
.hp-book__subtitle { font-family: "Montserrat", sans-serif; font-size: 1rem; font-weight: 600; color: rgba(255,255,255,0.75); margin-bottom: 18px; }
.hp-book__description { font-family: var(--font-body); font-size: 0.95rem; color: rgba(255,255,255,0.82); line-height: 1.75; max-width: 100%; margin-bottom: 28px; }
.hp-book__cta { display: inline-block; background: #F36F21; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; padding: 14px 28px; border-radius: 3px; text-decoration: none; transition: background 0.2s, transform 0.15s; box-shadow: 0 4px 16px rgba(243,111,33,0.4); }
.hp-book__cta:hover { background: #FC914D; color: #ffffff; transform: translateY(-2px); }

/* ==========================================================================
   HOMEPAGE — TOPIC CARDS
   ========================================================================== */

/* scroll-margin-top accounts for the sticky header so smooth-scroll anchor jumps (e.g. "browse all topics") don't hide the heading. --header-h is set by main.js to the measured header height; 280px is the fallback if JS hasn't run yet. */
.hp-topics { background: #f5f6fa; padding: 56px 0 64px; scroll-margin-top: calc(var(--header-h, 280px) + 20px); }

.hp-topics__header { margin-bottom: 32px; }
.hp-topics__heading { font-family: "Montserrat", sans-serif; font-size: 1.6rem; font-weight: 800; color: #2B3990; }

.hp-topics__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

/* Card */
.hp-topic-card { display: flex; flex-direction: column; background: #ffffff; border: 1px solid #e8e8e8; border-radius: 4px; overflow: hidden; transition: box-shadow 0.2s ease, transform 0.2s ease; }
.hp-topic-card:hover { box-shadow: 0 8px 32px rgba(43, 57, 144, 0.11); transform: translateY(-3px); }

/* Hidden cards — must come AFTER .hp-topic-card to win the cascade */
.hp-topic-card--hidden { display: none !important; }
.hp-topics--expanded .hp-topic-card--hidden { display: flex !important; }

.hp-topic-card__img-link { display: block; line-height: 0; overflow: hidden; }
.hp-topic-card__img { width: 100%; height: 180px; object-fit: cover; display: block; transition: transform 0.35s ease; }
.hp-topic-card:hover .hp-topic-card__img { transform: scale(1.04); }
.hp-topic-card__img--placeholder { width: 100%; height: 180px; background: linear-gradient(135deg, #dde2f0 0%, #c8d0e8 100%); }

.hp-topic-card__body { padding: 20px 22px 22px; display: flex; flex-direction: column; flex: 1; }

.hp-topic-card__title { font-family: "Montserrat", sans-serif; font-size: 0.92rem; font-weight: 700; color: #2B3990; line-height: 1.25; margin: 0 0 12px; }
.hp-topic-card__title a { color: inherit; text-decoration: none; }
.hp-topic-card__title a:hover { color: #F36F21; }

/* Post list — orange left-border accent, clear separation between items */
.hp-topic-card__posts { list-style: none; margin: 0 0 16px; padding: 0; flex: 1; }
.hp-topic-card__posts li { padding: 7px 0 7px 12px; border-top: 1px solid #f0f2f8; border-left: 2px solid transparent; transition: border-left-color 0.15s ease; position: relative; }
.hp-topic-card__posts li:first-child { border-top: none; }
.hp-topic-card__posts li:hover { border-left-color: #F36F21; }
.hp-topic-card__posts li a { font-family: var(--font-body); font-size: 0.78rem; color: #444444; line-height: 1.4; text-decoration: none; display: block; }
.hp-topic-card__posts li a:hover { color: #F36F21; }

.hp-topic-card__more { display: inline-block; font-family: "Montserrat", sans-serif; font-size: 0.7rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.07em; text-decoration: none; margin-top: auto; transition: color 0.2s; }
.hp-topic-card__more:hover { color: #FC914D; }

/* Toggle button */
.hp-topics__toggle-wrap { text-align: center; margin-top: 36px; }
.hp-topics__toggle { display: inline-flex; align-items: center; gap: 8px; background: #ffffff; color: #2B3990; border: 2px solid #2B3990; font-family: "Montserrat", sans-serif; font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; padding: 12px 28px; border-radius: 3px; cursor: pointer; transition: background 0.2s, color 0.2s; }
.hp-topics__toggle:hover { background: #2B3990; color: #ffffff; }
.hp-topics__toggle-icon { transition: transform 0.25s ease; flex-shrink: 0; }
.hp-topics--expanded .hp-topics__toggle-icon { transform: rotate(180deg); }


/* ==========================================================================
   SINGLE POST
   ========================================================================== */

.blog-single-article { width: 100%; }

/* Breadcrumb */
.blog-single-breadcrumb { font-family: var(--font-body); font-size: 0.78rem; color: #999999; margin-bottom: 20px; display: flex; flex-wrap: wrap; align-items: center; gap: 6px; }
.blog-single-breadcrumb a { color: #2B3990; text-decoration: none; }
.blog-single-breadcrumb a:hover { color: #F36F21; }
.blog-single-breadcrumb .current { color: #555; }

/* Meta */
.blog-single-meta { display: flex; align-items: center; gap: 8px; font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 14px; }
.blog-single-meta__sep { color: #F36F21; }

/* Title */
.blog-single-title { font-family: "Montserrat", sans-serif; font-size: clamp(1.4rem, 1rem + 2vw, 2.2rem); font-weight: 800; color: #2B3990; line-height: 1.2; margin: 0 0 16px; }

/* Byline */
.blog-single-byline { font-family: var(--font-body); font-size: 0.875rem; color: #666; margin-bottom: 28px; }
.blog-single-byline a { color: #2B3990; text-decoration: none; font-weight: 600; }
.blog-single-byline a:hover { color: #F36F21; }

/* Featured image */
.blog-single-thumb { margin-bottom: 36px; border-radius: 4px; overflow: hidden; line-height: 0; }
.blog-single-thumb__img { width: 100%; height: 480px; object-fit: cover; display: block; }

/* Author bio box */
.blog-author-box { display: flex; gap: 24px; align-items: flex-start; background: #f8f9fe; border: 1px solid #e0e4f0; border-radius: 4px; padding: 28px; margin-top: 40px; }
.blog-author-box__photo { flex-shrink: 0; }
.blog-author-box__photo img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; display: block; border: 3px solid #ffffff; box-shadow: 0 2px 12px rgba(43,57,144,0.15); }
.blog-author-box__content { flex: 1; min-width: 0; }
.blog-author-box__header { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 12px; flex-wrap: wrap; }
.blog-author-box__label { display: block; font-family: "Montserrat", sans-serif; font-size: 0.65rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: #F36F21; margin-bottom: 4px; }
.blog-author-box__name { display: block; font-family: "Montserrat", sans-serif; font-size: 1rem; font-weight: 700; color: #2B3990; text-decoration: none; line-height: 1.2; }
a.blog-author-box__name:hover { color: #F36F21; }
.blog-author-box__title { display: block; font-family: var(--font-body); font-size: 0.8rem; color: #888; margin-top: 3px; }
.blog-author-box__profile-link { display: inline-block; font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: #F36F21; text-decoration: none; white-space: nowrap; flex-shrink: 0; padding-top: 2px; }
.blog-author-box__profile-link:hover { color: #FC914D; }
.blog-author-box__bio { font-family: var(--font-body); font-size: 0.875rem; color: #555; line-height: 1.75; }
.blog-author-box__bio p { margin: 0 0 0.75em; }
.blog-author-box__bio p:last-child { margin-bottom: 0; }
.blog-author-box__bio a { color: #2B3990; }
.blog-author-box__bio a:hover { color: #F36F21; }

/* Category buttons */
.blog-single-cats { margin-top: 48px; padding-top: 40px; border-top: 2px solid #e8e8e8; }
.blog-single-cats__heading { font-family: "Montserrat", sans-serif; font-size: 1rem; font-weight: 700; color: #2B3990; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 18px; }
.blog-single-cats__list { display: flex; flex-wrap: wrap; gap: 10px; }
.blog-single-cat-btn { display: inline-flex; align-items: center; gap: 5px; background: #f0f2f9; color: #2B3990; font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 8px 14px; border-radius: 3px; text-decoration: none; border: 1px solid #d8ddf0; transition: background 0.18s, color 0.18s, border-color 0.18s; white-space: nowrap; }
.blog-single-cat-btn:hover { background: #2B3990; color: #ffffff; border-color: #2B3990; }
.blog-single-cat-btn__count { font-weight: 400; opacity: 0.75; font-size: 0.68rem; }

/* Related posts grid — 3×2 */
.blog-related { margin-top: 48px; padding-top: 40px; border-top: 2px solid #e8e8e8; }
.blog-related__heading { font-family: "Montserrat", sans-serif; font-size: 1rem; font-weight: 700; color: #2B3990; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 24px; }
.blog-related__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.blog-related-card { display: flex; flex-direction: column; background: #ffffff; border: 1px solid #e8e8e8; border-radius: 4px; overflow: hidden; transition: box-shadow 0.2s, transform 0.2s; }
.blog-related-card:hover { box-shadow: 0 6px 24px rgba(43,57,144,0.10); transform: translateY(-2px); }
.blog-related-card__thumb-link { display: block; line-height: 0; overflow: hidden; }
.blog-related-card__thumb { width: 100%; height: 160px; object-fit: cover; display: block; transition: transform 0.3s ease; }
.blog-related-card:hover .blog-related-card__thumb { transform: scale(1.04); }
.blog-related-card__thumb--placeholder { width: 100%; height: 160px; background: linear-gradient(135deg, #dde2f0 0%, #c8d0e8 100%); }
.blog-related-card__body { padding: 16px 18px 18px; flex: 1; display: flex; flex-direction: column; gap: 8px; }
.blog-related-card__meta { font-family: "Montserrat", sans-serif; font-size: 0.65rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.07em; }
.blog-related-card__title { font-family: "Montserrat", sans-serif; font-size: 0.85rem; font-weight: 700; color: #2B3990; line-height: 1.3; margin: 0; }
.blog-related-card__title a { color: inherit; text-decoration: none; }
.blog-related-card__title a:hover { color: #F36F21; }

/* Post navigation */
.blog-post-nav { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-top: 40px; padding-top: 32px; border-top: 2px solid #e8e8e8; }
.blog-post-nav__item { display: flex; flex-direction: column; gap: 6px; }
.blog-post-nav__item--next { text-align: right; }
.blog-post-nav__label { font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #888; }
.blog-post-nav__title { font-family: "Montserrat", sans-serif; font-size: 0.88rem; font-weight: 700; color: #2B3990; text-decoration: none; line-height: 1.3; }
.blog-post-nav__title:hover { color: #F36F21; }


/* ==========================================================================
   MAIN CONTENT LAYOUT
   ========================================================================== */

/* blog-body-wrap: used by category archives, search, page.php (has sidebar) */
.blog-body-wrap { padding: clamp(36px, 5vw, 64px) 0; }

.blog-body-wrap .container { display: grid; grid-template-columns: 1fr 300px; gap: clamp(36px, 5vw, 60px); align-items: start; }

/* blog-single-wrap: used by single.php (no sidebar, full width) */
.blog-single-wrap { background: #ffffff; padding: 0 0 64px; }
.blog-single-content-col { width: 100%; max-width: 1200px !important; margin: 0 auto; padding: 40px 40px 0; }

/* ==========================================================================
   BREADCRUMB
   ========================================================================== */

.blog-breadcrumb { background: #f5f5f5; border-bottom: 1px solid #e8e8e8; padding: 10px 0; font-family: var(--font-body); font-size: 0.8rem; color: #888888; }
.blog-breadcrumb a { color: #2B3990; }
.blog-breadcrumb a:hover { color: #F36F21; }
.blog-breadcrumb span.sep { margin: 0 6px; color: #cccccc; }
.blog-breadcrumb span.current { color: #555555; font-weight: 600; }

/* ==========================================================================
   ARCHIVE / INDEX — POST LIST
   ========================================================================== */

.blog-posts-list { display: flex; flex-direction: column; gap: 48px; }

.blog-post-card { border-bottom: 1px solid #e8e8e8; padding-bottom: 48px; }
.blog-post-card:last-child { border-bottom: none; padding-bottom: 0; }

.blog-post-card__thumb { margin-bottom: 20px; overflow: hidden; border-radius: 4px; aspect-ratio: 16 / 7; }
.blog-post-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s ease; }
.blog-post-card:hover .blog-post-card__thumb img { transform: scale(1.03); }

/* #5: meta shows date only (no tags) */
.blog-post-card__meta { font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: 10px; }

.blog-post-card h2 { font-size: clamp(1.25rem, 1.1rem + 0.8vw, 1.75rem); margin-bottom: 12px; line-height: 1.25; }
.blog-post-card h2 a { color: #2B3990; }
.blog-post-card h2 a:hover { color: #F36F21; }

.blog-post-card__excerpt { font-size: 0.95rem; color: #555555; line-height: 1.75; margin-bottom: 20px; }

.blog-read-more { display: inline-block; font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #ffffff; background: #2B3990; padding: 10px 22px; border-radius: 3px; transition: background 0.2s ease; }
.blog-read-more:hover { background: #F36F21; color: #ffffff; }

/* ==========================================================================
   PAGINATION — #12: fixed to always render as a horizontal row
   ========================================================================== */

.blog-pagination { margin-top: 48px; }

/* WordPress outputs paginate_links as a <ul> when type=list */
.blog-pagination ul { display: flex; flex-direction: row; align-items: center; justify-content: center; flex-wrap: wrap; gap: 6px; list-style: none; margin: 0; padding: 0; }
.blog-pagination ul li { display: block; margin: 0; padding: 0; }
.blog-pagination ul li .page-numbers { display: inline-block; font-family: "Montserrat", sans-serif; font-size: 0.82rem; font-weight: 700; padding: 9px 15px; border: 2px solid #2B3990; border-radius: 3px; color: #2B3990; line-height: 1; transition: all 0.2s ease; }
.blog-pagination ul li .page-numbers:hover { background: #2B3990; color: #ffffff; }
.blog-pagination ul li .page-numbers.current { background: #F36F21; border-color: #F36F21; color: #ffffff; }
.blog-pagination ul li .page-numbers.dots { border-color: transparent; background: transparent; padding: 9px 4px; }

/* Fallback: if WordPress outputs plain links instead of list */
.blog-pagination .page-numbers { display: inline-block; font-family: "Montserrat", sans-serif; font-size: 0.82rem; font-weight: 700; padding: 9px 15px; border: 2px solid #2B3990; border-radius: 3px; color: #2B3990; line-height: 1; margin: 3px; transition: all 0.2s ease; }
.blog-pagination .page-numbers:hover { background: #2B3990; color: #ffffff; }
.blog-pagination .page-numbers.current { background: #F36F21; border-color: #F36F21; color: #ffffff; }
.blog-pagination .page-numbers.dots { border-color: transparent; background: transparent; }

/* ==========================================================================
   SINGLE POST — HEADER + FEATURED IMAGE
   ========================================================================== */

.blog-single-header { margin-bottom: 28px; }
.blog-single-header .blog-post-card__meta { margin-bottom: 12px; }
.blog-single-header h1 { margin-bottom: 16px; font-size: clamp(1.75rem, 1.4rem + 1.5vw, 2.75rem); }
.blog-single-header .blog-post-byline { font-family: var(--font-body); font-size: 0.85rem; color: #888888; padding-top: 14px; border-top: 1px solid #e8e8e8; }

.blog-post-card__meta .meta-sep { color: #cccccc; font-weight: 400; }

.blog-single-header .blog-post-byline a { color: #2B3990; font-weight: 600; }

.blog-featured-image { margin-bottom: 32px; border-radius: 4px; overflow: hidden; }
.blog-featured-image img { width: 100%; height: auto; max-height: 480px; object-fit: cover; }

/* ==========================================================================
   POST CONTENT TYPOGRAPHY
   ========================================================================== */

.blog-post-content { font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.05rem); color: #333333; line-height: 1.5; }
.blog-post-content h2 { font-size: clamp(1.3rem, 1.1rem + 1vw, 1.75rem); margin: 2.25rem 0 0.85rem; padding-top: 0; }
.blog-post-content h3 { font-size: clamp(1.1rem, 1rem + 0.5vw, 1.35rem); margin: 1.75rem 0 0.7rem; color: #2B3990; }
.blog-post-content h4 { font-size: clamp(1rem, 0.95rem + 0.25vw, 1.125rem); margin: 1.5rem 0 0.6rem; color: #333333; }
.blog-post-content p { margin-bottom: 1.35rem; }
.blog-post-content ul, .blog-post-content ol { margin: 0 0 1.35rem 1.75rem; }
.blog-post-content ul { list-style: disc; }
.blog-post-content ol { list-style: decimal; }
.blog-post-content li { margin-bottom: 0.45rem; line-height: 1.7; }
.blog-post-content a { color: #2B3990; text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.blog-post-content a:hover { color: #F36F21; text-decoration: none; }
.blog-post-content blockquote { border-left: 4px solid #F36F21; background: #f9f9f9; padding: 18px 24px; margin: 1.75rem 0; font-style: italic; color: #555555; border-radius: 0 3px 3px 0; }
.blog-post-content strong { color: #2B3990; font-weight: 700; }
.blog-post-content table { width: 100%; border-collapse: collapse; margin-bottom: 1.75rem; font-size: 0.9rem; }
.blog-post-content th { background: #2B3990; color: #ffffff; font-family: "Montserrat", sans-serif; font-weight: 700; padding: 11px 16px; text-align: left; font-size: 0.78rem; letter-spacing: 0.04em; text-transform: uppercase; }
.blog-post-content td { padding: 10px 16px; border-bottom: 1px solid #e8e8e8; vertical-align: top; }
.blog-post-content tr:nth-child(even) td { background: #f9f9f9; }
.blog-post-content img { max-width: 100%; height: auto; margin: 1.25rem 0; border-radius: 3px; }
.blog-post-content .wp-caption { max-width: 100%; margin: 1.25rem 0; }
.blog-post-content .wp-caption-text { font-size: 0.8rem; color: #888888; text-align: center; margin-top: 6px; font-style: italic; }

/* ==========================================================================
   POST FOOTER — TAGS (shown at end of posts, not in meta line)
   ========================================================================== */

.blog-post-footer { margin-top: 40px; padding-top: 24px; border-top: 2px solid #e8e8e8; }

.blog-post-tags { margin-bottom: 16px; }
.blog-post-tags .tag-label { font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #888888; margin-right: 8px; }
.blog-post-tags a { display: inline-block; background: #f0f0f0; color: #555555; font-family: "Montserrat", sans-serif; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; padding: 4px 10px; border-radius: 2px; margin: 3px 3px 3px 0; transition: all 0.2s ease; }
.blog-post-tags a:hover { background: #2B3990; color: #ffffff; }

/* ==========================================================================
   STATIC PAGE CONTENT
   ========================================================================== */

.blog-page-header { margin-bottom: 28px; padding-bottom: 18px; border-bottom: 3px solid #F36F21; }
.blog-page-header h1 { margin-bottom: 0; }

.blog-page-content { font-size: clamp(0.95rem, 0.9rem + 0.3vw, 1.05rem); line-height: 1.8; color: #333333; }
.blog-page-content h2 { font-size: clamp(1.25rem, 1.1rem + 0.8vw, 1.6rem); margin: 1.75rem 0 0.8rem; padding-top: 0.5rem; }
.blog-page-content h3 { font-size: clamp(1.05rem, 1rem + 0.4vw, 1.25rem); margin: 1.5rem 0 0.65rem; }
.blog-page-content p { margin-bottom: 1.25rem; }
.post-footer-note p { margin-bottom: 0; }
.blog-page-content ul, .blog-page-content ol { margin: 0 0 1.25rem 1.75rem; }
.blog-page-content ul { list-style: disc; }
.blog-page-content ol { list-style: decimal; }
.blog-page-content li { margin-bottom: 0.5rem; }
.blog-page-content a { color: #2B3990; text-decoration: underline; text-underline-offset: 2px; }
.blog-page-content a:hover { color: #F36F21; text-decoration: none; }
.blog-page-content strong { color: #2B3990; font-weight: 700; }

/* ==========================================================================
   SIDEBAR — #8: smaller text; #10: gray bg + visual widget headers
   ========================================================================== */

.blog-sidebar { position: sticky; top: 110px; }

/* #10: light gray background per widget, rounded card feel */
.blog-sidebar-widget { margin-bottom: 20px; border-radius: 4px; overflow: hidden; box-shadow: 0 1px 6px rgba(43, 57, 144, 0.07); }
.blog-sidebar-widget:last-child { margin-bottom: 0; }

/* #10: widget body — light gray background */
.blog-sidebar-widget__body { background: #fefefe; border: 1px solid #e8e8e8; border-top: none; padding: 16px; }

/* #10: widget title bar — all orange to match search, with navy left accent */
.blog-sidebar-widget__title { font-family: "Montserrat", sans-serif; font-size: 0.7rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.12em; color: #2B3990; background: #EEE; padding: 11px 16px 11px 20px; margin-bottom: 0; display: flex; align-items: center; gap: 10px; border-left: 4px solid #F36F21; }

.blog-sidebar-search form { display: flex; align-items: center; }

/* #5: no orange border on input; clean gray border */
.blog-sidebar-search input[type="search"] { flex: 1; border: 1px solid #dddddd; border-right: none; padding: 9px 12px; font-family: var(--font-body); font-size: 0.8rem; border-radius: 3px 0 0 3px; outline: none; color: #333333; background: #ffffff; transition: border-color 0.2s ease; }
.blog-sidebar-search input[type="search"]::placeholder { color: #aaaaaa; }
.blog-sidebar-search input[type="search"]:focus { border-color: #2B3990; }

/* #5: search button blue, not orange */
.blog-sidebar-search button[type="submit"] { background: #2B3990; border: 3px solid #2B3990; border-left: none; color: #ffffff; padding: 9px 14px; cursor: pointer; border-radius: 0 3px 3px 0; transition: background 0.2s ease; display: flex; align-items: center; }
.blog-sidebar-search button[type="submit"]:hover { background: #F36F21; border-color: #F36F21; }

/* #8: sidebar lists — noticeably smaller than main content */
.blog-sidebar-list { list-style: none; margin: 0; padding: 0; }
.blog-sidebar-list li { border-bottom: 1px solid #eeeeee; }
.blog-sidebar-list li:last-child { border-bottom: none; }
.blog-sidebar-list li a { display: block; padding: 8px 0; font-family: var(--font-body); font-size: 0.78rem; font-weight: 600; color: #444444; line-height: 1.4; text-decoration: none; transition: color 0.15s ease, padding-left 0.15s ease; }
.blog-sidebar-list li a:hover { color: #F36F21; padding-left: 4px; }

/* #11: Accordion — hidden items */
.blog-sidebar-list li.sidebar-accordion-hidden { display: none; }

/* #11: Show more button */
.blog-accordion-toggle { display: flex; align-items: center; gap: 6px; margin-top: 10px; background: none; border: none; cursor: pointer; font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: #F36F21; padding: 0; transition: color 0.2s ease; }
.blog-accordion-toggle:hover { color: #2B3990; }
.blog-accordion-toggle .toggle-icon { width: 16px; height: 16px; border-radius: 50%; background: #F36F21; color: #ffffff; display: flex; align-items: center; justify-content: center; font-size: 14px; line-height: 1; flex-shrink: 0; transition: background 0.2s ease; }
.blog-accordion-toggle:hover .toggle-icon { background: #2B3990; }

/* Sidebar CTA banners */
.blog-sidebar-banner { display: block; border-radius: 0; overflow: hidden; transition: opacity 0.2s ease; }
.blog-sidebar-banner:hover { opacity: 0.92; }
.blog-sidebar-banner img { width: 100%; height: auto; display: block; }

/* No extra padding for banner widgets */
.blog-sidebar-widget--banner { box-shadow: 0 2px 10px rgba(43, 57, 144, 0.1); }
.blog-sidebar-widget--banner .blog-sidebar-widget__body { padding: 0; background: transparent; border: none; }

/* Attorney grid — #8: small text */
.blog-sidebar-attorneys { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.blog-sidebar-attorney { text-align: center; }
.blog-sidebar-attorney a { display: block; text-decoration: none; transition: opacity 0.2s ease; }
.blog-sidebar-attorney a:hover { opacity: 0.85; }
.blog-sidebar-attorney img { width: 80px; height: 80px; object-fit: cover; object-position: top center; border-radius: 3px; margin: 0 auto 6px; display: block; }
.blog-sidebar-attorney__name { display: block; font-family: "Montserrat", sans-serif; font-size: 0.6rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.04em; color: #2B3990; line-height: 1.3; transition: color 0.2s ease; }
.blog-sidebar-attorney a:hover .blog-sidebar-attorney__name { color: #F36F21; }
.blog-sidebar-attorney__title { display: block; font-family: var(--font-body); font-size: 0.56rem; color: #888888; margin-top: 1px; line-height: 1.3; }

/* ==========================================================================
   INTERIOR FOOTER — BOOK STRIP
   Sits above the main footer on all interior pages (single, archive,
   search, page). Omitted on the homepage where the book has a full section.
   ========================================================================== */

.footer-book-strip { padding-top: clamp(32px, 4vw, 48px); padding-bottom: clamp(32px, 4vw, 48px); border-top: 1px solid rgba(255,255,255,0.12); }

.footer-book-strip__inner { display: flex; align-items: center; gap: 32px; }

.footer-book-strip__cover-link { display: block; flex-shrink: 0; line-height: 0; transition: transform 0.22s ease; }
.footer-book-strip__cover-link:hover { transform: translateY(-3px); }
.footer-book-strip__cover { width: 80px; height: auto; border-radius: 2px; box-shadow: 0 8px 24px rgba(0,0,0,0.4); display: block; }

.footer-book-strip__content { flex: 1; min-width: 0; }
.footer-book-strip__action { flex-shrink: 0; text-align: right; }

.footer-book-strip__eyebrow { font-family: "Montserrat", sans-serif; font-size: 0.62rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.45); margin: 0 0 4px; }
.footer-book-strip__title { font-family: "Montserrat", sans-serif; font-size: clamp(1rem, 0.85rem + 0.8vw, 1.35rem); font-weight: 800; color: #ffffff; line-height: 1.15; margin: 0 0 4px; }
.footer-book-strip__subtitle { font-family: var(--font-body); font-size: 0.82rem; color: rgba(255,255,255,0.6); margin: 0; line-height: 1.5; }
.footer-book-strip__cta { display: inline-block; background: #F36F21; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.09em; padding: 9px 20px; border-radius: 3px; text-decoration: none; transition: background 0.2s ease; white-space: nowrap; }
.footer-book-strip__cta:hover { background: #FC914D; color: #ffffff; }

/* ==========================================================================
   FOOTER — #1: social icons moved here
   ========================================================================== */

.blog-site-footer { background: #2B3990; color: #ffffff; padding: clamp(40px, 6vw, 64px) 0 0; margin-top: 0; }

/* CTA strip */
.blog-footer-cta { text-align: center; padding-bottom: clamp(36px, 5vw, 56px); border-bottom: 1px solid rgba(255, 255, 255, 0.12); margin-bottom: clamp(36px, 5vw, 52px); }
.blog-footer-cta__label { font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: #FC914D; margin-bottom: 12px; }
.blog-footer-cta__title { font-size: clamp(1.5rem, 1.2rem + 1.5vw, 2.25rem); color: #ffffff; margin-bottom: 10px; }
.blog-footer-cta__text { font-size: 0.95rem; color: rgba(255, 255, 255, 0.75); margin-bottom: 24px; max-width: 560px; margin-left: auto; margin-right: auto; }
.blog-footer-cta__btn { display: inline-block; background: #F36F21; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.82rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; padding: 14px 32px; border-radius: 3px; transition: background 0.2s ease; }
.blog-footer-cta__btn:hover { background: #FC914D; color: #ffffff; }
.blog-footer-cta__phone { display: block; font-family: "Montserrat", sans-serif; font-size: 0.82rem; font-weight: 700; color: rgba(255, 255, 255, 0.75); margin-top: 16px; letter-spacing: 0.04em; }
.blog-footer-cta__phone a { color: #FC914D; font-size: 1.1rem; }
.blog-footer-cta__phone a:hover { color: #ffffff; }

/* Office grid */
.blog-footer-offices-heading { font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: #FC914D; margin-bottom: 20px; text-align: center; }
.blog-footer-offices { display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; margin-bottom: clamp(32px, 5vw, 48px); }
.blog-footer-office h4 { font-family: "Montserrat", sans-serif; font-size: 0.8rem; font-weight: 700; color: #ffffff; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 8px; }
.blog-footer-office address { font-style: normal; font-size: 0.82rem; color: rgba(255, 255, 255, 0.65); line-height: 1.6; }
.blog-footer-office a { color: rgba(255, 255, 255, 0.65); text-decoration: none; transition: color 0.2s ease; }
.blog-footer-office a:hover { color: #FC914D; }

/* Social — #1: moved to footer */
.blog-footer-social { display: flex; align-items: center; gap: 10px; margin-bottom: 20px; flex-shrink: 0; }

/* Inside footer.php bottom bar — restore column divider, clear margin */
.blog-footer-bottom .blog-footer-social { border-left: 1px solid rgba(255, 255, 255, 0.1); padding-left: 24px; margin-bottom: 0; }

.blog-footer-social a { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: 1px solid rgba(255, 255, 255, 0.25); border-radius: 50%; color: rgba(255, 255, 255, 0.7); font-size: 14px; transition: all 0.2s ease; text-decoration: none; }
.blog-footer-social a:hover { background: #F36F21; border-color: #F36F21; color: #ffffff; }

/* Bottom bar */
.blog-footer-bottom { border-top: 1px solid rgba(255, 255, 255, 0.1); padding: 20px 0; display: flex; align-items: center; justify-content: space-between; gap: 0; flex-wrap: wrap; }
.blog-footer-disclaimer-col { border-left: 1px solid rgba(255, 255, 255, 0.1); padding-left: 24px; padding-right: 24px; flex: 1; }
.blog-footer-bottom > div:first-child { padding-right: 24px; }
.blog-footer-copyright { font-size: 0.78rem; color: rgba(255, 255, 255, 0.5); margin-bottom: 6px; }
.blog-footer-legal-nav { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; margin-bottom: 6px; }
.blog-footer-legal-nav a { font-size: 0.75rem; color: rgba(255, 255, 255, 0.55); text-decoration: none; transition: color 0.2s ease; }
.blog-footer-legal-nav a:hover { color: #FC914D; }
.blog-footer-legal-nav .divider { color: rgba(255, 255, 255, 0.25); font-size: 0.7rem; }
.blog-footer-credit { font-size: 0.72rem; color: rgba(255, 255, 255, 0.35); }
.blog-footer-credit a { color: rgba(255, 255, 255, 0.45); text-decoration: none; }
.blog-footer-credit a:hover { color: #FC914D; }
.blog-footer-disclaimer { font-size: 0.78rem; color: rgba(255, 255, 255, 0.5); max-width: 480px; line-height: 1.55; }
.blog-footer-disclaimer strong { color: rgba(255, 255, 255, 0.75); }

/* ==========================================================================
   SEARCH RESULTS PAGE
   ========================================================================== */

.blog-search-header { margin-bottom: 32px; padding-bottom: 18px; border-bottom: 3px solid #F36F21; }
.blog-search-header h1 { font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem); margin-bottom: 8px; }
.blog-search-header p { font-size: 0.9rem; color: #666666; margin: 0; }

.blog-search-no-results { font-size: 0.95rem; color: #555555; padding: 24px 0; }

/* Active-filter banner shown on /?s=&category_name= search results */
.blog-search-filter-banner { display: inline-flex; align-items: center; flex-wrap: wrap; gap: 10px; background: #f5f6fa; border: 1px solid #d8dce8; border-left: 3px solid #F36F21; border-radius: 3px; padding: 10px 14px 10px 16px; margin: 0 0 24px; font-family: var(--font-body); font-size: 0.85rem; }
.blog-search-filter-banner__label { color: #6a6f85; }
.blog-search-filter-banner__value { font-family: "Montserrat", sans-serif; font-weight: 700; color: #2B3990; letter-spacing: 0.01em; }
.blog-search-filter-banner__clear { display: inline-flex; align-items: center; gap: 5px; margin-left: auto; padding-left: 14px; font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: #2B3990; text-decoration: none; transition: color 0.18s ease; }
.blog-search-filter-banner__clear:hover { color: #F36F21; }
.blog-search-filter-banner__clear svg { display: block; flex-shrink: 0; }
@media (max-width: 540px) {
    .blog-search-filter-banner { display: flex; }
    .blog-search-filter-banner__clear { margin-left: 0; padding-left: 0; width: 100%; justify-content: flex-start; border-top: 1px solid #e4e6f0; padding-top: 10px; margin-top: 4px; }
}

/* ==========================================================================
   404 PAGE
   ========================================================================== */

.blog-404 { text-align: center; padding: clamp(60px, 10vw, 100px) 0; }
.blog-404 .error-number { font-family: "Montserrat", sans-serif; font-size: clamp(5rem, 10vw, 10rem); font-weight: 900; color: #F36F21; line-height: 1; margin-bottom: 16px; letter-spacing: -0.04em; }
.blog-404 h1 { font-size: clamp(1.5rem, 1.2rem + 1vw, 2rem); margin-bottom: 16px; }
.blog-404 p { font-size: 1rem; color: #555555; margin-bottom: 28px; max-width: 480px; margin-left: auto; margin-right: auto; }

.blog-btn-primary { display: inline-block; background: #2B3990; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.78rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; padding: 13px 28px; border-radius: 3px; transition: background 0.2s ease; }
.blog-btn-primary:hover { background: #F36F21; color: #ffffff; }

/* ==========================================================================
   MOBILE NAV DRAWER
   ========================================================================== */

/* Drawer — hidden off-screen by default; becomes fixed overlay when open */
.blog-mobile-nav { display: none; position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: #2B3990; z-index: 9999; overflow-y: auto; padding: 72px 28px 48px; transform: translateX(-100%); transition: transform 0.3s ease; }
.blog-mobile-nav.open { transform: translateX(0); }

/* Top-level menu items — stacked vertically */
.blog-mobile-nav .blog-nav-menu { list-style: none; margin: 0; padding: 0; display: block; }
.blog-mobile-nav .blog-nav-menu > li { display: block; position: relative; border-bottom: 1px solid rgba(255,255,255,0.12); }
.blog-mobile-nav .blog-nav-menu > li > a { display: block; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.95rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; padding: 16px 44px 16px 0; text-decoration: none; white-space: normal; background: none; }
.blog-mobile-nav .blog-nav-menu > li > a:hover { color: #FC914D; background: none; }

/* Override the desktop ::after dropdown arrow inside the drawer */
.blog-mobile-nav .blog-nav-menu > li.menu-item-has-children > a::after { display: none; }

/* Chevron toggle button — injected by JS */
.blog-submenu-toggle { position: absolute; top: 0; right: 0; height: 52px; width: 44px; background: transparent; border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.7); padding: 0; }
.blog-submenu-toggle:hover { color: #FC914D; }
.blog-submenu-toggle svg { transition: transform 0.25s ease; }
.blog-mobile-nav .menu-item-has-children.expanded .blog-submenu-toggle svg { transform: rotate(180deg); }

/* Submenus inside drawer */
.blog-mobile-nav .sub-menu { display: block; position: static; list-style: none; margin: 0; padding: 0 0 0 16px; background: transparent; opacity: 1; visibility: visible; transform: none; box-shadow: none; min-width: 0; max-height: 0; overflow: hidden; transition: max-height 0.35s ease, padding 0.35s ease; }
.blog-mobile-nav .sub-menu.open { max-height: 1200px; padding: 4px 0 12px 16px; }
.blog-mobile-nav .sub-menu li { display: block; }
.blog-mobile-nav .sub-menu li a { display: block; color: rgba(255,255,255,0.8); font-family: var(--font-body); font-size: 0.875rem; font-weight: 400; text-transform: none; letter-spacing: 0; padding: 9px 0; border-bottom: none; background: none; }
.blog-mobile-nav .sub-menu li a:hover { color: #FC914D; background: none; padding-left: 0; }

/* Action buttons in mobile drawer */
.blog-mobile-nav-actions { margin-top: 28px; display: flex; flex-direction: column; gap: 12px; }
.blog-mobile-contact-btn { display: block; background: #F36F21; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; text-align: center; padding: 14px 20px; text-decoration: none; border-radius: 3px; }
.blog-mobile-contact-btn:hover { background: #FC914D; color: #ffffff; }
.blog-mobile-visit-link { display: flex; align-items: center; justify-content: center; gap: 6px; color: #ffffff; font-family: var(--font-body); font-size: 0.875rem; padding: 12px 20px; border: 1px solid rgba(255,255,255,0.35); border-radius: 3px; text-decoration: none; }
.blog-mobile-visit-link:hover { border-color: rgba(255,255,255,0.7); color: #ffffff; }

/* Close button — injected by JS */
.blog-mobile-close { position: fixed; top: 16px; right: 20px; background: transparent; border: none; color: #ffffff; cursor: pointer; padding: 6px; z-index: 10000; line-height: 0; }
.blog-mobile-close:hover { color: #FC914D; }
.blog-mobile-close:focus-visible { outline: 2px solid #FC914D; outline-offset: 2px; }

/* Body scroll lock */
body.blog-nav-open { overflow: hidden; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */


/* Footer book strip responsive */
@media (max-width: 860px) {
    /* Move CTA action column under content on narrower viewports */
    .footer-book-strip__inner { flex-wrap: wrap; }
    .footer-book-strip__action { flex: 0 0 100%; text-align: left; padding-left: calc(80px + 32px); margin-top: 12px; }
    .footer-book-strip__subtitle { margin-bottom: 0; }
}
@media (max-width: 600px) {
    .footer-book-strip__inner { gap: 20px; }
    .footer-book-strip__cover { width: 60px; }
    .footer-book-strip__action { padding-left: calc(60px + 20px); }
}

/* Single post responsive */
@media (max-width: 900px) {
    .blog-single-content-col { padding: 32px 28px 0; }
    .blog-single-thumb__img { height: 340px; }
    .blog-related__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 600px) {
    .blog-single-content-col { padding: 24px 20px 0; }
    .blog-single-thumb__img { height: 240px; }
    .blog-related__grid { grid-template-columns: 1fr; }
    .blog-post-nav { grid-template-columns: 1fr; }
    .blog-post-nav__item--next { text-align: left; }
    .blog-author-box { flex-direction: column; gap: 16px; }
}

/* Homepage responsive */
@media (max-width: 1024px) {
    /* Carousel: 3-up → 2-up, hide side arrows (swipe + dots handle navigation on tablet) */
    .hp-featured__track       { gap: 24px; }
    .hp-featured__card        { flex: 0 0 calc((100% - 24px) / 2); }
    .hp-featured__arrow--side { display: none; }
    /* Other sections */
    .hp-topics__grid          { grid-template-columns: repeat(3, 1fr); gap: 20px; }
    .hp-book__inner           { gap: 36px; }
    .hp-book__cover           { width: 150px; }
}
@media (max-width: 860px) {
    .hp-topics__grid          { grid-template-columns: repeat(2, 1fr); }
    .hp-book__inner           { flex-direction: column; text-align: center; gap: 28px; }
    .hp-book__cover           { width: 140px; }
    .hp-book__description     { margin: 0 auto 28px; }
    .hp-scope__banner         { flex-direction: column; }
    .hp-scope__text           { padding: 20px 24px; font-size: 0.95rem; }
    .hp-scope__cta            { padding: 16px 24px; justify-content: center; }
}
@media (max-width: 768px) {
    /* Carousel: 2-up → 1-up */
    .hp-featured__track       { gap: 20px; }
    .hp-featured__card        { flex: 0 0 100%; }
    .hp-featured__controls    { gap: 18px; margin-top: 28px; }
}
@media (max-width: 540px) {
    .hp-topics__grid { grid-template-columns: 1fr; }
}

/* Search-and-filter bar responsive */
@media (max-width: 1024px) {
    .blog-search-bar__inner { max-width: 100%; gap: 14px; }
    .blog-search-bar__hint  { display: none; }
}
@media (max-width: 860px) {
    .blog-search-bar { padding: 14px 0; }
    .blog-search-bar__inner { flex-direction: column; align-items: stretch; gap: 10px; }
    .blog-search-bar__label { text-align: left; }
    .blog-search-bar__form  { flex-wrap: wrap; }
    .blog-search-bar__input-wrap { flex: 1 0 100%; border-bottom: 1px solid #e4e6f0; }
    .blog-search-bar__divider    { display: none; }
    .blog-search-bar__select-wrap { flex: 1; }
    .blog-search-bar__select     { width: 100%; max-width: none; }
    .blog-search-bar__submit     { flex-shrink: 0; padding: 14px 22px; }
}

/* Mobile-only proposal copy in topbar-left — hidden on desktop */
.blog-topbar-proposal-mobile { display: none; }

@media (max-width: 1340px) {
    .blog-nav-menu > li > a { padding-left: 15px; padding-right: 15px; }
    .blog-nav-menu > li:first-child > a { padding-left: 0; }
}
@media (max-width: 1240px) {
    .blog-nav-menu > li > a { padding-left: 10px; padding-right: 10px; letter-spacing: 0.04em; }
    .blog-nav-menu > li:first-child > a { padding-left: 0; }
}
@media (max-width: 1180px) {
    .blog-nav-menu > li > a { padding-left: 7px; padding-right: 7px; letter-spacing: 0.03em; }
    .blog-nav-menu > li:first-child > a { padding-left: 0; }
    .blog-nav-menu > li.menu-item-has-children > a::after { margin-left: 3px; }
}
@media (max-width: 1140px) {
    .blog-category-nav { display: none; }
    .blog-mobile-toggle { display: flex; align-items: center; justify-content: center; }
    .blog-mobile-nav { display: block; }
    /* Show proposal on left; hide proposal on right */
    .blog-topbar-proposal-mobile { display: inline-block; }
    .blog-header-topbar-right .blog-header-proposal { display: none; }
}
@media (min-width: 1141px) {
    .blog-mobile-nav { display: none !important; transform: none !important; }
    .blog-mobile-toggle { display: none !important; }
}
@media (max-width: 1100px) {
    .blog-body-wrap .container { grid-template-columns: 1fr 260px; gap: 32px; }
    .blog-footer-offices { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 960px) {
    .blog-header-tagline { display: none; }
}
@media (max-width: 900px) {
    .blog-body-wrap .container { grid-template-columns: 1fr; }
    .blog-sidebar { position: static; border-top: 2px solid #e8e8e8; padding-top: 40px; margin-top: 0; }
}
@media (max-width: 768px) {
    .blog-header-identity { padding: 10px 0; }
    .blog-logo img { height: 52px; }
    .blog-site-name { font-size: clamp(0.85rem, 0.7rem + 1.5vw, 1.1rem); white-space: normal; }
    .blog-header-phone { display: none; }
    .blog-footer-offices { grid-template-columns: repeat(2, 1fr); }
    .blog-footer-bottom { flex-direction: column; gap: 16px; }
    .blog-footer-disclaimer-col,
    .blog-footer-bottom .blog-footer-social { border-left: none; padding-left: 0; }
    .blog-footer-disclaimer { max-width: 100%; }
}
@media (max-width: 540px) {
    .blog-header-divider { display: none; }
    .blog-header-topbar .container { padding: 0 16px; }
}
@media (max-width: 480px) {
    .blog-footer-offices { grid-template-columns: 1fr; }
}

/* ==========================================================================
   AUTHOR ARCHIVE
   ========================================================================== */

/* .blog-author-header inherits border-bottom + spacing from .blog-page-header */

.blog-author-eyebrow { font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 8px; }

/* ==========================================================================
   AUTHOR ARCHIVE — About the Author box
   ========================================================================== */

.blog-author-bio { display: flex; gap: 18px; align-items: flex-start; margin: 0 0 28px; padding: 14px 18px; background: #f7f7f9; border-left: 3px solid #F36F21; border-radius: 2px; }
.blog-author-bio__headshot { flex: 0 0 90px; width: 90px; }
.blog-author-bio__headshot img { display: block; width: 90px; height: 90px; object-fit: cover; object-position: center top; border-radius: 4px; }
.blog-author-bio__main { flex: 1 1 auto; min-width: 0; }
.blog-author-bio__header-row { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px 12px; margin-bottom: 6px; }
.blog-author-bio__label { font-family: "Montserrat", sans-serif; font-size: 0.68rem; font-weight: 700; color: #2B3990; text-transform: uppercase; letter-spacing: 0.08em; margin: 0 0 4px; }
.blog-author-bio__name { font-family: "Montserrat", sans-serif; font-size: 0.92rem; font-weight: 700; color: #1a1a2e; margin: 0; }
.blog-author-bio__title { font-family: "Montserrat", sans-serif; font-size: 0.78rem; font-weight: 600; color: #555; margin: 0; line-height: 1.3; }
.blog-author-bio__title::before { content: "• "; color: #aaa; margin-right: 2px; }
.blog-author-bio__full-bio-link { font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; color: #F36F21; text-transform: uppercase; letter-spacing: 0.06em; text-decoration: none; margin-left: auto; white-space: nowrap; }
.blog-author-bio__full-bio-link:hover { color: #2B3990; text-decoration: underline; }
.blog-author-bio__body { font-size: 0.85rem; line-height: 1.55; color: #444; }
.blog-author-bio__body p { margin: 0; }
.blog-author-bio__body p + p { margin-top: 0.5rem; }
.blog-author-bio__body a { color: #2B3990; text-decoration: underline; }
.blog-author-bio__body a:hover { color: #F36F21; }

/* Stack on narrow viewports */
@media (max-width: 480px) {
    .blog-author-bio { gap: 14px; padding: 12px 14px; }
    .blog-author-bio__headshot { flex: 0 0 70px; width: 70px; }
    .blog-author-bio__headshot img { width: 70px; height: 70px; }
}

/* ============================================================
   PRINT-TO-PDF BUTTON — on-screen styling (hidden in print)
   ============================================================ */
.blog-post-print { margin: 40px 0 0; }
.blog-post-print__btn { display: inline-flex; align-items: center; gap: 9px; background: #2B3990; color: #ffffff; font-family: "Montserrat", sans-serif; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; padding: 12px 24px; border: none; border-radius: 3px; cursor: pointer; transition: background 0.2s ease, transform 0.15s ease; }
.blog-post-print__btn:hover { background: #1e2a6e; transform: translateY(-1px); }
.blog-post-print__btn svg { stroke-width: 2.2; }

/* Source URL shown only when printing. Hidden on screen. */
.blog-print-source { display: none; }

/* ============================================================
   PRINT STYLES — strips chrome, reformats the article body
   for clean paper / save-as-PDF output. Mirrors the look of
   the old blog's print output.
   ============================================================ */
@media print {

    @page {
        margin: 0.6in 0.55in;
    }

    html, body {
        background: #ffffff !important;
        color: #000000 !important;
        font-size: 11pt;
        line-height: 1.55;
    }

    /* Hide all chrome */
    .blog-site-header,
    .blog-search-bar,
    .blog-mobile-nav,
    .blog-mobile-toggle,
    .blog-site-footer,
    .blog-footer-cta,
    .blog-footer-offices,
    .footer-book-strip,
    .blog-footer-bottom,
    .blog-footer-social,
    .blog-single-breadcrumb,
    .blog-related,
    .blog-single-cats,
    .blog-post-nav,
    .blog-author-box,
    .blog-post-print,
    .blog-post-footer,
    .blog-single-thumb,
    .blog-sidebar,
    .comments-area,
    #comments,
    nav,
    aside {
        display: none !important;
    }

    /* Reset wrapper widths */
    .blog-single-wrap,
    .blog-single-content-col {
        display: block !important;
        max-width: none !important;
        width: auto !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* Source URL sits below the byline. Carries the divider that
       separates the article header from the body. */
    .blog-print-source {
        display: block !important;
        font-family: "Helvetica Neue", Arial, sans-serif !important;
        font-size: 9pt !important;
        color: #000 !important;
        margin: 0 0 16pt 0 !important;
        padding: 0 0 12pt 0 !important;
        border-bottom: 0.5pt solid #ccc !important;
        word-break: break-all;
    }
    .blog-print-source strong {
        font-weight: 700 !important;
        color: #000 !important;
    }

    /* Title block */
    .blog-single-title {
        font-family: "Helvetica Neue", Arial, sans-serif !important;
        font-size: 22pt !important;
        font-weight: 700 !important;
        color: #000 !important;
        margin: 0 0 10pt 0 !important;
        line-height: 1.25 !important;
        page-break-after: avoid;
    }

    /* Meta: show date only, drop reading-time */
    .blog-single-meta {
        font-family: "Helvetica Neue", Arial, sans-serif !important;
        font-size: 10pt !important;
        font-weight: 400 !important;
        color: #555 !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
        margin: 0 0 4pt 0 !important;
        display: block !important;
    }
    .blog-single-meta__sep,
    .blog-single-meta__read { display: none !important; }

    /* Byline */
    .blog-single-byline {
        font-family: "Helvetica Neue", Arial, sans-serif !important;
        font-size: 10pt !important;
        color: #000 !important;
        margin: 0 0 4pt 0 !important;
        padding: 0 !important;
        border-bottom: none !important;
    }
    .blog-single-byline a { color: #000 !important; text-decoration: none !important; }

    /* Article body. The descendant rule below forces every inline
       color attribute (typically blue links and emphasis text from the
       WordPress editor) to black in print output. */
    .blog-post-content {
        font-family: "Helvetica Neue", Arial, sans-serif !important;
        font-size: 11pt !important;
        color: #000 !important;
        line-height: 1.55 !important;
    }
    .blog-post-content,
    .blog-post-content * {
        color: #000 !important;
    }
    .blog-post-content p {
        orphans: 3;
        widows: 3;
        margin: 0 0 10pt 0;
    }
    .blog-post-content h2,
    .blog-post-content h3,
    .blog-post-content h4 {
        font-family: "Helvetica Neue", Arial, sans-serif !important;
        color: #000 !important;
        page-break-after: avoid;
        page-break-inside: avoid;
    }
    .blog-post-content h2 {
        font-size: 14pt !important;
        font-weight: 700 !important;
        margin: 18pt 0 6pt 0 !important;
        text-decoration: underline;
    }
    .blog-post-content h3 {
        font-size: 12pt !important;
        font-weight: 700 !important;
        margin: 14pt 0 5pt 0 !important;
    }
    .blog-post-content h4 {
        font-size: 11pt !important;
        font-weight: 700 !important;
        margin: 12pt 0 4pt 0 !important;
        text-transform: none !important;
        letter-spacing: 0 !important;
    }
    .blog-post-content a {
        color: #000 !important;
        text-decoration: underline !important;
    }
    .blog-post-content ul,
    .blog-post-content ol {
        margin: 0 0 10pt 0 !important;
        padding-left: 20pt !important;
    }
    .blog-post-content li { margin-bottom: 4pt; }
    .blog-post-content img,
    .blog-post-content figure {
        max-width: 100% !important;
        height: auto !important;
        page-break-inside: avoid;
    }
    .blog-post-content table {
        page-break-inside: avoid;
        font-size: 10pt !important;
        border-collapse: collapse;
    }
    .blog-post-content blockquote {
        margin: 10pt 14pt !important;
        padding-left: 10pt !important;
        border-left: 2pt solid #999 !important;
        color: #333 !important;
        font-style: italic;
    }
}