@charset "UTF-8";
/*!
Theme Name: Habitu
Theme URI: https://habitu.com.au/
Template: kadence
Author: Hazardawareness
Author URI: https://hazardawareness.com.au/
Description: Habitu child theme.
Version: 1.2.1
Text Domain: kadence-child
*/
/* Theme customisation starts here 
-------------------------------------------------------------- */
html body,
html body .editor-styles-wrapper {
  --wp--preset--font-size--medium: 16px;
  --wp--preset--font-size--large: 22px;
  --wp--preset--font-size--huge: 26px;
  --row-section-padding: 20px;
  --separator-height: 20px;
  --image-border-radius: 20px;
  --border-radius: 10px;
}
@media (min-width: 800px) {
  html body,
  html body .editor-styles-wrapper {
    --row-section-padding: 40px;
    --wp--preset--font-size--medium: 18px;
    --wp--preset--font-size--large: 30px;
    --wp--preset--font-size--huge: 34px;
    --separator-height: 28px;
    --image-border-radius: 30px;
  }
}
@media (min-width: 1100px) {
  html body,
  html body .editor-styles-wrapper {
    --wp--preset--font-size--medium: 20px;
    --wp--preset--font-size--large: 36px;
    --wp--preset--font-size--huge: 42px;
    --border-radius: 15px;
    --row-section-padding: 50px;
    --separator-height: 40px;
  }
}

.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5 {
  text-wrap: balance;
}
.entry-content strong,
.entry-content b {
  font-weight: 700;
}
.entry-content .wp-block-heading mark {
  text-transform: uppercase;
  background-color: transparent !important;
  text-decoration: underline;
  text-decoration-color: var(--global-palette1);
  text-decoration-thickness: 0.1em;
  text-underline-offset: 0.3em;
}

p.has-large-font-size {
  line-height: 1.2;
  text-wrap: balance;
}

p.has-text-align-center {
  max-width: 80ch;
  margin-left: auto;
  margin-right: auto;
}

.entry-content .has-larger-font-size {
  font-size: var(--wp--preset--font-size--huge) !important;
}

/* Typography
-------------------------------------------------------------- */
h1,
h2,
h3,
h4,
h5,
h6 {
  text-wrap: balance;
}

.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5 {
  text-wrap: balance;
}
.entry-content strong,
.entry-content b {
  font-weight: 700;
}
.entry-content .wp-block-heading mark {
  text-transform: uppercase;
  background-color: transparent !important;
  text-decoration: underline;
  text-decoration-color: var(--global-palette1);
  text-decoration-thickness: 0.1em;
  text-underline-offset: 0.3em;
}

p.has-large-font-size {
  line-height: 1.2;
  text-wrap: balance;
}

p.has-text-align-center {
  max-width: 80ch;
  margin-left: auto;
  margin-right: auto;
}

.entry-content .has-larger-font-size {
  font-size: var(--wp--preset--font-size--huge) !important;
}

/* Navigation
-------------------------------------------------------------- */
.site-footer .wp-block-heading {
  color: var(--global-palette2);
  text-transform: uppercase;
  font-size: 16px;
  margin-bottom: 1em;
  margin-top: 1em;
}
.site-footer a {
  color: #fff;
}
.site-footer .site-bottom-footer-inner-wrap {
  margin-top: 0;
  padding-top: 0;
}

/* Groups
-------------------------------------------------------------- */
.wp-block-group.is-style-narrow-group {
  max-width: 80ch;
  margin-left: auto;
  margin-right: auto;
}
.wp-block-group.is-style-feature-gradient-background {
  background-color: var(--global-palette5);
}
.wp-block-group.is-style-highlight-box {
  background-color: var(--global-palette4);
  padding: 1em;
  border-radius: var(--border-radius);
  border: solid 1px var(--global-palette7);
}
.wp-block-group.has-theme-palette-9-background-color {
  border-radius: var(--border-radius);
}
.wp-block-group.has-background {
  padding: 25px 30px !important;
}
@media (min-width: 900px) {
  .wp-block-group.has-background {
    padding: 35px 40px !important;
  }
}

/* Media & Text Block
-------------------------------------------------------------- */
/* Separator
-------------------------------------------------------------- */
/* Header
-------------------------------------------------------------- */
.wp-block-heading.is-style-sub-heading {
  text-transform: uppercase;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.2;
}

/* Buttons
-------------------------------------------------------------- */
.wp-block-button .wp-block-button__link {
  text-transform: uppercase;
}
/* Quote
-------------------------------------------------------------- */
.wp-block-quote.is-style-default {
  text-align: center;
  color: #fff;
  border: none;
  padding: 0;
}
.wp-block-quote.is-style-default::before {
  content: "“";
  display: block;
  font-size: 5em;
  color: #fff;
}
.wp-block-quote.is-style-default cite {
  color: var(--global-palette8);
}

