@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,opsz,wght@0,6..30,300..800;1,6..30,300..800&family=Inter:wght@300;400;500;600&display=swap');

@tailwind base;
@tailwind components;
@tailwind utilities;

/* ─────────────────────────────────────
   CUSTOM PROPERTIES
───────────────────────────────────── */
:root {
  --color-navy:    #0B1F3A;
  --color-navy-950:#050C17;
  --color-electric:#2563EB;
  --color-emerald: #00E0A4;
  --color-neon:    #00E0A4;
  --color-gold:    #D4AF37;
  --color-slate:   #64748B;
  --color-white:   #FFFFFF;
  --radius-premium: 1.5rem;
  --font-heading: 'Plus Jakarta Sans', sans-serif;
  --font-body: 'Inter', sans-serif;
}

/* ─────────────────────────────────────
   TEXTURES & OVERLAYS
───────────────────────────────────── */
.bg-noise {
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity: 0.05;
  pointer-events: none;
}

.bg-mesh {
  background-color: var(--color-navy-950);
  background-image: 
    radial-gradient(at 0% 0%, rgba(37,99,235,0.15) 0px, transparent 50%),
    radial-gradient(at 100% 0%, rgba(16,185,129,0.1) 0px, transparent 50%),
    radial-gradient(at 100% 100%, rgba(37,99,235,0.1) 0px, transparent 50%),
    radial-gradient(at 0% 100%, rgba(212,175,55,0.05) 0px, transparent 50%);
}

.bg-tech-grid { 
  background-image: radial-gradient(circle, rgba(255,255,255,0.02) 1px, transparent 1px); 
  background-size: 40px 40px;
}

.bg-tech-grid-dark { 
  background-image: radial-gradient(circle, rgba(0,0,0,0.02) 1px, transparent 1px); 
  background-size: 40px 40px;
}

