/**
 * Bee Happy Honey — Brand Stylesheet
 * Phase 1: Modern Honey palette
 * Built on GeneratePress (free).
 *
 * MODERN HONEY PALETTE:
 *   Near-Black:   #1A1A1A
 *   Gold:         #E8A838  (matches logo ring)
 *   White:        #FFFFFF
 *   Off-White:    #F7F3ED
 *   Green:        #5B8C5A  (decorative/large)
 *   Green Dark:   #4E7D4D  (text-safe, 4.8:1 on white)
 *
 * All text/background combos pass WCAG AA (4.5:1+).
 *
 * @package BeeHappyHoney
 * @since 1.0.0
 */

/* FONT FACES — Local WOFF2 (SIL Open Font Licence) */
@font-face { font-family: 'Lora'; src: url('../fonts/lora-latin-400-normal.woff2') format('woff2'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'Lora'; src: url('../fonts/lora-latin-700-normal.woff2') format('woff2'); font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: 'Lora'; src: url('../fonts/lora-latin-400-italic.woff2') format('woff2'); font-weight: 400; font-style: italic; font-display: swap; }
@font-face { font-family: 'Source Sans 3'; src: url('../fonts/source-sans-3-latin-400-normal.woff2') format('woff2'); font-weight: 400; font-style: normal; font-display: swap; }
@font-face { font-family: 'Source Sans 3'; src: url('../fonts/source-sans-3-latin-700-normal.woff2') format('woff2'); font-weight: 700; font-style: normal; font-display: swap; }
@font-face { font-family: 'Caveat'; src: url('../fonts/caveat-latin-400-normal.woff2') format('woff2'); font-weight: 400; font-style: normal; font-display: swap; }

/* === CUSTOM PROPERTIES === */
:root {
    --bhh-black: #1A1A1A;
    --bhh-gold: #E8A838;
    --bhh-white: #FFFFFF;
    --bhh-offwhite: #F7F3ED;
    --bhh-green: #5B8C5A;
    --bhh-green-text: #4E7D4D;
    --bhh-gold-light: #F0C060;
    --bhh-gold-dark: #C88E28;
    --bhh-black-soft: #2B2B2B;
    --bhh-grey-light: #E8E4DE;
    --bhh-grey-border: #E0DCD6;
    --bhh-text-primary: #1A1A1A;
    --bhh-text-body: #3D3D3D;
    --bhh-text-light: #FFFFFF;
    --bhh-text-muted: #7A7A7A;
    --bhh-font-heading: 'Lora', Georgia, 'Times New Roman', serif;
    --bhh-font-body: 'Source Sans 3', 'Segoe UI', Tahoma, sans-serif;
    --bhh-font-accent: 'Caveat', cursive;
    --bhh-space-xs: 0.25rem;
    --bhh-space-sm: 0.5rem;
    --bhh-space-md: 1rem;
    --bhh-space-lg: 1.5rem;
    --bhh-space-xl: 2rem;
    --bhh-space-2xl: 3rem;
    --bhh-space-3xl: 4rem;
    --bhh-max-width: 1200px;
    --bhh-border-radius: 6px;
    --bhh-transition: 0.2s ease;
}

/* === BASE === */
body { font-family: var(--bhh-font-body); font-size: 1.0625rem; line-height: 1.7; color: var(--bhh-text-body); background-color: var(--bhh-white); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
h1, h2, h3, h4, h5, h6, .entry-title, .site-title { font-family: var(--bhh-font-heading); color: var(--bhh-text-primary); font-weight: 700; line-height: 1.3; }
h1, .entry-title { font-size: 2rem; }
h2 { font-size: 1.625rem; }
h3 { font-size: 1.375rem; }
h4 { font-size: 1.125rem; }
a { color: var(--bhh-text-primary); text-decoration-color: var(--bhh-gold); text-decoration-thickness: 2px; text-underline-offset: 3px; transition: color var(--bhh-transition), text-decoration-color var(--bhh-transition); }
a:hover, a:focus { color: var(--bhh-gold-dark); text-decoration-color: var(--bhh-gold-dark); }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible, [tabindex]:focus-visible { outline: 3px solid var(--bhh-gold); outline-offset: 2px; border-radius: 2px; }
p { margin-bottom: var(--bhh-space-md); }
img { border-radius: var(--bhh-border-radius); }
::selection { background-color: var(--bhh-gold); color: var(--bhh-black); }

/* === SKIP LINK === */
.bhh-skip-link { position: absolute; top: -100%; left: 50%; transform: translateX(-50%); background: var(--bhh-black); color: var(--bhh-text-light); padding: var(--bhh-space-sm) var(--bhh-space-lg); font-size: 0.875rem; font-weight: 700; z-index: 10000; border-radius: 0 0 var(--bhh-border-radius) var(--bhh-border-radius); text-decoration: none; transition: top var(--bhh-transition); }
.bhh-skip-link:focus { top: 0; outline: 3px solid var(--bhh-gold); outline-offset: 2px; }

/* === HEADER === */
.site-header { background-color: var(--bhh-white); border-bottom: 3px solid var(--bhh-gold); position: relative; z-index: 100; }
.inside-header { max-width: var(--bhh-max-width); margin: 0 auto; padding: var(--bhh-space-md) var(--bhh-space-lg); display: flex; align-items: center; justify-content: space-between; gap: var(--bhh-space-lg); }
.site-title { font-family: var(--bhh-font-heading); font-size: 1.625rem; font-weight: 700; margin: 0; line-height: 1.2; }
.site-title a { color: var(--bhh-black); text-decoration: none; transition: color var(--bhh-transition); }
.site-title a:hover { color: var(--bhh-gold-dark); }
.bhh-tagline { font-family: var(--bhh-font-accent); font-size: 1.0625rem; color: var(--bhh-gold-dark); margin: 0; line-height: 1.2; }

/* === DESKTOP NAV === */
.main-navigation { font-family: var(--bhh-font-body); font-size: 0.9375rem; font-weight: 600; letter-spacing: 0.02em; }
.main-navigation .main-nav > ul { display: flex; align-items: center; gap: var(--bhh-space-xs); list-style: none; margin: 0; padding: 0; }
.main-navigation .main-nav > ul > li > a { display: block; padding: var(--bhh-space-sm) var(--bhh-space-md); color: var(--bhh-black); text-decoration: none; border-radius: var(--bhh-border-radius); transition: background-color var(--bhh-transition); position: relative; }
.main-navigation .main-nav > ul > li > a:hover, .main-navigation .main-nav > ul > li > a:focus { background-color: var(--bhh-offwhite); }
.main-navigation .main-nav > ul > li.current-menu-item > a::after, .main-navigation .main-nav > ul > li.current-menu-ancestor > a::after { content: ''; position: absolute; bottom: 2px; left: var(--bhh-space-md); right: var(--bhh-space-md); height: 3px; background-color: var(--bhh-gold); border-radius: 2px; }
.main-navigation ul ul { background-color: var(--bhh-white); border: 1px solid var(--bhh-grey-border); border-radius: var(--bhh-border-radius); box-shadow: 0 4px 16px rgba(26,26,26,0.08); min-width: 200px; }
.main-navigation ul ul a { padding: var(--bhh-space-sm) var(--bhh-space-md); color: var(--bhh-black); text-decoration: none; font-weight: 400; font-size: 0.875rem; }
.main-navigation ul ul a:hover, .main-navigation ul ul a:focus { background-color: var(--bhh-offwhite); }

/* === MOBILE NAV === */
.menu-toggle, .mobile-menu-control-wrapper .menu-toggle { display: none; align-items: center; gap: var(--bhh-space-sm); background: var(--bhh-black); color: var(--bhh-text-light); border: none; border-radius: var(--bhh-border-radius); padding: var(--bhh-space-sm) var(--bhh-space-md); font-family: var(--bhh-font-body); font-size: 0.875rem; font-weight: 600; cursor: pointer; transition: background-color var(--bhh-transition); line-height: 1; }
.menu-toggle:hover, .menu-toggle:focus { background: var(--bhh-black-soft); }
.menu-toggle:focus-visible { outline: 3px solid var(--bhh-gold); outline-offset: 2px; }
.menu-toggle .bhh-hamburger { display: flex; flex-direction: column; gap: 4px; width: 20px; }
.menu-toggle .bhh-hamburger span { display: block; height: 2px; background-color: currentColor; border-radius: 1px; transition: transform var(--bhh-transition), opacity var(--bhh-transition); }
.menu-toggle[aria-expanded="true"] .bhh-hamburger span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.menu-toggle[aria-expanded="true"] .bhh-hamburger span:nth-child(2) { opacity: 0; }
.menu-toggle[aria-expanded="true"] .bhh-hamburger span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

@media (max-width: 768px) {
    .menu-toggle, .mobile-menu-control-wrapper .menu-toggle { display: flex; }
    .main-navigation:not(.toggled) .main-nav > ul { display: none; }
    .main-navigation.toggled .main-nav > ul { display: flex; flex-direction: column; position: absolute; top: 100%; left: 0; right: 0; background-color: var(--bhh-white); border-top: 3px solid var(--bhh-gold); box-shadow: 0 8px 24px rgba(26,26,26,0.1); padding: var(--bhh-space-md); gap: 0; z-index: 200; animation: bhh-slideDown 0.25s ease; }
    .main-navigation.toggled .main-nav > ul > li > a { padding: var(--bhh-space-md); border-bottom: 1px solid var(--bhh-grey-border); border-radius: 0; font-size: 1rem; }
    .main-navigation.toggled .main-nav > ul > li:last-child > a { border-bottom: none; }
    .main-navigation.toggled .main-nav > ul > li.current-menu-item > a::after { display: none; }
    .main-navigation.toggled .main-nav > ul > li.current-menu-item > a { background-color: var(--bhh-offwhite); border-left: 3px solid var(--bhh-gold); }
    .main-navigation.toggled ul ul { position: static; box-shadow: none; border: none; padding-left: var(--bhh-space-lg); background: transparent; }
    .inside-header { flex-wrap: wrap; padding: var(--bhh-space-md); }
}

@keyframes bhh-slideDown { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }

/* === BREADCRUMBS === */
.bhh-breadcrumbs { font-family: var(--bhh-font-body); font-size: 0.8125rem; color: var(--bhh-text-muted); padding: var(--bhh-space-sm) 0; margin-bottom: var(--bhh-space-md); }
.bhh-breadcrumbs a { color: var(--bhh-text-muted); text-decoration: none; }
.bhh-breadcrumbs a:hover, .bhh-breadcrumbs a:focus { color: var(--bhh-black); text-decoration: underline; }
.bhh-breadcrumb-sep { margin: 0 var(--bhh-space-xs); color: var(--bhh-grey-light); }

/* === CONTENT === */
.site-content { max-width: var(--bhh-max-width); margin: 0 auto; padding: var(--bhh-space-xl) var(--bhh-space-lg); }
.entry-title { color: var(--bhh-black); margin-bottom: var(--bhh-space-sm); }
.entry-title a { color: var(--bhh-black); text-decoration: none; }
.entry-title a:hover { color: var(--bhh-gold-dark); }
.entry-meta { font-size: 0.8125rem; color: var(--bhh-text-muted); margin-bottom: var(--bhh-space-lg); }
.entry-meta a { color: var(--bhh-text-muted); text-decoration: none; }
.entry-meta a:hover { color: var(--bhh-black); }
.entry-content { font-size: 1.0625rem; line-height: 1.8; }
.entry-content h2 { margin-top: var(--bhh-space-2xl); margin-bottom: var(--bhh-space-md); padding-bottom: var(--bhh-space-xs); border-bottom: 2px solid var(--bhh-gold); }
.entry-content h3 { margin-top: var(--bhh-space-xl); margin-bottom: var(--bhh-space-sm); }
.entry-content blockquote { border-left: 4px solid var(--bhh-gold); background-color: var(--bhh-offwhite); padding: var(--bhh-space-lg); margin: var(--bhh-space-xl) 0; border-radius: 0 var(--bhh-border-radius) var(--bhh-border-radius) 0; font-family: var(--bhh-font-heading); font-style: italic; font-size: 1.125rem; color: var(--bhh-black); }
.entry-content blockquote p:last-child { margin-bottom: 0; }
.entry-content ul, .entry-content ol { padding-left: var(--bhh-space-xl); margin-bottom: var(--bhh-space-md); }
.entry-content li { margin-bottom: var(--bhh-space-xs); }
.entry-content img { border-radius: var(--bhh-border-radius); }
.wp-caption-text, figcaption { font-size: 0.8125rem; color: var(--bhh-text-muted); font-style: italic; text-align: center; margin-top: var(--bhh-space-sm); }
.post-image { margin-bottom: var(--bhh-space-xl); border-radius: var(--bhh-border-radius); overflow: hidden; }
.post-image img { width: 100%; height: auto; display: block; border-radius: 0; }

/* === BUTTONS === */
.bhh-button, button[type="submit"], input[type="submit"], .wp-block-button__link { display: inline-block; background-color: var(--bhh-gold); color: var(--bhh-black); font-family: var(--bhh-font-body); font-weight: 700; font-size: 0.9375rem; padding: var(--bhh-space-sm) var(--bhh-space-xl); border: none; border-radius: var(--bhh-border-radius); cursor: pointer; text-decoration: none; text-align: center; transition: background-color var(--bhh-transition), transform var(--bhh-transition); line-height: 1.5; }
.bhh-button:hover, button[type="submit"]:hover, input[type="submit"]:hover, .wp-block-button__link:hover { background-color: var(--bhh-gold-dark); color: var(--bhh-black); transform: translateY(-1px); }
.bhh-button:focus-visible, button[type="submit"]:focus-visible, input[type="submit"]:focus-visible { outline: 3px solid var(--bhh-black); outline-offset: 2px; }
.bhh-button-secondary { background: transparent; color: var(--bhh-black); border: 2px solid var(--bhh-black); }
.bhh-button-secondary:hover { background-color: var(--bhh-black); color: var(--bhh-text-light); transform: translateY(-1px); }

/* === SIDEBAR === */
.widget-area .widget { margin-bottom: var(--bhh-space-xl); padding: var(--bhh-space-lg); background-color: var(--bhh-offwhite); border-radius: var(--bhh-border-radius); border: 1px solid var(--bhh-grey-border); }
.widget-area .widget-title { font-family: var(--bhh-font-heading); font-size: 1.125rem; color: var(--bhh-black); margin-bottom: var(--bhh-space-md); padding-bottom: var(--bhh-space-sm); border-bottom: 2px solid var(--bhh-gold); }
.widget-area .widget ul { list-style: none; padding: 0; margin: 0; }
.widget-area .widget li { padding: var(--bhh-space-sm) 0; border-bottom: 1px solid var(--bhh-grey-border); }
.widget-area .widget li:last-child { border-bottom: none; }

/* === FOOTER === */
.bhh-footer-widgets { background-color: var(--bhh-black-soft); color: var(--bhh-text-light); padding: var(--bhh-space-3xl) var(--bhh-space-lg); }
.bhh-footer-widgets-inner { max-width: var(--bhh-max-width); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--bhh-space-2xl); }
.bhh-footer-widget .widget-title { font-family: var(--bhh-font-heading); font-size: 1.125rem; color: var(--bhh-gold); margin-bottom: var(--bhh-space-md); border-bottom: none; padding-bottom: 0; }
.bhh-footer-widget, .bhh-footer-widget a { color: rgba(255,255,255,0.8); }
.bhh-footer-widget a { text-decoration: none; transition: color var(--bhh-transition); }
.bhh-footer-widget a:hover { color: var(--bhh-gold); }
.site-info { background-color: var(--bhh-black); color: rgba(255,255,255,0.6); font-size: 0.8125rem; text-align: center; padding: var(--bhh-space-lg); }
.site-info a { color: var(--bhh-gold); text-decoration: none; }
.site-info a:hover { color: var(--bhh-gold-light); text-decoration: underline; }
@media (max-width: 768px) { .bhh-footer-widgets-inner { grid-template-columns: 1fr; gap: var(--bhh-space-xl); } }

/* === NEWSLETTER === */
.bhh-newsletter-section { background-color: var(--bhh-black); color: var(--bhh-text-light); padding: var(--bhh-space-3xl) var(--bhh-space-lg); text-align: center; border-radius: var(--bhh-border-radius); margin: var(--bhh-space-2xl) 0; }
.bhh-newsletter-inner { max-width: 600px; margin: 0 auto; }
.bhh-newsletter-heading { font-family: var(--bhh-font-heading); color: var(--bhh-gold); font-size: 1.625rem; margin-bottom: var(--bhh-space-md); border-bottom: none; }
.bhh-newsletter-text { color: rgba(255,255,255,0.8); font-size: 1.0625rem; line-height: 1.6; margin-bottom: var(--bhh-space-lg); }
.bhh-newsletter-placeholder { color: rgba(255,255,255,0.5); font-size: 0.875rem; }
.bhh-newsletter-post-footer { margin-top: var(--bhh-space-2xl); }
.bhh-newsletter-widget input[type="email"] { padding: var(--bhh-space-sm) var(--bhh-space-md); border: 2px solid rgba(255,255,255,0.25); border-radius: var(--bhh-border-radius); background: rgba(255,255,255,0.08); color: var(--bhh-text-light); font-family: var(--bhh-font-body); font-size: 1rem; width: 100%; max-width: 320px; }
.bhh-newsletter-widget input[type="email"]:focus { border-color: var(--bhh-gold); outline: none; }
.bhh-newsletter-widget input[type="email"]::placeholder { color: rgba(255,255,255,0.4); }

/* === BEE GIRL ACCENT === */
.bhh-bee-girl-text, .bhh-handwritten { font-family: var(--bhh-font-accent); font-size: 1.25rem; color: var(--bhh-gold-dark); line-height: 1.4; }
.bhh-author-bee-girl .bhh-author-name { font-family: var(--bhh-font-accent); font-size: 1.375rem; }

/* === SOCIAL SHARING === */
.bhh-share-toggle { display: inline-flex; align-items: center; gap: var(--bhh-space-sm); background: transparent; border: 1px solid var(--bhh-grey-border); border-radius: var(--bhh-border-radius); padding: var(--bhh-space-xs) var(--bhh-space-md); font-family: var(--bhh-font-body); font-size: 0.8125rem; color: var(--bhh-text-muted); cursor: pointer; transition: border-color var(--bhh-transition), color var(--bhh-transition); }
.bhh-share-toggle:hover { border-color: var(--bhh-gold); color: var(--bhh-black); }
.bhh-share-panel { display: none; gap: var(--bhh-space-sm); margin-top: var(--bhh-space-sm); }
.bhh-share-panel.bhh-share-open { display: flex; }
.bhh-share-link { display: inline-flex; align-items: center; justify-content: center; width: 36px; height: 36px; border-radius: 50%; background: var(--bhh-offwhite); color: var(--bhh-black); text-decoration: none; font-size: 0.875rem; transition: background-color var(--bhh-transition); }
.bhh-share-link:hover { background: var(--bhh-gold); color: var(--bhh-black); }

/* === GREEN ACCENT === */
.bhh-green-accent { color: var(--bhh-green-text); }
.bhh-green-bg { background-color: var(--bhh-green); color: var(--bhh-text-light); }
.bhh-category-tag { display: inline-block; background-color: var(--bhh-green); color: var(--bhh-text-light); font-size: 0.6875rem; font-weight: 700; padding: 2px 10px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.05em; text-decoration: none; }
.bhh-category-tag:hover { background-color: var(--bhh-green-text); color: var(--bhh-text-light); }

/* === UTILITIES === */
.screen-reader-text { border: 0; clip: rect(1px,1px,1px,1px); clip-path: inset(50%); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; word-wrap: normal !important; }
.screen-reader-text:focus { background-color: var(--bhh-white); clip: auto !important; clip-path: none; color: var(--bhh-black); display: block; font-size: 0.875rem; font-weight: 700; height: auto; left: 5px; line-height: normal; padding: var(--bhh-space-md); text-decoration: none; top: 5px; width: auto; z-index: 100000; }
.bhh-text-center { text-align: center; }
.bhh-accent-underline { text-decoration: none; background-image: linear-gradient(var(--bhh-gold), var(--bhh-gold)); background-size: 100% 3px; background-position: 0 100%; background-repeat: no-repeat; padding-bottom: 2px; }

/* === RESPONSIVE === */
@media (max-width: 1024px) { h1, .entry-title { font-size: 1.75rem; } h2 { font-size: 1.375rem; } .inside-header { padding: var(--bhh-space-md); } }
@media (max-width: 768px) { body { font-size: 1rem; } h1, .entry-title { font-size: 1.5rem; } h2 { font-size: 1.25rem; } h3 { font-size: 1.125rem; } .site-content { padding: var(--bhh-space-lg) var(--bhh-space-md); } .entry-content blockquote { padding: var(--bhh-space-md); margin: var(--bhh-space-lg) 0; } .bhh-newsletter-section { padding: var(--bhh-space-2xl) var(--bhh-space-md); border-radius: 0; margin-left: calc(var(--bhh-space-md) * -1); margin-right: calc(var(--bhh-space-md) * -1); } }
@media (max-width: 480px) { .site-title { font-size: 1.375rem; } .bhh-tagline { font-size: 0.9375rem; } }

/* === PRINT === */
@media print { .site-header, .main-navigation, .bhh-breadcrumbs, .bhh-newsletter-section, .bhh-footer-widgets, .site-info, .widget-area, .bhh-share-toggle, .bhh-share-panel { display: none !important; } body { font-size: 12pt; line-height: 1.5; color: #000; background: #fff; } a { color: #000; text-decoration: underline; } .entry-content img { max-width: 100%; box-shadow: none; } }


/* =========================================================================
   19. CATEGORY ACCENT COLOURS — Playful section identities
   Each section gets its own colour for: nav underline, category tags,
   H2 borders within posts, and breadcrumb hints.
   Everything else stays black + gold.
   ========================================================================= */

:root {
    /* Decorative (underlines, tags, borders) */
    --bhh-cat-hive:     #E8A838;   /* Hive & Seek — Gold (signature) */
    --bhh-cat-buzz:     #1A9E8F;   /* The Buzzword — Teal */
    --bhh-cat-wing:     #D45B3F;   /* Wing It — Coral */
    --bhh-cat-beegirl:  #9272C2;   /* Bee Girl's Corner — Purple */
    --bhh-cat-start:    #4A8AE0;   /* Start Here — Blue */

    /* Text-safe versions (4.5:1+ on white for AA compliance) */
    --bhh-cat-hive-text:     #A47A20;
    --bhh-cat-buzz-text:     #0E7C6E;
    --bhh-cat-wing-text:     #C0472B;
    --bhh-cat-beegirl-text:  #7B5EA7;
    --bhh-cat-start-text:    #2E6AB8;

    /* Light tints (card backgrounds, hover states) */
    --bhh-cat-hive-light:    #E8A83815;
    --bhh-cat-buzz-light:    #1A9E8F12;
    --bhh-cat-wing-light:    #D45B3F12;
    --bhh-cat-beegirl-light: #9272C212;
    --bhh-cat-start-light:   #4A8AE012;
}

/* --- Nav underlines per category --- */
.main-navigation .main-nav > ul > li.category-hive.current-menu-item > a::after,
.main-navigation .main-nav > ul > li.category-hive.current-menu-ancestor > a::after,
body.category-hive-seek .main-navigation .main-nav > ul > li.category-hive > a::after {
    background-color: var(--bhh-cat-hive);
}

.main-navigation .main-nav > ul > li.category-buzz.current-menu-item > a::after,
.main-navigation .main-nav > ul > li.category-buzz.current-menu-ancestor > a::after,
body.category-the-buzzword .main-navigation .main-nav > ul > li.category-buzz > a::after {
    background-color: var(--bhh-cat-buzz);
}

.main-navigation .main-nav > ul > li.category-wing.current-menu-item > a::after,
.main-navigation .main-nav > ul > li.category-wing.current-menu-ancestor > a::after,
body.category-wing-it .main-navigation .main-nav > ul > li.category-wing > a::after {
    background-color: var(--bhh-cat-wing);
}

.main-navigation .main-nav > ul > li.category-beegirl.current-menu-item > a::after,
.main-navigation .main-nav > ul > li.category-beegirl.current-menu-ancestor > a::after,
body.category-bee-girls-corner .main-navigation .main-nav > ul > li.category-beegirl > a::after {
    background-color: var(--bhh-cat-beegirl);
}

.main-navigation .main-nav > ul > li.category-start.current-menu-item > a::after,
.main-navigation .main-nav > ul > li.category-start.current-menu-ancestor > a::after,
body.category-start-here .main-navigation .main-nav > ul > li.category-start > a::after {
    background-color: var(--bhh-cat-start);
}

/* --- Mobile nav: coloured left border instead of underline --- */
@media (max-width: 768px) {
    .main-navigation.toggled .main-nav > ul > li.category-hive.current-menu-item > a {
        border-left-color: var(--bhh-cat-hive);
    }
    .main-navigation.toggled .main-nav > ul > li.category-buzz.current-menu-item > a {
        border-left-color: var(--bhh-cat-buzz);
    }
    .main-navigation.toggled .main-nav > ul > li.category-wing.current-menu-item > a {
        border-left-color: var(--bhh-cat-wing);
    }
    .main-navigation.toggled .main-nav > ul > li.category-beegirl.current-menu-item > a {
        border-left-color: var(--bhh-cat-beegirl);
    }
    .main-navigation.toggled .main-nav > ul > li.category-start.current-menu-item > a {
        border-left-color: var(--bhh-cat-start);
    }
}

/* --- Category tag pills --- */
.bhh-category-tag { display: inline-block; color: var(--bhh-text-light); font-size: 0.6875rem; font-weight: 700; padding: 2px 10px; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.05em; text-decoration: none; }
.bhh-category-tag.cat-hive    { background-color: var(--bhh-cat-hive); color: var(--bhh-black); }
.bhh-category-tag.cat-buzz    { background-color: var(--bhh-cat-buzz); }
.bhh-category-tag.cat-wing    { background-color: var(--bhh-cat-wing); }
.bhh-category-tag.cat-beegirl { background-color: var(--bhh-cat-beegirl); }
.bhh-category-tag.cat-start   { background-color: var(--bhh-cat-start); }

/* --- H2 borders within posts inherit category colour --- */
body.category-hive-seek .entry-content h2         { border-bottom-color: var(--bhh-cat-hive); }
body.category-the-buzzword .entry-content h2       { border-bottom-color: var(--bhh-cat-buzz); }
body.category-wing-it .entry-content h2            { border-bottom-color: var(--bhh-cat-wing); }
body.category-bee-girls-corner .entry-content h2   { border-bottom-color: var(--bhh-cat-beegirl); }
body.category-start-here .entry-content h2         { border-bottom-color: var(--bhh-cat-start); }

/* --- Blockquote accent follows category too --- */
body.category-hive-seek .entry-content blockquote       { border-left-color: var(--bhh-cat-hive); }
body.category-the-buzzword .entry-content blockquote     { border-left-color: var(--bhh-cat-buzz); }
body.category-wing-it .entry-content blockquote          { border-left-color: var(--bhh-cat-wing); }
body.category-bee-girls-corner .entry-content blockquote { border-left-color: var(--bhh-cat-beegirl); }
body.category-start-here .entry-content blockquote       { border-left-color: var(--bhh-cat-start); }

/* --- Widget/sidebar title border can pick up category on archive pages --- */
body.category-hive-seek .widget-area .widget-title       { border-bottom-color: var(--bhh-cat-hive); }
body.category-the-buzzword .widget-area .widget-title     { border-bottom-color: var(--bhh-cat-buzz); }
body.category-wing-it .widget-area .widget-title          { border-bottom-color: var(--bhh-cat-wing); }
body.category-bee-girls-corner .widget-area .widget-title { border-bottom-color: var(--bhh-cat-beegirl); }
body.category-start-here .widget-area .widget-title       { border-bottom-color: var(--bhh-cat-start); }

/* --- Bee Girl's Corner — extra personality --- */
body.category-bee-girls-corner .entry-title {
    font-family: var(--bhh-font-accent);
    font-size: 2.25rem;
    color: var(--bhh-cat-beegirl-text);
}

body.category-bee-girls-corner .entry-content {
    font-size: 1.125rem;
}

/* Pencil drawing / illustration frame */
.bhh-illustration {
    border: 2px solid var(--bhh-grey-border);
    border-radius: var(--bhh-border-radius);
    padding: var(--bhh-space-sm);
    background: var(--bhh-white);
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
}

.bhh-illustration img {
    display: block;
    width: 100%;
    height: auto;
    border-radius: 4px;
}

.bhh-illustration figcaption {
    font-family: var(--bhh-font-accent);
    font-size: 1.0625rem;
    color: var(--bhh-cat-beegirl-text);
    text-align: center;
    margin-top: var(--bhh-space-sm);
}

/* Sketch with purple tint background — for Bee Girl's drawings */
.bhh-illustration-beegirl {
    background: #9272C20A;
    border-color: #9272C240;
}


/* =========================================================================
   20. LOGO SIZING — Constrain the circular logo in the header
   ========================================================================= */

.site-header .header-image,
.site-header .custom-logo-link {
    display: inline-block;
    max-width: 60px;
    flex-shrink: 0;
}

.site-header .header-image img,
.site-header .custom-logo-link img,
.site-header .custom-logo {
    width: 60px;
    height: 60px;
    max-height: 60px;
    object-fit: contain;
    border-radius: 0;
}

/* When logo is present, tighten the brand area */
.inside-header .site-branding {
    display: flex;
    align-items: center;
    gap: var(--bhh-space-md);
}

/* Option: Remove logo entirely via CSS if you'd rather go text-only
   Uncomment these lines to hide the logo and use text only:
   
.site-header .header-image,
.site-header .custom-logo-link { display: none !important; }
*/


/* =========================================================================
   21. WORDPRESS SITE DESCRIPTION — Caveat handwriting font
   When tagline is set in Customise → Site Identity, style it to match.
   ========================================================================= */

.site-description {
    font-family: var(--bhh-font-accent) !important;
    font-size: 1.0625rem !important;
    color: var(--bhh-gold-dark) !important;
    margin: 0 !important;
    line-height: 1.2;
    letter-spacing: 0.01em;
    font-weight: 400;
}


/* =========================================================================
   20. HOMEPAGE — Full-width sections
   ========================================================================= */

/* --- Front page base --- */
.bhh-front-page { padding: 0; max-width: none; }
.bhh-section { padding: var(--bhh-space-3xl) var(--bhh-space-lg); }
.bhh-section-inner { max-width: var(--bhh-max-width); margin: 0 auto; }
.bhh-section-heading { text-align: center; border-bottom: none; margin-bottom: var(--bhh-space-sm); }
.bhh-section-subheading { text-align: center; color: var(--bhh-text-muted); font-size: 1.0625rem; margin-bottom: var(--bhh-space-lg); }
.bhh-section-cta { text-align: center; margin-top: var(--bhh-space-xl); }

/* --- Hero --- */
.bhh-hero {
    position: relative;
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    background-color: var(--bhh-black);
    background-image: url('../images/hero-bg.jpg');
    background-size: cover;
    background-position: center;
    overflow: hidden;
}

.bhh-hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(26,26,26,0.45) 0%, rgba(26,26,26,0.65) 100%);
    z-index: 1;
}

.bhh-hero-inner {
    position: relative;
    z-index: 2;
    max-width: 720px;
    padding: var(--bhh-space-2xl) var(--bhh-space-lg);
}

.bhh-hero-title {
    font-family: var(--bhh-font-heading);
    font-size: 3rem;
    color: var(--bhh-white);
    margin-bottom: var(--bhh-space-sm);
    line-height: 1.1;
}

.bhh-hero-tagline {
    font-family: var(--bhh-font-accent);
    font-size: 1.5rem;
    color: var(--bhh-gold);
    margin-bottom: var(--bhh-space-lg);
}

.bhh-hero-subtitle {
    color: rgba(255,255,255,0.85);
    font-size: 1.125rem;
    line-height: 1.6;
    margin-bottom: var(--bhh-space-xl);
}

.bhh-hero-cta {
    display: flex;
    gap: var(--bhh-space-md);
    justify-content: center;
    flex-wrap: wrap;
}

.bhh-button-hero-secondary {
    border-color: var(--bhh-white);
    color: var(--bhh-white);
}

.bhh-button-hero-secondary:hover {
    background-color: var(--bhh-white);
    color: var(--bhh-black);
}

/* --- Intro section --- */
.bhh-intro { background-color: var(--bhh-offwhite); text-align: center; }
.bhh-intro-inner { max-width: 720px; margin: 0 auto; }
.bhh-intro h2 { border-bottom: none; }

/* --- Latest Posts grid --- */
.bhh-latest-posts { background-color: var(--bhh-white); }

.bhh-posts-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--bhh-space-xl);
    margin-top: var(--bhh-space-xl);
    margin-bottom: var(--bhh-space-xl);
}

