/* ===== GLOBAL STYLES ===== */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

a {
    text-decoration: none;
}

body {
    font-family: 'Inter', -apple-system, sans-serif;
    overflow-x: hidden;
    background: #fff;
}

/* ===== HEADER ===== */
.header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(10px);
    z-index: 1000;
    padding: 25px 155px;
}

.header-inner {
    max-width: 1440px;
    margin: 0 auto;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.logo img {
    width: 85px;
    height: auto;
}

.nav {
    display: flex;
    gap: 26px;
}

.nav a {
    color: #000;
    text-decoration: none;
    font-size: 16px;
    font-weight: 600;
}

.header-actions {
    display: flex;
    gap: 15px;
    align-items: center;
}

.btn-login {
    font-size: 18px;
    color: #000;
    text-decoration: none;
}

.btn-demo {
    background: linear-gradient(90deg, #02c3ef 0%, #015bf8 100%);
    color: #fff;
    padding: 9px 18px;
    border-radius: 10px;
    font-size: 18px;
    text-decoration: none;
}

/* ===== HERO SECTION ===== */
.hero {
    padding-top: 110px;
    padding-bottom: 280px;
    padding-left: 155px;
    padding-right: 155px;
    background: #fff;
    border-radius: 0 0 70px 70px;
    position: relative;
}

.hero-wrapper {
    max-width: 1130px;
    margin: 0 auto;
}

/* Badge */
.hero-badge {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 11px;
    margin-bottom: 37px;
}

.badge-text {
    font-size: 16px;
    font-weight: 500;
    color: #000;
}

.badge-star {
    width: 14px;
    height: 13px;
}

.badge-rating {
    font-size: 16px;
    font-weight: 500;
    color: #868686;
}

/* Subtitle */
.hero-subtitle {
    font-size: 20px;
    font-weight: 600;
    text-align: center;
    color: #000;
    margin-bottom: 20px;
    line-height: 1.3;
}

/* Main Title */
.hero-title {
    font-size: 60px;
    font-weight: 600;
    text-align: center;
    color: #000;
    margin-bottom: 60px;
    line-height: 1.2;
}

/* Hero Content Grid */
.hero-content {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
    margin-bottom: 60px;
}

/* Left: Checkmarks */
.hero-features {
    display: flex;
    flex-direction: column;
    gap: 88px;
    padding-left: 8px;
}

.feature-item {
    display: flex;
    align-items: center;
    gap: 10px;
}

.feature-check {
    width: 19.5px;
    height: 8px;
}

.feature-text {
    font-size: 18px;
    font-weight: 600;
    color: #000;
}

/* Right: Phone Mockup */
.hero-phone {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 852px;
}

.phone-container {
    position: relative;
    width: 393px;
    height: 852px;
}

/* Phone Status Bar */
.phone-status {
    position: absolute;
    top: 44px;
    left: 22px;
    right: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 30px;
    z-index: 3;
}

.status-time {
    font-size: 20px;
    font-weight: 600;
    color: #000;
}

.status-icons {
    display: flex;
    gap: 8px;
    align-items: center;
}

.signal-bars {
    display: flex;
    gap: 3px;
    align-items: flex-end;
    height: 18px;
}

.signal-bars span {
    width: 3px;
    background: #000;
    border-radius: 1px;
}

.signal-bars span:nth-child(1) {
    height: 8px;
}

.signal-bars span:nth-child(2) {
    height: 11px;
}

.signal-bars span:nth-child(3) {
    height: 13px;
}

.signal-bars span:nth-child(4) {
    height: 16px;
}

.status-icons img {
    width: auto;
    height: 22px;
}

/* Phone Screen Image */
.phone-screen {
    position: absolute;
    top: 0;
    left: -10px;
    width: 420px;
    height: 852px;
    object-fit: cover;
    z-index: 1;
}

/* Phone Info Badge */
.phone-badge {
    position: absolute;
    top: 87px;
    left: 50%;
    transform: translateX(-50%);
    width: 380px;
    /* background: rgba(255, 255, 255, 0.95); */
    /* backdrop-filter: blur(10px); */
    border-radius: 15px;
    padding: 27px 25px;
    text-align: center;
    /* box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15); */
    z-index: 2;
}

.phone-badge h3 {
    font-size: 24px;
    font-weight: 700;
    color: #000;
    margin-bottom: 17px;
    line-height: 1.3;
}

.phone-badge p {
    font-size: 14px;
    font-weight: 700;
    color: #868686;
    line-height: 1.5;
}

/* Small Demo Button on Phone */
.phone-demo {
    position: absolute;
    top: 270px;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(90deg, #02c1ef 0%, #0165f7 100%);
    color: #fff;
    font-size: 12px;
    font-weight: 400;
    padding: 5px 8px;
    border-radius: 5px;
    text-decoration: none;
    box-shadow: 0 4px 12px rgba(1, 91, 248, 0.3);
    z-index: 3;
}

/* Decorative Frame */
.phone-decoration {
    position: absolute;
    bottom: -50px;
    left: 50%;
    transform: translateX(-50%);
    width: 180px;
    z-index: 0;
}

/* ===== SEARCH BOX ===== */
.search-wrapper {
    position: relative;
    z-index: 10;
}

.search-gradient {
    position: absolute;
    left: 0;
    right: 0;
    height: 350px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.72) 0%, rgba(255, 255, 255, 1) 100%);
    pointer-events: none;
}

.search-box {
    position: relative;
    display: flex;
    align-items: center;
    gap: 20px;
    max-width: 751px;
    height: 94px !important;
    margin: 0 auto;
    background: #fff;
    border-radius: 22px;
    box-shadow: 0px 3px 11.7px 2px #ffb900;
    padding: 0 20px;
    margin-top: -230px;
}

.search-input {
    flex: 1;
    height: 57px;
    border: none;
    outline: none;
    font-size: 20px;
    font-weight: 600;
    color: #000;
    font-family: 'Inter', sans-serif;
}

.search-input::placeholder {
    color: #868686;
}

.search-btn {
    display: flex;
    align-items: center;
    gap: 25px;
    padding: 14px 21px;
    height: 49px;
    background: linear-gradient(90deg, #02c3ef 0%, #0060f7 100%);
    border-radius: 7px;
    border: none;
    font-size: 16px;
    font-weight: 600;
    color: #fff;
    cursor: pointer;
    text-decoration: none;
    white-space: nowrap;
}

.search-btn img {
    width: 14.73px;
    height: 22px;
}

/* ===== TRUSTED SECTION ===== */
.trusted {
    padding: 100px;
    /* background: linear-gradient(180deg, rgba(240, 234, 225, 0.34) 0%, rgba(240, 234, 225, 1) 100%); */
}

.section-title {
    font-size: 36px;
    font-weight: 600;
    text-align: center;
    color: #000;
    margin-bottom: 60px;
}

.testimonials-slider {
    display: flex;
    gap: 28px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    padding-bottom: 20px;
    justify-content: center;
    -webkit-overflow-scrolling: touch;
}

.testimonials-slider::-webkit-scrollbar {
    height: 8px;
}

.testimonials-slider::-webkit-scrollbar-track {
    background: #f1f1f1;
    border-radius: 10px;
}

.testimonials-slider::-webkit-scrollbar-thumb {
    background: #888;
    border-radius: 10px;
}

.testimonial-card-above {
    flex: 0 0 325px;
    scroll-snap-align: start;
}

.testimonial-card-above img {
    width: 325px;
    height: 412px;
    border-radius: 26px;
    object-fit: cover;
    margin-bottom: 10px;
}

.testimonial-name {
    font-size: 30px;
    font-weight: 600;
    color: #000;
    margin-bottom: 3px;
}

.testimonial-title {
    font-size: 20px;
    font-weight: 600;
    color: #868686;
}

/* ===== TABS SECTION ===== */
.tabs-section {
    padding: 100px 155px;
    background: rgba(240, 234, 225, 0.5);
}

.tabs-title {
    font-size: 48px;
    font-weight: 600;
    text-align: center;
    color: #000;
    margin-bottom: 60px;
    line-height: 1.3;
}

.tab-buttons {
    display: flex;
    justify-content: center;
    gap: 30px;
    margin-bottom: 50px;
    flex-wrap: wrap;
}

.tab-btn {
    position: relative;
    padding: 15px 30px;
    /* background: #000; */
    border-radius: 6px;
    border: none;
    font-size: 18px;
    font-weight: 600;
    color: #868686;
    cursor: pointer;
    transition: all 0.3s;
    box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.25);
}

.tab-btn.active {
    /* background: #015bf8; */
    color: #000;
}

.tab-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: rgba(255, 255, 255, 0.3);
    border-radius: 0 0 6px 6px;
    overflow: hidden;
}

