/* Contrast Overrides for Primary Backgrounds */
.bg-primary,
.bg-accent,
.bg-dark,
.btn-primary,
.bg-gradient,
.badge-primary {
    color: #ffffff !important;
}

.bg-primary *,
.bg-accent *,
.bg-dark *,
.btn-primary *,
.bg-gradient *,
.badge-primary * {
    color: inherit !important;
}


/* Specific button text color */
.btn-primary {
    color: #ffffff !important;
}

.btn-primary:hover {
    color: #ffffff !important;
}

/* Footer Customization */
.tt-footer,
.tt-footer-top,
.tt-footer-bottom {
    background-color: #0e121b !important;
    color: #ffffff !important;
}

.tt-footer *,
.tt-footer-top *,
.tt-footer-bottom *,
.tt-footer-widget *,
.tt-footer-menu li a,
.tt-footer-widget address,
.tt-footer-widget li {
    color: #ffffff !important;
}

.tt-footer-menu li a:hover {
    color: #ffcccc !important;
    text-decoration: underline !important;
}

.tt-footer h6,
.tt-footer .text-white {
    color: #ffffff !important;
}


/* Logo Optimization */
.tt-header .container,
.tt-header .navbar {
    align-items: center;
}

.tt-header-logo {
    display: flex !important;
    align-items: center;
    margin: 0 24px 0 0 !important;
    padding: 0 !important;
    line-height: 1;
    flex-shrink: 0;
}

.logo-img {
    display: block;
    max-height: 34px !important;
    width: auto !important;
}

@media (min-width: 1200px) {
    .tt-header .navbar > .container {
        display: flex;
        align-items: center;
        flex-wrap: nowrap;
    }

    .tt-header .main-navbar-wrapper.tt-main-header {
        flex: 1 1 auto;
        min-width: 0;
        margin-right: 0.5rem;
    }

    .tt-header .main-navbar-wrapper.tt-main-header #mainNavbar {
        display: flex;
        justify-content: center;
        width: 100%;
    }

    .tt-header #nav.navbar-nav {
        display: flex;
        flex-wrap: nowrap;
        align-items: center;                         
        justify-content: center;
        width: 100%;
        margin-bottom: 0;
    }

    .tt-header #nav > li {
        flex: 0 0 auto;
    }

    .tt-header .tt-main-header ul li a {
        font-size: 15.5px;
        letter-spacing: -0.01em;
        white-space: nowrap;
    }

    .tt-header .tt-main-header ul li a.pr-4 {
        padding-right: 0.98rem !important;
        padding-left: 0.98rem !important;
    }

    .tt-header .tt-toolbar-wrap.tt-main-header {
        flex: 0 0 auto;
        margin-left: 0.25rem;
    }

    .tt-header .tt-secondary-list {
        display: flex;
        align-items: center;
        flex-wrap: nowrap;
        gap: 0.2rem;
        margin-bottom: 0;
        white-space: nowrap;
    }

    .tt-header .tt-secondary-list .nav-item > a,
    .tt-header .tt-secondary-list .nav-item > button,
    .tt-header .tt-secondary-list .btn-sm {
        font-size: 14.5px;
    }

    .tt-header .tt-secondary-list .btn-sm {
        display: inline-flex;
        align-items: center;
        padding: 0.28rem 0.52rem;
    }

    .tt-header .tt-secondary-list .cart-btn {
        padding-inline: 0.35rem;
    }
}

@media (min-width: 1200px) and (max-width: 1399.98px) {
    .tt-header-logo {
        margin-right: 18px !important;
    }

    .tt-header .tt-main-header ul li a {
        font-size: 14.25px;
    }

    .tt-header .tt-main-header ul li a.pr-4 {
        padding-right: 0.78rem !important;
        padding-left: 0.78rem !important;
    }

    .tt-header .tt-secondary-list .nav-item > a,
    .tt-header .tt-secondary-list .nav-item > button,
    .tt-header .tt-secondary-list .btn-sm {
        font-size: 13.75px;
    }
}

@media (max-width: 1199.98px) {
    .tt-header-logo {
        margin-right: 16px !important;
    }

    .logo-img {
        max-height: 30px !important;
    }
}



/* Typography for Light Sections (Home) */
section.ptb-100:not(.bg-dark):not(.bg-primary):not(.bg-accent):not(.bg-gradient) h2,
section.ptb-100:not(.bg-dark):not(.bg-primary):not(.bg-accent):not(.bg-gradient) h3,
section.ptb-100:not(.bg-dark):not(.bg-primary):not(.bg-accent):not(.bg-gradient) h5,
section.ptb-100:not(.bg-dark):not(.bg-primary):not(.bg-accent):not(.bg-gradient) p,
.bg-white h2,
.bg-white h3,
.bg-white h5,
.bg-white p,
.bg-white .card-title,
.bg-white .tt-price-wrap h2,
.bg-white .tt-price {
    color: #0e121b !important;
}

.bg-white .text-muted {
    color: #0e121b !important;
    opacity: 0.7;
}

section#main-body.tt-home-main-body {
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
}

section#main-body.tt-home-main-body > .container {
    padding: 0 !important;
}

/* Hero Section Subject-Background Contrast Fix */
.tt-hero-bg-custom {
    background-color: #0e121b !important;
    min-height: clamp(551px, 64vh, 723px);
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
}

.tt-hero-media,
.tt-hero-overlay {
    position: absolute;
    inset: 0;
}

.tt-hero-media {
    z-index: 0;
    background: #0e121b;
}

.tt-hero-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
}

.tt-hero-overlay {
    z-index: 1;
    background:
        linear-gradient(90deg, rgba(7, 12, 20, 0.84) 0%, rgba(8, 14, 24, 0.7) 34%, rgba(9, 15, 25, 0.48) 58%, rgba(10, 17, 27, 0.3) 100%);
}

.tt-hero-bg-custom .ptb-60 {
    flex: 1 0 auto;
    display: flex;
    align-items: center;
    position: relative;
    z-index: 2;
    padding: clamp(88px, 8.3vw, 120px) 0 clamp(58px, 5.4vw, 78px) !important;
}

.tt-hero-bg-custom .container,
.tt-hero-bg-custom .row {
    height: 100%;
}

.tt-hero-bg-custom .tt-hero {
    max-width: 880px;
    padding-right: 0;
}

