/*
Theme Name: ColorBlock
Theme URI: https://icanthascheezburger.com
Author: Aaron
Description: A vibrant, minimalist block theme with colorful grid layout and dark mode support. Inspired by modern, playful design aesthetics.
Requires at least: 6.0
Tested up to: 6.4
Requires PHP: 7.4
Version: 2.0.5
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: colorblock
Tags: blog, one-column, custom-colors, custom-menu, editor-style, featured-images, full-site-editing, block-patterns, rtl-language-support, sticky-post, threaded-comments, grid-layout
*/

/* =============================================================================
   FONT DECLARATIONS
   ============================================================================= */

@font-face {
  font-family: 'Teko';
  src: url('assets/fonts/Teko-Regular.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

/* =============================================================================
   COLOR SYSTEM - Light & Dark Mode with System Detection
   ============================================================================= */

:root {
  /* Light mode colors */
  --color-base: #10c0f1; 
  --color-contrast: #1a1a1a;
  
  /* Vibrant colors for light mode */
  --color-1: #8B7FC7; /* Ube Purple */
  --color-2: #FF6B9D; /* Sonic Pink */
  --color-3: #4ECDC4; /* Tales Teal */
  --color-4: #FFE66D; /* Energy Yellow */
  --color-5: #FF6B35; /* Neo Orange */
  
  /* Text on colored backgrounds */
  --color-on-vibrant: #000000;
}

/* System dark mode detection */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --color-base: #003330; /* Dark teal background */
    --color-contrast: #f5f5f5;
    
    /* Darker color variants for dark mode */
    --color-1: #3d2e5f; /* Dark Purple */
    --color-2: #8B4968; /* Dark Pink */
    --color-3: #2d7a72; /* Dark Teal */
    --color-4: #b8a04c; /* Dark Gold */
    --color-5: #b84a24; /* Dark Orange */
    
    --color-on-vibrant: #ffffff;
  }
}

/* Manual dark mode override */
[data-theme="dark"] {
  --color-base: #003330; /* Dark teal background */
  --color-contrast: #f5f5f5;
  
  --color-1: #3d2e5f;
  --color-2: #8B4968;
  --color-3: #2d7a72;
  --color-4: #b8a04c;
  --color-5: #b84a24;
  
  --color-on-vibrant: #ffffff;
}

/* Manual light mode override */
[data-theme="light"] {
  --color-base: #10c0f1; 
  --color-contrast: #1a1a1a;
  
  --color-1: #8B7FC7;
  --color-2: #FF6B9D;
  --color-3: #4ECDC4;
  --color-4: #FFE66D;
  --color-5: #FF6B35;
  
  --color-on-vibrant: #000000;
}

body {
  background-color: var(--color-base);
  color: var(--color-contrast);
  transition: background-color 0.3s ease, color 0.3s ease;
  margin: 0 !important;
  padding: 0 !important;
  overflow-x: hidden;
}

/* Remove default padding from main WordPress containers */
.wp-site-blocks {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
}

main.wp-block-group {
  padding-left: 0 !important;
  padding-right: 0 !important;
  padding-top: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
}

/* Remove padding from all top-level containers */
body > * {
  max-width: 100% !important;
}

.wp-block-group {
  max-width: 100% !important;
}

/* =============================================================================
   GRID LAYOUT - 3 columns on desktop, 1 on mobile
   ============================================================================= */

.colorblock-post-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 0;
}

@media (min-width: 768px) {
  .colorblock-post-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
  }
}

@media (min-width: 1024px) {
  .colorblock-post-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
  }
}

/* =============================================================================
   COLORFUL POST CARDS
   ============================================================================= */

.colorblock-post-card {
  position: relative;
  border-radius: 0;
  overflow: hidden;
  height: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  box-shadow: none;
  box-sizing: border-box;
}

.colorblock-post-card:hover {
  transform: none;
  box-shadow: none;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .colorblock-post-card:hover {
    box-shadow: none;
  }
}

[data-theme="dark"] .colorblock-post-card:hover {
  box-shadow: none;
}

/* Color rotation for each post - targeting list items */
.colorblock-post-grid > li:nth-child(5n+1) .colorblock-post-card {
  background-color: var(--color-1);
}

