/*
Theme Name: The Open-Source Atelier
Theme URI:
Author: WPMaven
Author URI: https://webmaven.ai
Description: A website for wpmaven: Createa and run your businesses on autopilot. Built on open-source WordPress.
Version: 1.0.0
Text Domain: the_open_source_atelier
*/

:root {
  --color-primary-50: #fcf7f5;
  --color-primary-100: #f8ebe6;
  --color-primary-200: #f0d1c6;
  --color-primary-300: #e6b5a3;
  --color-primary-400: #d7886b;
  --color-primary-500: #C85A32;
  --color-primary-600: #aa4d2b;
  --color-primary-700: #8c3f23;
  --color-primary-800: #6e321c;
  --color-primary-900: #4c2213;
  --color-primary-950: #2c140b;
  --color-secondary-50: #f4f4f4;
  --color-secondary-100: #e4e4e4;
  --color-secondary-200: #c0c0c0;
  --color-secondary-300: #9a9a9a;
  --color-secondary-400: #5d5d5d;
  --color-secondary-500: #1E1E1E;
  --color-secondary-600: #1a1a1a;
  --color-secondary-700: #151515;
  --color-secondary-800: #111111;
  --color-secondary-900: #0b0b0b;
  --color-secondary-950: #070707;
  --color-accent-50: #f9f8f5;
  --color-accent-100: #f1ede6;
  --color-accent-200: #dfd6c5;
  --color-accent-300: #cbbda2;
  --color-accent-400: #ac966b;
  --color-accent-500: #8C6D31;
  --color-accent-600: #775d2a;
  --color-accent-700: #624c22;
  --color-accent-800: #4d3c1b;
  --color-accent-900: #352913;
  --color-accent-950: #1f180b;
  --color-neutral-50: #f4f4f4;
  --color-neutral-100: #e4e4e4;
  --color-neutral-200: #c0c0c0;
  --color-neutral-300: #9a9a9a;
  --color-neutral-400: #5d5d5d;
  --color-neutral-500: #1E1E1E;
  --color-neutral-600: #1a1a1a;
  --color-neutral-700: #151515;
  --color-neutral-800: #111111;
  --color-neutral-900: #0b0b0b;
  --color-neutral-950: #070707;
  --font-heading: 'DM Serif Display', sans-serif;
  --font-body: 'DM Mono', sans-serif;
  /* Alias variables for cross-pattern compatibility */
  --color-primary: #C85A32;
  --color-primary-rgb: 200, 90, 50;
  --color-primary-dark: #8c3f23;
  --color-primary-light: #f8ebe6;
  --color-primary-contrast: #ffffff;
  --color-secondary-contrast: #ffffff;
  --color-accent-contrast: #ffffff;
  --color-border: #c0c0c0;
  --color-text-on-dark: #fff;

  /* Role-based color tokens (M3 / DESIGN.md taxonomy) */
  --ds-color-primary: #C85A32;
  --ds-color-on-primary: #FDFBF7;
  --ds-color-primary-container: #F5EBE6;
  --ds-color-on-primary-container: #6E2E14;
  --ds-color-secondary: #1E1E1E;
  --ds-color-on-secondary: #FDFBF7;
  --ds-color-secondary-container: #EAE6DF;
  --ds-color-on-secondary-container: #1E1E1E;
  --ds-color-tertiary: #8C6D31;
  --ds-color-on-tertiary: #FDFBF7;
  --ds-color-tertiary-container: #F6F0E5;
  --ds-color-on-tertiary-container: #4A3712;
  --ds-surface-dim: #fdfbf7;
  --ds-surface-base: #FDFBF7;
  --ds-surface-bright: #f3f1ed;
  --ds-surface-container-lowest: #FDFBF7;
  --ds-surface-container-low: #f5f3f0;
  --ds-surface-container: #eeece8;
  --ds-surface-container-high: #e4e2de;
  --ds-surface-container-highest: #dad8d4;
  --ds-color-on-surface: #1E1E1E;
  --ds-color-on-surface-variant: #5C5852;
  --ds-surface-inverse: #1E1E1E;
  --ds-surface-on-inverse: #FDFBF7;
  --ds-outline-default: #D4C3B3;
  --ds-scrim: rgba(0, 0, 0, 0.5);
  --ds-color-error: #A83232;
  --ds-color-on-error: #FDFBF7;
  --ds-color-error-container: #F7ECEB;
  --ds-color-on-error-container: #5C1A1A;
  --ds-color-success: #2A6B4E;
  --ds-color-on-success: #FDFBF7;
  --ds-color-success-container: #EBF5F0;
  --ds-color-on-success-container: #123324;
  --ds-color-warning: #8C5800;
  --ds-color-on-warning: #FDFBF7;
  --ds-color-warning-container: #F7F2E8;
  --ds-color-on-warning-container: #4D3305;
  --ds-color-info: #2B5876;
  --ds-color-on-info: #FDFBF7;
  --ds-color-info-container: #EBF0F5;
  --ds-color-on-info-container: #10283B;

  /* Typography role tokens */
  --ds-typography-code-font-family: 'JetBrains Mono', ui-monospace, monospace;
  --ds-typography-code-font-size: 0.9375rem;
  --ds-typography-code-font-weight: 400;
  --ds-typography-code-line-height: 1.55;
  --ds-typography-body-lg-font-family: 'DM Mono', sans-serif;
  --ds-typography-body-lg-font-size: 1.125rem;
  --ds-typography-body-lg-font-weight: 400;
  --ds-typography-body-lg-line-height: 1.65;
  --ds-typography-body-md-font-family: 'DM Mono', sans-serif;
  --ds-typography-body-md-font-size: 1rem;
  --ds-typography-body-md-font-weight: 400;
  --ds-typography-body-md-line-height: 1.6;
  --ds-typography-body-sm-font-family: 'DM Mono', sans-serif;
  --ds-typography-body-sm-font-size: 0.9375rem;
  --ds-typography-body-sm-font-weight: 400;
  --ds-typography-body-sm-line-height: 1.55;
  --ds-typography-caption-font-family: 'DM Mono', sans-serif;
  --ds-typography-caption-font-size: 0.8125rem;
  --ds-typography-caption-font-weight: 400;
  --ds-typography-caption-line-height: 1.4;
  --ds-typography-label-lg-font-family: 'DM Mono', sans-serif;
  --ds-typography-label-lg-font-size: 0.9375rem;
  --ds-typography-label-lg-font-weight: 500;
  --ds-typography-label-lg-line-height: 1.4;
  --ds-typography-label-lg-letter-spacing: 0.01em;
  --ds-typography-label-md-font-family: 'DM Mono', sans-serif;
  --ds-typography-label-md-font-size: 0.875rem;
  --ds-typography-label-md-font-weight: 500;
  --ds-typography-label-md-line-height: 1.4;
  --ds-typography-label-md-letter-spacing: 0.01em;
  --ds-typography-label-sm-font-family: 'DM Mono', sans-serif;
  --ds-typography-label-sm-font-size: 0.75rem;
  --ds-typography-label-sm-font-weight: 500;
  --ds-typography-label-sm-line-height: 1.35;
  --ds-typography-label-sm-letter-spacing: 0.04em;
  --ds-typography-title-lg-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-title-lg-font-size: 1.375rem;
  --ds-typography-title-lg-font-weight: 600;
  --ds-typography-title-lg-line-height: 1.3;
  --ds-typography-title-md-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-title-md-font-size: 1.125rem;
  --ds-typography-title-md-font-weight: 600;
  --ds-typography-title-md-line-height: 1.35;
  --ds-typography-title-sm-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-title-sm-font-size: 1rem;
  --ds-typography-title-sm-font-weight: 600;
  --ds-typography-title-sm-line-height: 1.4;
  --ds-typography-display-lg-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-display-lg-font-size: clamp(3.5rem, 6vw, 6rem);
  --ds-typography-display-lg-font-weight: 700;
  --ds-typography-display-lg-line-height: 1;
  --ds-typography-display-lg-letter-spacing: -0.03em;
  --ds-typography-display-md-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-display-md-font-size: clamp(2.5rem, 5vw, 4.5rem);
  --ds-typography-display-md-font-weight: 700;
  --ds-typography-display-md-line-height: 1.05;
  --ds-typography-display-md-letter-spacing: -0.02em;
  --ds-typography-display-sm-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-display-sm-font-size: clamp(2rem, 4vw, 3.5rem);
  --ds-typography-display-sm-font-weight: 700;
  --ds-typography-display-sm-line-height: 1.1;
  --ds-typography-display-sm-letter-spacing: -0.02em;
  --ds-typography-headline-lg-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-headline-lg-font-size: clamp(1.75rem, 3vw, 2.5rem);
  --ds-typography-headline-lg-font-weight: 600;
  --ds-typography-headline-lg-line-height: 1.15;
  --ds-typography-headline-lg-letter-spacing: -0.01em;
  --ds-typography-headline-md-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-headline-md-font-size: clamp(1.5rem, 2.5vw, 2rem);
  --ds-typography-headline-md-font-weight: 600;
  --ds-typography-headline-md-line-height: 1.2;
  --ds-typography-headline-sm-font-family: 'DM Serif Display', sans-serif;
  --ds-typography-headline-sm-font-size: clamp(1.25rem, 2vw, 1.625rem);
  --ds-typography-headline-sm-font-weight: 600;
  --ds-typography-headline-sm-line-height: 1.25;

  /* Named spacing scale */
  --ds-spacing-lg: 1.5rem;
  --ds-spacing-md: 1rem;
  --ds-spacing-sm: 0.75rem;
  --ds-spacing-xl: 2rem;
  --ds-spacing-xs: 0.5rem;
  --ds-spacing-xxl: 3rem;
  --ds-spacing-xxs: 0.25rem;
  --ds-spacing-section: 6rem;

  /* Named radius scale */
  --ds-radius-lg: 0.75rem;
  --ds-radius-md: 0.5rem;
  --ds-radius-sm: 0.375rem;
  --ds-radius-xl: 1rem;
  --ds-radius-xs: 0.25rem;
  --ds-radius-pill: 9999px;

  /* Elevation tokens */
  --ds-elevation-flat-tone: var(--ds-surface-surface);
  --ds-elevation-raised-tone: var(--ds-surface-container);
  --ds-elevation-raised-shadow: 1px 1px 0px 0px #1E1E1E;
  --ds-elevation-overlay-tone: var(--ds-surface-container-high);
  --ds-elevation-overlay-shadow: 2px 2px 0px 0px #1E1E1E;
  --ds-elevation-modal-tone: var(--ds-surface-container-high);
  --ds-elevation-modal-shadow: 4px 4px 0px 0px #1E1E1E;
  --ds-elevation-popover-tone: var(--ds-surface-container-high);
  --ds-elevation-popover-shadow: 2px 2px 0px 0px #1E1E1E;
  --ds-shadow-as-border: 0 0 0 1px #D4C3B3;

  /* M3 motion durations */
  --ds-motion-duration-short1: 50ms;
  --ds-motion-duration-short2: 100ms;
  --ds-motion-duration-short3: 120ms;
  --ds-motion-duration-short4: 150ms;
  --ds-motion-duration-medium1: 200ms;
  --ds-motion-duration-medium2: 250ms;
  --ds-motion-duration-medium3: 280ms;
  --ds-motion-duration-medium4: 300ms;
  --ds-motion-duration-long1: 350ms;
  --ds-motion-duration-long2: 380ms;
  --ds-motion-duration-long3: 400ms;
  --ds-motion-duration-long4: 450ms;
  --ds-motion-duration-extra-long1: 500ms;
  --ds-motion-duration-extra-long2: 600ms;
  --ds-motion-duration-extra-long3: 700ms;
  --ds-motion-duration-extra-long4: 800ms;

  /* M3 easing tokens */
  --ds-motion-easing-standard: cubic-bezier(0.2, 0.8, 0.2, 1);
  --ds-motion-easing-standard-decelerate: cubic-bezier(0, 0, 0.2, 1);
  --ds-motion-easing-standard-accelerate: cubic-bezier(0.3, 0, 1, 1);
  --ds-motion-easing-emphasized: cubic-bezier(0.3, 0, 0, 1);
  --ds-motion-easing-emphasized-decelerate: cubic-bezier(0.05, 0.7, 0.1, 1);
  --ds-motion-easing-emphasized-accelerate: cubic-bezier(0.3, 0, 0.8, 0.15);
  --ds-motion-easing-linear: linear;

  /* Focus tokens */
  --ds-focus-color: #C85A32;
  --ds-focus-width: 2px;
  --ds-focus-offset: 2px;
  --ds-focus-ring: 0 0 0 2px #C85A32, 0 0 0 4px rgba(200, 90, 50, 0.25);

  /* Z-index scale */
  --ds-z-modal: 1300;
  --ds-z-toast: 1500;
  --ds-z-sticky: 1100;
  --ds-z-popover: 1400;
  --ds-z-tooltip: 1600;
  --ds-z-dropdown: 1000;

  /* Breakpoints */
  --ds-breakpoint-wide: 1920px;
  --ds-breakpoint-mobile: 768px;
  --ds-breakpoint-tablet: 1024px;
  --ds-breakpoint-desktop: 1440px;
}