.tab-fill {
    height: 100%;
    width: 0%;
    background: linear-gradient(90deg, #02c3ef 0%, #015bf8 100%);
    transition: width 0.1s linear;
}

.tab-btn.active .tab-fill {
    animation: fillProgress 10s linear;
}

@keyframes fillProgress {
    from {
        width: 0%;
    }

    to {
        width: 100%;
    }
}

.tab-content {
    max-width: 1192px;
    margin: 0 auto;
}

.tab-panel {
    display: none;
}

.tab-panel.active {
    display: block;
}

.tab-panel img {
    width: 100%;
    max-height: 750px;
    object-fit: cover;
    border-radius: 40px;
    margin-bottom: 20px;
}

.tab-info {
    text-align: center;
    padding: 20px;
}

.tab-info h3 {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 10px;
}

.tab-info p {
    font-size: 15px;
    font-weight: 600;
    line-height: 1.6;
}

.tab-info.white h3,
.tab-info.white p {
    color: #fff;
}

.tab-info.black h3,
.tab-info.black p {
    color: #000;
}

.tab-arrows {
    display: flex;
    justify-content: center;
    gap: 850px;
    margin-top: 50px;
}

.tab-arrow {
    display: flex;
    align-items: center;
    gap: 12px;
    background: none;
    border: none;
    font-size: 20px;
    font-weight: 600;
    color: #868686;
    cursor: pointer;
    padding: 10px;
    border-radius: 10% !important;
    -webkit-border-radius: 10% !important;
    -moz-border-radius: 10% !important;
    -ms-border-radius: 10% !important;
    -o-border-radius: 10% !important;
}

.tab-arrow img {
    width: 21px;
}

/* arrows 20px rounded with this bg color ececec */
.tab-arrow:hover {
    background: #090a0b12;

}

/* ===== RESPONSIVE ===== */
@media (max-width: 1200px) {

    .header,
    .hero,
    .trusted,
    .tabs-section,
    .reviews {
        padding-left: 60px;
        padding-right: 60px;
    }

    .hero-badge {
        margin-top: 35px;
    }
}

@media (max-width: 900px) {
    .hero-content {
        grid-template-columns: 1fr;
        gap: 40px;
    }

    .reveal.is-visible {
        display: grid;
        text-align: center;
    }

    .hero-badge {
        margin-top: 35px;
    }

    .hero-phone {
        min-height: auto;
    }

    .phone-container {
        transform: scale(0.8);
    }

    .reviews-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .nav {
        display: none;
    }

    .reveal.is-visible {
        display: grid;
        text-align: center;
    }

    .hero-badge {
        margin-top: 35px;
    }

    .header,
    .hero,
    .trusted,
    .tabs-section,
    .reviews {
        padding-left: 30px;
        padding-right: 30px;
    }

    .hero {
        padding-top: 120px;
    }

    .hero-title {
        font-size: 40px;
    }

    .hero-subtitle {
        font-size: 28px;
    }

    .search-box {
        flex-direction: column;
        height: auto;
        padding: 20px;
    }

    .search-input,
    .search-btn {
        width: 100%;
    }

    .phone-container {
        transform: scale(0.7);
    }

    .tab-buttons {
        flex-direction: column;
    }

    .tab-btn {
        width: 100%;
    }

    .reviews-grid {
        grid-template-columns: 1fr;
    }

    .testimonial-card {
        flex: 0 0 280px;
    }

    .testimonial-card img {
        width: 280px;
        height: 355px;
    }
}

@media (max-width: 480px) {
    .reveal.is-visible {
        display: grid;
        text-align: center;
    }

    .hero-title {
        font-size: 32px;
    }

    .hero-badge {
        margin-top: 35px;
    }

    .hero-subtitle {
        font-size: 22px;
    }

    .section-title {
        font-size: 28px;
    }

    .tabs-title {
        font-size: 32px;
    }

    .phone-container {
        transform: scale(0.6);
    }
}


.header {
    position: fixed;
    top: 0;
    width: 100%;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(10px);
    z-index: 1000;
    padding: 16px 80px;
}

.header-inner {
    max-width: 1240px;
    margin: auto;
}

.nav a {
    font-size: 14px;
    font-weight: 600;
}

.btn-login {
    font-size: 14px;
}

.btn-demo {
    font-size: 14px;
    padding: 10px 16px;
    border-radius: 8px;
}

@media (max-width: 768px) {
    .header {
        padding: 14px 20px;
    }

    .nav {
        display: none;
    }
}

.hero-subtitle {
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 12px;
}

.hero-title {
    font-size: 55px;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 40px;
}

.hero-content {
    align-items: center;
}

.hero-features {
    gap: 30px;
}

.feature-text {
    font-size: 16px;
}

@media (max-width: 900px) {
    .hero-content {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .hero-features {
        align-items: center;
    }

    .hero-phone {
        margin-top: 40px;
    }

    .phone-container {
        transform: scale(0.8);
    }
}

@media (max-width: 480px) {
    .hero-title {
        font-size: 30px;
    }

    .hero-subtitle {
        font-size: 20px;
    }

    .phone-container {
        transform: scale(0.65);
    }
}

.search-box {
    height: 94px;
    border-radius: 18px;
    box-shadow: 0px 6px 18px rgba(255, 185, 0, 0.35);
}

.search-input {
    font-size: 16px;
}

.testimonial-card {
    flex: 0 0 260px;
}

.testimonial-card img {
    /* width: 260px; */
    height: 340px;
    border-radius: 22px;
}

.testimonial-name {
    font-size: 18px;
}

.testimonial-title {
    font-size: 14px;
}

@media (max-width: 768px) {
    .testimonial-card {
        flex: 0 0 220px;
    }

    .testimonial-card img {
        width: 220px;
        height: 300px;
    }
}

.hero-content-center {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 40px;
    margin-top: 60px;
}

/* FEATURES */
.hero-feature {
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 16px;
    font-weight: 600;
    color: #000;
}

.hero-feature.left {
    justify-content: flex-end;
    text-align: right;
}

.hero-feature.right {
    justify-content: flex-start;
    text-align: left;
    margin-top: -420px;
}

.hero-feature img {
    width: 18px;
}

/* PHONE CENTER */
.hero-phone {
    display: flex;
    justify-content: center;
}

.phone-container {
    width: 390px;
    height: 850px;
    position: relative;
}

@media (max-width: 900px) {
    .hero-content-center {
        grid-template-columns: 1fr;
        gap: 30px;
        text-align: center;
    }

    .hero-feature.left,
    .hero-feature.right {
        justify-content: center;
        text-align: center;
    }

    .phone-container {
        transform: scale(0.8);
    }
}

@media (max-width: 480px) {
    .phone-container {
        transform: scale(0.65);
    }
}

.w-200px {
    width: 320px;
    margin: auto;
    margin-top: 290px;
    margin-left: 58px;
}


/* ADD THIS TO YOUR EXISTING style.css */

/* ===== TABS SECTION UPDATES ===== */

/* Tab panel container with relative positioning for overlays */
.tab-panel {
    position: relative;
}

.tab-panel img {
    width: 100%;
    max-height: 750px;
    object-fit: cover;
    border-radius: 40px;
    margin-bottom: 0;
    /* Remove bottom margin */
}

/* Text overlay on images */
.tab-text-overlay {
    position: absolute;
    max-width: 450px;
    z-index: 10;
    padding: 30px;
}

/* Tab 1: Left Center */
.tab-panel[data-panel="1"] .tab-text-overlay {
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
}

/* Tab 2: Left Center */
.tab-panel[data-panel="2"] .tab-text-overlay {
    left: 60px;
    top: 50%;
    transform: translateY(-50%);
}

/* Tab 3: Left Center */
.tab-panel[data-panel="3"] .tab-text-overlay {
    left: 60px;
    top: 50%;
    transform: translateY(-50%);
}

/* Tab 4: Left Top Corner */
.tab-panel[data-panel="4"] .tab-text-overlay {
    left: 50px;
    top: 55px;
}

/* Overlay text styling */
.tab-text-overlay h3 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 20px;
    line-height: 1.2;
}

.tab-text-overlay p {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.6;
}

/* White text for dark backgrounds (tabs 1, 2, 4) */
.tab-text-overlay.white h3,
.tab-text-overlay.white p {
    color: #fff;
    text-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Black text for light background (tab 3) */
.tab-text-overlay.black h3,
.tab-text-overlay.black p {
    color: #000;
    text-shadow: 0 2px 8px rgba(255, 255, 255, 0.3);
}

/* Video container for laptop screen on Tab 1 */
.laptop-video-container {
    position: absolute;
    top: 44.6%;
    right: 65px;
    transform: translateY(-50%);
    width: 398px;
    height: 380px;
    overflow: hidden;
    border-radius: 32px;
    background-color: rgba(227, 227, 227, 1);
    -webkit-border-radius: 32px;
    -moz-border-radius: 32px;
    -ms-border-radius: 32px;
    -o-border-radius: 32px;
}

.laptop-video-container video {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Remove old tab-info styles */
.tab-info {
    display: none;
}

/* Responsive adjustments */
@media (max-width: 1200px) {
    .tab-text-overlay {
        max-width: 380px;
        padding: 25px;
    }

    .tab-panel[data-panel="1"] .tab-text-overlay,
    .tab-panel[data-panel="2"] .tab-text-overlay,
    .tab-panel[data-panel="3"] .tab-text-overlay {
        left: 40px;
    }

    .tab-panel[data-panel="4"] .tab-text-overlay {
        left: 40px;
        top: 60px;
    }

    .tab-text-overlay h3 {
        font-size: 28px;
    }

    .tab-text-overlay p {
        font-size: 16px;
    }

    .laptop-video-container {
        width: 480px;
        height: 320px;
        right: 80px;
    }
}

@media (max-width: 900px) {
    .tab-text-overlay {
        max-width: 100%;
        padding: 20px;
        position: static;
        transform: none;
        margin-top: 20px;
        background: rgba(0, 0, 0, 0.7);
        border-radius: 15px;
    }

    .tab-panel[data-panel="1"] .tab-text-overlay,
    .tab-panel[data-panel="2"] .tab-text-overlay,
    .tab-panel[data-panel="3"] .tab-text-overlay,
    .tab-panel[data-panel="4"] .tab-text-overlay {
        left: 0;
        top: auto;
        transform: none;
    }

    .tab-text-overlay.black {
        background: rgba(255, 255, 255, 0.9);
    }

    .laptop-video-container {
        position: static;
        transform: none;
        width: 100%;
        max-width: 500px;
        height: 320px;
        margin: 20px auto;
    }
}

@media (max-width: 768px) {
    .tab-text-overlay h3 {
        font-size: 22px;
        margin-bottom: 15px;
    }

    .tab-text-overlay p {
        font-size: 14px;
    }

    .laptop-video-container {
        height: 260px;
    }
}

@media (max-width: 480px) {
    .tab-text-overlay {
        padding: 15px;
    }

    .tab-text-overlay h3 {
        font-size: 20px;
    }

    .tab-text-overlay p {
        font-size: 13px;
    }

    .laptop-video-container {
        height: 220px;
    }
}

.laptop-video-container video {
    height: auto;
    object-fit: cover;
    border-radius: 50px;
}

/* Responsive adjustments */
@media (max-width: 1200px) {
    .laptop-video-container {
        top: 22%;
        right: 14%;
        width: 43%;
        height: 53%;
    }
}

@media (max-width: 900px) {
    .laptop-video-container {
        position: relative;
        top: 0;
        right: 0;
        width: 100%;
        height: 300px;
        margin: 20px 0;
    }
}

/* ===== REVIEWS SECTION ===== */
/* ===== REVIEWS SECTION - FINAL FIX ===== */

/* Background with gradient - VISIBLE */
.reviews {
    padding: 100px 120px 140px;
    background: linear-gradient(180deg, #F8F5F0 100%, #F3EEE7 100%, #F0EAE1 100%);
}

.section-title {
    font-size: 36px;
    font-weight: 600;
    text-align: center;
    margin-bottom: 40px;
    color: #000;
}

/* Rating Badges */
.rating-badges {
    display: flex;
    justify-content: center;
    gap: 18px;
    margin-bottom: 40px;
    flex-wrap: wrap;
}

.rating-badge {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 16px;
    background: #ddd7cf;
    border-radius: 12px;
}

.rating-badge img {
    width: 41px;
    height: 41px;
    object-fit: cover;
    border-radius: 50%;
}

.rating-badge span {
    font-size: 12px;
    font-weight: 600;
    color: #000;
    max-width: 140px;
}

.rating-tagline {
    font-size: 12px;
    font-weight: 600;
    color: #015bf8;
    text-align: center;
    margin-bottom: 60px;
}

/* Reviews Grid - 3 columns */
.reviews-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 330px));
    gap: 10px;
    max-width: 1030px;
    margin: 0 auto 60px;
}

/* Base Card - WHITE background on top of gradient */
.review-card {
    background: #ffffff;
    padding: 28px;
    border-radius: 20px;
    transition: all 0.3s ease;
}

/* FIRST CARD IN EACH ROW (1, 4, 7) - Light shadow + DOWN */
.review-card:nth-child(1),
.review-card:nth-child(4),
.review-card:nth-child(7) {
    /* box-shadow: 0px 6px 16px rgba(0, 0, 0, 0.10); */
    transform: translateY(60px);
    -webkit-transform: translateY(60px);
    -moz-transform: translateY(60px);
    -ms-transform: translateY(60px);
    -o-transform: translateY(60px);
}

/* SECOND CARD IN EACH ROW (2, 5, 8) - Strong shadow + UP (stays at top) */
.review-card:nth-child(2),
.review-card:nth-child(5),
.review-card:nth-child(8) {
    /* box-shadow: 0px 24px 60px rgba(0, 0, 0, 0.18); */
    transform: translateY(0px);
}

/* THIRD CARD IN EACH ROW (3, 6, 9) - Medium shadow + DOWN */
.review-card:nth-child(3),
.review-card:nth-child(6),
.review-card:nth-child(9) {
    /* box-shadow: 0px 10px 28px rgba(0, 0, 0, 0.12); */
    transform: translateY(60px);
    -webkit-transform: translateY(60px);
    -moz-transform: translateY(60px);
    -ms-transform: translateY(60px);
    -o-transform: translateY(60px);
}

/* Hover Effect */
.review-card:hover {
    /* transform: translateY(-10px) !important; */
    box-shadow: 0px 30px 70px rgba(0, 0, 0, 0.20) !important;
}

/* Stars */
.review-stars {
    display: flex;
    gap: 2px;
    margin-bottom: 15px;
}

.review-stars img {
    width: 15px;
    height: 14px;
}

/* Review Text */
.review-text {
    font-size: 18px;
    font-weight: 400;
    color: #000;
    line-height: 1.5;
    margin-bottom: 22px;
}

/* Author */
.review-author {
    display: flex;
    align-items: center;
    gap: 10px;
}

.review-author img {
    width: 40px;
    height: 40px;
    border-radius: 50%;
}

.review-author span {
    font-size: 14px;
    font-weight: 500;
    color: #000;
}

/* See More Reviews Button */
.btn-reviews {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    width: 180px;
    height: 48px;
    background: #000;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
    margin: 0 auto;
    text-decoration: none;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    /* position: relative;
    z-index: 99;
    margin-top: -122px; */
}

.btn-reviews:hover {
    background: #1a1a1a;
    transform: scale(1.05);
}

.btn-reviews img {
    width: 6px;
    height: 10px;
}

/* ===================== RESPONSIVE ===================== */

@media (max-width: 1200px) {
    .reviews {
        padding: 80px 60px 120px;
    }

    .reviews-grid {
        gap: 20px;
    }
}

@media (max-width: 1024px) {
    .reviews {
        padding: 80px 40px 100px;
    }

    /* 2 columns on tablet */
    .reviews-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Reset transforms on tablet */
    .review-card:nth-child(1),
    .review-card:nth-child(2),
    .review-card:nth-child(3),
    .review-card:nth-child(4),
    .review-card:nth-child(5),
    .review-card:nth-child(6),
    .review-card:nth-child(7),
    .review-card:nth-child(8),
    .review-card:nth-child(9) {
        transform: translateY(0) !important;
        box-shadow: 0px 10px 30px rgba(0, 0, 0, 0.12) !important;
    }
}

@media (max-width: 768px) {
    .reviews {
        padding: 60px 30px 80px;
    }

    .section-title {
        font-size: 28px;
    }

    /* Single column on mobile */
    .reviews-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .review-card {
        max-width: 500px;
        margin: 0 auto;
    }

    .review-text {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .reviews {
        padding: 60px 20px 60px;
    }

    .section-title {
        font-size: 24px;
    }

    .review-card {
        padding: 20px;
    }

    .review-text {
        font-size: 15px;
    }
}

/* ==========================================
   OWNER.COM STYLE REVIEW CARDS
   Masonry/Staggered Layout - 3 Columns
   ========================================== */

/* Hide old review cards if any */
.landing-page .frame-38,
.landing-page .frame-39,
.landing-page .frame-40,
.landing-page .frame-53,
.landing-page .frame-54,
.landing-page .frame-55,
.landing-page .frame-56,
.landing-page .frame-57,
.landing-page .frame-58 {
    display: none !important;
}

/* Main Container */
.review-cards-masonry {
    position: absolute;
    top: 3500px;
    /* Adjust based on your layout */
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 1200px;
    padding: 60px 30px;
}

/* Masonry Grid - 3 Columns */
.review-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    position: relative;
}

/* Individual Review Card */
.review-card {
    background: #ffffff;
    border-radius: 20px;
    padding: 32px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    display: flex;
    flex-direction: column;
}

/* .review-card:hover {
    transform: translateY(-8px);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.12);
} */

/* Star Rating */
.review-stars {
    display: flex;
    gap: 4px;
}

.review-stars svg {
    width: 16px;
    height: 16px;
    fill: #000000;
}

/* Review Text */
.review-text {
    font-family: "Inter", Helvetica, sans-serif;
    font-size: 16px;
    line-height: 1.6;
    color: #000000;
    font-weight: 400;
}

/* Reviewer Info */
.reviewer-info {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-top: auto;
}

.reviewer-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    object-fit: cover;
}

