/*
Theme Name: Common Roots
Template: twentytwentyfour
Text Domain: crm-theme
Version: 1.0.0
*/

html, body {
  overflow-x: hidden;
  margin: 0;
  padding: 0;
}


*, *::before, *::after {
  box-sizing: border-box;
/* outline: 1px solid red !important; */
}

img, video, iframe {
  max-width: 100%;
  height: auto;
}

.cta-bottom {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%!important;
  box-shadow: 0 -2px 6px rgba(0,0,0,0.1);
  z-index: 9999;
  justify-content: center;
  margin: 0 !important;

  opacity: 0;
  transform: translateY(100%);
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.4s ease;
}

.cta-bottom.visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

:root :where(.is-layout-constrained) > * {
  margin-block-start: 0;
  margin-block-end: 0;
}

details {
	padding: 1em;
}

details p {
	padding-top: 0!important;
}

summary {
	font-size: 1.2em;
}

summary::after {
	margin-right: 15px!important;
}

.wp-block-button {
	font-variant-caps: all-small-caps;
}

@media only screen and (max-width: 480px) {
	.featured-text-block {
		font-size: 1.2em;
	}

	.mb-font-size-body {
		font-size: 1.2em;
	}

	.group-intro-block {
		position: relative;
	}

	.autumn-leaves-img {
		aspect-ratio: 1/1;
		object-fit: cover;
		position: absolute;
		top: -640px;
		right: -30px;
		max-width: 200px;
	}

	.hide-mobile {
		display: none!important;
	}

	.cta-bottom {
		padding: 0!important;
	}

  .cta-bottom-wrapper {
		width: 100%!important;
		padding: 0.6em!important;
	}

	.cta-bottom-title {
		font-size: 1em!important;
	}

	.cta-bottom-btn {
		width: 100%!important;
		font-size: 1.4em!important;
	}
}


/* Hide title in Gutenberg editor preview */
.editor-post-title {
  display: none !important;
}

.editor-visual-editor__post-title-wrapper {
    display: none !important;
}

main {
    margin-top: 0!important;
}

:where(.wp-site-blocks) > * {
    margin-top: 0;
}

.card {
	border-radius: 20px;
	box-shadow: 10px 10px 0px 0px rgba(234,221,213,1);
	background-color: white;
	padding: 40px;
}

.card--form {
	padding: 20px 40px;
	font-size: 1rem;
}

.card--form .helptext  {
	display: block;
	font-size: 0.8rem;
	margin-bottom: 0.7rem;
}

.card .input-wrapper {
	box-sizing: border-box;
	border: 1px solid #b2b2b2;
	margin-top: 0.3rem;
	padding: 0.6rem;
	width: 100%;
	border-radius: .33rem;
	color: inherit;
	cursor: text;
}

/* =========================================================
   COMMON ROOTS MONTESSORI — Mobile Styles
   Extends style.css — Twenty Twenty-Four child theme
   ========================================================= */


/* ---------------------------------------------------------
   1. MOBILE BASELINE (≤ 768px)
   --------------------------------------------------------- */