.tt-hero-kicker {
    display: inline-block;
    margin-bottom: 22px;
    color: #ff3030;
    font-size: 0.95rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tt-hero-title {
    margin: 0;
    font-size: clamp(4.2rem, 5.9vw, 5.5rem);
    font-weight: 800;
    line-height: 0.94;
    letter-spacing: -0.05em;
    text-shadow: 0 10px 32px rgba(0, 0, 0, 0.34);
}

.tt-hero-title-main,
.tt-hero-title-accent {
    display: block;
}

.tt-hero-title-main {
    color: #ffffff;
}

.tt-hero-title-accent {
    margin-top: 4px;
    color: #ff2626;
    text-shadow: 0 10px 32px rgba(0, 0, 0, 0.28);
}

.tt-hero-description {
    max-width: 920px;
    margin: 24px 0 0;
    color: rgba(234, 239, 247, 0.88);
    font-size: clamp(1.2rem, 1.55vw, 1.35rem);
    font-weight: 400;
    line-height: 1.4;
    text-shadow: 0 6px 24px rgba(0, 0, 0, 0.24);
}

.tt-hero-description span {
    display: block;
}

.tt-hero-bg-custom .tt-hero-btns {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    margin-top: 34px;
}

.tt-hero-bg-custom .tt-shape {
    display: block;
    margin-top: -2px;
    line-height: 0;
    position: relative;
    z-index: 2;
}

.tt-hero-bg-custom .tt-hero-btns .btn {
    min-width: 168px;
    min-height: 46px;
    padding: 0.78rem 1.45rem;
    border-radius: 999px;
    font-size: 0.92rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    box-shadow: 0 14px 35px rgba(0, 0, 0, 0.22);
}

.tt-hero-bg-custom .tt-hero-btns .btn-primary {
    background: #ff2a2a;
    border-color: #ff2a2a;
    color: #ffffff !important;
}

.tt-hero-bg-custom .tt-hero-btns .btn-primary:hover,
.tt-hero-bg-custom .tt-hero-btns .btn-primary:focus {
    background: #ff4545;
    border-color: #ff4545;
    color: #ffffff !important;
}

.tt-hero-bg-custom .tt-hero-btns .btn-outline-light {
    border-width: 1px;
    border-color: rgba(255, 255, 255, 0.7);
    background: rgba(255, 255, 255, 0.08);
    color: #ffffff !important;
    backdrop-filter: blur(6px);
}

.tt-hero-bg-custom .tt-hero-btns .btn-outline-light:hover,
.tt-hero-bg-custom .tt-hero-btns .btn-outline-light:focus {
    border-color: #ffffff;
    background: rgba(255, 255, 255, 0.16);
    color: #ffffff !important;
}

.tt-hero-bg-custom .tt-shape img {
    display: block;
    width: 100%;
}

.tt-hero-bg-custom::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 3;
    height: 1px;
    background: rgba(255, 255, 255, 0.14);
}

@media (max-width: 1399.98px) {
    .tt-hero-bg-custom {
        min-height: clamp(533px, 60vh, 662px);
    }

    .tt-hero-video {
        object-position: 62% center;
    }
}

@media (max-width: 1199.98px) {
    .tt-hero-bg-custom .tt-hero {
        max-width: 720px;
    }

    .tt-hero-video {
        object-position: 66% center;
    }

    .tt-hero-title {
        font-size: clamp(3.8rem, 5.3vw, 5rem);
    }
}

@media (max-width: 991.98px) {
    .tt-hero-bg-custom {
        min-height: auto;
    }

    .tt-hero-overlay {
        background:
            linear-gradient(180deg, rgba(8, 14, 24, 0.8) 0%, rgba(8, 14, 24, 0.62) 100%);
    }

    .tt-hero-bg-custom .ptb-60 {
        min-height: 360px;
        align-items: flex-end;
        padding: 54px 0 56px !important;
    }

    .tt-hero-bg-custom .tt-hero {
        max-width: none;
        padding-right: 0;
    }

    .tt-hero-kicker {
        margin-bottom: 14px;
        font-size: 0.88rem;
    }

    .tt-hero-title {
        font-size: clamp(3.15rem, 8.3vw, 4.35rem);
    }

    .tt-hero-description {
        max-width: 700px;
        margin-top: 22px;
        font-size: 1.08rem;
    }

    .tt-hero-video {
        object-position: 72% center;
    }
}

@media (max-width: 767.98px) {
    .tt-hero-bg-custom .ptb-60 {
        min-height: 330px;
        padding: 40px 0 44px !important;
    }

    .tt-hero-title {
        font-size: clamp(2.55rem, 10.4vw, 3.3rem);
        line-height: 0.96;
    }

    .tt-hero-title-accent {
        margin-top: 6px;
    }

    .tt-hero-description {
        font-size: 0.98rem;
        line-height: 1.45;
    }

    .tt-hero-bg-custom .tt-hero-btns {
        gap: 12px;
        margin-top: 28px;
    }

    .tt-hero-bg-custom .tt-hero-btns .btn {
        min-width: 0;
        width: auto;
        margin-right: 0 !important;
    }

    .tt-hero-video {
        object-position: 76% center;
    }
}

/* Quick Access */
.tt-promo-section {
    padding-top: 72px !important;
    padding-bottom: 46px !important;
}

.tt-promo {
    min-height: 148px;
    border: 1px solid #edf0f5;
    box-shadow: 0 14px 34px rgba(17, 17, 17, 0.05);
}

.tt-promo .ico-container {
    margin-bottom: 12px;
}

.tt-promo i {
    font-size: 30px;
}

.tt-promo-title {
    display: block;
    color: #161b26;
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.2;
}

.tt-promo-copy {
    display: block;
    margin-top: 8px;
    color: #6f7685;
    font-size: 0.83rem;
    line-height: 1.35;
}

/* Trust Strip */
.tt-trust-strip-section {
    padding-bottom: 34px;
}

.tt-trust-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    padding: 18px 22px;
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border: 1px solid #edf0f5;
    box-shadow: 0 12px 28px rgba(17, 17, 17, 0.05);
}

.tt-trust-item {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    color: #1a2030;
    font-size: 0.9rem;
    font-weight: 700;
    text-align: center;
}

.tt-trust-item i {
    color: #b11116;
    font-size: 1rem;
}

/* Domain Search */
.tt-domain-search-section {
    position: relative;
    z-index: 4;
    margin-top: 0;
    padding: 0;
    background: #991214;
}

.tt-domain-search-shell {
    padding: 10px 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    border-radius: 0;
    backdrop-filter: none;
}

.tt-domain-search-bar {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) auto;
    align-items: center;
    gap: 18px;
}

.tt-domain-search-main {
    min-width: 0;
}