.reviewer-name {
    font-family: "Inter", Helvetica, sans-serif;
    font-size: 14px;
    font-weight: 600;
    color: #000000;
}

/* Staggered Positioning - Column Heights */
/* Column 1 - Left */
.review-card:nth-child(3n+1) {
    margin-top: 0;
}

/* Column 2 - Center */
/* .review-card:nth-child(3n+2) {
    margin-top: 40px;
} */

/* Column 3 - Right */
.review-card:nth-child(3n+3) {
    margin-top: 0;
}

/* Different Card Heights for Natural Flow */
.review-card:nth-child(1) {
    max-height: 240px;
}

.review-card:nth-child(2) {
    max-height: 240px;
}

.review-card:nth-child(3) {
    max-height: 240px;
}

.review-card:nth-child(4) {
    max-height: 240px;
}

.review-card:nth-child(5) {
    max-height: 240px;
}

.review-card:nth-child(6) {
    max-height: 240px;
}

.review-card:nth-child(7) {
    max-height: 240px;
}

.review-card:nth-child(8) {
    max-height: 240px;
}

.review-card:nth-child(9) {
    max-height: 240px;
}

/* Fade Effect for Lower Cards */
.review-card:nth-child(n+7) {
    opacity: 0.4;
    pointer-events: none;
}

