/* ============================================================ 
TESTIMONIALS PAGE — scoped .tt-* styles Palette: Navy #09102e · Green #7ACC0D · Light green #c5f07a ============================================================ */
 .page-testimonials { overflow-x: clip; background: #fff; color: #09102e; } 
 .tt-eyebrow { display: inline-flex; align-items: center; gap: 10px; padding: 7px 18px; border-radius: 999px; background: rgba(122, 204, 13, 0.14); border: 1px solid rgba(122, 204, 13, 0.4); color: #568f00; font-size: 11.5px; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase; margin-bottom: 20px; } 
 .tt-eyebrow-light { background: rgba(122, 204, 13, 0.18); border-color: rgba(122, 204, 13, 0.5); color: #c5f07a; } 
 .tt-dot { width: 6px; height: 6px; background: #7ACC0D; border-radius: 50%; box-shadow: 0 0 10px #7ACC0D; } 


/* ---------- HERO ---------- */ 
.tt-hero { position: relative; padding: var(--sec-py-lg, 120px) 0; background: linear-gradient(180deg, rgba(9,16,46,0.86) 0%, rgba(10,20,58,0.78) 50%, rgba(9,16,46,0.92) 100%), url('../images/banners/collage-customer-experience-concept.jpg') center / cover no-repeat; color: #fff; overflow: hidden; isolation: isolate; } .tt-hero-bg { position: absolute; inset: 0; background: radial-gradient(700px 460px at 20% 20%, rgba(122, 204, 13, 0.28), transparent 60%), radial-gradient(600px 420px at 85% 80%, rgba(80, 120, 255, 0.18), transparent 60%); pointer-events: none; z-index: 0; } 
.tt-hero-mark { position: absolute; top: 40px; left: 50%; transform: translateX(-50%); font-family: 'Fraunces', Georgia, serif; font-weight: 800; font-size: clamp(220px, 30vw, 360px); line-height: 1; color: transparent; -webkit-text-stroke: 1.5px rgba(122, 204, 13, 0.14); pointer-events: none; user-select: none; z-index: 0; } .tt-hero > .container { position: relative; z-index: 2; text-align: center; } 
.tt-hero-title { font-family: 'Fraunces', 'Inter', serif; font-weight: 800; font-size: clamp(30px, 5.2vw, 72px); line-height: 1.2; letter-spacing: -0.025em; color: #fff; margin: 0 auto 20px; max-width: 880px; } 
.tt-hero-title em { font-style: italic; background: linear-gradient(90deg, #c5f07a 0%, #7ACC0D 60%, #ffffff 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; } 
.tt-hero-sub { font-size: 17.5px; line-height: 1.7; color: rgba(255, 255, 255, 0.78); max-width: 640px; margin: 0 auto 38px; } 
.tt-hero-badges { display: inline-flex; align-items: center; gap: 24px; flex-wrap: wrap; justify-content: center; padding: 14px 22px; background: rgba(255, 255, 255, 0.05); border: 1px solid rgba(122, 204, 13, 0.22); border-radius: 999px; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px); } 
.tt-hero-badge { display: inline-flex; align-items: center; gap: 8px; color: rgba(255, 255, 255, 0.85); font-size: 13.5px; font-weight: 600; } 
.tt-hero-badge strong { color: #c5f07a; font-weight: 800; }
.tt-hero-badge i { color: #c5f07a; font-size: 15px; }



/* ---------- STATS STRIP (green band) ---------- */ 
.tt-stats { background: #7ACC0D; padding: 36px 0; position: relative; } 
.tt-stats::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, transparent 0%, rgba(9, 16, 46, 0.35) 50%, transparent 100%); } 
.tt-stats-row { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(4, 1fr); } 
.tt-stat { text-align: center; padding: 6px 24px; border-right: 1px solid rgba(9, 16, 46, 0.16); } 
.tt-stat:last-child { border-right: 0; }
.tt-stat-num { display: block; font-family: 'Fraunces', 'Publico Banner', serif; font-weight: 800; font-size: clamp(34px, 4.2vw, 52px); line-height: 1; color: #09102e; letter-spacing: -0.03em; margin-bottom: 6px; } 
.tt-stat-num small { font-size: 0.55em; color: #09102e; font-weight: 700; margin-left: 2px; } 
.tt-stat-label { display: block; font-size: 13px; font-weight: 600; color: rgba(9, 16, 46, 0.78); letter-spacing: 0.04em; } 

@media (max-width: 767px) { 
.tt-stats-row { grid-template-columns: repeat(2, 1fr); } 
.tt-stat { padding: 10px 14px; } 
.tt-stat:nth-child(2) { border-right: 0; }
.tt-hero-badges {
    border-radius: 120px / 210px;
}
.tt-hero-sub {
    font-size: 16px;
    margin: 0 auto 28px;
}



} 

/* ---------- FEATURED TESTIMONIAL ---------- */ 
.tt-featured { padding: var(--sec-py-lg, 120px) 0; background: #ffffff; }
.tt-featured-card { position: relative; display: grid; grid-template-columns: 340px 1fr; gap: 44px; align-items: center; max-width: 1080px; margin: 0 auto; padding: 44px; background: linear-gradient(160deg, #fbfaf5 0%, #ffffff 100%); border: 1px solid rgba(122, 204, 13, 0.25); border-radius: 24px; box-shadow: 0 30px 60px rgba(9, 16, 46, 0.08); } 
.tt-featured-card::before { content: "\201C"; position: absolute; top: 8px; right: 42px; font-family: 'Fraunces', serif; font-size: 200px; line-height: 1; color: rgba(122, 204, 13, 0.22); font-weight: 700; pointer-events: none; } 
.tt-featured-portrait { position: relative; aspect-ratio: 4 / 5; border-radius: 240px 240px 28px 28px; overflow: hidden; background: linear-gradient(160deg, #09102e 0%, #0a143a 100%); display: flex; align-items: center; justify-content: center; color: #c5f07a; font-family: 'Fraunces', serif; font-weight: 800; font-size: 120px; letter-spacing: -0.03em; text-shadow: 0 14px 30px rgba(0, 0, 0, 0.25); box-shadow: 0 30px 60px rgba(9, 16, 46, 0.28); }
.tt-featured-portrait img { width: 100%; height: 100%; object-fit: cover; display: block; } 
.tt-featured-body { position: relative; z-index: 2; }
.tt-featured-stars { display: inline-flex; gap: 3px; color: #F4C542; font-size: 16px; margin-bottom: 18px; } 
.tt-featured-quote { font-family: 'Fraunces', Georgia, serif; font-size: clamp(22px, 2.2vw, 28px); line-height: 1.45; color: #09102e; font-style: italic; margin: 0 0 24px; letter-spacing: -0.005em; }
.tt-featured-quote strong { color: #568f00; font-style: normal; font-family: 'Inter', sans-serif; font-weight: 800; }
.tt-featured-author { display: flex; align-items: center; gap: 14px; padding-top: 20px; border-top: 1px solid rgba(9, 16, 46, 0.1); } 
.tt-featured-author-meta { display: flex; flex-direction: column; gap: 2px; }
.tt-featured-author-meta strong { font-size: 16px; font-weight: 700; color: #09102e; letter-spacing: -0.005em; }
.tt-featured-author-meta span { font-size: 13px; color: #6a7090; }

@media (max-width: 991px) {
.tt-featured-card { grid-template-columns: 1fr; padding: 28px; gap: 28px; }
.tt-featured-portrait { max-width: 220px; margin: 0 auto; font-size: 78px; } 
.tt-featured-card::before { font-size: 140px; top: 0; right: 22px; } }



/* ---------- QUOTES GRID ---------- */
.tt-grid-section { padding: var(--sec-py-lg, 120px) 0; background: linear-gradient(180deg, rgba(9, 16, 46, 0.72) 0%, rgba(9, 16, 46, 0.88) 100%), url('../images/rm251.webp') center center / cover no-repeat, #09102e; background-attachment: fixed, fixed, scroll; position: relative; overflow: hidden; isolation: isolate; } 
.tt-grid-section::before { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255, 255, 255, 0.06) 1px, transparent 1.4px); background-size: 26px 26px; mask-image: radial-gradient(ellipse at center, #000 20%, transparent 75%); -webkit-mask-image: radial-gradient(ellipse at center, #000 20%, transparent 75%); pointer-events: none; z-index: 1; }
.tt-grid-section::after { content: ""; position: absolute; inset: 0; background: radial-gradient(600px 400px at 15% 10%, rgba(122, 204, 13, 0.12), transparent 65%), radial-gradient(500px 380px at 85% 95%, rgba(122, 204, 13, 0.08), transparent 60%); pointer-events: none; z-index: 1; } 
.tt-grid-section > .container { position: relative; z-index: 2; } 

/* Dark-scope head overrides */ 
.tt-grid-section .tt-head h2 { color: #ffffff; }
.tt-grid-section .tt-head h2 em { background: linear-gradient(90deg, #c5f07a 0%, #7ACC0D 60%, #ffffff 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; } 
.tt-grid-section .tt-head p { color: rgba(255, 255, 255, 0.7); }
.tt-grid-section .tt-eyebrow { background: rgba(122, 204, 13, 0.18); border-color: rgba(122, 204, 13, 0.5); color: #c5f07a; }
.tt-head { text-align: center; max-width: 720px; margin: 0 auto 56px; }
.tt-head h2 { font-family: 'Fraunces', 'Inter', serif; font-weight: 800; font-size: clamp(32px, 4vw, 52px); line-height: 1.06; letter-spacing: -0.02em; color: #09102e; margin: 0 0 14px; }
.tt-head h2 em { font-style: italic; background: linear-gradient(90deg, #7ACC0D 0%, #3d7c00 60%, #09102e 100%); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.tt-head p { color: #5b637a; font-size: 16px; line-height: 1.7; margin: 0; } 


/* Masonry-style grid via CSS columns — cards flow to available height */ 
.tt-grid { columns: 3 320px; column-gap: 22px; max-width: 1240px; margin: 0 auto; } 
.tt-card { position: relative; break-inside: avoid; -webkit-column-break-inside: avoid; page-break-inside: avoid; background: #ffffff; border: 1px solid rgba(255, 255, 255, 0.14); border-radius: 20px; padding: 34px 28px 24px; display: inline-block; width: 100%; margin: 0 0 22px; transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1), box-shadow 0.35s ease, border-color 0.35s ease; box-shadow: 0 20px 48px rgba(0, 0, 0, 0.28), 0 4px 12px rgba(0, 0, 0, 0.12); overflow: hidden; }
.tt-card::before { content: "\201C"; position: absolute; top: -6px; left: 20px; font-family: 'Fraunces', Georgia, serif; font-size: 88px; line-height: 1; color: rgba(122, 204, 13, 0.25); font-weight: 700; pointer-events: none; transition: color 0.35s ease, transform 0.35s ease; } 
.tt-card:hover { transform: translateY(-6px); border-color: rgba(122, 204, 13, 0.6); box-shadow: 0 36px 70px rgba(0, 0, 0, 0.38), 0 0 0 1px rgba(122, 204, 13, 0.2); } 
.tt-card:hover::before { color: rgba(122, 204, 13, 0.55); transform: scale(1.08); } 
.tt-card-stars { color: #F4C542; font-size: 14px; letter-spacing: 2px; display: inline-flex; gap: 2px; margin-bottom: 14px; position: relative; z-index: 1; } 
.tt-card-quote { font-family: 'Fraunces', Georgia, serif; font-size: 15.5px; line-height: 1.62; color: #2a3353; margin: 0 0 20px; letter-spacing: -0.005em; position: relative; z-index: 1; } 
.tt-card-author { display: flex; align-items: center; gap: 12px; padding-top: 16px; border-top: 1px solid rgba(9, 16, 46, 0.08); }
.tt-card-avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, #09102e 0%, #1a2657 100%); color: #c5f07a; display: inline-flex; align-items: center; justify-content: center; font-family: 'Fraunces', serif; font-weight: 800; font-size: 14px; letter-spacing: 0.02em; flex-shrink: 0; box-shadow: 0 6px 14px rgba(9, 16, 46, 0.22); position: relative; overflow: hidden; } 
.tt-card-avatar img { width: 100%; height: 100%; object-fit: cover; } 
.tt-card-avatar::after { content: ""; position: absolute; bottom: -2px; right: -2px; width: 14px; height: 14px; border-radius: 50%; background: #7ACC0D; border: 2.5px solid #fff; }
.tt-card-meta { display: flex; flex-direction: column; line-height: 1.3; }
.tt-card-meta strong { font-size: 14.5px; font-weight: 700; color: #09102e; } 
.tt-card-meta span { font-size: 12.5px; color: #6a7090; margin-top: 2px; } 

@media (max-width: 991px) { 
.tt-grid { column-gap: 16px; }
.tt-card { padding: 30px 24px 22px; margin-bottom: 16px; } 

} 

/* ---------- PAGINATION ---------- */ 
.tt-pagination { display: flex; justify-content: center; align-items: center; flex-wrap: wrap; gap: 8px; margin: 56px auto 0; max-width: 1240px; position: relative; z-index: 2; } 
.tt-pagination a, .tt-pagination span { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px; padding: 0 14px; border-radius: 999px; font-family: 'Inter', sans-serif; font-weight: 700; font-size: 14px; letter-spacing: 0.02em; text-decoration: none; border: 1px solid rgba(255, 255, 255, 0.16); background: rgba(255, 255, 255, 0.05); color: rgba(255, 255, 255, 0.82); transition: transform 0.22s, background 0.22s, border-color 0.22s, color 0.22s, box-shadow 0.22s; backdrop-filter: blur(8px); } 
.tt-pagination a:hover { transform: translateY(-2px); background: rgba(122, 204, 13, 0.18); border-color: rgba(122, 204, 13, 0.55); color: #c5f07a; box-shadow: 0 14px 30px rgba(0, 0, 0, 0.25); }
.tt-pagination .current { background: linear-gradient(135deg, #7ACC0D 0%, #68b10a 100%); border-color: transparent; color: #09102e; box-shadow: 0 14px 32px rgba(122, 204, 13, 0.35); }
.tt-pagination .dots { background: transparent; border-color: transparent; color: rgba(255, 255, 255, 0.45); min-width: 30px; padding: 0 4px; } 
.tt-pagination .prev, .tt-pagination .next { padding: 0 18px; font-size: 13px; text-transform: uppercase; letter-spacing: 0.12em; } 

@media (max-width: 767px) {
.tt-pagination {
    margin: 15px auto 0;
}




}

@media (max-width: 575px) { 
.tt-pagination a, .tt-pagination span { min-width: 36px; height: 36px; font-size: 13px; padding: 0 10px; }
.tt-pagination .prev, .tt-pagination .next { padding: 0 14px; }

}