/* ════════════════════════════════════════════════════════════
   TECHNOCRATS DIGIMATE — DESIGN SYSTEM
   v1.0.0 | Obsidian × Prestige Gold
════════════════════════════════════════════════════════════ */

/* ─── CSS CUSTOM PROPERTIES ─── */
:root {
  /* Colour Palette */
  --td-ink:        #080808;
  --td-ink-2:      #141414;
  --td-ink-3:      #1E1E1E;
  --td-smoke:      #F9F8F5;
  --td-smoke-2:    #EFEEE9;
  --td-white:      #FFFFFF;
  --td-gold:       #C4922A;
  --td-gold-lt:    #D9AE5A;
  --td-gold-dk:    #8A6418;
  --td-gold-a06:   rgba(196, 146, 42, 0.06);
  --td-gold-a12:   rgba(196, 146, 42, 0.12);
  --td-gold-a22:   rgba(196, 146, 42, 0.22);
  --td-platinum:   #9A9A9A;
  --td-muted:      #666666;
  --td-border-dk:  rgba(255, 255, 255, 0.07);
  --td-border-dk2: rgba(255, 255, 255, 0.12);
  --td-border-lt:  rgba(0, 0, 0, 0.08);

  /* Typography */
  --td-ff-display: 'Cormorant Garamond', Georgia, serif;
  --td-ff-body:    'DM Sans', -apple-system, sans-serif;
  --td-ff-mono:    'DM Mono', 'Courier New', monospace;

  /* Radius */
  --td-r4:  4px;
  --td-r8:  8px;
  --td-r12: 12px;
  --td-r16: 16px;
  --td-r24: 24px;

  /* Shadows */
  --td-sh-card: 0 4px 28px rgba(0, 0, 0, 0.10);
  --td-sh-deep: 0 24px 80px rgba(0, 0, 0, 0.28);
  --td-sh-gold: 0 0 48px rgba(196, 146, 42, 0.14);

  /* Transitions */
  --td-ease: cubic-bezier(0.4, 0, 0.2, 1);
  --td-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ─── RESET ─── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family:    var(--td-ff-body);
  background:     var(--td-ink);
  color:          var(--td-white);
  line-height:    1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ─── TYPOGRAPHY SCALE ─── */
.td-display-xl {
  font-family:    var(--td-ff-display);
  font-size:      clamp(44px, 5.5vw, 72px);
  font-weight:    700;
  line-height:    1.06;
  letter-spacing: -1.5px;
}
.td-display-lg {
  font-family:    var(--td-ff-display);
  font-size:      clamp(32px, 4vw, 52px);
  font-weight:    700;
  line-height:    1.10;
  letter-spacing: -0.5px;
}
.td-display-md {
  font-family:    var(--td-ff-display);
  font-size:      clamp(24px, 3vw, 38px);
  font-weight:    700;
  line-height:    1.15;
}
.td-display-sm {
  font-family:    var(--td-ff-display);
  font-size:      clamp(20px, 2.5vw, 28px);
  font-weight:    600;
  line-height:    1.2;
}
.td-italic { font-style: italic; color: var(--td-gold-lt); }
.td-italic-dk { font-style: italic; color: var(--td-gold-dk); }

.td-eyebrow {
  display:        inline-flex;
  align-items:    center;
  gap:            10px;
  font-family:    var(--td-ff-mono);
  font-size:      10.5px;
  font-weight:    500;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color:          var(--td-gold);
  margin-bottom:  16px;
}
.td-eyebrow-dark {
  color:          var(--td-gold-dk);
}
.td-eyebrow-line {
  width:       28px;
  height:      1px;
  background:  var(--td-gold);
  flex-shrink: 0;
}
.td-eyebrow-dark .td-eyebrow-line {
  background: var(--td-gold-dk);
}
.td-lead {
  font-size:    17px;
  font-weight:  300;
  color:        var(--td-platinum);
  line-height:  1.75;
  max-width:    580px;
}
.td-lead-dark {
  color: var(--td-muted);
}

/* ─── SECTION DIVIDER ─── */
.td-sec-divider {
  width:         48px;
  height:        2px;
  background:    linear-gradient(90deg, var(--td-gold), var(--td-gold-lt));
  border-radius: 2px;
  margin-bottom: 32px;
}
.td-sec-divider--center {
  margin-left:  auto;
  margin-right: auto;
}
.td-gold-rule {
  width:      100%;
  height:     1px;
  background: linear-gradient(90deg, transparent, var(--td-gold-a22), transparent);
  border:     none;
  margin:     0;
}

/* ─── BUTTONS ─── */
.td-btn,
.elementor-button.td-btn {
  display:         inline-flex;
  align-items:     center;
  gap:             8px;
  font-family:     var(--td-ff-body);
  font-weight:     700;
  font-size:       13.5px;
  letter-spacing:  0.2px;
  border-radius:   var(--td-r8);
  cursor:          pointer;
  transition:      all 0.22s var(--td-ease);
  text-decoration: none;
  border:          none;
  white-space:     nowrap;
}
.td-btn-primary {
  background: var(--td-gold);
  color:      var(--td-ink) !important;
  padding:    13px 28px;
}
.td-btn-primary:hover {
  background:  var(--td-gold-lt);
  transform:   translateY(-2px);
  box-shadow:  0 10px 32px rgba(196, 146, 42, 0.38);
  color:       var(--td-ink) !important;
}
.td-btn-ghost {
  background: transparent;
  color:      var(--td-white) !important;
  padding:    12px 24px;
  border:     1px solid rgba(255, 255, 255, 0.18);
}
.td-btn-ghost:hover {
  border-color: var(--td-gold);
  color:        var(--td-gold-lt) !important;
}
.td-btn-dark {
  background: var(--td-ink);
  color:      var(--td-white) !important;
  padding:    13px 28px;
  border:     1px solid var(--td-border-dk2);
}
.td-btn-dark:hover {
  background:   var(--td-gold);
  color:        var(--td-ink) !important;
  border-color: var(--td-gold);
}
.td-btn-arrow {
  display:    inline-block;
  transition: transform 0.2s;
}
.td-btn:hover .td-btn-arrow {
  transform: translateX(4px);
}

/* ─── SERVICE BADGE ─── */
.td-svc-badge {
  display:       inline-flex;
  align-items:   center;
  gap:           8px;
  background:    var(--td-gold-a12);
  border:        1px solid var(--td-gold-a22);
  padding:       6px 16px;
  border-radius: 100px;
  margin-bottom: 24px;
}
.td-svc-badge__dot {
  width:            6px;
  height:           6px;
  border-radius:    50%;
  background:       var(--td-gold);
  animation:        tdPulse 2s infinite;
  flex-shrink:      0;
}
.td-svc-badge__text {
  font-family:    var(--td-ff-mono);
  font-size:      10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color:          var(--td-gold-lt);
}
@keyframes tdPulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .5; transform: scale(.8); }
}