/* See More Button */
.see-more-reviews-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 16px 32px;
    background: #000000;
    color: #ffffff;
    border-radius: 8px;
    font-family: "Inter", Helvetica, sans-serif;
    font-size: 16px;
    font-weight: 500;
    text-decoration: none;
    margin: 40px auto 0;
    transition: all 0.3s ease;
    cursor: pointer;
}

.see-more-reviews-btn:hover {
    background: #1a1a1a;
    transform: translateY(-2px);
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.see-more-reviews-btn svg {
    width: 12px;
    height: 12px;
    fill: #ffffff;
}

/* Center the button */
.review-cards-masonry {
    display: flex;
    flex-direction: column;
}

/* Responsive */
@media (max-width: 992px) {
    .review-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Reset staggering for 2 columns */
    .review-card:nth-child(2n+1) {
        margin-top: 0;
    }

    .review-card:nth-child(2n+2) {
        margin-top: 30px;
    }
}

@media (max-width: 640px) {
    .review-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .review-card {
        margin-top: 0 !important;
        padding: 24px;
    }

    .review-text {
        font-size: 15px;
    }
}



/* ============================================
   GIVE YOUR MEDSPA SECTION
   ============================================ */

.proven-section {
    background: #fff;
    padding: 80px 0 100px;
    border-radius: 15px;
    -webkit-border-radius: 15px;
    -moz-border-radius: 15px;
    -ms-border-radius: 15px;
    -o-border-radius: 15px;
}

.section-container {
    max-width: 1240px;
    margin: auto;
    padding: 0 24px;
}

.section-title {
    font-size: 48px;
    font-weight: 600;
    margin-bottom: 60px;
    color: #000;
    line-height: 1.2;
}

/* ===== TOP IMAGE SECTION - Text Wrap ===== */
.top-image-section {
    position: relative;
    width: 100%;
    margin-bottom: 30px;
    border-radius: 36px;
    overflow: hidden;
}

.main-app-image {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 36px;
}

.text-wrap-overlay {
    position: absolute;
    top: 30px;
    left: 30px;
    padding: 20px 30px;
    border-radius: 16px;
    z-index: 10;
}

.text-wrap-overlay p {
    font-size: 20px;
    font-weight: 500;
    color: #000;
    line-height: 1.5;
    margin: 0;
}

/* ===== BOTTOM GRID - 2 Columns ===== */
.design-bottom-grid {
    display: grid;
    grid-template-columns: 1fr 0.8fr;
    gap: 24px;
}

/* ===== LEFT CARD - Video Overlay ===== */
.booking-video-card {
    position: relative;
    background: #fff;
    border-radius: 36px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.booking-bg-image {
    width: 100%;
    height: auto;
    display: block;
}

/* Video Overlay Container */
.video-overlay-container {
    position: absolute;
    top: 44%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 70%;
    max-width: 400px;
    z-index: 10;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
    border-radius: inherit;
}

.booking-video {
    width: 100%;
    height: auto;
    display: block;
}

/* Bottom Text on Left Card */
.booking-bottom-text {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 30px;
    margin-top: 0;
    padding-bottom: 45px;
    text-align: center;
}

.booking-bottom-text h4 {
    font-size: 16px;
    font-weight: 600;
    color: #fff;
    margin-bottom: 8px;
}

.booking-bottom-text p {
    font-size: 32px;
    font-weight: 600;
    color: #181f1f;
    margin: 0;
    line-height: 1.2;
}

/* ===== RIGHT CARD - Service Cards Stack ===== */
.service-cards-stack {
    display: flex;
    flex-direction: column;
    gap: 20px;
    justify-content: center;
}

/* Individual Service Card */
.service-card {
    background: #fff;
    border-radius: 20px;
    display: grid;
    grid-template-columns: 1fr 167px;
    align-items: center;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    transition: all 0.3s ease;
    -webkit-border-radius: 20px;
    -moz-border-radius: 20px;
    -ms-border-radius: 20px;
    -o-border-radius: 20px;
}

.service-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.service-card-content {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 28px;
}

.service-title {
    font-size: 18px;
    font-weight: 600;
    color: #000;
    margin: 0;
}

.service-description {
    font-size: 13px;
    font-weight: 400;
    color: #868686;
    line-height: 1.5;
    margin: 0;
}

.service-price {
    font-size: 22px;
    font-weight: 600;
    color: #000;
    margin-top: 5px;
}

.service-image {
    width: 170px;
    height: 170px;
    border-radius: 18px;
    object-fit: cover;
}

/* Service Cards Footer Text */
.service-cards-footer {
    /* padding: 25px; */
    border-radius: 24px;
    margin-top: 40px;
    text-align: center;
}

.footer-main-text {
    font-size: 18px;
    font-weight: 600;
    color: #6B6B6B;
    margin: 0 0 8px 0;
    line-height: 1.4;
}

.highlight-text {
    color: #000;
}

.footer-sub-text {
    font-size: 14px;
    font-weight: 500;
    color: #868686;
    margin: 0;
}

/* ===== RESPONSIVE ===== */
@media (max-width: 991px) {
    .section-title {
        font-size: 36px;
    }

    .design-bottom-grid {
        grid-template-columns: 1fr;
    }

    .text-wrap-overlay {
        max-width: 90%;
        top: 20px;
        left: 20px;
        padding: 16px 20px;
    }

    .text-wrap-overlay p {
        font-size: 14px;
    }

    .video-overlay-container {
        width: 80%;
    }

    .booking-bottom-text h4 {
        font-size: 14px;
    }

    .booking-bottom-text p {
        font-size: 24px;
    }

    .service-card {
        grid-template-columns: 1fr 100px;
    }

    .service-image {
        width: 100px;
        height: 100px;
    }
}

@media (max-width: 768px) {
    .proven-section {
        padding: 60px 0 80px;
    }

    .section-title {
        font-size: 28px;
        margin-bottom: 40px;
    }

    .text-wrap-overlay {
        position: static;
        margin-bottom: 20px;
        max-width: 100%;
    }

    .service-card {
        padding: 20px;
    }

    .service-title {
        font-size: 16px;
    }

    .service-description {
        font-size: 12px;
    }

    .service-price {
        font-size: 18px;
    }

    .footer-main-text {
        font-size: 16px;
    }
}

@media (max-width: 576px) {
    .section-title {
        font-size: 24px;
    }

    .service-card {
        grid-template-columns: 1fr;
        text-align: center;
    }

    .service-image {
        width: 100%;
        height: 180px;
        margin: 0 auto;
    }

    .booking-bottom-text {
        padding: 20px;
    }

    .booking-bottom-text p {
        font-size: 20px;
    }
}


/* ==========================================
   OWNER.COM STYLE TESTIMONIALS
   Smooth slider with fade animations
   ========================================== */

.owner-testimonials {
    background: #F8F5F0;
    padding: 80px 0 100px;
    position: relative;
}

.owner-testimonials-container {
    max-width: 1340px;
    margin: 0 auto;
    padding: 0 40px;
    position: relative;
}

/* ===== SLIDER WRAPPER ===== */
.owner-slider-wrapper {
    position: relative;
    min-height: 500px;
    background: #ffffff;
    border-radius: 32px;
    /* padding: 60px; */
    padding-right: 40px;
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.04);
}

/* ===== SLIDE HEADER - Name + Button ===== */
.slide-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 30px;
    gap: 20px;
}

