:root {
    --kt-red: #D50000;
    --kt-red-dark: #a90000;
    --kt-black: #111;
    --kt-dark: #171717;
    --kt-gray: #5c5c5c;
    --kt-light: #f7f7f7;
    --kt-white: #fff;
    --kt-border: #e7e7e7;
    --kt-shadow: 0 20px 60px rgba(0, 0, 0, .12);
    --kt-radius: 24px;
    --kt-font: 'Roboto', sans-serif
}



* {
    box-sizing: border-box
}

html {
    scroll-behavior: smooth
}

body {
    margin: 0;
    font-family: var(--kt-font);
    color: var(--kt-black);
    background: #fff;
    line-height: 1.65
}

img {
    max-width: 100%;
    height: auto;
    display: block
}

a {
    color: inherit;
    text-decoration: none
}

.kt-container {
    width: min(1180px, calc(100% - 32px));
    margin-inline: auto
}

.screen-reader-text {
    position: absolute !important;
    height: 1px;
    width: 1px;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px)
}

.skip-link:focus {
    left: 12px;
    top: 12px;
    z-index: 9999;
    background: #fff;
    padding: 12px;
    clip: auto;
    width: auto;
    height: auto
}

.kt-topbar {
    background: var(--kt-black);
    color: #fff;
    font-size: 14px
}

.kt-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 8px 0
}

.kt-top-links {
    display: flex;
    gap: 18px;
    align-items: center;
    flex-wrap: wrap
}

.kt-top-links a,
.kt-top-links span {
    display: inline-flex;
    align-items: center;
    gap: 6px
}

.kt-topbar-icon {
    width: 15px;
    height: 15px;
    stroke: var(--kt-red);
    stroke-width: 2.2px;
    fill: none;
    flex-shrink: 0
}

.kt-header {
    position: sticky;
    top: 0;
    z-index: 999;
    background: rgba(255, 255, 255, .92);
    backdrop-filter: blur(14px);
    border-bottom: 1px solid rgba(0, 0, 0, .08)
}

.admin-bar .kt-header {
    top: 32px
}

.kt-nav-wrap {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 12px 0
}

.kt-logo {
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 190px
}

.kt-logo img {
    width: 220px;
    max-height: 74px;
    object-fit: contain
}

.kt-site-title {
    font-weight: 900;
    font-size: 22px;
    line-height: 1
}

.kt-menu {
    display: flex;
    align-items: center;
    gap: 6px;
    margin: 0;
    padding: 0;
    list-style: none
}

.kt-menu li {
    list-style: none
}

.kt-menu a {
    display: block;
    padding: 11px 14px;
    border-radius: 999px;
    font-weight: 800;
    font-size: 14px;
    color: #202020
}

.kt-menu a:hover,
.kt-menu .current-menu-item>a {
    background: var(--kt-red);
    color: #fff
}

.kt-nav-actions {
    display: flex;
    align-items: center;
    gap: 10px
}

.kt-btn,
.wp-block-button__link,
.kt-form button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 999px;
    padding: 13px 20px;
    border: 0;
    background: var(--kt-red);
    color: #fff;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .02em;
    box-shadow: 0 12px 24px rgba(213, 0, 0, .22);
    transition: .25s ease;
    cursor: pointer
}

.kt-btn:hover,
.wp-block-button__link:hover,
.kt-form button:hover {
    transform: translateY(-2px);
    background: var(--kt-red-dark);
    color: #fff
}

.kt-btn-dark {
    background: var(--kt-black);
    box-shadow: 0 12px 28px rgba(0, 0, 0, .2)
}

.kt-btn-outline {
    background: #fff;
    color: var(--kt-black);
    border: 1px solid #ddd;
    box-shadow: none
}

.kt-btn-whatsapp {
    background: #25D366
}

.kt-mobile-toggle {
    display: none;
    border: 0;
    background: var(--kt-black);
    color: #fff;
    border-radius: 14px;
    padding: 11px 13px;
    font-weight: 900
}

.kt-hero {
    position: relative;
    overflow: hidden;
    background: radial-gradient(circle at 74% 34%, rgba(213, 0, 0, .16), transparent 32%), linear-gradient(135deg, #0c0c0c 0%, #171717 54%, #2a0000 100%);
    color: #fff
}

.kt-hero:before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(0, 0, 0, .82), rgba(0, 0, 0, .45)), url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="900" height="500" viewBox="0 0 900 500"><rect width="900" height="500" fill="%23111111"/><path d="M60 380h760M120 320h650M210 260h520" stroke="%23D50000" stroke-width="4" opacity=".35"/><circle cx="660" cy="350" r="70" fill="none" stroke="%23ffffff" stroke-width="18" opacity=".18"/><circle cx="300" cy="350" r="55" fill="none" stroke="%23ffffff" stroke-width="16" opacity=".16"/><path d="M180 250h300l70 70h150v48H130v-70c0-27 22-48 50-48z" fill="%23ffffff" opacity=".09"/></svg>') center/cover;
    opacity: .9
}

.kt-hero-inner {
    position: relative;
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    align-items: center;
    gap: 34px;
    padding: 86px 0 72px
}

.kt-kicker {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(213, 0, 0, .15);
    border: 1px solid rgba(255, 255, 255, .14);
    padding: 8px 14px;
    border-radius: 999px;
    color: #fff;
    font-weight: 900;
    font-size: 13px;
    text-transform: uppercase
}

.kt-hero h1 {
    font-size: clamp(40px, 6vw, 76px);
    line-height: .95;
    margin: 18px 0 16px;
    letter-spacing: -0.015em
}

.kt-hero p {
    font-size: clamp(17px, 2vw, 22px);
    color: rgba(255, 255, 255, .82);
    max-width: 660px
}

.kt-hero-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin: 28px 0
}

.kt-trust-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 28px
}

.kt-trust-pill {
    background: rgba(255, 255, 255, .09);
    border: 1px solid rgba(255, 255, 255, .14);
    border-radius: 16px;
    padding: 12px 14px;
    font-weight: 800
}

.kt-hero-visual {
    position: relative;
    min-height: 420px;
    display: grid;
    place-items: center
}

.kt-tire-orbit {
    width: min(420px, 80vw);
    aspect-ratio: 1;
    border-radius: 50%;
    background: url('../images/tire.png') no-repeat center center;
    background-size: contain;
    box-shadow: 0 0 0 18px rgba(255, 255, 255, .06), 0 35px 80px rgba(0, 0, 0, .45);
    position: relative;
    animation: ktRotate 6s linear infinite
}

.kt-tire-orbit:before,
.kt-tire-orbit:after {
    display: none
}

.kt-tire-logo {
    position: absolute;
    width: 250px;
    border-radius: 20px;
    background: #fff;
    padding: 10px;
    box-shadow: var(--kt-shadow);
    z-index: 2
}

.kt-speed-lines {
    position: absolute;
    inset: auto 0 45px auto;
    width: 58%;
    height: 90px;
    background: repeating-linear-gradient(0deg, transparent 0 18px, rgba(213, 0, 0, .8) 19px 24px);
    transform: skewX(-22deg);
    opacity: .8
}

.kt-floating-card {
    position: absolute;
    left: 0;
    bottom: 42px;
    background: #fff;
    color: var(--kt-black);
    border-radius: 22px;
    padding: 18px;
    box-shadow: var(--kt-shadow);
    width: 230px
}

.kt-floating-card strong {
    display: block;
    font-size: 28px;
    color: var(--kt-red)
}

@keyframes ktRotate {
    to {
        transform: rotate(360deg)
    }
}

.kt-section {
    padding: 82px 0
}

.kt-section-sm {
    padding: 48px 0
}

.kt-bg-light {
    background: var(--kt-light)
}

.kt-bg-dark {
    background: var(--kt-black);
    color: #fff
}

.kt-section-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 22px;
    margin-bottom: 34px
}

.kt-section-head h2,
.entry-content h2 {
    font-size: clamp(30px, 4vw, 50px);
    line-height: 1.03;
    margin: 0 0 10px;
    letter-spacing: -0.015em
}

.kt-section-head p {
    max-width: 650px;
    color: var(--kt-gray);
    margin: 0
}

.kt-bg-dark .kt-section-head p {
    color: rgba(255, 255, 255, .72)
}

.kt-grid {
    display: grid;
    gap: 22px
}

.kt-grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr))
}

.kt-grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr))
}

.kt-card {
    background: #fff;
    border: 1px solid var(--kt-border);
    border-radius: var(--kt-radius);
    padding: 28px;
    box-shadow: 0 14px 40px rgba(0, 0, 0, .06);
    position: relative;
    overflow: hidden
}

.kt-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--kt-shadow);
    transition: .28s ease
}

.kt-card-dark {
    background: #171717;
    border-color: rgba(255, 255, 255, .1);
    color: #fff
}

.kt-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: rgba(213, 0, 0, .1);
    display: grid;
    place-items: center;
    color: var(--kt-red);
    font-size: 28px;
    margin-bottom: 18px
}

.kt-card h3 {
    margin: 0 0 10px;
    font-size: 22px
}

.kt-card p {
    margin: 0 0 18px;
    color: var(--kt-gray)
}

.kt-card-dark p {
    color: rgba(255, 255, 255, .72)
}

.kt-emergency {
    background: linear-gradient(135deg, #d50000 0%, #aa0000 50%, #7a0000 80%, #300000 100%);
    color: #fff;
    position: relative;
    overflow: hidden;
}

.kt-emergency-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    padding: 24px 0;
    position: relative;
    z-index: 5;
}

.kt-emergency-visual {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 100%;
    display: flex;
    align-items: center;
    z-index: 2;
    opacity: 0.85;
    pointer-events: none;
}