/* ─── TAG PILLS ─── */
.td-tag-pill {
  display:       inline-flex;
  align-items:   center;
  font-family:   var(--td-ff-mono);
  font-size:     10px;
  font-weight:   500;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding:       4px 12px;
  border-radius: 100px;
  background:    var(--td-gold-a12);
  border:        1px solid var(--td-gold-a22);
  color:         var(--td-gold-lt);
}
.td-tag-sm {
  font-size:     10px;
  padding:       3px 10px;
  background:    rgba(255, 255, 255, 0.04);
  border:        1px solid var(--td-border-dk);
  color:         var(--td-platinum);
  border-radius: 100px;
  font-family:   var(--td-ff-mono);
  letter-spacing: .5px;
}

/* ─── HERO BADGE ─── */
.td-hero-badge {
  display:       inline-flex;
  align-items:   center;
  gap:           8px;
  background:    var(--td-gold-a12);
  border:        1px solid var(--td-gold-a22);
  padding:       6px 16px;
  border-radius: 100px;
  margin-bottom: 28px;
}
.td-hero-badge__dot {
  width:         6px;
  height:        6px;
  border-radius: 50%;
  background:    var(--td-gold);
  animation:     tdPulse 2s infinite;
}
.td-hero-badge__text {
  font-family:    var(--td-ff-mono);
  font-size:      10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color:          var(--td-gold-lt);
}