.fog-transition {
  background: linear-gradient(to bottom, var(--color-navy-950) 0%, #ffffff 100%);
}

/* ─────────────────────────────────────
   BASE
───────────────────────────────────── */
html { -webkit-font-smoothing: antialiased; }
/* NOTE: scroll-behavior:smooth removed — Lenis owns smooth scroll */

body {
  font-family: 'Plus Jakarta Sans', ui-sans-serif, system-ui;
  color: #1a202c;
  background: #ffffff;
}

::selection { background: #2563EB; color: white; }
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: #f1f5f9; }
::-webkit-scrollbar-thumb { background: #2563EB; border-radius: 3px; }

/* ─────────────────────────────────────
   HERO
───────────────────────────────────── */
.hero-gradient {
  background: linear-gradient(135deg, #0A1628 0%, #0f2550 45%, #0A1628 100%);
}
.hero-glow {
  background: radial-gradient(ellipse at 50% 0%, rgba(37,99,235,0.25) 0%, transparent 70%);
}
.cta-gradient {
  background: linear-gradient(135deg, #2563EB 0%, #10B981 100%);
}
.gradient-text {
  background: linear-gradient(135deg, #2563EB, #00C896);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.bg-navy-gradient {
    background: linear-gradient(135deg, #0B1F3A 0%, #081424 100%);
}

/* ─────────────────────────────────────
   SHADOW UTILITIES
───────────────────────────────────── */
.shadow-card       { box-shadow: 0 4px 20px rgba(10,22,40,0.08); }
.shadow-card-hover { box-shadow: 0 12px 40px rgba(37,99,235,0.15); }
.shadow-glow       { box-shadow: 0 0 30px rgba(37,99,235,0.3); }
.shadow-glow-green { box-shadow: 0 0 50px rgba(0,224,164,0.5); }
.shadow-neon       { box-shadow: 0 0 20px rgba(0,224,164,0.3); }

/* Deep Depth Layering */
.shadow-premium {
    box-shadow: 
        0 10px 15px -3px rgba(0, 0, 0, 0.4), 
        0 4px 6px -2px rgba(0, 0, 0, 0.2),
        inset 0 1px 1px rgba(255, 255, 255, 0.05);
}

.shadow-premium-hover {
    box-shadow: 
        0 20px 25px -5px rgba(0, 0, 0, 0.5), 
        0 10px 10px -5px rgba(0, 0, 0, 0.3),
        inset 0 1px 1px rgba(255, 255, 255, 0.1);
}

.rounded-premium {
    border-radius: var(--radius-premium);
}

/* ─────────────────────────────────────
   ANIMATION HELPERS (GSAP)
───────────────────────────────────── */
.anim-reveal {
    overflow: hidden;
    display: inline-block;
}
.anim-reveal > * {
    display: inline-block;
    transform: translateY(105%);
}

.anim-fade-up {
    opacity: 0;
    transform: translateY(30px);
}

/* ─────────────────────────────────────
   BUTTONS
───────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: #2563EB;
  color: white;
  font-weight: 600;
  font-size: 0.9375rem;
  border-radius: 0.75rem;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s ease;
  box-shadow: 0 4px 14px rgba(37,99,235,0.3);
}
.btn-primary:hover {
  background: #1D4ED8;
  transform: translateY(-2px);
  box-shadow: 0 0 30px rgba(37,99,235,0.4);
}
.btn-primary:active { transform: translateY(0); }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: white;
  color: #0A1628;
  font-weight: 600;
  font-size: 0.9375rem;
  border-radius: 0.75rem;
  border: 2px solid #e2e8f0;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s ease;
}
.btn-secondary:hover {
  border-color: #2563EB;
  color: #2563EB;
  transform: translateY(-2px);
}

.btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  background: transparent;
  color: #2563EB;
  font-weight: 600;
  border-radius: 0.75rem;
  border: 2px solid #2563EB;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s ease;
}
.btn-outline:hover { background: #2563EB; color: white; }

.btn-lg { padding: 1rem 2rem; font-size: 1.0625rem; border-radius: 1rem; }
.btn-sm { padding: 0.5rem 1rem; font-size: 0.875rem; border-radius: 0.625rem; }

/* ─────────────────────────────────────
   CARDS
───────────────────────────────────── */
.card {
  background: white;
  border-radius: 1.25rem;
  border: 1px solid #f1f5f9;
  padding: 1.5rem;
  box-shadow: 0 4px 20px rgba(10,22,40,0.06);
  transition: all 0.3s ease;
}
.card:hover {
  box-shadow: 0 12px 40px rgba(37,99,235,0.12);
  transform: translateY(-4px);
}

.card-service {
  background: white;
  border-radius: 1.5rem;
  border: 1px solid #f1f5f9;
  padding: 1.75rem;
  box-shadow: 0 4px 20px rgba(10,22,40,0.04);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  cursor: pointer;
  display: block;
  text-decoration: none;
  color: inherit;
  position: relative;
  overflow: hidden;
}

.card-service::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(600px circle at var(--mouse-x) var(--mouse-y), rgba(37,99,235,0.06), transparent 40%);
  opacity: 0;
  transition: opacity 0.5s;
}

.card-service:hover::after {
  opacity: 1;
}

.card-service:hover {
  box-shadow: 0 20px 40px rgba(10,22,40,0.08);
  transform: translateY(-6px);
  border-color: #dbeafe;
}

.border-beam {
  position: relative;
  border-radius: inherit;
}
.border-beam::before {
  content: "";
  position: absolute;
  inset: -2px;
  background: linear-gradient(90deg, transparent, var(--color-electric), transparent);
  background-size: 200% 100%;
  animation: border-beam 4s infinite linear;
  border-radius: inherit;
  z-index: -1;
  opacity: 0;
  transition: opacity 0.3s;
}
.border-beam:hover::before {
  opacity: 0.4;
}

/* Elite Minimalist Infrastructure (EMI) */
.card-elite {
  @apply bg-white border border-slate-100 rounded-[2.5rem] transition-all duration-500;
  box-shadow: 
    0 1px 2px rgba(0,0,0,0.02),
    0 2px 4px rgba(0,0,0,0.02),
    0 4px 8px rgba(0,0,0,0.02),
    0 8px 16px rgba(0,0,0,0.02),
    0 16px 32px rgba(0,0,0,0.02);
}

.card-elite:hover {
  border-color: rgba(37, 99, 235, 0.3);
  box-shadow: 
    0 2px 4px rgba(37,99,235,0.03),
    0 4px 8px rgba(37,99,235,0.03),
    0 8px 16px rgba(37,99,235,0.03),
    0 16px 32px rgba(37,99,235,0.03),
    0 32px 64px rgba(37,99,235,0.03);
  transform: translateY(-4px);
}

.slot-minimal {
  @apply bg-slate-50 border border-slate-100/80 rounded-[2rem] transition-all;
}

.slot-minimal:hover {
  background-color: white;
  border-color: rgba(37, 99, 235, 0.2);
}

.text-expert {
  @apply tracking-tight leading-snug;
}

.shadow-soft {
  box-shadow: 0 10px 40px -10px rgba(10,22,40,0.05);
}

/* Vertical Rhythm & Spacing */
.section-full {
  @apply py-32 md:py-48;
}

.trust-strip {
  @apply py-8 bg-white border-y border-slate-100;
}

.bg-alternate {
  @apply bg-slate-50;
}

.badge-popular {
  @apply bg-electric text-white px-3 py-1 rounded-full text-[9px] font-black uppercase tracking-widest animate-pulse;
}

.badge-recommended {
  background-color: rgba(16, 185, 129, 0.1);
  color: #10B981;
  border: 1px solid rgba(16, 185, 129, 0.2);
  @apply px-3 py-1 rounded-full text-[9px] font-black uppercase tracking-widest;
}

.card-glass {
  background: rgba(255,255,255,0.1);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 1.5rem;
  border: 1px solid rgba(255,255,255,0.2);
  padding: 2rem;
}

.package-card {
  background: white;
  border-radius: 1.25rem;
  border: 2px solid #f1f5f9;
  padding: 2rem;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 20px rgba(10,22,40,0.06);
  transition: all 0.3s ease;
}
.package-card-popular {
  border-color: #2563EB;
  box-shadow: 0 0 30px rgba(37,99,235,0.2);
  transform: scale(1.03);
}

/* Premium Vertical List (White on Black) */
.list-premium {
    @apply border-t border-white/10 py-12 transition-all duration-500 cursor-pointer flex flex-col md:flex-row md:items-center justify-between;
}

.list-premium:hover {
    @apply pl-8 bg-white/5;
}

.list-premium .number {
    @apply text-white/20 text-4xl font-black transition-colors;
}

.list-premium:hover .number {
    @apply text-emerald;
}

.list-premium .label {
    @apply text-white text-3xl md:text-5xl font-black tracking-tighter transition-all;
}

.list-premium:hover .label {
    @apply translate-x-4;
}

/* Glass Card Enhanced */
.glass-panel {
    background: rgba(255, 255, 255, 0.03);
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.5);
}

.glass-panel:hover {
    border-color: rgba(0, 224, 164, 0.3);
    box-shadow: 0 0 40px rgba(0, 200, 150, 0.1);
}

/* ─────────────────────────────────────
   LAYOUT
───────────────────────────────────── */
.section { padding: 5rem 1rem; }
.container-main { max-width: 80rem; margin: 0 auto; padding: 0 1.5rem; }

.section-label {
  display: inline-block;
  font-size: 0.8125rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: #2563EB;
  margin-bottom: 0.75rem;
}
.section-title {
  font-size: clamp(1.875rem, 4vw, 3rem);
  font-weight: 800;
  color: #0A1628;
  line-height: 1.15;
}
.section-subtitle {
  font-size: 1.0625rem;
  color: #64748B;
  margin-top: 1rem;
  line-height: 1.7;
}

/* ─────────────────────────────────────
   NAVBAR
───────────────────────────────────── */
.nav-scrolled {
  background: rgba(255,255,255,0.97) !important;
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 20px rgba(10,22,40,0.1);
}

/* ─────────────────────────────────────
   BADGES
───────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  border-radius: 9999px;
  font-size: 0.75rem;
  font-weight: 600;
}
.badge-blue   { background: #dbeafe; color: #1d4ed8; }
.badge-green  { background: #d1fae5; color: #065f46; }
.badge-amber  { background: #fef3c7; color: #92400e; }
.badge-red    { background: #fee2e2; color: #991b1b; }
.badge-navy   { background: #0A1628; color: white; }
.badge-popular{ background: #2563EB; color: white; }

/* Status badges */
.status-pending      { display:inline-flex; align-items:center; padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:600; background:#fef3c7; color:#92400e; }
.status-in_progress  { display:inline-flex; align-items:center; padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:600; background:#dbeafe; color:#1d4ed8; }
.status-under_review { display:inline-flex; align-items:center; padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:600; background:#ede9fe; color:#5b21b6; }
.status-completed    { display:inline-flex; align-items:center; padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:600; background:#d1fae5; color:#065f46; }
.status-cancelled    { display:inline-flex; align-items:center; padding:.25rem .75rem; border-radius:9999px; font-size:.75rem; font-weight:600; background:#fee2e2; color:#991b1b; }

/* ─────────────────────────────────────
   FORM INPUTS
───────────────────────────────────── */
.input {
  width: 100%;
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  border: 1.5px solid #e2e8f0;
  background: white;
  color: #1e293b;
  font-size: 0.9375rem;
  transition: all 0.2s;
  outline: none;
}
.input:focus { border-color: #2563EB; box-shadow: 0 0 0 3px rgba(37,99,235,0.1); }
.input::placeholder { color: #94a3b8; }
.label { display: block; font-size: 0.875rem; font-weight: 600; color: #374151; margin-bottom: 0.375rem; }

/* ─────────────────────────────────────
   DASHBOARD SIDEBAR
───────────────────────────────────── */
.sidebar-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  border-radius: 0.75rem;
  color: #64748b;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.2s;
}
.sidebar-link:hover { background: #eff6ff; color: #2563EB; }
.sidebar-link-active { background: #eff6ff; color: #2563EB; font-weight: 600; }

/* ─────────────────────────────────────
   TIMELINE
───────────────────────────────────── */
.timeline-dot         { width:2.5rem; height:2.5rem; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; font-weight:700; font-size:.875rem; }
.timeline-dot-done    { background:#10B981; color:white; }
.timeline-dot-active  { background:#2563EB; color:white; box-shadow:0 0 0 4px rgba(37,99,235,0.2); }
.timeline-dot-pending { background:#f1f5f9; color:#94a3b8; }

/* ─────────────────────────────────────
   WHATSAPP FLOAT
───────────────────────────────────── */
.whatsapp-float {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 3.5rem;
  height: 3.5rem;
  background: #25D366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(37,211,102,0.4);
  transition: all 0.2s;
  z-index: 50;
  text-decoration: none;
}
.whatsapp-float:hover { background: #22c55e; transform: scale(1.1); }
.whatsapp-float svg { width: 1.75rem; height: 1.75rem; color: white; fill: white; }

/* ─────────────────────────────────────
   ANIMATIONS
───────────────────────────────────── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(30px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes fadeIn {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-16px); }
}
@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
@keyframes pulseSlow {
  0%, 100% { opacity: 1; }
  50%       { opacity: .5; }
}

.animate-fade-in-up  { animation: fadeInUp  0.6s ease-out both; }
.animate-fade-in     { animation: fadeIn    0.5s ease-out both; }
.animate-float       { animation: float     5s ease-in-out infinite; }
.animate-pulse-slow  { animation: pulseSlow 3s ease-in-out infinite; }

/* Accessibility Motion Gate */
/* Typography Reveal */
.reveal-text {
  display: block;
  transform: translateY(110%);
  transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-text.active {
  transform: translateY(0);
}

/* Perspective & Tilt */
.perspective-1000 {
  perspective: 1000px;
}

@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

.noise-overlay {
    position: fixed;
    inset: 0;
    width: 100%;
    height: 100%;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
    opacity: 0.02;
    pointer-events: none;
    z-index: 9999;
}

/* ─────────────────────────────────────
   PREMIUM COMPONENTS (AVANT-GARDE)
───────────────────────────────────── */
.section-label {
    display: block;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: 0.4em;
    color: #00E0A4;
    margin-bottom: 1.5rem;
}

.section-title {
    font-size: clamp(2.5rem, 5vw, 5rem);
    font-weight: 900;
    line-height: 0.95;
    letter-spacing: -0.05em;
    color: #0B1F3A;
    margin-bottom: 2rem;
}

.section-subtitle {
    font-size: 1.25rem;
    color: #64748b;
    font-weight: 500;
    line-height: 1.6;
}

.list-premium {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 3rem 0;
    border-bottom: 1px solid rgba(255,255,255,0.05);
    text-decoration: none;
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.list-premium .number {
    font-size: 1.25rem;
    font-weight: 900;
    color: rgba(255,255,255,0.1);
    font-family: monospace;
}

.list-premium .label {
    font-size: clamp(2rem, 4vw, 4rem);
    font-weight: 900;
    color: white;
    letter-spacing: -0.04em;
    margin-bottom: 0;
}

.list-premium:hover {
    padding-left: 2rem;
    background: rgba(255,255,255,0.02);
}

/* ─────────────────────────────────────
   DEV HELPERS
───────────────────────────────────── */
.divider { border-top: 1px solid #f1f5f9; margin: 2rem 0; }
.scrollbar-hide { -ms-overflow-style:none; scrollbar-width:none; }
.scrollbar-hide::-webkit-scrollbar { display:none; }


/* ████████████████████████████████████████████████████████
   TEXORA PREMIUM HOMEPAGE SYSTEM (tx-)
   Rebuilt from reference: tanujashastri.com
   Every section has its own distinct visual identity.
████████████████████████████████████████████████████████ */

:root {
  --tx-navy:    #080F1E;
  --tx-navy-2:  #0D1B2E;
  --tx-neon:    #00E0A4;
  --tx-white:   #FFFFFF;
  --tx-muted:   #637085;
  --tx-border:  rgba(255,255,255,0.07);
  --tx-border-l:rgba(0,0,0,0.08);
  --tx-pad: clamp(5rem, 10vw, 9rem);
  --tx-font: 'Plus Jakarta Sans', ui-sans-serif, system-ui;
}

.tx-eyebrow {
  display: block;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--tx-neon);
  margin-bottom: 1.5rem;
}
.tx-eyebrow--dim   { color: rgba(255,255,255,0.35); }

.tx-accent-text {
  background: linear-gradient(110deg, #00E0A4 0%, #2563EB 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ─── HERO ───────────────────────────────────────────── */
.tx-hero {
  min-height: 96svh;
  background: var(--tx-navy);
  background-image:
    radial-gradient(ellipse 70% 55% at 50% -5%, rgba(37,99,235,0.22) 0%, transparent 70%),
    radial-gradient(ellipse 35% 40% at 92% 55%, rgba(0,224,164,0.08) 0%, transparent 60%);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 3rem;
  padding: 8rem clamp(1.5rem,6vw,6rem) 5rem;
  position: relative;
  overflow: hidden;
}
.tx-hero::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.012) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}
@media (max-width: 1024px) {
  .tx-hero { grid-template-columns: 1fr; padding-top: 7rem; text-align: center; }
  .tx-hero__card { margin: 0 auto; max-width: 460px; }
  .tx-hero__proof, .tx-hero__cta { justify-content: center; }
  .tx-hero__desc { margin: 0 auto 2.5rem; }
}

.tx-hero__status {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 100px;
  padding: .4rem 1rem;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
  margin-bottom: 2.5rem;
}
.tx-status-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--tx-neon);
  box-shadow: 0 0 8px var(--tx-neon);
  animation: txPing 2s ease-in-out infinite;
}
@keyframes txPing {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.6; transform:scale(1.4); }
}

.tx-hero__headline {
  font-size: clamp(3rem, 7vw, 6.5rem);
  font-weight: 900;
  line-height: .9;
  letter-spacing: -.04em;
  color: var(--tx-white);
  margin: 0 0 2rem;
  overflow: hidden;
}
.tx-split-line { display: block; transform: translateY(110%); opacity: 0; }

.tx-hero__desc {
  font-size: clamp(.95rem, 1.5vw, 1.15rem);
  color: rgba(255,255,255,0.42);
  font-weight: 450;
  line-height: 1.7;
  max-width: 440px;
  margin-bottom: 2.5rem;
}

.tx-hero__cta { display: flex; align-items: center; flex-wrap: wrap; gap: 1rem; margin-bottom: 3.5rem; }

.tx-hero__proof {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1.5rem;
}
.tx-proof-item { display: flex; flex-direction: column; gap: .1rem; }
.tx-proof-item strong { font-size: 1.1rem; font-weight: 900; color: var(--tx-white); letter-spacing: -.02em; }
.tx-proof-item span { font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: rgba(255,255,255,0.28); }
.tx-proof-divider { width: 1px; height: 28px; background: rgba(255,255,255,0.08); }

/* Hero Card */
.tx-hero__card {
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 2rem;
  padding: 2.25rem;
  position: relative;
  will-change: transform;
  transform-style: preserve-3d;
}
.tx-hero__card::before {
  content: '';
  position: absolute; inset: 0;
  border-radius: 2rem;
  background: radial-gradient(ellipse at top right, rgba(0,224,164,0.07), transparent 60%);
  pointer-events: none;
}
.tx-card-label {
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.22);
  margin-bottom: 1.25rem;
}
.tx-card-links { display: flex; flex-direction: column; gap: .5rem; }
.tx-card-link {
  display: flex;
  align-items: center;
  gap: .9rem;
  padding: .85rem 1.1rem;
  border-radius: 1.1rem;
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.04);
  text-decoration: none;
  transition: all .35s cubic-bezier(.16,1,.3,1);
}
.tx-card-link:hover {
  background: rgba(0,224,164,0.06);
  border-color: rgba(0,224,164,0.18);
  transform: translateX(4px);
}
.tx-card-link__icon { font-size: 1.3rem; flex-shrink: 0; }
.tx-card-link__text { flex: 1; display: flex; flex-direction: column; gap: .08rem; }
.tx-card-link__name {
  font-size: .8rem;
  font-weight: 800;
  color: var(--tx-white);
  letter-spacing: -.01em;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.tx-card-link__name em {
  font-style: normal;
  font-size: 8px;
  font-weight: 900;
  letter-spacing: .15em;
  text-transform: uppercase;
  background: var(--tx-neon);
  color: var(--tx-navy);
  padding: .1rem .45rem;
  border-radius: 100px;
}
.tx-card-link__sub { font-size: 10px; color: rgba(255,255,255,0.28); font-weight: 500; }
.tx-card-link__arrow { color: rgba(255,255,255,0.18); transition: all .3s ease; flex-shrink: 0; }
.tx-card-link:hover .tx-card-link__arrow { color: var(--tx-neon); transform: translateX(3px); }
.tx-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1.25rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255,255,255,0.06);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.18);
}
.tx-online-badge { display: flex; align-items: center; gap: .4rem; color: var(--tx-neon); }
.tx-online-badge span {
  display: inline-block;
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--tx-neon);
  box-shadow: 0 0 5px var(--tx-neon);
  animation: txPing 2s infinite;
}

/* BUTTONS */
.tx-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .85rem 1.85rem;
  border-radius: 100px;
  background: var(--tx-white);
  color: var(--tx-navy);
  font-weight: 800;
  font-size: .85rem;
  letter-spacing: .01em;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: all .35s cubic-bezier(.16,1,.3,1);
}
.tx-btn-primary:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(255,255,255,0.12); }
.tx-btn-primary--neon { background: var(--tx-neon); color: var(--tx-navy); box-shadow: 0 0 25px rgba(0,224,164,0.3); }
.tx-btn-primary--neon:hover { box-shadow: 0 10px 40px rgba(0,224,164,0.5); }

.tx-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .85rem 1.85rem;
  border-radius: 100px;
  background: transparent;
  color: rgba(255,255,255,0.5);
  font-weight: 700;
  font-size: .85rem;
  border: 1px solid rgba(255,255,255,0.1);
  cursor: pointer;
  text-decoration: none;
  transition: all .3s ease;
}
.tx-btn-ghost:hover { background: rgba(255,255,255,0.05); color: var(--tx-white); border-color: rgba(255,255,255,0.22); }
.tx-btn-ghost--light { color: rgba(255,255,255,0.5); border-color: rgba(255,255,255,0.12); }

/* ─── SERVICE INDEX ──────────────────────────────────── */
.tx-index {
  background: #fff;
  padding: var(--tx-pad) clamp(1.5rem,6vw,6rem);
}
.tx-index__header {
  max-width: 1320px;
  margin: 0 auto 3.5rem;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.tx-index__header .tx-eyebrow { margin-bottom: 0; align-self: center; }
.tx-index__desc { max-width: 360px; font-size: .95rem; color: #6B7280; font-weight: 450; line-height: 1.65; }
.tx-index__list { max-width: 1320px; margin: 0 auto; display: flex; flex-direction: column; }

.tx-index__row {
  display: grid;
  grid-template-columns: 52px 1fr auto 52px;
  align-items: center;
  gap: 2rem;
  padding: 1.85rem 0;
  border-bottom: 1px solid rgba(0,0,0,0.055);
  text-decoration: none;
  transition: all .4s cubic-bezier(.16,1,.3,1);
  cursor: pointer;
}
.tx-index__row:hover { padding-left: 1.25rem; background: rgba(0,0,0,0.016); }
.tx-index__row:hover .tx-index__title { color: #2563EB; }
.tx-index__row:hover .tx-index__arrow { background: var(--tx-neon); color: var(--tx-navy); border-color: transparent; }

.tx-index__num { font-size: 11px; font-weight: 900; font-family: monospace; color: rgba(0,0,0,0.15); letter-spacing: .05em; }
.tx-index__main { display: flex; flex-direction: column; gap: .2rem; }
.tx-index__title { font-size: clamp(1.15rem, 2.4vw, 1.7rem); font-weight: 900; color: var(--tx-navy); letter-spacing: -.03em; line-height: 1.1; transition: color .3s; }
.tx-index__sub { font-size: 11px; font-weight: 600; color: #94a3b8; text-transform: uppercase; letter-spacing: .1em; }
.tx-index__price { font-size: .95rem; font-weight: 800; color: var(--tx-navy); letter-spacing: -.01em; white-space: nowrap; }
.tx-index__arrow {
  width: 48px; height: 48px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(0,0,0,0.3);
  transition: all .35s ease;
  flex-shrink: 0;
}
@media (max-width: 640px) {
  .tx-index__row { grid-template-columns: 40px 1fr 48px; gap: .75rem; }
  .tx-index__price { display: none; }
}

/* ─── Services list: animated left-line indicator ──── */
.tx-index__row {
  position: relative; /* needed for the ::before bar */
  overflow: hidden;
}
.tx-index__row::before {
  content: '';
  position: absolute;
  left: 0; top: 0;
  width: 3px;
  height: 100%;
  background: var(--tx-neon, #00E0A4);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .4s cubic-bezier(.16,1,.3,1);
  border-radius: 0 2px 2px 0;
}
.tx-index__row:hover::before { transform: scaleY(1); }
.tx-index__row:hover {
  padding-left: 1.5rem;
  background: rgba(0,224,164,0.03);
  transform: translateX(6px);
}
.tx-index__row:hover .tx-index__title { color: #2563EB; }
.tx-index__row:hover .tx-index__arrow {
  background: var(--tx-neon, #00E0A4);
  color: var(--tx-navy, #080F1E);
  border-color: transparent;
  box-shadow: 0 0 20px rgba(0,224,164,0.4);
}

/* ─── WHY TEXORA ─────────────────────────────────────── */
.tx-why {
  background: linear-gradient(140deg, #0B1F3A 0%, #060C18 100%);
  padding: var(--tx-pad) clamp(1.5rem,6vw,6rem);
  position: relative;
  overflow: hidden;
}
.tx-why::after {
  content: '';
  position: absolute; right:-8%; top:-15%;
  width: 550px; height: 550px;
  background: radial-gradient(circle, rgba(0,224,164,0.07) 0%, transparent 65%);
  pointer-events: none;
}
.tx-why__inner {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 5rem;
  align-items: center;
}
@media (max-width: 900px) { .tx-why__inner { grid-template-columns: 1fr; gap: 3rem; } }

.tx-why__headline {
  font-size: clamp(2rem, 4.5vw, 3.8rem);
  font-weight: 900;
  color: var(--tx-white);
  letter-spacing: -.04em;
  line-height: 1.05;
  margin: 0;
}
.tx-why__headline em { font-style: normal; color: var(--tx-neon); }
.tx-why__right { display: flex; flex-direction: column; gap: 2.25rem; }
.tx-why__item { display: flex; align-items: flex-start; gap: 1.1rem; }
.tx-why__item-icon { font-size: 1.75rem; flex-shrink: 0; margin-top: .05rem; }
.tx-why__item-title { font-size: 1rem; font-weight: 800; color: var(--tx-white); letter-spacing: -.02em; margin: 0 0 .3rem; }
.tx-why__item-desc { font-size: .875rem; color: rgba(255,255,255,0.38); font-weight: 450; line-height: 1.65; margin: 0; }

/* ─── PROTOCOL ───────────────────────────────────────── */
.tx-protocol {
  background: #F8FAFC;
  padding: var(--tx-pad) clamp(1.5rem,6vw,6rem);
}
.tx-protocol__header { max-width: 1320px; margin: 0 auto 4.5rem; }
.tx-protocol__headline {
  font-size: clamp(2.5rem, 6vw, 5rem);
  font-weight: 900;
  color: var(--tx-navy);
  letter-spacing: -.05em;
  line-height: .93;
  margin: 0;
}
.tx-protocol__steps {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border: 1px solid rgba(0,0,0,0.07);
  border-radius: 1.75rem;
  overflow: hidden;
}
@media (max-width: 768px) { .tx-protocol__steps { grid-template-columns: 1fr; } }
.tx-step {
  background: #fff;
  padding: 3rem 2.25rem;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
  border-right: 1px solid rgba(0,0,0,0.05);
  transition: background .4s ease;
}
.tx-step:last-child { border-right: none; }
.tx-step:hover { background: var(--tx-navy); }
.tx-step:hover .tx-step__num { color: rgba(0,224,164,0.35); }
.tx-step:hover .tx-step__title { color: #fff; }
.tx-step:hover .tx-step__desc { color: rgba(255,255,255,0.38); }
.tx-step__num { font-size: 10px; font-weight: 900; font-family: monospace; letter-spacing: .1em; color: rgba(0,0,0,0.18); transition: color .4s; }
.tx-step__icon { font-size: 2rem; }
.tx-step__title { font-size: 1.5rem; font-weight: 900; color: var(--tx-navy); letter-spacing: -.04em; line-height: 1; margin: 0; transition: color .4s; }
.tx-step__desc { font-size: .875rem; color: #637085; font-weight: 450; line-height: 1.65; margin: 0; transition: color .4s; }

/* ─── GLOBAL NODES ───────────────────────────────────── */
.tx-global {
  background: var(--tx-navy);
  padding: var(--tx-pad) clamp(1.5rem,6vw,6rem);
  position: relative;
  overflow: hidden;
}
.tx-global::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,0.01) 1px, transparent 1px);
  background-size: 44px 44px;
  pointer-events: none;
}
.tx-global__eyebrow { max-width: 1320px; margin: 0 auto 1.25rem; }
.tx-global__headline {
  max-width: 1320px;
  margin: 0 auto 4.5rem;
  font-size: clamp(3.5rem, 9vw, 9rem);
  font-weight: 900;
  color: var(--tx-white);
  letter-spacing: -.055em;
  line-height: .88;
}
.tx-global__grid {
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 56px 1fr;
  align-items: stretch;
}
@media (max-width: 900px) { .tx-global__grid { grid-template-columns: 1fr; } .tx-global__bridge { display: none; } }
.tx-global__card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 2rem;
  padding: 3.5rem;
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  transition: all .5s cubic-bezier(.16,1,.3,1);
}
.tx-global__card:hover { background: rgba(255,255,255,0.05); border-color: rgba(0,224,164,0.18); transform: translateY(-5px); }
.tx-global__card-top { display: flex; align-items: center; justify-content: space-between; }
.tx-flag { font-size: 2.75rem; }
.tx-currency { font-size: 1.1rem; font-weight: 900; color: var(--tx-neon); letter-spacing: -.02em; }
.tx-global__card-title { font-size: clamp(1.8rem,3.5vw,2.75rem); font-weight: 900; color: var(--tx-white); letter-spacing: -.04em; line-height: 1; margin: 0; }
.tx-global__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .75rem; }
.tx-global__list li { font-size: .875rem; color: rgba(255,255,255,0.38); font-weight: 500; padding-left: 1.1rem; position: relative; }
.tx-global__list li::before { content: ''; position: absolute; left: 0; top: .55rem; width: 4px; height: 4px; border-radius: 50%; background: var(--tx-neon); }
.tx-global__cta { display: inline-flex; align-items: center; gap: .5rem; font-size: .75rem; font-weight: 900; letter-spacing: .15em; text-transform: uppercase; color: var(--tx-neon); text-decoration: none; margin-top: auto; transition: gap .3s; }
.tx-global__cta:hover { gap: .9rem; }
.tx-global__bridge { display: flex; align-items: center; justify-content: center; }
.tx-global__bridge svg { width: 56px; height: 100%; opacity: .3; }

/* ─── TESTIMONIALS ───────────────────────────────────── */
.tx-testimonials { background: #fff; padding: var(--tx-pad) clamp(1.5rem,6vw,6rem); }
.tx-testimonials__header {
  max-width: 1320px;
  margin: 0 auto 3.5rem;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 2rem;
}
.tx-testimonials__headline { font-size: clamp(2.2rem,5vw,4.25rem); font-weight: 900; color: var(--tx-navy); letter-spacing: -.05em; line-height: .93; margin: .5rem 0 0; }
.tx-testimonials__stat { display: flex; flex-direction: column; align-items: flex-end; gap: .15rem; }
.tx-testimonials__stat strong { font-size: 2.4rem; font-weight: 900; color: var(--tx-navy); letter-spacing: -.04em; }
.tx-testimonials__stat span { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: .18em; color: #94a3b8; }
.tx-testimonials__grid { max-width: 1320px; margin: 0 auto; display: grid; grid-template-columns: repeat(3,1fr); gap: 1.25rem; }
@media (max-width: 900px) { .tx-testimonials__grid { grid-template-columns: 1fr; } }
.tx-tcard {
  background: #F8FAFC;
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 1.5rem;
  padding: 2.25rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  transition: all .4s cubic-bezier(.16,1,.3,1);
}
.tx-tcard:hover { background: #fff; border-color: rgba(0,224,164,0.18); box-shadow: 0 14px 50px rgba(0,0,0,0.07); transform: translateY(-4px); }
.tx-tcard__quote { font-size: 1rem; font-weight: 500; color: #374151; line-height: 1.7; font-style: italic; flex: 1; }
.tx-tcard__author { display: flex; align-items: center; gap: .8rem; }
.tx-tcard__avatar { width: 42px; height: 42px; border-radius: .75rem; background: var(--tx-navy); color: var(--tx-white); display: flex; align-items: center; justify-content: center; font-weight: 900; font-size: 1rem; flex-shrink: 0; transition: background .3s; }
.tx-tcard:hover .tx-tcard__avatar { background: var(--tx-neon); color: var(--tx-navy); }
.tx-tcard__name { font-size: .875rem; font-weight: 800; color: var(--tx-navy); letter-spacing: -.01em; }
.tx-tcard__role { font-size: 9px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: var(--tx-neon); }
.tx-tcard__stars { display: flex; gap: .2rem; color: var(--tx-neon); }

/* ─── FINAL CTA ──────────────────────────────────────── */
.tx-cta {
  background: var(--tx-navy);
  padding: var(--tx-pad) clamp(1.5rem,6vw,6rem);
  position: relative;
  overflow: hidden;
}
.tx-cta::before {
  content: '';
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(0,224,164,0.055) 0%, transparent 65%);
  pointer-events: none;
}
.tx-cta__inner { max-width: 1320px; margin: 0 auto; display: flex; flex-direction: column; align-items: flex-start; }
.tx-cta__headline { font-size: clamp(4rem,11vw,10.5rem); font-weight: 900; color: var(--tx-white); letter-spacing: -.06em; line-height: .84; margin: 0 0 3.5rem; }
.tx-cta__dot { color: var(--tx-neon); }
.tx-cta__actions { display: flex; align-items: center; flex-wrap: wrap; gap: 1rem; margin-bottom: 2rem; }
.tx-cta__micro { font-size: 10px; font-weight: 700; letter-spacing: .22em; text-transform: uppercase; color: rgba(255,255,255,0.18); margin: 0; }

/* ─── ACCESSIBILITY ──────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .tx-split-line { transform: none !important; opacity: 1 !important; }
  * { animation-duration: .01ms !important; transition-duration: .01ms !important; }
}


/* ─────────────────────────────────────
   DEV HELPERS
───────────────────────────────────── */
.divider { border-top: 1px solid #f1f5f9; margin: 2rem 0; }
.scrollbar-hide { -ms-overflow-style:none; scrollbar-width:none; }
.scrollbar-hide::-webkit-scrollbar { display:none; }


/* ████████████████████████████████████████████████████████
   TXSS — STICKY SCROLL SERVICES
   Pattern: tanujashastri.com "Projects (05)" interaction
   500vh scroll track · GSAP ScrollTrigger pinning
████████████████████████████████████████████████████████ */

/* ─── Outer scroll track ─────────────────────────────── */
.txss-wrap {
  height: 500vh; /* 5 services × 100vh */
  position: relative;
  background: #06111E; /* deep navy */
  overflow: clip;
}

/* Section label (outside sticky, top of section) */
.txss-section-label {
  position: absolute;
  top: 3rem;
  left: clamp(1.5rem, 5vw, 5rem);
  display: flex;
  align-items: center;
  gap: 1rem;
  z-index: 10;
  pointer-events: none;
}
.txss-section-num {
  font-size: 11px;
  font-weight: 900;
  font-family: monospace;
  color: rgba(255,255,255,0.2);
  letter-spacing: .15em;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  padding: .3rem .75rem;
  border-radius: 100px;
}
.txss-section-title {
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
}

/* ─── Sticky container (100vh, pins to top) ─────────── */
.txss-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1fr;
  overflow: hidden;
  will-change: contents;
}
@media (max-width: 900px) {
  .txss-wrap { height: 600vh; } /* allow more scroll per panel on mobile */
  .txss-sticky { grid-template-columns: 1fr; grid-template-rows: 1fr 1fr; }
}

/* ─── Number Navigation Dots (right side, outside sticky) */
.txss-nav {
  position: absolute;
  left: clamp(1.5rem, 3vw, 3rem);
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: .75rem;
  z-index: 20;
}
.txss-nav__dot {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.3);
  font-size: 10px;
  font-weight: 900;
  font-family: monospace;
  cursor: pointer;
  transition: all .3s cubic-bezier(.16,1,.3,1);
  display: flex;
  align-items: center;
  justify-content: center;
}
.txss-nav__dot.is-active,
.txss-nav__dot:hover {
  background: #00E0A4;
  border-color: #00E0A4;
  color: #06111E;
  transform: scale(1.2);
  box-shadow: 0 0 16px rgba(0,224,164,0.5);
}
@media (max-width: 768px) { .txss-nav { display: none; } }

/* ─── LEFT: Panel area ───────────────────────────────── */
.txss-left {
  position: relative;
  display: flex;
  align-items: center;
  padding: 0 clamp(1.5rem, 6vw, 5rem);
  overflow: hidden;
}

/* ─── Panel ──────────────────────────────────────────── */
.txss-panel {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 clamp(1.5rem, 6vw, 5rem);
  opacity: 0;
  transform: translateY(60px);
  pointer-events: none;
  will-change: transform, opacity;
  transition: none; /* controlled by GSAP only */
}
.txss-panel.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: all;
}

.txss-panel__meta {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}
.txss-panel__num {
  font-size: 11px;
  font-weight: 900;
  font-family: monospace;
  letter-spacing: .15em;
  color: rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  padding: .25rem .65rem;
  border-radius: 100px;
}
.txss-panel__tag {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: #00E0A4;
}

.txss-panel__heading {
  font-size: clamp(2.4rem, 4.5vw, 4rem);
  font-weight: 900;
  color: #fff;
  letter-spacing: -.04em;
  line-height: .95;
  margin: 0 0 1.25rem;
}

.txss-panel__desc {
  font-size: clamp(.875rem, 1.2vw, 1rem);
  color: rgba(255,255,255,0.4);
  font-weight: 450;
  line-height: 1.7;
  max-width: 440px;
  margin: 0 0 1.75rem;
}

/* ─── Sub-types ──────────────────────────────────────── */
.txss-types {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 1.25rem;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 1rem;
  overflow: hidden;
}
.txss-type {
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.txss-type:last-child { border-bottom: none; }

.txss-type__header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1.1rem;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.6);
  font-size: .8rem;
  font-weight: 700;
  cursor: pointer;
  text-align: left;
  transition: all .25s ease;
}
.txss-type__header:hover { color: #fff; background: rgba(255,255,255,0.02); }
.txss-type.is-open .txss-type__header { color: #fff; }
.txss-type.is-open .txss-type__arrow { transform: rotate(180deg); }
.txss-type__arrow { transition: transform .3s ease; flex-shrink: 0; }

.txss-type__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s ease;
}
.txss-type.is-open .txss-type__body { max-height: 100px; }
.txss-type__body p {
  padding: 0 1.1rem .85rem;
  font-size: .78rem;
  color: rgba(255,255,255,0.32);
  line-height: 1.6;
  margin: 0;
}

/* ─── Accordions (Requirements / Timeline) ───────────── */
.txss-accordions {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-bottom: 2rem;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 1rem;
  overflow: hidden;
}
.txss-acc { border-bottom: 1px solid rgba(255,255,255,0.05); }
.txss-acc:last-child { border-bottom: none; }

.txss-acc__header {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  background: transparent;
  border: none;
  color: rgba(255,255,255,0.55);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .03em;
  cursor: pointer;
  text-align: left;
  transition: all .25s ease;
}
.txss-acc__header:hover { color: #fff; background: rgba(255,255,255,0.03); }
.txss-acc.is-open .txss-acc__header { color: #fff; }
.txss-acc.is-open .txss-acc__arrow { transform: rotate(180deg); }
.txss-acc__arrow { transition: transform .3s ease; flex-shrink: 0; }

.txss-acc__body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s cubic-bezier(.16,1,.3,1);
}
.txss-acc.is-open .txss-acc__body { max-height: 300px; }

.txss-acc__body ul {
  list-style: none;
  padding: 0 1.25rem .85rem;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.txss-acc__body ul li {
  font-size: .8rem;
  color: rgba(255,255,255,0.35);
  font-weight: 500;
  padding-left: 1rem;
  position: relative;
  line-height: 1.5;
}
.txss-acc__body ul li::before {
  content: '';
  position: absolute;
  left: 0; top: .55rem;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: #00E0A4;
}

.txss-acc__timeline {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: 0 1.25rem .85rem;
  margin: 0;
  font-size: .85rem;
  font-weight: 700;
  color: #00E0A4;
}

/* ─── Panel CTA ──────────────────────────────────────── */
.txss-panel__cta {
  display: flex;
  align-items: center;
  gap: 1.5rem;
}

.txss-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  padding: .9rem 2rem;
  border-radius: 100px;
  background: var(--accent, #00E0A4);
  color: #06111E;
  font-size: .85rem;
  font-weight: 900;
  letter-spacing: .02em;
  text-decoration: none;
  transition: all .35s cubic-bezier(.16,1,.3,1);
  box-shadow: 0 0 20px color-mix(in srgb, var(--accent, #00E0A4) 30%, transparent);
}
.txss-cta-btn:hover {
  transform: translateY(-3px) scale(1.04);
  box-shadow: 0 8px 30px color-mix(in srgb, var(--accent, #00E0A4) 50%, transparent);
}
.txss-price {
  font-size: .8rem;
  font-weight: 700;
  color: rgba(255,255,255,0.3);
  letter-spacing: .05em;
}

/* ─── RIGHT: Visual area ─────────────────────────────── */
.txss-right {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 clamp(1rem, 4vw, 4rem);
  overflow: hidden;
  background: rgba(255,255,255,0.015);
  border-left: 1px solid rgba(255,255,255,0.04);
}

.txss-visual {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 1.5rem;
  padding: 2rem clamp(1rem, 4vw, 3.5rem);
  opacity: 0;
  transform: scale(0.94) translateY(20px);
  pointer-events: none;
  will-change: transform, opacity;
}
.txss-visual.is-active {
  opacity: 1;
  transform: scale(1) translateY(0);
  pointer-events: all;
}

.txss-visual__glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  animation: txssGlowPulse 4s ease-in-out infinite;
}
@keyframes txssGlowPulse {
  0%,100% { opacity: .6; }
  50%      { opacity: 1; }
}

/* ─── Mock Certificate Card ──────────────────────────── */
.txss-visual__card {
  width: 100%;
  max-width: 400px;
  background: rgba(255,255,255,0.035);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 1.75rem;
  padding: 2rem;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  position: relative;
  z-index: 2;
  transition: transform .3s ease;
}
.txss-visual__card:hover { transform: translateY(-4px); }

.txss-visual__card-header {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.txss-visual__icon { font-size: 2.2rem; }
.txss-visual__card-title {
  font-size: .9rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.01em;
}
.txss-visual__card-sub {
  font-size: 10px;
  font-weight: 600;
  color: rgba(255,255,255,0.3);
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-top: .15rem;
}
.txss-visual__badge {
  margin-left: auto;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: .35rem .8rem;
  border-radius: 100px;
  white-space: nowrap;
  flex-shrink: 0;
}

.txss-visual__divider {
  height: 1px;
  background: rgba(255,255,255,0.06);
  margin: 1.5rem 0;
}

.txss-visual__data {
  display: flex;
  flex-direction: column;
  gap: .65rem;
}
.txss-visual__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.txss-visual__key {
  font-size: .78rem;
  color: rgba(255,255,255,0.3);
  font-weight: 600;
}
.txss-visual__val {
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: -.01em;
}

.txss-visual__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255,255,255,0.06);
}
.txss-visual__seal {
  width: 52px; height: 52px;
  border-radius: 50%;
  border: 1px solid;
  display: flex;
  align-items: center;
  justify-content: center;
}
.txss-visual__seal-inner {
  width: 42px; height: 42px;
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .2rem;
  font-size: 5px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-align: center;
  line-height: 1.3;
}
.txss-visual__seal-inner svg { flex-shrink: 0; }
.txss-visual__watermark {
  font-size: 8px;
  font-weight: 900;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.08);
  text-align: right;
  line-height: 1.4;
}

/* Chips (floating stat pills) */
.txss-visual__chips {
  display: flex;
  gap: .75rem;
  flex-wrap: wrap;
  justify-content: center;
  position: relative;
  z-index: 2;
}
.txss-visual__chip {
  display: flex;
  align-items: center;
  gap: .4rem;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 100px;
  padding: .5rem 1rem;
  font-size: .78rem;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
}

/* ─── Vertical progress track (right side) ───────────── */
.txss-progress-track {
  position: absolute;
  right: 1.5rem;
  top: 50%;
  transform: translateY(-50%);
  width: 2px;
  height: 160px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px;
  overflow: hidden;
}
.txss-progress-fill {
  width: 100%;
  height: 20%;
  background: #00E0A4;
  border-radius: 2px;
  transition: height .5s cubic-bezier(.16,1,.3,1);
  box-shadow: 0 0 8px rgba(0,224,164,0.6);
}

/* ─── Mobile layout ──────────────────────────────────── */
@media (max-width: 900px) {
  .txss-section-label { display: none; }
  .txss-sticky { grid-template-columns: 1fr; grid-template-rows: 55% 45%; }
  .txss-left { padding: 0 1.5rem; }
  .txss-panel { padding: 0 1.5rem; }
  .txss-panel__heading { font-size: 2rem; }
  .txss-right { border-left: none; border-top: 1px solid rgba(255,255,255,0.04); }
  .txss-visual__card { max-width: 320px; padding: 1.5rem; }
  .txss-progress-track { display: none; }
}

/* ─── Reduces motion ─────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .txss-panel, .txss-visual {
    transition: opacity .2s !important;
    transform: none !important;
  }
}



/* --------------------------------------------------------
   CUSTOM CURSOR (desktop only)
-------------------------------------------------------- */
#tx-cursor,
#tx-cursor-dot {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 99999;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: opacity .3s;
}
#tx-cursor {
  width: 36px; height: 36px;
  border: 1.5px solid rgba(0,224,164,0.45);
  background: transparent;
  transition: width .3s ease, height .3s ease, border-color .3s ease, background .3s ease;
}
#tx-cursor.is-hover {
  width: 56px; height: 56px;
  border-color: #00E0A4;
  background: rgba(0,224,164,0.08);
}
#tx-cursor-dot {
  width: 6px; height: 6px;
  background: #00E0A4;
  box-shadow: 0 0 8px rgba(0,224,164,0.8);
}
@media (max-width: 1024px) {
  #tx-cursor, #tx-cursor-dot { display: none; }
}

/* --------------------------------------------------------
   TEXORA SCROLLBASE HOMEPAGE REFRESH
-------------------------------------------------------- */
:root {
  --tx-bg-dark: #050608;
  --tx-bg-ink: #0b0d10;
  --tx-paper: #f7f7f2;
  --tx-muted: rgba(255,255,255,0.58);
  --tx-line: rgba(255,255,255,0.1);
  --tx-neon: var(--color-neon, #00E0A4);
  --tx-electric: var(--color-electric, #2563EB);
  --tx-navy: var(--color-navy, #0B1F3A);
  --tx-pad: clamp(5rem, 10vw, 10rem);
}

.tx-home {
  background: var(--tx-bg-dark);
  color: #fff;
  overflow: clip;
}

#navbar {
  color: #fff;
}
#navbar > .container-main {
  width: min(1320px, calc(100% - clamp(1.5rem, 6vw, 6rem)));
  padding-inline: 0;
}
#navbar .h-20 {
  height: 3.6rem !important;
}
#navbar.nav-scrolled,
#navbar {
  backdrop-filter: blur(18px);
}
#navbar a,
#navbar button {
  letter-spacing: .08em;
}
#navbar .btn-primary {
  min-height: 2.7rem;
  border-radius: 100px !important;
  padding-inline: 1.1rem !important;
  box-shadow: none;
}

.tx-site-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 999;
  padding: .85rem clamp(.75rem, 3vw, 2.2rem);
  color: #fff;
  pointer-events: none;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
}
.tx-site-nav__shell {
  width: min(1450px, calc(100vw - clamp(2rem, 16vw, 21rem)));
  min-height: 4rem;
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(160px, 1fr) auto minmax(160px, 1fr);
  align-items: center;
  gap: clamp(.7rem, 1.4vw, 1.2rem);
  padding: .65rem .9rem .65rem 1.1rem;
  border-radius: 999px;
  background: #50515a;
  border: 0;
  box-shadow: 0 18px 40px rgba(21,21,21,.1);
  backdrop-filter: none;
  pointer-events: auto;
}
.tx-site-nav__brand,
.tx-site-nav__links a,
.tx-site-nav__actions a,
.tx-site-nav__dropdown > button {
  color: #f8f8f8;
  text-shadow: 0 1px 0 rgba(0,0,0,.12);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .11em;
  line-height: 1;
  text-transform: uppercase;
  text-decoration: none;
  white-space: nowrap;
}
.tx-site-nav__brand {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  gap: .65rem;
}
.tx-site-nav__brand img {
  max-height: 2.2rem;
  width: auto;
  object-fit: contain;
}
.tx-site-nav__links,
.tx-site-nav__actions {
  display: flex;
  align-items: center;
  gap: clamp(.85rem, 1.45vw, 1.35rem);
}
.tx-site-nav__links {
  justify-self: center;
}
.tx-site-nav__actions {
  justify-self: end;
}
.tx-site-nav__pill {
  min-height: 2.55rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .25rem 1.55rem;
  border-radius: 999px;
  background: #37d5a7;
  color: #101010 !important;
}
.tx-site-nav__dropdown {
  position: relative;
  min-height: 3rem;
  display: flex;
  align-items: center;
}
.tx-site-nav__dropdown > button {
  border: 0;
  background: transparent;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: .38rem;
  padding: .9rem 0;
}
.tx-site-nav__dropdown > button span {
  opacity: .55;
  transition: transform .22s ease;
}
.tx-site-nav__dropdown:hover > button span,
.tx-site-nav__dropdown:focus-within > button span {
  transform: rotate(180deg);
}
.tx-site-nav__menu {
  position: absolute;
  top: 100%;
  left: 50%;
  width: 320px;
  max-width: calc(100vw - 2rem);
  transform: translateX(-50%) translateY(8px) scale(.98);
  margin-top: 12px;
  padding: 8px;
  border-radius: 20px;
  background: #50515a;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 18px 38px rgba(21,21,21,.18);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
}
.tx-site-nav__menu::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -12px;
  height: 12px;
}
.tx-site-nav__dropdown:hover .tx-site-nav__menu,
.tx-site-nav__dropdown:focus-within .tx-site-nav__menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0) scale(1);
}
.tx-site-nav__menu a {
  display: block;
  padding: 10px 14px;
  border-radius: 12px;
  transition: background .2s ease, transform .2s ease;
  white-space: normal;
}
.tx-site-nav__menu a:hover {
  background: rgba(255,255,255,.08);
  transform: translateX(3px);
}
.tx-site-nav__menu strong {
  display: block;
  color: #fff;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.2;
  text-transform: none;
  white-space: normal;
}
.tx-site-nav__menu small {
  display: block;
  margin-top: 4px;
  color: rgba(255,255,255,.5);
  font-size: 12px;
  line-height: 1.25;
  letter-spacing: .01em;
  text-transform: none;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.tx-site-nav__toggle,
.tx-site-nav__mobile {
  display: none;
}

@media (max-width: 1180px) {
  .tx-site-nav__links,
  .tx-site-nav__actions {
    display: none;
  }
  .tx-site-nav__shell {
    grid-template-columns: 1fr auto;
  }
  .tx-site-nav__toggle {
    width: 3rem;
    height: 3rem;
    border: 1px solid rgba(255,255,255,.14);
    border-radius: 999px;
    background: rgba(255,255,255,.06);
    display: grid;
    place-items: center;
    gap: .22rem;
    cursor: pointer;
  }
  .tx-site-nav__toggle span {
    width: 1.15rem;
    height: 2px;
    background: #fff;
    display: block;
  }
  .tx-site-nav__mobile {
    pointer-events: auto;
    width: min(640px, calc(100vw - 2rem));
    margin: .65rem auto 0;
    padding: 1rem;
    border-radius: 1.5rem;
    background: rgba(80,81,90,.98);
    border: 1px solid rgba(255,255,255,.1);
    box-shadow: 0 24px 64px rgba(21,21,21,.18);
  }
  .tx-site-nav__mobile a,
  .tx-site-nav__mobile p {
    display: block;
    margin: 0;
    padding: .72rem .85rem;
    color: rgba(255,255,255,.75);
    font-size: .82rem;
    font-weight: 800;
    letter-spacing: .06em;
    text-transform: uppercase;
  }
  .tx-site-nav__mobile p {
    color: rgba(255,255,255,.35);
    font-size: .68rem;
    padding-top: 1.1rem;
  }
}

@media (max-width: 640px) {
  .tx-site-nav {
    padding: .55rem;
  }
  .tx-site-nav__shell {
    width: 100%;
    min-height: 4.2rem;
  }
  .tx-site-nav__brand {
    font-size: .78rem;
  }
}

.tx-footer {
  padding: clamp(1rem, 3vw, 3rem);
  background: #f6f6f4;
  color: #f6f6f4;
}
.tx-footer__shell {
  width: min(1760px, calc(100vw - clamp(1rem, 5vw, 7rem)));
  margin: 0 auto;
  padding: clamp(3rem, 7vw, 7rem);
  border-radius: .28rem;
  background: #151515;
  overflow: hidden;
}
.tx-footer__top {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2rem;
  align-items: end;
  margin-bottom: clamp(3rem, 6vw, 6rem);
}
.tx-footer__kicker {
  display: block;
  margin-bottom: 1rem;
  color: rgba(246,246,244,.44);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.tx-footer h2 {
  margin: 0;
  font-family: "TJ Instrument", "Times New Roman", serif;
  font-size: clamp(4.4rem, 8vw, 10rem);
  font-weight: 400;
  letter-spacing: -.06em;
  line-height: .88;
}
.tx-footer h2 em {
  font-style: italic;
}
.tx-footer__cta {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
  justify-content: flex-end;
}
.tx-footer__cta a {
  min-height: 3.2rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .2rem 1.25rem;
  border-radius: 999px;
  background: #1710e6;
  color: #fff;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
}
.tx-footer__cta a:last-child {
  background: #37d5a7;
  color: #151515;
}
.tx-footer__grid {
  display: grid;
  grid-template-columns: minmax(260px, 1.4fr) repeat(3, minmax(150px, 1fr));
  gap: clamp(2rem, 5vw, 5rem);
  padding-top: 2rem;
  border-top: 1px solid rgba(246,246,244,.14);
}
.tx-footer__brand > a {
  color: #fff;
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  text-decoration: none;
}
.tx-footer__brand p {
  max-width: 380px;
  margin: 1.25rem 0;
  color: rgba(246,246,244,.48);
  line-height: 1.7;
}
.tx-footer__brand p + a {
  color: rgba(246,246,244,.74);
  text-decoration: none;
}
.tx-footer h3 {
  margin: 0 0 1.2rem;
  color: rgba(246,246,244,.4);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.tx-footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: .85rem;
}
.tx-footer li a,
.tx-footer li button {
  border: 0;
  padding: 0;
  background: transparent;
  color: rgba(246,246,244,.72);
  cursor: pointer;
  font: 800 .86rem/1.35 "Plus Jakarta Sans", sans-serif;
  text-align: left;
  text-decoration: none;
  transition: color .2s ease;
}
.tx-footer li a:hover,
.tx-footer li button:hover {
  color: #fff;
}
.tx-footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  margin-top: clamp(3rem, 6vw, 6rem);
  padding-top: 1.4rem;
  border-top: 1px solid rgba(246,246,244,.12);
  color: rgba(246,246,244,.34);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}

@media (max-width: 900px) {
  .tx-footer__top,
  .tx-footer__grid {
    grid-template-columns: 1fr;
  }
  .tx-footer__cta {
    justify-content: flex-start;
  }
  .tx-footer__bottom {
    flex-direction: column;
  }
}

.tx-container {
  width: min(1320px, calc(100% - clamp(2rem, 8vw, 8rem)));
  margin-inline: auto;
}

.noise-overlay {
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: .06;
  mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}

.tx-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  color: var(--tx-neon);
  font-size: .7rem;
  font-weight: 900;
  letter-spacing: .22em;
  text-transform: uppercase;
}
.tx-eyebrow::before {
  content: "";
  width: 2.5rem;
  height: 1px;
  background: currentColor;
  opacity: .55;
}
.tx-accent-text,
.tx-dot {
  color: var(--tx-neon);
}

.tx-hero {
  min-height: 100svh;
  display: flex;
  align-items: center;
  padding: clamp(7rem, 12vw, 11rem) clamp(1.25rem, 5vw, 5rem) clamp(4rem, 8vw, 7rem);
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), transparent 22%),
    radial-gradient(circle at 78% 30%, rgba(0,224,164,.18), transparent 28rem),
    radial-gradient(circle at 24% 18%, rgba(37,99,235,.2), transparent 26rem),
    #050608;
  position: relative;
}
.tx-hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 38vh;
  background: linear-gradient(0deg, #f7f7f2, transparent);
  opacity: .08;
  pointer-events: none;
}
.tx-hero::before {
  content: "Texora";
  position: absolute;
  right: clamp(1rem, 4vw, 4rem);
  bottom: clamp(1rem, 4vw, 3rem);
  color: rgba(255,255,255,.035);
  font-size: clamp(5rem, 18vw, 18rem);
  font-weight: 900;
  line-height: .75;
  letter-spacing: 0;
  pointer-events: none;
}
.tx-hero__inner {
  width: min(1420px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(360px, .85fr);
  align-items: center;
  gap: clamp(2rem, 7vw, 7rem);
  position: relative;
  z-index: 2;
}
.tx-hero__copy {
  max-width: 920px;
}
.tx-hero__status {
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  border: 1px solid var(--tx-line);
  background: rgba(255,255,255,.045);
  border-radius: 100px;
  padding: .65rem 1rem;
  color: rgba(255,255,255,.7);
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
  backdrop-filter: blur(16px);
}
.tx-status-dot {
  width: .55rem;
  height: .55rem;
  border-radius: 50%;
  background: var(--tx-neon);
  box-shadow: 0 0 18px var(--tx-neon);
}
.tx-hero__headline {
  margin: clamp(1.5rem, 4vw, 3rem) 0 1.5rem;
  font-size: clamp(3.35rem, 9vw, 9.8rem);
  font-weight: 900;
  letter-spacing: 0;
  line-height: .86;
}
.tx-split-line {
  display: block;
  overflow: hidden;
  transform-origin: left bottom;
}
.tx-hero__desc {
  max-width: 680px;
  color: var(--tx-muted);
  font-size: clamp(1rem, 1.6vw, 1.22rem);
  line-height: 1.75;
  margin: 0 0 2rem;
}
.tx-hero__cta,
.tx-cta__actions {
  display: flex;
  align-items: center;
  gap: .85rem;
  flex-wrap: wrap;
}
.tx-btn-primary,
.tx-btn-ghost {
  min-height: 3.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .65rem;
  border-radius: 100px;
  padding: .95rem 1.35rem;
  text-decoration: none;
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  transition: transform .35s cubic-bezier(.16,1,.3,1), background .35s, border-color .35s, color .35s, box-shadow .35s;
}
.tx-btn-primary {
  color: #05110d;
  background: var(--tx-neon);
  border: 1px solid transparent;
  box-shadow: 0 14px 40px rgba(0,224,164,.24);
}
.tx-btn-ghost {
  color: rgba(255,255,255,.72);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.035);
}
.tx-btn-primary:hover,
.tx-btn-ghost:hover {
  transform: translateY(-3px);
}
.tx-hero__visual {
  min-height: 580px;
  position: relative;
}
.tx-hero-card {
  position: absolute;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(145deg, rgba(255,255,255,.12), rgba(255,255,255,.035));
  border-radius: 1.75rem;
  box-shadow: 0 30px 100px rgba(0,0,0,.32);
  backdrop-filter: blur(24px);
}
.tx-hero-card--main {
  inset: 8% 0 auto 6%;
  padding: clamp(1.5rem, 3vw, 2.4rem);
  min-height: 360px;
}
.tx-hero-card--float {
  right: 4%;
  bottom: 18%;
  width: 185px;
  padding: 1.3rem;
}
.tx-hero-card--mini {
  left: 0;
  bottom: 7%;
  width: 230px;
  padding: 1.2rem 1.35rem;
}
.tx-hero-card__top,
.tx-hero-card__grid,
.tx-hero-card--mini,
.tx-hero-card--float {
  display: grid;
  gap: .8rem;
}
.tx-hero-card__top {
  grid-template-columns: 1fr auto;
  align-items: center;
  color: rgba(255,255,255,.48);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.tx-hero-card__top strong,
.tx-hero-card strong {
  color: #fff;
}
.tx-hero-card__meter {
  height: 9rem;
  border-radius: 1.2rem;
  margin: 2rem 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 28px 28px;
  position: relative;
  overflow: hidden;
}
.tx-hero-card__meter span {
  position: absolute;
  inset: auto 1rem 1rem;
  height: 56%;
  border-radius: 1rem;
  background: linear-gradient(135deg, var(--tx-neon), #fff7a7);
  transform-origin: bottom;
  animation: txMeter 4s ease-in-out infinite;
}
@keyframes txMeter {
  0%,100% { transform: scaleY(.58); opacity: .72; }
  50% { transform: scaleY(1); opacity: 1; }
}
.tx-hero-card__grid {
  grid-template-columns: 1fr auto;
  color: rgba(255,255,255,.45);
  font-size: .88rem;
}
.tx-hero-card__label,
.tx-hero-card--mini span {
  color: rgba(255,255,255,.45);
  font-size: .72rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 900;
}
.tx-hero-card--float strong {
  font-size: 3rem;
  letter-spacing: 0;
  color: var(--tx-neon);
}

.tx-index,
.tx-protocol,
.tx-testimonials {
  background: var(--tx-paper) !important;
  color: #111;
}
.tx-index .tx-eyebrow,
.tx-protocol .tx-eyebrow,
.tx-testimonials .tx-eyebrow {
  color: #111;
}
.tx-index {
  padding: var(--tx-pad) 0 !important;
}
.tx-index__header {
  display: grid !important;
  grid-template-columns: 1fr minmax(280px, 420px);
  align-items: end;
  gap: 2rem;
  margin-bottom: clamp(3rem, 7vw, 6rem) !important;
}
.tx-index__headline,
.tx-testimonials__headline {
  font-size: clamp(2.75rem, 7vw, 7rem) !important;
  line-height: .9 !important;
  letter-spacing: 0 !important;
  margin: 1rem 0 0 !important;
  color: #111 !important;
}
.tx-index__desc,
.tx-testimonials__sub {
  color: #64635d !important;
  line-height: 1.7;
}
.tx-index__row {
  min-height: 8.5rem;
  border-color: rgba(0,0,0,.1) !important;
  color: #111;
}
.tx-index__row:hover {
  background: #fff !important;
  padding-left: clamp(1rem, 3vw, 2rem) !important;
  padding-right: clamp(1rem, 3vw, 2rem) !important;
}
.tx-index__title {
  font-size: clamp(1.8rem, 4vw, 4.5rem) !important;
  line-height: .95;
  letter-spacing: 0 !important;
}

.tx-why,
.tx-global,
.tx-cta {
  background:
    radial-gradient(circle at 10% 10%, rgba(0,224,164,.11), transparent 24rem),
    radial-gradient(circle at 90% 20%, rgba(37,99,235,.12), transparent 22rem),
    var(--tx-bg-ink) !important;
  color: #fff;
  padding: var(--tx-pad) clamp(1.25rem, 5vw, 5rem);
  position: relative;
  overflow: hidden;
}
.tx-why__inner,
.tx-global__grid,
.tx-protocol__header,
.tx-protocol__steps,
.tx-cta__inner {
  width: min(1320px, 100%);
  margin-inline: auto;
}
.tx-why__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 520px);
  gap: clamp(3rem, 9vw, 9rem);
}
.tx-intro__hello {
  margin: 0 0 1.25rem;
  color: rgba(255,255,255,.38);
  font-size: clamp(2rem, 5vw, 4.5rem);
  font-weight: 900;
  line-height: .9;
  letter-spacing: 0;
}
.tx-why__headline,
.tx-protocol__headline,
.tx-global__headline,
.tx-cta__headline {
  font-size: clamp(3rem, 8.5vw, 9rem);
  line-height: .88;
  letter-spacing: 0;
  font-weight: 900;
}
.tx-why__item,
.tx-step,
.tx-global__card,
.tx-testimonial-card {
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.045);
  backdrop-filter: blur(16px);
  border-radius: 1.25rem;
  transition: transform .35s cubic-bezier(.16,1,.3,1), border-color .35s, background .35s;
}
.tx-why__item {
  padding: 1.35rem;
}
.tx-why__item:hover,
.tx-step:hover,
.tx-global__card:hover,
.tx-testimonial-card:hover {
  transform: translateY(-6px);
  border-color: rgba(0,224,164,.26);
  background: rgba(255,255,255,.07);
}

.txss-wrap {
  height: 520vh;
  background:
    radial-gradient(circle at 72% 44%, rgba(0,224,164,.08), transparent 28rem),
    #050608;
}
.txss-sticky {
  isolation: isolate;
}
.txss-section-label {
  top: clamp(5rem, 8vw, 7rem);
}
.txss-section-title {
  letter-spacing: .18em;
}
.txss-section-title::after {
  content: "(05)";
  margin-left: .55rem;
  color: var(--tx-neon);
}
.txss-left {
  background: linear-gradient(90deg, rgba(255,255,255,.05), transparent);
  padding-left: clamp(5rem, 9vw, 8rem);
}
.txss-panel__heading {
  font-size: clamp(2.8rem, 5.8vw, 6.6rem);
  letter-spacing: 0;
}
.txss-panel__desc {
  max-width: 560px;
}
.txss-visual__card {
  border-radius: 1.25rem;
  box-shadow: 0 32px 110px rgba(0,0,0,.32);
}
.txss-visual__chips {
  transform: translateY(-.5rem);
}

.tx-protocol {
  padding: var(--tx-pad) clamp(1.25rem, 5vw, 5rem);
}
.tx-protocol__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}
.tx-step {
  background: #fff;
  color: #111;
  border-color: rgba(0,0,0,.08);
  padding: clamp(1.5rem, 3vw, 2rem);
}
.tx-step__num {
  color: rgba(0,0,0,.22);
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .18em;
}
.tx-step__icon {
  display: none;
}

.tx-global__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 90px minmax(0, 1fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: stretch;
}
.tx-global__card {
  min-height: 520px;
  padding: clamp(1.5rem, 4vw, 3rem);
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.tx-flag {
  font-size: 1rem !important;
  font-weight: 900;
  letter-spacing: .14em;
  color: var(--tx-neon);
}

.tx-testimonials {
  padding: var(--tx-pad) clamp(1.25rem, 5vw, 5rem) !important;
}
.tx-testimonials__header {
  max-width: 980px !important;
  text-align: left !important;
  margin: 0 0 clamp(3rem, 7vw, 6rem) !important;
}
.tx-testimonials__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.tx-testimonial-card {
  background: #fff;
  border-color: rgba(0,0,0,.08);
  color: #111;
  border-radius: 1.25rem;
}

.tx-cta {
  min-height: 82vh;
  display: flex;
  align-items: center;
}

.tx-reveal-card {
  will-change: transform, opacity;
}

@media (max-width: 1024px) {
  .tx-hero__inner,
  .tx-index__header,
  .tx-why__inner,
  .tx-global__grid {
    grid-template-columns: 1fr;
  }
  .tx-hero__visual {
    min-height: 420px;
  }
  .tx-global__bridge {
    display: none;
  }
  .tx-protocol__steps,
  .tx-testimonials__grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .tx-hero {
    padding-top: 7rem;
  }
  .tx-hero__headline,
  .tx-why__headline,
  .tx-protocol__headline,
  .tx-global__headline,
  .tx-cta__headline {
    font-size: clamp(3rem, 16vw, 5.2rem);
  }
  .tx-hero__visual {
    min-height: 360px;
  }
  .tx-hero-card--main {
    inset: 0;
    min-height: 280px;
  }
  .tx-hero-card--float {
    right: 0;
    bottom: 3rem;
  }
  .tx-hero-card--mini {
    width: 190px;
    bottom: 0;
  }
  .txss-wrap {
    height: auto;
  }
  .txss-left {
    padding-left: 1.5rem;
  }
  .txss-sticky {
    position: relative;
    height: auto;
    min-height: auto;
  }
  .txss-left,
  .txss-right {
    min-height: auto;
  }
  .txss-panel,
  .txss-visual {
    position: relative;
    display: none;
    min-height: auto;
    padding-block: 4rem;
  }
  .txss-panel.is-active,
  .txss-visual.is-active {
    display: flex;
  }
  .txss-panel__heading {
    font-size: clamp(2.4rem, 12vw, 4rem);
  }
  .tx-index__row {
    min-height: auto;
    padding: 1.5rem 0 !important;
  }
  .tx-index__price {
    margin-right: 0;
  }
}

/* Sticky service presenter: one active service per pinned screen */
.tj-services--pinned {
  width: 100%;
  margin: 0;
  padding: 0;
}
.tj-services-track {
  height: calc(var(--service-count, 5) * 100vh);
  min-height: 500vh;
  position: relative;
}
.tj-services-sticky {
  position: sticky;
  top: 0;
  height: 100vh;
  width: var(--tj-shell);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: visible;
}
.tj-services-heading {
  position: absolute;
  top: clamp(2.6rem, 5vw, 4rem);
  left: 0;
  right: 0;
  z-index: 4;
  pointer-events: none;
}
.tj-services--pinned .tj-section-kicker {
  margin: 0 10% .4rem auto;
}
.tj-services--pinned h2 {
  margin: 0;
  text-align: center;
  font-family: var(--tj-serif);
  font-size: clamp(4.8rem, 7.2vw, 8.5rem);
  line-height: .8;
  font-weight: 400;
  letter-spacing: -.055em;
}
.tj-services--pinned h2 span {
  color: var(--tj-blue);
}
.tj-services-presenter {
  display: grid;
  grid-template-columns: minmax(320px, .42fr) minmax(0, .58fr);
  gap: clamp(1.25rem, 3vw, 2.5rem);
  align-items: center;
  padding-top: clamp(7rem, 12vw, 10rem);
}
.tj-service-content,
.tj-service-demo {
  height: min(62vh, 620px);
  min-height: 430px;
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.tj-service-slide,
.tj-demo-panel {
  position: absolute;
  inset: 0;
  opacity: 0;
  visibility: hidden;
  z-index: 0;
  pointer-events: none;
}
.tj-service-slide.is-active,
.tj-demo-panel.is-active {
  opacity: 1;
  visibility: visible;
  z-index: 2;
  pointer-events: auto;
}
.tj-services--pinned .tj-service-slide:not(.is-active),
.tj-services--pinned .tj-demo-panel:not(.is-active) {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}
.tj-service-slide {
  background: rgba(255,255,255,.56);
  border: 1px solid rgba(21,21,21,.08);
  padding: clamp(1.6rem, 3vw, 2.4rem);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  transform: translateY(46px);
  will-change: transform, opacity, filter;
}
.tj-service-slide small {
  color: var(--tj-muted);
  font-family: "Geist Mono", monospace;
  margin-bottom: auto;
}
.tj-service-slide h3 {
  margin: 0;
  max-width: 560px;
  font-size: clamp(2.6rem, 4vw, 5rem);
  line-height: .92;
  letter-spacing: -.06em;
  font-weight: 500;
}
.tj-service-slide p {
  max-width: 560px;
  margin: 1rem 0 2rem;
  color: #5b5b5b;
  font-size: clamp(1rem, 1.3vw, 1.25rem);
  line-height: 1.45;
}
.tj-service-slide dl {
  width: min(100%, 520px);
  margin: auto 0 1.4rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .65rem 1rem;
}
.tj-service-slide dt {
  color: var(--tj-muted);
}
.tj-service-slide dd {
  margin: 0;
  font-weight: 800;
}
.tj-service-demo {
  border-radius: .22rem;
}
.tj-service-tabs {
  position: absolute;
  top: 50%;
  right: clamp(.8rem, 1.8vw, 1.35rem);
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .55rem;
  z-index: 12;
}
.tj-service-tabs button {
  width: 2.65rem;
  height: 2.65rem;
  border: 1px solid rgba(246,246,244,.24);
  border-radius: 999px;
  background: rgba(246,246,244,.08);
  color: rgba(246,246,244,.76);
  backdrop-filter: blur(12px);
  font: 800 .78rem/1 var(--tj-sans);
  cursor: pointer;
  box-shadow: 0 12px 34px rgba(0,0,0,.18);
  transition: background .25s, color .25s, border-color .25s, transform .25s;
}
.tj-service-tabs button.is-active {
  background: var(--tj-blue);
  border-color: var(--tj-blue);
  color: #fff;
  transform: scale(1.08);
}
.tj-demo-panel {
  overflow: hidden;
  border-radius: .22rem;
  background:
    radial-gradient(circle at 68% 18%, rgba(23,16,230,.28), transparent 14rem),
    radial-gradient(circle at 18% 82%, rgba(255,255,255,.08), transparent 18rem),
    linear-gradient(135deg, rgba(255,255,255,.055), transparent),
    #262626;
  color: #f6f6f4;
  transform: scale(.96) translateY(24px);
  will-change: transform, opacity, filter;
  box-shadow: 0 24px 70px rgba(0,0,0,.1);
}
.tj-demo-panel > span {
  position: absolute;
  top: -.15rem;
  right: -.15rem;
  width: 1.45rem;
  height: 1.45rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--tj-blue);
  color: #fff;
  font-size: .68rem;
  font-weight: 900;
  z-index: 5;
}
.tj-demo-panel > b {
  position: absolute;
  left: clamp(1.5rem, 3vw, 2.2rem);
  bottom: clamp(1.1rem, 3vw, 2rem);
  max-width: 76%;
  font-family: var(--tj-serif);
  font-size: clamp(3rem, 5vw, 6.6rem);
  font-weight: 400;
  line-height: .82;
  letter-spacing: -.06em;
  opacity: .12;
  z-index: 2;
}
.tj-demo-window {
  position: absolute;
  left: 12%;
  top: 15%;
  width: 72%;
  height: 48%;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 1rem;
  background:
    linear-gradient(90deg, rgba(255,255,255,.1) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.1) 1px, transparent 1px),
    rgba(255,255,255,.035);
  background-size: 34px 34px;
}
.tj-demo-window i {
  position: absolute;
  top: .9rem;
  width: .42rem;
  height: .42rem;
  border-radius: 50%;
  background: rgba(255,255,255,.28);
}
.tj-demo-window i:nth-child(1) { left: 1rem; }
.tj-demo-window i:nth-child(2) { left: 1.8rem; }
.tj-demo-window i:nth-child(3) { left: 2.6rem; }
.tj-demo-window strong {
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: 14%;
  height: 28%;
  border-radius: .9rem;
  background: linear-gradient(90deg, var(--tj-blue), #37d5a7, #e9ff4d);
  transform-origin: left center;
}
.tj-demo-notes {
  position: absolute;
  right: clamp(1rem, 2vw, 1.6rem);
  bottom: clamp(1rem, 2vw, 1.6rem);
  display: grid;
  gap: .45rem;
  width: min(230px, 42%);
}
.tj-demo-notes p {
  margin: 0;
  padding: .6rem .8rem;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.045);
  color: rgba(246,246,244,.7);
  font-size: .78rem;
}
.tj-demo-progress {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: rgba(255,255,255,.08);
}
.tj-demo-progress i {
  display: block;
  width: 100%;
  height: 100%;
  background: var(--tj-blue);
  transform: scaleX(.2);
  transform-origin: left center;
}
.tj-service-slide,
.tj-demo-panel {
  cursor: pointer;
}
.tj-service-slide:focus-visible,
.tj-demo-panel:focus-visible {
  outline: 3px solid var(--tj-blue);
  outline-offset: 5px;
}

@media (max-width: 980px) {
  .tj-services-track {
    height: auto;
    min-height: 0;
  }
  .tj-services-sticky {
    position: relative;
    height: auto;
    overflow: visible;
    padding: 5rem 0;
  }
  .tj-services-heading {
    position: relative;
    top: auto;
    margin-bottom: 2rem;
  }
  .tj-services-presenter {
    grid-template-columns: 1fr;
    padding-top: 0;
  }
  .tj-service-content,
  .tj-service-demo {
    height: auto;
    min-height: 0;
  }
  .tj-service-slide,
  .tj-demo-panel {
    position: relative;
    inset: auto;
    opacity: 1 !important;
    visibility: visible !important;
    z-index: auto !important;
    transform: none !important;
    pointer-events: auto;
    margin-bottom: 1rem;
  }
  .tj-demo-panel {
    min-height: 360px;
    display: none;
  }
  .tj-demo-panel.is-active {
    display: block;
  }
  .tj-service-tabs {
    position: relative;
    top: auto;
    right: auto;
    transform: none;
    flex-direction: row;
    flex-wrap: wrap;
    margin-bottom: 1rem;
  }
  .tj-service-tabs button {
    background: rgba(255,255,255,.78);
    border-color: rgba(21,21,21,.14);
    color: #151515;
  }
  .tj-service-tabs button.is-active {
    color: #fff;
  }
}

/* --------------------------------------------------------
   Premium inner pages aligned with the Tanuja-style homepage
-------------------------------------------------------- */
.txp-page {
  --txp-blue: #1710e6;
  --txp-black: #151515;
  --txp-ink: #262626;
  --txp-paper: #f6f6f4;
  --txp-muted: #666;
  --txp-serif: "TJ Instrument", "Times New Roman", serif;
  --txp-sans: "Plus Jakarta Sans", Inter, ui-sans-serif, system-ui, sans-serif;
  background: var(--txp-paper);
  color: var(--txp-black);
  font-family: var(--txp-sans);
  overflow: clip;
}
.txp-page a { text-decoration: none; }
.txp-shell {
  width: min(1760px, calc(100vw - clamp(1rem, 7vw, 9.5rem)));
  margin-inline: auto;
}
.txp-hero {
  min-height: min(820px, 92svh);
  padding: clamp(8rem, 16vw, 12rem) 0 clamp(4rem, 9vw, 8rem);
  display: grid;
  align-items: center;
  position: relative;
}
.txp-hero--dark,
.txp-dark {
  background: #151515;
  color: #f6f6f4;
}
.txp-dark .txp-section-head p,
.txp-dark .txp-lede {
  color: rgba(246,246,244,.64);
}
.txp-hero--blue {
  background: linear-gradient(135deg, #1d16f0 0%, #1710e6 48%, #0d086d 100%);
  color: #fff;
}
.txp-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
  gap: clamp(2rem, 6vw, 7rem);
  align-items: end;
}
.txp-kicker {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  margin-bottom: 1.4rem;
  color: var(--txp-blue);
  font-size: .76rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.txp-kicker::before {
  content: "";
  width: .62rem;
  height: .62rem;
  border-radius: 50%;
  background: currentColor;
}
.txp-hero--dark .txp-kicker,
.txp-dark .txp-kicker { color: #37d5a7; }
.txp-title {
  margin: 0;
  max-width: 1050px;
  font-family: var(--txp-serif);
  font-weight: 400;
  font-size: clamp(4.8rem, 9vw, 12rem);
  line-height: .92;
  letter-spacing: -.06em;
}
.txp-title em,
.txp-serif {
  font-family: var(--txp-serif);
  font-style: italic;
  font-weight: 400;
}
.txp-dot { color: var(--txp-blue); }
.txp-lede {
  max-width: 720px;
  margin: 1.5rem 0 0;
  color: rgba(21,21,21,.62);
  font-size: clamp(1.05rem, 1.55vw, 1.55rem);
  line-height: 1.55;
}
.txp-hero--dark .txp-lede,
.txp-dark .txp-lede,
.txp-hero--blue .txp-lede { color: rgba(246,246,244,.68); }
.txp-section {
  padding: clamp(5rem, 10vw, 10rem) 0;
}
.txp-section--tight {
  padding: clamp(3.5rem, 7vw, 7rem) 0;
}
.txp-section-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: clamp(2rem, 5vw, 5rem);
}
.txp-section-head h2 {
  margin: 0;
  font-family: var(--txp-serif);
  font-size: clamp(4rem, 7vw, 9rem);
  font-weight: 400;
  line-height: .86;
  letter-spacing: -.06em;
}
.txp-section-head p {
  max-width: 520px;
  margin: 0;
  color: var(--txp-muted);
  line-height: 1.65;
}
.txp-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.6rem);
}
.txp-grid--2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.txp-card {
  min-height: 320px;
  display: flex;
  flex-direction: column;
  padding: clamp(1.45rem, 3vw, 2.7rem);
  border: 1px solid rgba(21,21,21,.08);
  background: rgba(255,255,255,.54);
  color: #151515;
  transition: transform .35s ease, border-color .35s ease, background .35s ease, box-shadow .35s ease;
}
.txp-card:hover {
  transform: translateY(-8px);
  border-color: rgba(23,16,230,.28);
  background: #fff;
  box-shadow: 0 24px 70px rgba(0,0,0,.08);
}
.txp-card small,
.txp-row small {
  color: var(--txp-muted);
  font-family: "Geist Mono", ui-monospace, monospace;
}
.txp-card h3 {
  margin: auto 0 .9rem;
  font-size: clamp(1.9rem, 3vw, 3.5rem);
  line-height: .95;
  letter-spacing: -.055em;
  font-weight: 500;
}
.txp-card p {
  margin: 0 0 1.35rem;
  color: #5b5b5b;
  line-height: 1.55;
}
.txp-card-meta {
  margin-top: auto;
  padding-top: 1.3rem;
  border-top: 1px solid rgba(21,21,21,.08);
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  color: #5b5b5b;
  font-weight: 800;
}
.txp-actions {
  margin-top: auto;
  padding-top: 1.35rem;
  display: grid;
  gap: .72rem;
}
.txp-action-primary,
.txp-action-secondary {
  min-height: 3.25rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
  text-decoration: none;
  font: 900 .82rem/1 "Plus Jakarta Sans", Inter, ui-sans-serif, system-ui, sans-serif;
  letter-spacing: .03em;
  transition: transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
.txp-action-primary {
  width: 100%;
  background: var(--txp-blue);
  color: #fff;
  box-shadow: 0 18px 42px rgba(23,16,230,.22);
}
.txp-action-secondary {
  width: 100%;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(21,21,21,.1);
  color: #151515;
}
.txp-action-whatsapp {
  background: #37d5a7;
  border-color: #37d5a7;
}
.txp-action-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .7rem;
}
.txp-action-primary:hover,
.txp-action-secondary:hover {
  transform: translateY(-2px);
}
.txp-blue-panel .txp-action-secondary,
.txp-dark .txp-action-secondary {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.16);
  color: #fff;
}
.txp-blue-panel .txp-action-whatsapp,
.txp-dark .txp-action-whatsapp {
  background: #37d5a7;
  border-color: #37d5a7;
  color: #151515;
}
.txp-button,
.txp-button-dark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .7rem;
  min-height: 3.7rem;
  padding: .25rem 1.6rem;
  border-radius: 999px;
  font-size: .82rem;
  font-weight: 900;
  letter-spacing: .06em;
  color: #fff;
  background: var(--txp-blue);
  box-shadow: 0 18px 38px rgba(23,16,230,.18);
  transition: transform .28s ease, box-shadow .28s ease;
}
.txp-button:hover,
.txp-button-dark:hover {
  transform: translateY(-3px);
  box-shadow: 0 26px 60px rgba(23,16,230,.24);
}
.txp-button-dark {
  background: #151515;
}
.txp-visual {
  min-height: 440px;
  border-radius: .24rem;
  background:
    radial-gradient(circle at 70% 18%, rgba(23,16,230,.24), transparent 14rem),
    linear-gradient(135deg, rgba(255,255,255,.08), transparent),
    #262626;
  position: relative;
  overflow: hidden;
}
.txp-visual::before {
  content: "";
  position: absolute;
  inset: 13% 10% 28%;
  border: 1px solid rgba(255,255,255,.12);
  background:
    linear-gradient(90deg, rgba(255,255,255,.1) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.1) 1px, transparent 1px);
  background-size: 36px 36px;
}
.txp-visual::after {
  content: "";
  position: absolute;
  left: 16%;
  right: 16%;
  top: 48%;
  height: 72px;
  border-radius: 1rem;
  background: linear-gradient(90deg, #1710e6, #37d5a7, #e9ff4d);
}
.txp-visual b {
  position: absolute;
  left: 7%;
  bottom: 8%;
  max-width: 70%;
  font-family: var(--txp-serif);
  font-size: clamp(4rem, 6vw, 7.5rem);
  font-weight: 400;
  line-height: .8;
  color: rgba(246,246,244,.12);
  letter-spacing: -.06em;
}
.txp-row {
  display: grid;
  grid-template-columns: minmax(260px, 1.2fr) minmax(180px, .8fr) minmax(130px, auto);
  align-items: center;
  gap: 1.5rem;
  min-height: 6.8rem;
  border-top: 1px solid rgba(246,246,244,.16);
  color: rgba(246,246,244,.92);
}
.txp-row:last-child {
  border-bottom: 1px solid rgba(246,246,244,.16);
}
.txp-row strong {
  font-family: var(--txp-serif);
  font-size: clamp(2.1rem, 3.6vw, 4.2rem);
  font-weight: 400;
  letter-spacing: -.055em;
}
.txp-row span,
.txp-row em {
  color: rgba(246,246,244,.48);
  font-style: normal;
  font-weight: 800;
}
.txp-blue-panel {
  background: linear-gradient(135deg, #1d16f0, #100b86);
  color: #fff;
}
.txp-blue-panel .txp-card {
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.14);
  color: #fff;
}
.txp-blue-panel .txp-card p,
.txp-blue-panel .txp-card-meta {
  color: rgba(255,255,255,.82);
}
.txp-blue-panel .txp-card small {
  color: rgba(255,255,255,.56);
}
.txp-blue-panel .txp-card h3 {
  color: #fff;
}

.txp-about-hero-grid {
  align-items: center;
}
.txp-about-hero-copy {
  align-self: center;
  padding-top: clamp(1rem, 6vw, 5rem);
}
.txp-about-visual {
  background:
    radial-gradient(circle at 70% 20%, rgba(23,16,230,.32), transparent 13rem),
    radial-gradient(circle at 18% 80%, rgba(55,213,167,.16), transparent 13rem),
    linear-gradient(135deg, rgba(255,255,255,.09), transparent),
    #1c1c1f;
  box-shadow: 0 28px 90px rgba(21,21,21,.13);
}
.txp-about-visual::before {
  inset: 10% 9% 20%;
  border-radius: 1.1rem;
  background:
    linear-gradient(90deg, rgba(255,255,255,.09) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.09) 1px, transparent 1px),
    rgba(255,255,255,.035);
  background-size: 42px 42px;
}
.txp-about-visual::after {
  left: 14%;
  right: 26%;
  top: 54%;
  height: 58px;
  border-radius: 999px;
}
.txp-about-visual b {
  max-width: 88%;
}
.txp-about-visual__panel {
  position: absolute;
  top: 18%;
  right: 10%;
  width: min(340px, 48%);
  padding: 1.1rem;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: #f6f6f4;
  z-index: 4;
}
.txp-about-visual__panel span {
  display: block;
  margin-bottom: .7rem;
  color: rgba(246,246,244,.52);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.txp-about-visual__panel strong {
  display: block;
  font-size: clamp(.95rem, 1.2vw, 1.2rem);
  line-height: 1.4;
}
.txp-about-visual__panel i {
  display: block;
  height: 6px;
  margin-top: 1rem;
  border-radius: 999px;
  background: linear-gradient(90deg, #1710e6, #37d5a7);
}
.txp-form {
  display: grid;
  gap: 1rem;
}
.txp-input,
.txp-select,
.txp-textarea {
  width: 100%;
  border: 1px solid rgba(21,21,21,.1);
  background: rgba(255,255,255,.8);
  padding: 1.15rem 1.2rem;
  color: #151515;
  outline: none;
  transition: border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.txp-textarea { min-height: 160px; resize: vertical; }
.txp-input:focus,
.txp-select:focus,
.txp-textarea:focus {
  background: #fff;
  border-color: var(--txp-blue);
  box-shadow: 0 0 0 4px rgba(23,16,230,.08);
}
.txp-label {
  display: block;
  margin-bottom: .55rem;
  color: rgba(21,21,21,.52);
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.txp-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1);
  transition: filter .6s ease, transform .8s ease;
}
.txp-card:hover .txp-image,
.txp-image:hover {
  filter: grayscale(0);
  transform: scale(1.045);
}

@media (max-width: 1024px) {
  .txp-hero-grid,
  .txp-grid,
  .txp-grid--2 {
    grid-template-columns: 1fr;
  }
  .txp-row {
    grid-template-columns: 1fr;
    gap: .55rem;
    padding: 1.4rem 0;
  }
  .txp-section-head {
    display: block;
  }
  .txp-section-head p {
    margin-top: 1rem;
  }
}

@media (max-width: 640px) {
  .txp-shell {
    width: min(100% - 1.2rem, 1760px);
  }
  .txp-hero {
    min-height: auto;
    padding-top: 7.4rem;
  }
  .txp-title {
    font-size: clamp(4rem, 18vw, 6.4rem);
  }
  .txp-card {
    min-height: 260px;
  }
  .txp-visual {
    min-height: 320px;
  }
  .txp-action-row {
    grid-template-columns: 1fr;
  }
}

/* --------------------------------------------------------
   Tanuja-style Texora homepage
-------------------------------------------------------- */
@font-face {
  font-family: "TJ Instrument";
  src: url("https://fonts.gstatic.com/s/instrumentserif/v5/jizBRFtNs2ka5fXjeivQ4LroWlx-2zcZj1bIkNo.woff2") format("woff2");
  font-display: swap;
  font-style: normal;
  font-weight: 400;
}
@font-face {
  font-family: "TJ Instrument";
  src: url("https://fonts.gstatic.com/s/instrumentserif/v5/jizHRFtNs2ka5fXjeivQ4LroWlx-6zATjnTNgNq55w.woff2") format("woff2");
  font-display: swap;
  font-style: italic;
  font-weight: 400;
}

body:has(.tj-page) {
  background: #f6f6f4 !important;
  color: #151515;
}
body:has(.tj-page) .tx-site-nav {
  background: transparent;
  box-shadow: none;
}
body:has(.tj-page) .tx-site-nav::before,
body:has(.tj-page) .tx-site-nav::after {
  display: none;
}
body:has(.tj-page) .noise-overlay,
body:has(.tj-page) #tx-cursor,
body:has(.tj-page) #tx-cursor-dot {
  display: none !important;
}

.tj-page {
  --tj-blue: #1710e6;
  --tj-blue-deep: #100b86;
  --tj-green: #8cc651;
  --tj-black: #151515;
  --tj-ink: #262626;
  --tj-paper: #f6f6f4;
  --tj-muted: #5b5b5b;
  --tj-shell: min(1760px, calc(100vw - clamp(1rem, 7vw, 9.5rem)));
  --tj-serif: "TJ Instrument", "Times New Roman", serif;
  --tj-sans: "Plus Jakarta Sans", Inter, ui-sans-serif, system-ui, sans-serif;
  background: var(--tj-paper);
  color: var(--tj-black);
  font-family: var(--tj-sans);
  overflow: clip;
}

.tj-page a {
  color: inherit;
  text-decoration: none;
}

.tj-hero {
  min-height: 100svh;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 7.5rem clamp(1rem, 4vw, 4.6rem) 2rem;
}

.tj-topline {
  width: var(--tj-shell);
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 1.8rem;
  color: #151515;
  font-size: clamp(.78rem, .9vw, 1rem);
  line-height: 1;
  letter-spacing: .12em;
  text-transform: uppercase;
  position: relative;
  z-index: 10;
}
.tj-clock {
  color: var(--tj-blue);
}
.tj-open {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  letter-spacing: .04em;
  text-transform: none;
}
.tj-open i {
  width: .72rem;
  height: .72rem;
  border-radius: 50%;
  background: var(--tj-green);
}

.tj-nav-shell {
  width: min(1450px, calc(100vw - clamp(2rem, 16vw, 21rem)));
  min-height: 4rem;
  margin-top: -1.15rem;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1rem;
  padding: .65rem .9rem .65rem 1.1rem;
  border-radius: 999px;
  background: #50515a;
  color: #f8f8f8;
  box-shadow: 0 18px 40px rgba(25, 25, 25, .12);
  position: sticky;
  top: .8rem;
  z-index: 50;
}
.tj-brand,
.tj-nav-shell a {
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .11em;
  text-transform: uppercase;
}
.tj-brand {
  justify-self: start;
}
.tj-nav-links,
.tj-nav-actions {
  display: flex;
  align-items: center;
  gap: clamp(1rem, 2vw, 1.7rem);
}
.tj-nav-links {
  justify-self: center;
}
.tj-nav-actions {
  justify-self: end;
}
.tj-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2.55rem;
  padding: .2rem 1.35rem;
  border-radius: 999px;
  background: #37d5a7;
  color: #111 !important;
}
.tj-nav-dropdown {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 3rem;
}
.tj-nav-dropdown > button {
  border: 0;
  background: transparent;
  color: #f8f8f8;
  cursor: pointer;
  font: 900 .78rem/1 var(--tj-sans);
  letter-spacing: .11em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  padding: .8rem 0;
}
.tj-nav-dropdown > button span {
  font-size: .9rem;
  opacity: .55;
  transform: translateY(-1px);
  transition: transform .25s ease;
}
.tj-nav-dropdown:hover > button span,
.tj-nav-dropdown:focus-within > button span {
  transform: rotate(180deg) translateY(1px);
}
.tj-nav-menu {
  position: absolute;
  top: calc(100% + .9rem);
  left: 50%;
  width: min(330px, calc(100vw - 2rem));
  transform: translateX(-50%) translateY(10px) scale(.98);
  padding: .65rem;
  border-radius: 1.35rem;
  background: rgba(80, 81, 90, .96);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 28px 70px rgba(21,21,21,.2);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .22s ease, transform .22s ease, visibility .22s ease;
}
.tj-nav-menu::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: -.95rem;
  height: .95rem;
}
.tj-nav-dropdown:hover .tj-nav-menu,
.tj-nav-dropdown:focus-within .tj-nav-menu {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0) scale(1);
}
.tj-nav-menu a {
  display: block;
  padding: .92rem 1rem;
  border-radius: .9rem;
  transition: background .2s ease, transform .2s ease;
}
.tj-nav-menu a:hover {
  background: rgba(255,255,255,.08);
  transform: translateX(3px);
}
.tj-nav-menu strong {
  display: block;
  color: #fff;
  font-size: .88rem;
  line-height: 1.1;
  letter-spacing: 0;
  text-transform: none;
}
.tj-nav-menu small {
  display: block;
  margin-top: .3rem;
  color: rgba(255,255,255,.48);
  font-size: .68rem;
  line-height: 1.35;
  letter-spacing: .02em;
  text-transform: none;
}