.kt-emergency-visual img {
    height: 140%;
    width: auto;
    object-fit: contain;
    transform: translateX(40px) rotate(-15deg);
    filter: drop-shadow(-10px 0 20px rgba(0, 0, 0, 0.5));
}

.kt-emergency h2 {
    margin: 0;
    font-size: clamp(26px, 4vw, 42px)
}

.kt-areas {
    display: flex;
    gap: 10px;
    flex-wrap: wrap
}

.kt-area {
    padding: 12px 16px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid var(--kt-border);
    font-weight: 900
}

.kt-page-hero {
    padding: 76px 0;
    background: linear-gradient(135deg, #111, #260000);
    color: #fff;
    position: relative;
    overflow: hidden;
    text-align: center;
}

.kt-page-hero::before {
    content: "";
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.28;
    z-index: 1;
    pointer-events: none;
}

.kt-page-hero:after {
    content: "";
    position: absolute;
    right: -80px;
    top: -100px;
    width: 360px;
    aspect-ratio: 1;
    border-radius: 50%;
    border: 40px solid rgba(213, 0, 0, .24);
    animation: ktRotate 14s linear infinite;
    z-index: 2;
}

.kt-page-hero h1 {
    position: relative;
    font-size: clamp(38px, 6vw, 68px);
    line-height: 1;
    margin: 0;
    letter-spacing: -0.015em;
    z-index: 3;
}

.kt-breadcrumbs {
    position: relative;
    margin-top: 14px;
    color: rgba(255, 255, 255, .74);
    font-weight: 700
}

.entry-content {
    font-size: 18px
}

.entry-content a {
    color: var(--kt-red);
    font-weight: 800
}

.kt-service-row {
    display: grid;
    grid-template-columns: 80px 1fr auto;
    gap: 22px;
    align-items: center;
    background: #fff;
    border: 1px solid var(--kt-border);
    border-radius: 26px;
    padding: 24px;
    margin-bottom: 18px;
    box-shadow: 0 12px 34px rgba(0, 0, 0, .055)
}

.kt-service-number {
    width: 68px;
    height: 68px;
    border-radius: 22px;
    background: var(--kt-black);
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 900;
    font-size: 20px
}

.kt-gallery-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px
}

.kt-gallery-item {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    background: #111;
    min-height: 260px;
    border: 1px solid var(--kt-border);
    cursor: pointer
}

.kt-gallery-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: .35s ease
}

.kt-gallery-item:hover img {
    transform: scale(1.06)
}

.kt-gallery-caption {
    position: absolute;
    inset: auto 14px 14px;
    background: rgba(0, 0, 0, .72);
    color: #fff;
    border-radius: 16px;
    padding: 12px;
    font-weight: 900
}

.kt-placeholder-img {
    height: 280px;
    background: radial-gradient(circle at 75% 30%, rgba(213, 0, 0, .35), transparent 26%), linear-gradient(135deg, #161616, #333);
    display: grid;
    place-items: center;
    color: #fff;
    font-size: 18px;
    font-weight: 900;
    text-align: center;
    padding: 20px
}

.kt-contact-wrap {
    display: grid;
    grid-template-columns: .9fr 1.1fr;
    gap: 24px
}

.kt-form {
    display: grid;
    gap: 14px
}

.kt-form input,
.kt-form textarea,
.kt-form select,
.wpcf7-form input,
.wpcf7-form textarea {
    width: 100%;
    border: 1px solid var(--kt-border);
    border-radius: 16px;
    padding: 15px 16px;
    font: inherit;
    background: #fff
}

.kt-form textarea,
.wpcf7-form textarea {
    min-height: 140px
}

.kt-info-list {
    display: grid;
    gap: 14px
}

.kt-info-item {
    display: flex;
    gap: 12px;
    padding: 16px;
    border: 1px solid var(--kt-border);
    border-radius: 18px;
    background: #fff
}

.kt-map {
    border: 0;
    width: 100%;
    height: 430px;
    border-radius: 24px;
    filter: saturate(.85)
}

.kt-footer {
    background: #0d0d0d;
    color: #fff;
    padding: 62px 0 26px
}

.kt-footer-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr 1fr;
    gap: 34px
}

.kt-footer a {
    color: rgba(255, 255, 255, .82)
}

.kt-footer a:hover {
    color: #fff
}

.kt-footer h3 {
    margin-top: 0
}

.kt-footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, .11);
    margin-top: 34px;
    padding-top: 22px;
    display: flex;
    justify-content: space-between;
    gap: 15px;
    color: rgba(255, 255, 255, .62);
    font-size: 14px
}

.kt-sticky-actions {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 1000;
    display: grid;
    gap: 10px
}

.kt-sticky-actions a {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    font-size: 22px;
    font-weight: 900;
    box-shadow: 0 12px 30px rgba(0, 0, 0, .25)
}

.kt-sticky-call {
    background: var(--kt-red)
}

.kt-sticky-wa {
    background: #25D366
}

.kt-lightbox {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, .86);
    display: none;
    align-items: center;
    justify-content: center;
    z-index: 2000;
    padding: 22px
}

.kt-lightbox.is-open {
    display: flex
}

.kt-lightbox img {
    max-height: 86vh;
    border-radius: 18px
}

.kt-lightbox button {
    position: absolute;
    top: 20px;
    right: 20px;
    border: 0;
    background: #fff;
    border-radius: 999px;
    padding: 10px 14px;
    font-weight: 900
}

.alignwide {
    max-width: 1180px;
    margin-inline: auto
}

.alignfull {
    width: 100vw;
    margin-left: calc(50% - 50vw)
}

.wp-block-image img {
    border-radius: 22px
}

@media (prefers-reduced-motion:reduce) {

    *,
    *:before,
    *:after {
        animation: none !important;
        transition: none !important
    }
}