.header-left {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.testimonial-author {
    font-size: 45px;
    font-weight: 800;
    color: #000;
    margin: 0;
    line-height: 1.2;
}

.testimonial-company {
    font-size: 45px;
    font-weight: 800;
    color: #000;
    margin: 0;
    line-height: 1.3;
}

/* ===== SEE ALL REVIEWS BUTTON - Inline ===== */
.see-all-reviews-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: #000;
    color: #fff;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s ease;
    flex-shrink: 0;
    white-space: nowrap;
}

.see-all-reviews-btn:hover {
    background: #1a1a1a;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

.see-all-reviews-btn svg {
    width: 16px;
    height: 16px;
}

/* ===== INDIVIDUAL SLIDE ===== */
.owner-slide {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    transform: translateX(50px);
    transition: all 0.6s cubic-bezier(0.4, 0, 0.2, 1);
    padding: 48px;
    padding-right: 0px;
    padding-bottom: 35px;
}

.owner-slide.active {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    position: relative;
}

/* Slide Content - Grid Layout */
.owner-slide-content {
    display: grid;
    grid-template-columns: 35% 65%;
    gap: 20px;
    /* align-items: center; */
}

/* ===== LEFT CONTENT ===== */
.owner-slide-left {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.testimonial-quote {
    font-size: 16px;
    font-weight: 400;
    color: #555;
    line-height: 1.7;
    margin: 0;
}

/* Metrics */
.testimonial-metrics {
    display: flex;
    flex-direction: column;
    gap: 28px;
    margin-top: 115px;
}

.metric-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.metric-value {
    font-size: 48px;
    font-weight: 600;
    color: #000;
    line-height: 1;
    letter-spacing: -0.02em;
}

.metric-label {
    font-size: 15px;
    font-weight: 500;
    color: #666;
    line-height: 1.4;
}

/* ===== RIGHT IMAGE ===== */
.owner-slide-right {
    position: relative;
    border-radius: 28px;
    overflow: hidden;
    /* background: #E8DED1; */
    height: 450px;
}

.owner-slide-right img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Image Overlay Text */
.image-overlay-text {
    position: absolute;
    bottom: 40px;
    left: 40px;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.image-overlay-text span {
    font-size: 20px;
    font-weight: 600;
    color: #ffffff;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}

.overlay-company {
    font-size: 18px;
    font-weight: 500;
}

/* ===== NAVIGATION BUTTONS ===== */
.owner-slider-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 30px;
}

.owner-nav-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    border: none;
    font-size: 16px;
    font-weight: 500;
    color: #666;
    cursor: pointer;
    padding: 8px 0;
    transition: all 0.3s ease;
}

.owner-nav-btn:hover {
    color: #000;
    transform: translateX(0);
}

.owner-nav-prev:hover {
    transform: translateX(-4px);
}

.owner-nav-next:hover {
    transform: translateX(4px);
}

.owner-nav-btn svg {
    width: 20px;
    height: 20px;
}

/* ===== SEE ALL REVIEWS BUTTON ===== */
.see-all-reviews-btn {
    position: absolute;
    top: 60px;
    right: 60px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 14px 28px;
    background: #000;
    color: #fff;
    border-radius: 10px;
    font-size: 15px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.3s ease;
    z-index: 100;
}

.see-all-reviews-btn:hover {
    background: #1a1a1a;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.25);
}

.see-all-reviews-btn svg {
    width: 16px;
    height: 16px;
}

/* ===== ANIMATIONS ===== */

/* Fade in animation for metrics */
.owner-slide.active .metric-item {
    animation: fadeInUp 0.6s ease-out forwards;
}

.owner-slide.active .metric-item:nth-child(1) {
    animation-delay: 0.2s;
}

.owner-slide.active .metric-item:nth-child(2) {
    animation-delay: 0.4s;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }

    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Slide in from right animation */
.owner-slide:not(.active) {
    pointer-events: none;
}

/* ===== RESPONSIVE ===== */

@media (max-width: 991px) {
    .owner-slider-wrapper {
        padding: 40px;
        min-height: 700px;
    }

    .owner-slide {
        padding: 40px;
    }

    .slide-header {
        flex-direction: column;
        align-items: flex-start;
        margin-bottom: 25px;
    }

    .see-all-reviews-btn {
        align-self: flex-start;
    }

    .owner-slide-content {
        grid-template-columns: 1fr;
        gap: 50px;
    }

    .owner-slide-right {
        height: 420px;
    }

    .testimonial-author {
        font-size: 24px;
    }

    .testimonial-company {
        font-size: 18px;
    }

    .metric-value {
        font-size: 42px;
    }
}

@media (max-width: 768px) {
    .owner-testimonials {
        padding: 60px 0 80px;
    }

    .owner-testimonials-container {
        padding: 0 20px;
    }

    .owner-slider-wrapper {
        padding: 30px;
        min-height: 750px;
    }

    .owner-slide {
        padding: 30px;
    }

    .slide-header {
        margin-bottom: 20px;
    }

    .testimonial-author {
        font-size: 22px;
    }

    .testimonial-company {
        font-size: 17px;
    }

    .see-all-reviews-btn {
        padding: 12px 24px;
        font-size: 14px;
    }

    .owner-slide-content {
        gap: 40px;
    }

    .testimonial-quote {
        font-size: 15px;
    }

    .metric-value {
        font-size: 38px;
    }

    .metric-label {
        font-size: 14px;
    }

    .owner-slider-nav {
        margin-top: 25px;
    }

    .owner-nav-btn {
        font-size: 15px;
    }
}

@media (max-width: 576px) {
    .owner-slider-wrapper {
        padding: 24px;
        border-radius: 24px;
        min-height: 800px;
    }

    .owner-slide {
        padding: 24px;
    }

    .slide-header {
        gap: 16px;
    }

    .testimonial-author {
        font-size: 20px;
    }

    .testimonial-company {
        font-size: 16px;
    }

    .see-all-reviews-btn {
        padding: 10px 20px;
        font-size: 13px;
        /* width: 100%; */
        margin-top: 740px;
        margin-right: 65px;
        justify-content: center;
    }

    .owner-slide-content {
        gap: 30px;
    }

    .testimonial-quote {
        font-size: 14px;
    }

    .metric-value {
        font-size: 32px;
    }

    .metric-label {
        font-size: 13px;
    }

    .owner-slide-right {
        height: 320px;
    }

    .image-overlay-text {
        bottom: 24px;
        left: 24px;
    }

    .image-overlay-text span {
        font-size: 18px;
    }

    .overlay-company {
        font-size: 16px;
    }
}

/* ============================================
   TESTIMONIALS CAROUSEL
   ============================================ */

.testimonials-carousel {
    background: #f6f1e9;
    padding: 80px 0;
    /* border-radius: 70px; */
    position: relative;
    overflow: visible;
}

.carousel-container {
    max-width: 1440px;
    margin: auto;
    position: relative;
    z-index: 2;
    padding: 0 20px;
}

/* DECORATIVE BACKGROUND IMAGES - FIXED POSITION */
.bg-left,
.bg-right {
    position: absolute;
    width: 132px;
    z-index: 1;
}

.bg-left {
    left: 155px;
    top: 112px;
}

.bg-right {
    right: 155px;
    top: 117px;
}

/* SLIDER WRAPPER */
.slider-wrapper {
    position: relative;
    width: 100%;
    overflow: hidden;
}

/* CAROUSEL TRACK - SLIDING CONTAINER */
.carousel-track {
    display: flex;
    transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94);
    padding: 40px 0;
    will-change: transform;
}

/* TESTIMONIAL SLIDE WRAPPER */
.testimonial-slide {
    min-width: 100%;
    flex-shrink: 0;
}

/* MAIN CARD */
.testimonial-card {
    background: #fff;
    border-radius: 40px;
    display: grid;
    grid-template-columns: 420px 1fr;
    overflow: hidden;
    height: 450px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.1);
    max-width: 1176px;
    margin: 0 auto;
}