.bhh-post-card {
    background: var(--bhh-white);
    border: 1px solid var(--bhh-grey-border);
    border-radius: var(--bhh-border-radius);
    overflow: hidden;
    transition: transform var(--bhh-transition), box-shadow var(--bhh-transition);
}

.bhh-post-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(26,26,26,0.08);
}

.bhh-card-image img {
    width: 100%;
    height: 200px;
    object-fit: cover;
    display: block;
    border-radius: 0;
}

.bhh-card-body { padding: var(--bhh-space-lg); }
.bhh-card-body .bhh-category-tag { margin-bottom: var(--bhh-space-sm); }

.bhh-card-title {
    font-size: 1.125rem;
    margin-bottom: var(--bhh-space-sm);
    line-height: 1.3;
}

.bhh-card-title a { text-decoration: none; color: var(--bhh-black); }
.bhh-card-title a:hover { color: var(--bhh-gold-dark); }

.bhh-card-excerpt {
    font-size: 0.9375rem;
    color: var(--bhh-text-body);
    line-height: 1.5;
    margin-bottom: var(--bhh-space-md);
}

.bhh-card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8125rem;
    color: var(--bhh-text-muted);
}

.bhh-card-readmore a { color: var(--bhh-gold-dark); text-decoration: none; font-weight: 600; }
.bhh-card-readmore a:hover { text-decoration: underline; }