/* ==========================================================================
   Content Styles - Required for page content sections
   ========================================================================== */

/* ==========================================================================
   Baseline Styles — resets, safety, WordPress compatibility
   All creative/component styles are generated by the LLM per theme.
   ========================================================================== */

/* Global Reset */
html, body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}

/* Image Safety — prevents overflow in any context */
img {
  max-width: 100%;
  height: auto;
}

section img,
article img {
  max-width: 100%;
  height: auto;
}


/* ==========================================================================
   WordPress Core Styles - Search, Posts, Comments
   ========================================================================== */

/* ==========================================================================
   WordPress Core - Search, Posts, Comments
   Same variables as content sections for theme consistency
   ========================================================================== */

/* Search Form (get_search_form) */
.search-form {
  display: flex;
  gap: var(--space-sm, var(--spacing-sm, 0.5rem));
  max-width: 100%;
  margin: var(--space-md, var(--spacing-md, 1rem)) 0;
  font-family: var(--font-body, inherit);
}

.search-form label {
  flex: 1;
  min-width: 0;
  margin: 0;
}

.search-form .search-field {
  width: 100%;
  padding: 0.625rem 1rem;
  font-size: 1rem;
  font-family: inherit;
  line-height: 1.5;
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.15));
  border-radius: var(--radius-md, var(--border-radius, 0.5rem));
  background: var(--color-surface, var(--color-neutral-100, #fff));
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
  transition: border-color 0.2s, box-shadow 0.2s;
}

.search-form .search-field:focus {
  outline: none;
  border-color: var(--color-primary, var(--color-primary-500, #3b82f6));
  box-shadow: 0 0 0 3px var(--color-primary-light, rgba(59, 130, 246, 0.2));
}

.search-form .search-submit {
  padding: 0.625rem 1.25rem;
  font-size: 1rem;
  font-weight: 600;
  font-family: inherit;
  color: var(--color-primary-contrast, #fff);
  background: var(--color-primary, var(--color-primary-500, #3b82f6));
  border: none;
  border-radius: var(--radius-md, var(--border-radius, 0.5rem));
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
  flex-shrink: 0;
}

.search-form .search-submit:hover {
  background: var(--color-primary-dark, var(--color-primary-600, #2563eb));
  transform: translateY(-1px);
}

/* Post List / Archive / Loop */
.posts-list,
.site-main .posts {
  display: grid;
  gap: var(--space-xl, var(--spacing-xl, 2.5rem));
}

.post,
.hentry {
  padding-bottom: var(--space-xl, var(--spacing-xl, 2.5rem));
  border-bottom: 1px solid var(--color-border, rgba(0, 0, 0, 0.08));
}

.post-thumbnail,
.entry-thumbnail {
  margin-bottom: var(--space-md, var(--spacing-md, 1rem));
  border-radius: var(--radius-md, var(--border-radius, 0.5rem));
  overflow: hidden;
}

.post-thumbnail img,
.entry-thumbnail img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
}

.entry-title {
  font-size: clamp(1.25rem, 2.5vw, 1.75rem);
  font-weight: 700;
  font-family: var(--font-heading, inherit);
  line-height: 1.3;
  margin: 0 0 var(--space-sm, var(--spacing-sm, 0.5rem));
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

.entry-title a {
  color: inherit;
  text-decoration: none;
}

.entry-title a:hover {
  color: var(--color-primary, var(--color-primary-500, #3b82f6));
}

.entry-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm, var(--spacing-sm, 0.5rem)) var(--space-md, var(--spacing-md, 1rem));
  font-size: 0.875rem;
  color: var(--color-text-secondary, #6b7280);
}

.entry-meta a {
  color: inherit;
  text-decoration: none;
}

.entry-meta a:hover {
  color: var(--color-primary, var(--color-primary-500, #3b82f6));
}

.entry-content {
  font-size: 1rem;
  font-family: var(--font-body, inherit);
  line-height: 1.7;
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

.entry-content p {
  margin-bottom: var(--space-md, var(--spacing-md, 1rem));
}

.entry-content a {
  color: var(--color-primary, var(--color-primary-500, #3b82f6));
}

.entry-content a:hover {
  text-decoration: underline;
}

.read-more,
.more-link {
  display: inline-block;
  margin-top: var(--space-sm, var(--spacing-sm, 0.5rem));
  font-weight: 600;
  color: var(--color-primary, var(--color-primary-500, #3b82f6));
}

/* Pagination */
.posts-navigation,
.post-navigation,
.pagination {
  margin-top: var(--space-2xl, var(--spacing-2xl, 3rem));
  padding-top: var(--space-xl, var(--spacing-xl, 2rem));
  border-top: 1px solid var(--color-border, rgba(0, 0, 0, 0.08));
}

.nav-links {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm, var(--spacing-sm, 0.5rem));
  justify-content: center;
}

.nav-links a {
  padding: 0.5rem 1rem;
  font-weight: 500;
  text-decoration: none;
  border-radius: var(--radius-md, var(--border-radius, 0.5rem));
  background: var(--color-surface, var(--color-neutral-100, #f3f4f6));
  color: var(--color-heading, var(--color-neutral-900, #374151));
  transition: background 0.2s, color 0.2s;
}

.nav-links a:hover {
  background: var(--color-primary, var(--color-primary-500, #3b82f6));
  color: var(--color-primary-contrast, #fff);
}

.nav-links .current {
  background: var(--color-primary, var(--color-primary-500, #3b82f6));
  color: var(--color-primary-contrast, #fff);
}

.no-results,
.no-posts {
  padding: var(--space-2xl, var(--spacing-2xl, 3rem));
  text-align: center;
  color: var(--color-text-secondary, #6b7280);
}

.no-results .page-title {
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

/* Comments */
.comments-area {
  margin-top: var(--space-2xl, var(--spacing-2xl, 3rem));
  padding-top: var(--space-2xl, var(--spacing-2xl, 3rem));
  border-top: 1px solid var(--color-border, rgba(0, 0, 0, 0.08));
}

.comments-title {
  font-size: clamp(1.25rem, 2.5vw, 1.5rem);
  font-weight: 700;
  font-family: var(--font-heading, inherit);
  margin-bottom: var(--space-lg, var(--spacing-lg, 2rem));
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

.comment-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-2xl, var(--spacing-2xl, 3rem));
}

.comment-list .children {
  list-style: none;
  padding-left: var(--space-xl, var(--spacing-xl, 2rem));
  margin-top: var(--space-md, var(--spacing-md, 1rem));
  border-left: 3px solid var(--color-border, rgba(0, 0, 0, 0.1));
}

.comment {
  padding: var(--space-lg, var(--spacing-lg, 2rem)) 0;
  border-bottom: 1px solid var(--color-border, rgba(0, 0, 0, 0.06));
}

.comment-author .fn {
  font-style: normal;
  font-weight: 600;
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

.comment-metadata {
  font-size: 0.875rem;
  color: var(--color-text-secondary, #6b7280);
  margin-bottom: var(--space-md, var(--spacing-md, 1rem));
}

.comment-metadata a:hover {
  color: var(--color-primary, var(--color-primary-500, #3b82f6));
}

.comment-content {
  font-family: var(--font-body, inherit);
  line-height: 1.6;
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

.comment-reply-link {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary, var(--color-primary-500, #3b82f6));
}

/* Comment Form */
#respond,
.comment-respond {
  margin-top: var(--space-2xl, var(--spacing-2xl, 3rem));
  padding: var(--space-xl, var(--spacing-xl, 2rem));
  background: var(--color-surface, var(--color-neutral-100, #f9fafb));
  border-radius: var(--radius-lg, var(--border-radius, 0.75rem));
}

.comment-reply-title {
  font-size: clamp(1.125rem, 2vw, 1.375rem);
  font-weight: 700;
  font-family: var(--font-heading, inherit);
  margin-bottom: var(--space-lg, var(--spacing-lg, 2rem));
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
}

.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  padding: 0.625rem 1rem;
  font-size: 1rem;
  font-family: var(--font-body, inherit);
  border: 1px solid var(--color-border, rgba(0, 0, 0, 0.15));
  border-radius: var(--radius-md, var(--border-radius, 0.5rem));
  background: var(--color-surface, #fff);
  color: var(--color-heading, var(--color-neutral-900, #1a1a2e));
  margin-bottom: var(--space-md, var(--spacing-md, 1rem));
}

.comment-form input:focus,
.comment-form textarea:focus {
  outline: none;
  border-color: var(--color-primary, var(--color-primary-500, #3b82f6));
  box-shadow: 0 0 0 3px var(--color-primary-light, rgba(59, 130, 246, 0.2));
}

.comment-form .submit {
  padding: 0.625rem 1.5rem;
  font-size: 1rem;
  font-weight: 600;
  font-family: inherit;
  color: var(--color-primary-contrast, #fff);
  background: var(--color-primary, var(--color-primary-500, #3b82f6));
  border: none;
  border-radius: var(--radius-md, var(--border-radius, 0.5rem));
  cursor: pointer;
  transition: background 0.2s, transform 0.2s;
}

.comment-form .submit:hover {
  background: var(--color-primary-dark, var(--color-primary-600, #2563eb));
  transform: translateY(-1px);
}

@media (max-width: 768px) {
  .search-form { flex-direction: column; }
  .search-form .search-submit { width: 100%; }
  .comment-list .children { padding-left: var(--space-md, var(--spacing-md, 1rem)); }
}


/* ==========================================================================
   Image Safety - Prevents image overflow
   ========================================================================== */

/* ==========================================================================
   IMAGE SAFETY SYSTEM
   Prevents image overflow and layout breaking
   ========================================================================== */

/* Base image safety */
img {
  max-width: 100%;
  height: auto;
  display: block;
}

/* Figure/media containers */
figure {
  margin: 0;
  overflow: hidden;
}

/* WordPress block images */
.wp-block-image {
  overflow: hidden;
}

.wp-block-image img {
  max-width: 100%;
  height: auto;
}

/* Cover blocks */
.wp-block-cover {
  overflow: hidden;
}

.wp-block-cover img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

/* Media & text blocks */
.wp-block-media-text {
  overflow: hidden;
}

.wp-block-media-text__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Gallery images */
.wp-block-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ==========================================================================
   Brand logo floor (plan 47, deterministic) - an uploaded SVG custom_logo has
   NO intrinsic display size in WordPress, so wp_get_attachment_image() / the
   the_custom_logo() <img> would render at its raw 512px (giant) or collapse to
   nothing. Constrain it to a header-sized mark; theme.css can override.
   ========================================================================== */
.site-logo-mark,
.custom-logo {
  display: block;
  width: auto;
  height: clamp(28px, 4vw, 44px);
  max-width: 200px;
  object-fit: contain;
}
/* Header lockup: the home link wraps the mark + the .site-title — make it a
   centered inline-flex so the icon and wordmark line up vertically. Zero
   specificity (:where) so the holistic theme.css can fully restyle the lockup. */
:where(a:has(.site-logo-mark)) {
  display: inline-flex;
  align-items: center;
  gap: 0.5em;
}

/* ==========================================================================
   Flex-safety floor (deterministic) - generated content frequently sets flex
   properties (flex-direction / align-items / justify-content) on an element
   WITHOUT display:flex, which is inert and silently collapses the row to
   stacked blocks. Force flex ONLY when no display is set inline (:not match)
   and at zero specificity, so any real class/inline display wins untouched.
   ========================================================================== */
:where(
  [style*="flex-direction"]:not([style*="display"]),
  [style*="justify-content"]:not([style*="display"]),
  [style*="align-items"]:not([style*="display"])
) {
  display: flex;
}

/* ==========================================================================
   Plugin + Core Surface Baseline (deterministic) - style.css loads AFTER
   plugin stylesheets and BEFORE theme.css, so this beats plugin defaults
   while any theme.css rule overrides it (plan 45: floor guarantees, the
   theme beautifies).
   ========================================================================== */

/* ── Shared button recipe: every plugin/core submit + WC action button ───── */
.woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt,
.woocommerce .single_add_to_cart_button, .woocommerce .checkout-button,
.woocommerce #place_order, .woocommerce #respond input#submit,
.wpforms-container .wpforms-form button[type="submit"], .wpforms-container .wpforms-form .wpforms-submit,
.wpcf7-form input[type="submit"], .wpcf7-form button[type="submit"],
.comment-form input[type="submit"] {
  background: var(--ds-color-primary, #1f2937);
  color: var(--ds-color-on-primary, #ffffff);
  border: 0;
  border-radius: var(--ds-radius-md, 8px);
  padding: 0.75em 1.5em;
  font: inherit;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  transition: filter var(--ds-motion-duration-medium2, 0.2s) var(--ds-motion-easing-standard, ease);
}
.woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover,
.woocommerce .single_add_to_cart_button:hover, .woocommerce .checkout-button:hover,
.woocommerce #place_order:hover,
.wpforms-container .wpforms-form button[type="submit"]:hover,
.wpcf7-form input[type="submit"]:hover,
.comment-form input[type="submit"]:hover {
  background: var(--ds-color-primary, #1f2937);
  color: var(--ds-color-on-primary, #ffffff);
  filter: brightness(1.12);
}

/* ── WooCommerce: catalog grid (kills the legacy float layout) ───────────── */
.woocommerce ul.products, .woocommerce-page ul.products {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(16rem, 1fr));
  gap: var(--ds-spacing-lg, 1.5rem);
  margin: 0 0 var(--ds-spacing-lg, 1.5rem);
  padding: 0;
  list-style: none;
}
/* WooCommerce ships a clearfix .woocommerce ul.products::before/::after
   (content:" ";display:table). Under display:grid those pseudo-elements
   become real grid items — the ::before takes the first cell and shoves every
   product card one column to the right. Remove them. (style.css loads after
   woocommerce.css at equal specificity, so this wins.) */
.woocommerce ul.products::before, .woocommerce ul.products::after,
.woocommerce-page ul.products::before, .woocommerce-page ul.products::after {
  content: none;
  display: none;
}
.woocommerce ul.products li.product, .woocommerce-page ul.products li.product {
  float: none;
  width: auto;
  margin: 0;
  display: flex;
  flex-direction: column;
}
.woocommerce ul.products li.product img {
  width: 100%;
  height: auto;
  border-radius: var(--ds-radius-md, 8px);
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 1.05em;
  color: var(--ds-color-on-surface, inherit);
  margin: 0.75em 0 0.25em;
}
.woocommerce ul.products li.product .price {
  color: var(--ds-color-primary, inherit);
  font-weight: 600;
  margin-bottom: 0.75em;
}
.woocommerce ul.products li.product .button { margin-top: auto; align-self: flex-start; }
.woocommerce span.onsale {
  background: var(--ds-color-primary, #1f2937);
  color: var(--ds-color-on-primary, #ffffff);
  border-radius: 999px;
  padding: 0.25em 0.9em;
  min-height: 0;
  min-width: 0;
  line-height: 1.6;
}
.woocommerce .woocommerce-result-count { color: var(--ds-color-on-surface, inherit); opacity: 0.75; }
.woocommerce .woocommerce-ordering select {
  font: inherit;
  color: var(--ds-color-on-surface, inherit);
  background: var(--ds-surface-container, #ffffff);
  border: 1px solid var(--ds-outline-default, rgba(127, 127, 127, 0.4));
  border-radius: var(--ds-radius-md, 8px);
  padding: 0.4em 0.75em;
}

/* ── WooCommerce: page framing (functions.php wraps WC content in .container) ─ */
/* Vertical breathing room for the wrapped shop/single content. */
.wm-woo-content { padding-block: var(--ds-spacing-xxl, 3rem); }
/* Cart / Checkout / Account pages have no theme .container wrapper, so center
   and constrain them. Covers BOTH the classic shortcode (.woocommerce) and the
   block Cart/Checkout (.wp-block-woocommerce-*, which render full-bleed
   'alignwide' by default). */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce,
.wp-block-woocommerce-cart,
.wp-block-woocommerce-checkout {
  max-width: 75rem;
  margin-inline: auto;
  padding-block: var(--ds-spacing-xxl, 3rem);
  padding-inline: var(--ds-spacing-lg, 1.5rem);
}

/* ── WooCommerce: single product ─────────────────────────────────────────── */
/* Two-column gallery | summary (the default float layout often collapses to a
   stacked full-width block once the theme touches it). Tabs + related/upsells
   span full width below. Collapses to one column on phones. */
.woocommerce div.product {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--ds-spacing-xl, 2rem);
  align-items: start;
}
.woocommerce div.product .woocommerce-product-gallery,
.woocommerce div.product .summary {
  float: none;
  width: auto;
  margin: 0;
}
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related,
.woocommerce div.product .upsells {
  grid-column: 1 / -1;
}
@media (max-width: 768px) {
  .woocommerce div.product { grid-template-columns: 1fr; }
}
.woocommerce div.product p.price, .woocommerce div.product span.price {
  color: var(--ds-color-primary, inherit);
  font-size: 1.35em;
}
.woocommerce div.product .woocommerce-product-gallery img { border-radius: var(--ds-radius-md, 8px); }
.woocommerce div.product .quantity .qty {
  font: inherit;
  color: var(--ds-color-on-surface, inherit);
  background: var(--ds-surface-container, #ffffff);
  border: 1px solid var(--ds-outline-default, rgba(127, 127, 127, 0.4));
  border-radius: var(--ds-radius-md, 8px);
  padding: 0.55em 0.5em;
  width: 4.5em;
  text-align: center;
  -moz-appearance: textfield;
  appearance: textfield;
}
.woocommerce div.product .quantity .qty::-webkit-outer-spin-button,
.woocommerce div.product .quantity .qty::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  padding: 0;
  margin: 0 0 1em;
  border-bottom: 1px solid var(--ds-outline-variant, rgba(127, 127, 127, 0.25));
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-bottom: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: transparent;
  border: 0;
  border-radius: 0;
  margin: 0;
  padding: 0 1em 0 0;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after { display: none; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  color: var(--ds-color-on-surface, inherit);
  opacity: 0.7;
  padding: 0.6em 0.25em;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a {
  opacity: 1;
  border-bottom: 2px solid var(--ds-color-primary, currentColor);
}
.woocommerce .related.products > h2, .woocommerce .upsells.products > h2 {
  margin-bottom: 0.75em;
}

/* ── WooCommerce: cart / checkout tables + boxes ─────────────────────────── */
.woocommerce table.shop_table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid var(--ds-outline-variant, rgba(127, 127, 127, 0.25));
  border-radius: var(--ds-radius-md, 8px);
}
.woocommerce table.shop_table th, .woocommerce table.shop_table td {
  padding: 0.9em 1em;
  border: 0;
  border-top: 1px solid var(--ds-outline-variant, rgba(127, 127, 127, 0.25));
  background: transparent;
  color: var(--ds-color-on-surface, inherit);
}
.woocommerce table.shop_table thead th { border-top: 0; }
.woocommerce table.shop_table img { width: 64px; border-radius: var(--ds-radius-md, 8px); }
.woocommerce .cart_totals, .woocommerce-checkout #order_review,
.woocommerce-checkout #order_review_heading {
  background: var(--ds-surface-container, rgba(127, 127, 127, 0.06));
  border-radius: var(--ds-radius-md, 8px);
}
.woocommerce .cart_totals, .woocommerce-checkout #order_review { padding: var(--ds-spacing-lg, 1.5rem); }
.woocommerce-checkout #order_review_heading { padding: var(--ds-spacing-lg, 1.5rem) var(--ds-spacing-lg, 1.5rem) 0; }
.woocommerce form .form-row label { display: block; margin-bottom: 0.35em; color: var(--ds-color-on-surface, inherit); }
.woocommerce form .form-row { margin-bottom: 1em; }
.woocommerce form .form-row .woocommerce-input-wrapper { display: block; }
.woocommerce #payment {
  background: var(--ds-surface-container, rgba(127, 127, 127, 0.06));
  border-radius: var(--ds-radius-md, 8px);
}
.woocommerce #payment div.payment_box {
  background: var(--ds-surface-container-high, rgba(127, 127, 127, 0.12));
  color: var(--ds-color-on-surface, inherit);
}
.woocommerce #payment div.payment_box::before { display: none; }

/* ── WooCommerce: account ────────────────────────────────────────────────── */
.woocommerce-MyAccount-navigation ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.25em; }
.woocommerce-MyAccount-navigation li a {
  display: block;
  padding: 0.6em 1em;
  border-radius: var(--ds-radius-md, 8px);
  color: var(--ds-color-on-surface, inherit);
  text-decoration: none;
}
.woocommerce-MyAccount-navigation li.is-active a {
  background: var(--ds-color-primary, #1f2937);
  color: var(--ds-color-on-primary, #ffffff);
}

/* ── WooCommerce: notices ────────────────────────────────────────────────── */
.woocommerce-message, .woocommerce-info, .woocommerce-error {
  background: var(--ds-surface-container, rgba(127, 127, 127, 0.06));
  color: var(--ds-color-on-surface, inherit);
  border-top: 0;
  border-left: 4px solid var(--ds-color-primary, #1f2937);
  border-radius: var(--ds-radius-md, 8px);
  padding: 1em 1.25em 1em 3em;
}
.woocommerce-message::before, .woocommerce-info::before, .woocommerce-error::before { color: inherit; top: 1em; left: 1.1em; }
.woocommerce-message { border-left-color: #3a7d44; }
.woocommerce-error { border-left-color: #b3261e; }

/* ── WPForms (mirrors plugin selector shapes; theme.css still overrides) ─── */
.wpforms-container .wpforms-form .wpforms-field { padding: 0 0 1.1em; }
.wpforms-container .wpforms-form .wpforms-field-label {
  display: block;
  margin-bottom: 0.35em;
  font-weight: 600;
  color: var(--ds-color-on-surface, inherit);
}
.wpforms-container .wpforms-form .wpforms-field-sublabel,
.wpforms-container .wpforms-form .wpforms-field-description {
  color: var(--ds-color-on-surface, inherit);
  opacity: 0.7;
}
.wpforms-container .wpforms-form input[type="text"],
.wpforms-container .wpforms-form input[type="email"],
.wpforms-container .wpforms-form input[type="tel"],
.wpforms-container .wpforms-form input[type="url"],
.wpforms-container .wpforms-form input[type="number"],
.wpforms-container .wpforms-form textarea,
.wpforms-container .wpforms-form select {
  font: inherit;
  color: var(--ds-color-on-surface, inherit);
  background: var(--ds-surface-container, #ffffff);
  border: 1px solid var(--ds-outline-default, rgba(127, 127, 127, 0.4));
  border-radius: var(--ds-radius-md, 8px);
  padding: 0.65em 0.9em;
  max-width: 100%;
}
.wpforms-container .wpforms-confirmation-container-full {
  background: var(--ds-surface-container, rgba(127, 127, 127, 0.06));
  border: 1px solid var(--ds-outline-variant, rgba(127, 127, 127, 0.25));
  border-radius: var(--ds-radius-md, 8px);
  color: var(--ds-color-on-surface, inherit);
}

/* ── Core surfaces nothing else styles — zero specificity on purpose ─────── */
:where(.comment-list) { list-style: none; margin: 0 0 1.5em; padding: 0; display: grid; gap: 1em; }
:where(.comment-list .comment .comment-body) {
  background: var(--ds-surface-container, rgba(127, 127, 127, 0.06));
  border-radius: var(--ds-radius-md, 8px);
  padding: 1em 1.25em;
}
:where(.comment-list .comment-meta, .comment-list .comment-metadata) { opacity: 0.7; font-size: 0.9em; }
:where(.comment-respond, #respond) { margin-top: 1.5em; }
:where(.comment-reply-title, #reply-title) { font-size: 1.25em; margin-bottom: 0.75em; }
:where(.comment-form) { display: grid; gap: 0.9em; }
:where(.comment-form label) { display: block; margin-bottom: 0.3em; font-weight: 600; }
:where(.comment-form-cookies-consent) { display: flex; gap: 0.5em; align-items: baseline; }
:where(.comment-form-cookies-consent label) { display: inline; font-weight: 400; }
:where(.required-field-message, .comment-notes) { opacity: 0.7; font-size: 0.9em; }
:where(.nav-links, .woocommerce-pagination ul.page-numbers) { display: flex; flex-wrap: wrap; gap: 0.4em; justify-content: center; margin: 1.5em 0; }
:where(.page-numbers li) { list-style: none; margin: 0; }
:where(a.page-numbers, span.page-numbers) {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.4em;
  padding: 0.45em 0.7em;
  border: 1px solid var(--ds-outline-variant, rgba(127, 127, 127, 0.25));
  border-radius: var(--ds-radius-md, 8px);
  text-decoration: none;
  color: var(--ds-color-on-surface, inherit);
}
:where(span.page-numbers.current) {
  background: var(--ds-color-primary, #1f2937);
  color: var(--ds-color-on-primary, #ffffff);
  border-color: transparent;
}
:where(.search-form) { display: flex; gap: 0.5em; align-items: stretch; }
:where(.post-password-form input[type="password"]) { margin-inline: 0.5em; }


/* ==========================================================================
   Theme-Specific Styles - Add your custom styles below
   ========================================================================== */