@media(max-width:960px) {
    .kt-topbar-inner {
        justify-content: center;
        text-align: center
    }

    .kt-top-links {
        display: none
    }

    .kt-mobile-toggle {
        display: inline-flex
    }

    .kt-menu-wrap {
        position: absolute;
        top: 100%;
        left: 0;
        right: 0;
        background: #fff;
        border-bottom: 1px solid var(--kt-border);
        box-shadow: var(--kt-shadow);
        display: none
    }

    .kt-menu-wrap.is-open {
        display: block
    }

    .kt-menu {
        display: grid;
        gap: 0;
        padding: 12px
    }

    .kt-menu a {
        border-radius: 14px
    }

    .kt-nav-actions .kt-btn {
        display: none
    }

    .kt-logo img {
        width: 190px
    }

    .kt-hero-inner {
        grid-template-columns: 1fr;
        padding: 62px 0
    }

    .kt-hero-visual {
        min-height: 310px
    }

    .kt-tire-orbit {
        width: 310px
    }

    .kt-tire-logo {
        width: 205px
    }

    .kt-floating-card {
        position: relative;
        left: auto;
        bottom: auto;
        margin-top: -30px
    }

    .kt-section-head,
    .kt-emergency-inner {
        display: grid
    }

    .kt-emergency-visual {
        display: none
    }

    .kt-grid-2,
    .kt-grid-3,
    .kt-contact-wrap,
    .kt-footer-grid {
        grid-template-columns: 1fr
    }

    .kt-service-row {
        grid-template-columns: 1fr
    }

    .kt-gallery-grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media(max-width:600px) {
    body {
        font-size: 16px
    }

    .admin-bar .kt-header {
        top: 0
    }

    .kt-container {
        width: min(100% - 24px, 1180px)
    }

    .kt-logo img {
        width: 165px
    }

    .kt-hero h1 {
        font-size: 42px
    }

    .kt-hero-actions .kt-btn {
        width: 100%
    }

    .kt-trust-pill {
        width: 100%;
        text-align: center
    }

    .kt-section {
        padding: 58px 0
    }

    .kt-card {
        padding: 22px
    }

    .kt-gallery-grid {
        grid-template-columns: 1fr
    }

    .kt-gallery-item {
        min-height: 220px
    }

    .kt-map {
        height: 320px
    }

    .kt-footer-bottom {
        display: grid
    }

    .kt-sticky-actions {
        left: 12px;
        right: 12px;
        bottom: 12px;
        grid-template-columns: 1fr 1fr
    }

    .kt-sticky-actions a {
        width: auto;
        border-radius: 999px;
        height: 52px
    }

    .kt-sticky-call:after {
        content: " Call"
    }

    .kt-sticky-wa:after {
        content: " WhatsApp"
    }
}

/* ===== Klimax Pro UI Fix v2: buttons, typography, card borders, floating icons ===== */
:root {
    --kt-red: #D50000;
    --kt-red-2: #b40000;
    --kt-black: #111111;
    --kt-ink: #151515;
    --kt-muted: #555;
    --kt-border-strong: #d8d8d8;
    --kt-card-border: #dedede;
    --kt-soft: #f6f6f6;
    --kt-ring: 0 0 0 4px rgba(213, 0, 0, .12)
}

body {
    font-size: 17px;
    line-height: 1.72;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility
}

.kt-hero h1 {
    /* font-weight: 900; */
    letter-spacing: -0.015em
}

.kt-section-head h2,
.entry-content h2 {
    /* font-weight: 900; */
    letter-spacing: -0.015em
}

.kt-card h3,
.kt-service-row h3 {
    font-size: 24px;
    line-height: 1.18;
    /* font-weight: 900 */
}

.kt-card p,
.kt-service-row p {
    font-size: 16.5px;
    line-height: 1.7
}

.kt-menu a {
    font-size: 15px;
    font-weight: 900
}

.kt-kicker {
    font-size: 12px;
    letter-spacing: .08em
}

.kt-btn,
.wp-block-button__link,
.kt-form button {
    min-height: 48px;
    padding: 14px 22px;
    border: 2px solid transparent;
    font-size: 14px;
    line-height: 1.1;
    box-shadow: 0 12px 26px rgba(213, 0, 0, .24);
    white-space: nowrap;
    flex-shrink: 0
}

.kt-btn:hover,
.wp-block-button__link:hover,
.kt-form button:hover {
    background: var(--kt-black);
    border-color: var(--kt-black);
    color: #fff;
    transform: translateY(-2px)
}

.kt-btn:focus-visible,
.kt-menu a:focus-visible,
.kt-sticky-actions a:focus-visible {
    outline: 0;
    box-shadow: var(--kt-ring), 0 12px 26px rgba(0, 0, 0, .18)
}

.kt-btn-dark {
    background: var(--kt-black);
    border-color: var(--kt-black);
    color: #fff;
    box-shadow: 0 14px 32px rgba(0, 0, 0, .28)
}

.kt-btn-dark:hover {
    background: #fff;
    color: var(--kt-black);
    border-color: #fff;
    box-shadow: 0 18px 35px rgba(0, 0, 0, .22)
}

.kt-btn-outline {
    background: #fff;
    color: var(--kt-black);
    border-color: #d5d5d5;
    box-shadow: 0 10px 24px rgba(0, 0, 0, .08)
}

.kt-btn-outline:hover {
    background: var(--kt-black);
    color: #fff;
    border-color: var(--kt-black)
}

.kt-btn-whatsapp {
    background: #1fae57;
    border-color: #1fae57;
    box-shadow: 0 12px 26px rgba(31, 174, 87, .24)
}

.kt-btn-whatsapp:hover {
    background: #128c43;
    border-color: #128c43;
    color: #fff
}

.kt-emergency .kt-btn,
.kt-bg-dark .kt-btn {
    background: #fff;
    color: var(--kt-black);
    border-color: #fff;
    box-shadow: 0 14px 30px rgba(0, 0, 0, .22)
}

.kt-emergency .kt-btn:hover,
.kt-bg-dark .kt-btn:hover {
    background: var(--kt-black);
    border-color: var(--kt-black);
    color: #fff
}

.kt-emergency .kt-btn-whatsapp,
.kt-bg-dark .kt-btn-whatsapp {
    background: #1fae57;
    color: #fff;
    border-color: #1fae57
}

.kt-emergency .kt-btn-whatsapp:hover,
.kt-bg-dark .kt-btn-whatsapp:hover {
    background: #128c43;
    border-color: #128c43;
    color: #fff
}

.kt-emergency .kt-btn-dark {
    background: #111;
    color: #fff;
    border-color: #111
}

.kt-emergency .kt-btn-dark:hover {
    background: #fff;
    color: #111;
    border-color: #fff
}

.kt-card {
    border: 2px solid var(--kt-card-border);
    box-shadow: 0 10px 28px rgba(0, 0, 0, .07)
}

.kt-card:hover {
    border-color: rgba(213, 0, 0, .38)
}

.kt-card-dark {
    border: 2px solid rgba(255, 255, 255, .18)
}

.kt-icon {
    border: 1px solid rgba(213, 0, 0, .16);
    font-weight: 900
}

.kt-service-row {
    border: 2px solid var(--kt-card-border);
    box-shadow: 0 12px 32px rgba(0, 0, 0, .07)
}

.kt-service-row:hover {
    border-color: rgba(213, 0, 0, .38);
    box-shadow: 0 18px 42px rgba(0, 0, 0, .1)
}

.kt-area {
    border: 2px solid var(--kt-card-border);
    box-shadow: 0 8px 18px rgba(0, 0, 0, .045)
}

.kt-info-item,
.kt-form input,
.kt-form textarea,
.kt-form select,
.wpcf7-form input,
.wpcf7-form textarea {
    border: 2px solid var(--kt-border-strong)
}

.kt-form input:focus,
.kt-form textarea:focus,
.kt-form select:focus,
.wpcf7-form input:focus,
.wpcf7-form textarea:focus {
    outline: 0;
    border-color: var(--kt-red);
    box-shadow: var(--kt-ring)
}

.kt-gallery-item {
    border: 2px solid var(--kt-card-border)
}

.kt-page-hero {
    border-bottom: 6px solid var(--kt-red)
}

.kt-sticky-actions {
    gap: 12px
}

.kt-sticky-actions a {
    width: 60px;
    height: 60px;
    border: 2px solid rgba(255, 255, 255, .45);
    font-size: 0;
    position: relative;
    overflow: hidden
}

.kt-sticky-actions a svg {
    width: 28px;
    height: 28px;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 2.4;
    stroke-linecap: round;
    stroke-linejoin: round
}

.kt-sticky-call {
    background: var(--kt-red)
}

.kt-sticky-call:hover {
    background: var(--kt-black);
    transform: translateY(-3px)
}

.kt-sticky-wa {
    background: #1fae57
}

.kt-sticky-wa:hover {
    background: #128c43;
    transform: translateY(-3px)
}

.kt-sticky-wa svg {
    fill: currentColor;
    stroke: none
}

.kt-topbar {
    font-weight: 750
}

.kt-footer {
    border-top: 6px solid var(--kt-red)
}

@media(max-width:960px) {
    body {
        font-size: 16.5px
    }

    .kt-card h3,
    .kt-service-row h3 {
        font-size: 22px
    }

    .kt-btn {
        min-height: 50px
    }

    .kt-card {
        border-width: 2px
    }

    .kt-menu a {
        font-size: 16px;
        padding: 14px 16px;
        border: 1px solid #eee
    }

    .kt-menu a:hover,
    .kt-menu .current-menu-item>a {
        border-color: var(--kt-red)
    }
}

@media(max-width:600px) {
    .kt-hero h1 {
        font-size: 44px;
        line-height: .98
    }

    .kt-section-head h2,
    .entry-content h2 {
        font-size: 34px
    }

    .kt-card h3,
    .kt-service-row h3 {
        font-size: 21px
    }

    .kt-card p,
    .kt-service-row p {
        font-size: 16px
    }

    .kt-sticky-actions a {
        height: 54px;
        border-radius: 999px;
        font-size: 14px;
        gap: 8px
    }

    .kt-sticky-actions a svg {
        width: 22px;
        height: 22px
    }

    .kt-sticky-call:after {
        content: "Call Now";
        font-weight: 900
    }

    .kt-sticky-wa:after {
        content: "WhatsApp";
        font-weight: 900
    }

    .kt-sticky-actions a {
        display: flex;
        align-items: center;
        justify-content: center
    }

    .kt-emergency-inner .kt-btn {
        width: 100%
    }
}

/* ===== Klimax Pro v3: latest-model About + Services pages ===== */
.kt-kicker-light {
    background: #fff;
    border: 2px solid rgba(213, 0, 0, .14);
    color: var(--kt-red);
    box-shadow: 0 10px 24px rgba(0, 0, 0, .05)
}

.kt-about-grid,
.kt-service-intro-grid,
.kt-process-grid,
.kt-service-process-grid {
    display: grid;
    grid-template-columns: 1.05fr .95fr;
    gap: 34px;
    align-items: center
}

.kt-about-copy h2,
.kt-services-intro h2,
.kt-process-grid h2,
.kt-service-process-grid h2 {
    font-size: clamp(34px, 4.6vw, 58px);
    line-height: 1.02;
    letter-spacing: -0.015em;
    margin: 16px 0;
    font-weight: 900
}

.kt-editable-content {
    background: #fff;
    border: 2px solid var(--kt-card-border);
    border-radius: 24px;
    padding: 22px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .055)
}

.kt-about-intro .kt-editable-content,
.kt-services-intro .kt-editable-content {
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
}

.kt-about-intro .kt-editable-content h2,
.kt-services-intro .kt-editable-content h2 {
    display: none;
}

.kt-about-intro .kt-editable-content p,
.kt-services-intro .kt-editable-content p {
    font-size: clamp(16px, 2vw, 18px);
    line-height: 1.7;
    color: var(--kt-gray);
    margin-bottom: 24px;
}

.kt-about-actions,
.kt-cta-actions,
.kt-service-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 22px
}