.tj-hero-copy {
  width: var(--tj-shell);
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: clamp(1rem, 4vw, 4rem) 0 4.7rem;
}
.tj-hero-copy h1 {
  margin: 0;
  font-family: var(--tj-serif);
  font-weight: 400;
  font-size: clamp(5.8rem, 8.35vw, 10.4rem);
  line-height: 1.04;
  letter-spacing: -.055em;
  color: #151515;
}
.tj-hero-copy h1 span {
  display: block;
}
.tj-hero-copy p {
  max-width: 690px;
  margin: clamp(1.5rem, 3vw, 2.6rem) auto 0;
  font-size: clamp(1rem, 1.25vw, 1.25rem);
  line-height: 1.55;
  color: #151515;
}

.tj-floating-cta {
  position: fixed;
  left: 50%;
  bottom: 4.85rem;
  transform: translateX(-50%);
  z-index: 60;
  display: flex;
  align-items: center;
  gap: .85rem;
  filter: drop-shadow(0 20px 30px rgba(0,0,0,.18));
}
.tj-cta-primary,
.tj-cta-secondary {
  min-height: 4rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  border-radius: 999px;
  padding: .4rem 2rem;
  font-size: 1rem;
  font-weight: 900;
  letter-spacing: -.04em;
  white-space: nowrap;
}
.tj-cta-primary {
  background: #12192d;
  color: #fff !important;
}
.tj-cta-secondary {
  background: rgba(255,255,255,.86);
  border: 1px solid rgba(21,21,21,.22);
  color: #12192d !important;
  backdrop-filter: blur(16px);
}
.tj-cta-primary span {
  font-size: 1.35rem;
  line-height: 1;
}