/* LEFT IMAGE */
.testimonial-image {
    position: relative;
    height: 100%;
}

.testimonial-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.image-labels {
    position: absolute;
    bottom: 20px;
    left: 40px;
}

.label {
    color: #fff;
    display: block;
    width: fit-content;
    margin-bottom: 6px;
    font-size: 24px;
    font-weight: 700;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

.label-sub {
    color: #fff;
    display: block;
    width: fit-content;
    font-size: 14px;
    font-weight: 500;
    opacity: 0.95;
    text-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
}

/* RIGHT CONTENT */
.testimonial-content {
    padding: 50px 60px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-bottom: 0px;
}

.testimonial-content1 {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.quote {
    font-size: 18px;
    line-height: 1.6;
    font-weight: 600;
    margin-bottom: 156px;
    color: #333;
}

/* STATS */
.stats {
    display: flex;
    gap: 50px;
    margin-bottom: 30px;
    flex-wrap: wrap;
}

.stat-item h3 {
    font-size: 32px;
    font-weight: 700;
    color: #2c2c2c;
    margin-bottom: 8px;
}

.stat-item p {
    font-size: 12px;
    color: #666;
    font-weight: 500;
}

/* BUTTON */
.story-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #efebe3;
    padding: 12px 24px;
    border-radius: 8px;
    font-weight: 600;
    width: fit-content;
    text-decoration: none;
    color: #333;
    transition: all 0.3s ease;
    margin-top: 20px;
    justify-content: end;
}

.story-btn:hover {
    background: #e5dfd4;
    transform: translateX(5px);
}

.story-btn img {
    transition: transform 0.3s ease;
    width: 8px;
    height: 12px;
}

.story-btn:hover img {
    transform: translateX(3px);
}

/* PAGINATION DOTS */
.carousel-dots {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 40px;
}

.carousel-dots .dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #d4cec1;
    border: none;
    cursor: pointer;
    transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    padding: 0;
    position: relative;
    overflow: hidden;
}

