/*
Theme Name: Insight Counselling
Author: Orqa Design
Author URI: https://orqadesign.com/
Description: 2026 Custom built theme for Insight Counselling
Version: 1.0
License: For use by Insight Counselling Only
*/

/* =========================================================
   01. RESET
========================================================= */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; }
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
body { line-height: 1; }
blockquote, q { quotes: none; }
blockquote::before, blockquote::after, q::before, q::after { content: ""; }
table { border-collapse: collapse; border-spacing: 0; }
/* =========================================================
   02. ICONS / FONTS / ADMIN
========================================================= */

.fas, .fab, .fab-brands, .fa, .bullet-icon { display: inline-block; font: normal normal normal 14px/1 FontAwesome; font-size: inherit; text-rendering: auto; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
.fa-classic, .fa-regular, .fa-solid, .far, .fas, .fa.fa-handshake-o, .fontawesome { font-family: "FontAwesome" !important; }
body#tinymce { font-family: "Open Sans", sans-serif; font-optical-sizing: auto; }
/* =========================================================
   03. GLOBAL / BASE
========================================================= */

* { -webkit-font-smoothing: antialiased; box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { font-family: "Open Sans", sans-serif; font-optical-sizing: auto; font-weight: 300; font-size: 16px; line-height: 1.75; color: #3e5944; overflow-x: hidden; }
div { box-sizing: border-box; }
a { color: #3e5944; text-decoration: underline; font-weight: 700; }
p { margin-bottom: 20px; }
b { font-weight: 700; }
strong { font-weight: 500; }
em { font-style: italic; }
img { max-width: 100%; height: auto; }
a img { transition: transform 0.4s ease, opacity 0.4s ease; }
a:hover img { transform: scale(1.05); opacity: 0.9; }
.font300 { font-weight: 300; }
.font18 { font-size: 18px; }
.opensans { font-family: "Open Sans", sans-serif; }
.left { float: left; }
.right { float: right; }
.clear { clear: both; float: none !important; }
/* =========================================================
   04. TYPOGRAPHY
========================================================= */

h1 { font-family: "Lora", serif; font-optical-sizing: auto; font-weight: 400; font-size: 72px; line-height: 72px; text-align: center; }
h2 { font-family: "Lora", serif; font-size: 50px; line-height: 50px; text-align: center; }
h3 { font-weight: 700; }
/* =========================================================
   05. LAYOUT / WRAPPERS
========================================================= */

.wrapper { width: 1530px; margin: 0 auto; }
.inner-wrapper { max-width: 960px; margin: 0 auto; }
.inner-med-wrapper { max-width: 1200px; margin: 0 auto; }
.basic-page { padding-top: 100px; padding-bottom: 100px; }
.basic-page .content { padding-top: 40px; }
.basic-page ul { padding: 20px 0 20px 20px; }
.basic-page li { padding-left: 20px; }
/* =========================================================
   06. HEADER / NAVIGATION
========================================================= */

header { width: 100%; padding-top: 30px; padding-bottom: 30px; background-color: #f7f4ef; }
.logo { width: 256px; height: auto; }
.logo {
  image-rendering: -webkit-optimize-contrast;
}

.logo svg {
  shape-rendering: geometricPrecision;
  text-rendering: geometricPrecision;
}
.menu-icon img { width: 29px; height: 29px; }
a#menu-icon { display: none; }
#navigation { padding-top: 20px; }
.menu-main-menu-container li { display: inline-block; padding: 10px; font-family: "Lora", serif; font-size: 18px; }
.menu-main-menu-container li a { font-weight: normal; text-decoration: none; }
.menu-main-menu-container li a:hover, .menu-main-menu-container li.current_page_item a { text-decoration: underline; }
/* =========================================================
   07. FOOTER
========================================================= */

footer { width: 100%; padding-top: 20px; padding-bottom: 40px; background-color: #f7f4ef; }
.footer-container { display: flex; gap: 30px; }
.footer-left, .footer-middle, .footer-right { flex: 1; }
.footer-left, .footer-right { padding-top: 30px; font-family: "Lora", serif; font-size: 20px; line-height: 24px !important; }
.footer-left { text-align: left; }
.footer-middle { text-align: center; }
.footer-right { text-align: right; }
.footer-email { padding-top: 20px; font-family: "Open Sans", sans-serif; font-size: 18px; font-weight: bold; }
.tagline { font-family: "Lora", serif; font-size: 30px; line-height: 30px; text-align: center; }
.socials { padding-top: 50px; padding-bottom: 35px; text-align: center; }
.socials .fab { margin-left: 10px; margin-right: 10px; font-size: 36px; color: #adb3a9; }
.footer-middle .logo { width: 360px; height: auto; }
.copy { padding-top: 20px; font-size: 11px; line-height: 14px; font-weight: 400; letter-spacing: 4px; text-align: center; text-transform: uppercase; }
.copy a { font-weight: 400; text-decoration: none; }
.copy a:hover { text-decoration: underline; }
/* =========================================================
   08. BUTTONS
========================================================= */

.btn { display: inline-flex; align-items: center; justify-content: center; padding: 9px 26px; border: 1px solid transparent; cursor: pointer; font-weight: 300; letter-spacing: 0.12em; text-transform: uppercase; text-decoration: none; transition: all 0.2s ease; }
.btn-outline { background: transparent; color: var(--accent); border-color: var(--accent); }
.button, .wpcf7-form .wpcf7-submit { display: inline-block; padding: 12px 24px; border: none; border-radius: 40px; background: #3e5944; color: #fff; font-family: "Lora", serif; font-weight: 400; line-height: 18px; text-decoration: none; box-sizing: border-box; transition: transform 0.25s ease, opacity 0.25s ease; }
.button:hover, .wpcf7-form .wpcf7-submit:hover, #image-button .item .button:hover, #image-button .item .button:focus, .prefooter-cta .button:hover { transform: translateY(-5px); }
/* =========================================================
   09. LISTS
========================================================= */

ol { padding-left: 20px; padding-bottom: 40px; }
ol li { padding-left: 20px; padding-bottom: 15px; }
 ol li::marker {
 font-weight: 700;
 text-align: center;
}
/* =========================================================
   10. CONTACT FORM 7
========================================================= */

.wpcf7-form { margin: 0; color: #231b16; font-family: inherit; }
.wpcf7-form p { margin: 0; }
.wpcf7-form .wpcf7-form-control-wrap { display: block; margin-bottom: -10px; }
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"], .wpcf7-form textarea, textarea { display: block; width: 100%; padding: 0.8rem 1rem; border: none; border-radius: 0; background: #fff; font-family: "Open Sans", sans-serif; font-size: 0.98rem; font-weight: 600; letter-spacing: 0.03em; text-transform: none; box-sizing: border-box; }
.wpcf7-form textarea, textarea { height: 100px; }
 .wpcf7-form input::placeholder, .wpcf7-form textarea::placeholder, textarea::placeholder {
 color: #3e5944;
 opacity: 1;
 font-weight: 300;
}
.wpcf7-form input:focus, .wpcf7-form textarea:focus, textarea:focus { outline: none; border-color: #221915; }
.wpcf7-form br + span[data-name="checkbox-399"] { display: inline-block; margin-top: 0.6rem; font-family: "Open Sans", sans-serif; }
.wpcf7-form span[data-name="checkbox-399"] .wpcf7-list-item { display: inline-flex; align-items: center; margin-top: 0.6rem; margin-right: 2rem; }
.wpcf7-form span[data-name="checkbox-399"] input[type="checkbox"], .wpcf7-form span[data-name="acceptance-690"] input[type="checkbox"] { appearance: none; -webkit-appearance: none; width: 26px; height: 26px; border: 1px solid #221915; border-radius: 4px; background: transparent; cursor: pointer; }
.wpcf7-form span[data-name="checkbox-399"] input[type="checkbox"] { margin: 0 0 -7px; }
.wpcf7-form span[data-name="acceptance-690"] input[type="checkbox"] { margin-top: 0.15rem; margin-left: 0; }
.wpcf7-form span[data-name="checkbox-399"] input[type="checkbox"]:checked, .wpcf7-form span[data-name="acceptance-690"] input[type="checkbox"]:checked { background: #221915; }
.wpcf7-form span[data-name="checkbox-399"] .wpcf7-list-item-label { margin-left: 0.6rem; font-weight: 600; }
.wpcf7-acceptance input { float: left; }
.wpcf7-acceptance span.wpcf7-list-item-label { display: block; float: left; width: 85%; padding-left: 20px; font-size: 10px; line-height: 12px; }
.wpcf7-form span[data-name="acceptance-690"] .wpcf7-list-item { display: flex; align-items: flex-start; gap: 0.7rem; margin-top: 1rem; }
.wpcf7-form span[data-name="acceptance-690"] .wpcf7-list-item-label { font-size: 0.85rem; line-height: 1.5; }
.wpcf7-form span[data-name="acceptance-690"] a { text-decoration: underline; }
.wpcf7-form .wpcf7-submit { width: 100%; margin-top: 20px; }
/* =========================================================
   11. HOME
========================================================= */

.hero { position: relative; display: flex; align-items: center; min-height: 760px; padding: 80px 0; overflow: hidden; background: none !important; }
.hero-bg { position: absolute; inset: -8%; z-index: 1; background-position: center center; background-repeat: no-repeat; background-size: cover; transform-origin: center center; will-change: transform; animation: heroZoom 10s ease-in-out infinite alternate; }
.hero .wrapper { position: relative; z-index: 2; }
 @keyframes heroZoom {  0% {
 transform: scale(1) translateY(0);
}
 100% {
 transform: scale(1.2) translateY(80px);
}
}
.hero-block { max-width: 700px; margin-top: 120px; padding: 60px 50px; background: rgba(245, 242, 236, 0.95); text-align: center; }
.hero-block h1 { position: relative; display: flex; align-items: center; justify-content: center; gap: 15px; margin-bottom: 15px; font-family: "Open Sans", sans-serif; font-size: 14px; line-height: 14px; font-weight: 600; letter-spacing: 2px; text-transform: uppercase; }
.hero-block h1::before, .hero-block h1::after { content: ""; flex: none; width: 40px; height: 1px; background: #8b8f86; }
.hero-block h2 { margin-bottom: 15px !important; font-family: "Lora", serif !important; font-size: clamp(32px, 4vw, 50px) !important; line-height: 1.1 !important; font-weight: 400 !important; }
.hero-block h3 { margin-bottom: 25px; font-size: 20px; line-height: 28px; font-weight: 300; color: #666; }
.about-home { padding: 90px 0 150px; background: #f7f7f4; }
.about-home img { display: block; width: 50px; height: auto; margin: 0 auto 20px; }
.home h2 { margin: 0 0 8px; font-family: "Lora", serif; font-size: clamp(50px, 4vw, 72px); line-height: 1.05; font-weight: 400; text-align: center; }
.about-home h3 { margin: -20px 0 50px; font-family: "Lora", serif; font-size: clamp(20px, 2vw, 28px); line-height: 1.2; font-weight: 300; text-align: center; }
.about-home .inner-wrapper { display: grid; grid-template-columns: 1fr 1fr; column-gap: 55px; row-gap: 20px; }
.about-home img, .about-home h2, .about-home h3, .about-home .online-inperson { grid-column: 1 / -1; }
.about-home .col1 { grid-column: 1; }
.about-home .col2 { grid-column: 2; }
.about-home .col1, .about-home .col2 { font-size: 1rem; line-height: 1.75; text-align: justify; }
.about-home .col1 a, .about-home .col2 a { font-weight: normal; }
.about-home .col1 p, .about-home .col2 p { margin: 0 0 26px; }
.about-home .col1 ul, .about-home .col2 ul { margin: 0 0 26px 0; padding-left: 20px; }
.about-home .col1 ul, .about-home .col2 ul { list-style: none; padding-left: 0; margin-top: -25px; }
.about-home .col1 li, .about-home .col2 li { position: relative; margin-bottom: 2px; padding-left: 26px; text-align: left; }
.about-home .col1 li::before, .about-home .col2 li::before { content: ""; position: absolute; top: 8px; left: 0; width: 12px; height: 12px; background-image: url('/wp-content/themes/insight-counselling-theme/images/bullet.png'); background-repeat: no-repeat; background-size: contain; }
.about-home .online-inperson { display: flex; align-items: center; gap: 14px; font-size: 1.05rem; line-height: 18px; font-weight: 600; }
.about-home .online-inperson .fa { font-size: 2rem; line-height: 1; }
.about-home .online-inperson .fa-user { margin-left: -2px; }
.image-buttons-area { position: relative; z-index: 2; margin-top: -70px; padding-bottom: 100px; }
.image-buttons-area .wrapper { position: relative; }
.image-buttons-area::before { content: ""; position: absolute; right: 0; bottom: 0; left: 0; z-index: 0; height: 430px; background: linear-gradient(to bottom, #3d5743 0%, #2f4635 100%); }
#image-button { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; width: 85%; margin: auto; }
#image-button .item { position: relative; display: flex; flex-direction: column; justify-content: flex-end; min-height: 400px; padding: 34px 26px 28px; overflow: hidden; background-position: center center !important; background-size: 190% !important; }
#image-button .item::before { content: ""; position: absolute; inset: 0; background: rgba(60, 70, 55, 0.11); }
#image-button .item > * { position: relative; z-index: 2; }
#image-button .item h3 { margin: 0 0 14px; font-family: "Lora", serif; font-size: 2.9rem; line-height: 1.05; font-weight: 400; color: #fff; text-align: center; }
#image-button .item h4 { margin: 0 0 22px; font-size: 1rem; line-height: 1.45; font-weight: 600; color: rgba(255, 255, 255, 0.95); text-align: center; }
#image-button .item .button { display: inline-flex; align-items: center; justify-content: center; align-self: center; min-width: 155px; min-height: 48px; padding: 0 24px; border-radius: 999px; background: #3e5944; color: #fff; font-size: 1rem; line-height: 1; text-decoration: none; transition: 0.25s ease; }
.accessibility-section { padding: 30px 0; background: #f7f7f4; font-family: "Lora", serif; }
.accessibility-section .wrapper { display: flex; align-items: flex-start; gap: 18px; max-width: 1330px; }
.accessibility-section img { display: block; flex: 0 0 80px; width: 80px; height: auto; margin-top: -10px; }
.accessibility-section .access-wrap { flex: 1; }
.accessibility-section h4 { margin: 0 0 6px; font-size: 1.3rem; line-height: 1.2; font-weight: 400; }
.accessibility-section .access-wrap div, .accessibility-section .access-wrap p { margin: 0; font-size: 0.9rem; line-height: 1.3; }
.prefooter-cta { max-width: 850px; margin: 0 auto; padding: 50px 20px; text-align: center; }
.prefooter-cta h2 { margin: 0 0 20px; font-family: "Lora", serif; font-size: clamp(1.8rem, 3vw, 2rem); line-height: 1.2; font-weight: 400; }
.prefooter-cta h3 { margin: -20px 0 30px; font-family: "Lora", serif; font-size: 18px; line-height: 1.3; font-weight: 300; }
.prefooter-cta .button { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 34px; border-radius: 999px; background: #3e5944; color: #fff; font-size: 1rem; line-height: 1; text-decoration: none; transition: 0.25s ease; }
/* =========================================================
   12. PAGE INTRO / INTERNAL HERO
========================================================= */

.page-intro { position: relative; padding: 80px 0 120px; overflow: hidden; background: #3e5944; }
.page-intro::after { content: ""; position: absolute; bottom: 0; left: 0; z-index: 0; width: 100%; height: 120px; background: #f7f4ef; }
.page-intro-inner { position: relative; display: grid; grid-template-columns: minmax(280px, 420px) 1fr; gap: 70px; align-items: center; max-width: 1200px; margin: 0 auto; padding: 10px 0 40px; }
.top-image-wrap, .page-info { position: relative; z-index: 2; }
.top-image-wrap { position: relative; z-index: 2; width: 400px; margin-bottom: -100px; padding-left: 20px; }
.top-image-wrap img { display: block; width: 100%; height: auto; max-width: 420px; }
.page-info { color: #fff; }
.page-info-inner { max-width: 620px; }
.page-info h1 { margin-bottom: 10px;  font-weight: 300; text-align: left; }
.page-subtitle { margin: 0 0 28px; font-family: "Lora", serif; font-size: 24px; font-weight: 400; opacity: 0.9; text-align: left; }
.page-text { margin-bottom: 30px; font-size: 16px; line-height: 1.7; text-align: justify; }
.page-text strong { font-weight: 600; }
.page-text p { margin-bottom: 16px; }
.page-text a { color: #fff; }
.watermark { position: absolute; z-index: 3; left: 37%; width: 200px; }
.page-intro-inner .watermark { position: absolute; top: 52%; left: 35%; max-width: 230px;  transform: translate(-50%, -50%); pointer-events: none; z-index: 3; }
/* =========================================================
   13. PAGE INTRO SLIDER
========================================================= */

.page-intro-slider-section { position: relative; overflow: hidden; }
.page-intro-slider-wrap, .page-intro-slider-outer, .page-intro-slider { position: relative; width: 100%; }
.page-intro-slider { transition: height 0.35s ease; }
.page-intro-slide { position: absolute; top: 0; left: 0; width: 100%; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.45s ease; }
.page-intro-slide.is-active { position: relative; z-index: 2; opacity: 1; visibility: visible; pointer-events: auto; }
.page-intro-heading-row { margin-bottom: 12px; }
.page-intro-inline-nav { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.step-nav-item { padding: 0; margin: 0; border: 0; background: none; cursor: pointer; font-family: inherit; font-size: 3rem; line-height: 1; color: rgba(255, 255, 255, 0.18); transition: color 0.25s ease; }
.step-nav-item.is-active { color: rgba(255, 255, 255, 0.75); }
.page-intro-next { padding: 10px 20px; border: 1px solid rgba(255, 255, 255, 0.4); border-radius: 999px; background: #fff; color: #4f614c; font-size: 0.95rem; cursor: pointer; transition: all 0.25s ease; }
.page-intro-next:hover { background: rgba(255, 255, 255, 0.9); transform: translateY(-1px); }
.page-intro-next.is-disabled { opacity: 0.45; pointer-events: none; }
.page-intro-bottom-nav { display: flex; align-items: flex-start; gap: 16px; flex-wrap: wrap; margin-top: 18px; font-size: 0.9rem; }
.step-bottom-item { padding: 0; margin: 0; border: 0; background: none; color: rgba(255, 255, 255, 0.45); cursor: pointer; font-family: inherit; text-align: left; transition: color 0.25s ease; }
.step-bottom-item:hover { color: rgba(255, 255, 255, 0.75); }
.step-bottom-item.is-active { color: #fff; }
.step-bottom-number, .step-bottom-title { display: inline; font-size: 0.95rem; line-height: 1.4; }
.step-bottom-number { margin-right: 4px; font-weight: 600; }
/* =========================================================
   14. GENERIC CONTENT SECTIONS
========================================================= */

.one-col { padding-top: 20px; padding-bottom: 80px; background: #f7f4ef; text-align: justify; text-align-last: center; }
.one-col .text { padding-top: 30px; padding-bottom: 10px; }
.col1 h2, .col2 h2 { padding-bottom: 40px; text-align: left; }
.divider-mini { width: 120px; height: 3px; margin: auto; background: #3e5944; text-align: center; }
.confid { font-size: 13px; line-height: 16px; }
/* =========================================================
   15. ABOUT / INFO ICONS
========================================================= */

.about .about-home { padding-bottom: 50px; background-color: #fff; }
.info-icons { display: flex; justify-content: center; gap: 60px; padding-top: 40px; padding-bottom: 40px; background: #f7f7f4; text-align: center; }
.info-item { max-width: 220px; }
.info-icon { display: flex; align-items: center; justify-content: center; width: 140px; height: 140px; margin: 0 auto 10px; border-radius: 50%; background: #5b6b57; color: #fff; font-size: 48px; }
.info-badge { font-size: 46px; font-weight: 500; color: #fff; letter-spacing: -3px; }
/* =========================================================
   16. HOW IT WORKS / AREAS OF SUPPORT
========================================================= */

.how-it-works .one-col, .areas-of-support .one-col { padding-top: 80px; background: #fff; }
.how-it-works .one-col .fas { padding-bottom: 20px; font-size: 40px; }
.how-it-works .page-intro::after { background: #fff; }
.areas-of-support .prefooter-cta, .contact .prefooter-cta { max-width: 100%; padding: 260px 20px 60px; background-position: center; background-repeat: no-repeat; background-size: cover; background-attachment: fixed; }
.areas-of-support .prefooter-cta h2, .contact .prefooter-cta h2 { color: #fff; }
.areas-support { padding: 90px 0; background: #f7f4ef; }
.areas-support-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); column-gap: 48px; row-gap: 42px; }
.area-support-item { position: relative; padding-left: 26px; }
.area-support-item::before { content: ""; position: absolute; top: 4px; left: 0; width: 1px; height: calc(100% - 8px); background: rgba(79, 97, 76, 0.55); }
.area-support-inner { min-height: 100%; }
.area-support-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 14px; }
.area-support-title { font-family: "Lora", serif; font-size: 30px; line-height: 30px; font-weight: 300; text-align:left; }
.area-support-icon { flex: 0 0 auto; width: 58px; line-height: 0; }
.area-support-icon img { display: block; width: 100%; height: auto; object-fit: contain; }
.area-support-description p:last-child { margin-bottom: 0; }
/* =========================================================
   17. CONTACT PAGE
========================================================= */

.contact .top-image-wrap { margin-bottom: -120px; padding-top: 30px; padding-right: 20px; background: #f7f4ef; }
.contact .top-image-wrap h2 { padding-bottom: 20px; font-size: 24px; line-height: 26px; font-weight: 300; text-align: left; }
.contact .page-intro::after { background: #fff; }

/* =========================================================
   18. RESPONSIVE MEDIA QUERIES
========================================================= */




@media only screen and (max-width: 1746px) {
}

@media (max-width: 1512px) {
  .one-col {
    text-align: center!important;
  }
}

 @media only screen and (max-width: 1600px) {
.wrapper { width: 1200px; }
.watermark { left: 33%; }
}
 @media only screen and (max-width: 1440px) {

}
 @media only screen and (max-width: 1270px) {
.wrapper { width: 1000px; }
#image-button .item { min-height: 300px; }
.image-buttons-area::before { height: 380px; }
.footer-middle { padding: 20px; }
.step-bottom-item { width: 100%; }
}
 @media only screen and (max-width: 1050px) {
.wrapper { width: 800px; }
.image-buttons-area { margin-top: -45px; }
#image-button .item { min-height: 291px; padding: 28px 20px 24px; }
#image-button .item h3 { font-size: clamp(1.7rem, 3vw, 2.4rem); }
#image-button .item h4 { font-size: 0.95rem; line-height: 1.2; }
.image-buttons-area::before { height: 350px; }
.footer-container { display: block; }
.footer-left,  .footer-right { padding-bottom: 30px; text-align: center; }
.page-intro-inner { grid-template-columns: 420px 1fr; gap: 60px; max-width: 1200px; margin: 0 auto; padding: 0 0 50px; }
.watermark { left: 33%; }
.step-nav-item { font-size: 30px; letter-spacing: -1px; }
}
 @media only screen and (max-width: 950px) {
#navigation ul#menu-primary li { display: block; float: none; margin-right: 0; padding-left: 0; list-style-type: none; }
ul#menu-primary { position: absolute; right: 0; z-index: 201; width: 100%; margin-top: 55px; padding: 10px; background: #482b7d; border: 0; box-sizing: border-box; text-align: center; -webkit-box-shadow: -1px 7px 17px -3px rgba(0, 0, 0, 1); -moz-box-shadow: -1px 7px 17px -3px rgba(0, 0, 0, 1); box-shadow: -1px 7px 17px -3px rgba(0, 0, 0, 1); }
.menu-main-menu-container li { display: inline-block; width: 100%; padding: 5px; text-align: center; }
.menu { display: none; width: 100%; margin-top: 29px; background-color: #3e5944; }
.menu.active { display: block; padding-top: 10px; padding-bottom: 20px; }
#navigation { position: absolute; left: 50%; z-index: 1000000; width: 100vw; margin-top: 90px; padding-top: 0; transform: translateX(-50%); }
.menu-main-menu-container li a { color: #f7f4ef; }
.hero { padding: 60px 0; }
.hero-block { max-width: 500px; }
.menu-main-menu-container li { padding: 5px; }
a#menu-icon { display: block; float: right; margin-top: -78px; margin-right: 50px; margin-bottom: 5px;  padding-right: 0; font-size: 40px; cursor: pointer; }
.menu-main-menu-container { box-shadow: 0 8px 20px rgba(0, 0, 0, 0.5); }
.page-intro-inner { gap: 0; }
.top-image-wrap { max-width: 350px; margin-bottom: 0px; padding-left: 0; }
.contact .top-image-wrap { padding-left: 20px; }
}
 @media only screen and (max-width: 850px) {
.wrapper { width: 700px; }
.footer-container { flex-direction: column; }
#image-button { grid-template-columns: 1fr; gap: 16px; width: 330px; margin-top: -60px; }
.image-buttons-area { margin-top: 0; }
#image-button .item { min-height: 300px; }
#image-button .item h3 { font-size: 36px; }
.image-buttons-area::before { height: 971px; }
.accessibility-section { padding-top: 50px; }
.page-intro-inner { grid-template-columns: 240px 1fr; gap: 40px; }
.top-image-wrap { max-width: 260px; margin-bottom: 0; }
.watermark { left: 0; }
.page-intro::after { height: 70px; }
.how-it-works .top-image-wrap { margin-top: -60px; }
}
 @media only screen and (max-width: 767px) {

.page-intro-inner .watermark { top: 35%; left: 50%; max-width: 150px; }
.page-intro-inline-nav { gap: 12px; }
.step-nav-item { font-size: 2rem; }
.page-intro-bottom-nav { flex-direction: column; gap: 14px; }
.areas-support-grid { grid-template-columns: 1fr; gap: 28px; }
.area-support-item { padding-left: 18px; }
.area-support-header { gap: 12px; margin-bottom: 10px; }
}
 @media only screen and (max-width: 720px) {
.wrapper { width: auto; margin-left: 40px; margin-right: 40px; }
.page-intro-inner { grid-template-columns: 1fr; gap: 40px; }
.top-image-wrap { width: 100%; max-width: 100%; }
.page-info-inner { max-width: 100%; }
.page-intro::after { height: 0; }
.page-intro { padding: 40px 0 0; }
.watermark { position: absolute; bottom: 30%; left: 50%; transform: translateX(-50%); }
.one-col { padding-top: 80px; }
.how-it-works .top-image-wrap { margin-top: 0; }
.how-it-works .top-image-wrap img { max-width: 100%; }
.page-intro-slider { height: auto !important; }
.top-image-wrap img {
 
  max-width: 100%;
}
.contact .top-image-wrap {
  margin-bottom: 0px;}
}
 @media only screen and (max-width: 600px) {
.hero { min-height: auto; padding: 40px 0; }
.hero-block { max-width: 100%; padding: 25px; }
.hero-block h1 { font-size: 12px; }
.hero-block h2 { font-size: 30px; }
.hero-block h3 { font-size: 15px; line-height: 18px; }
.button { width: 100%; text-align: center; }
.about-home .inner-wrapper { grid-template-columns: 1fr; row-gap: 0; }
.about-home .col1,  .about-home .col2 { grid-column: 1; }
.about-home h3 { margin-top: 10px; }
#image-button .item .button { min-width: 145px; min-height: 44px; font-size: 0.95rem; }
.accessibility-section .wrapper { flex-direction: column; gap: 12px; }
.accessibility-section img { margin: auto; }
.accessibility-section { text-align: center; }
a#menu-icon { margin-top: -95px; margin-right: 20px; }
.footer-left,  .footer-right { font-size: 16px; line-height: 20px !important; }
.font18 { font-size: 14px; }
.tagline { font-size: 24px; line-height: 28px; }
.copy { font-size: 8px; }
.wrapper { width: auto; margin-left: 20px; margin-right: 20px; }
.socials { padding-top: 0; padding-bottom: 20px; }
h2 { font-size: 43px; line-height: 43px; }
.info-icons { gap: 5px; }
.info-icon { width: 120px; height: 120px; font-size: 40px; }
.info-badge { font-size: 36px; }
}
 @media only screen and (max-width: 580px) {
.wrapper,  .inner-wrapper,  .menu-overlay .inner-wrapper { margin-left: 20px; margin-right: 20px; }
}
 @media only screen and (max-width: 480px) {
.watermark { bottom: 40%; }
.hero-block {
  margin-top: 0px;}
    .one-col {
    text-align: justify;!important;
  }
    .page-intro-inner .watermark {
    top: 25%;}
    h1 {
  font-size: 52px;
  line-height: 52px;
}
.how-it-works .one-col, .areas-of-support .one-col {
  padding-top: 40px;}
}
 @media only screen and (max-width: 420px) {
#image-button { width: 100%; }
.logo { width: 200px; height: auto; }
.menu { margin-top: 13px; }
.footer-middle .logo { width: 100%; }
.watermark { bottom: 60%; }
.inner-wrapper { margin-left: 0; margin-right: 0; }
.info-icons { display: grid; }
}
 @media only screen and (max-width: 319px) {
body { min-width: 319px; }
}