.wp-block-pullquote.wp-block-pullquote {
  padding: 1em 2em;
}
.wp-block-pullquote.wp-block-pullquote blockquote {
  font-weight: 500;
  padding: 1em;
}
.wp-block-pullquote.wp-block-pullquote blockquote p {
  text-wrap: balance;
}
.wp-block-pullquote.wp-block-pullquote blockquote::before {
  content: "";
}
.wp-block-pullquote.wp-block-pullquote blockquote cite {
  color: var(--global-palette5);
  font-weight: 400;
  text-transform: none;
  font-size: var(--global-kb-font-size-md);
}
@media (max-width: 600px) {
  .wp-block-pullquote.wp-block-pullquote {
    padding: 0;
  }
  .wp-block-pullquote.wp-block-pullquote blockquote {
    padding-left: 0;
    padding-right: 0;
  }
  .wp-block-pullquote.wp-block-pullquote blockquote p {
    font-size: 0.9em;
    line-height: 1.3;
  }
}

/* Lists
-------------------------------------------------------------- */
ul.is-style-plus-icons,
.content-wrap ul.is-style-plus-icons {
  list-style: none;
  padding-left: 1.4em;
}
ul.is-style-plus-icons li,
.content-wrap ul.is-style-plus-icons li {
  margin-left: 0;
  position: relative;
}
ul.is-style-plus-icons li:before,
.content-wrap ul.is-style-plus-icons li:before {
  content: "+";
  color: var(--global-palette1);
  font-weight: 700;
  font-size: 1.2em;
  margin-right: 0.5em;
  position: absolute;
  left: -1em;
  top: -0.1em;
}

/* Paragraph
-------------------------------------------------------------- */
.entry-content p.is-style-program-tag {
  font-size: var(--global-kb-font-size-sm);
  display: inline-block;
  line-height: 1.2;
  margin: 0 0 0.2em;
  padding: 0.4em 0.6em;
  border-radius: 2px;
}
.entry-content p.is-style-program-tag a {
  color: inherit;
}