.carousel-dots .dot:hover {
    transform: scale(1.3);
    background: #999;
}

.carousel-dots .dot.active {
    width: 40px;
    border-radius: 5px;
    background: #e8e4dc;
    animation: dotPulse 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Progress Bar Inside Active Dot */
.carousel-dots .dot.active::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0;
    background: linear-gradient(90deg, #4a90e2 0%, #357abd 100%);
    border-radius: 5px;
    animation: progressBar 5s linear forwards;
}

@keyframes dotPulse {
    0% {
        transform: scale(0.8);
    }

    50% {
        transform: scale(1.1);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes progressBar {
    0% {
        width: 0%;
    }

    100% {
        width: 100%;
    }
}

/* MOBILE */
@media (max-width: 1024px) {
    .testimonial-card {
        grid-template-columns: 320px 1fr;
    }

    .testimonial-content {
        padding: 30px 40px;
    }

    .bg-left {
        left: 50px;
    }

    .bg-right {
        right: 50px;
    }
}

@media (max-width: 768px) {
    .testimonials-carousel {
        padding: 60px 0;
        /* border-radius: 40px; */
    }

    .carousel-container {
        padding: 0 15px;
    }

    .testimonial-card {
        height: auto;
        grid-template-columns: 1fr;
    }

    .testimonial-image {
        height: 280px;
    }

    .image-labels {
        left: 30px;
        bottom: 20px;
    }

    .testimonial-content {
        padding: 30px;
    }

    .stats {
        gap: 30px;
    }

    .stat-item h3 {
        font-size: 26px;
    }

    .bg-left,
    .bg-right {
        width: 80px;
    }

    .bg-left {
        left: 20px;
        top: 40px;
    }

    .bg-right {
        right: 20px;
        top: 40px;
    }
}

/* ================= GUIDED SECTION ================= */

.guides-section {
    padding: 100px 120px;
    background: #fff;
}

/* ================= TOP ================= */
.guided-section-container {
    max-width: 1340px;
    margin: 0 auto;
    padding: 0 24px;
}

.guides-top {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 80px;
    margin-bottom: 100px;
}

.guides-subtitle {
    font-size: 32px;
    font-weight: 800;
    margin-bottom: 14px;
}

.guides-desc {
    font-size: 14px;
    color: #555;
    margin-bottom: 32px;
    line-height: 1.6;
}

.founder {
    display: flex;
    align-items: end;
    gap: 14px;
}

.founder img {
    width: 70px;
    height: 50px;
    border-radius: 15%;
    -webkit-border-radius: 15%;
    -moz-border-radius: 15%;
    -ms-border-radius: 15%;
    -o-border-radius: 15%;
}

.founder strong {
    display: block;
    font-size: 14px;
}

.founder span {
    font-size: 12px;
    color: #777;
}

/* RIGHT */

.guides-right .principle {
    margin-bottom: 36px;
}

.guides-right h4 {
    font-size: 15px;
    font-weight: 600;
    margin-bottom: 8px;
}

.guides-right p {
    font-size: 14px;
    line-height: 1.7;
    color: #878787;
}

/* ================= BOTTOM ================= */

.guides-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 40px;
}

.guides-header h2 {
    font-size: 34px;
    font-weight: 600;
}

.blog-btn {
    background: #000;
    color: #fff;
    padding: 10px 16px;
    border-radius: 6px;
    font-size: 14px;
    text-decoration: none;
}

/* CARDS */

.guides-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
}

.guide-card {
    position: relative;
    border-radius: 16px;
    overflow: hidden;
}

.guide-card img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.guide-card span {
    position: absolute;
    bottom: 30px;
    left: 20px;
    right: 20px;
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.4;
}

@media (max-width: 1024px) {
    .guides-section {
        padding: 80px 40px;
    }

    .guides-top {
        grid-template-columns: 1fr;
        gap: 60px;
    }
}

@media (max-width: 640px) {
    .guides-section {
        padding: 60px 20px;
    }

    .guides-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px;
    }

    .guides-header h2 {
        font-size: 26px;
    }
}