.kt-about-visual,
.kt-service-side-card {
    position: relative;
    min-height: 430px;
    border-radius: 34px;
    background: radial-gradient(circle at 70% 25%, rgba(213, 0, 0, .34), transparent 30%), linear-gradient(135deg, #111, #292929);
    overflow: hidden;
    border: 2px solid rgba(255, 255, 255, .08);
    box-shadow: 0 28px 70px rgba(0, 0, 0, .18);
    display: grid;
    place-items: center;
    padding: 26px;
    color: #fff
}

.kt-about-visual:before,
.kt-service-side-card:before {
    content: "";
    position: absolute;
    inset: -80px;
    background: repeating-linear-gradient(135deg, rgba(255, 255, 255, .07) 0 1px, transparent 1px 18px);
    opacity: .35
}

.kt-rotating-mini-tire {
    width: 220px;
    aspect-ratio: 1;
    border-radius: 50%;
    background: url('../images/tire.png') no-repeat center center;
    background-size: 100%;
    position: relative;
    animation: ktRotate 8s linear infinite;
    box-shadow: 0 0 0 14px rgba(255, 255, 255, .08), 0 22px 60px rgba(0, 0, 0, .38);
    z-index: 1
}

.kt-rotating-mini-tire:before {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 50%;
    background: repeating-conic-gradient(#090909 0 7deg, #3f3f3f 7deg 11deg, #111 11deg 18deg)
}

.kt-rotating-mini-tire:after {
    content: "";
    position: absolute;
    inset: 74px;
    border-radius: 50%;
    background: radial-gradient(circle, #fff 0 17%, #bcbcbc 18% 28%, #111 29% 46%, transparent 47%);
    box-shadow: inset 0 0 0 10px #ececec
}

.kt-glass-panel {
    position: absolute;
    left: 24px;
    right: 24px;
    bottom: 24px;
    z-index: 2;
    background: rgba(255, 255, 255, .12);
    backdrop-filter: blur(14px);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 24px;
    padding: 18px
}

.kt-glass-panel strong {
    display: block;
    font-size: 22px;
    line-height: 1.15
}

.kt-glass-panel span {
    display: block;
    color: rgba(255, 255, 255, .76);
    margin-top: 6px
}

.kt-about-badge {
    position: absolute;
    z-index: 2;
    background: #fff;
    color: #111;
    border-radius: 999px;
    padding: 11px 15px;
    font-weight: 950;
    box-shadow: 0 16px 34px rgba(0, 0, 0, .2);
    border: 2px solid rgba(213, 0, 0, .22)
}

.kt-about-badge-one {
    top: 28px;
    left: 28px
}

.kt-about-badge-two {
    right: 26px;
    top: 112px
}

.kt-stats-band {
    background: var(--kt-red);
    color: #fff;
    padding: 22px 0
}

.kt-stats-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 14px
}

.kt-stat-card {
    background: rgba(255, 255, 255, .11);
    border: 1px solid rgba(255, 255, 255, .2);
    border-radius: 22px;
    padding: 18px;
    text-align: center
}

.kt-stat-card strong {
    display: block;
    font-size: clamp(28px, 4vw, 44px);
    line-height: 1;
    font-weight: 950
}

.kt-stat-card span {
    display: block;
    margin-top: 8px;
    font-weight: 850;
    color: rgba(255, 255, 255, .82)
}

.kt-value-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px
}

.kt-value-card {
    position: relative;
    background: #fff;
    border: 2px solid var(--kt-card-border);
    border-radius: 28px;
    padding: 28px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, .065);
    overflow: hidden;
    transition: .25s ease
}

.kt-value-card:before {
    content: "";
    position: absolute;
    inset: 0 0 auto;
    height: 5px;
    background: var(--kt-red)
}

.kt-value-card:hover {
    transform: translateY(-6px);
    border-color: rgba(213, 0, 0, .42);
    box-shadow: 0 22px 52px rgba(0, 0, 0, .11)
}

.kt-value-icon,
.kt-service-emoji {
    width: 58px;
    height: 58px;
    border-radius: 20px;
    background: #fff1f1;
    border: 2px solid rgba(213, 0, 0, .16);
    display: grid;
    place-items: center;
    font-size: 28px;
    margin-bottom: 20px
}

.kt-value-card h3 {
    font-size: 25px;
    margin: 0 0 10px;
    font-weight: 900;
    letter-spacing: -0.01em
}

.kt-process-section {
    background: #fff
}

.kt-process-list {
    display: grid;
    gap: 14px
}

.kt-process-item {
    display: grid;
    grid-template-columns: 78px 1fr;
    align-items: center;
    gap: 16px;
    background: #fff;
    border: 2px solid var(--kt-card-border);
    border-radius: 24px;
    padding: 16px;
    box-shadow: 0 10px 26px rgba(0, 0, 0, .055)
}

.kt-process-item span {
    width: 58px;
    height: 58px;
    border-radius: 18px;
    background: #111;
    color: #fff;
    display: grid;
    place-items: center;
    font-weight: 950
}

.kt-process-item strong {
    font-size: 20px
}

.kt-about-cta {
    background: linear-gradient(135deg, var(--kt-red), #7c0000);
    color: #fff
}

.kt-about-cta .kt-emergency-inner {
    background: transparent;
    border: 0;
    padding: 0;
    box-shadow: none
}

.kt-about-cta h2 {
    font-size: clamp(32px, 4vw, 52px);
    line-height: 1.05;
    margin: 12px 0;
    font-weight: 950;
    letter-spacing: -.05em
}

.kt-about-cta-bar h2 {
    font-size: clamp(32px, 4vw, 48px);
    line-height: 1.1;
    font-weight: 900;
    margin-bottom: 8px;
    letter-spacing: -0.015em;
}

.kt-about-cta-bar p {
    font-size: clamp(14px, 1.4vw, 17px);
    margin: 0;
    opacity: 0.95;
    font-weight: 500;
}

.kt-about-cta .kt-btn {
    background: #fff;
    color: #111;
    border-color: #fff
}

.kt-about-cta .kt-btn:hover {
    background: #111;
    color: #fff;
    border-color: #111
}

.kt-about-cta .kt-btn-whatsapp {
    background: #1fae57;
    color: #fff;
    border-color: #1fae57
}

.kt-about-cta .kt-btn-whatsapp:hover {
    background: #128c43;
    border-color: #128c43;
    color: #fff
}

.kt-services-intro {
    background: linear-gradient(180deg, #fff, #fafafa)
}

.kt-service-side-card {
    min-height: 380px;
    align-content: center;
    text-align: center
}

.kt-service-side-card h3 {
    position: relative;
    z-index: 2;
    font-size: 30px;
    margin: 24px 0 8px;
    font-weight: 950
}

.kt-service-side-card p,
.kt-service-side-card a {
    position: relative;
    z-index: 2
}

.kt-service-nav-wrap {
    position: sticky;
    top: 98px;
    z-index: 50;
    background: rgba(255, 255, 255, .9);
    backdrop-filter: blur(14px);
    border-top: 1px solid #eee;
    border-bottom: 1px solid #eee
}

.admin-bar .kt-service-nav-wrap {
    top: 130px
}

.kt-service-filter-bar {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding: 12px 0
}

.kt-service-filter-bar a {
    white-space: nowrap;
    border: 2px solid var(--kt-card-border);
    background: #fff;
    border-radius: 999px;
    padding: 10px 16px;
    font-weight: 950;
    font-size: 14px
}

.kt-service-filter-bar a:hover,
.kt-service-filter-bar a.is-active {
    background: var(--kt-red);
    border-color: var(--kt-red);
    color: #fff
}

.kt-services-grid-modern {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px
}

.kt-service-card-modern {
    position: relative;
    background: #fff;
    border: 2px solid var(--kt-card-border);
    border-radius: 30px;
    padding: 28px;
    box-shadow: 0 16px 36px rgba(0, 0, 0, .07);
    overflow: hidden;
    transition: .25s ease
}

.kt-service-card-modern:before {
    content: "";
    position: absolute;
    right: -70px;
    top: -80px;
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background: rgba(213, 0, 0, .07)
}

.kt-service-card-modern:hover {
    transform: translateY(-6px);
    border-color: rgba(213, 0, 0, .42);
    box-shadow: 0 24px 56px rgba(0, 0, 0, .12)
}

.kt-service-card-top {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start
}

.kt-service-index {
    font-weight: 950;
    color: rgba(17, 17, 17, .18);
    font-size: 42px;
    line-height: 1
}

.kt-service-card-modern h2 {
    position: relative;
    font-size: clamp(24px, 2.3vw, 32px);
    line-height: 1.08;
    letter-spacing: -.045em;
    margin: 12px 0;
    font-weight: 950
}

.kt-benefit-box {
    display: grid;
    gap: 6px;
    background: #f7f7f7;
    border: 2px solid #e1e1e1;
    border-radius: 20px;
    padding: 15px;
    margin-top: 18px
}

.kt-benefit-box strong {
    color: var(--kt-red);
    text-transform: uppercase;
    font-size: 12px;
    letter-spacing: .08em
}

.kt-text-link {
    display: inline-flex;
    align-items: center;
    font-weight: 950;
    color: var(--kt-red)
}

.kt-service-card-modern.is-hidden {
    display: none
}

.kt-service-process-dark {
    background: radial-gradient(circle at 80% 20%, rgba(213, 0, 0, .32), transparent 28%), linear-gradient(135deg, #111, #262626);
    color: #fff
}

.kt-service-process-dark h2 {
    color: #fff
}

.kt-mini-steps {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px
}

.kt-mini-steps div {
    background: rgba(255, 255, 255, .09);
    border: 1px solid rgba(255, 255, 255, .17);
    border-radius: 22px;
    padding: 20px
}

.kt-mini-steps span {
    display: block;
    color: #ffb3b3;
    font-weight: 950;
    font-size: 14px;
    margin-bottom: 8px
}

.kt-mini-steps strong {
    font-size: 18px
}

@media(max-width:960px) {

    .kt-about-grid,
    .kt-service-intro-grid,
    .kt-process-grid,
    .kt-service-process-grid {
        grid-template-columns: 1fr
    }

    .kt-about-visual,
    .kt-service-side-card {
        min-height: 340px
    }

    .kt-stats-grid {
        grid-template-columns: repeat(2, 1fr)
    }

    .kt-value-grid,
    .kt-services-grid-modern,
    .kt-mini-steps {
        grid-template-columns: 1fr
    }

    .kt-service-nav-wrap {
        top: 78px
    }

    .admin-bar .kt-service-nav-wrap {
        top: 78px
    }

    .kt-about-copy h2,
    .kt-services-intro h2,
    .kt-process-grid h2,
    .kt-service-process-grid h2 {
        font-size: 40px
    }

    .kt-editable-content {
        padding: 18px
    }

    .kt-service-card-modern {
        padding: 24px
    }
}

@media(max-width:600px) {
    .kt-stats-grid {
        grid-template-columns: 1fr
    }

    .kt-about-visual,
    .kt-service-side-card {
        min-height: 310px;
        border-radius: 26px
    }

    .kt-rotating-mini-tire {
        width: 180px
    }

    .kt-rotating-mini-tire:after {
        inset: 60px
    }

    .kt-about-badge {
        font-size: 12px;
        padding: 9px 12px
    }

    .kt-about-badge-two {
        top: 82px
    }

    .kt-glass-panel {
        left: 14px;
        right: 14px;
        bottom: 14px
    }

    .kt-glass-panel strong {
        font-size: 18px
    }

    .kt-about-copy h2,
    .kt-services-intro h2,
    .kt-process-grid h2,
    .kt-service-process-grid h2 {
        font-size: 34px
    }

    .kt-process-item {
        grid-template-columns: 60px 1fr;
        padding: 13px
    }

    .kt-process-item span {
        width: 48px;
        height: 48px
    }

    .kt-process-item strong {
        font-size: 17px
    }

    .kt-service-filter-bar {
        width: 100%;
        padding: 10px 12px
    }

    .kt-service-card-modern h2 {
        font-size: 25px
    }

    .kt-service-actions .kt-btn {
        width: 100%
    }
}

/* ===== Klimax Interactive Why Choose Us Section Styles ===== */
.kt-why-choose-head {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    margin-bottom: 48px
}

.kt-why-choose-head h2 {
    margin-top: 10px;
    max-width: 850px;
    font-size: clamp(30px, 4.5vw, 50px);
    font-weight: 950;
    letter-spacing: -.05em;
    color: var(--kt-black);
    line-height: 1.06;
    margin-bottom: 0
}

.kt-kicker-red {
    display: block;
    color: var(--kt-red);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 0
}

.kt-grid-4 {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 20px;
    margin-top: 40px
}

.kt-why-card {
    background: #fff;
    border: 1.5px solid var(--kt-card-border);
    border-radius: 8px;
    padding: 45px 30px;
    text-align: center;
    box-shadow: 0 15px 45px rgba(0, 0, 0, .03);
    transition: all .3s cubic-bezier(.25, .8, .25, 1);
    position: relative;
    overflow: hidden
}

.kt-why-card h3 {
    font-size: 21px;
    font-weight: 950;
    line-height: 1.2;
    margin: 0 0 12px;
    color: var(--kt-black);
    letter-spacing: -.03em
}

.kt-why-card p {
    font-size: 15px;
    line-height: 1.55;
    color: var(--kt-gray);
    margin: 0
}

.kt-why-card:hover {
    transform: translateY(-8px);
    border-color: var(--kt-red);
    box-shadow: 0 22px 50px rgba(213, 0, 0, .06), 0 12px 24px rgba(0, 0, 0, .03)
}

.kt-why-card:hover .kt-why-icon-wrap {
    transform: scale(1.06);
    background-color: rgba(213, 0, 0, .04)
}

.kt-why-card.is-highlighted {
    border-color: var(--kt-red);
    box-shadow: 0 20px 40px rgba(213, 0, 0, .06)
}

.kt-why-icon-wrap {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: 5px solid var(--kt-red);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--kt-red);
    background-color: #fff;
    margin-bottom: 24px;
    transition: all .3s ease
}

.kt-why-svg {
    width: 28px;
    height: 28px;
    stroke: var(--kt-red);
    stroke-width: 2.2
}

@media(max-width:960px) {
    .kt-grid-4 {
        grid-template-columns: repeat(2, minmax(0, 1fr))
    }
}

@media(max-width:600px) {
    .kt-grid-4 {
        grid-template-columns: 1fr
    }
}

/* ===== Klimax Interactive Services Section Styles ===== */
.kt-services-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 44px;
    gap: 24px
}

.kt-services-title-area {
    flex: 1
}

.kt-services-kicker {
    display: block;
    color: var(--kt-red);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 8px
}

.kt-services-header h2 {
    margin: 0;
    font-size: clamp(30px, 4.5vw, 50px);
    font-weight: 950;
    letter-spacing: -.05em;
    color: var(--kt-black);
    line-height: 1.06;
    max-width: 800px
}

.kt-services-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: #111;
    color: #fff;
    font-weight: 900;
    font-size: 13px;
    padding: 14px 24px;
    border-radius: 6px;
    text-transform: uppercase;
    letter-spacing: .06em;
    transition: all .3s ease;
    box-shadow: 0 8px 20px rgba(0, 0, 0, .15);
    flex-shrink: 0;
    cursor: pointer
}

