/***********
*  COLORS  *
***********/
:root {
	--bs-primary: #134068;
	--bs-secondary: #EE8A1E;
	--bs-gray: #737785;
	--bs-primary-rgb: 19,64,105;
	--bs-secondary-rgb: 238,138,30;
}

h1,h2,h3,h4,h5,h6 {
	color: var(--bs-primary);
}

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	margin-bottom: 1rem;
}

a,
.link-primary {
	color: var(--bs-primary);
}

a:hover,
a:focus,
.link-primary:hover,
.link-primary:focus {
	color: var(--bs-secondary);
}

.link-secondary {
	color: var(--bs-secondary);
}

.link-secondary:hover,
.link-secondary:focus {
	color: var(--bs-primary);
}

.light,
.light * {
	color:  white;
}

.dark,
.dark * {
	color: black;
}

.bg-primary {
	background-color: var(--bs-primary);
}

.bg-secondary {
	background-color: var(--bs-secondary);
}

.bg-gray {
	background-color: #f8f8f8;
}

.blocks-overlay {
	background-image: url(/images/2022_design/bg-blocks-overlay.png);
}

/**********
*  FONTS  *
**********/

h1, h2, h3,
figcaption {
	font-family: 'Playfair Display', serif;
}

body,
h4, h5, h6 {
	font-family: 'Inter', sans-serif;
}

h4, h5, h6 {
	font-weight: bold;
}

h6 {
	text-transform: uppercase;
}

h1.fancy:after,
h2.fancy:after,
h3.fancy:after,
h4.fancy:after,
h5.fancy:after,
h6.fancy:after {
	content: "";
	display: block;
	position: absolute;
	width: 1.2rem;
	border-bottom: 2px solid var(--bs-secondary);
}

.stronglinks a {
	text-decoration: none;
	font-weight: bold;
	color: var(--bs-body-color);
	display: inline-block;
}

.stronglinks a:hover {
	color: var(--bs-secondary);
}

a[href^="mailto:"] {
	word-break: break-word;
}

a[href^="tel:"] {
	color: inherit;
}

a[href^="tel:"]:not(:hover) {
	text-decoration: none;
}

/************
*  BUTTONS  *
************/
.btn {
	border: none;
	border-radius: 0;
	text-transform: uppercase;
	font-weight: bold;
	transition: all 0.2s ease;
	padding: 0.75rem 1.5rem;
}

@media (min-width: 992px) {
	.btn {
		min-width: 250px;
	}
}

.btn:hover,
.btn:active,
.btn:focus {
	transform: scale(1.05);
}

.btn-primary {
	background-color: var(--bs-secondary);
}

.btn-primary:hover,
.btn-primary:active,
.btn-primary:focus,
.btn-primary:active:focus {
	background-color: var(--bs-primary);
	box-shadow: none;
}

.btn-secondary {
	background-color: var(--bs-primary);
}

.btn-secondary:hover,
.btn-secondary:active,
.btn-secondary:focus,
.btn-secondary:active:focus {
	background-color: var(--bs-secondary);
	box-shadow: none;
}

.bg-primary .btn-primary:hover,
.bg-primary .btn-primary:active,
.bg-primary .btn-primary:focus,
.bg-primary .btn-primary:active:focus,
.bg-secondary .btn-secondary:hover,
.bg-secondary .btn-secondary:active,
.bg-secondary .btn-secondary:focus,
.bg-secondary .btn-secondary:active:focus {
	background-color: var(--bs-gray);
}



@keyframes wiggle {
	0% { transform: rotate(0deg); }
   50% { transform: rotate(10deg); }
  100% { transform: rotate(0deg); }
}

.wiggle-icon i {
  display: inline-block;
}

.wiggle-icon:hover i {
  animation: wiggle 0.5s infinite;
}


/***********
*  LAYOUT  *
***********/
.main.content-page,
main {
	overflow: hidden;
}

img {
	max-width: 100%;
}

.bg-primary.light iframe[src*="youtube"],
.bg-primary .light iframe[src*="youtube"] {
    border: 3px solid #ee8a1e;
}