/* ─── CARDS ─── */
.td-card-dark {
  background:    linear-gradient(160deg, #1C1C1C 0%, #131313 100%);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r24);
  position:      relative;
  overflow:      hidden;
}
.td-card-dark::before {
  content:    '';
  position:   absolute;
  top:        0;
  left:       20px;
  right:      20px;
  height:     1.5px;
  background: linear-gradient(90deg, transparent, var(--td-gold), transparent);
}
.td-card-light {
  background:    var(--td-white);
  border:        1px solid rgba(0, 0, 0, 0.05);
  border-radius: var(--td-r24);
  box-shadow:    var(--td-sh-card);
}
.td-card-service {
  background:    linear-gradient(160deg, #171717 0%, #111 100%);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r24);
  padding:       32px 28px;
  transition:    all 0.3s ease;
  position:      relative;
  overflow:      hidden;
  display:       flex;
  flex-direction: column;
  gap:           18px;
}
.td-card-service::after {
  content:          '';
  position:         absolute;
  bottom:           0; left: 0; right: 0;
  height:           2px;
  background:       linear-gradient(90deg, transparent, var(--td-gold), transparent);
  transform:        scaleX(0);
  transform-origin: left;
  transition:       transform 0.3s ease;
}
.td-card-service:hover {
  border-color: var(--td-gold-a22);
  transform:    translateY(-5px);
  box-shadow:   var(--td-sh-gold);
}
.td-card-service:hover::after { transform: scaleX(1); }

/* ─── SERVICE CARD ELEMENTS ─── */
.td-sc-icon {
  width:      52px;
  height:     52px;
  border-radius: var(--td-r12);
  background: var(--td-gold-a06);
  border:     1px solid var(--td-gold-a12);
  display:    flex;
  align-items: center;
  justify-content: center;
  font-size:  22px;
  transition: all 0.3s;
  flex-shrink: 0;
}
.td-card-service:hover .td-sc-icon {
  background:  var(--td-gold-a22);
  box-shadow:  0 0 20px rgba(196, 146, 42, 0.2);
}
.td-sc-metric {
  font-family:    var(--td-ff-mono);
  font-size:      10px;
  color:          var(--td-gold);
  background:     var(--td-gold-a06);
  border:         1px solid var(--td-gold-a12);
  padding:        4px 10px;
  border-radius:  100px;
  white-space:    nowrap;
  flex-shrink:    0;
}
.td-sc-title {
  font-size:  16.5px;
  font-weight: 700;
  color:       var(--td-white);
  transition:  color 0.2s;
}
.td-card-service:hover .td-sc-title { color: var(--td-gold-lt); }
.td-sc-desc {
  font-size:   13px;
  color:       var(--td-muted);
  line-height: 1.65;
  flex:        1;
}
.td-sc-link {
  display:     flex;
  align-items: center;
  gap:         6px;
  font-size:   12.5px;
  font-weight: 700;
  color:       var(--td-gold);
  margin-top:  auto;
}

/* ─── TESTIMONIAL CARDS ─── */
.td-testi-card {
  background:    var(--td-white);
  border-radius: var(--td-r24);
  padding:       32px;
  position:      relative;
  overflow:      hidden;
  border:        1px solid rgba(0, 0, 0, .05);
  box-shadow:    var(--td-sh-card);
  transition:    transform 0.3s, box-shadow 0.3s;
}
.td-testi-card::before {
  content:    '"';
  position:   absolute;
  top:       -10px; right: 20px;
  font-family: var(--td-ff-display);
  font-size:  120px;
  color:      rgba(196, 146, 42, 0.08);
  line-height: 1;
  pointer-events: none;
}
.td-testi-card:hover {
  transform:  translateY(-4px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.15);
}
.td-testi-card__stars {
  color:          var(--td-gold);
  font-size:      14px;
  letter-spacing: 2px;
  margin-bottom:  16px;
}
.td-testi-card__quote {
  font-size:    13.5px;
  line-height:  1.75;
  color:        #333;
  font-style:   italic;
  margin-bottom: 24px;
}
.td-testi-card__footer {
  display:     flex;
  align-items: center;
  gap:         12px;
  padding-top: 20px;
  border-top:  1px solid rgba(0, 0, 0, 0.07);
}
.td-testi-card__avatar {
  width:          44px;
  height:         44px;
  border-radius:  50%;
  background:     linear-gradient(135deg, var(--td-gold-dk), var(--td-gold-lt));
  display:        flex;
  align-items:    center;
  justify-content: center;
  font-weight:    700;
  font-size:      13px;
  color:          var(--td-ink);
  flex-shrink:    0;
  font-family:    var(--td-ff-display);
}
.td-testi-card__name {
  font-size:   13px;
  font-weight: 700;
  color:       var(--td-ink);
}
.td-testi-card__role {
  font-size:   11px;
  color:       var(--td-muted);
  margin-top:  1px;
}

/* ─── CASE STUDY CARDS ─── */
.td-cs-card {
  background:    var(--td-ink-2);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r24);
  overflow:      hidden;
  transition:    all 0.3s;
}
.td-cs-card:hover {
  border-color: var(--td-gold-a22);
  transform:    translateY(-4px);
  box-shadow:   var(--td-sh-gold);
}
.td-cs-card__head {
  background:   linear-gradient(160deg, #1E1E1E, #111);
  padding:      28px;
  position:     relative;
  min-height:   140px;
  display:      flex;
  flex-direction: column;
  justify-content: flex-end;
  gap:          8px;
}
.td-cs-card__industry {
  font-family:    var(--td-ff-mono);
  font-size:      9px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color:          var(--td-gold);
  background:     var(--td-gold-a12);
  border:         1px solid var(--td-gold-a22);
  padding:        4px 10px;
  border-radius:  100px;
  display:        inline-block;
  width:          fit-content;
}
.td-cs-card__headline {
  font-family:  var(--td-ff-display);
  font-size:    30px;
  font-weight:  700;
  color:        var(--td-gold-lt);
  line-height:  1.1;
}
.td-cs-card__sub {
  font-size:  13px;
  color:      var(--td-platinum);
}
.td-cs-card__body { padding: 24px; }
.td-cs-card__excerpt {
  font-size:    13px;
  color:        var(--td-muted);
  line-height:  1.6;
  margin-bottom: 16px;
}
.td-cs-card__metrics {
  display:               grid;
  grid-template-columns: 1fr 1fr;
  gap:                   8px;
  margin-bottom:         16px;
}
.td-cs-card__metric {
  background:    rgba(255, 255, 255, .03);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r8);
  padding:       10px;
  text-align:    center;
}
.td-cs-card__metric-num {
  font-family:  var(--td-ff-display);
  font-size:    20px;
  font-weight:  700;
  color:        var(--td-gold-lt);
  display:      block;
  line-height:  1;
}
.td-cs-card__metric-lbl {
  font-size:   10px;
  color:       var(--td-muted);
  font-family: var(--td-ff-mono);
  letter-spacing: .3px;
}
.td-cs-card__quote {
  font-style:   italic;
  font-size:    13px;
  color:        var(--td-platinum);
  line-height:  1.65;
  padding-top:  14px;
  border-top:   1px solid var(--td-border-dk);
  margin-top:   14px;
}
.td-cs-card__author {
  display:      block;
  margin-top:   8px;
  font-style:   normal;
  font-weight:  700;
  font-size:    11px;
  color:        var(--td-gold-lt);
}
.td-cs-card__tag {
  display:        inline-flex;
  margin-top:     12px;
  font-family:    var(--td-ff-mono);
  font-size:      9.5px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color:          var(--td-gold);
  background:     var(--td-gold-a06);
  border:         1px solid var(--td-gold-a12);
  padding:        4px 10px;
  border-radius:  100px;
}

/* ─── TEAM CARDS ─── */
.td-team-card {
  background:    var(--td-white);
  border-radius: var(--td-r24);
  overflow:      hidden;
  border:        1px solid rgba(0, 0, 0, .06);
  box-shadow:    var(--td-sh-card);
  transition:    all 0.3s;
}
.td-team-card:hover { transform: translateY(-4px); box-shadow: 0 20px 60px rgba(0, 0, 0, .15); }
.td-team-card__photo {
  height:         180px;
  background:     linear-gradient(160deg, #2A2A2A, #1A1A1A);
  display:        flex;
  align-items:    center;
  justify-content: center;
  position:       relative;
  overflow:       hidden;
}
.td-team-card__photo img {
  width:      100%;
  height:     100%;
  object-fit: cover;
  filter:     grayscale(0.5);
  transition: filter 0.3s;
}
.td-team-card:hover .td-team-card__photo img { filter: grayscale(0); }
.td-team-card__avatar {
  width:          76px;
  height:         76px;
  border-radius:  50%;
  background:     linear-gradient(135deg, var(--td-gold-dk), var(--td-gold-lt));
  display:        flex;
  align-items:    center;
  justify-content: center;
  font-family:    var(--td-ff-display);
  font-size:      28px;
  font-weight:    700;
  color:          var(--td-ink);
}
.td-team-card__li {
  position:       absolute;
  bottom:         12px; right: 12px;
  background:     var(--td-gold-a12);
  border:         1px solid var(--td-gold-a22);
  border-radius:  var(--td-r4);
  padding:        3px 8px;
  font-family:    var(--td-ff-mono);
  font-size:      9px;
  letter-spacing: .5px;
  color:          var(--td-gold);
  text-decoration: none;
  text-transform: uppercase;
}
.td-team-card__info { padding: 20px; }
.td-team-card__name {
  font-size:   15px;
  font-weight: 700;
  color:       var(--td-ink);
  margin-bottom: 2px;
}
.td-team-card__role {
  font-family:    var(--td-ff-mono);
  font-size:      9.5px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color:          var(--td-gold);
  margin-bottom:  8px;
}
.td-team-card__bio {
  font-size:   12px;
  color:       var(--td-muted);
  line-height: 1.55;
}

/* ─── METRICS BAR ─── */
.td-metrics-bar { background: var(--td-gold); padding: 64px 0; }
.td-metrics-row {
  display:               grid;
  grid-template-columns: repeat(4, 1fr);
  text-align:            center;
}
.td-metric-item {
  padding:  20px;
  position: relative;
}
.td-metric-item::after {
  content:    '';
  position:   absolute;
  right:      0; top: 15%; bottom: 15%;
  width:      1px;
  background: rgba(8, 8, 8, 0.15);
}
.td-metric-item:last-child::after { display: none; }
.td-metric-num {
  font-family:    var(--td-ff-display);
  font-size:      52px;
  font-weight:    700;
  color:          var(--td-ink);
  line-height:    1;
  letter-spacing: -2px;
  display:        block;
  margin-bottom:  6px;
}
.td-metric-label {
  font-family:    var(--td-ff-mono);
  font-size:      10.5px;
  font-weight:    500;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color:          rgba(8, 8, 8, 0.6);
}

/* ─── PROCESS STEPS ─── */
.td-process-grid {
  display:               grid;
  grid-template-columns: repeat(4, 1fr);
  position:              relative;
}
.td-process-grid::before {
  content:    '';
  position:   absolute;
  top:        38px; left: 12.5%; right: 12.5%;
  height:     1px;
  background: linear-gradient(90deg, transparent, var(--td-gold-a22), transparent);
  pointer-events: none;
}
.td-process-5 {
  display:               grid;
  grid-template-columns: repeat(5, 1fr);
  position:              relative;
}
.td-process-5::before {
  content:    '';
  position:   absolute;
  top:        37px; left: 10%; right: 10%;
  height:     1px;
  background: linear-gradient(90deg, transparent, var(--td-gold-a22), transparent);
  pointer-events: none;
}
.td-proc-step {
  padding:    0 20px;
  text-align: center;
}
.td-proc-num {
  width:          76px;
  height:         76px;
  border-radius:  50%;
  background:     var(--td-ink);
  border:         1px solid var(--td-gold-a22);
  display:        flex;
  align-items:    center;
  justify-content: center;
  margin:         0 auto 24px;
  font-family:    var(--td-ff-display);
  font-size:      26px;
  font-weight:    700;
  color:          var(--td-gold);
  position:       relative;
  z-index:        2;
  transition:     all 0.3s;
}
.td-proc-step:hover .td-proc-num {
  background:  var(--td-gold-a12);
  border-color: var(--td-gold);
  box-shadow:  0 0 28px rgba(196, 146, 42, 0.25);
}
.td-proc-title {
  font-size:    14px;
  font-weight:  700;
  color:        var(--td-white);
  margin-bottom: 8px;
}
.td-proc-desc {
  font-size:  12.5px;
  color:      var(--td-muted);
  line-height: 1.6;
}

/* ─── PROBLEM COMPARISON ─── */
.td-prob-grid {
  display:       grid;
  grid-template-columns: 1fr 1fr;
  gap:           2px;
  border-radius: var(--td-r24);
  overflow:      hidden;
  box-shadow:    var(--td-sh-card);
}
.td-prob-col { padding: 48px 44px; }
.td-prob-col--bad  { background: #FFF9F9; }
.td-prob-col--good { background: var(--td-ink); }
.td-prob-header {
  display:      flex;
  align-items:  center;
  gap:          12px;
  margin-bottom: 28px;
}
.td-prob-icon {
  width:   36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.td-prob-icon--bad  { background: rgba(220, 38, 38, .1); }
.td-prob-icon--good { background: var(--td-gold-a12); }
.td-prob-title { font-size: 13.5px; font-weight: 700; }
.td-prob-col--bad  .td-prob-title { color: #991B1B; }
.td-prob-col--good .td-prob-title { color: var(--td-gold-lt); }
.td-prob-list { display: flex; flex-direction: column; gap: 14px; }
.td-prob-item { display: flex; gap: 10px; align-items: flex-start; font-size: 13.5px; line-height: 1.55; }
.td-prob-col--bad  .td-prob-item { color: #555; }
.td-prob-col--good .td-prob-item { color: var(--td-platinum); }
.td-prob-bullet {
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; flex-shrink: 0; margin-top: 1px;
}
.td-prob-bullet--bad  { background: rgba(220,38,38,.1); color: #EF4444; }
.td-prob-bullet--good { background: var(--td-gold-a12); color: var(--td-gold); }

/* ─── STATS CARD (About page) ─── */
.td-stats-card {
  background:    linear-gradient(160deg, #1C1C1C, #131313);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r24);
  padding:       36px;
  position:      relative;
  overflow:      hidden;
}
.td-stats-card::before {
  content:    '';
  position:   absolute;
  top:        0; left: 20px; right: 20px;
  height:     1.5px;
  background: linear-gradient(90deg, transparent, var(--td-gold), transparent);
}
.td-stat-row {
  display:       flex;
  align-items:   center;
  justify-content: space-between;
  padding:       14px 0;
  border-bottom: 1px solid var(--td-border-dk);
  font-size:     13px;
}
.td-stat-row:last-child { border-bottom: none; padding-bottom: 0; }
.td-stat-label { color: var(--td-platinum); }
.td-stat-val {
  font-family:  var(--td-ff-display);
  font-size:    28px;
  font-weight:  700;
  color:        var(--td-gold-lt);
  line-height:  1;
}

/* ─── VALUES CARDS ─── */
.td-val-card {
  background:    linear-gradient(160deg, #171717, #111);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r24);
  padding:       32px 24px;
  transition:    all 0.3s;
}
.td-val-card:hover {
  border-color: var(--td-gold-a22);
  transform:    translateY(-4px);
  box-shadow:   var(--td-sh-gold);
}
.td-val-icon {
  width:         52px; height: 52px;
  border-radius: var(--td-r12);
  background:    var(--td-gold-a06);
  border:        1px solid var(--td-gold-a12);
  display:       flex; align-items: center; justify-content: center;
  font-size:     22px; margin-bottom: 20px;
  transition:    all 0.3s;
}
.td-val-card:hover .td-val-icon { background: var(--td-gold-a22); box-shadow: var(--td-sh-gold); }
.td-val-title { font-size: 15px; font-weight: 700; color: var(--td-white); margin-bottom: 8px; }
.td-val-desc  { font-size: 13px; color: var(--td-muted); line-height: 1.65; }

/* ─── CERTS ROW ─── */
.td-cert-item { display: flex; flex-direction: column; align-items: center; gap: 10px; }
.td-cert-icon {
  width: 72px; height: 72px;
  border-radius: var(--td-r16);
  background:    rgba(255, 255, 255, .03);
  border:        1px solid var(--td-border-dk);
  display:       flex; align-items: center; justify-content: center;
  font-size:     28px;
  transition:    all 0.3s;
}
.td-cert-item:hover .td-cert-icon { background: var(--td-gold-a06); border-color: var(--td-gold-a22); }
.td-cert-label {
  font-family:    var(--td-ff-mono);
  font-size:      9px; letter-spacing: 1px;
  text-transform: uppercase; color: var(--td-platinum);
}

/* ─── FORM ELEMENTS ─── */
.td-form-label {
  font-size:   12px; font-weight: 600;
  color:       #333; letter-spacing: .3px;
  margin-bottom: 6px; display: block;
}
.td-form-input,
.td-form-select,
.td-form-textarea {
  background:    #F9F8F5;
  border:        1px solid rgba(0, 0, 0, .1);
  border-radius: var(--td-r8);
  padding:       12px 16px;
  font-size:     14px; color: var(--td-ink);
  font-family:   var(--td-ff-body);
  outline:       none;
  transition:    border-color .2s, box-shadow .2s;
  width:         100%;
}
.td-form-input:focus, .td-form-select:focus, .td-form-textarea:focus {
  border-color: var(--td-gold);
  box-shadow:   0 0 0 3px rgba(196, 146, 42, .12);
}
.td-form-textarea { min-height: 120px; resize: vertical; }
.td-form-submit {
  width: 100%; background: var(--td-ink);
  color: var(--td-white); font-weight: 700;
  font-size: 15px; padding: 16px;
  border-radius: var(--td-r8); border: none;
  cursor: pointer; font-family: var(--td-ff-body);
  transition: all .22s; display: flex;
  align-items: center; justify-content: center; gap: 8px;
}
.td-form-submit:hover { background: var(--td-gold); color: var(--td-ink); }

/* ─── WHATSAPP BUTTON ─── */
.td-wa-btn {
  display:        flex; align-items: center; justify-content: center; gap: 10px;
  background:     #25D366; color: var(--td-white) !important;
  font-weight:    700; font-size: 14px;
  padding:        14px; border-radius: var(--td-r12);
  text-decoration: none; transition: all .22s;
}
.td-wa-btn:hover {
  background:  #22C55E;
  transform:   translateY(-2px);
  box-shadow:  0 8px 24px rgba(37, 211, 102, .3);
}

/* ─── FAQ ACCORDION ─── */
.td-faq-item    { border-bottom: 1px solid var(--td-border-dk); }
.td-faq-q {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 0; cursor: pointer;
  font-size: 14px; font-weight: 600; color: var(--td-white);
  gap: 16px; transition: color .2s;
}
.td-faq-q:hover { color: var(--td-gold-lt); }
.td-faq-chevron { font-size: 12px; color: var(--td-gold); transition: transform .25s; flex-shrink: 0; }
.td-faq-item.open .td-faq-chevron { transform: rotate(180deg); }
.td-faq-a { font-size: 13.5px; color: var(--td-platinum); line-height: 1.7; padding-bottom: 20px; display: none; }
.td-faq-item.open .td-faq-a { display: block; }

/* ─── CONTACT INFO ─── */
.td-ci-icon {
  width: 36px; height: 36px;
  border-radius: var(--td-r8);
  background: var(--td-gold-a06);
  border: 1px solid var(--td-gold-a12);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; flex-shrink: 0;
}
.td-ci-label {
  font-family: var(--td-ff-mono);
  font-size: 9px; letter-spacing: 1px;
  text-transform: uppercase; color: var(--td-muted);
  margin-bottom: 2px;
}
.td-ci-val { font-size: 14px; color: var(--td-white); font-weight: 500; }

/* ─── COURSE CARD (Sticky Pricing) ─── */
.td-course-card {
  background:    linear-gradient(160deg, #1C1C1C, #141414);
  border:        1px solid var(--td-border-dk);
  border-radius: var(--td-r24);
  overflow:      hidden;
  position:      sticky;
  top:           100px;
}
.td-course-card__top { height: 4px; background: linear-gradient(90deg, var(--td-gold-dk), var(--td-gold-lt)); }
.td-course-card__body { padding: 28px; }
.td-cc-price { font-family: var(--td-ff-display); font-size: 44px; font-weight: 700; color: var(--td-white); line-height: 1; }
.td-cc-orig  { font-size: 17px; color: var(--td-muted); text-decoration: line-through; }
.td-cc-save  {
  background:    rgba(76, 175, 80, .15);
  border:        1px solid rgba(76, 175, 80, .3);
  color:         #A5D6A7; font-size: 11px; font-weight: 700;
  padding:       3px 10px; border-radius: 100px;
  font-family:   var(--td-ff-mono);
}
.td-enroll-btn {
  width: 100%; background: var(--td-gold);
  color: var(--td-ink); font-weight: 800; font-size: 15px;
  padding: 16px; border-radius: var(--td-r8); border: none;
  cursor: pointer; font-family: var(--td-ff-body);
  transition: all .22s; display: block; text-align: center;
}
.td-enroll-btn:hover { background: var(--td-gold-lt); box-shadow: 0 10px 32px rgba(196,146,42,.38); }

/* ─── MODULE CARDS ─── */
.td-module-card {
  background:    var(--td-white);
  border-radius: var(--td-r12);
  padding:       20px 24px;
  display:       flex; gap: 14px; align-items: flex-start;
  border:        1px solid rgba(0, 0, 0, .06);
  box-shadow:    0 2px 12px rgba(0, 0, 0, .04);
  transition:    all .25s;
}
.td-module-card:hover { border-color: rgba(196, 146, 42, .3); transform: translateY(-2px); }
.td-mod-num {
  width: 40px; height: 40px; border-radius: var(--td-r8);
  background: var(--td-gold-a12); border: 1px solid var(--td-gold-a22);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--td-ff-mono); font-size: 12px; font-weight: 600;
  color: var(--td-gold); flex-shrink: 0;
}
.td-mod-title { font-size: 14px; font-weight: 700; color: var(--td-ink); margin-bottom: 4px; }
.td-mod-desc  { font-size: 12px; color: var(--td-muted); line-height: 1.5; }

/* ─── HERO GRID BACKGROUND ─── */
.td-hero-bg-grid {
  position:         absolute; inset: 0; pointer-events: none;
  background-image: linear-gradient(rgba(196,146,42,.03) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(196,146,42,.03) 1px, transparent 1px);
  background-size:  80px 80px;
}
.td-hero-glow {
  position:  absolute;
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle, rgba(196,146,42,.07) 0%, transparent 65%);
}

/* ─── SCROLL REVEAL ─── */
.td-reveal {
  opacity:    0;
  transform:  translateY(24px);
  transition: opacity .65s ease, transform .65s ease;
}
.td-reveal-left {
  opacity:    0;
  transform:  translateX(-32px);
  transition: opacity .65s ease, transform .65s ease;
}
.td-reveal-right {
  opacity:    0;
  transform:  translateX(32px);
  transition: opacity .65s ease, transform .65s ease;
}
.td-reveal.is-visible,
.td-reveal-left.is-visible,
.td-reveal-right.is-visible {
  opacity:   1;
  transform: translate(0);
}
.td-delay-1 { transition-delay: .10s; }
.td-delay-2 { transition-delay: .18s; }
.td-delay-3 { transition-delay: .26s; }
.td-delay-4 { transition-delay: .34s; }
.td-delay-5 { transition-delay: .42s; }
.td-delay-6 { transition-delay: .50s; }

/* ─── RESPONSIVE ─── */
@media (max-width: 1024px) {
  .td-prob-grid    { grid-template-columns: 1fr; }
  .td-metrics-row  { grid-template-columns: 1fr 1fr; }
  .td-process-grid { grid-template-columns: 1fr 1fr; }
  .td-process-grid::before { display: none; }
  .td-process-5    { grid-template-columns: 1fr 1fr; }
  .td-process-5::before { display: none; }
}
@media (max-width: 768px) {
  .td-metrics-row  { grid-template-columns: 1fr 1fr; }
  .td-prob-col     { padding: 32px 24px; }
  .td-metric-num   { font-size: 36px; }
}
@media (max-width: 480px) {
  .td-course-card  { position: static; }
  .td-metrics-row  { grid-template-columns: 1fr 1fr; }
}