.kt-services-btn:hover {
    background: var(--kt-red);
    color: #fff;
    transform: translateY(-2px)
}

.kt-services-btn:hover .kt-btn-arrow {
    transform: translateX(4px)
}

.kt-btn-arrow {
    display: inline-block;
    transition: transform .3s ease;
    font-size: 16px;
    line-height: 1
}

.kt-service-modern-card {
    background: #fff;
    border: 1.5px solid var(--kt-card-border);
    border-radius: 12px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    position: relative;
    box-shadow: 0 15px 45px rgba(0, 0, 0, .03);
    transition: all .3s cubic-bezier(.25, .8, .25, 1)
}

.kt-service-modern-card:hover {
    transform: translateY(-8px);
    border-color: var(--kt-red);
    box-shadow: 0 25px 50px rgba(213, 0, 0, .06), 0 12px 24px rgba(0, 0, 0, .03)
}

.kt-service-top-bg {
    height: 150px;
    position: relative;
    background: radial-gradient(circle at center, rgba(213, 0, 0, .7) 0%, transparent 60%), repeating-linear-gradient(135deg, #1c1c1c, #1c1c1c 2px, #242424 2px, #242424 14px);
    overflow: hidden;
    transition: all .3s ease
}

.kt-service-modern-card:hover .kt-service-top-bg {
    background: radial-gradient(circle at center, rgba(213, 0, 0, .95) 0%, transparent 70%), repeating-linear-gradient(135deg, #1c1c1c, #1c1c1c 2px, #242424 2px, #242424 14px)
}

.kt-service-icon-container {
    width: 58px;
    height: 58px;
    border-radius: 50%;
    border: 4px solid #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    background: var(--kt-red);
    position: absolute;
    left: 24px;
    top: 121px;
    z-index: 2;
    box-shadow: 0 8px 16px rgba(213, 0, 0, .25);
    transition: all .3s ease
}

.kt-service-modern-card:hover .kt-service-icon-container {
    transform: scale(1.1);
    box-shadow: 0 10px 20px rgba(213, 0, 0, .35)
}

.kt-service-svg {
    width: 26px;
    height: 26px;
    stroke: #fff;
    stroke-width: 2.2
}

.kt-service-bottom-content {
    padding: 42px 24px 28px;
    text-align: left
}

.kt-service-bottom-content h3 {
    font-size: 20px;
    font-weight: 950;
    line-height: 1.2;
    margin: 0 0 10px;
    color: var(--kt-black);
    letter-spacing: -.03em
}

.kt-service-bottom-content p {
    font-size: 15px;
    line-height: 1.55;
    color: var(--kt-gray);
    margin: 0
}

@media(max-width:768px) {
    .kt-services-header {
        flex-direction: column;
        align-items: flex-start;
        gap: 16px
    }

    .kt-services-btn {
        align-self: flex-start
    }
}

/* ===== Klimax Interactive Service Areas Section Styles ===== */
.kt-areas-layout {
    display: grid;
    grid-template-columns: 1.05fr auto 1.95fr;
    gap: 40px;
    align-items: stretch
}

.kt-v4-area-divider {
    width: 1.5px;
    background: linear-gradient(180deg, transparent, var(--kt-red), transparent);
    align-self: stretch
}

.kt-areas-left-side {
    text-align: left
}

.kt-areas-kicker {
    display: block;
    color: var(--kt-red);
    font-size: 13px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 12px
}

.kt-areas-left-side h2 {
    margin: 0 0 16px;
    font-size: clamp(36px, 5.5vw, 56px);
    font-weight: 950;
    letter-spacing: -.05em;
    color: var(--kt-black);
    line-height: 1.04
}

.kt-areas-left-side p {
    font-size: 16.5px;
    line-height: 1.6;
    color: var(--kt-gray);
    margin: 0 0 34px
}

.kt-areas-info-card {
    background: #fff;
    border: 1.5px solid var(--kt-card-border);
    border-radius: 12px;
    padding: 26px;
    display: flex;
    align-items: center;
    gap: 20px;
    box-shadow: 0 12px 35px rgba(0, 0, 0, .03);
    transition: all .3s ease
}

.kt-areas-info-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(0, 0, 0, .05)
}

.kt-areas-info-icon {
    width: 52px;
    height: 52px;
    border-radius: 50%;
    background: rgba(213, 0, 0, .05);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--kt-red);
    flex-shrink: 0
}

.kt-areas-truck-svg {
    width: 24px;
    height: 24px
}

.kt-areas-info-text {
    display: flex;
    flex-direction: column;
    gap: 4px
}

.kt-areas-info-text strong {
    font-size: 16px;
    font-weight: 950;
    color: var(--kt-black)
}

.kt-areas-info-text .kt-color-red {
    font-size: 15px;
    font-weight: 950;
    color: var(--kt-red)
}

.kt-areas-right-side {
    position: relative;
    background-color: #fafafa;
    background-image: linear-gradient(45deg, #f4f4f4 25%, transparent 25%), linear-gradient(-45deg, #f4f4f4 25%, transparent 25%), linear-gradient(45deg, transparent 75%, #f4f4f4 75%), linear-gradient(-45deg, transparent 75%, #f4f4f4 75%);
    background-size: 40px 40px;
    background-position: 0 0, 0 20px, 20px -20px, -20px 0;
    border-radius: 16px;
    padding: 44px;
    border: 1.5px solid var(--kt-card-border);
    overflow: visible
}

.kt-areas-list-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px 22px
}