blockquote {
	border: 1px solid rgba(0,0,0,.125);
	border-left: 3px solid var(--bs-secondary);
	padding: 1rem;
}

blockquote:before {
    content: "”";
    font-family: 'Playfair Display', serif;
    color: var(--bs-secondary);
    display: block;
    font-size: 6rem;
    line-height: 4rem;
    height: 3rem;
}

blockquote p:last-child,
blockquote ol:last-child,
blockquote ul:last-child {
	margin-bottom: 0;
}

.full-width-content {
	width: 100vw;
	position: relative;
	margin-left: -50vw;
	left: 50%;
}

.gx-6 {
	--bs-gutter-x: 6rem;
}

.pad {
	padding-top: 6rem;
	padding-bottom: 6rem;
}

.pad-top {
	padding-top: 6rem;
}

.pad-bottom {
	padding-bottom: 6rem;
}

.card {
	border-radius: 0;
}

.card-body > p:last-child {
    margin-bottom: 0;
}

.card-header:first-child {
	border-radius: 0;
}

.featured-practice-areas .card {
	border-radius: 0;
	min-height: 100%;
}

li::marker {
	color: var(--bs-secondary);
	font-weight: bold;
}

@media (min-width: 576px) {
	.grid-4 {
		grid-template-columns: 1fr 1fr;
	}
}

@media (min-width: 768px) {
	.grid-4 {
		grid-template-columns: 1fr 1fr 1fr;
	}
}

@media (min-width: 992px) {
	.grid-4 {
		grid-template-columns: 1fr 1fr 1fr 1fr;
	}
}

@media (min-width: 768px) {
	ol.text-cols-2,
	ul.text-cols-2 {
		columns: 2;
		column-gap: 3rem;
	}
}

@media (min-width: 768px) {
	.columns-auto {
		columns: 2;
	}
}

@media (min-width: 992px) {
	.columns-auto {
		columns: 3;
	}
}

.columns-auto > div {
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
	break-inside: avoid;
}

.checklists ul,
ul.checklist {
	list-style: none;
	margin-bottom: 0;
}

.checklists ul li,
ul.checklist li {
	margin-bottom: 1rem;
	position: relative;
}

.checklists ul li:before,
ul.checklist li:before {
	font-family: bootstrap-icons !important;
	content: "\F26A";
	color: var(--bs-secondary);
	line-height: 1;
	/*position: relative;
	top: 0.125rem;
	margin-left: -2rem;
	margin-right: 0.75rem;*/
	position: absolute;
	top:  0.25rem;
	left: -2rem;
}

.carousel-indicators [data-bs-target] {
	transition: all 0.6s ease;
}

.carousel-indicators .active {
	width: 60px;
}

.carousel-control-prev-icon.bi,
.carousel-control-next-icon.bi {
	background-image: none;
	font-size: 1.8rem;
	line-height: 0.9rem;
	border-radius: 50%;
	border: 0.1rem solid white;
	color: white;
}

@media (min-width: 1032px) {
	.carousel-control-next.outset {
		width: auto;
		right: -2.75em;
	}

	.carousel-control-prev.outset {
		width: auto;
		left: -2.75em;
	}
}

@media (max-width: 767px) {
	.carousel-control-next,
	.carousel-control-prev {
		width: 10%;
	}
}

/***********
*  HEADER  *
***********/
.location-button {
	text-decoration: none;
	padding: 0px 5px;
	margin: 0 2px;
	color: white;
	background-color: var(--bs-primary);
	transition: all 0.1s ease;
}

.location-button:hover {
	transform: scale(1.05);
	color: white;
}

.phone {
	text-decoration: none;
	color: var(--bs-primary);
	font-size: 1.5rem;
	font-weight: bold;
	white-space: nowrap;
}

.phone:hover,
.phone:focus {
	color: var(--bs-secondary);
}

header a.social-icon {
	color: var(--bs-primary);
	background-color: #d9d2c1;
	border-color: transparent;
}