.tj-mini-menu {
  position: fixed;
  left: 50%;
  bottom: 1.55rem;
  transform: translateX(-50%);
  z-index: 60;
  display: flex;
  align-items: center;
  gap: .25rem;
}
.tj-mini-menu button,
.tj-mini-menu a {
  height: 3rem;
  border: 0;
  background: #252525;
  color: #fff;
  padding: 0 1.45rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  letter-spacing: -.03em;
}
.tj-mini-menu button {
  width: 3rem;
  padding: 0;
  border-radius: 999px;
  font-size: 2.1rem;
  font-weight: 300;
}
.tj-mini-menu a:last-child {
  border-radius: 0 999px 999px 0;
}

.tj-blue-panel {
  width: var(--tj-shell);
  min-height: 86vh;
  margin: 0 auto clamp(4rem, 7vw, 7rem);
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, .96fr);
  gap: clamp(2rem, 5vw, 5rem);
  padding: clamp(4rem, 6vw, 5.8rem) clamp(2rem, 5vw, 4.8rem);
  background:
    radial-gradient(circle at 74% 8%, rgba(255,255,255,.15), transparent 18rem),
    linear-gradient(135deg, #1d18e9, #0c087a 62%, #09045d);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.tj-blue-panel::before {
  content: "Linear";
  position: absolute;
  left: 50%;
  top: 1.1rem;
  transform: translateX(-50%);
  padding: .85rem 4.4rem .85rem 5.4rem;
  border-radius: .15rem;
  background: rgba(255,255,255,.94);
  color: #292929;
  font-size: 1.15rem;
  box-shadow: 0 0 0 1px rgba(255,255,255,.25);
}
.tj-blue-panel::after {
  content: "";
  position: absolute;
  top: 1.55rem;
  left: calc(50% - 5.8rem);
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 50%;
  background: var(--tj-blue);
  z-index: 1;
}
.tj-blue-copy,
.tj-blue-cards {
  position: relative;
  z-index: 2;
}
.tj-blue-copy > p {
  margin: 0 0 1.4rem;
  color: #e9ff4d;
  font-size: .8rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.tj-blue-copy h2 {
  margin: 0;
  max-width: 760px;
  font-size: clamp(3rem, 5.2vw, 6.2rem);
  line-height: 1.02;
  letter-spacing: -.06em;
  font-weight: 900;
}
.tj-blue-copy h2 em {
  font-family: var(--tj-serif);
  color: #e9ff4d;
  font-weight: 400;
}
.tj-blue-copy > span {
  display: block;
  max-width: 760px;
  margin-top: 1.8rem;
  font-size: clamp(1.1rem, 1.55vw, 1.7rem);
  line-height: 1.45;
  color: rgba(255,255,255,.82);
}
.tj-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.4rem;
  margin-top: 2.8rem;
}
.tj-stats strong {
  display: grid;
  gap: .5rem;
  font-size: clamp(1.8rem, 2.6vw, 3rem);
  line-height: 1;
}
.tj-stats small {
  font-size: .9rem;
  color: rgba(255,255,255,.7);
  font-weight: 500;
}
.tj-blue-cards {
  display: grid;
  align-content: start;
  gap: .9rem;
  padding-top: 3.2rem;
}
.tj-blue-cards article {
  border: 1px solid rgba(255,255,255,.13);
  border-radius: .85rem;
  background: rgba(255,255,255,.08);
  padding: 1.35rem 1.55rem;
  display: grid;
  gap: .45rem;
}
.tj-blue-cards b {
  font-size: clamp(1.1rem, 1.5vw, 1.5rem);
}
.tj-blue-cards span {
  color: rgba(255,255,255,.7);
  line-height: 1.45;
}

