/* ===================================
    Iliescu
====================================== */
/* font */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,600;1,700;1,800;1,900&display=swap');
/* variable */
:root {     
    --base-color: #a32d24;  
    --dark-gray: #152833;
    --medium-gray: #898d95;
    --very-light-gray: #f6f3ef;
    --alt-font: 'Playfair Display', serif;
    --primary-font: 'DM Sans', sans-serif;
}  
body {
    font-size: 17px;
    line-height: 32px;
}
/* custom cursor */
.custom-cursor .circle-cursor-inner {
    background-color: var(--base-color);
    width: 10px;
    height: 10px;
}
.custom-cursor .circle-cursor-inner.cursor-link-hover {
    background-color: var(--base-color);
}
.custom-cursor .circle-cursor-outer {
    border: 1px solid transparent;
}
/* header */
header .navbar-brand {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    width: 100px;
    min-width: 100px;
}
header .navbar-brand img {
    max-height: 36px;
    height: 36px;
    width: auto;
    display: block;
    object-fit: contain;
}
header .navbar-brand .default-logo,
header .navbar-brand .alt-logo,
header .navbar-brand .mobile-logo {
    max-height: 36px;
    height: 36px;
    width: auto;
}
header .left-nav .navbar-nav:before {
    background-color: var(--white);
    opacity: 0.2; 
    transform: translate(-28px, 0px);
    -webkit-transform: translate(-28px, 0px);
    transition: 0s;
}
header.sticky .left-nav .navbar-nav:before {
    transform: translate(-28px, 0px);
    -webkit-transform: translate(-28px, 0px);
}
.navbar .navbar-nav .nav-link { 
    font-size: 18px;
    font-weight: 400; 
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
    border-bottom: 1px solid #f6f3ef;
    padding: 16px 20px;
    font-weight: 500;
    font-size: 16px;
    color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:hover img {
    filter: invert(100%) sepia(100%) saturate(0%) hue-rotate(288deg) brightness(502%) contrast(502%);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a:hover,
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active:hover > a{
    background-color: var(--base-color);
    color: var(--white);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active > a {
    color: var(--medium-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu {
    width: 330px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a {
    color: var(--dark-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a p {
    line-height: 22px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a img {
    width: 65px;
}
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li.active > a,
.navbar .navbar-nav .dropdown.dropdown-with-icon .dropdown-menu li a:hover {
    color: var(--medium-gray);
}
.navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a img {
    width: 40px;
    margin-right: 10px;
}
/* pagination */
.pagination-style-01 .page-item.active .page-link,
.pagination-style-01 .page-item .page-link:hover {
    background: var(--dark-gray);
    color: var(--white);
}
.pagination-style-01 .page-item:first-child .page-link,
.pagination-style-01 .page-item:last-child .page-link {
    background: transparent;
    box-shadow: none !important;
}
.pagination-style-01 .page-item:first-child .page-link:hover,
.pagination-style-01 .page-item:last-child .page-link:hover {
    color: var(--dark-gray);
}
/* input */
.input-small, .textarea-small {
    font-size: 14px;
}
/* bg color */
.bg-blue-whale {
    background-color: #152833;
}
.bg-blue-licorice {
    background-color: #374b57;
}
/* bg gradient transparent */
.bg-gradient-dark-transparent {
    background: -webkit-gradient(linear, left bottom, left top, color-stop(7%, #0a171e), to(transparent));
    background: linear-gradient(to top, #0a171e 7%, transparent 70%);
}
/* btn */
.btn.btn-blue-whale {
    background-color:#152833; 
    color: var(--white);
}
.btn.btn-blue-whale:hover {
    background-color: transparent;
    border-color: #152833;
    color: #152833;
}
.btn {
    font-family: var(--primary-font);
    font-weight:500;
    text-transform: inherit;
    letter-spacing: 0px;
}
.btn.btn-link {
    padding: 0 0 2px; 
}
.btn.btn-rounded.btn-extra-large {
    padding: 18px 66px 18px 40px;
    font-size: 17px;
}
.btn.btn-rounded.btn-large {
    padding: 16px 55px 16px 38px;
    font-size: 16px;
}
.btn.btn-large {
    font-size: 15px;
}
/* number pagination style 01 */
.swiper-number-pagination-style-01 .swiper-number .swiper-pagination-bullet {
    font-size: 14px;
}
.process-step-style-02:hover .process-step-icon .number {
    color: var(--white);
}
/* page title */
.page-title-large h1 {
    font-size: 4rem;
    line-height: 3.9rem;
}
/* process step style 03 */
.process-step-style-03:hover .process-step-icon-box .progress-image {
    -webkit-transform: scale(1.3); 
    transform: scale(1.3);
}
/* social icon style 02 */
.social-icon-style-02 .small-icon li {
    margin: 0;
}
/* opacity */
.opacity-05 {
    opacity: 0.05;
}
/* top right bottom left */
.top-minus-35px {
    top: -35px;
}
.left-minus-35px {
    left: -35px;
}
.bottom-minus-35px {
    bottom: -35px;
}
/* footer */
footer .footer-logo {
    display: inline-block;
    min-height: 36px;
    min-width: 120px;
}
footer .footer-logo img {
    max-height: 36px;
    height: 36px;
    width: auto;
    display: block;
    object-fit: contain;
}
.footer-dark {
    color: #768086;
}
.footer-dark p, .footer-dark a {
    color: #768086;
}
.is-touchable .cursor-page-inner {
    display: none !important;
}
/* media query responsive */
@media (max-width: 1400px) {
    .xl-min-h-270px {
        min-height: 270px !important;
    }
}
@media (max-width: 1300px) {
    .navbar .navbar-nav .nav-link {
        padding-left: 15px;
        padding-right: 15px;
    }
}
@media (max-width: 1199px) {
    header .left-nav .navbar-nav:before {
        transform: translate(-10px, 0px);
        -webkit-transform: translate(-10px, 0px);
    }
    header.sticky .left-nav .navbar-nav:before {
        transform: translate(-10px, 0px);
        -webkit-transform: translate(-10px, 0px);
    }
    .elements-social .large-icon li {
        margin: 0 5px;
    }
    footer .nav-link {
        padding-left: .6rem;
        padding-right: .6rem;
    }
    .navbar .navbar-nav .nav-link {
        padding-left: 10px;
        padding-right: 10px;
    }
}
@media (max-width: 1024px) {
    .navbar .navbar-nav .nav-link {
        padding-left: 8px;
        padding-right: 8px;
    }
}
@media (max-width: 991px) {
    header .widget-text {
        color: var(--dark-gray);
    }
    header .widget-text i {
        color: var(--white);
    }
    .md-bottom-minus-15px {
        bottom: -15px;
    }
    .elements-social.social-icon-style-04 .large-icon a {
        font-size: 21px;
        width: 50px;
        height: 50px;
    }
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a {
        padding-left: 0;
        padding-right: 0;
    }
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a:hover,
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li:hover img{
        background-color: transparent;
        color: var(--dark-gray);
        filter: inherit;
    }
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li a:hover,
    .navbar .navbar-nav .dropdown.dropdown-with-icon-style02 .dropdown-menu li.active:hover > a {
        background-color: transparent;
        color: var(--medium-gray);        
    }
}
@media (max-width: 767px) {
    .sm-top-minus-25px {
        top: -25px;
    }
    .process-step-style-02 .progress-step-separator,
    .process-step-style-03 .progress-step-separator,
    .process-step-style-04 .progress-step-separator {
        display: block;
    }
}
@media (max-width: 575px) {
    .process-step-style-02 .progress-step-separator,
    .process-step-style-03 .progress-step-separator,
    .process-step-style-04 .progress-step-separator {
        display: none;
    }
}

/* ─── Blog post content typography ───────────────────────────────────────── */
.post-content {
    font-size: 17px;
    line-height: 1.9;
    color: #4d5860;
    text-align: left;
}
.post-content p {
    margin-bottom: 1.4rem;
}
.post-content h1,
.post-content h2,
.post-content h3,
.post-content h4,
.post-content h5,
.post-content h6 {
    font-family: var(--alt-font);
    color: var(--dark-gray);
    font-weight: 600;
    line-height: 1.25;
    margin-top: 2.2rem;
    margin-bottom: 0.9rem;
}
.post-content h1 { font-size: 2rem; }
.post-content h2 { font-size: 1.65rem; }
.post-content h3 { font-size: 1.35rem; }
.post-content h4 { font-size: 1.15rem; }
.post-content h5 { font-size: 1rem; }
.post-content h6 { font-size: 0.9rem; text-transform: uppercase; letter-spacing: 0.05em; }
.post-content ul,
.post-content ol {
    padding-left: 1.6rem !important;
    margin-bottom: 1.4rem !important;
}
.post-content ul { list-style-type: disc !important; }
.post-content ol { list-style-type: decimal !important; }
.post-content li {
    display: list-item !important;
    list-style: inherit !important;
    margin-bottom: 0.45rem !important;
    line-height: 1.75 !important;
    padding-left: 0 !important;
}
.post-content ul ul,
.post-content ol ol,
.post-content ul ol,
.post-content ol ul {
    margin-top: 0.4rem !important;
    margin-bottom: 0.4rem !important;
}
.post-content a {
    color: var(--base-color);
    text-decoration: underline;
    text-underline-offset: 3px;
    text-decoration-thickness: 1px;
}
.post-content a:hover {
    color: var(--dark-gray);
}
.post-content strong,
.post-content b {
    font-weight: 700;
    color: var(--dark-gray);
}
.post-content em,
.post-content i {
    font-style: italic;
}
.post-content blockquote {
    border-left: 4px solid var(--base-color);
    background-color: var(--very-light-gray);
    padding: 1.2rem 1.6rem;
    margin: 2rem 0;
    border-radius: 0 4px 4px 0;
    font-style: italic;
    font-size: 1.05rem;
    line-height: 1.75;
    color: var(--dark-gray);
}
.post-content blockquote p:last-child { margin-bottom: 0; }
.post-content hr {
    margin: 2.5rem 0;
    border: 0;
    border-top: 1px solid #e2ddd8;
}
.post-content img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
    margin: 1.5rem 0;
}
.post-content table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 1.4rem;
    font-size: 15px;
}
.post-content table th,
.post-content table td {
    padding: 10px 14px;
    border: 1px solid #ddd;
    text-align: left;
}
.post-content table th {
    background-color: var(--very-light-gray);
    font-weight: 600;
    color: var(--dark-gray);
}

/* Hero: mobile blur overlay and centered content */
.hero-mobile-blur-overlay {
    position: absolute;
    inset: 0;
    z-index: 0;
    background: rgba(21, 40, 51, 0.45);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
}
.full-screen.cover-background .container.position-relative {
    z-index: 1;
}

/* Hero: align background image to the right */
section.p-0.bg-dark-gray .full-screen.cover-background {
    background-position: right center !important;
}

/* Hero slider: on mobile, align background image to the right */
@media (max-width: 767px) {
    section.bg-dark-gray .swiper-slide.cover-background {
        background-position: right center !important;
    }
}

/* Practice areas slider: fixed icon size and padding in circle */
.pa-slider-icon {
    width: 40px;
    height: 40px;
    object-fit: contain;
    flex-shrink: 0;
}

/* ─── Mobile nav actions: visible on any menu background ───────────── */
@media (max-width: 991.98px) {
    header .navbar-collapse .mobile-nav-actions {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        margin: 0 10px 20px 10px;
        padding: 1rem 15px 1.25rem;
        background-color: var(--dark-gray);
        border-radius: 6px;
        border-top: 1px solid rgba(255, 255, 255, 0.15);
    }
    header .navbar-collapse .mobile-nav-actions a:not(.btn),
    header .navbar-collapse .mobile-nav-actions a span {
        color: #fff !important;
        opacity: 1 !important;
    }
    header .navbar-collapse .mobile-nav-actions .btn {
        opacity: 1 !important;
    }
    header .navbar-collapse .mobile-nav-actions .btn-outline-light {
        border-color: rgba(255, 255, 255, 0.8) !important;
        color: #fff !important;
    }
    header .navbar-collapse .mobile-nav-actions .btn-outline-light:hover {
        background-color: rgba(255, 255, 255, 0.15);
        color: #fff;
    }
}

/* ─── Consultation Modal: visible buttons on mobile ───────────────── */
#consultation-modal.modal.show {
    z-index: 1060;
}
@media (max-width: 767.98px) {
    #consultation-modal .modal-dialog {
        margin: 16px 20px;
        max-width: calc(100% - 40px);
    }
    #consultation-modal .modal-content {
        background-color: #fff;
    }
    #consultation-modal .btn-close {
        background-color: rgba(0, 0, 0, 0.5);
        opacity: 1;
        padding: 0.5rem;
        border-radius: 0.25rem;
    }
    #consultation-modal .btn-close:hover {
        background-color: rgba(0, 0, 0, 0.7);
    }
    #consultation-modal #consultation-submit {
        background-color: var(--dark-gray) !important;
        color: #fff !important;
        border: none !important;
    }
}

/* ─── Consultation Modal Inputs ──────────────────────────────────── */
#consultation-modal .form-control {
    border: 1px solid #d5d0ca !important;
    background-color: #fff !important;
}
#consultation-modal .form-control:focus {
    border-color: var(--base-color) !important;
    box-shadow: 0 0 0 3px rgba(163, 45, 36, 0.12) !important;
    background-color: #fff !important;
    outline: none !important;
}
