/* ============================================================
   Masterweb Premium Widgets — Avista-styled
   ============================================================ */

:root {
    --tx-primary: #FF6F2C;
    --tx-primary-2: #ff4500;
    --tx-bg-dark: #0a0a0a;
    --tx-bg-2: #050505;
    --tx-card: #131313;
    --tx-card-2: #1a1a1a;
    --tx-text: #ffffff;
    --tx-muted: #a0a0a0;
    --tx-dim: #6b6b6b;
    --tx-border: rgba(255,255,255,0.08);
    --tx-border-hover: rgba(255,111,44,0.3);
    --tx-light-bg: #f8f8f8;
    --tx-light-text: #0a0a0a;
}

.tx-section { padding: 100px 0; position: relative; overflow: hidden; }
.tx-section--dark { background: var(--tx-bg-dark); color: var(--tx-text); }
.tx-section--light { background: var(--tx-light-bg); color: var(--tx-light-text); }
.tx-container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }

.tx-eyebrow {
    display: inline-block;
    color: var(--tx-primary);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-bottom: 14px;
}
.tx-eyebrow::before { content: '{ '; opacity: 0.6; }
.tx-eyebrow::after { content: ' }'; opacity: 0.6; }

.tx-h1 {
    font-size: clamp(40px, 6vw, 76px);
    line-height: 1.05;
    font-weight: 800;
    letter-spacing: -0.02em;
    margin: 0 0 24px;
}
.tx-h2 {
    font-size: clamp(32px, 4.5vw, 56px);
    line-height: 1.1;
    font-weight: 700;
    letter-spacing: -0.02em;
    margin: 0 0 20px;
}
.tx-accent {
    background: linear-gradient(120deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.tx-lead {
    font-size: clamp(16px, 1.6vw, 19px);
    line-height: 1.65;
    max-width: 640px;
    color: inherit;
    opacity: 0.85;
    margin: 0 0 24px;
}

/* Buttons */
.tx-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 16px 32px; border-radius: 999px;
    font-weight: 600; font-size: 15px;
    transition: all 0.3s ease;
    text-decoration: none;
}
.tx-btn--primary {
    background: var(--tx-primary); color: #fff;
}
.tx-btn--primary:hover {
    background: var(--tx-primary-2);
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(255,111,44,0.4);
    color: #fff;
}
.tx-btn--ghost {
    background: transparent; color: inherit;
    border: 1px solid var(--tx-border);
}
.tx-btn--ghost:hover {
    border-color: var(--tx-primary);
    color: var(--tx-primary);
}
.tx-btn-arrow { transition: transform 0.3s; }
.tx-btn:hover .tx-btn-arrow { transform: translateX(4px); }

/* ============ HERO ============ */
.tx-hero { padding: 140px 0 100px; background: var(--tx-bg-dark); color: #fff; position: relative; }
.tx-hero::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(circle at 20% 30%, rgba(255,111,44,0.12), transparent 50%),
                radial-gradient(circle at 80% 70%, rgba(255,111,44,0.08), transparent 50%);
    pointer-events: none;
}
.tx-hero-grid {
    display: grid; grid-template-columns: 1.4fr 1fr;
    gap: 60px; align-items: center;
    position: relative; z-index: 1;
}
@media (max-width: 968px) { .tx-hero-grid { grid-template-columns: 1fr; gap: 40px; } }
.tx-hero-meta {
    display: flex; gap: 24px; flex-wrap: wrap; margin-top: 32px;
}
.tx-hero-meta span {
    color: var(--tx-muted); font-size: 14px;
    padding: 10px 18px; background: rgba(255,255,255,0.04);
    border: 1px solid var(--tx-border); border-radius: 999px;
    backdrop-filter: blur(10px);
}
.tx-stat-card {
    background: linear-gradient(145deg, var(--tx-card), var(--tx-card-2));
    border: 1px solid var(--tx-border);
    border-radius: 24px; padding: 40px;
    position: relative; overflow: hidden;
}
.tx-stat-card::before {
    content: ''; position: absolute; top: 0; right: 0;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(255,111,44,0.15), transparent 70%);
    pointer-events: none;
}
.tx-stat-num {
    font-size: clamp(60px, 7vw, 96px); font-weight: 800;
    line-height: 1; letter-spacing: -0.04em;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.tx-stat-label { color: var(--tx-muted); font-size: 15px; line-height: 1.5; margin-top: 12px; }
.tx-stat-rows { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--tx-border); }
.tx-stat-row { display: flex; justify-content: space-between; margin-bottom: 12px; align-items: center; }
.tx-stat-row-label { color: var(--tx-muted); font-size: 14px; }
.tx-stat-row-value { color: #fff; font-weight: 700; }
.tx-stat-row-value--accent { color: var(--tx-primary); }
.tx-stat-row-value--success { color: #16a34a; }

/* ============ MARQUEE ============ */
.tx-marquee {
    background: var(--tx-bg-dark); color: #fff;
    padding: 40px 0; position: relative; overflow: hidden;
    border-top: 1px solid var(--tx-border);
    border-bottom: 1px solid var(--tx-border);
}
.tx-marquee-row {
    display: flex; gap: 60px; white-space: nowrap;
    animation: tx-scroll 40s linear infinite;
}
.tx-marquee-row--reverse { animation-direction: reverse; }
.tx-marquee-row--2 { margin-top: 18px; opacity: 0.6; }
.tx-marquee-item {
    font-size: clamp(28px, 3vw, 48px); font-weight: 700;
    color: #fff; flex-shrink: 0; letter-spacing: -0.01em;
}
.tx-marquee-item::after {
    content: ' ✦ '; color: var(--tx-primary); margin-left: 60px;
}
@keyframes tx-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}

/* ============ WHY STAT ============ */
.tx-why-grid {
    display: grid; grid-template-columns: 1fr 1.5fr;
    gap: 80px; align-items: start;
}
@media (max-width: 968px) { .tx-why-grid { grid-template-columns: 1fr; gap: 40px; } }
.tx-bigstat {
    font-size: clamp(96px, 14vw, 200px); font-weight: 900;
    line-height: 0.85; letter-spacing: -0.06em;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.tx-bigstat-sub { font-size: 17px; line-height: 1.5; margin-top: 20px; opacity: 0.7; }

/* ============ COMPARISON BARS (Why+Stat alternative visual) ============ */
.tx-compare-visual {
    margin: 32px 0;
    display: flex; flex-direction: column; gap: 24px;
}
.tx-compare-row { display: flex; flex-direction: column; gap: 8px; }
.tx-compare-label {
    font-size: 14px; font-weight: 600;
    color: inherit; opacity: 0.7;
    letter-spacing: 0.02em;
}
.tx-compare-bar {
    position: relative;
    height: 48px;
    border-radius: 12px;
    background: rgba(0, 0, 0, 0.06);
    overflow: hidden;
    display: flex; align-items: center;
}
.tx-section--dark .tx-compare-bar {
    background: rgba(255, 255, 255, 0.06);
}
.tx-compare-fill {
    height: 100%;
    border-radius: 12px;
    transition: width 1.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.tx-compare-bar--before .tx-compare-fill {
    background: linear-gradient(90deg, #888, #555);
}
.tx-compare-bar--after .tx-compare-fill {
    background: linear-gradient(90deg, var(--tx-primary), var(--tx-primary-2));
    box-shadow: 0 4px 16px rgba(255,111,44,0.3);
}
.tx-compare-val {
    position: absolute;
    right: 16px;
    font-weight: 700;
    font-size: 15px;
    color: inherit;
    z-index: 2;
}
.tx-compare-result {
    margin-top: 12px;
    padding: 24px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(255,111,44,0.08), rgba(255,111,44,0.02));
    border: 1px solid rgba(255,111,44,0.2);
    display: flex; flex-direction: column; gap: 4px;
    align-items: flex-start;
}
.tx-compare-result-num {
    font-size: clamp(48px, 6vw, 72px); font-weight: 900;
    line-height: 1; letter-spacing: -0.04em;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.tx-compare-result-label {
    font-size: 15px; opacity: 0.75;
    margin-top: 4px;
}

/* ============ DONUT CHART (Why+Stat alternative) ============ */
.tx-donut-visual {
    position: relative;
    width: 260px; height: 260px;
    margin: 24px 0;
}
.tx-donut { width: 100%; height: 100%; transform: rotate(-90deg); }
.tx-donut-bg, .tx-donut-fg {
    fill: none;
    stroke-width: 8;
}
.tx-donut-bg { stroke: rgba(0,0,0,0.08); }
.tx-section--dark .tx-donut-bg { stroke: rgba(255,255,255,0.08); }
.tx-donut-fg {
    stroke: url(#tx-donut-gradient);
    stroke-linecap: round;
    transition: stroke-dashoffset 1.6s cubic-bezier(0.16, 1, 0.3, 1);
    filter: drop-shadow(0 4px 12px rgba(255,111,44,0.4));
}
/* Apply orange gradient to SVG via stroke */
.tx-donut-fg {
    stroke: var(--tx-primary);
}
.tx-donut-center {
    position: absolute; inset: 0;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
}
.tx-donut-num {
    font-size: 56px; font-weight: 900;
    line-height: 1; letter-spacing: -0.04em;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.tx-donut-label {
    font-size: 13px;
    opacity: 0.7;
    margin-top: 8px;
    max-width: 160px;
}

/* ============ SUPPORTING CHIPS (under any visual) ============ */
.tx-supporting-chips {
    display: flex; flex-wrap: wrap; gap: 12px;
    margin-top: 24px;
}
.tx-chip {
    display: flex; flex-direction: column; gap: 2px;
    padding: 12px 16px;
    background: rgba(255,255,255,0.6);
    backdrop-filter: blur(10px);
    border: 1px solid rgba(0,0,0,0.06);
    border-radius: 12px;
    transition: all 0.3s;
}
.tx-section--dark .tx-chip {
    background: rgba(255,255,255,0.04);
    border-color: rgba(255,255,255,0.08);
}
.tx-chip:hover {
    transform: translateY(-2px);
    border-color: var(--tx-primary);
}
.tx-chip-value {
    font-size: 22px; font-weight: 800;
    color: var(--tx-primary);
    letter-spacing: -0.02em;
}
.tx-chip-label {
    font-size: 12px;
    opacity: 0.7;
    letter-spacing: 0.02em;
}
.tx-benefit-list { display: flex; flex-direction: column; gap: 14px; margin-top: 32px; }
.tx-benefit { display: flex; gap: 14px; align-items: flex-start; }
.tx-benefit-icon {
    width: 36px; height: 36px; flex-shrink: 0;
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    background: rgba(255,111,44,0.1); color: var(--tx-primary); font-size: 18px;
}
.tx-benefit-text { font-size: 16px; line-height: 1.5; padding-top: 6px; }

/* ============ FEATURES GRID ============ */
.tx-features-head { text-align: center; max-width: 720px; margin: 0 auto 60px; }
.tx-features {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 20px;
}
@media (max-width: 1100px) { .tx-features { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tx-features { grid-template-columns: 1fr; } }
.tx-fcard {
    position: relative; padding: 32px 28px;
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 20px; transition: all 0.4s ease;
    overflow: hidden;
}
.tx-fcard::before {
    content: attr(data-num); position: absolute; top: 16px; right: 24px;
    font-size: 14px; font-weight: 700; color: var(--tx-dim);
    letter-spacing: 0.1em;
}
.tx-fcard:hover {
    border-color: var(--tx-border-hover); transform: translateY(-4px);
    box-shadow: 0 20px 40px rgba(255,111,44,0.1);
}
.tx-fcard-icon {
    font-size: 36px; margin-bottom: 20px; display: block;
    width: 64px; height: 64px;
    background: linear-gradient(135deg, rgba(255,111,44,0.15), rgba(255,111,44,0.05));
    border: 1px solid rgba(255,111,44,0.2);
    border-radius: 16px; display: flex; align-items: center; justify-content: center;
}
.tx-fcard h3 {
    font-size: 19px; font-weight: 700; margin: 0 0 10px;
    color: #fff; letter-spacing: -0.01em;
}
.tx-fcard p {
    font-size: 14px; line-height: 1.6; margin: 0;
    color: var(--tx-muted);
}

/* ============ PROCESS STEPS ============ */
.tx-process-head { text-align: center; max-width: 720px; margin: 0 auto 60px; }
.tx-process {
    display: grid; grid-template-columns: repeat(5, 1fr);
    gap: 16px;
}
@media (max-width: 1100px) { .tx-process { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tx-process { grid-template-columns: 1fr; } }
.tx-step {
    background: #fff; border-radius: 20px; padding: 28px 24px;
    border: 1px solid #e5e5e5; transition: all 0.3s;
}
.tx-step:hover {
    border-color: var(--tx-primary); transform: translateY(-4px);
    box-shadow: 0 16px 32px rgba(0,0,0,0.08);
}
.tx-step-num {
    font-size: 56px; font-weight: 900; line-height: 1;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    margin-bottom: 8px; letter-spacing: -0.04em;
}
.tx-step-dur {
    font-size: 13px; color: var(--tx-dim); font-weight: 600;
    margin-bottom: 16px; letter-spacing: 0.05em;
}
.tx-step h3 {
    font-size: 17px; font-weight: 700; margin: 0 0 10px;
    color: #0a0a0a; letter-spacing: -0.01em;
}
.tx-step p {
    font-size: 13px; line-height: 1.55; color: #666; margin: 0;
}
.tx-step-result {
    margin-top: 16px; padding-top: 14px; border-top: 1px dashed #e5e5e5;
    display: flex; flex-direction: column; gap: 4px;
}
.tx-step-result strong {
    font-size: 11px; color: var(--tx-primary);
    letter-spacing: 0.1em; text-transform: uppercase;
}
.tx-step-result span { font-size: 13px; color: #0a0a0a; font-weight: 600; }

/* ============ PRICING TRACKS ============ */
.tx-tracks {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 24px;
}
@media (max-width: 968px) { .tx-tracks { grid-template-columns: 1fr; } }
.tx-track {
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 24px; padding: 36px 32px;
    display: flex; flex-direction: column;
    transition: all 0.4s; position: relative; overflow: hidden;
}
.tx-track--featured {
    border-color: var(--tx-primary);
    background: linear-gradient(145deg, var(--tx-card), rgba(255,111,44,0.05));
}
.tx-track--featured::before {
    content: '⭐ Препоръчано'; position: absolute; top: 16px; right: 16px;
    background: var(--tx-primary); color: #fff;
    padding: 6px 14px; border-radius: 999px;
    font-size: 11px; font-weight: 700; letter-spacing: 0.05em;
}
.tx-track:hover {
    border-color: var(--tx-primary); transform: translateY(-6px);
    box-shadow: 0 24px 48px rgba(255,111,44,0.15);
}
.tx-track-tag {
    display: inline-block; padding: 6px 14px;
    background: rgba(255,111,44,0.1); color: var(--tx-primary);
    border-radius: 999px; font-size: 12px; font-weight: 600;
    letter-spacing: 0.05em; margin-bottom: 16px; align-self: flex-start;
}
.tx-track-name {
    font-size: 24px; font-weight: 700; color: #fff;
    margin: 0 0 12px; letter-spacing: -0.01em;
}
.tx-track-desc {
    color: var(--tx-muted); font-size: 14px; line-height: 1.55;
    margin: 0 0 24px;
}
.tx-track-features {
    list-style: none; padding: 0; margin: 0 0 24px;
    display: flex; flex-direction: column; gap: 10px; flex-grow: 1;
}
.tx-track-features li {
    color: #fff; font-size: 14px; padding-left: 24px; position: relative;
}
.tx-track-features li::before {
    content: '✓'; position: absolute; left: 0; top: 0;
    color: var(--tx-primary); font-weight: 700;
}
.tx-track-price {
    font-size: 22px; font-weight: 700; color: var(--tx-primary);
    margin: 0 0 20px; letter-spacing: -0.01em;
}

/* ============ REVIEWS GRID ============ */
.tx-reviews {
    display: grid; grid-template-columns: repeat(2, 1fr);
    gap: 24px;
}
@media (max-width: 968px) { .tx-reviews { grid-template-columns: 1fr; } }
.tx-review {
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 24px; padding: 36px;
    transition: all 0.3s;
}
.tx-review:hover {
    border-color: var(--tx-border-hover);
    transform: translateY(-2px);
}
.tx-quote {
    font-size: 17px; line-height: 1.6; color: #fff;
    margin: 0 0 24px; position: relative;
}
.tx-quote::before {
    content: '"'; font-size: 60px; color: var(--tx-primary);
    line-height: 0; margin-right: 4px; vertical-align: -16px;
    font-family: Georgia, serif;
}
.tx-author { display: flex; align-items: center; gap: 14px; margin-top: auto; }
.tx-avatar {
    width: 48px; height: 48px; border-radius: 50%;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    color: #fff; display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 16px;
}
.tx-author-name {
    display: block; color: #fff; font-weight: 700; font-size: 15px;
}
.tx-author-role {
    display: block; color: var(--tx-muted); font-size: 13px;
}

/* ============ PILLS ============ */
.tx-pills {
    display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
    max-width: 900px; margin: 0 auto;
}
.tx-pill {
    padding: 12px 22px; background: #fff;
    border: 1px solid #e5e5e5; border-radius: 999px;
    font-size: 14px; font-weight: 500; color: #0a0a0a;
    transition: all 0.3s;
}
.tx-pill:hover {
    border-color: var(--tx-primary); color: var(--tx-primary);
    transform: translateY(-2px);
}

/* ============ FINAL CTA ============ */
.tx-final {
    padding: 120px 0; background: var(--tx-bg-dark);
    color: #fff; position: relative; overflow: hidden; text-align: center;
}
.tx-final::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(circle at 50% 50%, rgba(255,111,44,0.1), transparent 60%);
    pointer-events: none;
}
.tx-final-inner { max-width: 720px; margin: 0 auto; padding: 0 24px; position: relative; z-index: 1; }
.tx-final h2 { font-size: clamp(36px, 5vw, 64px); margin-bottom: 20px; }
.tx-final p { color: var(--tx-muted); font-size: 18px; margin-bottom: 36px; }
.tx-final-actions {
    display: flex; gap: 16px; justify-content: center; flex-wrap: wrap;
    margin-bottom: 36px;
}
.tx-final-meta {
    display: flex; gap: 32px; justify-content: center; flex-wrap: wrap;
    color: var(--tx-muted); font-size: 14px;
}
.tx-final-meta strong { color: #fff; }

/* ============ RELATED GRID ============ */
.tx-related {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
@media (max-width: 1100px) { .tx-related { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .tx-related { grid-template-columns: 1fr; } }
.tx-rel-card {
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 20px; padding: 32px 24px; text-align: center;
    text-decoration: none; transition: all 0.3s; display: block;
}
.tx-rel-card:hover {
    border-color: var(--tx-primary); transform: translateY(-4px);
    background: linear-gradient(145deg, var(--tx-card), rgba(255,111,44,0.08));
}
.tx-rel-icon {
    font-size: 36px; margin-bottom: 16px;
    width: 64px; height: 64px; margin: 0 auto 16px;
    background: rgba(255,111,44,0.1); border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
}
.tx-rel-card h4 {
    font-size: 16px; font-weight: 700; color: #fff;
    margin: 0 0 8px;
}
.tx-rel-link { color: var(--tx-primary); font-size: 13px; font-weight: 600; }

/* ============ FAQ ACCORDION ============ */
.tx-faq { display: flex; flex-direction: column; gap: 12px; margin-top: 40px; }
.tx-faq-item {
    background: rgba(255,255,255,0.03);
    border: 1px solid var(--tx-border);
    border-radius: 16px; padding: 0;
    transition: all 0.3s;
}
.tx-section--light .tx-faq-item { background: #fff; border-color: #e5e5e5; }
.tx-faq-item[open] { border-color: var(--tx-primary); background: rgba(255,111,44,0.04); }
.tx-faq-q {
    cursor: pointer; padding: 24px 28px;
    font-size: 17px; font-weight: 600;
    display: flex; justify-content: space-between; align-items: center;
    list-style: none; outline: none;
}
.tx-faq-q::-webkit-details-marker { display: none; }
.tx-faq-icon {
    width: 32px; height: 32px; border-radius: 50%;
    background: rgba(255,111,44,0.15); color: var(--tx-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: 20px; font-weight: 700;
    transition: transform 0.3s;
}
.tx-faq-item[open] .tx-faq-icon {
    transform: rotate(45deg); background: var(--tx-primary); color: #fff;
}
.tx-faq-a {
    padding: 0 28px 24px; font-size: 15px; line-height: 1.7;
    opacity: 0.85; max-width: 720px;
}

/* ============ STATS ROW ============ */
.tx-stats-row {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 40px; margin-top: 64px;
    max-width: 1100px; margin-inline: auto;
}
.tx-stat-item {
    text-align: center;
    padding: 24px 16px;
    display: flex; flex-direction: column;
    align-items: center; gap: 8px;
    border-left: 1px solid rgba(255,255,255,0.06);
}
.tx-stat-item:first-child { border-left: none; }
.tx-section--light .tx-stat-item { border-left-color: rgba(0,0,0,0.08); }
@media (max-width: 768px) {
    .tx-stat-item { border-left: none; border-top: 1px solid rgba(255,255,255,0.06); padding-top: 32px; }
    .tx-stat-item:first-child { border-top: none; padding-top: 0; }
}
.tx-stat-big {
    font-size: clamp(36px, 4.5vw, 64px); font-weight: 800;
    line-height: 1.05; letter-spacing: -0.03em;
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    background-clip: text;
    margin-bottom: 4px;
    display: inline-flex; align-items: baseline; gap: 2px;
    white-space: nowrap;
}
.tx-stat-affix {
    font-size: 0.55em;
    font-weight: 700;
    opacity: 0.9;
}
.tx-stat-item-label {
    font-size: 14px; font-weight: 500; opacity: 0.7;
    letter-spacing: 0.01em;
    line-height: 1.4;
    max-width: 200px;
}

/* ============ BENTO GRID ============ */
.tx-bento {
    display: grid; grid-template-columns: repeat(4, 1fr);
    grid-auto-rows: 220px;
    gap: 16px; margin-top: 60px;
}
.tx-bento-card {
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 24px; padding: 32px;
    transition: all 0.4s;
    display: flex; flex-direction: column;
    overflow: hidden; position: relative;
}
.tx-bento-card::after {
    content: ''; position: absolute; top: -50%; left: -50%;
    width: 200%; height: 200%;
    background: radial-gradient(circle, rgba(255,111,44,0.1), transparent 50%);
    opacity: 0; transition: opacity 0.4s;
    pointer-events: none;
}
.tx-bento-card:hover {
    border-color: var(--tx-border-hover); transform: translateY(-4px);
}
.tx-bento-card:hover::after { opacity: 1; }
.tx-bento-card--highlight {
    background: linear-gradient(135deg, var(--tx-primary), var(--tx-primary-2));
    color: #fff; border-color: transparent;
}
.tx-bento-card--highlight .tx-bento-icon { filter: brightness(0) invert(1); }
.tx-bento-card--highlight .tx-bento-desc { opacity: 0.9; }
.tx-bento--sm { grid-column: span 1; }
.tx-bento--md { grid-column: span 2; }
.tx-bento--lg { grid-column: span 2; grid-row: span 1; }
.tx-bento--xl { grid-column: span 2; grid-row: span 2; }
.tx-bento-icon {
    font-size: 40px; margin-bottom: 16px;
    width: 64px; height: 64px;
    background: linear-gradient(135deg, rgba(255,111,44,0.15), rgba(255,111,44,0.05));
    border-radius: 16px;
    display: flex; align-items: center; justify-content: center;
}
.tx-bento-title {
    font-size: 20px; font-weight: 700; margin: 0 0 12px;
    color: inherit; letter-spacing: -0.01em;
}
.tx-bento-desc {
    font-size: 14px; line-height: 1.55; margin: 0; flex-grow: 1;
    color: var(--tx-muted);
}
.tx-bento-card--highlight .tx-bento-desc { color: rgba(255,255,255,0.9); }
.tx-bento-card--highlight .tx-bento-title { color: #fff; }
@media (max-width: 968px) {
    .tx-bento { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 200px; }
    .tx-bento--lg, .tx-bento--xl, .tx-bento--md { grid-column: span 2; grid-row: span 1; }
    .tx-bento--sm { grid-column: span 1; }
}

/* ============ TABS SHOWCASE ============ */
.tx-tabs-container { margin-top: 60px; }
.tx-tabs-nav {
    display: flex; gap: 8px; margin-bottom: 32px;
    background: var(--tx-card); padding: 8px;
    border-radius: 999px; border: 1px solid var(--tx-border);
    flex-wrap: wrap; justify-content: center;
}
.tx-tab-btn {
    padding: 12px 24px; background: transparent; border: none;
    color: var(--tx-muted); font-size: 15px; font-weight: 600;
    border-radius: 999px; cursor: pointer; transition: all 0.3s;
}
.tx-tab-btn:hover { color: #fff; }
.tx-tab-btn.is-active {
    background: var(--tx-primary); color: #fff;
}
.tx-tab-panel { display: none; }
.tx-tab-panel.is-active { display: block; animation: tx-fade-in 0.4s; }
@keyframes tx-fade-in { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.tx-tab-grid {
    display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px;
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 24px; padding: 48px; align-items: start;
}
@media (max-width: 968px) { .tx-tab-grid { grid-template-columns: 1fr; gap: 32px; padding: 32px; } }
.tx-tab-title {
    font-size: clamp(28px, 3.5vw, 40px); font-weight: 700;
    color: #fff; margin: 12px 0 16px; letter-spacing: -0.02em;
}
.tx-tab-desc { font-size: 16px; line-height: 1.65; color: var(--tx-muted); margin: 0 0 28px; }
.tx-tab-features {
    list-style: none; padding: 0; margin: 0;
    display: flex; flex-direction: column; gap: 12px;
}
.tx-tab-features li {
    color: #fff; font-size: 15px; padding-left: 32px; position: relative;
    padding-top: 4px; padding-bottom: 4px;
}
.tx-tab-features li::before {
    content: '✓'; position: absolute; left: 0; top: 4px;
    width: 24px; height: 24px; border-radius: 50%;
    background: rgba(255,111,44,0.15); color: var(--tx-primary);
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 700;
}

/* ============ HERO CENTERED ============ */
.tx-hero-centered {
    background: var(--tx-bg-dark); color: #fff;
    padding: 160px 0 120px; text-align: center;
    position: relative; overflow: hidden;
}
.tx-hero-centered::before {
    content: ''; position: absolute; inset: 0;
    background: radial-gradient(circle at 50% 100%, rgba(255,111,44,0.2), transparent 60%);
    pointer-events: none;
}
.tx-hero-centered-inner {
    max-width: 900px; margin: 0 auto;
    position: relative; z-index: 1;
}
.tx-h1--massive {
    font-size: clamp(48px, 9vw, 120px); line-height: 0.95;
    margin: 20px 0 28px;
}
.tx-lead--center {
    margin: 0 auto 36px; max-width: 720px;
}
.tx-hero-centered-actions {
    display: flex; gap: 14px; justify-content: center;
    margin-bottom: 36px; flex-wrap: wrap;
}

/* ============ COMPARE ============ */
.tx-compare {
    margin-top: 60px;
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 24px; overflow: hidden;
}
.tx-compare-row {
    display: grid; grid-template-columns: 1fr 1fr;
    border-bottom: 1px solid var(--tx-border);
}
.tx-compare-row:last-child { border-bottom: none; }
.tx-compare-head .tx-compare-cell {
    font-weight: 700; font-size: 18px; padding: 24px 32px;
}
.tx-compare-cell {
    padding: 20px 32px; display: flex; align-items: center; gap: 14px;
    font-size: 15px; line-height: 1.5;
}
.tx-compare-cell--bad {
    background: rgba(239,68,68,0.05); color: var(--tx-muted);
}
.tx-compare-cell--good {
    background: rgba(34,197,94,0.05); color: #fff; font-weight: 500;
}
.tx-compare-mark {
    width: 28px; height: 28px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; flex-shrink: 0;
}
.tx-compare-cell--bad .tx-compare-mark {
    background: rgba(239,68,68,0.2); color: #ef4444;
}
.tx-compare-cell--good .tx-compare-mark {
    background: rgba(34,197,94,0.2); color: #22c55e;
}
@media (max-width: 768px) {
    .tx-compare-row { grid-template-columns: 1fr; }
    .tx-compare-row:not(.tx-compare-head) > div:first-child { border-bottom: 1px solid var(--tx-border); }
}

/* ============ CHECKLIST ============ */
.tx-checklist {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 20px; margin-top: 60px;
}
.tx-check-card {
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 20px; padding: 28px; transition: all 0.3s;
}
.tx-section--light .tx-check-card { background: #fff; border-color: #e5e5e5; }
.tx-check-card:hover {
    border-color: var(--tx-border-hover); transform: translateY(-2px);
}
.tx-check-icon {
    font-size: 32px; margin-bottom: 12px;
    width: 56px; height: 56px;
    background: linear-gradient(135deg, rgba(255,111,44,0.15), rgba(255,111,44,0.05));
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
}
.tx-check-title {
    font-size: 17px; font-weight: 700; margin: 0 0 16px;
    color: inherit; letter-spacing: -0.01em;
}
.tx-check-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.tx-check-list li {
    font-size: 14px; line-height: 1.5; padding-left: 22px;
    position: relative; color: inherit; opacity: 0.85;
}
.tx-check-list li::before {
    content: '✓'; position: absolute; left: 0; top: 0;
    color: var(--tx-primary); font-weight: 700;
}

/* ============ DELIVERABLES ============ */
.tx-deliverables {
    display: grid; grid-template-columns: repeat(4, 1fr);
    gap: 16px; margin-top: 60px;
}
@media (max-width: 968px) { .tx-deliverables { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .tx-deliverables { grid-template-columns: 1fr; } }
.tx-delivery-card {
    background: var(--tx-card); border: 1px solid var(--tx-border);
    border-radius: 16px; padding: 24px; transition: all 0.3s;
    display: flex; gap: 14px; align-items: flex-start;
}
.tx-section--light .tx-delivery-card { background: #fff; border-color: #e5e5e5; }
.tx-delivery-card:hover {
    border-color: var(--tx-border-hover); transform: translateY(-2px);
}
.tx-delivery-icon {
    font-size: 28px; flex-shrink: 0;
    width: 48px; height: 48px;
    background: rgba(255,111,44,0.1); border-radius: 12px;
    display: flex; align-items: center; justify-content: center;
}
.tx-delivery-title {
    font-size: 15px; font-weight: 700; margin: 0 0 4px; color: inherit;
}
.tx-delivery-desc {
    font-size: 13px; line-height: 1.5; margin: 0;
    color: inherit; opacity: 0.7;
}

/* ============ ANIMATIONS (v3.0.0 GSAP-powered) ============ */

/* Split text — words wrapped for vertical reveal */
.tx-word { display: inline-block; overflow: hidden; vertical-align: top; }
.tx-word-inner { display: inline-block; }

/* Cards — initial state for tilt prep */
.tx-fcard, .tx-bento-card, .tx-track, .tx-rel-card {
    transform-style: preserve-3d;
    will-change: transform;
}

/* Reduced motion preference */
@media (prefers-reduced-motion: reduce) {
    [data-tx-anim], .tx-word-inner { opacity: 1 !important; transform: none !important; }
    .tx-marquee-row { animation: none !important; }
}

/* Lenis smooth scroll body modifier */
html.lenis { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: hidden; }
.lenis.lenis-scrolling iframe { pointer-events: none; }