.tj-services {
  width: var(--tj-shell);
  margin: 0 auto;
  padding: clamp(2rem, 5vw, 4rem) 0 clamp(4rem, 8vw, 8rem);
}
.tj-section-kicker {
  width: fit-content;
  margin: 0 14% .3rem auto;
  padding: .65rem 1rem;
  background: #262626;
  color: #f6f6f4;
  font-size: .72rem;
  line-height: 1.1;
}
.tj-services h2 {
  margin: 0 0 clamp(2.5rem, 5vw, 4.6rem);
  text-align: center;
  font-family: var(--tj-serif);
  font-size: clamp(5rem, 8vw, 10rem);
  line-height: .8;
  font-weight: 400;
  letter-spacing: -.055em;
}
.tj-services h2 span {
  color: var(--tj-blue);
}
.tj-service-stack {
  display: grid;
  gap: clamp(1.2rem, 2vw, 2rem);
}
.tj-service-card {
  display: grid;
  grid-template-columns: minmax(280px, .42fr) minmax(0, .58fr);
  gap: clamp(1rem, 2vw, 1.8rem);
  min-height: 330px;
  color: #151515;
  align-items: start;
}
.tj-service-copy {
  padding: clamp(1.2rem, 2vw, 1.7rem);
  background: rgba(255,255,255,.5);
  border: 1px solid rgba(21,21,21,.08);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.tj-service-copy small {
  font-family: "Geist Mono", monospace;
  color: var(--tj-muted);
  margin-bottom: 1.8rem;
}
.tj-service-copy h3 {
  margin: 0;
  font-size: clamp(1.35rem, 2vw, 2.1rem);
  line-height: 1.05;
  letter-spacing: -.045em;
}
.tj-service-copy p {
  margin: .9rem 0 1.4rem;
  color: #4d4d4d;
  line-height: 1.45;
}
.tj-service-copy dl {
  width: 100%;
  margin: auto 0 1.2rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: .5rem 1rem;
  font-size: .83rem;
}
.tj-service-copy dt {
  color: var(--tj-muted);
}
.tj-service-copy dd {
  margin: 0;
  font-weight: 700;
}
.tj-case-link {
  display: inline-flex;
  align-items: center;
  min-height: 2.2rem;
  padding: 0 .85rem;
  background: var(--tj-blue);
  color: #fff;
  border-radius: .15rem;
  font-size: .78rem;
  font-weight: 800;
}
.tj-service-visual {
  min-height: 330px;
  border-radius: .2rem;
  background:
    radial-gradient(circle at 72% 20%, rgba(23,16,230,.2), transparent 14rem),
    radial-gradient(circle at 20% 85%, rgba(255,255,255,.08), transparent 18rem),
    linear-gradient(135deg, rgba(255,255,255,.05), transparent),
    #262626;
  color: #f6f6f4;
  position: sticky;
  top: 6rem;
  will-change: transform, opacity;
  transform-origin: center;
  box-shadow: 0 22px 60px rgba(0,0,0,.08);
}
.tj-service-visual::before {
  content: "";
  position: relative;
  display: block;
  width: min(72%, 520px);
  height: 52%;
  margin: clamp(2rem, 5vw, 4rem) auto 0;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: .9rem;
  background:
    linear-gradient(90deg, rgba(255,255,255,.12) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255,255,255,.1) 1px, transparent 1px),
    rgba(255,255,255,.035);
  background-size: 34px 34px;
}
.tj-service-visual::after {
  content: "";
  position: absolute;
  left: 18%;
  top: 38%;
  width: 50%;
  height: 24%;
  border-radius: .75rem;
  background: linear-gradient(90deg, var(--tj-blue), #9ff0d1);
  opacity: .82;
}
.tj-service-visual {
  overflow: hidden;
  display: flex;
  align-items: flex-end;
  padding: 1.5rem;
}
.tj-service-visual span {
  position: absolute;
  right: -.2rem;
  top: -.2rem;
  width: 1.3rem;
  height: 1.3rem;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--tj-blue);
  color: #fff;
  font-size: .62rem;
  font-weight: 900;
}
.tj-service-visual b {
  max-width: 70%;
  font-family: var(--tj-serif);
  font-weight: 400;
  font-size: clamp(2.4rem, 4vw, 5rem);
  line-height: .86;
  letter-spacing: -.055em;
  opacity: .12;
  position: relative;
  z-index: 2;
}