.navbar-dark .navbar-nav .nav-link {
	color: white;
	text-transform: uppercase;
}

.nav-link.active {
	border-bottom: 2px solid white;
	padding-bottom: 6px;
}

.navbar-nav {
	width: 100%;
	justify-content: space-between;
}

.dropdown-menu {
	border-radius: 0;
}

.dropdown > .dropdown-menu {
	border-top: 0;
}

.dropdown-menu[data-bs-popper] {
	margin-top: 8px;
}

.dropdown-item {
	line-height: 1.3;
	padding: 0.35rem 1rem 0.35rem 1rem;
}

/*ul.dropdown-menu {
	max-width: 300px;
}*/

/* SubSub Menus */

@media (max-width:  991px) {
	.navbar-expand-lg .container-md {
		max-width: 420px;
	}
}
@media (min-width: 992px) {
	nav a[href="/practiceareas"] + ul.dropdown-menu li a {
		width: 300px;
		white-space: normal;
	}

	nav a[href="/practiceareas"] + .dropdown-menu > li:nth-last-child(1):hover ul,
	nav a[href="/practiceareas"] + .dropdown-menu > li:nth-last-child(2):hover ul,
	nav a[href="/practiceareas"] + .dropdown-menu > li:nth-last-child(3):hover ul,
	nav a[href="/practiceareas"] + .dropdown-menu > li:nth-last-child(4):hover ul,
	nav a[href="/practiceareas"] + .dropdown-menu > li:nth-last-child(5):hover ul {
		top: unset;
		bottom: -9px;
	}

	.dropdown-menu > li {
		position: relative;
	}

	.dropdown-menu > li:hover ul {
		display: block;
		left: 100%;
		top: -9px;
		border-left-color: #d9d9d9;
	}

	.dropdown-submenu .dropdown-item {
		padding-right: 1.75rem;
	}

	.dropdown-submenu:after {
		content: "";
		position: absolute;
		right: 5px;
		top: 12px;
		border: 0.3em solid transparent;
		border-left-color: black;
	}

	.dropdown-submenu:hover > .dropdown-item {
		background-color: #e9ecef;
	}
}

/***********
*  FOOTER  *
***********/
footer {
	border-top: 5px solid var(--bs-secondary);
}

footer nav a {
	text-decoration: none;
	font-weight: bold;
	color: black;
}

footer nav a.active, footer nav a:hover {
	color: var(--bs-secondary);
}

a.social-icon {
	text-decoration: none;
	display: inline-block;
	height: 32px;
	width: 32px;
	line-height: 16px;
	padding: 7px;
	border: 1px solid #4c4c4c;
	border-radius: 50%;
	background-color: white;
	color: #4c4c4c;
	transition: all 0.2s ease;
}

a.social-icon:hover {
	background-color: var(--bs-secondary);
	border-color: var(--bs-secondary);
	color: white;
}

/***********
*  BANNER  *
***********/
.banner {
	padding: 12vh 10vw;
	text-align: center;
	background-color: var(--bs-primary);
	background-size: cover;
	background-position: center;
}

@media (min-width: 1200px) {
	.banner h1,
	.banner .h1 {
		font-size: 3.5rem;
	}
}

.banner * {
	color: white;
}

.banner.overlay,
.banner.overlay .container {
	position: relative;
}

.banner.overlay:before {
	content: "";
	background-color: #000;
	opacity: 0.2;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	left: 0;
}

/*.big-banner {
	padding: 15vw 10vw;
}*/

/************
*  LINEBOX  *
************/
.linebox,
.linebtn {
	overflow: visible;
	position: relative;
}

.linebox:after,
.linebtn:after {
	content: "";
	display: block;
	position: absolute;
	border: 1px solid #555;
	pointer-events: none;
	mix-blend-mode: difference;
}

.linebox:after {
	height: calc(100% + 20px );
	width: calc(100% - 20px );
	top: -10px;
	left: 10px;
}