.founder-img {
    position: relative;
    width: 135px;
}

.founder-img img:first-child {
    width: 135px;
    height: 170px;
    border-radius: 16px;
    object-fit: cover;
}

.signature {
    position: absolute;
    bottom: -12px;
    left: -10px;
    width: 70px;
}

.principle-row {
    display: grid;
    grid-template-columns: 400px 400px 1fr;
    gap: 24px;
    margin-bottom: 36px;
}

.principle-tag {
    font-size: 16px;
    font-weight: 600;
}

.principle-row h4 {
    font-size: 15px;
    font-weight: 600;
    margin: 0;
}

.principle-row p {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 8px;
}


/* ===========================
   OWNER-LIKE INFINITE TRUSTED
   =========================== */

.trusted.trusted-infinite {
    /* padding: 80px 0 90px; */
    background: #fff;
}

.trusted-title {
    max-width: 1240px;
    margin: 0 auto 28px;
    padding: 0 40px;
    font-size: 45px;
    font-weight: 750;
    letter-spacing: -0.02em;
    color: #000;
    text-align: left;
}

/* viewport hides overflow like owner.com */
.trusted-viewport {
    margin: 0 auto;
    padding: 0 18px;
    overflow: hidden;
}

/* track moves via JS */
.trusted-track {
    display: flex;
    gap: 18px;
    will-change: transform;
    transform: translate3d(0, 0, 0);
    user-select: none;
    touch-action: pan-y;
    /* keep vertical scroll */
    cursor: grab;
}

.trusted-track.is-dragging {
    cursor: grabbing;
}

/* card sizing similar to owner */
.trusted-card {
    flex: 0 0 auto;
    width: clamp(260px, 22vw, 320px);
}

.trusted-card img {
    width: 100%;
    height: clamp(290px, 26vw, 360px);
    border-radius: 22px;
    object-fit: cover;
    display: block;
}

/* below-image meta (your current style) */
.trusted-meta {
    padding: 12px 4px 0;
}

.trusted-name {
    font-size: 16px;
    font-weight: 700;
    margin-bottom: 3px;
    color: #000;
}

.trusted-role {
    font-size: 12px;
    font-weight: 600;
    color: #7a7a7a;
}

@media (max-width: 1024px) {
    .trusted-title {
        font-size: 38px;
        padding: 0 24px;
    }
}

@media (max-width: 640px) {
    .trusted-title {
        font-size: 30px;
    }

    .reveal.is-visible {
        display: grid;
        text-align: center;
    }

}