/* --- Team section --- */
.bhh-team { background-color: var(--bhh-offwhite); text-align: center; }
.bhh-team h2 { border-bottom: none; }

.bhh-team-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--bhh-space-xl);
    margin-top: var(--bhh-space-xl);
    margin-bottom: var(--bhh-space-xl);
}

.bhh-team-card {
    background: var(--bhh-white);
    border-radius: var(--bhh-border-radius);
    padding: var(--bhh-space-xl);
    border: 1px solid var(--bhh-grey-border);
    text-align: center;
}

.bhh-team-emoji { font-size: 3rem; margin-bottom: var(--bhh-space-md); display: block; }
.bhh-team-name { font-family: var(--bhh-font-heading); font-size: 1.25rem; color: var(--bhh-black); margin-bottom: var(--bhh-space-xs); }
.bhh-team-role { font-family: var(--bhh-font-accent); color: var(--bhh-gold-dark); font-size: 1.0625rem; margin-bottom: var(--bhh-space-sm); }

.bhh-team-desc {
    font-size: 0.9375rem;
    color: var(--bhh-text-body);
    line-height: 1.5;
}

/* --- Shop teaser --- */
.bhh-shop-teaser { background-color: var(--bhh-black); color: var(--bhh-white); text-align: center; }
.bhh-shop-teaser h2 { color: var(--bhh-gold); border-bottom: none; }
.bhh-shop-teaser p { color: rgba(255,255,255,0.8); }