.colorblock-post-grid > li:nth-child(5n+2) .colorblock-post-card {
  background-color: var(--color-2);
}

.colorblock-post-grid > li:nth-child(5n+3) .colorblock-post-card {
  background-color: var(--color-3);
}

.colorblock-post-grid > li:nth-child(5n+4) .colorblock-post-card {
  background-color: var(--color-4);
}

.colorblock-post-grid > li:nth-child(5n+5) .colorblock-post-card {
  background-color: var(--color-5);
}

/* Featured Image */
.colorblock-featured-image {
  width: 100%;
  margin: 0;
  padding: 10px;
  box-sizing: border-box;
}

.colorblock-featured-image img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  display: block;
  border-radius: 0;
}

/* Content area */
.colorblock-post-content {
  padding: 2rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

/* Post meta */
.colorblock-post-date {
  color: var(--color-on-vibrant);
  opacity: 0.8;
  font-size: 0.875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0;
}

/* Post title */
.colorblock-post-title {
  margin: 0;
  padding: 0;
}

.colorblock-post-title a {
  color: var(--color-on-vibrant) !important;
  text-decoration: none;
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.3;
  transition: opacity 0.2s ease;
}

.colorblock-post-title a:hover {
  opacity: 0.9;
  text-decoration: none;
}

/* Post excerpt */
.colorblock-post-excerpt {
  color: var(--color-on-vibrant);
  opacity: 0.9;
  font-size: 0.95rem;
  line-height: 1.6;
  margin: 0;
}

.colorblock-post-excerpt p {
  margin: 0;
}

/* =============================================================================
   DARK MODE TOGGLE BUTTON
   ============================================================================= */

.dark-mode-toggle {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: none;
  background: linear-gradient(135deg, #8B7FC7 0%, #FF6B9D 100%);
  color: white;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
}

.dark-mode-toggle:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.dark-mode-toggle:active {
  transform: scale(0.95);
}

/* =============================================================================
   HEADER & FOOTER
   ============================================================================= */

.wp-block-site-title {
  margin-bottom: 0;
  font-weight: 700;
}

.wp-block-site-title a {
  text-decoration: none;
  color: var(--color-contrast);
}

/* =============================================================================
   NAVIGATION & HEADER
   ============================================================================= */

header,
header > *,
header .wp-block-group {
  padding: 0 !important;
  margin: 0 !important;
}

header {
  margin-bottom: 0 !important;
}

header + * {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

header .wp-block-group {
  height: 70px !important;
  max-height: 70px !important;
  min-height: 70px !important;
  overflow: hidden !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

header .wp-block-group.is-layout-constrained > * {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

header .wp-block-group > .wp-block-group {
  display: flex !important;
  flex-direction: row !important;
  justify-content: flex-start !important;
  align-items: stretch !important;
  width: 100%;
  height: 70px !important;
  max-height: 70px !important;
  min-height: 70px !important;
  padding: 0 !important;
  margin: 0 !important;
}

header .wp-block-site-title {
  display: flex;
  align-items: center;
  padding: 0 1.5rem;
}

header .wp-block-site-title a {
  line-height: 1 !important;
}

/* Force navigation to be full height and right-aligned */
nav.wp-block-navigation,
header nav.wp-block-navigation,
header .wp-block-navigation {
  font-size: 0.95rem !important;
  font-weight: 500 !important;
  gap: 0 !important;
  margin: 0 !important;
  margin-left: auto !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  justify-content: flex-end !important;
  height: 70px !important;
  min-height: 70px !important;
  max-height: 70px !important;
}

/* All inner navigation containers must be flex row and full height */
.wp-block-navigation .wp-block-navigation__responsive-container,
.wp-block-navigation .wp-block-navigation__responsive-container-content,
.wp-block-navigation > .wp-block-navigation__container,
.wp-block-navigation .wp-block-page-list,
.wp-block-navigation > ul,
.wp-block-navigation ul.wp-block-navigation__container {
  gap: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  height: 70px !important;
  min-height: 70px !important;
  max-height: 70px !important;
  list-style: none !important;
}

/* Navigation items must be flex and full height */
.wp-block-navigation .wp-block-navigation-item,
.wp-block-navigation li,
.wp-block-navigation li.wp-block-navigation-item {
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: stretch !important;
  height: 70px !important;
  min-height: 70px !important;
  max-height: 70px !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.wp-block-navigation a,
.wp-block-navigation .wp-block-navigation-item a,
.wp-block-navigation .wp-block-navigation-item__content {
  color: var(--color-on-vibrant) !important;
  text-decoration: none !important;
  padding-left: 1.5rem !important;
  padding-right: 1.5rem !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: opacity 0.2s ease;
  height: 70px !important;
  min-height: 70px !important;
  max-height: 70px !important;
  white-space: nowrap;
  box-sizing: border-box;
  font-family: 'Teko', sans-serif !important;
  font-size: 18pt !important;
}

.wp-block-navigation a:hover {
  opacity: 0.9;
}

/* Color rotation for navigation items - Light Mode */
.wp-block-navigation .wp-block-navigation-item:nth-child(1),
.wp-block-navigation li:nth-child(1) {
  background-color: #af7dff;
  border-left: 2px solid #5a2b99;
  border-top: 2px solid #5a2b99;
  border-bottom: 2px solid #5a2b99;
}

.wp-block-navigation .wp-block-navigation-item:nth-child(2),
.wp-block-navigation li:nth-child(2) {
  background-color: #ffaf7d;
  border-left: 2px solid #5a2b99;
  border-top: 2px solid #5a2b99;
  border-bottom: 2px solid #5a2b99;
}

.wp-block-navigation .wp-block-navigation-item:nth-child(3),
.wp-block-navigation li:nth-child(3) {
  background-color: #7dffaf;
  border-left: 2px solid #5a2b99;
  border-top: 2px solid #5a2b99;
  border-bottom: 2px solid #5a2b99;
}

.wp-block-navigation .wp-block-navigation-item:nth-child(4),
.wp-block-navigation li:nth-child(4) {
  background-color: #cdff7d;
  border-left: 2px solid #5a2b99;
  border-top: 2px solid #5a2b99;
  border-bottom: 2px solid #5a2b99;
}

.wp-block-navigation .wp-block-navigation-item:nth-child(5),
.wp-block-navigation li:nth-child(5) {
  background-color: #f07dff;
  border-left: 2px solid #5a2b99;
  border-top: 2px solid #5a2b99;
  border-bottom: 2px solid #5a2b99;
  border-right: 2px solid #5a2b99;
}

/* Ensure last navigation item always has right border */
.wp-block-navigation .wp-block-navigation-item:last-child,
.wp-block-navigation li:last-child {
  border-right: 2px solid #5a2b99 !important;
}

/* Color rotation for navigation items - Dark Mode (System) */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .wp-block-navigation .wp-block-navigation-item:nth-child(1),
  :root:not([data-theme="light"]) .wp-block-navigation li:nth-child(1) {
    background-color: #6b4a9f;
    border-left: 2px solid #3a2055;
    border-top: 2px solid #3a2055;
    border-bottom: 2px solid #3a2055;
  }

  :root:not([data-theme="light"]) .wp-block-navigation .wp-block-navigation-item:nth-child(2),
  :root:not([data-theme="light"]) .wp-block-navigation li:nth-child(2) {
    background-color: #9f6b4a;
    border-left: 2px solid #3a2055;
    border-top: 2px solid #3a2055;
    border-bottom: 2px solid #3a2055;
  }

  :root:not([data-theme="light"]) .wp-block-navigation .wp-block-navigation-item:nth-child(3),
  :root:not([data-theme="light"]) .wp-block-navigation li:nth-child(3) {
    background-color: #4a9f6b;
    border-left: 2px solid #3a2055;
    border-top: 2px solid #3a2055;
    border-bottom: 2px solid #3a2055;
  }

  :root:not([data-theme="light"]) .wp-block-navigation .wp-block-navigation-item:nth-child(4),
  :root:not([data-theme="light"]) .wp-block-navigation li:nth-child(4) {
    background-color: #7a9f4a;
    border-left: 2px solid #3a2055;
    border-top: 2px solid #3a2055;
    border-bottom: 2px solid #3a2055;
  }

  :root:not([data-theme="light"]) .wp-block-navigation .wp-block-navigation-item:nth-child(5),
  :root:not([data-theme="light"]) .wp-block-navigation li:nth-child(5) {
    background-color: #9f4a9f;
    border-left: 2px solid #3a2055;
    border-top: 2px solid #3a2055;
    border-bottom: 2px solid #3a2055;
    border-right: 2px solid #3a2055;
  }
  
  /* Ensure last navigation item always has right border in dark mode */
  :root:not([data-theme="light"]) .wp-block-navigation .wp-block-navigation-item:last-child,
  :root:not([data-theme="light"]) .wp-block-navigation li:last-child {
    border-right: 2px solid #3a2055 !important;
  }
}

/* Color rotation for navigation items - Dark Mode (Manual) */
[data-theme="dark"] .wp-block-navigation .wp-block-navigation-item:nth-child(1),
[data-theme="dark"] .wp-block-navigation li:nth-child(1) {
  background-color: #6b4a9f;
  border-left: 2px solid #3a2055;
  border-top: 2px solid #3a2055;
  border-bottom: 2px solid #3a2055;
}

[data-theme="dark"] .wp-block-navigation .wp-block-navigation-item:nth-child(2),
[data-theme="dark"] .wp-block-navigation li:nth-child(2) {
  background-color: #9f6b4a;
  border-left: 2px solid #3a2055;
  border-top: 2px solid #3a2055;
  border-bottom: 2px solid #3a2055;
}

[data-theme="dark"] .wp-block-navigation .wp-block-navigation-item:nth-child(3),
[data-theme="dark"] .wp-block-navigation li:nth-child(3) {
  background-color: #4a9f6b;
  border-left: 2px solid #3a2055;
  border-top: 2px solid #3a2055;
  border-bottom: 2px solid #3a2055;
}

[data-theme="dark"] .wp-block-navigation .wp-block-navigation-item:nth-child(4),
[data-theme="dark"] .wp-block-navigation li:nth-child(4) {
  background-color: #7a9f4a;
  border-left: 2px solid #3a2055;
  border-top: 2px solid #3a2055;
  border-bottom: 2px solid #3a2055;
}

[data-theme="dark"] .wp-block-navigation .wp-block-navigation-item:nth-child(5),
[data-theme="dark"] .wp-block-navigation li:nth-child(5) {
  background-color: #9f4a9f;
  border-left: 2px solid #3a2055;
  border-top: 2px solid #3a2055;
  border-bottom: 2px solid #3a2055;
  border-right: 2px solid #3a2055;
}

/* Ensure last navigation item always has right border in dark mode (manual) */
[data-theme="dark"] .wp-block-navigation .wp-block-navigation-item:last-child,
[data-theme="dark"] .wp-block-navigation li:last-child {
  border-right: 2px solid #3a2055 !important;
}

/* Footer styling */
footer .wp-block-group {
  background-color: transparent;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) footer .wp-block-group {
    border-top-color: rgba(255, 255, 255, 0.1);
  }
}

[data-theme="dark"] footer .wp-block-group {
  border-top-color: rgba(255, 255, 255, 0.1);
}

/* =============================================================================
   PAGINATION
   ============================================================================= */

.wp-block-query-pagination {
  margin-top: 3rem;
  gap: 1rem;
}

.wp-block-query-pagination a,
.wp-block-query-pagination .page-numbers {
  color: var(--color-contrast);
  text-decoration: none;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  transition: background-color 0.2s ease;
}

.wp-block-query-pagination a:hover {
  background-color: var(--color-1);
  color: white;
}

.wp-block-query-pagination .current {
  background-color: var(--color-1);
  color: white;
}

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

/* Full-width featured image at top of post */
.wp-singular > .wp-block-post-featured-image,
.wp-singular .wp-block-post-featured-image.alignfull {
  margin: 0 !important;
  padding: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
}

.wp-singular > .wp-block-post-featured-image img,
.wp-singular .wp-block-post-featured-image.alignfull img {
  width: 100%;
  height: auto;
  max-height: 500px;
  object-fit: cover;
  display: block;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  margin: 0;
}

/* Ensure full-width on mobile */
@media (max-width: 767px) {
  .wp-singular > .wp-block-post-featured-image,
  .wp-singular .wp-block-post-featured-image.alignfull {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
  
  .wp-singular > .wp-block-post-featured-image img,
  .wp-singular .wp-block-post-featured-image.alignfull img {
    max-height: 300px;
  }
}

/* Old constrained featured image styles (if placed elsewhere) */
.wp-singular .is-layout-constrained > .wp-block-post-featured-image {
  margin-left: 0 !important;
  margin-right: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 0;
  padding-right: 0;
  box-sizing: border-box;
}

.wp-singular .is-layout-constrained .wp-block-post-featured-image img {
  border-radius: 12px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
  padding-left: var(--wp--preset--spacing--50);
  padding-right: var(--wp--preset--spacing--50);
  box-sizing: border-box;
}

.wp-singular .wp-block-post-content {
  font-size: 1.1rem;
  line-height: 1.8;
}

/* Mobile content padding */
@media (max-width: 767px) {
  .wp-singular .wp-block-post-content,
  .wp-singular .wp-block-group.is-layout-constrained {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  
  /* Also apply to the main content wrapper */
  main.wp-block-group > .wp-block-group {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
}

.wp-singular .wp-block-post-content h2,
.wp-singular .wp-block-post-content h3 {
  color: var(--color-contrast);
  margin-top: 2rem;
}

/* Code blocks */
.wp-block-code {
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.05);
  border: none;
  padding: 1.5rem;
}

@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .wp-block-code {
    background: rgba(255, 255, 255, 0.05);
  }
}

[data-theme="dark"] .wp-block-code {
  background: rgba(255, 255, 255, 0.05);
}

/* Quote blocks */
.wp-block-quote {
  border-left: 4px solid var(--color-1);
  padding-left: 1.5rem;
  font-style: italic;
  margin: 2rem 0;
}

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

@media (max-width: 767px) {
  /* Prevent horizontal overflow and ensure proper scrolling */
  html, body {
    overflow-x: hidden;
    max-width: 100vw;
  }
  
  /* Force all containers to respect viewport width */
  body, 
  .wp-site-blocks,
  main.wp-block-group,
  .wp-block-group,
  header,
  header .wp-block-group {
    max-width: 100vw !important;
    overflow-x: hidden;
  }
  
  .colorblock-post-content {
    padding: 1.5rem;
  }
  
  .colorblock-post-title a {
    font-size: 1.25rem;
  }
  
  .dark-mode-toggle {
    bottom: 1.5rem;
    right: 1.5rem;
    width: 48px;
    height: 48px;
  }
}

/* =============================================================================
   MOBILE NAVIGATION
   ============================================================================= */

/* Ensure hamburger button is always visible and positioned correctly when closed */
.wp-block-navigation__responsive-container-open {
  position: relative !important;
  z-index: 999 !important;
  flex-shrink: 0 !important;
  margin-right: 0.5rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Style the hamburger icon to have three lines */
.wp-block-navigation__responsive-container-open svg {
  display: none !important;
}

.wp-block-navigation__responsive-container-open::after {
  content: '' !important;
  display: block !important;
  width: 24px !important;
  height: 2px !important;
  background-color: var(--color-on-vibrant) !important;
  position: relative !important;
  box-shadow: 
    0 -8px 0 0 var(--color-on-vibrant),
    0 8px 0 0 var(--color-on-vibrant) !important;
}

/* Hide hamburger open button when menu is open */
.wp-block-navigation.has-modal-open .wp-block-navigation__responsive-container-open,
.wp-block-navigation.is-menu-open .wp-block-navigation__responsive-container-open {
  display: none !important;
}

/* Hide mobile menu by default - only show when opened */
.wp-block-navigation__responsive-container:not(.is-menu-open) {
  display: none !important;
  opacity: 0;
  transform: translateX(100%);
}

.wp-block-navigation__responsive-container.is-menu-open {
  display: flex !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  bottom: auto !important;
  min-height: 100vh !important;
  z-index: 999 !important;
  opacity: 1;
  transform: translateX(0);
  animation: slideInRight 0.3s ease-out;
  overflow-y: visible !important;
}

/* Slide-in animation */
@keyframes slideInRight {
  from {
    opacity: 0;
    transform: translateX(100%);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Hamburger menu button styling */
.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close {
  background-color: var(--color-1) !important;
  color: var(--color-on-vibrant) !important;
  border: 2px solid #5a2b99 !important;
  padding: 0.5rem !important;
  border-radius: 4px;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.wp-block-navigation__responsive-container-open:hover,
.wp-block-navigation__responsive-container-close:hover {
  opacity: 0.9;
}

/* Position close button in top right */
.wp-block-navigation__responsive-container-close {
  position: fixed !important;
  top: 1rem !important;
  right: 1rem !important;
  z-index: 1000 !important;
}

/* Dark mode hamburger button */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container-open,
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container-close {
    border-color: #3a2055 !important;
  }
}

[data-theme="dark"] .wp-block-navigation__responsive-container-open,
[data-theme="dark"] .wp-block-navigation__responsive-container-close {
  border-color: #3a2055 !important;
}

/* Mobile menu overlay */
.wp-block-navigation__responsive-container.is-menu-open {
  background-color: var(--color-base) !important;
  padding: 4rem 1rem 1rem 1rem !important;
}

/* Mobile menu items - simple vertical list */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content {
  padding: 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container,
.wp-block-navigation__responsive-container.is-menu-open .wp-block-page-list,
.wp-block-navigation__responsive-container.is-menu-open ul {
  display: block !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item,
.wp-block-navigation__responsive-container.is-menu-open li {
  width: 100% !important;
  height: auto !important;
  min-height: auto !important;
  max-height: none !important;
  display: block !important;
  margin: 0 0 0.5rem 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:last-child,
.wp-block-navigation__responsive-container.is-menu-open li:last-child {
  margin-bottom: 0 !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
.wp-block-navigation__responsive-container.is-menu-open li a {
  width: 100% !important;
  height: auto !important;
  min-height: 50px !important;
  max-height: none !important;
  padding: 0.875rem 1rem !important;
  border: 2px solid #5a2b99 !important;
  border-radius: 4px;
  font-size: 14pt !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  box-sizing: border-box !important;
}

@media (max-width: 480px) {
  .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
  .wp-block-navigation__responsive-container.is-menu-open li a {
    font-size: 13pt !important;
    padding: 0.75rem 0.875rem !important;
    min-height: 45px !important;
  }
}

/* Mobile menu colors - use same rotation with solid backgrounds */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1),
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(1) {
  background-color: #af7dff !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1) a,
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(1) a {
  background-color: #af7dff !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2),
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(2) {
  background-color: #ffaf7d !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2) a,
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(2) a {
  background-color: #ffaf7d !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3),
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(3) {
  background-color: #7dffaf !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3) a,
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(3) a {
  background-color: #7dffaf !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4),
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(4) {
  background-color: #cdff7d !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4) a,
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(4) a {
  background-color: #cdff7d !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5),
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(5) {
  background-color: #f07dff !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5) a,
.wp-block-navigation__responsive-container.is-menu-open li:nth-child(5) a {
  background-color: #f07dff !important;
}

/* Dark mode mobile menu */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a {
    border-color: #3a2055 !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1),
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(1) {
    background-color: #6b4a9f !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1) a,
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(1) a {
    background-color: #6b4a9f !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2),
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(2) {
    background-color: #9f6b4a !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2) a,
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(2) a {
    background-color: #9f6b4a !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3),
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(3) {
    background-color: #4a9f6b !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3) a,
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(3) a {
    background-color: #4a9f6b !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4),
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(4) {
    background-color: #7a9f4a !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4) a,
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(4) a {
    background-color: #7a9f4a !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5),
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(5) {
    background-color: #9f4a9f !important;
  }
  
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5) a,
  :root:not([data-theme="light"]) .wp-block-navigation__responsive-container.is-menu-open li:nth-child(5) a {
    background-color: #9f4a9f !important;
  }
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item a,
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li a {
  border-color: #3a2055 !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1),
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(1) {
  background-color: #6b4a9f !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(1) a,
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(1) a {
  background-color: #6b4a9f !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2),
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(2) {
  background-color: #9f6b4a !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(2) a,
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(2) a {
  background-color: #9f6b4a !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3),
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(3) {
  background-color: #4a9f6b !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(3) a,
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(3) a {
  background-color: #4a9f6b !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4),
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(4) {
  background-color: #7a9f4a !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(4) a,
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(4) a {
  background-color: #7a9f4a !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5),
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(5) {
  background-color: #9f4a9f !important;
}

[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item:nth-child(5) a,
[data-theme="dark"] .wp-block-navigation__responsive-container.is-menu-open li:nth-child(5) a {
  background-color: #9f4a9f !important;
}

/* =============================================================================
   ACCESSIBILITY
   ============================================================================= */

.screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

/* Focus styles */
a:focus,
button:focus {
  outline: 2px solid var(--color-1);
  outline-offset: 2px;
}

/* Smooth scroll */
html {
  scroll-behavior: smooth;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* =============================================================================
   LOGO STYLING
   ============================================================================= */

.wp-block-site-logo {
  display: flex;
  align-items: center;
  margin: 0;
  padding: 0 1.5rem;
}

.wp-block-site-logo a {
  display: block;
  line-height: 0;
}

.wp-block-site-logo img,
.site-logo-img {
  height: 40px;
  width: auto;
  display: block;
  max-width: 100%;
}

/* Responsive logo sizing */
@media (max-width: 767px) {
  .wp-block-site-logo img,
  .site-logo-img {
    height: auto;
    max-height: 32px;
    max-width: 200px;
  }
}

@media (max-width: 480px) {
  .wp-block-site-logo img,
  .site-logo-img {
    max-height: 28px;
    max-width: 160px;
  }
}

/* =============================================================================
   COMMENTS STYLING
   ============================================================================= */

.colorblock-comments {
  margin-top: 4rem;
}

.wp-block-comments-title,
.wp-block-post-comments-form h3 {
  color: var(--color-contrast);
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 2rem;
}

/* Individual comment blocks with rotating colors */
.colorblock-comment {
  padding: 2rem;
  margin-bottom: 1.5rem;
  border-radius: 0;
  transition: transform 0.2s ease;
}

/* Color rotation for comments */
.wp-block-comment-template > li:nth-child(5n+1) .colorblock-comment {
  background-color: var(--color-1);
  color: var(--color-on-vibrant);
}

.wp-block-comment-template > li:nth-child(5n+2) .colorblock-comment {
  background-color: var(--color-2);
  color: var(--color-on-vibrant);
}

.wp-block-comment-template > li:nth-child(5n+3) .colorblock-comment {
  background-color: var(--color-3);
  color: var(--color-on-vibrant);
}

.wp-block-comment-template > li:nth-child(5n+4) .colorblock-comment {
  background-color: var(--color-4);
  color: var(--color-on-vibrant);
}

.wp-block-comment-template > li:nth-child(5n+5) .colorblock-comment {
  background-color: var(--color-5);
  color: var(--color-on-vibrant);
}

/* Comment author and meta */
.colorblock-comment .wp-block-comment-author-name,
.colorblock-comment .wp-block-comment-author-name a {
  color: var(--color-on-vibrant) !important;
  font-weight: 700;
  font-size: 1.1rem;
  text-decoration: none;
}

.colorblock-comment .wp-block-comment-date,
.colorblock-comment .wp-block-comment-date a {
  color: var(--color-on-vibrant) !important;
  opacity: 0.8;
  font-size: 0.875rem;
  text-decoration: none;
}

/* Comment content */
.colorblock-comment .wp-block-comment-content p {
  color: var(--color-on-vibrant);
  line-height: 1.6;
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}

/* Comment reply link */
.colorblock-comment .wp-block-comment-reply-link a {
  color: var(--color-on-vibrant) !important;
  text-decoration: underline;
  font-size: 0.875rem;
  opacity: 0.9;
  transition: opacity 0.2s ease;
}

.colorblock-comment .wp-block-comment-reply-link a:hover {
  opacity: 1;
}

/* Avatar styling */
.colorblock-comment .wp-block-avatar img {
  border-radius: 50%;
  border: 3px solid var(--color-on-vibrant);
}

/* Comment form */
.wp-block-post-comments-form {
  margin-top: 3rem;
  padding: 2rem;
  background-color: var(--color-1);
  border-radius: 0;
}

.wp-block-post-comments-form h3 {
  color: var(--color-on-vibrant) !important;
}

.wp-block-post-comments-form label {
  color: var(--color-on-vibrant);
  font-weight: 600;
  display: block;
  margin-bottom: 0.5rem;
}

.wp-block-post-comments-form input[type="text"],
.wp-block-post-comments-form input[type="email"],
.wp-block-post-comments-form input[type="url"],
.wp-block-post-comments-form textarea {
  width: 100%;
  padding: 0.75rem;
  border: 2px solid var(--color-on-vibrant);
  background-color: rgba(255, 255, 255, 0.9);
  color: #1a1a1a;
  border-radius: 4px;
  font-family: inherit;
  font-size: 1rem;
  margin-bottom: 1rem;
}

.wp-block-post-comments-form input[type="text"]:focus,
.wp-block-post-comments-form input[type="email"]:focus,
.wp-block-post-comments-form input[type="url"]:focus,
.wp-block-post-comments-form textarea:focus {
  outline: none;
  border-color: var(--color-on-vibrant);
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.1);
}

.wp-block-post-comments-form input[type="submit"],
.wp-block-post-comments-form button[type="submit"] {
  background-color: var(--color-on-vibrant);
  color: var(--color-1);
  padding: 0.75rem 2rem;
  border: none;
  border-radius: 4px;
  font-weight: 700;
  font-size: 1rem;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.wp-block-post-comments-form input[type="submit"]:hover,
.wp-block-post-comments-form button[type="submit"]:hover {
  opacity: 0.9;
}

/* Comments pagination */
.wp-block-comments-pagination {
  margin-top: 2rem;
  display: flex;
  gap: 1rem;
  justify-content: center;
}

.wp-block-comments-pagination a,
.wp-block-comments-pagination .page-numbers {
  color: var(--color-contrast);
  text-decoration: none;
  padding: 0.5rem 1rem;
  border-radius: 6px;
  transition: background-color 0.2s ease;
}

.wp-block-comments-pagination a:hover {
  background-color: var(--color-1);
  color: var(--color-on-vibrant);
}

.wp-block-comments-pagination .current {
  background-color: var(--color-1);
  color: var(--color-on-vibrant);
}

/* Remove default comment list styling */
.wp-block-comment-template {
  list-style: none;
  padding: 0;
  margin: 0;
}

/* =============================================================================
   MAILCHIMP FORM STYLING
   ============================================================================= */

/* Light mode - default styling */
#mc_embed_signup {
  background-color: rgba(255, 255, 255, 0.9);
  color: #1a1a1a;
  padding: 2rem;
  border-radius: 8px;
}

/* Dark mode - system preference */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) #mc_embed_signup {
    background-color: rgba(255, 255, 255, 0.1);
    color: var(--color-contrast);
  }
  
  :root:not([data-theme="light"]) #mc_embed_signup input[type="email"],
  :root:not([data-theme="light"]) #mc_embed_signup input[type="text"] {
    background-color: rgba(255, 255, 255, 0.15);
    color: var(--color-contrast);
    border-color: rgba(255, 255, 255, 0.3);
  }
  
  :root:not([data-theme="light"]) #mc_embed_signup label {
    color: var(--color-contrast);
  }
}

/* Dark mode - manual toggle */
[data-theme="dark"] #mc_embed_signup {
  background-color: rgba(255, 255, 255, 0.1);
  color: var(--color-contrast);
}

[data-theme="dark"] #mc_embed_signup input[type="email"],
[data-theme="dark"] #mc_embed_signup input[type="text"] {
  background-color: rgba(255, 255, 255, 0.15);
  color: var(--color-contrast);
  border-color: rgba(255, 255, 255, 0.3);
}

[data-theme="dark"] #mc_embed_signup label {
  color: var(--color-contrast);
}