.tj-service-card:nth-child(even) .tj-service-visual::after {
  background: linear-gradient(90deg, #37d5a7, #e9ff4d);
}
.tj-service-card:nth-child(3n) .tj-service-visual::after {
  background: linear-gradient(90deg, var(--tj-blue), #ffffff);
}

.tj-blogs {
  width: var(--tj-shell);
  margin: 0 auto clamp(2rem, 5vw, 4rem);
  padding: clamp(4rem, 7vw, 7rem) 0;
}
.tj-blogs-head {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 1rem;
  margin-bottom: clamp(2rem, 5vw, 4rem);
}
.tj-blogs-head span {
  grid-column: 1 / -1;
  color: var(--tj-blue);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.tj-blogs-head h2 {
  margin: 0;
  font-family: var(--tj-serif);
  font-weight: 400;
  font-size: clamp(4rem, 8vw, 9rem);
  line-height: .82;
  letter-spacing: -.055em;
}
.tj-blogs-head h2 em {
  color: var(--tj-blue);
}
.tj-blogs-head a {
  min-height: 2.6rem;
  padding: 0 1.1rem;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #252525;
  color: #fff;
  font-weight: 800;
}
.tj-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.tj-blog-card {
  min-height: 560px;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1rem;
  background: rgba(255,255,255,.55);
  border: 1px solid rgba(21,21,21,.08);
  color: var(--tj-black);
}
.tj-blog-media {
  min-height: 260px;
  background:
    radial-gradient(circle at 72% 18%, rgba(23,16,230,.35), transparent 12rem),
    #262626;
  overflow: hidden;
  display: grid;
  place-items: center;
  color: rgba(246,246,244,.18);
  font-family: var(--tj-serif);
  font-size: clamp(2.8rem, 4vw, 4.8rem);
  line-height: .9;
  letter-spacing: -.06em;
}
.tj-blog-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(1);
  transition: transform .8s cubic-bezier(.16,1,.3,1), filter .8s;
}
.tj-blog-card:hover .tj-blog-media img {
  transform: scale(1.08);
  filter: grayscale(0);
}
.tj-blog-card small {
  margin-top: .5rem;
  color: var(--tj-muted);
  font-size: .72rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.tj-blog-card h3 {
  margin: 0;
  font-size: clamp(1.6rem, 2.4vw, 2.7rem);
  line-height: .95;
  letter-spacing: -.055em;
}
.tj-blog-card p {
  margin: 0;
  color: #5b5b5b;
  line-height: 1.55;
}

.tj-international {
  width: var(--tj-shell);
  margin: 0 auto clamp(2rem, 5vw, 4rem);
  padding: clamp(4rem, 7vw, 7rem) clamp(1.5rem, 5vw, 5rem);
  background: #f6f6f4;
  color: #151515;
}
.tj-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 520px);
  gap: clamp(1.5rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: clamp(2rem, 5vw, 4rem);
}
.tj-intro span {
  grid-column: 1 / -1;
  color: var(--tj-blue);
  font-size: .78rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.tj-intro h2 {
  margin: 0;
  font-family: var(--tj-serif);
  font-size: clamp(4rem, 7vw, 8.5rem);
  font-weight: 400;
  line-height: .82;
  letter-spacing: -.065em;
}
.tj-intro h2 em {
  font-style: italic;
}
.tj-intro p {
  margin: 0 0 .6rem;
  color: #5b5b5b;
  font-size: clamp(1rem, 1.4vw, 1.35rem);
  line-height: 1.5;
}
.tj-international-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.4rem);
}
.tj-international-card {
  min-height: 520px;
  padding: clamp(1.4rem, 3vw, 2.5rem);
  display: flex;
  flex-direction: column;
  border-radius: .25rem;
  background:
    radial-gradient(circle at 78% 16%, rgba(37,28,235,.32), transparent 15rem),
    linear-gradient(135deg, rgba(255,255,255,.075), transparent),
    #151515;
  color: #f6f6f4;
  overflow: hidden;
  position: relative;
}
.tj-international-card::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 2px;
  background: linear-gradient(90deg, var(--tj-blue), #37d5a7, #e9ff4d);
  transform: scaleX(.34);
  transform-origin: left;
  transition: transform .8s cubic-bezier(.16,1,.3,1);
}
.tj-international-card:hover::after {
  transform: scaleX(1);
}
.tj-int-card-top,
.tj-int-card-foot {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
}
.tj-int-card-top span {
  display: grid;
  place-items: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 50%;
  background: var(--tj-blue);
  color: #fff;
  font-size: .8rem;
  font-weight: 900;
}
.tj-int-card-top em,
.tj-int-card-foot strong {
  color: rgba(246,246,244,.58);
  font-style: normal;
  font-weight: 800;
}
.tj-international-card h3 {
  margin: auto 0 1rem;
  max-width: 560px;
  font-family: var(--tj-serif);
  font-size: clamp(3rem, 5vw, 6.2rem);
  font-weight: 400;
  line-height: .82;
  letter-spacing: -.065em;
}
.tj-international-card p {
  max-width: 560px;
  margin: 0 0 1.5rem;
  color: rgba(246,246,244,.66);
  line-height: 1.55;
}
.tj-international-card ul {
  margin: 0 0 clamp(2rem, 4vw, 4rem);
  padding: 0;
  list-style: none;
  display: grid;
  gap: .65rem;
}
.tj-international-card li {
  color: rgba(246,246,244,.58);
  border-top: 1px solid rgba(246,246,244,.14);
  padding-top: .65rem;
}
.tj-int-card-foot {
  margin-top: auto;
}
.tj-int-card-foot a {
  min-height: 2.7rem;
  padding: 0 1.1rem;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  background: #f6f6f4;
  color: #151515 !important;
  font-weight: 900;
}

.tj-testimonials,
.tj-specialization,
.tj-final {
  width: var(--tj-shell);
  margin: 0 auto clamp(2rem, 5vw, 4rem);
  background: #151515;
  color: #f6f6f4;
}
.tj-testimonials {
  padding: clamp(4rem, 8vw, 8rem) clamp(1.6rem, 6vw, 7rem);
  min-height: 820px;
  text-align: center;
}
.tj-testimonials h2 {
  margin: 0 0 clamp(3rem, 6vw, 6rem);
  font-family: var(--tj-serif);
  font-size: clamp(3.5rem, 6.2vw, 7.6rem);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -.055em;
}
.tj-testimonials h2 em {
  color: var(--tj-green);
}
.tj-quotes {
  max-width: 680px;
  margin: 0 auto;
  display: grid;
  gap: clamp(2rem, 4vw, 4rem);
  text-align: left;
}
.tj-quotes article {
  position: relative;
  padding: 0 3.2rem;
}
.tj-quotes article::before,
.tj-quotes article::after {
  position: absolute;
  top: -.4rem;
  color: var(--tj-green);
  font-family: var(--tj-serif);
  font-size: 4.5rem;
  line-height: 1;
}
.tj-quotes article::before {
  content: "“";
  left: 0;
}
.tj-quotes article::after {
  content: "”";
  right: 0;
}
.tj-quotes p {
  margin: 0;
  line-height: 1.55;
  color: rgba(246,246,244,.86);
}
.tj-quotes span {
  display: block;
  margin-top: 1rem;
  color: rgba(246,246,244,.52);
  font-size: .85rem;
}

.tj-specialization {
  min-height: 760px;
  padding: clamp(4rem, 6vw, 6rem);
  border-radius: .3rem;
}
.tj-spec-head {
  display: flex;
  justify-content: flex-end;
  align-items: flex-start;
  gap: .8rem;
  margin-bottom: clamp(3rem, 6vw, 5.5rem);
}
.tj-spec-head span {
  font-family: var(--tj-serif);
  font-style: italic;
  font-size: clamp(2.5rem, 4vw, 4.8rem);
}
.tj-spec-head h2 {
  margin: 0;
  font-family: var(--tj-serif);
  font-size: clamp(2.5rem, 4vw, 4.8rem);
  font-weight: 400;
  line-height: .85;
}
.tj-spec-table {
  max-width: 1180px;
  margin: 0 auto;
  border-top: 1px solid rgba(246,246,244,.18);
}
.tj-spec-table div {
  display: grid;
  grid-template-columns: 1.2fr 1fr auto;
  gap: 1.2rem;
  padding: 1.25rem 0;
  border-bottom: 1px solid rgba(246,246,244,.18);
  align-items: center;
}
.tj-spec-table strong {
  font-family: var(--tj-serif);
  font-size: clamp(1.6rem, 2.5vw, 3rem);
  font-weight: 400;
  line-height: .9;
}
.tj-spec-table span,
.tj-spec-table em {
  color: rgba(246,246,244,.55);
  font-style: normal;
}
.tj-blue-button {
  width: fit-content;
  min-height: 2.6rem;
  margin: clamp(2rem, 4vw, 4rem) auto 0;
  padding: 0 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--tj-blue);
  color: #fff !important;
  font-weight: 800;
}