.bhh-collections {
    display: flex;
    justify-content: center;
    gap: var(--bhh-space-md);
    flex-wrap: wrap;
    margin: var(--bhh-space-xl) 0;
}

.bhh-collection-badge {
    display: inline-block;
    padding: var(--bhh-space-sm) var(--bhh-space-xl);
    border: 2px solid var(--bhh-gold);
    border-radius: 30px;
    color: var(--bhh-gold);
    font-weight: 700;
    font-size: 0.9375rem;
    text-decoration: none;
    transition: background-color var(--bhh-transition), color var(--bhh-transition);
}

.bhh-collection-badge:hover { background-color: var(--bhh-gold); color: var(--bhh-black); }

/* --- Homepage newsletter context --- */
.bhh-newsletter-homepage { border-radius: 0; margin: 0; }

/* --- Responsive: Homepage --- */
@media (max-width: 1024px) {
    .bhh-posts-grid { grid-template-columns: repeat(2, 1fr); }
    .bhh-hero-title { font-size: 2.5rem; }
}

@media (max-width: 768px) {
    .bhh-hero { min-height: 70vh; }
    .bhh-hero-title { font-size: 2rem; }
    .bhh-hero-tagline { font-size: 1.25rem; }
    .bhh-hero-subtitle { font-size: 1rem; }
    .bhh-posts-grid { grid-template-columns: 1fr; gap: var(--bhh-space-lg); }
    .bhh-team-grid { grid-template-columns: 1fr; gap: var(--bhh-space-lg); }
    .bhh-section { padding: var(--bhh-space-2xl) var(--bhh-space-md); }
    .bhh-collections { gap: var(--bhh-space-sm); }
    .bhh-collection-badge { padding: var(--bhh-space-xs) var(--bhh-space-lg); font-size: 0.875rem; }
}