.linebtn:after {
	height: calc(100% + 10px );
	width: calc(100% - 10px );
	top: -5px;
	left: 5px;
	transition: all 0.2s ease;
	border-color: var(--bs-secondary);
	mix-blend-mode: multiply;
}

.linebtn:hover:after,
.linebtn:focus:after {
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	border-color: transparent;
}

img.lined {
	outline: 1px solid white;
	outline-offset: -10px;
}

.thumbnail img.lined,
img.thumbnail.lined {
	outline-offset: -5px;
}


.line-connect {
	position: relative;
}

.line-connect:after {
	content: "";
	position: absolute;
	background-color: var(--bs-secondary);
	width: 3px;
	height: 100px;
	bottom:  -50px;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 1;
}

/*****************************
*  IMAGE WITH FANCY CAPTION  *
*****************************/
figure {
	overflow: visible;
	position: relative;
	margin-bottom: 40px;
	z-index: 1;
}

figure img {
	outline: 1px solid white;
	outline-offset: -10px;
}

figcaption {
	color: white;
	font-size: 2em;
}

figcaption.left,
figcaption.right {
	padding-left: 20px;
}

figcaption.left:after,
figcaption.right:after {
	content: "";
	display: block;
	position: absolute;
	z-index: -1;
	bottom: -40px;
	height: 300px;
	width: 100vw;
	background-image: url(/images/2022_design/bg-blocks-overlay.png);
}

figcaption.left {
	border-left: 3px solid var(--bs-secondary);
	margin: 40px 100px 40px 0px;
}

figcaption.left:after {
	background-color: var(--bs-primary);
	right: 60px;
}

figcaption.right {
	border-left: 3px solid var(--bs-primary);
	margin: 40px 40px 40px 100px;
}

figcaption.right:after {
	background-color: var(--bs-secondary);
	left: 60px;
}

/*****************
*  TESTIMONIAL   *
*****************/
.testimonial {
	border: 2px solid white;
	padding: 1.5rem;
	margin-top: 4.5rem;
}

.carousel-item .testimonial {
	margin: 4.5rem 15% 0;
}

.testimonial-body {
	background-color: white;
	padding: 3rem;
	text-align: center;
	margin-top: -6rem;
}

/*.testimonial-body:before {
	content: "”";
	font-family: 'Playfair Display', serif;
	color: var(--bs-secondary);
	display: block;
	font-size: 6rem;
	line-height: 4rem;
	height: 3rem;
}*/

.testimonial blockquote {
	padding: 0;
	border: none;
}

.testimonial .source {
	display: flex;
	justify-content: center;
	align-content: center;
}

.testimonial .thumbnail {
	box-sizing: content-box;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	border:  2px solid var(--bs-secondary);
	margin-right: 12px;
	object-fit: cover;
}

.testimonial .author {
	text-align: left;
}

.testimonial .name {
	font-family: 'Playfair Display', serif;
	color: var(--bs-primary);
}

@media (max-width: 767px) {
	.testimonial {
		padding: 0.5rem;
	}

	.testimonial-body {
		padding: 2rem;
		margin-top: -5rem;
	}

	.carousel-item .testimonial {
		margin: 4.5rem 11% 0;
	}
}

/******************
*  FEATURED BLOG  *
******************/
.home .news .article-thumbnail-banner,
.home .news .article-thumbnail-attorney {
	padding-bottom: 100%;
	background-size: cover;
	background-position: top center;
}

.home .news a {
	text-decoration: none;
}

.home .news .meta {
	padding: 1rem 1rem 1rem 0;
}

.home .news .date {
	text-transform: uppercase;
	color: var(--bs-gray);
}

.home .news .title {
	margin: 1rem 0;
	color: black;
}

.home .news .article:not(.featured) {
	border: 2px solid #eee;
}

.home .news .article.featured .row {
	flex-direction: column;
	position: relative;
}

.home .news .article.featured .date,
.home .news .article.featured .title {
	color: white;
}