@media (max-width: 768px) {

  /* --- Layout & Spacing --------------------------------- */

	.has-global-padding {
		padding-right: 0;
		padding-left: 0;
	}	

	/* .wp-block-group {
    	padding-left: var(--wp--style--root--padding-left, 1.25rem) !important;
    	padding-right: var(--wp--style--root--padding-right, 1.25rem) !important;
	} */

  /* Stack columns on mobile */
  .wp-block-columns {
    flex-direction: column !important;
    gap: 1.5rem !important;
  }

  .wp-block-column {
    flex-basis: 100% !important;
    width: 100% !important;
  }

  /* --- Typography --------------------------------------- */

  h1, .wp-block-heading.has-x-large-font-size {
    font-size: clamp(1.75rem, 6vw, 2.5rem) !important;
  }

  h2, .wp-block-heading.has-large-font-size {
    font-size: clamp(1.4rem, 5vw, 2rem) !important;
  }

  h3 {
    font-size: clamp(1.15rem, 4vw, 1.5rem) !important;
  }

  p, li, .wp-block-paragraph {
    font-size: 1rem;
    line-height: 1.7;
  }

  /* --- Buttons ------------------------------------------ */

  .wp-block-button__link {
    padding: 0.75em 1.4em !important;
    font-size: 1rem !important;
    width: 100%;
    text-align: center;
    display: block;
  }

  .wp-block-buttons {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0.75rem !important;
  }

  /* --- Images & Media ----------------------------------- */

  .wp-block-image,
  .wp-block-cover {
    min-height: 220px !important;
  }

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

  /* --- Cards -------------------------------------------- */

  .card {
    padding: 24px 20px;
    border-radius: 14px;
    box-shadow: 6px 6px 0px 0px rgba(234, 221, 213, 1);
  }

  .card--form {
    padding: 16px 20px;
  }

  /* --- Spacers ------------------------------------------ */

  .wp-block-spacer {
    height: 2rem !important;
  }

  /* --- Tables ------------------------------------------- */

  .wp-block-table table {
    font-size: 0.875rem;
  }

  .wp-block-table td,
  .wp-block-table th {
    padding: 0.5em 0.75em;
  }

  /* --- Utility classes ---------------------------------- */

  .show-mobile  { display: block  !important; }
  .hide-mobile  { display: none   !important; }
  .text-center-mobile { text-align: center !important; }
  .full-width-mobile  { width: 100% !important; }
}


/* ---------------------------------------------------------
   2. SMALL MOBILE REFINEMENTS (≤ 480px)
   Already partially defined in style.css — additions only
   --------------------------------------------------------- */

@media (max-width: 480px) {
  .wp-block-button__link {
    font-size: 1.05rem !important;
  }

  .card {
    border-radius: 10px;
    padding: 20px 16px;
  }
}

/*------ HEADER ------*/

header .wp-block-group {
  padding: 0.5em 1em;
}

@media (min-width: 768px) {
  header .wp-block-group {
    padding: 0.8em 1em;
  }
}


@media (min-width: 768px) {
  header .wp-block-group {
    padding: 1em 2em;
  }
}

/* ---------------------------------------------------------
   GUTENBERG DEFAULT NAVIGATION
   Collapsible with sub-item accordion
   Targets .wp-block-navigation (core block)
   --------------------------------------------------------- */
/* .wp-block-navigation-submenu {
  border: 0!important;
} */

.wp-block-navigation-submenu li {
  background-color: #e5ebe8!important;
  padding: 0.1em 0 0.3em 0!important;
  margin:0!important;
}

@media (min-width: 950px) {
  .wp-block-navigation-submenu .wp-block-navigation-link a:hover {
    text-decoration: none;
    color: white;
    background-color: var(--wp--preset--color--orange-medium);
  } 
}

/* ---------------------------------------------------------
   MOBILE NAV — hamburger + overlay at 950px
   Desktop nav is left completely untouched above this point
   --------------------------------------------------------- */

/* Hide hamburger button on desktop */
.wp-block-navigation__responsive-container-open {
  display: none !important;
}

.wp-block-navigation__responsive-dialog {
  margin-top: 0!important;
}