.kt-area-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding-bottom: 12px;
    border-bottom: 1px dashed rgba(0, 0, 0, .08);
    position: relative;
    overflow: visible;
    cursor: pointer
}

/* Tooltip container */
.kt-area-tooltip {
    position: absolute;
    bottom: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(4px) scale(0.9);
    background: var(--kt-white);
    border: 1.5px solid var(--kt-card-border);
    border-radius: 99px;
    padding: 6px 8px;
    display: flex;
    align-items: center;
    gap: 8px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.12);
    opacity: 0;
    pointer-events: none;
    z-index: 100;
    transition: opacity 0.2s cubic-bezier(0.4, 0, 0.2, 1), transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Show tooltip on hover */
.kt-area-item:hover .kt-area-tooltip {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(-6px) scale(1);
}

/* Tooltip Arrow */
.kt-area-tooltip::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 6px;
    border-style: solid;
    border-color: var(--kt-white) transparent transparent transparent;
}

/* Tooltip Arrow Border */
.kt-area-tooltip::before {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-width: 8px;
    border-style: solid;
    border-color: var(--kt-card-border) transparent transparent transparent;
    z-index: -1;
}

/* Tooltip buttons */
.kt-tooltip-btn {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    display: grid;
    place-items: center;
    color: #fff;
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1), filter 0.2s ease;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
}

.kt-tooltip-btn svg {
    width: 14px;
    height: 14px;
}

.kt-tooltip-call {
    background: var(--kt-red);
}

.kt-tooltip-call:hover {
    transform: scale(1.15);
    background: var(--kt-red-dark);
}

.kt-tooltip-wa {
    background: #25D366;
}

.kt-tooltip-wa:hover {
    transform: scale(1.15);
    background: #1fae57;
}

.kt-area-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--kt-red);
    flex-shrink: 0
}

.kt-area-pin-svg {
    width: 18px;
    height: 18px;
    stroke: var(--kt-red);
    stroke-width: 2.2
}

.kt-area-item strong {
    font-size: 15.5px;
    font-weight: 800;
    color: var(--kt-black)
}

@media(max-width:960px) {
    .kt-areas-layout {
        grid-template-columns: 1fr;
        gap: 34px
    }

    .kt-v4-area-divider {
        display: none
    }

    .kt-areas-right-side {
        padding: 30px
    }

    .kt-areas-list-grid {
        grid-template-columns: repeat(2, 1fr)
    }
}

@media(max-width:600px) {
    .kt-areas-list-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 12px 14px;
    }

    .kt-areas-right-side {
        padding: 16px;
    }

    .kt-area-item strong {
        font-size: clamp(12.5px, 3.6vw, 14.5px);
    }
}

/* ===== Fleet Service Animation Section Styles ===== */
:root {
    --scene-scale: 1;
}

@media (max-width: 1200px) {
    :root {
        --scene-scale: 0.95;
    }
}

@media (max-width: 1100px) {
    :root {
        --scene-scale: 0.88;
    }
}

@media (max-width: 1000px) {
    :root {
        --scene-scale: 0.8;
    }
}

@media (max-width: 900px) {
    :root {
        --scene-scale: 0.72;
    }
}

@media (max-width: 800px) {
    :root {
        --scene-scale: 0.64;
    }
}

@media (max-width: 700px) {
    :root {
        --scene-scale: 0.56;
    }
}

@media (max-width: 600px) {
    :root {
        --scene-scale: 0.48;
    }
}

@media (max-width: 500px) {
    :root {
        --scene-scale: 0.4;
    }
}

@media (max-width: 400px) {
    :root {
        --scene-scale: 0.32;
    }
}

@media (max-width: 350px) {
    :root {
        --scene-scale: 0.28;
    }
}

.fleet-service-animation {
    width: 100%;
    padding: 0;
    /* Full bleed edge-to-edge container */
    background: var(--kt-white);
    overflow: hidden;
}

.service-scene {
    position: relative;
    width: 100%;
    max-width: 100%;
    height: calc(270px * var(--scene-scale, 1));
    margin: 0;
    overflow: hidden;
    background: linear-gradient(to bottom, #eef4f8 0%, #f9fbfd 55%, #ffffff 100%);
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);
    transition: height 0.1s ease;
}

.scene-content {
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 1200px;
    height: 270px;
    transform: translateX(-50%) scale(var(--scene-scale, 1));
    transform-origin: bottom center;
    overflow: visible;
    z-index: 5;
    transition: transform 0.1s ease;
}

/* =========================
   Leafs
========================= */
.leaf {
    position: absolute;
    font-size: 34px;
    opacity: 0.16;
    z-index: 1;
    animation: leafFloat 6s ease-in-out infinite;
}

.leaf-1 {
    top: 48px;
    left: 90px;
}

.leaf-2 {
    top: 30px;
    left: 52%;
    animation-delay: 1.5s;
}

.leaf-3 {
    top: 82px;
    right: 110px;
    animation-delay: 3s;
}

@keyframes leafFloat {

    0%,
    100% {
        transform: translateY(0) rotate(0deg);
    }

    50% {
        transform: translateY(10px) rotate(10deg);
    }
}

/* =========================
   Road with repeating gradient
========================= */
.road {
    position: absolute;
    left: 50%;
    bottom: 0;
    width: 10000px;
    transform: translateX(-50%);
    height: 118px;
    background: #0d0d0f;
    z-index: 2;
}

.road::before {
    content: "";
    position: absolute;
    top: -8px;
    left: 0;
    width: 100%;
    height: 8px;
    background: var(--kt-red);
}

.road::after {
    content: "";
    position: absolute;
    top: 54px;
    left: 0;
    width: 100%;
    height: 8px;
    background: repeating-linear-gradient(90deg,
            var(--kt-white) 0px,
            var(--kt-white) 110px,
            transparent 110px,
            transparent 240px);
}

/* =========================
   Truck Unit Wrap & Scaled Truck
========================= */
.truck-unit-wrap {
    position: absolute;
    left: -720px;
    bottom: 92px;
    width: 690px;
    height: 135px;
    z-index: 8;
    animation: truckMove 18s ease-in-out infinite;
}

.truck-unit {
    position: relative;
    width: 100%;
    height: 100%;
    transform: scale(0.7);
    /* Scale truck & trailer to be smaller and fit better */
    transform-origin: left bottom;
}

@keyframes truckMove {
    0% {
        transform: translateX(0);
    }

    20% {
        transform: translateX(900px);
    }

    63% {
        transform: translateX(900px);
    }

    100% {
        transform: translateX(3000px);
    }
}

.trailer-box {
    position: absolute;
    left: 0;
    bottom: 24px;
    width: 470px;
    height: 98px;
    background: #f7f7f7;
    border: 4px solid var(--kt-black);
    border-radius: 12px;
    box-shadow: inset 0 -12px 0 rgba(0, 0, 0, 0.05);
}

.flag-mark {
    position: absolute;
    left: 18px;
    top: 16px;
    width: 52px;
    height: 34px;
    background: var(--kt-red);
    border-radius: 6px;
}

.trailer-company {
    position: absolute;
    left: 88px;
    top: 16px;
    font-size: 24px;
    font-weight: 900;
    color: var(--kt-black);
    letter-spacing: 1px;
    text-transform: uppercase;
    white-space: nowrap;
}

.trailer-text {
    position: absolute;
    left: 88px;
    top: 52px;
    font-size: 13px;
    font-weight: 900;
    color: var(--kt-red);
    letter-spacing: 0.8px;
    text-transform: uppercase;
}

.truck-connector {
    position: absolute;
    left: 455px;
    bottom: 28px;
    width: 42px;
    height: 46px;
    background: #0d0d0f;
    border-radius: 6px;
}

.truck-cabin {
    position: absolute;
    right: 24px;
    bottom: 24px;
    width: 192px;
    height: 106px;
    background: var(--kt-red);
    border: 4px solid var(--kt-black);
    border-radius: 24px 30px 12px 12px;
}

.truck-window {
    position: absolute;
    right: 18px;
    top: 18px;
    width: 76px;
    height: 34px;
    background: #cbeaff;
    border: 3px solid var(--kt-black);
    border-radius: 8px 16px 8px 8px;
}

.truck-headlight {
    position: absolute;
    right: -5px;
    bottom: 20px;
    width: 12px;
    height: 18px;
    background: #ffd34d;
    border-radius: 6px;
}

/* Wheels styling with detailed conic gradient spokes */
.truck-wheel,
.van-wheel,
.repair-tire,
.carry-tire {
    border-radius: 50%;
    background: var(--kt-black);
    border: 7px solid #3a3a3a;
    box-sizing: border-box;
}

.truck-wheel::after,
.van-wheel::after,
.repair-tire::after,
.carry-tire::after {
    content: "";
    position: absolute;
    inset: 0;
    background: repeating-conic-gradient(from 0deg, #777 0deg 30deg, #555 30deg 60deg);
    border-radius: 50%;
    box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.5);
}

.truck-wheel::before,
.van-wheel::before,
.repair-tire::before,
.carry-tire::before {
    content: "";
    position: absolute;
    inset: 10px;
    background: #222;
    border-radius: 50%;
    z-index: 3;
}

.truck-wheel {
    position: absolute;
    bottom: 7px;
    width: 42px;
    height: 42px;
    animation: truckWheelMove 18s ease-in-out infinite;
}

.tw-1 {
    left: 48px;
}

.tw-2 {
    left: 285px;
}

.tw-3 {
    right: 122px;
}

.tw-4 {
    right: 42px;
}