.tj-final {
  min-height: 480px;
  padding: clamp(4rem, 8vw, 8rem) clamp(1.5rem, 5vw, 5rem);
  text-align: center;
}
.tj-final p {
  color: rgba(246,246,244,.5);
}
.tj-final h2 {
  margin: 2rem 0;
  font-family: var(--tj-serif);
  font-size: clamp(5rem, 9vw, 11rem);
  font-weight: 400;
  line-height: .8;
  letter-spacing: -.06em;
}
.tj-final h2 em {
  font-style: italic;
}
.tj-final div {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.2rem;
}
.tj-final a {
  color: rgba(246,246,244,.76);
  border-bottom: 1px solid transparent;
}
.tj-final a:hover {
  color: var(--tj-green);
  border-color: var(--tj-green);
}

@media (max-width: 980px) {
  .tj-topline {
    grid-template-columns: 1fr;
    gap: .75rem;
  }
  .tj-nav-shell {
    width: calc(100vw - 1rem);
    grid-template-columns: 1fr auto;
  }
  .tj-nav-links {
    display: none;
  }
  .tj-hero-copy h1 {
    font-size: clamp(4.7rem, 16vw, 8rem);
  }
  .tj-blue-panel,
  .tj-service-card {
    grid-template-columns: 1fr;
  }
  .tj-blog-grid {
    grid-template-columns: 1fr;
  }
  .tj-blogs-head {
    grid-template-columns: 1fr;
  }
  .tj-intro,
  .tj-international-grid {
    grid-template-columns: 1fr;
  }
  .tj-stats {
    grid-template-columns: 1fr;
  }
  .tj-floating-cta {
    width: calc(100vw - 1.5rem);
    justify-content: center;
    bottom: 4.7rem;
  }
  .tj-cta-primary,
  .tj-cta-secondary {
    min-height: 3.35rem;
    padding-inline: 1rem;
    font-size: .9rem;
  }
}