/* Images
-------------------------------------------------------------- */
.wp-block-image.is-style-profile-pic {
  position: relative;
  padding-left: 4em;
  padding-bottom: 4em;
}
.wp-block-image.is-style-profile-pic img {
  position: relative;
  z-index: 1;
  aspect-ratio: 1/1;
  border-radius: 50%;
  object-fit: cover;
}
.wp-block-image.is-style-profile-pic::before {
  content: "";
  position: absolute;
  z-index: 0;
  width: 100%;
  height: 100%;
  left: 0;
  bottom: 0;
  background-image: url("assets/images/grey-speach-shape.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

/* Home
-------------------------------------------------------------- */
/* Page
-------------------------------------------------------------- */
.entry-hero.page-hero-section .entry-hero-container-inner,
.entry-hero.post-archive-hero-section .entry-hero-container-inner {
  position: relative;
}
.entry-hero.page-hero-section .entry-hero-container-inner .page-title,
.entry-hero.post-archive-hero-section .entry-hero-container-inner .page-title {
  justify-content: flex-end;
  padding-bottom: calc(1.5 * var(--global-content-edge-padding));
}

body:not(.has-featured-image) .entry-hero.page-hero-section .hero-section-overlay {
  display: none !important;
}

/* Consulting Services
-------------------------------------------------------------- */
/* Blog Archive
-------------------------------------------------------------- */
/* Single Post
-------------------------------------------------------------- */
/* Header
-------------------------------------------------------------- */
.site-header .kadence-sticky-header.item-is-fixed.item-is-stuck {
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.15);
}

/* Page Intros
-------------------------------------------------------------- */
/* All Sliders
-------------------------------------------------------------- */
.wp-block-cb-carousel.slick-slider .slick-arrow {
  width: 28px;
  height: 28px;
}
.wp-block-cb-carousel.slick-slider .slick-arrow::before {
  background-image: url(assets/images/slider-arrow.svg);
  background-color: transparent;
  background-size: contain;
  background-repeat: no-repeat;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: block;
  position: absolute;
}
.wp-block-cb-carousel.slick-slider .slick-arrow.slick-prev::before {
  transform: rotate(180deg);
}
.wp-block-cb-carousel.slick-slider .slick-dots li button::before {
  font-size: 13px;
  color: #fff;
}

/* Icon Slider
-------------------------------------------------------------- */
/* Staff Profiles
-------------------------------------------------------------- */
/* Service Links
-------------------------------------------------------------- */
/* Contact Section
-------------------------------------------------------------- */
.page-contact-section .wp-block-social-links .wp-social-link a {
  position: relative;
  padding: 12px;
  background-image: url("assets/images/speach-bubble-outline-2px.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.page-contact-section .wp-block-social-links .wp-social-link a svg {
  width: 1.1em;
  height: 1.1em;
  position: relative;
  top: -1px;
}

/* Backgrounds
-------------------------------------------------------------- */
/* Table
-------------------------------------------------------------- */
@media (max-width: 800px) {
  .wp-block-table {
    max-width: 100%;
    font-size: 14px;
    line-height: 1.3;
  }
  .wp-block-table table {
    max-width: 100%;
  }
}

/* Lists
-------------------------------------------------------------- */
.entry-content ul {
  list-style-type: "- ";
}

@media (min-width: 800px) {
  ul.multi-col-list {
    column-count: 2;
    column-gap: 2em;
  }
}

/* Lists
-------------------------------------------------------------- */
.entry-content .services-flex-container.wp-block-group {
  display: flex;
  flex-wrap: wrap;
  gap: var(--global-row-gutter-md, 2rem);
  justify-content: center;
  align-items: stretch;
  align-content: stretch;
}
.entry-content .services-flex-container.wp-block-group > * {
  flex-basis: 100%;
}
@media (min-width: 700px) {
  .entry-content .services-flex-container.wp-block-group > * {
    flex-basis: calc(50% - var(--global-row-gutter-md, 2rem));
  }
}
@media (min-width: 1100px) {
  .entry-content .services-flex-container.wp-block-group > * {
    flex-basis: calc(33.333% - var(--global-row-gutter-md, 2rem));
  }
}
.entry-content .services-flex-container.wp-block-group h4 {
  margin-top: 10px;
}
.entry-content .services-flex-container.wp-block-group .wp-block-kadence-column,
.entry-content .services-flex-container.wp-block-group .kt-inside-inner-col {
  height: auto;
  display: flex;
  flex-direction: column;
  justify-content: stretch;
  align-items: stretch;
}
.entry-content .services-flex-container.wp-block-group .wp-block-kadence-column .kt-inside-inner-col {
  height: 100%;
}

/* Header
-------------------------------------------------------------- */
/* Footer
-------------------------------------------------------------- */
/* Rows
-------------------------------------------------------------- */
.kb-row-layout-wrap.is-style-content-section {
  padding-top: var(--row-section-padding);
  padding-bottom: var(--row-section-padding);
}

/* Testimonials
-------------------------------------------------------------- */
/* Buttons
-------------------------------------------------------------- */
/* Forms
-------------------------------------------------------------- */
.wp-block-kadence-form.is-style-inline {
  margin: 0;
}
.wp-block-kadence-form.is-style-inline .kb-form {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
}
.wp-block-kadence-form.is-style-inline .kb-form .kadence-blocks-form-field,
.wp-block-kadence-form.is-style-inline .kb-form > * {
  margin: 0;
}
.wp-block-kadence-form.is-style-inline .kb-form .kb-submit-field {
  width: auto;
  flex-grow: 0;
}

/* Advanced Images
-------------------------------------------------------------- */
.wp-block-kadence-image.is-style-rounded-corners {
  border-radius: var(--image-border-radius);
  overflow: hidden;
}

/* Gallery
-------------------------------------------------------------- */
/* Accordion
-------------------------------------------------------------- */
.wp-block-kadence-accordion .kt-accordion-header-wrap .kt-blocks-accordion-icon-trigger::before,
.wp-block-kadence-accordion .kt-accordion-header-wrap .kt-blocks-accordion-icon-trigger::after {
  width: 13px;
  height: 2px;
  left: 4px;
  top: 12px;
}

/* InfoBox
-------------------------------------------------------------- */
/* Icon Links
-------------------------------------------------------------- */
/* Social Icons
-------------------------------------------------------------- */
/* Footer
-------------------------------------------------------------- */
.wp-block-kadence-imageoverlay .kt-image-overlay-wrap {
  border-radius: var(--style-border-radius);
  overflow: hidden;
}

/* Number Counter
-------------------------------------------------------------- */
.wp-block-kadence-countup .kb-count-up-number {
  line-height: 1.4;
}
.wp-block-kadence-countup .kb-count-up-title {
  font-size: var(--global-kb-font-size-sm);
  line-height: 1.1;
}

/* Video Popup
-------------------------------------------------------------- */
.is-style-video-overlap.wp-block-kadence-rowlayout {
  --overlap-height: 191px;
  position: relative;
  margin-top: var(--overlap-height);
  background-image: radial-gradient(circle at 50% 0%, #eaeaea 0%, #ffffff 57%);
}
.is-style-video-overlap.wp-block-kadence-rowlayout > .kt-row-column-wrap {
  padding-top: 0;
  margin-top: 0;
}
.is-style-video-overlap.wp-block-kadence-rowlayout .wp-block-kadence-videopopup {
  position: relative;
  margin-top: calc(-1 * var(--overlap-height));
  z-index: 1;
}

form input[type=text],
form input[type=password],
form input[type=number],
form input[type=search],
form input[type=email],
form input[type=url],
form textarea,
form select {
  color: var(--global-palette3);
  border-color: var(--global-palette3);
}
form :placeholder {
  color: var(--global-palette3);
}

::selection {
  background-color: var(--global-palette1);
  color: #fff;
}

::marker {
  color: var(--global-palette1);
}