.problem-wheel {
    animation: truckWheelMove 18s ease-in-out infinite, tireShake 18s ease-in-out infinite;
}

@keyframes tireShake {

    0%,
    20% {
        filter: none;
    }

    22%,
    60% {
        filter: drop-shadow(0 0 6px rgba(255, 0, 0, 0.5));
    }

    70%,
    100% {
        filter: none;
    }
}

@keyframes truckWheelMove {
    0% {
        transform: rotate(0deg);
    }

    20% {
        transform: rotate(1440deg);
    }

    63% {
        transform: rotate(1440deg);
    }

    100% {
        transform: rotate(4800deg);
    }
}

/* =========================
   Service Van Wrap & Scaled Van
========================= */
.service-van-wrap {
    position: absolute;
    right: -270px;
    bottom: 92px;
    width: 255px;
    height: 110px;
    z-index: 10;
    animation: vanMove 18s ease-in-out infinite;
}

.service-van-wrap::after {
    content: "";
    position: absolute;
    left: 22px;
    bottom: -3px;
    width: 200px;
    height: 14px;
    background: rgba(0, 0, 0, 0.22);
    border-radius: 50%;
    filter: blur(2px);
}

.service-van {
    position: relative;
    width: 100%;
    height: 100%;
    transform: scale(0.85);
    /* Scaled slightly to look balanced with truck */
    transform-origin: right bottom;
}

@keyframes vanMove {

    0%,
    18% {
        transform: translateX(0);
    }

    34%,
    64% {
        transform: translateX(-500px);
    }

    100% {
        transform: translateX(-2500px);
    }
}

.van-body {
    position: absolute;
    bottom: 22px;
    width: 236px;
    height: 82px;
    background: var(--kt-black);
    border: 4px solid var(--kt-red);
    border-radius: 18px 22px 10px 10px;
    overflow: hidden;
}

.van-logo {
    position: absolute;
    left: 14px;
    top: 16px;
    width: 52px;
    height: 28px;
    background: var(--kt-red);
    border-radius: 6px;
}

.van-company {
    position: absolute;
    left: 78px;
    top: 15px;
    color: var(--kt-white);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    white-space: nowrap;
}

.van-text {
    position: absolute;
    left: 78px;
    top: 38px;
    color: var(--kt-white);
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 1px;
    text-transform: uppercase;
}

.van-window {
    position: absolute;
    right: 16px;
    top: 14px;
    width: 56px;
    height: 28px;
    background: #cbeaff;
    border-radius: 8px;
}

