/* Collection-inspired theme for Involvia company profile */
:root {
    --bs-primary: #605dff;
    --bs-primary-rgb: 96, 93, 255;
    --bs-secondary: #3a4252;
    --bs-secondary-rgb: 58, 66, 82;
    --bs-success: #4f8dff;
    --bs-info: #2db6f5;
    --bs-warning: #7a5cff;
    --bs-danger: #605dff;
    --bs-body-bg: #f6f7f9;
    --bs-body-color: #64748b;
    --bs-border-color: #eceef2;
    --involvia-hero-gradient: linear-gradient(
        130deg,
        rgba(73, 54, 245, 0.2) 0%,
        rgba(96, 93, 255, 0.16) 48%,
        rgba(145, 53, 232, 0.16) 100%
    );
    --involvia-surface-gradient: linear-gradient(
        180deg,
        #f7f8ff 0%,
        #f3f5ff 52%,
        #f8f6ff 100%
    );
}

html {
    scroll-behavior: smooth;
}

body {
    background: var(--involvia-surface-gradient);
    color: var(--bs-body-color);
}

.banner-area,
.page-banner-area,
.footer-area {
    position: relative;
    overflow: hidden;
}

.banner-area,
.page-banner-area {
    background-image: linear-gradient(130deg, #eef2ff 0%, #ebedff 48%, #f1ebff 100%) !important;
}

.banner-area::before,
.page-banner-area::before,
.footer-area::before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--involvia-hero-gradient);
    pointer-events: none;
    z-index: 0;
}

.banner-area::before {
    background-size: 180% 180%;
    animation: involviaGradientShift 11s ease-in-out infinite;
}

.banner-area > .container,
.page-banner-area > .container,
.footer-area > .container {
    position: relative;
    z-index: 1;
}

.navbar .nav-link.active,
.navbar .nav-link:hover {
    color: var(--bs-primary) !important;
}

.navbar .navbar-brand img {
    display: block;
    height: 44px;
    width: auto;
    max-width: min(42vw, 210px);
}

.navbar.sticky .navbar-brand img {
    height: 40px;
}

@media only screen and (max-width: 991px) {
    .navbar .navbar-brand img,
    .navbar.sticky .navbar-brand img {
        height: 34px;
        max-width: min(54vw, 170px);
    }
}