.home .news .article.featured .meta {
	position: absolute;
	background-color: var(--bs-primary);
	background-image: url(/images/2022_design/bg-blocks-overlay.png);
	color: white;
	padding: 1rem 2rem;
	bottom: 2rem;
	left: 0;
	width: 90%;
	opacity: 0.9;
}

@media (min-width: 576px) {
	.home .news .article.featured .meta {
		left: -2rem;
		opacity: 1;
	}
}

.home .news .article.featured a {
	color: white;
}

.home .news .article:nth-child(2) {
	margin-top: 20px;
}

/******************************
*  HOMEPAGE FOOTER LOCATIONS  *
******************************/
.locations > div > div {
	display: flex;
	margin: 0.5rem 0;
}

.locations .bi {
	margin-right: 1rem;
}

.locations a {
	text-decoration: none;
}

/*.locations > div:nth-child(2) {
	border-style: solid;
	border-width: 0 1px;
	border-color: white;
}*/

@media (max-width:  767px) {
	.locations > div:nth-child(2) {
		border-width: 0;
		/*padding-top: 2rem;
		padding-bottom: 2rem;*/
	}
}

/******************
*  PROFESSIONALS  *
******************/
.professional-list {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.professional-list-item {
	text-align: center;
	width: 185px;
	padding: 1rem;
}

.hover-scale {
	transition: all 0.2s ease;
}

.hover-scale:hover {
	transform: scale(1.05);
}

@media (max-width: 767px) {
	.professional-list-item {
		width: 128px;
		padding: 0.5rem;
		font-size: 14px;
	}
}

.professional-list-item a {
	text-decoration: none;
}

.professional-list-item img {
	max-width: unset;
	width: 100%;
}

.professional-list-item .name {
	background-color: #134069;
	color: white;
	min-height: 48px;
	padding: 0 5px;
	display: flex;
	align-items: center;
	justify-content: center;
}

a.filter.dropdown-item {
	cursor: pointer;
}

/*********************
*  RESOURCES & NEWS  *
*********************/
.article-grid {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	grid-gap: 50px 30px;
}

@media (max-width: 991px) {
	.article-grid {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 767px) {
	.article-grid {
		grid-template-columns: 1fr;
	}
}

.article-grid .article {
	transition: all 0.2s ease;
}

@media (min-width: 768px) {
	.main.news .article-grid .article:first-child {
		grid-column: 1/3;
	}
}

.article-grid .article:hover {
	transform: scale(1.02);
}

.article-grid .date-ribbon {
	background-color: var(--bs-secondary);
	color: white;
	font-weight: bold;
	font-size: 14px;
	line-height: 1;
	padding: 4px 8px 4px 16px;
	position: absolute;
	left: 0;
	top: 39px;
	z-index: 1;
}

.article-grid .article-thumbnail,
.article-grid .article-thumbnail-attorney {
	display: inline-block;
	background-size: cover;
	background-position: center top;
	background-color: white;
	padding: 0 !important;
	border-radius: 50%;
	border: 3px solid var(--bs-secondary);
	width: 100px !important;
	height: 100px !important;
	margin-top: calc(-1.4rem - 50px);
	margin-bottom: 1rem;
}

@media (min-width: 1200px) {
	.article-grid .article-thumbnail,
	.article-grid .article-thumbnail-attorney {
		width: 120px !important;
		height: 120px !important;
		margin-top: calc(-1.4rem - 60px);
	}
}

/****************************
*  VIDEOS & PODCASTS MEDIA  *
****************************/
.mediaPreview {
    border: 3px solid #ee8a1e;
    display: block;
    position: relative;
}

.mediaPreview:after {
    position: absolute;
    inset: calc(50% - 30px);
    width: 60px;
    height: 60px;
    font-size: 40px;
    line-height: 40px;
    padding: 6px 6px 6px 8px;
    border: 4px solid white;
    border-radius: 50%;
    font-family: bootstrap-icons !important;
    content: "\F4F4";
    color: white;
    background-color: var(--bs-secondary);
    transition: all 0.2s ease;
}

.mediaPreview:hover:after {
    transform: scale(0.9);
}