.van-door {
    position: absolute;
    left: 66px;
    bottom: 0;
    width: 48px;
    height: 63px;
    background: linear-gradient(90deg, #191919, #2c2c2c);
    border-left: 3px solid var(--kt-red);
    border-right: 3px solid var(--kt-red);
    transform-origin: left center;
    animation: vanDoorOpen 18s ease-in-out infinite;
    z-index: 4;
}

.door-gap {
    position: absolute;
    left: 66px;
    bottom: 0;
    width: 48px;
    height: 63px;
    background: rgba(255, 255, 255, 0.08);
    z-index: 3;
}

@keyframes vanDoorOpen {

    0%,
    32% {
        transform: rotateY(0deg) translateX(0);
    }

    38%,
    62% {
        transform: rotateY(70deg) translateX(-18px);
    }

    68%,
    100% {
        transform: rotateY(0deg) translateX(0);
    }
}

.van-wheel {
    position: absolute;
    bottom: 2px;
    width: 40px;
    height: 40px;
    animation: vanWheelMove 18s ease-in-out infinite;
    z-index: 8;
}

.vw-1 {
    left: 32px;
}

.vw-2 {
    right: 28px;
}

@keyframes vanWheelMove {

    0%,
    18% {
        transform: rotate(0deg);
    }

    34% {
        transform: rotate(-1080deg);
    }

    64% {
        transform: rotate(-1080deg);
    }

    100% {
        transform: rotate(-5400deg);
    }
}

/* =========================
   Repair Zone
========================= */
.repair-zone {
    position: absolute;
    left: 625px;
    bottom: 104px;
    width: 320px;
    height: 155px;
    z-index: 16;
    pointer-events: none;
    animation: repairZoneShow 18s linear infinite;
}

@keyframes repairZoneShow {

    0%,
    32% {
        opacity: 0;
    }

    36%,
    66% {
        opacity: 1;
    }

    72%,
    100% {
        opacity: 0;
    }
}

.repair-tire {
    position: absolute;
    left: 28px;
    bottom: 7px;
    width: 54px;
    height: 54px;
    animation: repairTireEffect 18s ease-in-out infinite;
}

@keyframes repairTireEffect {

    0%,
    40% {
        transform: rotate(0deg) scale(1);
        opacity: 0.4;
    }

    47%,
    60% {
        transform: rotate(-12deg) scale(1.02);
        opacity: 1;
    }

    65%,
    100% {
        transform: rotate(0deg) scale(1);
        opacity: 1;
    }
}

.jack {
    position: absolute;
    left: 86px;
    bottom: 10px;
    width: 32px;
    height: 34px;
    z-index: 2;
    animation: jackShow 18s linear infinite;
}

.jack::before {
    content: "";
    position: absolute;
    left: 8px;
    bottom: 0;
    width: 16px;
    height: 7px;
    background: #222;
    border-radius: 3px;
}

.jack::after {
    content: "";
    position: absolute;
    left: 13px;
    bottom: 6px;
    width: 6px;
    height: 28px;
    background: var(--kt-red);
    border: 2px solid var(--kt-black);
    border-radius: 4px;
}

.jack span {
    position: absolute;
    left: 5px;
    top: -2px;
    width: 24px;
    height: 7px;
    background: var(--kt-black);
    border-radius: 4px;
}

@keyframes jackShow {

    0%,
    43% {
        opacity: 0;
        transform: translateY(8px);
    }

    48%,
    66% {
        opacity: 1;
        transform: translateY(0);
    }

    72%,
    100% {
        opacity: 0;
    }
}

.tool-box {
    position: absolute;
    left: 126px;
    bottom: 10px;
    width: 38px;
    height: 23px;
    background: var(--kt-red);
    border: 3px solid var(--kt-black);
    border-radius: 6px;
    animation: toolBoxDrop 18s linear infinite;
}

.tool-box::before {
    content: "";
    position: absolute;
    left: 9px;
    top: -9px;
    width: 13px;
    height: 8px;
    border: 3px solid var(--kt-black);
    border-bottom: none;
    border-radius: 6px 6px 0 0;
    background: transparent;
}

@keyframes toolBoxDrop {

    0%,
    41% {
        opacity: 0;
        transform: translateX(60px) translateY(-5px);
    }

    48%,
    66% {
        opacity: 1;
        transform: translateX(0) translateY(0);
    }

    72%,
    100% {
        opacity: 0;
    }
}

.repair-spark {
    position: absolute;
    width: 6px;
    height: 6px;
    background: #ffd34d;
    border-radius: 50%;
    left: 54px;
    bottom: 48px;
    opacity: 0;
    z-index: 25;
}

.spark-1 {
    animation: sparkOne 18s linear infinite;
}

.spark-2 {
    animation: sparkTwo 18s linear infinite;
}

.spark-3 {
    animation: sparkThree 18s linear infinite;
}

@keyframes sparkOne {

    0%,
    51% {
        opacity: 0;
        transform: translate(0, 0);
    }

    52% {
        opacity: 1;
        transform: translate(6px, -8px);
    }

    53% {
        opacity: 0;
        transform: translate(16px, -18px);
    }

    54%,
    100% {
        opacity: 0;
    }
}

@keyframes sparkTwo {

    0%,
    55% {
        opacity: 0;
        transform: translate(0, 0);
    }

    56% {
        opacity: 1;
        transform: translate(-8px, -6px);
    }

    57% {
        opacity: 0;
        transform: translate(-18px, -14px);
    }

    58%,
    100% {
        opacity: 0;
    }
}

@keyframes sparkThree {

    0%,
    59% {
        opacity: 0;
        transform: translate(0, 0);
    }

    60% {
        opacity: 1;
        transform: translate(8px, 5px);
    }

    61% {
        opacity: 0;
        transform: translate(18px, 12px);
    }

    62%,
    100% {
        opacity: 0;
    }
}

/* =========================
   Mechanics
========================= */
.mechanic {
    position: absolute;
    width: 46px;
    height: 96px;
    bottom: 10px;
    transform-origin: bottom center;
    z-index: 20;
}

.mechanic .head {
    position: absolute;
    top: 8px;
    left: 12px;
    width: 21px;
    height: 21px;
    background: #f0c39b;
    border: 2px solid var(--kt-black);
    border-radius: 50%;
    z-index: 3;
}

.mechanic .cap {
    position: absolute;
    top: 3px;
    left: 10px;
    width: 26px;
    height: 13px;
    background: var(--kt-black);
    border-radius: 14px 14px 5px 5px;
    z-index: 4;
}

.mechanic .cap::after {
    content: "";
    position: absolute;
    right: -8px;
    top: 7px;
    width: 13px;
    height: 5px;
    background: var(--kt-black);
    border-radius: 5px;
}

.mechanic .body {
    position: absolute;
    top: 30px;
    left: 12px;
    width: 22px;
    height: 31px;
    background: var(--kt-red);
    border: 2px solid var(--kt-black);
    border-radius: 7px;
    z-index: 2;
}

.mechanic .body::after {
    content: "";
    position: absolute;
    left: 8px;
    top: 2px;
    width: 3px;
    height: 26px;
    background: rgba(255, 255, 255, 0.45);
    border-radius: 5px;
}

.mechanic .arm {
    position: absolute;
    top: 33px;
    width: 7px;
    height: 29px;
    background: #f0c39b;
    border-radius: 5px;
    transform-origin: top center;
    z-index: 1;
}

.mechanic .arm-left {
    left: 6px;
}

.mechanic .arm-right {
    right: 6px;
}

.mechanic .leg {
    position: absolute;
    top: 60px;
    width: 7px;
    height: 32px;
    background: #202020;
    border-radius: 5px;
    transform-origin: top center;
}

.mechanic .leg-left {
    left: 14px;
}

.mechanic .leg-right {
    right: 14px;
}

/* Mechanic A */
.mechanic-a {
    left: 238px;
    animation: mechanicAFromVan 18s ease-in-out infinite;
}

@keyframes mechanicAFromVan {

    0%,
    34% {
        opacity: 0;
        transform: translateX(25px) translateY(0) scale(0.6);
    }

    38% {
        opacity: 1;
        transform: translateX(15px) translateY(0) scale(0.75);
    }

    45% {
        opacity: 1;
        transform: translateX(-60px) translateY(0) scale(1);
    }

    52% {
        opacity: 1;
        transform: translateX(-135px) translateY(0) scale(1);
    }

    63% {
        opacity: 1;
        transform: translateX(-150px) translateY(0) scale(1);
    }

    68%,
    100% {
        opacity: 0;
        transform: translateX(30px) translateY(0) scale(0.75);
    }
}

.mechanic-a .arm-left,
.mechanic-a .arm-right,
.mechanic-a .leg-left,
.mechanic-a .leg-right {
    animation: walkSwing 0.55s linear infinite;
}

.mechanic-a .arm-right,
.mechanic-a .leg-left {
    animation-direction: reverse;
}

.carry-tire {
    position: absolute;
    left: -14px;
    top: 34px;
    width: 34px;
    height: 34px;
    animation: carryTireFromVan 18s ease-in-out infinite;
    z-index: 10;
}

.carry-tire::after {
    inset: 0;
}

@keyframes carryTireFromVan {

    0%,
    34% {
        opacity: 0;
        transform: rotate(0deg);
    }

    38%,
    52% {
        opacity: 1;
        transform: rotate(-260deg);
    }

    56%,
    100% {
        opacity: 0;
        transform: rotate(-360deg);
    }
}

/* Mechanic B */
.mechanic-b {
    left: 226px;
    bottom: 8px;
    animation: mechanicBFromVan 18s ease-in-out infinite;
}

@keyframes mechanicBFromVan {

    0%,
    35% {
        opacity: 0;
        transform: translateX(28px) scale(0.6);
    }

    40% {
        opacity: 1;
        transform: translateX(12px) scale(0.78);
    }

    48% {
        opacity: 1;
        transform: translateX(-105px) scale(1);
    }

    52%,
    66% {
        opacity: 1;
        transform: translateX(-160px) translateY(10px) scale(0.95);
    }

    72%,
    100% {
        opacity: 0;
        transform: translateX(35px) scale(0.75);
    }
}

.mechanic-b .body {
    height: 27px;
    top: 31px;
}

.mechanic-b .arm-right {
    animation: wrenchMove 0.65s ease-in-out infinite;
}

.mechanic-b .arm-left {
    transform: rotate(32deg);
}

.mechanic-b .leg-left,
.mechanic-b .leg-right {
    top: 56px;
    height: 27px;
    animation: crouchLeg 0.65s ease-in-out infinite;
}

.tool.wrench {
    position: absolute;
    right: -4px;
    top: 48px;
    width: 20px;
    height: 4px;
    background: #777;
    border-radius: 4px;
    transform: rotate(30deg);
    animation: wrenchMoveTool 0.65s ease-in-out infinite;
    z-index: 10;
}

.tool.wrench::before {
    content: "";
    position: absolute;
    right: -5px;
    top: -4px;
    width: 9px;
    height: 9px;
    border: 3px solid #777;
    border-left-color: transparent;
    border-bottom-color: transparent;
    border-radius: 50%;
    transform: rotate(45deg);
}

@keyframes walkSwing {
    0% {
        transform: rotate(18deg);
    }

    50% {
        transform: rotate(-18deg);
    }

    100% {
        transform: rotate(18deg);
    }
}

@keyframes wrenchMove {
    0% {
        transform: rotate(28deg);
    }

    50% {
        transform: rotate(-38deg);
    }

    100% {
        transform: rotate(28deg);
    }
}

@keyframes wrenchMoveTool {
    0% {
        transform: rotate(25deg) translateY(0);
    }

    50% {
        transform: rotate(-22deg) translateY(3px);
    }

    100% {
        transform: rotate(25deg) translateY(0);
    }
}

@keyframes crouchLeg {
    0% {
        transform: rotate(8deg);
    }

    50% {
        transform: rotate(26deg);
    }

    100% {
        transform: rotate(8deg);
    }
}

/* Old manual responsive queries removed - layout now scales automatically and proportionally. */

/* ===== Need Immediate Tire Assistance CTA Bar ===== */
.kt-cta-bar-section {
    width: 100%;
    background: #000;
    overflow: hidden;
}

.kt-cta-bar-container {
    width: 100%;
    min-height: 120px;
    background: linear-gradient(135deg, #d50000 0%, #aa0000 50%, #7a0000 80%, #300000 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 30px;
    padding: 24px 60px;
    position: relative;
    overflow: hidden;
}

.kt-cta-bar-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-grow: 1;
    gap: 34px;
    z-index: 5;
}

.kt-cta-bar-text {
    color: #fff;
}

.kt-cta-bar-text h2 {
    font-size: clamp(24px, 2.5vw, 32px);
    font-weight: 900;
    margin: 0 0 6px;
    letter-spacing: -0.015em;
    line-height: 1.1;
}

.kt-cta-bar-text p {
    font-size: clamp(14px, 1.4vw, 16px);
    margin: 0;
    opacity: 0.9;
    font-weight: 500;
}

.kt-cta-bar-actions {
    display: flex;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
}

/* Call button */
.kt-cta-btn-phone {
    background: #fff;
    color: #111;
    border-radius: 999px;
    padding: 14px 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 16px;
    font-weight: 800;
    transition: transform 0.22s ease, background 0.22s ease;
    border: 2px solid transparent;
}

.kt-cta-btn-phone:hover {
    transform: translateY(-2px);
    background: #f0f0f0;
    color: #111;
}

/* WhatsApp button */
.kt-cta-btn-whatsapp {
    background: #000;
    color: #fff;
    border-radius: 999px;
    padding: 14px 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-size: 14px;
    font-weight: 800;
    transition: transform 0.22s ease, background 0.22s ease;
    border: 2px solid rgba(255, 255, 255, 0.22);
}

.kt-cta-btn-whatsapp:hover {
    transform: translateY(-2px);
    background: #111;
    border-color: rgba(255, 255, 255, 0.45);
}

.kt-cta-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* Far right tires visual */
.kt-cta-bar-visual {
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    height: 100%;
    display: flex;
    align-items: center;
    z-index: 2;
    opacity: 0.85;
    pointer-events: none;
}

.kt-cta-bar-visual img {
    height: 140%;
    width: auto;
    object-fit: contain;
    transform: translateX(40px) rotate(-15deg);
    filter: drop-shadow(-10px 0 20px rgba(0, 0, 0, 0.5));
}

/* Responsive styles */
@media (max-width: 1200px) {
    .kt-cta-bar-visual {
        opacity: 0.5;
    }
}

@media (max-width: 1024px) {
    .kt-cta-bar-container {
        padding: 30px 40px;
    }

    .kt-cta-bar-content {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }

    .kt-cta-bar-actions {
        width: 100%;
    }
}

@media (max-width: 768px) {
    .kt-cta-bar-visual {
        display: none;
    }

    .kt-cta-bar-container {
        padding: 24px 20px;
    }

    .kt-cta-bar-actions {
        display: flex;
        flex-direction: row !important;
        width: 100%;
        gap: 10px;
    }

    .kt-cta-btn-phone,
    .kt-cta-btn-whatsapp,
    .kt-cta-bar-actions .kt-btn {
        flex: 1;
        width: auto !important;
        justify-content: center;
        padding: 12px 6px;
        font-size: 13px;
        gap: 6px;
    }
}

/* ===== Mobile Sticky Contact Bar ===== */
.kt-mobile-sticky-bar {
    display: none;
}

@media (max-width: 768px) {
    .kt-mobile-sticky-bar {
        display: flex;
        position: fixed;
        bottom: 12px;
        left: 12px;
        right: 12px;
        z-index: 9999;
        gap: 10px;
        pointer-events: none;
    }

    .kt-mobile-sticky-bar a {
        flex: 1;
        pointer-events: auto;
        display: flex;
        align-items: center;
        justify-content: center;
        color: #fff;
        font-size: clamp(20px, 6.2vw, 28px);
        font-weight: 800;
        letter-spacing: 0.02em;
        padding: 14px 10px;
        border-radius: 12px;
        border: 2px solid #fff;
        text-decoration: none;
        transition: transform 0.2s ease, background-color 0.2s ease;
    }

    .kt-mobile-sticky-bar .kt-sticky-btn-call {
        background: var(--kt-red);
        box-shadow: 0 8px 24px rgba(213, 0, 0, 0.35), 0 4px 10px rgba(0, 0, 0, 0.2);
    }

    .kt-mobile-sticky-bar .kt-sticky-btn-call:active,
    .kt-mobile-sticky-bar .kt-sticky-btn-call:hover {
        transform: scale(0.96);
        background: var(--kt-red-dark);
    }

    body {
        padding-bottom: 90px;
    }

    .kt-trust-row {
        display: none;
    }
}