.tt-domain-search-input-group {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 42px;
    padding: 5px 6px 5px 16px;
    background: #ffffff;
    border: 1px solid rgba(217, 223, 233, 0.95);
    border-radius: 8px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.tt-domain-search-section .form-control {
    height: auto;
    min-height: 30px;
    padding: 0;
    border: 0;
    box-shadow: none !important;
    background: transparent;
    color: #1a2233 !important;
    font-size: 0.95rem;
    font-weight: 500;
}

.tt-domain-search-section .form-control::placeholder {
    color: #717b8e;
    opacity: 1;
}

.tt-domain-search-controls {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.tt-domain-search-submit {
    width: 34px;
    min-width: 34px;
    height: 34px;
    min-height: 34px !important;
    padding: 0;
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 7px !important;
    background: linear-gradient(180deg, #788297 0%, #667186 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 6px 14px rgba(44, 52, 69, 0.18);
}

.tt-domain-search-submit:hover,
.tt-domain-search-submit:focus {
    background: linear-gradient(180deg, #838da2 0%, #6f7a90 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 8px 16px rgba(44, 52, 69, 0.22);
}

.tt-domain-search-submit i {
    font-size: 0.86rem;
}

.tt-domain-search-offer {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-self: end;
    align-self: center;
    min-width: 260px;
    color: #1a2233;
    text-align: right;
}

.tt-domain-search-offer-title {
    display: block;
    font-size: 0.94rem;
    font-weight: 800;
    line-height: 1.1;
    color: #ffffff;
}

.tt-domain-search-offer-copy {
    display: block;
    margin-top: 3px;
    color: rgba(244, 246, 251, 0.84);
    font-size: 0.88rem;
    font-weight: 600;
    line-height: 1.25;
}

.tt-domain-search-offer-copy a {
    color: #ffffff !important;
    font-weight: 800;
    text-decoration: underline;
}

/* Services Section */
.tt-services-section {
    padding-top: 74px !important;
    padding-bottom: 74px !important;
}

.tt-services-kicker {
    display: inline-block;
    margin-bottom: 10px;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.86rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tt-services-copy {
    max-width: 650px;
    margin: 12px auto 0;
    color: rgba(255, 255, 255, 0.72);
    font-size: 1rem;
    line-height: 1.6;
}

.tt-services-section .tt-service-single:before,
.tt-services-section .tt-service-single:after {
    background: linear-gradient(45deg, rgba(255, 255, 255, 0.08), rgba(255, 112, 112, 0.16), rgba(255, 255, 255, 0.04));
}

.tt-services-section .tt-service-info {
    padding: 28px 26px;
    background: rgba(122, 8, 12, 0.36);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: none;
}

.tt-services-section .tt-service-info p {
    min-height: 72px;
    margin-bottom: 22px;
    color: rgba(255, 255, 255, 0.8);
    line-height: 1.55;
}

@media (max-width: 991.98px) {
    .tt-trust-strip {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767.98px) {
    .tt-promo-section {
        padding-top: 56px !important;
        padding-bottom: 34px !important;
    }

    .tt-promo {
        min-height: 132px;
    }

    .tt-trust-strip {
        grid-template-columns: 1fr;
        gap: 10px;
        padding: 16px;
    }

    .tt-domain-search-section {
        margin-top: 0;
    }

    .tt-domain-search-shell {
        padding: 10px 0 12px;
    }

    .tt-domain-search-bar {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .tt-domain-search-input-group {
        min-height: 40px;
        padding: 4px 5px 4px 12px;
        border-radius: 8px;
    }

    .tt-domain-search-section .form-control {
        min-height: 28px;
        font-size: 0.9rem;
    }

    .tt-domain-search-submit {
        width: 32px;
        min-width: 32px;
        height: 32px;
        min-height: 32px !important;
        border-radius: 7px !important;
    }

    .tt-domain-search-offer {
        align-items: flex-start;
        min-width: 0;
        justify-self: auto;
        align-self: auto;
        text-align: left;
    }

    .tt-domain-search-offer-title {
        font-size: 0.9rem;
    }

    .tt-domain-search-offer-copy {
        font-size: 0.82rem;
    }

    .tt-services-section {
        padding-top: 60px !important;
        padding-bottom: 60px !important;
    }

    .tt-services-section .tt-service-info {
        padding: 24px 20px;
    }

    .tt-services-section .tt-service-info p {
        min-height: 0;
    }
}

/* Homepage Shared Hosting Plans */
.tt-home-plans-heading {
    margin-bottom: 34px !important;
}

.tt-home-plans-kicker {
    display: inline-block;
    margin-bottom: 10px;
    color: #b11116;
    font-size: 0.88rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tt-home-plans-heading h2 {
    margin-bottom: 10px !important;
    font-size: clamp(1.9rem, 3vw, 2.45rem);
    line-height: 1.08;
}

.tt-home-plans-heading p {
    max-width: 640px;
    margin: 0 auto;
    color: #687082;
    font-size: 1rem;
    line-height: 1.55;
}

.tt-home-plans-row {
    margin-top: 6px;
    row-gap: 22px;
}

.tt-home-plan-card {
    position: relative;
    margin-top: 0;
    border: 1px solid #dbe2ec;
    border-radius: 16px;
    box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
    overflow: hidden;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    background: #fff;
}

.tt-home-plan-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 38px rgba(15, 23, 42, 0.09);
}

.tt-home-plan-card::before {
    display: none;
}

.tt-home-plan-card--featured {
    border-color: #202b3f;
    box-shadow: 0 18px 40px rgba(32, 43, 63, 0.12);
}

.tt-home-plan-badge {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 108px;
    height: 28px;
    padding: 0 14px;
    border-radius: 999px;
    background: #2b364c;
    color: #fff;
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.tt-home-plan-card__inner {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 20px 20px 18px;
}

.tt-home-plan-card__top {
    margin-bottom: 18px;
}

.tt-home-plan-price-wrap {
    min-width: 0;
}

.tt-home-plan-label {
    display: inline-block;
    margin-bottom: 10px;
    color: #cc181b;
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.tt-home-plan-title {
    margin: 0 0 8px;
    color: #131722;
    font-size: 1.9rem;
    font-weight: 800;
    line-height: 1.02;
}

.tt-home-plan-subtitle {
    margin: 0 0 14px;
    color: #677286;
    font-size: 0.9rem;
    line-height: 1.48;
    min-height: 42px;
}

.tt-home-plan-reference-price {
    margin-bottom: 6px;
    color: #99a3b5;
    font-size: 0.8rem;
    line-height: 1.3;
}

.tt-home-plan-price {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 8px;
}

.tt-home-plan-price__amount {
    color: #111827;
    font-size: 2.8rem;
    font-weight: 800;
    line-height: 0.9;
    letter-spacing: -0.04em;
}

.tt-home-plan-price__currency {
    padding-bottom: 0.32rem;
    color: #253247;
    font-size: 1rem;
    font-weight: 700;
}

.tt-home-plan-price__cycle {
    padding-bottom: 0.24rem;
    color: #6f7685;
    font-size: 0.95rem;
    font-weight: 600;
}

.tt-home-plan-billing-note {
    margin: 0 0 12px;
    color: #4f5666;
    font-size: 0.84rem;
    line-height: 1.45;
}

.tt-home-plan-saving-tag {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 11px;
    border-radius: 999px;
    background: #edf8ef;
    color: #2c8756;
    font-size: 0.73rem;
    font-weight: 700;
    line-height: 1.2;
}

.tt-home-plan-actions {
    margin-top: 0;
    margin-bottom: 18px;
}

.tt-home-plan-actions .btn {
    min-height: 44px;
    border-radius: 7px;
    font-size: 0.92rem;
    font-weight: 700;
}

.tt-home-plan-card .tt-home-plan-actions .btn-primary {
    background: transparent !important;
    border: 1px solid #d7dfe9 !important;
    color: #243247 !important;
    box-shadow: none !important;
}

.tt-home-plan-card .tt-home-plan-actions .btn-primary:hover {
    background: #f8fafc !important;
    border-color: #c8d3df !important;
    color: #172033 !important;
}

.tt-home-plan-card--featured .tt-home-plan-actions .btn-primary {
    background: #cc181b !important;
    border-color: #cc181b !important;
    color: #fff !important;
}

.tt-home-plan-card--featured .tt-home-plan-actions .btn-primary:hover {
    background: #a61417 !important;
    border-color: #a61417 !important;
}

.tt-home-plan-highlights,
.tt-home-plan-features {
    flex: 1 1 auto;
}

.tt-home-plan-highlights {
    margin-bottom: 16px;
}

.tt-home-plan-highlight-list,
.tt-home-plan-feature-list {
    display: grid;
    gap: 9px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.tt-home-plan-highlight-list li,
.tt-home-plan-feature-list li {
    position: relative;
    padding-left: 16px;
    color: #243247;
    font-size: 0.83rem;
    line-height: 1.4;
}

.tt-home-plan-highlight-list li {
    color: #0f5132;
    font-weight: 600;
}

.tt-home-plan-feature-heading {
    display: block;
    margin-bottom: 12px;
    color: #1a2333;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.tt-home-plan-features {
    padding-top: 16px;
    border-top: 1px solid #edf1f5;
}

.tt-home-plan-highlight-list li::before,
.tt-home-plan-feature-list li::before {
    content: "";
    position: absolute;
    top: 0.46rem;
    left: 0;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #22c55e;
    box-shadow: none;
}

.tt-home-plan-feature-list li::before {
    background: #cc181b;
}

.tt-home-plan-footer-note {
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid #edf1f5;
}

.tt-home-plan-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #7f8794 !important;
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    text-decoration: none !important;
}

.tt-home-plan-link:hover {
    color: #cc181b !important;
}

.tt-home-plans-domain-row {
    margin-top: 40px;
}

.tt-home-plans-loading {
    padding: 18px 0 6px;
    color: #6f7685;
}


@media (max-width: 991.98px) {
    .tt-home-plan-price__amount {
        font-size: 2.35rem;
    }
}

@media (max-width: 767.98px) {
    .tt-home-plans-heading {
        margin-bottom: 22px !important;
    }

    .tt-home-plans-heading h2 {
        font-size: 1.55rem;
    }

    .tt-home-plan-card {
        border-radius: 14px;
    }

    .tt-home-plan-card__inner {
        padding: 18px 16px 16px;
    }

    .tt-home-plan-title {
        font-size: 1.55rem;
    }

    .tt-home-plan-price__amount {
        font-size: 2.15rem;
    }

    .tt-home-plan-subtitle {
        min-height: 0;
    }

    .tt-home-plan-highlight-list li,
    .tt-home-plan-feature-list li {
        font-size: 0.81rem;
    }

    .tt-home-plans-domain-row {
        margin-top: 30px;
    }
}

/* Homepage Motion */

.tt-motion-reveal {
    opacity: 0;
    transform: translate3d(0, 34px, 0) scale(0.985);
    transition:
        opacity 0.82s cubic-bezier(0.22, 1, 0.36, 1),
        transform 0.82s cubic-bezier(0.22, 1, 0.36, 1);
    transition-delay: var(--tt-motion-delay, 0ms);
    will-change: transform, opacity;
}

.tt-motion-reveal.is-visible {
    opacity: 1;
    transform: translate3d(0, 0, 0) scale(1);
}

.tt-ph-section-heading h2,
.tt-home-plans-heading h2 {
    position: relative;
    padding-bottom: 18px;
}

.tt-ph-section-heading h2::after,
.tt-home-plans-heading h2::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 78px;
    height: 3px;
    border-radius: 999px;
    background: linear-gradient(90deg, rgba(204, 24, 27, 0.35) 0%, rgba(204, 24, 27, 0.95) 100%);
    transform: translateX(-50%) scaleX(0.28);
    transform-origin: center center;
    opacity: 0.3;
    transition: transform 0.72s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.45s ease;
}

.tt-ph-section-heading--left h2::after {
    left: 0;
    transform: scaleX(0.28);
    transform-origin: left center;
}

.tt-ph-section-heading.tt-motion-reveal.is-visible h2::after,
.tt-home-plans-heading.tt-motion-reveal.is-visible h2::after {
    opacity: 1;
    transform: translateX(-50%) scaleX(1);
}

.tt-ph-section-heading--left.tt-motion-reveal.is-visible h2::after {
    transform: scaleX(1);
}

.tt-promo,
.tt-trust-strip,
.tt-domain-search-shell,
.tt-home-plan-card,
.tt-services-section .tt-service-single,
.tt-services-section .tt-service-info,
.tt-ph-stat-card,
.tt-ph-solution-card,
.tt-ph-solution-stat,
.tt-ph-showcase-card,
.tt-ph-feature-card,
.tt-ph-promo-card,
.tt-ph-cta-shell {
    transition:
        transform 0.28s ease,
        box-shadow 0.28s ease,
        border-color 0.28s ease,
        background-color 0.28s ease;
}

.tt-home-plan-card,
.tt-ph-stat-card,
.tt-ph-solution-card,
.tt-ph-solution-stat,
.tt-ph-showcase-card,
.tt-ph-feature-card,
.tt-ph-promo-card,
.tt-ph-cta-shell {
    position: relative;
    isolation: isolate;
    transform-style: preserve-3d;
    will-change: transform;
}

.tt-home-plan-card::after,
.tt-ph-stat-card::after,
.tt-ph-solution-card::after,
.tt-ph-solution-stat::after,
.tt-ph-showcase-card::after,
.tt-ph-feature-card::after,
.tt-ph-promo-card::after,
.tt-ph-cta-shell::after {
    content: "";
    position: absolute;
    inset: -1px;
    border-radius: inherit;
    background: radial-gradient(circle at var(--tt-glow-x, 50%) var(--tt-glow-y, 50%), rgba(204, 24, 27, 0.18), transparent 42%);
    opacity: var(--tt-glow-opacity, 0);
    transition: opacity 0.28s ease;
    pointer-events: none;
    z-index: 0;
}

.tt-home-plan-card > *,
.tt-ph-stat-card > *,
.tt-ph-solution-card > *,
.tt-ph-solution-stat > *,
.tt-ph-showcase-card > *,
.tt-ph-feature-card > *,
.tt-ph-promo-card > *,
.tt-ph-cta-shell > * {
    position: relative;
    z-index: 1;
}

.tt-promo:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 38px rgba(17, 17, 17, 0.1);
}

.tt-promo .ico-container i,
.tt-trust-item i,
.tt-home-plan-icon {
    transition: transform 0.28s ease, filter 0.28s ease;
}

.tt-promo:hover .ico-container i,
.tt-trust-item:hover i {
    transform: translateY(-3px) scale(1.06);
}

.tt-trust-strip:hover {
    transform: translateY(-2px);
    box-shadow: 0 16px 34px rgba(17, 17, 17, 0.08);
}

.tt-home-plan-card:hover .tt-home-plan-icon {
    transform: translateY(-4px) scale(1.04);
}

.tt-services-section .tt-service-single:hover,
.tt-ph-stat-card:hover,
.tt-ph-solution-card:hover,
.tt-ph-solution-stat:hover,
.tt-ph-showcase-card:hover,
.tt-ph-feature-card:hover,
.tt-ph-promo-card:hover,
.tt-ph-cta-shell:hover {
    transform: translateY(-5px);
}

.tt-services-section .tt-service-single:hover .tt-service-info {
    background: rgba(122, 8, 12, 0.44);
    border-color: rgba(255, 255, 255, 0.14);
}

.tt-ph-showcase-media img,
.tt-ph-promo-media img {
    transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1), filter 0.35s ease;
    will-change: transform;
}

.tt-ph-showcase-card:hover .tt-ph-showcase-media img,
.tt-ph-promo-card:hover .tt-ph-promo-media img {
    transform: scale(1.05);
}

.tt-ph-stat-card i,
.tt-ph-solution-card i,
.tt-ph-feature-card i,
.tt-ph-inline-link i {
    transition: transform 0.28s ease, color 0.28s ease;
}

.tt-ph-stat-card:hover i,
.tt-ph-solution-card:hover i,
.tt-ph-feature-card:hover i {
    transform: translateY(-3px) scale(1.05);
}

.tt-ph-inline-link:hover i {
    transform: translateX(4px);
}

.tt-ph-stat-card.is-visible i,
.tt-ph-solution-card.is-visible i,
.tt-ph-feature-card.is-visible i,
.tt-home-plan-card.is-visible .tt-home-plan-icon {
    animation: ttIconFloat 4.8s ease-in-out infinite;
}

@keyframes ttIconFloat {
    0%,
    100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-4px);
    }
}

@keyframes ttDomainCarousel {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(calc(-50% - 9px));
    }
}

@media (prefers-reduced-motion: reduce) {
    .tt-motion-reveal,
    .tt-promo,
    .tt-trust-strip,
    .tt-domain-search-shell,
    .tt-home-plan-card,
    .tt-services-section .tt-service-single,
    .tt-services-section .tt-service-info,
    .tt-ph-stat-card,
    .tt-ph-solution-card,
    .tt-ph-solution-stat,
    .tt-ph-showcase-card,
    .tt-ph-feature-card,
    .tt-ph-promo-card,
    .tt-ph-cta-shell,
    .tt-ph-showcase-media img,
    .tt-ph-promo-media img,
    .tt-ph-stat-card i,
    .tt-ph-solution-card i,
    .tt-ph-feature-card i,
    .tt-ph-inline-link i,
    .tt-promo .ico-container i,
    .tt-trust-item i,
    .tt-home-plan-icon {
        animation: none !important;
        transition: none !important;
        transform: none !important;
        opacity: 1 !important;
    }

    .tt-ph-domain-carousel__track {
        animation: none !important;
    }
}

/* Premium Hosting Plan Cards */
.tt-home-plans-row {
    row-gap: 28px;
}

.tt-home-plans-row > div {
    display: flex;
}

.tt-home-plans-row > div > .tt-home-plan-card {
    width: 100%;
}

.tt-home-plans-row .tt-home-plan-card {
    --tt-plan-top-bg: linear-gradient(180deg, rgba(204, 24, 27, 0.08) 0%, rgba(255, 255, 255, 0.98) 100%);
    --tt-plan-top-glow: rgba(204, 24, 27, 0.12);
    --tt-plan-surface: linear-gradient(180deg, #fffefe 0%, #fff8f8 100%);
    border: 1px solid rgba(194, 204, 218, 0.5);
    border-radius: 24px;
    background: var(--tt-plan-surface);
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    transform-style: flat;
    will-change: auto;
}

.tt-home-plans-row .tt-home-plan-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    border: 1px solid rgba(255, 255, 255, 0.7);
    pointer-events: none;
    z-index: 0;
}

.tt-home-plans-row .tt-home-plan-card::after {
    display: none;
}

.tt-home-plans-row .tt-home-plan-card:hover {
    transform: translateY(-5px);
    box-shadow: 0 22px 52px rgba(15, 23, 42, 0.1);
}

.tt-home-plans-row .tt-home-plan-card--featured {
    border-color: rgba(204, 24, 27, 0.42);
    box-shadow: 0 24px 56px rgba(166, 20, 23, 0.12);
}

.tt-home-plans-row .tt-home-plan-card--featured:hover {
    transform: translateY(-6px);
}

.tt-home-plans-row .tt-home-plan-card--tier-1 {
    --tt-plan-top-bg: linear-gradient(180deg, rgba(17, 24, 39, 0.07) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.tt-home-plans-row .tt-home-plan-card--tier-2 {
    --tt-plan-top-bg: linear-gradient(180deg, rgba(204, 24, 27, 0.12) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.tt-home-plans-row .tt-home-plan-card--tier-3 {
    --tt-plan-top-bg: linear-gradient(180deg, rgba(79, 86, 102, 0.09) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.tt-home-plans-row .tt-home-plan-card--tier-4 {
    --tt-plan-top-bg: linear-gradient(180deg, rgba(127, 13, 17, 0.1) 0%, rgba(255, 255, 255, 0.98) 100%);
}

.tt-home-plans-row .tt-home-plan-card__inner {
    display: flex;
    flex-direction: column;
    height: 100%;
    padding: 0;
}

.tt-home-plans-row .tt-home-plan-card__top {
    position: relative;
    display: block;
    margin: 0;
    padding: 24px 24px 18px;
    background: var(--tt-plan-top-bg);
    overflow: hidden;
    border-bottom: 1px solid rgba(225, 231, 239, 0.8);
}

.tt-home-plans-row .tt-home-plan-card__top::before {
    content: "";
    position: absolute;
    width: 180px;
    height: 180px;
    top: -92px;
    right: -56px;
    border-radius: 50%;
    background: radial-gradient(circle, var(--tt-plan-top-glow) 0%, rgba(255, 255, 255, 0) 70%);
    pointer-events: none;
}

.tt-home-plans-row .tt-home-plan-card__top::after {
    display: none;
}

.tt-home-plans-row .tt-home-plan-meta {
    position: relative;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.tt-home-plans-row .tt-home-plan-recommended {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(204, 24, 27, 0.1);
    color: #a61417;
    font-size: 0.64rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    border: 1px solid rgba(204, 24, 27, 0.14);
}

.tt-home-plans-row .tt-home-plan-icon {
    position: relative;
    z-index: 1;
    width: 60px;
    padding: 12px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(219, 226, 236, 0.95);
    box-shadow: 0 14px 24px rgba(15, 23, 42, 0.08);
}

.tt-home-plans-row .tt-home-plan-price-wrap {
    position: relative;
    z-index: 1;
    min-width: 0;
    width: 100%;
}

.tt-home-plans-row .tt-home-plan-title {
    margin: 0 0 8px;
    color: #111827 !important;
    font-size: 1.55rem;
    font-weight: 800;
    line-height: 1.06;
    text-align: left;
}

.tt-home-plans-row .tt-home-plan-caption {
    margin: 0 0 18px;
    color: #6b7280 !important;
    font-size: 0.9rem;
    line-height: 1.5;
    max-width: none;
    text-align: left;
}

.tt-home-plans-row .tt-home-plan-price {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 8px;
}

.tt-home-plans-row .tt-home-plan-price__amount {
    color: #111827 !important;
    font-size: 1.7rem;
    font-weight: 800;
    line-height: 0.95;
    letter-spacing: -0.04em;
    text-align: left;
}

.tt-home-plans-row .tt-home-plan-price__cycle {
    padding-bottom: 0.24rem;
    color: #7b8394 !important;
    font-size: 0.85rem;
    font-weight: 600;
}

.tt-home-plans-row .tt-home-plan-features {
    position: relative;
    z-index: 1;
    flex: 1 1 auto;
    margin: 0 18px;
    padding: 18px 20px 10px;
    border: 1px solid rgba(236, 239, 244, 0.92);
    border-radius: 20px;
    background: #ffffff;
    box-shadow: 0 12px 26px rgba(15, 23, 42, 0.04);
    backdrop-filter: none;
}

.tt-home-plans-row .tt-home-plan-feature-list {
    gap: 12px;
}

.tt-home-plans-row .tt-home-plan-feature-list li {
    padding-left: 22px;
    color: #1f2937;
    font-size: 0.92rem;
    line-height: 1.45;
}

.tt-home-plans-row .tt-home-plan-feature-list li::before {
    width: 8px;
    height: 8px;
    top: 0.43rem;
    background: #cc181b;
    box-shadow: 0 0 0 6px rgba(204, 24, 27, 0.08);
}

.tt-home-plans-row .tt-home-plan-feature-more {
    display: inline-flex;
    align-items: center;
    margin-top: 16px;
    padding: 7px 12px;
    border-radius: 999px;
    background: #fff4f4;
    color: #a61417;
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.tt-home-plans-row .tt-home-plan-actions {
    margin-top: auto;
    padding: 18px 20px 22px;
}

.tt-home-plans-row .tt-home-plan-actions .btn {
    min-height: 50px;
    border: none;
    border-radius: 14px;
    background: linear-gradient(135deg, #cc181b 0%, #8f1114 100%) !important;
    color: #ffffff !important;
    font-size: 0.98rem;
    font-weight: 800;
    letter-spacing: -0.01em;
    box-shadow: 0 16px 30px rgba(204, 24, 27, 0.22);
}

.tt-home-plans-row .tt-home-plan-actions .btn:hover {
    background: linear-gradient(135deg, #df2327 0%, #a61417 100%) !important;
    box-shadow: 0 20px 34px rgba(166, 20, 23, 0.26);
}

.tt-home-plans-row .tt-home-plan-card--featured .tt-home-plan-actions .btn {
    background: linear-gradient(135deg, #b31518 0%, #7f0d11 100%) !important;
    box-shadow: 0 18px 32px rgba(166, 20, 23, 0.24);
}

.tt-home-plans-row .tt-home-plan-card--featured .tt-home-plan-actions .btn:hover {
    background: linear-gradient(135deg, #c81a1d 0%, #961417 100%) !important;
}

.tt-home-plans-row .tt-home-plan-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 16px;
    color: #6b7280 !important;
    font-size: 0.84rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    text-decoration: none !important;
}

.tt-home-plans-row .tt-home-plan-link:hover {
    color: #cc181b !important;
}

@media (max-width: 1199.98px) {
    .tt-home-plans-row .tt-home-plan-card--featured,
    .tt-home-plans-row .tt-home-plan-card--featured:hover {
        transform: translateY(-5px);
    }
}

@media (max-width: 767.98px) {
    .tt-home-plans-row {
        row-gap: 20px;
    }

    .tt-home-plans-row .tt-home-plan-card {
        border-radius: 24px;
    }

    .tt-home-plans-row .tt-home-plan-card__top {
        padding: 22px 20px 16px;
    }

    .tt-home-plans-row .tt-home-plan-meta {
        margin-bottom: 14px;
    }

    .tt-home-plans-row .tt-home-plan-icon {
        width: 58px;
        padding: 12px;
        border-radius: 18px;
    }

    .tt-home-plans-row .tt-home-plan-title {
        font-size: 1.35rem;
    }

    .tt-home-plans-row .tt-home-plan-caption {
        font-size: 0.87rem;
    }

    .tt-home-plans-row .tt-home-plan-price__amount {
        font-size: 1.52rem;
    }

    .tt-home-plans-row .tt-home-plan-features {
        margin: 0 14px;
        padding: 18px 16px 8px;
        border-radius: 22px;
    }

    .tt-home-plans-row .tt-home-plan-actions {
        padding: 16px 18px 22px;
    }

    .tt-ph-domain-carousel {
        padding: 22px 0 6px;
    }

    .tt-ph-domain-carousel__viewport::before,
    .tt-ph-domain-carousel__viewport::after {
        width: 44px;
    }

    .tt-ph-domain-carousel__track {
        gap: 12px;
    }

    .tt-ph-domain-chip {
        min-width: 150px;
        padding: 14px 15px;
        border-radius: 18px;
    }

    .tt-ph-domain-chip__tld {
        font-size: 1.02rem;
    }

    .tt-ph-domain-chip__meta {
        font-size: 0.76rem;
    }
}

/* PetroHost-inspired homepage */
:root {
    --tt-ph-primary: #CC181B;
    --tt-ph-primary-dark: #A61417;
    --tt-ph-primary-darker: #7F0D11;
    --tt-ph-primary-soft: #FFF1F1;
}

.tt-ph-domain-carousel {
    position: relative;
    padding: 30px 0 10px;
    background:#991214;
    overflow: hidden;
}

.tt-ph-domain-carousel__viewport {
    position: relative;
    overflow: hidden;
    border-radius: 26px;
    padding: 8px 0;
}

.tt-ph-domain-carousel__viewport::before,
.tt-ph-domain-carousel__viewport::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    width: 92px;
    z-index: 2;
    pointer-events: none;
}

.tt-ph-domain-carousel__viewport::before {
    left: 0;
    background: linear-gradient(90deg, #fffdfd 0%, rgba(255, 253, 253, 0) 100%);
}

.tt-ph-domain-carousel__viewport::after {
    right: 0;
    background: linear-gradient(270deg, #fffdfd 0%, rgba(255, 253, 253, 0) 100%);
}

.tt-ph-domain-carousel__track {
    display: flex;
    align-items: stretch;
    gap: 18px;
    width: max-content;
    animation: ttDomainCarousel 26s linear infinite;
}

.tt-ph-domain-chip {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-width: 184px;
    padding: 16px 18px;
    border: 1px solid rgba(225, 229, 236, 0.95);
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
    text-decoration: none !important;
    transition: transform 0.24s ease, box-shadow 0.24s ease, border-color 0.24s ease;
}

.tt-ph-domain-chip:hover {
    transform: translateY(-4px);
    border-color: rgba(204, 24, 27, 0.28);
    box-shadow: 0 18px 32px rgba(166, 20, 23, 0.1);
}

.tt-ph-domain-chip__tld {
    display: block;
    margin-bottom: 4px;
    color: #121927;
    font-size: 1.22rem;
    font-weight: 800;
    letter-spacing: -0.02em;
}

.tt-ph-domain-chip__meta {
    display: block;
    color: #727b8c;
    font-size: 0.84rem;
    line-height: 1.35;
}

.tt-ph-hero,
.tt-ph-stats,
.tt-ph-clients,
.tt-ph-solutions,
.tt-ph-showcase,
.tt-ph-complements,
.tt-ph-cta {
    position: relative;
}

.tt-ph-hero {
    padding: 96px 0 82px;
    background:
        radial-gradient(circle at top right, rgba(204, 24, 27, 0.35), transparent 34%),
        linear-gradient(135deg, #14090A 0%, #241012 42%, #461417 100%);
    color: #ffffff;
    overflow: hidden;
}

.tt-ph-hero .container {
    position: relative;
    z-index: 2;
}

.tt-ph-hero--video {
    background: #14090A;
}

.tt-ph-hero-video-wrap,
.tt-ph-hero-overlay {
    position: absolute;
    inset: 0;
}

.tt-ph-hero-video-wrap {
    z-index: 0;
    background: #12090A;
}

.tt-ph-hero-video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center center;
    display: block;
    transform: scale(1.04);
}

.tt-ph-hero-overlay {
    z-index: 1;
    background:
        linear-gradient(90deg, rgba(20, 9, 10, 0.84) 0%, rgba(36, 16, 18, 0.7) 34%, rgba(58, 18, 21, 0.54) 58%, rgba(82, 20, 23, 0.36) 100%);
}

.tt-ph-hero::before {
    content: "";
    position: absolute;
    right: -120px;
    bottom: -160px;
    width: 420px;
    height: 420px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
    filter: blur(4px);
}

.tt-ph-hero-copy,
.tt-ph-hero-panel {
    position: relative;
    z-index: 1;
}

.tt-ph-eyebrow,
.tt-ph-section-kicker,
.tt-ph-showcase-label,
.tt-ph-promo-tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 16px;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    color: #FFE3E4;
    font-size: 0.82rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.tt-ph-hero .tt-ph-eyebrow {
    background: rgba(255, 255, 255, 0.12);
    color: #E5E7EB;
}

.tt-ph-hero h1 {
    margin: 0;
    color: #ffffff;
    font-size: clamp(2.8rem, 5vw, 4.5rem);
    line-height: 0.98;
    letter-spacing: -0.04em;
}

.tt-ph-hero h1 span {
    display: block;
    color: rgba(255, 255, 255, 0.78);
    font-weight: 400;
}

.tt-ph-lead {
    max-width: 640px;
    margin: 24px 0 0;
    color: rgba(255, 236, 237, 0.84);
    font-size: 1.05rem;
    line-height: 1.7;
}

.tt-ph-checklist {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 20px;
    margin-top: 28px;
}

.tt-ph-checklist span {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: rgba(255, 255, 255, 0.9);
    font-size: 0.92rem;
    font-weight: 600;
}

.tt-ph-checklist i,
.tt-ph-guarantee i {
    color: #FF9B9D;
}

.tt-ph-hero .tt-ph-checklist i,
.tt-ph-hero .tt-ph-guarantee i {
    color: #D1D5DB;
}

.tt-ph-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    margin-top: 32px;
}

.tt-ph-actions .btn {
    min-height: 46px;
    padding: 0.8rem 1.5rem;
    border-radius: 12px;
    font-weight: 700;
    font-size: 0.94rem;
}

.tt-ph-actions .btn-primary {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(209, 213, 219, 0.38);
    color: #ffffff !important;
}

.tt-ph-actions .btn-primary:hover,
.tt-ph-actions .btn-primary:focus {
    background: rgba(229, 231, 235, 0.16);
    border-color: rgba(229, 231, 235, 0.5);
    color: #ffffff !important;
}

.tt-ph-actions .btn-default {
    background: rgba(255, 255, 255, 0.1);
    border-color: rgba(209, 213, 219, 0.38);
    color: #ffffff !important;
}

.tt-ph-actions .btn-default:hover,
.tt-ph-actions .btn-default:focus {
    background: rgba(229, 231, 235, 0.16);
    border-color: rgba(229, 231, 235, 0.5);
    color: #ffffff !important;
}

.tt-ph-guarantee {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 22px;
    color: rgba(221, 230, 242, 0.78);
    font-size: 0.9rem;
}

.tt-ph-hero-panel {
    padding: 26px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 24px;
    background: rgba(7, 13, 24, 0.28);
    box-shadow: 0 24px 60px rgba(6, 10, 18, 0.28);
    backdrop-filter: blur(10px);
}

.tt-ph-hero-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 18px;
    padding: 10px 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.08);
    color: #f4f8ff;
    font-size: 0.9rem;
    font-weight: 700;
}

.tt-ph-hero-badge i {
    color: #ffc857;
}

.tt-ph-hero-card {
    padding: 22px;
    border-radius: 18px;
    background: #ffffff;
    color: #131722;
}

.tt-ph-hero-card-label {
    display: block;
    margin-bottom: 10px;
    color: #9D4A4C;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.tt-ph-hero-card strong {
    display: block;
    color: #4B1114;
    font-size: 1.6rem;
    line-height: 1.1;
}

.tt-ph-hero-card p {
    margin: 12px 0 0;
    color: #5e697d;
    line-height: 1.6;
}

.tt-ph-hero-metrics {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 16px;
}

.tt-ph-metric {
    padding: 18px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.tt-ph-metric strong {
    display: block;
    color: #ffffff;
    font-size: 1.25rem;
    line-height: 1.1;
}

.tt-ph-metric span {
    display: block;
    margin-top: 6px;
    color: rgba(255, 235, 236, 0.72);
    font-size: 0.9rem;
}

.tt-ph-stats,
.tt-ph-clients,
.tt-ph-solutions,
.tt-ph-showcase,
.tt-ph-complements {
    padding: 84px 0;
    background: #ffffff;
}

.tt-ph-solutions {
    background: linear-gradient(180deg, #ffffff 0%, #fff7f7 100%);
}

.tt-ph-complements {
    background: #fff8f8;
}

.tt-ph-section-heading {
    max-width: 780px;
    margin: 0 auto 42px;
    text-align: center;
}

.tt-ph-section-heading--left {
    margin-left: 0;
    text-align: left;
}

.tt-ph-section-heading--narrow {
    max-width: 700px;
}

.tt-ph-section-heading h2,
.tt-ph-cta-shell h2 {
    margin: 0;
    color: #121926;
    font-size: clamp(2rem, 3vw, 2.8rem);
    line-height: 1.08;
    letter-spacing: -0.03em;
}

.tt-ph-section-heading p,
.tt-ph-cta-shell p {
    margin: 14px 0 0;
    color: #667085;
    font-size: 1rem;
    line-height: 1.7;
}

.tt-ph-section-heading .tt-ph-section-kicker,
.tt-ph-cta-shell .tt-ph-section-kicker {
    background: var(--tt-ph-primary-soft);
    color: var(--tt-ph-primary);
}

.tt-ph-stat-card,
.tt-ph-feature-card,
.tt-ph-solution-card,
.tt-ph-solution-stat,
.tt-ph-showcase-card,
.tt-ph-promo-card,
.tt-ph-cta-shell {
    border: 1px solid #e6edf6;
    border-radius: 22px;
    box-shadow: 0 16px 40px rgba(14, 18, 29, 0.06);
}

.tt-ph-stat-card {
    height: 100%;
    padding: 28px 24px;
    background: #ffffff;
}

.tt-ph-stat-card i {
    margin-bottom: 16px;
    color: var(--tt-ph-primary);
    font-size: 1.35rem;
}

.tt-ph-stat-card strong {
    display: block;
    color: #121926;
    font-size: 2rem;
    line-height: 1;
}

.tt-ph-stat-card span {
    display: block;
    margin-top: 10px;
    color: #1f2937;
    font-size: 1rem;
    font-weight: 700;
}

.tt-ph-stat-card p {
    margin: 8px 0 0;
    color: #6b7280;
    line-height: 1.6;
}

.tt-ph-client-grid {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 16px;
}

.tt-ph-client-card {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 96px;
    padding: 18px;
    border: 1px solid #edf1f7;
    border-radius: 18px;
    background: #ffffff;
    transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.tt-ph-client-card:hover {
    transform: translateY(-4px);
    border-color: #d7e2ef;
    box-shadow: 0 14px 34px rgba(14, 18, 29, 0.08);
}

.tt-ph-client-card img {
    max-width: 100%;
    max-height: 42px;
    object-fit: contain;
}

.tt-ph-client-badge {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin-top: 28px;
    padding: 11px 18px;
    border-radius: 999px;
    background: #fff5f5;
    border: 1px solid #f1d1d2;
    color: #66181A;
    font-weight: 700;
}

.tt-ph-client-badge i {
    color: #ffb400;
}

.tt-ph-solution-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
}

.tt-ph-solution-card,
.tt-ph-solution-stat {
    padding: 26px 24px;
    background: #ffffff;
    text-decoration: none !important;
}

.tt-ph-solution-card:hover {
    transform: translateY(-5px);
    border-color: #cfe0f3;
    box-shadow: 0 20px 42px rgba(14, 18, 29, 0.1);
}

.tt-ph-solution-badge {
    display: inline-flex;
    margin-bottom: 18px;
    padding: 7px 12px;
    border-radius: 999px;
    background: var(--tt-ph-primary-soft);
    color: var(--tt-ph-primary);
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
}

.tt-ph-solution-card i {
    display: block;
    margin-bottom: 18px;
    color: var(--tt-ph-primary);
    font-size: 1.55rem;
}

.tt-ph-solution-card h3,
.tt-ph-showcase-copy h3,
.tt-ph-feature-card h3,
.tt-ph-promo-copy h3 {
    margin: 0;
    color: #121926;
    font-size: 1.3rem;
    line-height: 1.2;
}

.tt-ph-solution-card p,
.tt-ph-showcase-copy p,
.tt-ph-feature-card p,
.tt-ph-promo-copy p {
    margin: 12px 0 0;
    color: #677489;
    line-height: 1.7;
}

.tt-ph-solution-meta {
    display: inline-flex;
    margin-top: 18px;
    color: var(--tt-ph-primary);
    font-weight: 700;
}

.tt-ph-solution-stat {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    background: linear-gradient(135deg, var(--tt-ph-primary-darker) 0%, var(--tt-ph-primary) 100%);
    border-color: transparent;
    color: #ffffff;
}

.tt-ph-solution-stat strong {
    color: #ffffff;
    font-size: 2.4rem;
    line-height: 1;
}

.tt-ph-solution-stat span {
    display: block;
    margin-top: 10px;
    color: rgba(255, 255, 255, 0.76);
    font-weight: 600;
}

.tt-ph-showcase-grid,
.tt-ph-promo-grid {
    display: grid;
    gap: 22px;
}

.tt-ph-showcase-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tt-ph-showcase-card,
.tt-ph-promo-card {
    overflow: hidden;
    background: #ffffff;
}

.tt-ph-showcase-media img,
.tt-ph-promo-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.tt-ph-showcase-media {
    height: 230px;
}

.tt-ph-showcase-copy,
.tt-ph-promo-copy {
    padding: 28px 24px;
}

.tt-ph-inline-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 20px;
    color: var(--tt-ph-primary) !important;
    font-weight: 700;
    text-decoration: none !important;
}

.tt-ph-inline-link:hover {
    color: var(--tt-ph-primary-dark) !important;
}

.tt-ph-complements-top {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
    gap: 22px;
    align-items: start;
}

.tt-ph-feature-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.tt-ph-feature-card {
    height: 100%;
    padding: 22px;
    background: #ffffff;
}

.tt-ph-feature-card i {
    margin-bottom: 14px;
    color: var(--tt-ph-primary);
    font-size: 1.2rem;
}

.tt-ph-promo-grid {
    margin-top: 28px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tt-ph-promo-card {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

.tt-ph-promo-tag {
    background: var(--tt-ph-primary-soft);
    color: var(--tt-ph-primary);
}

.tt-ph-promo-list {
    margin: 18px 0 0;
    padding: 0;
    list-style: none;
}

.tt-ph-promo-list li {
    position: relative;
    padding-left: 18px;
    color: #526177;
    line-height: 1.55;
}

.tt-ph-promo-list li + li {
    margin-top: 10px;
}

.tt-ph-promo-list li::before {
    content: "";
    position: absolute;
    top: 0.6rem;
    left: 0;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--tt-ph-primary);
}

.tt-ph-promo-media {
    min-height: 100%;
}

.tt-ph-cta {
    padding: 0 0 96px;
    background: #fff8f8;
}

.tt-ph-cta-shell {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 32px;
    background: linear-gradient(135deg, #14090A 0%, var(--tt-ph-primary) 100%);
    border-color: transparent;
}

.tt-ph-cta-shell h2,
.tt-ph-cta-shell p,
.tt-ph-cta-shell .tt-ph-section-kicker {
    color: #ffffff;
}

.tt-ph-cta-shell .tt-ph-section-kicker {
    background: rgba(255, 255, 255, 0.12);
}

.tt-ph-cta-shell p {
    color: rgba(230, 237, 247, 0.78);
}

.tt-ph-cta-shell .tt-ph-actions {
    margin-top: 0;
    justify-content: flex-end;
}

@media (max-width: 1199.98px) {
    .tt-ph-client-grid,
    .tt-ph-showcase-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .tt-ph-solution-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .tt-ph-complements-top,
    .tt-ph-promo-grid,
    .tt-ph-promo-card {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 991.98px) {
    .tt-ph-hero {
        padding: 78px 0 62px;
    }

    .tt-ph-hero-overlay {
        background:
            linear-gradient(180deg, rgba(20, 9, 10, 0.8) 0%, rgba(36, 16, 18, 0.64) 100%);
    }

    .tt-ph-hero-panel {
        margin-top: 6px;
    }

    .tt-ph-client-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .tt-ph-feature-grid {
        grid-template-columns: 1fr 1fr;
    }

    .tt-ph-cta-shell {
        flex-direction: column;
        align-items: flex-start;
    }

    .tt-ph-cta-shell .tt-ph-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 767.98px) {
    .tt-ph-hero,
    .tt-ph-stats,
    .tt-ph-clients,
    .tt-ph-solutions,
    .tt-ph-showcase,
    .tt-ph-complements {
        padding: 64px 0;
    }

    .tt-ph-cta {
        padding-bottom: 72px;
    }

    .tt-ph-hero h1 {
        font-size: 2.4rem;
    }

    .tt-ph-lead {
        font-size: 0.98rem;
    }

    .tt-ph-hero-video {
        transform: scale(1.08);
    }

    .tt-ph-hero-panel {
        padding: 20px;
        border-radius: 20px;
    }

    .tt-ph-hero-metrics,
    .tt-ph-client-grid,
    .tt-ph-solution-grid,
    .tt-ph-showcase-grid,
    .tt-ph-feature-grid {
        grid-template-columns: 1fr;
    }

    .tt-ph-showcase-media {
        height: 200px;
    }

    .tt-ph-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .tt-ph-actions .btn {
        width: 100%;
        justify-content: center;
    }
}