.default-btn.bg-primary,
.bg-primary.default-btn {
    background: linear-gradient(135deg, #605dff 0%, #4936f5 100%) !important;
}

.default-btn.bg-danger,
.bg-danger.default-btn {
    background: linear-gradient(135deg, #605dff 0%, #4936f5 100%) !important;
}

.default-btn.bg-warning,
.bg-warning.default-btn {
    background: linear-gradient(135deg, #7a5cff 0%, #9135e8 100%) !important;
}

.section-title h2 span,
.banner-content h1 span,
.about-content h2 span {
    background: linear-gradient(135deg, #605dff 0%, #2db6f5 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
}

.top-title {
    color: #4936f5;
}

.banner-area + .about-area {
    padding-top: clamp(84px, 9vw, 150px);
}

.portfolio-card,
.services-single-item,
.pricing-single-item,
.accordion-item {
    border: 1px solid rgba(96, 93, 255, 0.08);
    box-shadow: 0 10px 30px rgba(58, 66, 82, 0.06);
}

.services-details-sidebar a.active {
    color: var(--bs-primary) !important;
}

.services-details-sidebar a.active i {
    transform: translateX(2px);
}

.blog-preview-card {
    border: 1px solid rgba(96, 93, 255, 0.08);
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 10px 30px rgba(58, 66, 82, 0.06);
    padding: 10px;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.blog-preview-card:hover {
    transform: translateY(-4px);
}

.blog-preview-card.active {
    border-color: rgba(96, 93, 255, 0.45);
    box-shadow: 0 14px 34px rgba(73, 54, 245, 0.15);
}

/* About image composition refinements */
.about-area .position-sticky {
    top: 56px !important;
}

.about-area .row {
    --bs-gutter-x: 2.2rem;
}

.about-img-wrap {
    padding: 0;
    margin-right: 0;
    overflow: visible;
}

.about-img-wrap .about-img {
    width: 100%;
    max-width: 100%;
    display: block;
    margin: 0;
    border-radius: 22px;
    box-shadow: 0 20px 42px rgba(28, 33, 82, 0.14);
    position: relative;
    z-index: 2;
}

.about-img-wrap .net-profit {
    top: 12px;
    right: 12px;
    width: min(30%, 210px);
    z-index: 3;
    box-shadow: 0 14px 28px rgba(28, 33, 82, 0.14);
    opacity: 0.96;
}

.about-img-wrap .activity {
    bottom: 14px;
    right: 12px;
    width: min(24%, 165px);
    z-index: 3;
    box-shadow: 0 14px 28px rgba(28, 33, 82, 0.12);
    opacity: 0.96;
}

.about-img-wrap .dots {
    top: -22px;
    left: -58px;
    width: min(34%, 210px);
    z-index: 1;
    opacity: 0.28;
}

@media only screen and (max-width: 1399px) {
    .about-area .position-sticky {
        top: 36px !important;
    }

    .about-img-wrap {
        margin-right: 0;
    }

    .about-img-wrap .net-profit {
        right: 10px;
        width: min(29%, 195px);
    }

    .about-img-wrap .activity {
        right: 10px;
        width: min(22%, 145px);
    }

    .about-img-wrap .dots {
        left: -34px;
        width: min(30%, 180px);
    }
}

@media only screen and (max-width: 1199px) {
    .about-img-wrap {
        margin-right: 0;
    }

    .about-img-wrap .about-img {
        width: 100%;
        max-width: 100%;
    }

    .about-img-wrap .net-profit {
        top: 8px;
        right: 10px;
    }

    .about-img-wrap .activity {
        bottom: 10px;
        right: 10px;
    }
}

@media only screen and (max-width: 991px) {
    .banner-area + .about-area {
        padding-top: 54px;
    }

    .about-area .position-sticky {
        position: relative !important;
        top: 0 !important;
    }

    .about-img-wrap .net-profit,
    .about-img-wrap .activity,
    .about-img-wrap .dots {
        display: none !important;
    }
}

/* Hero banner image composition override for replaced assets */
.banner-img-wrap {
    max-width: min(1220px, 94vw);
    margin: 28px auto 0;
}

.banner-img-wrap::after {
    content: "";
    position: absolute;
    width: clamp(220px, 35vw, 460px);
    height: clamp(220px, 35vw, 460px);
    left: 50%;
    top: 48%;
    transform: translate(-50%, -50%);
    background: radial-gradient(circle, rgba(96, 93, 255, 0.28) 0%, rgba(145, 53, 232, 0.1) 45%, rgba(145, 53, 232, 0) 75%);
    filter: blur(42px);
    z-index: -1;
    pointer-events: none;
    animation: involviaOrbMove 9s ease-in-out infinite;
}

.banner-img-wrap .mw-900 {
    max-width: 980px;
    height: auto;
    min-height: 0;
}

.banner-img-wrap .banner-img-one {
    max-width: 980px;
    margin-top: 28px;
    top: 0;
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 22px 48px rgba(24, 29, 74, 0.18);
    animation: involviaMainFloat 4.2s ease-in-out infinite;
    will-change: transform, box-shadow;
}

.banner-img-wrap .banner-img-one img {
    width: 100%;
    display: block;
    object-fit: cover;
}

.banner-img-wrap .banner2,
.banner-img-wrap .banner3,
.banner-img-wrap .banner4 {
    border-radius: 18px;
    box-shadow: 0 16px 34px rgba(28, 33, 82, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.62);
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    transform-style: preserve-3d;
    image-rendering: auto;
    filter: saturate(1.04) contrast(1.03);
    opacity: 0.97;
    will-change: transform;
}

.banner-img-wrap .banner2 {
    width: clamp(150px, 16vw, 260px);
    left: 2%;
    top: 110px;
    transform: rotate(-12deg);
    animation: involviaCardFloatLeft 4.2s ease-in-out infinite, involviaCardPulse 3.4s ease-in-out infinite;
}

.banner-img-wrap .banner3 {
    width: clamp(95px, 9vw, 145px);
    right: 4%;
    top: 112px;
    transform: rotate(-14deg);
    animation: involviaCardFloatTopRight 4.8s ease-in-out infinite, involviaCardPulse 3.8s ease-in-out infinite;
}

.banner-img-wrap .banner4 {
    width: clamp(150px, 17vw, 260px);
    right: 2%;
    bottom: -34px;
    transform: rotate(12deg);
    animation: involviaCardFloatBottomRight 5.1s ease-in-out infinite, involviaCardPulse 4.1s ease-in-out infinite;
}

.banner-img-wrap.active .banner-img-one {
    max-width: 980px;
    top: 0;
}

.banner-img-wrap.active .banner2 {
    transform: rotate(-10deg);
}

.banner-img-wrap.active .banner3 {
    transform: rotate(-12deg);
}

.banner-img-wrap.active .banner4 {
    transform: rotate(10deg);
}

@media only screen and (max-width: 1199px) {
    .banner-img-wrap .mw-900 {
        max-width: 900px;
    }

    .banner-img-wrap .banner-img-one {
        max-width: 900px;
    }

    .banner-img-wrap .banner2 {
        left: -1%;
        top: 95px;
    }

    .banner-img-wrap .banner3 {
        right: 2%;
        top: 94px;
    }

    .banner-img-wrap .banner4 {
        right: -1%;
        bottom: -28px;
    }
}

@keyframes involviaGradientShift {
    0% {
        background-position: 0% 50%;
    }
    50% {
        background-position: 100% 50%;
    }
    100% {
        background-position: 0% 50%;
    }
}

@keyframes involviaMainFloat {
    0% {
        transform: translate3d(0, 0, 0);
        box-shadow: 0 22px 48px rgba(24, 29, 74, 0.16);
    }
    25% {
        transform: translate3d(0, -9px, 0) scale(1.004);
        box-shadow: 0 27px 56px rgba(24, 29, 74, 0.22);
    }
    50% {
        transform: translate3d(0, -15px, 0) scale(1.01);
        box-shadow: 0 32px 66px rgba(24, 29, 74, 0.28);
    }
    75% {
        transform: translate3d(0, -7px, 0) scale(1.004);
        box-shadow: 0 27px 56px rgba(24, 29, 74, 0.22);
    }
    100% {
        transform: translate3d(0, 0, 0);
        box-shadow: 0 22px 48px rgba(24, 29, 74, 0.16);
    }
}

@keyframes involviaCardFloatLeft {
    0% {
        transform: rotate(-12deg) translate3d(0, 0, 0);
    }
    25% {
        transform: rotate(-10.8deg) translate3d(4px, -8px, 0);
    }
    50% {
        transform: rotate(-11.4deg) translate3d(10px, -16px, 0);
    }
    75% {
        transform: rotate(-12.6deg) translate3d(4px, -7px, 0);
    }
    100% {
        transform: rotate(-12deg) translate3d(0, 0, 0);
    }
}

@keyframes involviaCardFloatTopRight {
    0% {
        transform: rotate(-14deg) translate3d(0, 0, 0);
    }
    25% {
        transform: rotate(-12.8deg) translate3d(-4px, -8px, 0);
    }
    50% {
        transform: rotate(-13.2deg) translate3d(-10px, -14px, 0);
    }
    75% {
        transform: rotate(-14.5deg) translate3d(-4px, -6px, 0);
    }
    100% {
        transform: rotate(-14deg) translate3d(0, 0, 0);
    }
}

@keyframes involviaCardFloatBottomRight {
    0% {
        transform: rotate(12deg) translate3d(0, 0, 0);
    }
    25% {
        transform: rotate(11deg) translate3d(-3px, -9px, 0);
    }
    50% {
        transform: rotate(11.8deg) translate3d(-7px, -16px, 0);
    }
    75% {
        transform: rotate(12.8deg) translate3d(-2px, -7px, 0);
    }
    100% {
        transform: rotate(12deg) translate3d(0, 0, 0);
    }
}

@keyframes involviaCardPulse {
    0%,
    100% {
        box-shadow: 0 16px 34px rgba(28, 33, 82, 0.14);
        opacity: 0.94;
    }
    50% {
        box-shadow: 0 23px 44px rgba(28, 33, 82, 0.24);
        opacity: 1;
    }
}

@keyframes involviaOrbMove {
    0%,
    100% {
        transform: translate(-50%, -50%) scale(1);
    }
    50% {
        transform: translate(-47%, -53%) scale(1.12);
    }
}

@media (prefers-reduced-motion: reduce) {
    .banner-area::before,
    .banner-img-wrap::after,
    .banner-img-wrap .banner-img-one,
    .banner-img-wrap .banner2,
    .banner-img-wrap .banner3,
    .banner-img-wrap .banner4 {
        animation: none !important;
    }
}

/* Dark mode harmonization for company profile sections */
[data-theme=dark] {
    background: linear-gradient(180deg, #070b14 0%, #0b1021 55%, #101733 100%) !important;
    color: #b8c2dc;
}

[data-theme=dark] .banner-area,
[data-theme=dark] .page-banner-area,
[data-theme=dark] .about-area,
[data-theme=dark] .features-area,
[data-theme=dark] .services-area,
[data-theme=dark] .portfolio-area,
[data-theme=dark] .faq-arae,
[data-theme=dark] .blog-area,
[data-theme=dark] .from-the-blog-area,
[data-theme=dark] .contact-us-area,
[data-theme=dark] .services-details-area {
    background-image: linear-gradient(135deg, #0a0f1f 0%, #101933 55%, #0f1b38 100%) !important;
    background-color: #0a0f1f !important;
}

[data-theme=dark] .about-content h2,
[data-theme=dark] .section-title h2,
[data-theme=dark] .faq-arae .section-title h2,
[data-theme=dark] .blog-single-item h3 {
    color: #f4f7ff !important;
}

[data-theme=dark] .about-content p,
[data-theme=dark] .about-info-list p,
[data-theme=dark] .about-info-list li,
[data-theme=dark] .features-single-item .features-content p,
[data-theme=dark] .services-single-item .services-content p,
[data-theme=dark] .portfolio-status,
[data-theme=dark] .blog-single-item ul li,
[data-theme=dark] .faq-wrapper.accordion .accordion-item .accordion-header .accordion-button,
[data-theme=dark] .faq-wrapper.accordion .accordion-item .accordion-body p {
    color: #c4cce2 !important;
}

[data-theme=dark] .blog-preview-card {
    background: #0c1427;
    border-color: #1b2644;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.35);
}

/* Mobile hardening for all pages */
html,
body {
    overflow-x: hidden;
}

@media only screen and (max-width: 991px) {
    .about-area .position-sticky,
    .services-details-sidebar.position-sticky {
        position: static !important;
        top: auto !important;
    }

    .services-details-sidebar {
        margin-bottom: 18px;
    }

    .portfolio-card-media {
        padding: 10px;
    }

    .portfolio-thumb-image {
        height: 92px;
    }

    .theme-switch {
        right: 10px !important;
    }

    .theme-switch .switch-toggle {
        gap: 6px !important;
    }

    .theme-switch .fs-14 {
        font-size: 12px !important;
    }
}

@media only screen and (max-width: 767px) {
    .navbar .others-option .default-btn {
        min-width: 100%;
        justify-content: center;
    }

    .footer-area .d-flex.justify-content-between {
        align-items: flex-start !important;
    }

    .footer-import-link {
        width: 100%;
    }

    .footer-import-link .d-flex {
        flex-direction: column;
        gap: 12px !important;
        width: 100%;
    }

    .footer-import-link ul li {
        margin-bottom: 10px;
    }

    .portfolio-modal-message {
        font-size: 13px;
        line-height: 1.45;
    }

    .portfolio-thumb-image {
        height: 84px;
    }

    .blog-preview-card {
        padding: 8px;
    }
}

/* Visi & Misi emphasis tuning */
.involvia-vision-mission .section-title {
    margin-bottom: 28px;
}

.involvia-vision-mission .section-title h2 {
    max-width: 820px;
    margin-bottom: 16px;
    line-height: 1.18;
    font-weight: 400;
}

.involvia-vision-mission .section-title p {
    max-width: 640px;
    line-height: 1.72;
    font-size: 1.05rem;
}

.involvia-vision-mission .journey-visual-wrap {
    max-width: 860px;
    margin: 6px auto 34px;
}

.involvia-vision-mission .journey-visual {
    width: 100%;
    height: clamp(220px, 30vw, 340px);
    object-fit: cover;
    border-radius: 20px;
    box-shadow: 0 16px 36px rgba(23, 32, 54, 0.14);
    opacity: 0.9;
}

.involvia-vision-mission .mission-card {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(96, 93, 255, 0.14);
    border-radius: 18px;
    padding: 24px;
    height: 100%;
    box-shadow: 0 10px 28px rgba(58, 66, 82, 0.08);
}

.involvia-vision-mission .mission-card h3 {
    margin-bottom: 12px;
}

[data-theme=dark] .involvia-vision-mission .journey-visual {
    opacity: 0.76;
}

[data-theme=dark] .involvia-vision-mission .mission-card {
    background: #0c1427;
    border-color: #1b2644;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.35);
}

@media only screen and (max-width: 767px) {
    .involvia-vision-mission .section-title h2 {
        font-size: 30px;
    }

    .involvia-vision-mission .section-title p {
        font-size: 0.97rem;
        line-height: 1.64;
    }

    .involvia-vision-mission .journey-visual {
        height: 200px;
    }

    .involvia-vision-mission .mission-card {
        padding: 18px;
    }
}

/* Scroll reveal animation system */
[data-sa] {
    opacity: 0;
    transform: translate3d(0, 28px, 0);
    filter: blur(2px);
    transition:
        opacity 760ms cubic-bezier(0.22, 1, 0.36, 1) var(--sa-delay, 0ms),
        transform 760ms cubic-bezier(0.22, 1, 0.36, 1) var(--sa-delay, 0ms),
        filter 760ms cubic-bezier(0.22, 1, 0.36, 1) var(--sa-delay, 0ms);
    will-change: opacity, transform, filter;
}

[data-sa="fade"] {
    transform: none;
    filter: none;
}

[data-sa="zoom"] {
    transform: translate3d(0, 18px, 0) scale(0.965);
}

[data-sa="left"] {
    transform: translate3d(-30px, 0, 0);
}

[data-sa="right"] {
    transform: translate3d(30px, 0, 0);
}

[data-sa].sa-in {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
    filter: blur(0);
}

@media (prefers-reduced-motion: reduce) {
    html {
        scroll-behavior: auto;
    }

    [data-sa] {
        opacity: 1 !important;
        transform: none !important;
        filter: none !important;
        transition: none !important;
    }
}