@media (max-width: 950px) {
  /* Show hamburger on mobile */
  .wp-block-navigation__responsive-container-open {
    display: flex !important;
  }

  /* Hide the inline desktop nav list */
  .wp-block-navigation__responsive-container:not(.is-menu-open) {
    display: none !important;
  }

  /* Overlay container when open */
  .wp-block-navigation__responsive-container.is-menu-open {
    background-color: var(--wp--preset--color--base, #fff) !important;
    padding: 0.2rem 1.5rem 1rem 1.5rem !important;
    overflow-y: auto;
  }

  /* Close / hamburger button */
  .wp-block-navigation__responsive-container-close,
  .wp-block-navigation__responsive-container-open {
    color: var(--wp--preset--color--contrast, #1a1a1a) !important;
    padding: 0.5rem !important;
  }

  /* Nav list reset */
  .wp-block-navigation__responsive-container-content
  .wp-block-navigation__container {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    width: 100% !important;
    align-items: stretch !important;
  }

  /* Top-level nav items */
  .wp-block-navigation__responsive-container-content
  .wp-block-navigation-item {
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    width: 100% !important;
  }

  .wp-block-navigation__responsive-container-content
  .wp-block-navigation-item__content {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    padding: 1rem 0 !important;
    font-size: 1.1rem !important;
    font-weight: 500 !important;
    color: var(--wp--preset--color--contrast, #1a1a1a) !important;
    text-decoration: none !important;
    width: 100% !important;
  }

  .wp-block-navigation__responsive-container-content
  .wp-block-navigation-item__content:hover {
    color: var(--wp--preset--color--primary, #5c7a5c) !important;
  }

  /* -------------------------------------------------------
     Sub-menu: collapsible accordion
     ------------------------------------------------------- */

  /* Hide submenu by default */
  .wp-block-navigation__responsive-container-content
  .has-child
  .wp-block-navigation__submenu-container {
    display: none !important;
    flex-direction: column !important;
    padding: 0 0 0.5rem 1rem !important;
    background: transparent !important;
    position: static !important;
    min-width: unset !important;
    box-shadow: none !important;
    border: none !important;
    width: 100% !important;
  }


  .wp-block-navigation__responsive-container.is-menu-open:not(.disable-default-overlay) .wp-block-navigation__responsive-container-content {
    padding-top: 1em!important;
  }

  .wp-block-navigation__responsive-container-close {
    position: absolute;
    right: -8px;
    top: 1.5em;
    z-index: 2;
  }

  .wp-block-navigation__responsive-container-close svg, 
  .wp-block-navigation__responsive-container-open svg {
    color: var(--wp--preset--color--orange-medium);
  }

  /* Show when open */
  .wp-block-navigation__responsive-container-content
  .has-child.is-open
  .wp-block-navigation__submenu-container {
    display: flex !important;
  }

  /* Sub-item links */
  .wp-block-navigation__responsive-container-content
  .has-child
  .wp-block-navigation__submenu-container
  .wp-block-navigation-item__content {
    font-size: 1rem !important;
    font-weight: 400 !important;
    padding: 0.65rem 0 !important;
    border-bottom: none !important;
    color: var(--wp--preset--color--contrast-2, #555) !important;
  }

  .wp-block-navigation__responsive-container-content
  .has-child
  .wp-block-navigation__submenu-container
  .wp-block-navigation-item {
    border-bottom: none !important;
  }

  /* Toggle button injected by JS */
  .wp-block-navigation__responsive-container-content
  .has-child
  > .wp-block-navigation-item__content
  > .submenu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    padding: 0.25rem !important;
    color: inherit !important;
    transition: transform 0.25s ease !important;
    line-height: 1 !important;
    flex-shrink: 0 !important;
    min-width: 44px !important;
    min-height: 44px !important;
  }

  .wp-block-navigation__responsive-container-content
  .has-child.is-open
  > .wp-block-navigation-item__content
  > .submenu-toggle {
    transform: rotate(180deg) !important;
  }

  /* Hide the native Gutenberg chevron inside the overlay
     (JS also hides it inline as belt-and-suspenders) */
  .wp-block-navigation__responsive-container-content
  .wp-block-navigation__submenu-icon {
    display: none !important;
  }

  .crm-nav-contact {
    margin: 1.2em 0 1.5em 0;
    background-color: var(--wp--preset--color--primary);
  }

  .crm-nav-contact__title {
    font-size: 1em;
    margin-bottom: 0.3em;
  }

  .crm-nav-contact__body {
    font-size: 1.2em;
  }
}


/* -------------------------------------------------------
   Section with SVG Background
------------------------------------------------------- */

.svg-background {
    background-image: var(--bg-leaf1);
    background-attachment: fixed;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: top;
}

.svg-background--center { background-position: center; }
.svg-background--left   { background-position: left center; }
.svg-background--right  { background-position: right center; }
.svg-background--pattern {
    background-size: 150px;
    background-repeat: repeat;
}