@media (max-width: 640px) {
  .tj-hero {
    min-height: 92svh;
  }
  .tj-nav-actions a:first-child {
    display: none;
  }
  .tj-hero-copy {
    padding-bottom: 7rem;
  }
  .tj-hero-copy h1 {
    font-size: clamp(4rem, 19vw, 6rem);
  }
  .tj-hero-copy p {
    font-size: .96rem;
  }
  .tj-floating-cta {
    flex-direction: column;
    gap: .45rem;
  }
  .tj-mini-menu {
    display: none;
  }
  .tj-blue-panel {
    width: calc(100vw - 1rem);
    padding: 5rem 1.2rem 2rem;
  }
  .tj-blue-panel::before {
    padding-inline: 3.2rem;
  }
  .tj-services,
  .tj-international,
  .tj-testimonials,
  .tj-specialization,
  .tj-final {
    width: calc(100vw - 1rem);
  }
  .tj-service-card {
    min-height: auto;
  }
  .tj-service-visual {
    min-height: 220px;
    position: relative;
    top: auto;
  }
  .tj-spec-table div {
    grid-template-columns: 1fr;
  }
}
/* --- INDEX / SERVICES (Premium White) ----------------- */
.tx-index {
    padding: var(--tx-pad) clamp(1.5rem, 6vw, 6rem);
    background: #ffffff;
}
.tx-index__header {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 4rem;
    gap: 2rem;
}
@media (min-width: 768px) {
    .tx-index__header { flex-direction: row; align-items: flex-end; }
}
.tx-index__desc {
    max-width: 400px;
    font-size: 1.15rem;
    color: #4b5563;
    line-height: 1.6;
    font-weight: 500;
}
.tx-index__list {
    display: flex;
    flex-direction: column;
}
.tx-index__row {
    display: flex;
    align-items: center;
    padding: 2.5rem 0;
    border-bottom: 1px solid #e5e7eb;
    text-decoration: none;
    transition: all 0.4s cubic-bezier(0.2, 0, 0, 1);
}
.tx-index__row:first-child { border-top: 1px solid #e5e7eb; }
.tx-index__row:hover {
    padding-left: 1.5rem;
    padding-right: 1.5rem;
    background: #f9fafb;
}
.tx-index__num {
    font-size: 0.875rem;
    font-weight: 800;
    color: #9ca3af;
    margin-right: 3rem;
    font-family: monospace;
}
.tx-index__main {
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}
.tx-index__title {
    font-size: clamp(1.5rem, 3vw, 2.5rem);
    font-weight: 800;
    color: #111827;
    letter-spacing: -0.02em;
    margin: 0;
}
.tx-index__sub {
    font-size: 0.75rem;
    font-weight: 800;
    color: #9ca3af;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    margin-top: 0.5rem;
}
.tx-index__price {
    font-size: 1.25rem;
    font-weight: 800;
    color: #111827;
    margin-right: 4rem;
}
.tx-index__arrow {
    width: 3.5rem;
    height: 3.5rem;
    border-radius: 50%;
    border: 1px solid #e5e7eb;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.4s ease;
    color: #111827;
}
.tx-index__row:hover .tx-index__arrow {
    background: #111827;
    color: #ffffff;
    border-color: #111827;
    transform: rotate(-45deg);
}

/* Tanuja-style chat / conversion engine */
.tx-chat-engine {
  font-family: var(--tj-sans, "Plus Jakarta Sans", system-ui, sans-serif);
}
.tx-chat-engine .tx-chat-launcher {
  width: 4.25rem !important;
  height: 4.25rem !important;
  border: 1px solid rgba(246,246,244,.18) !important;
  background: #151515 !important;
  box-shadow: 0 18px 50px rgba(0,0,0,.24) !important;
}
.tx-chat-engine .tx-chat-launcher::before {
  content: "";
  position: absolute;
  inset: .55rem;
  border: 1px solid rgba(246,246,244,.16);
  border-radius: inherit;
  transition: transform .35s cubic-bezier(.16,1,.3,1), border-color .35s;
}
.tx-chat-engine .tx-chat-launcher:hover::before {
  transform: scale(1.18);
  border-color: var(--tj-blue, #1f1aff);
}
.tx-chat-engine .tx-chat-launcher > div:nth-child(1) {
  background: linear-gradient(135deg, #151515, #262626) !important;
}
.tx-chat-engine .tx-chat-launcher > div:nth-child(2) {
  background: var(--tj-blue, #1f1aff) !important;
}
.tx-chat-engine .tx-chat-tooltip {
  border-radius: .35rem !important;
  border-color: rgba(21,21,21,.1) !important;
  box-shadow: 0 18px 44px rgba(0,0,0,.1) !important;
}
.tx-chat-engine .tx-chat-window {
  width: min(430px, calc(100vw - 1.25rem)) !important;
  height: min(720px, calc(100svh - 7rem)) !important;
  right: 1.5rem !important;
  bottom: 6.5rem !important;
  border-radius: .45rem !important;
  border: 1px solid rgba(21,21,21,.12) !important;
  background: #f6f6f4 !important;
  box-shadow: 0 30px 90px rgba(0,0,0,.24) !important;
}
.tx-chat-engine .tx-chat-header {
  background:
    radial-gradient(circle at 78% 8%, rgba(31,26,255,.35), transparent 12rem),
    linear-gradient(135deg, rgba(255,255,255,.06), transparent),
    #151515 !important;
}
.tx-chat-engine .tx-chat-header h3,
.tx-chat-engine .tx-chat-header p,
.tx-chat-engine .tx-chat-header span {
  letter-spacing: -.035em;
}
.tx-chat-engine .tx-chat-header h3 {
  font-family: var(--tj-serif, Georgia, serif);
  font-weight: 400 !important;
  font-size: clamp(2.4rem, 7vw, 3.6rem) !important;
  line-height: .9 !important;
}
.tx-chat-engine .tx-chat-body {
  background: transparent;
}
.tx-chat-engine .tx-chat-start-card,
.tx-chat-engine .tx-channel-card,
.tx-chat-engine .tx-chat-note {
  border-radius: .35rem !important;
  border: 1px solid rgba(21,21,21,.09) !important;
  box-shadow: 0 18px 50px rgba(0,0,0,.08) !important;
}
.tx-chat-engine .tx-chat-start-card {
  background: rgba(255,255,255,.86) !important;
}
.tx-chat-engine .tx-chat-start-card:hover,
.tx-chat-engine .tx-channel-card:hover {
  transform: translateY(-4px) !important;
}
.tx-chat-engine .tx-chat-note {
  background: #151515 !important;
  color: #f6f6f4 !important;
}
.tx-chat-engine .tx-chat-note p {
  color: rgba(246,246,244,.72) !important;
}
.tx-chat-engine .tx-channel-card {
  background: rgba(255,255,255,.82) !important;
}
.tx-chat-engine .bg-navy,
.tx-chat-engine .text-navy {
  --tw-bg-opacity: 1;
}
.tx-chat-engine .bg-navy {
  background-color: #151515 !important;
}
.tx-chat-engine .text-navy {
  color: #151515 !important;
}
.tx-chat-engine .bg-emerald {
  background-color: var(--tj-blue, #1f1aff) !important;
}
.tx-chat-engine .text-emerald {
  color: var(--tj-blue, #1f1aff) !important;
}
.tx-chat-engine textarea,
.tx-chat-engine input {
  border-radius: .35rem !important;
  background: #f6f6f4 !important;
  border-color: rgba(21,21,21,.1) !important;
}
.tx-chat-engine .tx-chat-scroll {
  overscroll-behavior: contain;
  touch-action: pan-y;
}
.tx-chat-engine textarea:focus,
.tx-chat-engine input:focus {
  border-color: var(--tj-blue, #1f1aff) !important;
  box-shadow: 0 0 0 3px rgba(31,26,255,.08) !important;
}
.tx-chat-engine button:disabled {
  opacity: .48;
  cursor: not-allowed;
  transform: none !important;
}
.tx-chat-engine .tx-chat-tabs {
  background: rgba(246,246,244,.92) !important;
  border-color: rgba(21,21,21,.1) !important;
  backdrop-filter: blur(16px);
}
.tx-chat-engine .tx-chat-tabs button {
  border-radius: .35rem;
  padding: .55rem .4rem;
}
.tx-chat-engine .tx-chat-tabs button.text-navy,
.tx-chat-engine .tx-chat-tabs button:hover {
  color: var(--tj-blue, #1f1aff) !important;
  background: rgba(31,26,255,.08);
}

.txp-flow {
  position: relative;
  width: min(700px, calc(100vw - 1.5rem));
  max-height: none;
  overflow: visible;
  color: #f6f6f4;
  background:
    radial-gradient(circle at 88% 0%, rgba(55,213,167,.14), transparent 12rem),
    radial-gradient(circle at 0% 100%, rgba(31,26,255,.14), transparent 12rem),
    linear-gradient(135deg, rgba(255,255,255,.075), rgba(255,255,255,.025)),
    #111113;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: .6rem;
  box-shadow: 0 24px 70px rgba(0,0,0,.36);
  padding: clamp(1rem, 2vw, 1.35rem);
  isolation: isolate;
}
.txp-flow::-webkit-scrollbar {
  width: 8px;
}
.txp-flow::-webkit-scrollbar-thumb {
  background: rgba(246,246,244,.22);
  border-radius: 999px;
}
.txp-flow__glow {
  display: none;
}
.txp-flow__glow--one {
  right: -7rem;
  top: -7rem;
  background: #37d5a7;
}
.txp-flow__glow--two {
  left: -8rem;
  bottom: -8rem;
  background: #1f1aff;
}
.txp-flow__top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .85rem;
}
.txp-flow__eyebrow,
.txp-flow__prep small,
.txp-flow__summary small {
  display: block;
  margin-bottom: .35rem;
  color: rgba(246,246,244,.5);
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .16em;
  text-transform: uppercase;
}
.txp-flow h2 {
  margin: 0;
  font-family: var(--tj-serif, Georgia, serif);
  font-size: clamp(2.25rem, 5vw, 3.4rem);
  font-weight: 400;
  line-height: .9;
  letter-spacing: 0;
}
.txp-flow h2 span {
  color: #1f1aff;
}
.txp-flow p {
  max-width: 42rem;
  margin-top: .45rem;
  color: rgba(246,246,244,.68);
  font-size: .88rem;
  line-height: 1.45;
}
.txp-flow__close {
  flex: 0 0 auto;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  background: rgba(246,246,244,.08);
  color: #f6f6f4;
  font-size: 1.25rem;
  line-height: 1;
  transition: transform .2s ease, background .2s ease;
}
.txp-flow__close:hover {
  transform: rotate(90deg);
  background: rgba(246,246,244,.16);
}
.txp-flow__body {
  display: grid;
  gap: .75rem;
}
.txp-flow__prep,
.txp-flow__summary,
.txp-flow__error {
  border: 1px solid rgba(246,246,244,.12);
  background: rgba(246,246,244,.06);
  border-radius: .4rem;
  padding: .75rem;
}
.txp-flow__requirements {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .45rem;
}
.txp-flow__requirement {
  display: flex;
  align-items: center;
  gap: .5rem;
  min-height: 2.4rem;
  border: 1px solid rgba(246,246,244,.1);
  background: rgba(0,0,0,.18);
  border-radius: .3rem;
  padding: .55rem .65rem;
}
.txp-flow__requirement span {
  color: #37d5a7;
  font-weight: 900;
}
.txp-flow__requirement strong {
  color: #f6f6f4;
  font-size: .72rem;
  line-height: 1.25;
}
.txp-flow__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
}
.txp-flow__field,
.txp-flow__upload {
  display: grid;
  gap: .35rem;
}
.txp-flow__field span,
.txp-flow__upload span {
  color: rgba(246,246,244,.52);
  font-size: .62rem;
  font-weight: 900;
  letter-spacing: .14em;
  text-transform: uppercase;
}
.txp-flow__field input,
.txp-flow__upload {
  width: 100%;
  border: 1px solid rgba(246,246,244,.13);
  border-radius: .38rem;
  background: rgba(246,246,244,.08);
  color: #f6f6f4;
}
.txp-flow__field input {
  min-height: 2.7rem;
  padding: 0 .85rem;
  outline: none;
  font-size: .9rem;
}
.txp-flow__field input:focus {
  border-color: rgba(55,213,167,.75);
  box-shadow: 0 0 0 4px rgba(55,213,167,.1);
}
.txp-flow__field input:disabled {
  opacity: .65;
}
.txp-flow__field em {
  color: #ff8d8d;
  font-size: .78rem;
  font-style: normal;
}
.txp-flow__upload {
  min-height: 6.2rem;
  place-content: center;
  padding: .8rem;
  cursor: pointer;
}
.txp-flow__upload input {
  max-width: 100%;
  color: rgba(246,246,244,.7);
  font-size: .82rem;
}
.txp-flow__upload strong {
  color: #f6f6f4;
}
.txp-flow__check {
  display: flex;
  align-items: center;
  gap: .7rem;
  border: 1px solid rgba(246,246,244,.12);
  border-radius: .38rem;
  background: rgba(246,246,244,.06);
  padding: .75rem;
  color: rgba(246,246,244,.74);
  font-size: .86rem;
}
.txp-flow__check input {
  width: 1rem;
  height: 1rem;
  accent-color: #1f1aff;
}
.txp-flow__summary strong {
  display: block;
  color: #f6f6f4;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1;
}
.txp-flow__actions {
  display: grid;
  grid-template-columns: .45fr 1fr;
  gap: .55rem;
}
.txp-flow__actions--stack {
  grid-template-columns: 1fr;
}
.txp-flow__primary,
.txp-flow__secondary {
  min-height: 2.9rem;
  border-radius: 999px;
  padding: 0 1rem;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}
.txp-flow__primary {
  background: #1f1aff;
  color: #fff;
  box-shadow: 0 18px 45px rgba(31,26,255,.28);
}
.txp-flow__secondary {
  border: 1px solid rgba(246,246,244,.16);
  background: rgba(246,246,244,.08);
  color: #f6f6f4;
}
.txp-flow__primary:hover,
.txp-flow__secondary:hover {
  transform: translateY(-2px);
}
.txp-flow__primary:disabled,
.txp-flow__secondary:disabled {
  opacity: .5;
  cursor: wait;
  transform: none;
}
.txp-flow__error {
  color: #ffb4b4;
  font-weight: 800;
}
.txp-flow__error a {
  margin-left: .4rem;
  color: #fff;
  text-decoration: underline;
}

@media (max-width: 640px) {
  .tx-chat-engine {
    padding: .75rem !important;
  }
  .tx-chat-engine .tx-chat-window {
    right: .75rem !important;
    bottom: 5.8rem !important;
    width: calc(100vw - 1.5rem) !important;
    height: min(680px, calc(100svh - 6.5rem)) !important;
  }
  .tx-chat-engine .tx-chat-tooltip {
    display: none !important;
  }
  .txp-flow {
    max-height: calc(100svh - 1rem);
    overflow-y: auto;
    padding: .9rem;
  }
  .txp-flow__top {
    align-items: flex-start;
  }
  .txp-flow__requirements,
  .txp-flow__grid,
  .txp-flow__actions {
    grid-template-columns: 1fr;
  }
  .txp-flow h2 {
    font-size: clamp(2.1rem, 11vw, 3rem);
  }
}
