html { font-size: 9px; font-weight: 300; -webkit-tap-highlight-color: transparent; }

@media (min-width: 700px) { html { font-size: 10px; } }

header { text-transform: uppercase; }

header h1 { text-transform: capitalize; }

body { line-height: 1.75; font-size: 2em; }

body, input, textarea { font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif; color: #3A4145; text-rendering: geometricPrecision; }

label, h1, h2, h3, h4, h5, h6 { font-family: "Lato", "Helvetica Neue", Helvetica, Arial, sans-serif; font-weight: 400; }

h1, h2, h3, h4, h5, h6 { margin: 0; line-height: 1.5; }

h1:not(:first-child), h2:not(:first-child), h3:not(:first-child), h4:not(:first-child), h5:not(:first-child), h6:not(:first-child) { margin-top: 1.5rem; }

h2 { font-size: 3.6rem; }

h3 { font-size: 2.7rem; }

h4 { font-size: 2.3rem; }

h5 { font-size: 2rem; }

h6 { font-size: 2rem; }

a { color: #4489b1; transition: color 0.2s ease; }

a:hover { color: #73a9c9; }

.ital { font-style: italic; }

body { margin: 0; padding: 0; background-color: #fefefe; }

.box, .post-summary, .post-comments, .testimonial-message { background-color: #fefefe; box-shadow: 1px 1px 5px 0 rgba(100, 100, 100, 0.2); padding: 20px; border-radius: 2px; }

.call1 { display: none; }

@media (min-width: 1000px) { .call1 { display: block; } }

.call2 { margin: 1rem 0; text-transform: none; }

@media (min-width: 1000px) { .call2 { display: none; } }

.call2.active { display: none; }

.hamburger { display: flex; flex-direction: column; cursor: pointer; border: none; background: none; }

@media (min-width: 1000px) { .hamburger { display: none; } }

.hamburger-line { width: 25px; height: 3px; background-color: #132a48; margin: 4px 0; transition: 0.4s; }

.header-top-row { display: flex; flex-flow: row; align-items: center; justify-content: space-between; }

@media (max-width: 1000px) { .header-top-row { width: 100%; } .header-top-row .logo { flex-basis: 70%; } }

header { background-size: cover; box-sizing: border-box; }

header .header-container { padding: 1rem 2rem; display: flex; flex-flow: column; align-items: center; justify-content: space-between; }

@media (min-width: 1000px) { header .header-container { flex-flow: row; } }

@media (min-width: 1000px) { header { background-size: contain; background-position: calc(50% - 300px) calc(100% + 20px); } header .header-container { text-align: right; } }

header .logo { margin: 1rem 0 2rem 0; }

header .logo img { vertical-align: bottom; object-fit: contain; max-width: 100%; max-height: 10vh; }

@media (min-width: 1000px) { header .logo { margin: 1rem 0; } header .logo img { height: 6rem; } }

header a { color: #132a48; text-decoration: none; }

header a.active { border-bottom: 2px solid; }

header nav { max-width: 100%; }

header .nav-container { display: flex; justify-content: space-between; align-items: center; }

header ul.nav-menu { list-style: none; margin: 0; padding: 0; display: flex; }

header ul.nav-menu li { margin: 0 10px; }

@media (max-width: 1000px) { header .nav-container { flex-direction: column; align-items: center; } header ul.nav-menu { flex-direction: column; align-items: center; display: none; width: 100%; } header ul.nav-menu.active { display: flex; } }

section { padding: 30px 20px; }

@media (min-width: 700px) { section { padding: 80px 40px; } }

.content img { max-width: 100%; max-height: 100%; height: auto; border-radius: 2px; }

.main { font-size: 2.25rem; }

.light-section, .main { background-color: #f5f5f7; box-shadow: inset 0px 15px 15px -15px rgba(100, 100, 100, 0.2); }

.light-section-opaque { background-color: #f5f5f766; box-shadow: inset 0px 15px 15px -15px rgba(100, 100, 100, 0.2); }

.dark-section, .quote-section { background-color: #3e3f46; color: white; box-shadow: inset 0px 15px 15px -15px rgba(0, 0, 0, 0.5); }

.dark-section a, .quote-section a { color: #efefef; transition: color 0.2s ease; }

.dark-section a:hover, .quote-section a:hover { color: #fefefe; }

.hero { display: flex; flex-direction: column; align-items: center; justify-content: space-evenly; padding: 2rem; background-repeat: no-repeat !important; background-size: cover !important; background-position: center 75% !important; min-height: 50vh !important; background: linear-gradient(rgba(19, 42, 72, 0.75), rgba(19, 42, 72, 0.75)), url("/images/skyline.jpg") no-repeat center center; }

@media (min-width: 700px) { .hero { padding: 0; flex-direction: row; min-height: 60vh !important; background-position: center 60% !important; background: linear-gradient(90deg, rgba(19, 42, 72, 0.75) 45%, transparent, rgba(255, 255, 255, 0.6) 60%), url("/images/skyline.jpg") no-repeat center center; } }

.hero-cta { color: #132a48; display: flex; flex-direction: column; justify-content: space-around; align-items: center; row-gap: 2rem; background-color: rgba(19, 42, 72, 0.75); }

.hero-cta h3 { display: none; }

@media (min-width: 700px) { .hero-cta { background-color: transparent; flex-basis: 30%; } .hero-cta h3 { display: block; } .hero-cta .btn { padding: 1rem 6rem; } }

.hero-cta h3 { font-size: 4rem; }

.hero-cta a { font-weight: 400; }

.hero-cta .btn { padding: 1rem 4rem; text-wrap: nowrap; }

.hero-text { display: flex; color: white; align-items: flex-start; flex-flow: column nowrap; text-align: center; }

@media (min-width: 700px) { .hero-text { flex-basis: 30%; text-align: start; } }

.hero-text h1 { margin-top: 0; font-size: 3rem; }

.hero-text a { color: #fefefe; transition: color 0.2s ease; }

.hero-text a:hover { color: #fff; }

.cta-btn { background: white !important; color: black !important; }

@media (min-width: 700px) { .cta-btn { background: #132a48 !important; color: white !important; } }

.curved-border { border-radius: 30px; padding: 30px; }

.blue-background { background-color: #132a48 !important; color: white; padding: 30px; }

.blue-background a { color: white; text-decoration: underline; }

.map-section { padding: 0; }

.map-section #map { height: 300px; width: 100%; /* The width is the width of the web page */ }

.quote-section { font-style: italic; padding: 1rem 2rem; text-align: center; display: flex; flex-direction: column; align-items: center; }

.quote-section h4 { font-size: 3rem; }

.quote-section p { font-size: 2rem; }

.quote-section p { margin: 0; }

.quote-section .btn { margin: 4rem 0; }

@media (min-width: 700px) { .quote-section .btn { width: 33%; } }

.staff-list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; }

.staff { flex-wrap: wrap; margin: 20px; }

.staff p { margin: 0; }

.staff small { opacity: 0.6; font-size: 1.7rem; }

.staff-bio { border-top: 2px dotted white; margin-top: 2rem; }

.staff-bio p { margin-bottom: 1rem; }

.staff-info { list-style: none; margin: 0; padding: 0; }

.staff-details { margin: 0; display: flex; flex-direction: column; column-gap: 4rem; }

.staff-details .staff-image img { border-radius: 20px; }

@media (min-width: 700px) { .staff-details { flex-direction: row; } }

.staff-name { font-weight: 400; }

footer { position: relative; font-size: 1.9rem; }

footer h2 { font-size: 2.5rem; margin: 0 0 30px 0; }

footer .footer-rows { display: flex; flex-direction: column; }

footer .footer-columns { display: flex; flex-flow: wrap; margin: -10px -10px 10px -10px; }

footer .legal-line { width: 100%; margin: 0; }

footer .legal-line a { font-style: italic; }

footer .logo { margin: 0 auto; }

.footer-links { flex: 1 0 180px; margin: 10px; padding: 0; }

.footer-links li { list-style: none; margin: 15px 0; }

.footer-links li a svg { fill: #ffffff; margin-right: 10px; transition: fill 0.2s ease; vertical-align: middle; position: relative; top: -2px; width: 22px; height: 22px; }

.footer-links li a:hover svg { fill: #73a9c9; }

.testimonials { font-size: 1.8rem; display: flex; flex-wrap: wrap; margin: 0 -20px; background-color: #3e3f46; }

.testimonial { flex: 1 0 0%; margin: 0 20px; }

.testimonial-author, .post-summary-author { display: flex; align-items: center; color: #efefef; margin: 25px 20px 20px 20px; }

.testimonial-author img, .post-summary-author img { max-width: 30px; max-height: 30px; border-radius: 50%; margin-right: 10px; position: relative; top: -2px; }

.testimonial-message { font-style: italic; position: relative; }

.testimonial-message::before, .testimonial-message::after { content: " "; position: absolute; transform: translateY(-50%) rotate(45deg); background-color: #fefefe; }

.testimonial-message::before { top: 100%; left: 25px; width: 18px; height: 18px; box-shadow: 1px 1px 5px 0 rgba(100, 100, 100, 0.2); }

.testimonial-message::after { top: 100%; left: 22px; height: 24px; width: 24px; z-index: 1; margin-top: -5px; }

.home-section { margin-bottom: 4rem; display: flex; flex-direction: column; }

.our-approach { margin-top: 4rem; display: flex; flex-direction: column; column-gap: 2rem; }

.our-approach .horiz { display: block; }

.our-approach .vert { display: none; }

@media (min-width: 1000px) { .our-approach { flex-direction: row; } .our-approach .horiz { display: none; } .our-approach .vert { display: block; } }

.why-choose-cards { margin-top: 4rem; display: flex; flex-direction: column; justify-content: space-between; column-gap: 4rem; row-gap: 4rem; }

@media (min-width: 1200px) { .why-choose-cards { flex-direction: row; } }

.why-choose-cards div { flex: 1 1 0px; }

.card-white { border-bottom: dotted white; }

.card-white h4 { white-space: pre; text-wrap: auto; }

@media (min-width: 1000px) { .card-white { border-left: dotted white; border-bottom: 0; padding-left: 2rem; } }

.practice-list { display: flex; flex-wrap: wrap; gap: 4rem; justify-content: space-around; }

.practice-list a { text-decoration: none; }

.practice-area { width: 200px; height: 200px; display: flex; align-items: center; text-align: center; }

.practice-area h3 { width: 100%; text-decoration: none; }

.columns { display: flex; flex-wrap: wrap; margin: 0 -20px; }

.contact-container h3 { margin-bottom: 2rem; margin-top: 2rem; }

@media (min-width: 700px) { .contact-container h3 { text-align: center; } }

.contact-infos { display: flex; flex-direction: column; }

@media (min-width: 700px) { .contact-infos { flex-direction: row; justify-content: space-evenly; } }

.post-list { list-style: none; padding: 0; }

.pagination { margin-top: 30px; display: flex; justify-content: space-around; text-align: center; align-items: center; }

.pagination a, .pagination span { flex: 1; }

.post-comments { margin-top: 20px; }

.post-summary { display: flex; flex-direction: column; }

@media (min-width: 700px) { .post-summary { flex-direction: row; flex-wrap: wrap; } }

.post-summary:not(:last-child) { margin-bottom: 30px; }

.post-summary-excerpt { margin-bottom: 0; }

.post-summary-content.has-post-summary-image { flex: 0 1 75%; }

.post-summary-image { flex: 0 1 25%; box-sizing: border-box; margin-bottom: 15px; }

@media (min-width: 700px) { .post-summary-image { margin-bottom: 0; padding-right: 20px; } }

.post-summary-details { color: #75828a; font-size: 1.9rem; }

.post-summary-author { margin: 1em 0; }

gmp-map { height: 300px; }

.white-bg { background: white !important; color: black !important; }

.white-bg a { color: #373737 !important; }

.white-bg a:hover { color: black !important; }

.btn { font-style: normal; border-radius: 1rem !important; padding: 1rem; text-decoration: none; }

.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0; }

*:focus { outline: 2px solid #132a48; outline-offset: 2px; }

*:focus:not(:focus-visible) { outline: none; }

*:focus-visible { outline: 2px solid #132a48; outline-offset: 2px; }

label { display: block; letter-spacing: 4px; font-size: 1.5rem; }

input, textarea { padding: 10px; margin: 10px 0; box-shadow: 1px 1px 5px 0 rgba(100, 100, 100, 0.2); border: 0; border-radius: 2px; width: 100%; max-width: 500px; margin: 0 0 20px 0; box-sizing: border-box; font-size: 2rem; }

textarea { min-height: 250px; }

input[type=submit] { display: block; }

input[type=submit] { padding: 10px 15px; margin: 0; background-color: #4489b1; font-size: 2rem; color: #fefefe; cursor: pointer; }

input[type=submit]:hover { color: #fefefe; background-color: #73a9c9; }

.form-group { margin-bottom: 1.5rem; }

.form-group label { display: block; margin-bottom: 0.5rem; font-weight: 600; color: #132a48; }

.form-group label.required::after { content: " *"; color: #dc3545; font-weight: bold; }

.form-group input, .form-group textarea { width: 100%; padding: 0.75rem; border: 2px solid #e1e5e9; border-radius: 4px; transition: border-color 0.2s ease, box-shadow 0.2s ease; }

.form-group input:focus, .form-group textarea:focus { outline: none; border-color: #132a48; box-shadow: 0 0 0 3px rgba(19, 42, 72, 0.1); }

.form-group input[aria-invalid="true"], .form-group textarea[aria-invalid="true"] { border-color: #dc3545; box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.1); }

.form-group input::placeholder, .form-group textarea::placeholder { color: #6c757d; opacity: 0.7; }

.form-group textarea { resize: vertical; min-height: 120px; }

.form-group .help-text { display: block; margin-top: 0.25rem; color: #6c757d; line-height: 1.4; }

.submit-btn { background-color: #132a48; color: white; border: none; padding: 0.875rem 2rem; font-weight: 600; border-radius: 4px; cursor: pointer; transition: background-color 0.2s ease, transform 0.1s ease; }

.submit-btn:hover { background-color: #081220; transform: translateY(-1px); }

.submit-btn:focus { outline: none; box-shadow: 0 0 0 3px rgba(19, 42, 72, 0.3); }

.submit-btn:active { transform: translateY(0); }

.submit-btn .button-text { pointer-events: none; }

@media (min-width: 1000px) { .contact-infos { position: sticky; top: 2rem; } }

.contact-infos .contact-info { margin-bottom: 1.5rem; padding: 1rem; background: rgba(255, 255, 255, 0.05); }

@media (min-width: 1000px) { .contact-infos .contact-info { margin-bottom: 2rem; padding: 1.5rem; } }

.contact-infos .contact-info label { display: block; font-weight: 600; color: #132a48; margin-bottom: 0.5rem; text-transform: uppercase; letter-spacing: 1px; }

.contact-infos .contact-info p, .contact-infos .contact-info address { margin: 0; line-height: 1.6; font-weight: 500; }

.contact-infos .contact-info a { color: #132a48; text-decoration: none; transition: color 0.2s ease, transform 0.2s ease; display: inline-block; }

.contact-infos .contact-info a:hover { color: black; text-decoration: underline; transform: translateY(-1px); }

.contact-infos .contact-info a:focus { outline: 2px solid #132a48; outline-offset: 2px; }

#form-title, #contact-info { color: #132a48; margin-bottom: 1rem; }

@media (min-width: 1000px) { #form-title, #contact-info { margin-bottom: 1.5rem; text-align: left; } }

.form-description { margin-bottom: 1.5rem; color: #6c757d; line-height: 1.6; }

@media (min-width: 1000px) { .form-description { margin-bottom: 2rem; } }

#contact-form { display: grid; gap: 1.5rem; grid-template-columns: 1fr; }

@media (min-width: 1000px) { #contact-form { grid-template-columns: 1fr 1fr; gap: 2rem; } #contact-form .form-group:nth-child(4), #contact-form .form-group:last-of-type { grid-column: 1 / -1; } }

@media (min-width: 1200px) { #contact-form { max-width: 800px; gap: 2.5rem; } }

.contact-container { max-width: 1200px; margin: 0 auto; }

@media (min-width: 1000px) { .contact-container { display: grid; grid-template-columns: 1fr 2fr; gap: 4rem; align-items: start; } }

@media (min-width: 1000px) { #intake-form { grid-column: 2; } }

@media (min-width: 1000px) { .contact-infos { grid-column: 1; flex-direction: column; gap: 2rem; } }

@media (max-width: 700px) { .form-group input, .form-group textarea { padding: 0.875rem; font-size: 16px; min-height: 48px; } .form-group label { margin-bottom: 0.75rem; } .submit-btn { width: 100%; padding: 1rem 2rem; min-height: 48px; } .contact-container { padding: 1rem; } }

@media (min-width: 700px) and (max-width: 1000px) { #contact-form { max-width: 600px; margin: 0 auto; } .form-group input, .form-group textarea { padding: 1rem; } .submit-btn { width: auto; min-width: 200px; padding: 1rem 2.5rem; } }

/*# sourceMappingURL=main.css.map */