/* =============================================================================
   Trademark Seva Theme — main.css
   One file for everything: variables, reset, layout, header, homepage sections,
   inner pages, footer, responsive. No framework, no bloat.
============================================================================= */

/* ── CSS Variables ──────────────────────────────────────────────────────────── */
:root {
  --ts-ink:         #16203A;
  --ts-ink-soft:    #5A6379;
  --ts-line:        #E4E7F0;
  --ts-line-soft:   #EEF0F6;
  --ts-bg:          #F4F6FC;
  --ts-surface:     #FFFFFF;
  --ts-blue:        #2456D8;
  --ts-blue-dark:   #1B43AD;
  --ts-blue-soft:   #E8EEFC;
  --ts-green:       #15A05A;
  --ts-green-soft:  #E2F3EA;
  --ts-amber:       #C9851A;
  --ts-amber-soft:  #FBF0D8;
  --ts-red:         #E5484D;
  --ts-red-soft:    #FCEDED;
  --ts-purple:      #7C3AED;
  --ts-purple-soft: #F1EAFE;
  --ts-orange:      #E8870E;
  --ts-radius:      16px;
  --ts-shadow:      0 1px 2px rgba(22,32,58,.04), 0 12px 34px rgba(22,32,58,.10);
  --ts-shadow-sm:   0 1px 2px rgba(22,32,58,.04), 0 4px 14px rgba(22,32,58,.06);
  --ts-header-h:    68px;
}

/* ── Reset & Base ───────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--ts-bg);
  color: var(--ts-ink);
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img, video, svg { max-width: 100%; height: auto; display: block; }

a { color: var(--ts-blue); text-decoration: none; }
a:hover { color: var(--ts-blue-dark); }

h1, h2, h3, h4, h5, h6 {
  margin: 0 0 .5em;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  line-height: 1.15;
  letter-spacing: -.01em;
  color: var(--ts-ink);
}

p  { margin: 0 0 1em; }
ul, ol { margin: 0; padding: 0; list-style: none; }

/* Accessibility */
.screen-reader-text {
  clip: rect(1px,1px,1px,1px);
  height: 1px; width: 1px;
  overflow: hidden;
  position: absolute;
  white-space: nowrap;
  word-wrap: normal;
}
.screen-reader-text:focus {
  background: var(--ts-surface);
  clip: auto;
  color: var(--ts-ink);
  display: block;
  font-size: 14px;
  font-weight: 600;
  height: auto;
  width: auto;
  left: 8px; top: 8px;
  outline: 2px solid var(--ts-blue);
  padding: 10px 16px;
  z-index: 100000;
}

/* ── Layout ─────────────────────────────────────────────────────────────────── */
.ts-wrap,
.ts-container {
  max-width: 1140px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 24px;
  padding-right: 24px;
  box-sizing: border-box;
}

.ts-section          { padding: 56px 0; }
.ts-section-white    { background: var(--ts-surface); border-top: 1px solid var(--ts-line); border-bottom: 1px solid var(--ts-line); }
.ts-section-dark     { background: linear-gradient(135deg, #16203A, #26345A); color: #fff; }
.ts-section-nopt     { padding-top: 0; }

.ts-sec-title {
  font-size: 30px;
  text-align: center;
  margin: 0 0 8px;
}
.ts-sec-sub {
  text-align: center;
  color: var(--ts-ink-soft);
  font-size: 15px;
  max-width: 36em;
  margin: 0 auto 36px;
}

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.ts-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--ts-green);
  color: #fff;
  border: none;
  border-radius: 11px;
  font: 600 15px 'Hanken Grotesk', system-ui, sans-serif;
  padding: 13px 22px;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s;
  -webkit-appearance: none;
}
.ts-btn-primary:hover, .ts-btn-primary:focus { background: #128a4d; color: #fff; outline: none; }
.ts-btn-primary svg { width: 17px; height: 17px; flex-shrink: 0; }

.ts-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  background: #fff;
  border: 1.5px solid var(--ts-green);
  color: var(--ts-green);
  border-radius: 10px;
  padding: 12px;
  font: 600 14px 'Hanken Grotesk', system-ui, sans-serif;
  cursor: pointer;
  text-decoration: none;
  transition: background .15s, color .15s;
  -webkit-appearance: none;
}
.ts-btn-outline:hover, .ts-btn-outline:focus { background: var(--ts-green); color: #fff; outline: none; }

.ts-chip {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 9px;
  border-radius: 7px;
  background: var(--ts-green-soft);
  color: var(--ts-green);
}

/* ── Header ─────────────────────────────────────────────────────────────────── */
.ts-header {
  background: rgba(255, 255, 255, .94);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--ts-line);
  position: sticky;
  top: 0;
  z-index: 40;
  height: var(--ts-header-h);
}

.ts-nav-inner {
  display: flex;
  align-items: center;
  height: var(--ts-header-h);
  gap: 32px;
}

/* Logo */
.ts-logo {
  display: flex;
  align-items: center;
  gap: 11px;
  text-decoration: none;
  flex-shrink: 0;
}
.ts-logo:hover { text-decoration: none; }

.ts-logo-mark {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  background: linear-gradient(135deg, var(--ts-blue), #3D6BE8);
  display: grid;
  place-items: center;
  color: #fff;
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 19px;
  flex-shrink: 0;
}
.ts-logo-name {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 21px;
  line-height: 1;
  color: var(--ts-ink);
  display: block;
}
.ts-logo-name .ts-logo-accent { color: var(--ts-green); }
.ts-logo-tagline {
  font-size: 10px;
  color: var(--ts-ink-soft);
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  display: block;
  margin-top: 3px;
}

/* Custom logo image */
.ts-logo .custom-logo-link img,
.ts-logo .custom-logo-link { display: block; }
.ts-logo .custom-logo-link img { max-height: 48px; width: auto; }

/* Nav */
.ts-nav-menu {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0;
}
.ts-nav-menu ul, .ts-nav-list {
  display: flex;
  align-items: center;
  gap: 26px;
  list-style: none;
  margin: 0;
  padding: 0;
}
.ts-nav-menu li, .ts-nav-list li { list-style: none; position: relative; }
.ts-nav-menu a, .ts-nav-list a {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ts-ink);
  text-decoration: none;
  display: block;
  padding: 4px 0;
  transition: color .15s;
}
.ts-nav-menu a:hover, .ts-nav-list a:hover,
.ts-nav-menu .current-menu-item > a,
.ts-nav-menu .current_page_item > a { color: var(--ts-blue); }

/* Sub-menus (desktop dropdown) */
.ts-nav-menu .sub-menu,
.ts-nav-menu .children {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 12px;
  box-shadow: var(--ts-shadow);
  min-width: 180px;
  padding: 8px 0;
  margin-top: 4px;
  z-index: 50;
  flex-direction: column;
  gap: 0;
}
.ts-nav-menu li:hover > .sub-menu,
.ts-nav-menu li:focus-within > .sub-menu { display: flex; }
.ts-nav-menu .sub-menu a {
  padding: 9px 16px;
  font-size: 13.5px;
}

/* Nav right */
.ts-nav-right {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  margin-left: auto;
}

.ts-nav-phone {
  display: flex;
  align-items: center;
  gap: 7px;
  font-weight: 600;
  font-size: 14px;
  border: 1px solid var(--ts-line);
  border-radius: 10px;
  padding: 9px 14px;
  color: var(--ts-ink);
  text-decoration: none;
  transition: border-color .15s;
}
.ts-nav-phone:hover { border-color: var(--ts-green); color: var(--ts-ink); }
.ts-nav-phone svg { width: 15px; height: 15px; color: var(--ts-green); flex-shrink: 0; }

.ts-nav-cta { padding: 11px 18px; font-size: 14px; }

/* Hamburger */
.ts-hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: none;
  border: 1px solid var(--ts-line);
  border-radius: 8px;
  cursor: pointer;
  padding: 8px;
  flex-shrink: 0;
  align-items: center;
}
.ts-hamburger span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--ts-ink);
  border-radius: 2px;
  transition: transform .2s, opacity .2s;
}
.ts-nav-open .ts-hamburger span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.ts-nav-open .ts-hamburger span:nth-child(2) { opacity: 0; }
.ts-nav-open .ts-hamburger span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Site main ──────────────────────────────────────────────────────────────── */
#ts-main { min-height: 60vh; }

/* ── HERO ───────────────────────────────────────────────────────────────────── */
.ts-hero {
  background: radial-gradient(1100px 420px at 85% -10%, #E6EDFC 0%, transparent 55%), var(--ts-bg);
  padding: 56px 0 44px;
}
.ts-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 44px;
  align-items: start;
}
.ts-hero-headline {
  font-size: 44px;
  line-height: 1.06;
  letter-spacing: -.025em;
  margin: 0 0 14px;
}
.ts-hero-headline .ts-accent { color: var(--ts-blue); display: inline; }
.ts-hero-lede {
  font-size: 16px;
  color: var(--ts-ink-soft);
  max-width: 30em;
  margin: 0 0 22px;
}

/* Trust strip */
.ts-hero-trust {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-top: 22px;
}
.ts-trust-item {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ts-ink);
}
.ts-trust-item svg { width: 20px; height: 20px; color: var(--ts-green); flex-shrink: 0; }
.ts-trust-item small { color: var(--ts-ink-soft); font-weight: 500; display: block; font-size: 11px; }
.ts-trust-item span { display: flex; flex-direction: column; }

/* ── Sample Report Card (hero right column) ─────────────────────────────────── */
.ts-report {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: var(--ts-radius);
  box-shadow: var(--ts-shadow);
  overflow: hidden;
}
.ts-report-head {
  background: linear-gradient(135deg, var(--ts-blue), #3D6BE8);
  color: #fff;
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 12px;
}
.ts-report-body { padding: 20px; }
.ts-report-top {
  display: flex;
  gap: 18px;
  align-items: center;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--ts-line);
  margin-bottom: 4px;
}
.ts-gauge { width: 100px; height: 100px; flex-shrink: 0; }
.ts-risk-label { font-size: 11px; font-weight: 600; color: var(--ts-ink-soft); margin-bottom: 4px; }
.ts-risk-value {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 24px;
  color: var(--ts-amber);
  display: flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 6px;
}
.ts-risk-value svg { width: 18px; height: 18px; }
.ts-report-top p { margin: 0; font-size: 12px; color: var(--ts-ink-soft); }
.ts-report-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 0;
  border-bottom: 1px solid var(--ts-line-soft);
  font-size: 13px;
}
.ts-report-row:last-of-type { border-bottom: none; }
.ts-report-row .ts-rl { color: var(--ts-ink-soft); }
.ts-report-row .ts-rv { display: flex; align-items: center; gap: 7px; font-weight: 600; }
.ts-arr { color: #C2CCE4; }
.ts-report-note {
  display: flex;
  gap: 11px;
  align-items: center;
  background: var(--ts-purple-soft);
  border-radius: 11px;
  padding: 12px;
  margin-top: 14px;
  font-size: 12px;
  color: #5B4B86;
}
.ts-report-note svg { width: 28px; height: 28px; color: var(--ts-purple); flex-shrink: 0; }

/* ── What You'll Get ─────────────────────────────────────────────────────────── */
.ts-feat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
}
.ts-feat-card {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 14px;
  padding: 24px 18px;
  text-align: center;
  box-shadow: var(--ts-shadow-sm);
}
.ts-feat-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  margin: 0 auto 14px;
}
.ts-feat-icon svg { width: 25px; height: 25px; }
.ts-feat-card h4 { margin: 0 0 7px; font-size: 15px; font-family: 'Hanken Grotesk', system-ui, sans-serif; font-weight: 700; }
.ts-feat-card p  { margin: 0; font-size: 13px; color: var(--ts-ink-soft); }
.ts-ic-grn  { background: var(--ts-green-soft);  color: var(--ts-green);  }
.ts-ic-blue { background: var(--ts-blue-soft);   color: var(--ts-blue);   }
.ts-ic-pur  { background: var(--ts-purple-soft); color: var(--ts-purple); }
.ts-ic-org  { background: #FCEEDD;               color: var(--ts-orange); }

/* ── Comparison ─────────────────────────────────────────────────────────────── */
.ts-compare {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.ts-cmp-card {
  border-radius: var(--ts-radius);
  padding: 28px;
  position: relative;
  overflow: hidden;
}
.ts-cmp-bad  { background: var(--ts-red-soft);   border: 1px solid #F6D4D4; }
.ts-cmp-good { background: var(--ts-green-soft); border: 1px solid #C5E6D2; }
.ts-cmp-card h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 19px;
  margin: 0 0 16px;
}
.ts-cmp-bad h3  { color: #C5343A; }
.ts-cmp-good h3 { color: #0F7A43; }
.ts-cmp-item {
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 8px 0;
  font-size: 14px;
  font-weight: 500;
}
.ts-cmp-item svg { width: 20px; height: 20px; flex-shrink: 0; }
.ts-cmp-bad  .ts-cmp-item svg { color: var(--ts-red);   }
.ts-cmp-good .ts-cmp-item svg { color: var(--ts-green); }

/* ── How It Works ───────────────────────────────────────────────────────────── */
.ts-steps {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}
.ts-step {
  flex: 1;
  min-width: 168px;
  text-align: center;
  position: relative;
  padding: 0 6px;
}
.ts-step-num {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  display: grid;
  place-items: center;
  margin: 0 auto 12px;
}
.ts-step-icon {
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  display: grid;
  place-items: center;
  margin: 0 auto 12px;
  box-shadow: var(--ts-shadow-sm);
}
.ts-step-icon svg { width: 27px; height: 27px; color: var(--ts-ink); }
.ts-step h4 { margin: 0 0 6px; font-size: 14.5px; font-family: 'Hanken Grotesk', system-ui, sans-serif; font-weight: 700; }
.ts-step p  { margin: 0; font-size: 12px; color: var(--ts-ink-soft); }
.ts-step-arrow {
  position: absolute;
  top: 44px;
  right: -14px;
  color: #C2CCE4;
  font-size: 20px;
  line-height: 1;
}

/* ── Sample Analysis ─────────────────────────────────────────────────────────── */
.ts-sample-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 20px;
  align-items: stretch;
}
.ts-sample-table {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: var(--ts-radius);
  box-shadow: var(--ts-shadow-sm);
  overflow: hidden;
}
.ts-sample-row {
  display: grid;
  grid-template-columns: .8fr 1.2fr;
  border-bottom: 1px solid var(--ts-line-soft);
}
.ts-sample-row:last-child { border-bottom: none; }
.ts-sample-key {
  padding: 13px 16px;
  font-size: 12.5px;
  color: var(--ts-ink-soft);
  font-weight: 600;
  background: #FBFCFE;
}
.ts-sample-val { padding: 13px 16px; font-size: 13px; }

/* CTA panel (replaces gate form) */
.ts-cta-panel {
  background: linear-gradient(150deg, var(--ts-blue), #3F3AC9);
  border-radius: var(--ts-radius);
  padding: 28px;
  color: #fff;
  box-shadow: var(--ts-shadow);
  display: flex;
  flex-direction: column;
}
.ts-cta-panel-icon {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  background: rgba(255,255,255,.15);
  display: grid;
  place-items: center;
  margin-bottom: 14px;
}
.ts-cta-panel-icon svg { width: 22px; height: 22px; }
.ts-cta-panel h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 22px;
  color: #fff;
  margin: 0 0 6px;
}
.ts-cta-panel p { font-size: 13px; opacity: .85; margin: 0 0 16px; }
.ts-cta-panel-li {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 13px;
  margin-bottom: 8px;
}
.ts-cta-panel-li svg { width: 15px; height: 15px; color: #7DE6AC; flex-shrink: 0; }
.ts-cta-panel-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--ts-green);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 14px;
  font: 600 15px 'Hanken Grotesk', system-ui, sans-serif;
  margin-top: auto;
  padding-top: 18px;
  text-decoration: none;
  cursor: pointer;
  transition: background .15s;
}
.ts-cta-panel-btn:hover { background: #128a4d; color: #fff; }
.ts-cta-panel-btn svg { width: 17px; height: 17px; }
.ts-cta-panel-note { text-align: center; font-size: 11px; opacity: .7; margin-top: 10px; }

/* ── Pricing ─────────────────────────────────────────────────────────────────── */
.ts-price-grid {
  display: grid;
  grid-template-columns: 1fr 1fr .9fr;
  gap: 18px;
  align-items: start;
}
.ts-price-card {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 14px;
  padding: 24px;
  box-shadow: var(--ts-shadow-sm);
}
.ts-price-who { font-size: 13px; font-weight: 600; color: var(--ts-ink-soft); }
.ts-price-amt {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 34px;
  margin: 8px 0 2px;
}
.ts-price-amt small {
  font-size: 14px;
  color: var(--ts-ink-soft);
  font-weight: 400;
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
}
.ts-price-break { font-size: 12px; color: var(--ts-ink-soft); margin: 0 0 18px; }
.ts-price-incl {
  background: linear-gradient(160deg, #16203A, #283861);
  color: #fff;
  border-radius: 14px;
  padding: 24px;
}
.ts-price-incl h4 { font-family: 'Hanken Grotesk', system-ui, sans-serif; font-weight: 700; margin: 0 0 4px; font-size: 15px; }
.ts-price-usp { font-size: 12px; color: #7DE6AC; font-weight: 600; margin: 0 0 16px; }
.ts-price-incl-item { display: flex; align-items: center; gap: 9px; font-size: 13px; padding: 6px 0; }
.ts-price-incl-item svg { width: 16px; height: 16px; color: #4ED38A; flex-shrink: 0; }
.ts-price-foot { text-align: center; font-size: 11.5px; color: var(--ts-ink-soft); margin-top: 16px; }

/* ── Stats Band ──────────────────────────────────────────────────────────────── */
.ts-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  text-align: center;
}
.ts-stat-num {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 40px;
  line-height: 1;
}
.ts-stat-num span { color: #4ED38A; }
.ts-stat-lbl { font-size: 13px; color: #C9D2E6; margin-top: 6px; }

/* ── FAQ ─────────────────────────────────────────────────────────────────────── */
.ts-faq-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.ts-faq-col { display: flex; flex-direction: column; gap: 14px; }
.ts-faq-item {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 12px;
  overflow: hidden;
}
.ts-faq-q {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 16px 18px;
  cursor: pointer;
  font-weight: 600;
  font-size: 14px;
  color: var(--ts-ink);
  background: none;
  border: none;
  text-align: left;
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  line-height: 1.4;
}
.ts-faq-q:focus { outline: 2px solid var(--ts-blue); outline-offset: -2px; }
.ts-faq-pm {
  color: var(--ts-blue);
  font-size: 22px;
  flex-shrink: 0;
  transition: transform .2s;
  line-height: 1;
  margin-left: auto;
}
.ts-faq-open .ts-faq-pm { transform: rotate(45deg); }
.ts-faq-a {
  padding: 0 18px;
  max-height: 0;
  overflow: hidden;
  color: var(--ts-ink-soft);
  font-size: 13.5px;
  line-height: 1.6;
  transition: max-height .28s ease, padding .28s ease;
}
.ts-faq-open .ts-faq-a { max-height: 300px; padding: 0 18px 16px; }

/* ── Final CTA Band ──────────────────────────────────────────────────────────── */
.ts-cta-section { padding: 8px 0 56px; }
.ts-cta-band {
  background: linear-gradient(135deg, var(--ts-blue), #6D3BEA);
  border-radius: var(--ts-radius);
  padding: 36px 40px;
  display: flex;
  align-items: center;
  gap: 40px;
  flex-wrap: wrap;
}
.ts-cta-text { flex: 1; min-width: 220px; }
.ts-cta-text h2 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 600;
  font-size: 26px;
  color: #fff;
  margin: 0 0 6px;
}
.ts-cta-text p { color: rgba(255,255,255,.85); margin: 0; font-size: 15px; }
.ts-cta-search-wrap { flex: 0 0 360px; max-width: 100%; }
.ts-cta-actions { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.ts-cta-action-primary { white-space: nowrap; background: #fff; color: var(--ts-blue) !important; }
.ts-cta-action-primary:hover { background: var(--ts-blue-soft, #e8f0fe); }

/* ── Footer ──────────────────────────────────────────────────────────────────── */
.ts-footer {
  background: var(--ts-ink);
  color: #AEB8CE;
  padding: 48px 0 22px;
  font-size: 13px;
}
.ts-foot-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.3fr;
  gap: 32px;
  padding-bottom: 28px;
  border-bottom: 1px solid #2A3658;
}
.ts-foot-col h5 {
  color: #fff;
  font-size: 13px;
  font-family: 'Hanken Grotesk', system-ui, sans-serif;
  font-weight: 700;
  margin: 0 0 14px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
/* Footer nav menu */
.ts-foot-col nav,
.ts-foot-col ul,
.ts-foot-nav-list { list-style: none; margin: 0; padding: 0; }
.ts-foot-col a,
.ts-foot-nav-list a {
  display: block;
  color: #AEB8CE;
  text-decoration: none;
  margin-bottom: 10px;
  font-size: 13px;
  transition: color .15s;
}
.ts-foot-col a:hover,
.ts-foot-nav-list a:hover { color: #fff; }

/* Logo in footer */
.ts-foot-logo-mark {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.ts-foot-logo-mark .ts-logo-mark { width: 36px; height: 36px; font-size: 16px; }
.ts-foot-logo-mark .ts-logo-name { color: #fff; }
.ts-foot-logo-mark .ts-logo-name .ts-logo-accent { color: #4ED38A; }
.ts-foot-col p { font-size: 13px; line-height: 1.65; color: #AEB8CE; margin: 0; }

/* Contact info */
.ts-foot-contact-item {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 11px;
  color: #AEB8CE;
  font-size: 13px;
}
.ts-foot-contact-item svg { width: 14px; height: 14px; color: #4ED38A; flex-shrink: 0; }
.ts-foot-contact-item a { color: #AEB8CE; display: inline; margin: 0; }
.ts-foot-contact-item a:hover { color: #fff; }

.ts-foot-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 20px;
  font-size: 12px;
  color: #7F89A3;
  flex-wrap: wrap;
  gap: 8px;
}

/* ── Inner page templates ─────────────────────────────────────────────────────── */
.ts-page-header {
  background: var(--ts-surface);
  border-bottom: 1px solid var(--ts-line);
  padding: 40px 0 36px;
}
.ts-page-header h1 {
  font-size: 36px;
  margin: 0 0 8px;
}
.ts-page-header .ts-breadcrumb {
  font-size: 13px;
  color: var(--ts-ink-soft);
}
.ts-page-header .ts-breadcrumb a { color: var(--ts-ink-soft); }
.ts-page-header .ts-breadcrumb a:hover { color: var(--ts-blue); }

.ts-page-body { padding: 48px 0 64px; }
.ts-page-content { max-width: 800px; }

.ts-page-content .entry-content h2 { font-size: 26px; margin: 32px 0 12px; }
.ts-page-content .entry-content h3 { font-size: 20px; margin: 26px 0 10px; }
.ts-page-content .entry-content p  { color: var(--ts-ink); line-height: 1.7; margin-bottom: 1.2em; }
.ts-page-content .entry-content ul,
.ts-page-content .entry-content ol { padding-left: 1.4em; margin-bottom: 1.2em; }
.ts-page-content .entry-content ul { list-style: disc; }
.ts-page-content .entry-content ol { list-style: decimal; }
.ts-page-content .entry-content li { margin-bottom: .4em; }
.ts-page-content .entry-content a  { color: var(--ts-blue); }
.ts-page-content .entry-content a:hover { text-decoration: underline; }
.ts-page-content .entry-content img { border-radius: 10px; margin: 16px 0; }
.ts-page-content .entry-content blockquote {
  border-left: 3px solid var(--ts-blue);
  padding: 12px 20px;
  margin: 20px 0;
  background: var(--ts-blue-soft);
  border-radius: 0 8px 8px 0;
  font-style: italic;
  color: var(--ts-ink-soft);
}

/* Full-width template */
.ts-full-width .ts-page-content { max-width: 100%; }
.ts-full-width .entry-content { max-width: 100%; }

/* ── Blog / Archive ───────────────────────────────────────────────────────────── */
.ts-post-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.ts-post-card {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: var(--ts-radius);
  overflow: hidden;
  box-shadow: var(--ts-shadow-sm);
  display: flex;
  flex-direction: column;
}
.ts-post-thumb img { width: 100%; height: 200px; object-fit: cover; }
.ts-post-body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.ts-post-cat  { font-size: 11px; font-weight: 700; text-transform: uppercase; color: var(--ts-blue); letter-spacing: .05em; margin-bottom: 8px; }
.ts-post-card h2 { font-size: 18px; margin: 0 0 10px; }
.ts-post-card h2 a { color: var(--ts-ink); text-decoration: none; }
.ts-post-card h2 a:hover { color: var(--ts-blue); }
.ts-post-excerpt { font-size: 13.5px; color: var(--ts-ink-soft); flex: 1; margin-bottom: 16px; }
.ts-post-meta { font-size: 12px; color: var(--ts-ink-soft); display: flex; gap: 12px; }
.ts-post-more { margin-top: 12px; }
.ts-post-more a { font-size: 13px; font-weight: 600; color: var(--ts-blue); }

/* ── Search results ────────────────────────────────────────────────────────────── */
.ts-search-form-wrap {
  margin-bottom: 36px;
}
.ts-search-form-wrap .search-form { display: flex; gap: 10px; max-width: 520px; }
.ts-search-form-wrap .search-field {
  flex: 1;
  border: 1.5px solid var(--ts-line);
  border-radius: 10px;
  padding: 11px 14px;
  font: 500 14px 'Hanken Grotesk', system-ui, sans-serif;
  outline: none;
  color: var(--ts-ink);
}
.ts-search-form-wrap .search-field:focus { border-color: var(--ts-blue); box-shadow: 0 0 0 3px rgba(36,86,216,.12); }
.ts-search-form-wrap .search-submit { flex-shrink: 0; }
.ts-no-results { text-align: center; padding: 48px 0; color: var(--ts-ink-soft); }

/* ── Pagination ────────────────────────────────────────────────────────────────── */
.ts-pagination {
  margin-top: 48px;
  display: flex;
  justify-content: center;
  gap: 8px;
}
.ts-pagination .nav-links { display: flex; gap: 8px; align-items: center; }
.ts-pagination a,
.ts-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--ts-line);
  border-radius: 8px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ts-ink);
  text-decoration: none;
  transition: border-color .15s, background .15s;
}
.ts-pagination a:hover,
.ts-pagination .current {
  background: var(--ts-blue);
  border-color: var(--ts-blue);
  color: #fff;
}

/* ── 404 ──────────────────────────────────────────────────────────────────────── */
.ts-error-page { padding: 80px 0; text-align: center; }
.ts-error-code {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 96px;
  font-weight: 600;
  color: var(--ts-blue-soft);
  line-height: 1;
  margin-bottom: 12px;
}
.ts-error-page h1 { font-size: 30px; margin-bottom: 12px; }
.ts-error-page p { color: var(--ts-ink-soft); max-width: 32em; margin: 0 auto 24px; }

/* ── Single post ──────────────────────────────────────────────────────────────── */
.ts-page-title { font-size: 36px; margin: 0 0 8px; }
.ts-post-meta {
  font-size: 12px;
  color: var(--ts-ink-soft);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 8px;
}
.ts-meta-sep   { opacity: .4; }
.ts-post-cats a { color: var(--ts-blue); }
.ts-post-nav {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--ts-line);
}
.ts-post-nav-prev,
.ts-post-nav-next {
  font-size: 13.5px;
  font-weight: 600;
  color: var(--ts-blue);
  max-width: 46%;
  line-height: 1.4;
}
.ts-post-nav-next { text-align: right; }

/* ── Post cards (archive / index / search) ──────────────────────────────────── */
.ts-post-thumb { display: block; overflow: hidden; }
.ts-post-thumb img { width: 100%; height: 200px; object-fit: cover; transition: transform .3s; }
.ts-post-thumb:hover img { transform: scale(1.03); }
.ts-post-card-body {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.ts-post-card-title { font-size: 17px; margin: 0 0 10px; }
.ts-post-card-title a { color: var(--ts-ink); text-decoration: none; }
.ts-post-card-title a:hover { color: var(--ts-blue); }
.ts-post-date {
  display: block;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--ts-ink-soft);
  margin-bottom: 8px;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.ts-post-excerpt { font-size: 13.5px; color: var(--ts-ink-soft); flex: 1; margin-bottom: 16px; }
.ts-post-read-more {
  font-size: 13px;
  font-weight: 600;
  color: var(--ts-blue);
  margin-top: auto;
}
.ts-post-read-more:hover { color: var(--ts-blue-dark); }

/* ── Archive description ─────────────────────────────────────────────────────── */
.ts-archive-desc {
  font-size: 15px;
  color: var(--ts-ink-soft);
  margin: 6px 0 0;
  max-width: 40em;
}

/* ── 404 page ────────────────────────────────────────────────────────────────── */
.ts-404-inner {
  text-align: center;
  padding: 72px 0;
}
.ts-404-code {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 96px;
  font-weight: 600;
  color: var(--ts-blue-soft);
  line-height: 1;
  margin-bottom: 16px;
  -webkit-text-stroke: 2px var(--ts-blue);
}
.ts-404 h1 { font-size: 30px; margin: 0 0 12px; }
.ts-404 > .ts-wrap > .ts-404-inner p { color: var(--ts-ink-soft); max-width: 32em; margin: 0 auto 24px; }
.ts-404-actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}
.ts-404-actions .ts-btn-primary  { white-space: nowrap; }
.ts-404-actions .ts-btn-outline  { width: auto; white-space: nowrap; }

/* ── WordPress core class support ──────────────────────────────────────────────── */
.alignwide  { margin-left: -60px; margin-right: -60px; }
.alignfull  { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); width: auto; max-width: 100vw; }
.wp-caption { max-width: 100%; font-size: 12px; color: var(--ts-ink-soft); }
.sticky     { /* handled by theme */ }

/* ────────────────────────────────────────────────────────────────────────────
   RESPONSIVE
────────────────────────────────────────────────────────────────────────────── */

/* ── Tablet / medium screens (≤ 980px) ─────────────────────────────────────── */
@media (max-width: 980px) {
  .ts-nav-phone,
  .ts-nav-menu > ul > li,
  .ts-nav-menu > .ts-nav-list { display: none; }

  .ts-hamburger { display: flex; margin-left: auto; }
  .ts-nav-inner { gap: 0; }  /* logo flush-left, hamburger flush-right via margin-left:auto */

  /* Fullscreen dropdown nav */
  .ts-nav-menu {
    position: absolute;
    top: var(--ts-header-h);
    left: 0;
    right: 0;
    background: var(--ts-surface);
    border-bottom: 1px solid var(--ts-line);
    flex-direction: column;
    align-items: flex-start;
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s ease;
    z-index: 39;
    box-shadow: 0 8px 24px rgba(22,32,58,.10);
  }
  .ts-header { position: sticky; } /* ensure relative for absolute child */
  .ts-nav-open .ts-nav-menu { max-height: 80vh; overflow-y: auto; }
  .ts-nav-open .ts-nav-menu > ul,
  .ts-nav-open .ts-nav-menu .ts-nav-list {
    display: flex !important;
    flex-direction: column;
    width: 100%;
    padding: 16px 24px;
    gap: 4px;
  }
  /* Show individual li items — they are hidden by the rule above when nav is closed */
  .ts-nav-open .ts-nav-menu ul > li { display: block; }
  .ts-nav-menu a,
  .ts-nav-list a { padding: 10px 0; font-size: 16px; border-bottom: 1px solid var(--ts-line-soft); }
  .ts-nav-menu .sub-menu { position: static; border: none; box-shadow: none; padding: 0 0 0 16px; }
  .ts-nav-menu li:hover > .sub-menu { display: flex; }

  .ts-nav-cta { font-size: 13px; padding: 9px 14px; }
  .ts-hero-grid { grid-template-columns: 1fr; }
  .ts-report { display: none; } /* hide report card on mobile — search card takes full width */
  .ts-hero-trust { grid-template-columns: 1fr 1fr; }
}

/* ── Small tablet (≤ 880px) ─────────────────────────────────────────────────── */
@media (max-width: 880px) {
  .ts-hero-headline { font-size: 34px; }
  .ts-feat-grid     { grid-template-columns: 1fr 1fr; }
  .ts-compare       { grid-template-columns: 1fr; }
  .ts-price-grid    { grid-template-columns: 1fr; }
  .ts-faq-grid      { grid-template-columns: 1fr; }
  .ts-foot-grid     { grid-template-columns: 1fr 1fr; }
  .ts-sample-grid   { grid-template-columns: 1fr; }
  .ts-cta-band      { padding: 28px 24px; }
  .ts-cta-search-wrap { flex: 1 1 100%; }
  .ts-cta-actions { flex: 1 1 100%; justify-content: center; }
  .ts-post-grid     { grid-template-columns: 1fr 1fr; }
  .ts-step-arrow    { display: none; }
}

/* ── Mobile (≤ 640px) ───────────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .ts-wrap { padding: 0 16px; }
  .ts-section { padding: 40px 0; }
  .ts-hero { padding: 40px 0 32px; }
  .ts-hero-headline { font-size: 28px; }
  .ts-hero-trust { grid-template-columns: 1fr 1fr; gap: 10px; }
  .ts-feat-grid { grid-template-columns: 1fr; }
  .ts-steps { gap: 20px; }
  .ts-step { min-width: 100%; }
  .ts-stats-grid { grid-template-columns: 1fr 1fr; gap: 24px; }
  .ts-foot-grid { grid-template-columns: 1fr; }
  .ts-post-grid { grid-template-columns: 1fr; }
  .ts-cta-band { flex-direction: column; border-radius: 12px; }
  .ts-sec-title { font-size: 24px; }
  .ts-price-amt { font-size: 28px; }
  .ts-nav-cta { display: none; } /* hide header CTA on very small screens */
  .ts-error-code { font-size: 64px; }
  .ts-alignwide, .alignwide { margin-left: 0; margin-right: 0; }
}

/* ── Very small (≤ 380px) ────────────────────────────────────────────────────── */
@media (max-width: 380px) {
  .ts-hero-headline { font-size: 24px; }
  .ts-hero-trust { grid-template-columns: 1fr; }
}

/* =============================================================================
   TRADEMARK CLASSES MEGA-MENU
   Panel is position:absolute relative to .ts-header (position:sticky).
   .ts-mega-item overrides the generic li { position:relative } so the panel
   climbs past the li/ul/nav to the header as its containing block.
============================================================================= */

/* ── Trigger button ─────────────────────────────────────────────────────────── */
.ts-mega-item {
  position: static !important;
}

.ts-mega-trigger {
  display: flex;
  align-items: center;
  gap: 5px;
  background: none;
  border: none;
  padding: 4px 0;
  cursor: pointer;
  font: 500 14.5px/1 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  transition: color .15s;
  white-space: nowrap;
}
.ts-mega-trigger:hover,
.ts-mega-trigger:focus-visible,
.ts-mega-item.ts-mega-open .ts-mega-trigger { color: var(--ts-blue); outline: none; }

.ts-mega-chevron {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  transition: transform .2s ease;
}
.ts-mega-item.ts-mega-open .ts-mega-chevron { transform: rotate(180deg); }

/* ── Panel (desktop) ────────────────────────────────────────────────────────── */
.ts-mega-panel {
  display: none;
  position: absolute;
  top: var(--ts-header-h);
  left: 0;
  right: 0;
  background: var(--ts-surface);
  border-top: 2px solid var(--ts-blue);
  border-bottom: 1px solid var(--ts-line);
  box-shadow: 0 16px 40px rgba(22,32,58,.14);
  z-index: 50;
  overflow-x: hidden;
  max-height: 70vh;
  overflow-y: auto;
}

.ts-mega-item.ts-mega-open .ts-mega-panel {
  display: block;
  animation: ts-mega-drop .14s ease both;
}

@keyframes ts-mega-drop {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Panel inner layout (tmseva-mm-* = explicit grid, never auto-fill) ──────── */
.tmseva-mm-panel {
  box-sizing: border-box;
  width: min(1080px, calc(100vw - 40px));
  max-height: 78vh;
  overflow-y: auto;
  overflow-x: hidden;
  margin: 0 auto;
  padding: 20px 24px 16px;
}

.tmseva-mm-group { margin-bottom: 20px; }

.tmseva-mm-heading {
  font: 700 11px/1 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ts-ink-soft);
  margin: 0 0 8px;
}
.tmseva-mm-heading-svc { color: var(--ts-green); }

/* 4 explicit columns — badge + label stay together in one cell, wrap by word */
.tmseva-mm-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 4px 18px;
}

.tmseva-mm-item {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 6px 6px;
  border-radius: 6px;
  text-decoration: none;
  color: var(--ts-ink);
  transition: background .1s, color .1s;
}
.tmseva-mm-item:hover { background: var(--ts-blue-soft); color: var(--ts-blue); }

.tmseva-mm-num {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 18px;
  padding: 0 4px;
  border-radius: 4px;
  background: var(--ts-blue-soft);
  color: var(--ts-blue);
  font: 700 11px/1 'Hanken Grotesk', system-ui, sans-serif;
}
.tmseva-mm-num-svc {
  background: var(--ts-green-soft);
  color: var(--ts-green);
}

.tmseva-mm-label {
  min-width: 0;
  white-space: normal;
  overflow-wrap: break-word;
  line-height: 1.25;
  font: 500 13px/1.35 'Hanken Grotesk', system-ui, sans-serif;
}

.tmseva-mm-footer {
  border-top: 1px solid var(--ts-line);
  padding-top: 12px;
  margin-top: 4px;
}

.tmseva-mm-viewall {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--ts-blue);
  color: #fff !important;
  font: 700 14px/1 'Hanken Grotesk', system-ui, sans-serif;
  border-radius: 9px;
  padding: 10px 16px;
  text-decoration: none;
  transition: background .15s;
  white-space: nowrap;
}
.tmseva-mm-viewall:hover { background: var(--ts-blue-dark); color: #fff !important; }

/* Tablet: 3 columns */
@media (max-width: 1024px) {
  .tmseva-mm-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* ── Mobile mega-menu (≤ 980px): accordion inside mobile nav ────────────────── */
@media (max-width: 980px) {

  /* Outer panel: static / in-flow, not a breakout overlay */
  .ts-mega-panel {
    display: none;
    position: static !important;
    max-height: none;
    overflow: visible;
    border: none;
    border-top: 1px solid var(--ts-line-soft);
    box-shadow: none;
    background: transparent;
    padding: 0;
    animation: none !important;
  }

  .ts-mega-item.ts-mega-open .ts-mega-panel {
    display: block;
    animation: none !important;
  }

  /* Inner panel: full width, no scroll */
  .tmseva-mm-panel {
    width: 100%;
    max-height: none;
    overflow: visible;
    padding: 8px 0 12px;
  }

  .tmseva-mm-group { margin-bottom: 12px; }

  /* Single-column vertical list */
  .tmseva-mm-grid {
    grid-template-columns: 1fr;
    gap: 0;
  }

  .tmseva-mm-item {
    padding: 9px 0;
    border-bottom: 1px solid var(--ts-line-soft);
    border-radius: 0;
    background: transparent !important;
    color: var(--ts-ink) !important;
  }

  .tmseva-mm-footer {
    border-top: none;
    padding-top: 8px;
    margin-top: 4px;
  }

  .tmseva-mm-viewall { font-size: 13px; padding: 9px 14px; }

  /* Trigger: full-width, styled like other mobile nav links */
  .ts-mega-trigger {
    width: 100%;
    justify-content: space-between;
    padding: 10px 0;
    font-size: 16px;
    border-bottom: 1px solid var(--ts-line-soft);
  }
  .ts-mega-item.ts-mega-open .ts-mega-trigger {
    color: var(--ts-blue);
    border-bottom-color: transparent;
  }
  .ts-mega-item.ts-mega-open .ts-mega-chevron { transform: rotate(180deg); }
}

/* =============================================================================
   RESOURCES NAV DROPDOWN
   Single-column panel anchored to its own <li>. Solid opaque background,
   high z-index — never bleeds through. Right-aligned (last nav item).
============================================================================= */

/* ── List item wrapper ───────────────────────────────────────────────────────── */
.ts-res-item {
  position: relative;
  height: var(--ts-header-h);  /* full header height → top:100% = header bottom */
  display: flex;
  align-items: center;
}

/* Open state — re-use shared trigger + chevron classes */
.ts-res-item.ts-res-open .ts-mega-trigger { color: var(--ts-blue); outline: none; }
.ts-res-item.ts-res-open .ts-mega-chevron { transform: rotate(180deg); }

/* ── Panel — hidden by default ───────────────────────────────────────────────── */
.tmseva-resources-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  width: 300px;
  max-height: 80vh;
  overflow-y: auto;
  overflow-x: hidden;
  box-sizing: border-box;
  padding: 12px;
  background: #fff;             /* solid opaque — prevents page bleed-through */
  border-top: 2px solid var(--ts-blue);
  border-radius: 0 0 12px 12px;
  box-shadow: 0 12px 32px rgba(0,0,0,.14);
  z-index: 1000;                /* above page content */
}

.ts-res-item.ts-res-open .tmseva-resources-dropdown {
  display: block;
  animation: ts-mega-drop .14s ease both;
}

/* ── Groups ──────────────────────────────────────────────────────────────────── */
.tmseva-resources-group { margin-bottom: 6px; }

/* Divider between groups — only between siblings, not above the first */
.tmseva-resources-group + .tmseva-resources-group {
  border-top: 1px solid #eef2f7;
  margin-top: 8px;
  padding-top: 8px;
}

.tmseva-resources-heading {
  font: 700 .72rem/1 'Hanken Grotesk', system-ui, sans-serif;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: #64748b;
  padding: 6px 8px 4px;
  margin-top: 2px;
  /* subtle left accent bar */
  border-left: 3px solid var(--ts-blue);
  padding-left: 6px;
}

/* ── Article links (flat <a> — no ul/li) ─────────────────────────────────────── */
.tmseva-resources-link {
  display: block;
  padding: 8px;
  border-radius: 8px;
  font: 500 13.5px/1.35 'Hanken Grotesk', system-ui, sans-serif;
  color: #16203a;
  text-decoration: none;
  border-bottom: none !important;  /* override mobile nav <a> border */
  transition: background .12s, color .12s;
}

.tmseva-resources-link::before { content: none; }  /* dots removed — dividers + heading bars provide structure */

.tmseva-resources-link:hover {
  background: #f1f5f9;
  color: var(--ts-blue);
}

/* ── View-all footer ─────────────────────────────────────────────────────────── */
.tmseva-resources-footer {
  border-top: 1px solid var(--ts-line-soft);
  margin-top: 6px;
  padding-top: 4px;
}

.tmseva-resources-footer a {
  display: block;
  padding: 8px;
  font: 700 13px/1 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-blue);
  text-decoration: none;
  border-bottom: none !important;
}

.tmseva-resources-footer a:hover { color: var(--ts-blue-dark); text-decoration: underline; }

/* ── Mobile (≤980px): in-flow accordion ─────────────────────────────────────── */
@media (max-width: 980px) {

  .ts-res-item {
    height: auto;
    display: block;
    position: static;
  }

  .tmseva-resources-dropdown {
    display: none;
    position: static;
    width: 100%;
    max-height: none;
    overflow: visible;
    padding: 4px 0 8px;
    background: transparent;    /* in-flow accordion — page bg shows through, expected */
    border-top: 1px solid var(--ts-line-soft);
    border-radius: 0;
    box-shadow: none;
    animation: none !important;
  }

  .ts-res-item.ts-res-open .tmseva-resources-dropdown {
    display: block;
    animation: none !important;
  }

  /* Suppress trigger bottom border when panel is open (avoid double line) */
  .ts-res-item.ts-res-open .ts-mega-trigger { border-bottom-color: transparent; }

  .tmseva-resources-heading { padding: 8px 0 2px; }

  .tmseva-resources-link {
    padding: 9px 0 9px 12px;
    font-size: 15px;
    border-radius: 0;
    border-bottom: 1px solid var(--ts-line-soft) !important;
  }

  .tmseva-resources-footer { border-top: none; margin-top: 0; padding-top: 0; }

  .tmseva-resources-footer a {
    padding: 9px 0 9px 12px;
    font-size: 13px;
    border-bottom: none !important;
  }
}

/* =============================================================================
   HOMEPAGE v2 — New Sections
   All new classes are prefixed ts-hero-*, ts-journey-*, ts-cm-*, ts-biz-*,
   ts-usp-*, ts-expert-* to avoid collisions with existing code.
============================================================================= */

/* ── Hero v2: eyebrow chip ──────────────────────────────────────────────────── */
.ts-hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: var(--ts-blue-soft);
  color: var(--ts-blue);
  border-radius: 99px;
  padding: 7px 14px;
  font: 600 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  margin-bottom: 18px;
}
.ts-hero-eyebrow svg { width: 13px; height: 13px; flex-shrink: 0; }

/* ── Hero v2: feature chips ─────────────────────────────────────────────────── */
.ts-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 24px;
}
.ts-hero-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 99px;
  padding: 5px 12px;
  font: 500 12px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  white-space: nowrap;
}
.ts-hero-chip::before {
  content: '✓';
  color: var(--ts-green);
  font-weight: 700;
  font-size: 11px;
  flex-shrink: 0;
}

/* ── Hero v2: right-column search wrapper ───────────────────────────────────── */
#ts-hero .ts-hero-grid { align-items: center; } /* v2: center-align the two cols */

.ts-hero-search-col {
  position: relative;
  display: flex;
  flex-direction: column;
}

/* Gradient top accent line injected onto the existing .tmh-search-card */
.ts-hero-search-col .tmh-search-card {
  position: relative;
  overflow: hidden;
  box-shadow: 0 6px 40px rgba(36, 86, 216, .14), 0 1px 4px rgba(22, 32, 58, .06);
  border-color: #D0DDF8;
  border-radius: 18px;
}
.ts-hero-search-col .tmh-search-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--ts-blue) 0%, #5C8DF6 50%, var(--ts-green) 100%);
  border-radius: 18px 18px 0 0;
  pointer-events: none;
}

/* Decorative shield watermark */
.ts-hero-shield {
  position: absolute;
  top: -24px;
  right: -24px;
  width: 110px;
  height: 110px;
  color: var(--ts-blue);
  opacity: .05;
  pointer-events: none;
}

/* Trust note below search card */
.ts-hero-search-note {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-size: 12px;
  color: var(--ts-ink-soft);
  margin: 12px 0 0;
  text-align: center;
}
.ts-hero-search-note svg { width: 14px; height: 14px; color: var(--ts-green); flex-shrink: 0; }

/* ── Journey section ─────────────────────────────────────────────────────────── */
.ts-journey-section { padding-bottom: 48px; }

.ts-journey {
  position: relative;
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  margin-top: 8px;
}

/* Horizontal connecting line — sits at the vertical centre of the badges */
.ts-journey::before {
  content: '';
  position: absolute;
  top: 17px; /* half of 36px badge height */
  left: calc(100% / 14);
  right: calc(100% / 14);
  height: 2px;
  background: linear-gradient(90deg, #D6E4FF 0%, #C5D5F0 50%, #D6E4FF 100%);
  z-index: 0;
}

.ts-jstep {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 0 4px;
  position: relative;
  z-index: 1;
}

.ts-jstep-badge {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: #fff;
  font: 700 13px 'Hanken Grotesk', system-ui, sans-serif;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 0 0 5px var(--ts-surface); /* halo masks the connecting line */
  margin-bottom: 12px;
}

.ts-jstep-content { display: flex; flex-direction: column; align-items: center; }

.ts-jstep-icon {
  width: 42px;
  height: 42px;
  border-radius: 11px;
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 10px;
  box-shadow: var(--ts-shadow-sm);
}

.ts-jstep-title {
  font: 700 12px/1.25 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin-bottom: 4px;
}
.ts-jstep-desc {
  font: 400 11px/1.35 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
}

.ts-journey-cta {
  display: flex;
  justify-content: center;
  margin-top: 36px;
}

/* ── Why the right class matters ────────────────────────────────────────────── */
.ts-class-matters-section { background: var(--ts-bg); }

.ts-cm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

.ts-cm-eyebrow {
  display: inline-block;
  font: 700 11px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--ts-blue);
  margin-bottom: 12px;
}

.ts-cm-heading {
  font-size: 26px;
  line-height: 1.2;
  margin: 0 0 12px;
}

.ts-cm-lede {
  font-size: 14px;
  color: var(--ts-ink-soft);
  margin-bottom: 20px;
  line-height: 1.65;
}

.ts-cm-risks { display: flex; flex-direction: column; gap: 10px; }

.ts-cm-risk-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font: 500 13.5px 'Hanken Grotesk', system-ui, sans-serif;
  padding: 10px 14px;
  border-radius: 10px;
}
.ts-cm-risk-item svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; }
.ts-cm-bad  { background: var(--ts-red-soft);   color: #B92D31; }
.ts-cm-bad  svg { color: var(--ts-red); }
.ts-cm-good { background: var(--ts-green-soft); color: #0F7A43; }
.ts-cm-good svg { color: var(--ts-green); }

/* Examples card (right col) */
.ts-cm-examples {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 16px;
  padding: 24px;
  box-shadow: var(--ts-shadow-sm);
}

.ts-cm-ex-head {
  display: flex;
  align-items: center;
  gap: 7px;
  font: 700 12px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--ts-ink-soft);
  padding-bottom: 14px;
  border-bottom: 1px solid var(--ts-line);
  margin-bottom: 14px;
}
.ts-cm-ex-head svg { color: var(--ts-blue); }

.ts-cm-ex-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--ts-line-soft);
}
.ts-cm-ex-row:last-of-type { border-bottom: none; }

.ts-cm-ex-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

.ts-cm-ex-info {
  display: flex;
  align-items: center;
  gap: 7px;
  flex: 1;
  min-width: 0;
}
.ts-cm-ex-product {
  font: 600 13px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  white-space: nowrap;
}
.ts-cm-ex-arrow { color: var(--ts-ink-soft); font-size: 14px; }
.ts-cm-ex-class { font: 700 12px 'Hanken Grotesk', system-ui, sans-serif; white-space: nowrap; }
.ts-cm-ex-label {
  font: 400 11.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  white-space: nowrap;
}

.ts-cm-ex-note {
  font-size: 12px;
  color: var(--ts-ink-soft);
  margin: 14px 0 0;
  padding-top: 12px;
  border-top: 1px solid var(--ts-line);
  font-style: italic;
}

/* ── Business types grid ─────────────────────────────────────────────────────── */
.ts-biz-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}

.ts-biz-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: var(--ts-surface);
  border: 1.5px solid var(--ts-line);
  border-radius: 14px;
  padding: 22px 14px 18px;
  text-decoration: none;
  color: var(--ts-ink);
  box-shadow: var(--ts-shadow-sm);
  transition: border-color .15s, box-shadow .15s, transform .15s;
  cursor: pointer;
  position: relative;
  overflow: hidden;
}
.ts-biz-card:hover {
  border-color: var(--ts-blue);
  box-shadow: 0 6px 24px rgba(36, 86, 216, .12);
  transform: translateY(-2px);
  color: var(--ts-ink);
  text-decoration: none;
}
@media (prefers-reduced-motion: reduce) {
  .ts-biz-card { transition: border-color .15s; }
  .ts-biz-card:hover { transform: none; }
}

.ts-biz-icon {
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 12px;
  flex-shrink: 0;
}

.ts-biz-label {
  font: 600 13px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin-bottom: 8px;
  line-height: 1.3;
}

.ts-biz-class {
  font: 700 11px 'Hanken Grotesk', system-ui, sans-serif;
  padding: 3px 9px;
  border-radius: 99px;
  background: transparent; /* relies on inline color, no bg needed */
  border: 1.5px solid currentColor;
  opacity: .85;
}

.ts-biz-note {
  text-align: center;
  font-size: 13.5px;
  color: var(--ts-ink-soft);
}
.ts-biz-note a { color: var(--ts-blue); font-weight: 600; }

/* ── USP: ₹2,000 all-inclusive ───────────────────────────────────────────────── */
.ts-usp-section {
  background: linear-gradient(160deg, #EEF4FF 0%, #F7FAFF 100%);
  border-top: 1px solid #D6E4FF;
  border-bottom: 1px solid #D6E4FF;
}

.ts-usp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}

.ts-usp-label {
  font: 700 11px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ts-blue);
  margin-bottom: 10px;
}

.ts-usp-price {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 68px;
  font-weight: 600;
  line-height: 1;
  color: var(--ts-ink);
  letter-spacing: -.03em;
  margin-bottom: 8px;
}
.ts-usp-currency {
  font-size: 40px;
  vertical-align: super;
  line-height: 1;
}

.ts-usp-tagline {
  font: 600 15px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-green);
  margin-bottom: 22px;
}

.ts-usp-checklist {
  list-style: none;
  margin: 0 0 20px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.ts-usp-checklist li {
  display: flex;
  align-items: center;
  gap: 10px;
  font: 500 14px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
}
.ts-usp-checklist li svg { width: 18px; height: 18px; color: var(--ts-green); flex-shrink: 0; }

.ts-usp-distinction {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font: 400 13px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  font-style: italic;
  margin-bottom: 24px;
  padding: 10px 14px;
  background: rgba(21, 160, 90, .07);
  border-radius: 8px;
  border-left: 3px solid var(--ts-green);
}
.ts-usp-distinction svg { flex-shrink: 0; margin-top: 1px; color: var(--ts-green); }

.ts-usp-govt-note {
  font: 400 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin-bottom: 16px;
  padding: 8px 12px;
  background: rgba(36, 86, 216, .06);
  border-radius: 6px;
  border-left: 3px solid var(--ts-blue);
}

.ts-usp-cta { font-size: 15px; padding: 14px 22px; }

.ts-usp-visual-col { display: flex; align-items: center; justify-content: center; }
.ts-usp-visual-img {
  width: 100%;
  max-width: 440px;
  border-radius: 20px;
  box-shadow: 0 8px 40px rgba(36, 86, 216, .18);
}
.ts-usp-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  width: 100%;
  max-width: 440px;
  min-height: 260px;
  border: 2px dashed #c5d5f0;
  border-radius: 16px;
  background: rgba(36, 86, 216, .03);
  padding: 32px 28px;
  text-align: center;
}
.ts-usp-placeholder svg { width: 40px; height: 40px; color: #c5d5f0; }
.ts-usp-placeholder p {
  margin: 0;
  font: 400 13px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  max-width: 220px;
  line-height: 1.55;
}

/* ── Awareness: what happens after filing ─────────────────────────────────────── */
.ts-after-filing-section { background: var(--ts-bg); }

.ts-af-eyebrow {
  font: 700 11px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--ts-amber);
  text-align: center;
  margin: 0 0 8px;
}

/* Journey strip */
.ts-af-steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  margin: 36px auto 40px;
  max-width: 780px;
  overflow-x: auto;
  padding-bottom: 4px;
}

.ts-af-connector {
  flex: 1 0 12px;
  max-width: 52px;
  min-width: 6px;
  height: 2px;
  background: var(--ts-line);
  margin-top: 23px; /* aligns to centre of 48px badge */
  flex-shrink: 1;
}

.ts-af-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  width: 92px;
  flex-shrink: 0;
}

.ts-af-step-badge {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ts-af-step-badge svg { width: 20px; height: 20px; }

.ts-af-step-label {
  font: 600 11.5px 'Hanken Grotesk', system-ui, sans-serif;
  text-align: center;
  line-height: 1.3;
  color: var(--ts-ink-soft);
}

.ts-af-step-risk-tag {
  display: inline-block;
  font: 700 9px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 2px 6px;
  border-radius: 99px;
}

/* Step colour variants */
.ts-af-step--ok .ts-af-step-badge {
  background: var(--ts-line-soft);
  color: var(--ts-ink-soft);
}

.ts-af-step--risk .ts-af-step-badge      { background: var(--ts-amber-soft); color: var(--ts-amber); }
.ts-af-step--risk .ts-af-step-label      { color: var(--ts-amber); font-weight: 700; }
.ts-af-step--risk .ts-af-step-risk-tag   { background: var(--ts-amber-soft); color: var(--ts-amber); }

.ts-af-step--risk-high .ts-af-step-badge    { background: var(--ts-red-soft); color: var(--ts-red); }
.ts-af-step--risk-high .ts-af-step-label    { color: var(--ts-red); font-weight: 700; }
.ts-af-step--risk-high .ts-af-step-risk-tag { background: var(--ts-red-soft); color: var(--ts-red); }

.ts-af-step--success .ts-af-step-badge { background: var(--ts-green-soft); color: var(--ts-green); }
.ts-af-step--success .ts-af-step-label { color: var(--ts-green); }

/* Explainer cards */
.ts-af-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 24px;
}

.ts-af-card {
  display: flex;
  gap: 16px;
  padding: 24px;
  border-radius: 14px;
  border: 1.5px solid transparent;
  background: var(--ts-surface);
}
.ts-af-card--dept  { border-color: #f3d8a0; background: #fffbf2; }
.ts-af-card--third { border-color: #f5c0c0; background: #fff6f6; }

.ts-af-card-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ts-af-card-icon svg { width: 20px; height: 20px; }
.ts-af-card--dept  .ts-af-card-icon { background: var(--ts-amber-soft); color: var(--ts-amber); }
.ts-af-card--third .ts-af-card-icon { background: var(--ts-red-soft);   color: var(--ts-red);   }

.ts-af-card-body { flex: 1; min-width: 0; }

.ts-af-card-tag {
  display: inline-block;
  font: 700 10px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .08em;
  padding: 3px 8px;
  border-radius: 99px;
  margin-bottom: 8px;
}
.ts-af-card--dept  .ts-af-card-tag { background: var(--ts-amber-soft); color: var(--ts-amber); }
.ts-af-card--third .ts-af-card-tag { background: var(--ts-red-soft);   color: var(--ts-red);   }

.ts-af-card-title {
  font: 700 17px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin: 0 0 8px;
}

.ts-af-card-body p {
  font-size: 13.5px;
  color: var(--ts-ink-soft);
  line-height: 1.55;
  margin: 0 0 10px;
}

.ts-af-card-note {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  font: 600 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: #0F7A43;
  background: var(--ts-green-soft);
  border-radius: 8px;
  padding: 8px 10px;
  margin: 0;
  line-height: 1.4;
}
.ts-af-card-note svg { width: 14px; height: 14px; flex-shrink: 0; margin-top: 1px; }

/* Insight callout */
.ts-af-callout {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 20px 24px;
  background: var(--ts-ink);
  color: rgba(255,255,255,.88);
  border-radius: 12px;
  margin-bottom: 28px;
  font-size: 14px;
  line-height: 1.6;
}
.ts-af-callout p      { margin: 0; }
.ts-af-callout strong { color: #fff; }
.ts-af-callout-icon   { width: 22px; height: 22px; color: #F9C84D; flex-shrink: 0; margin-top: 2px; }

/* CTA row */
.ts-af-ctas {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

/* Responsive */
@media (max-width: 768px) {
  .ts-af-step { width: 74px; }
  .ts-af-step-badge { width: 42px; height: 42px; }
  .ts-af-step-label { font-size: 10.5px; }
  .ts-af-connector  { margin-top: 20px; }
  .ts-af-step-risk-tag { display: none; }
  .ts-af-grid { grid-template-columns: 1fr; }
}

@media (max-width: 520px) {
  .ts-af-steps   { display: none; }
  .ts-af-callout { flex-direction: column; gap: 8px; }
  .ts-af-ctas    { flex-direction: column; align-items: stretch; text-align: center; }
}

/* ── Stats band: icon items ──────────────────────────────────────────────────── */
.ts-stat-icon-item {
  display: flex;
  justify-content: center;
  margin-bottom: 8px;
}
.ts-stat-icon-item svg {
  width: 38px;
  height: 38px;
  color: #4ED38A;
}

/* ── Talk to expert ───────────────────────────────────────────────────────────── */
.ts-expert-band {
  background: linear-gradient(135deg, #16203A 0%, #1E2D55 60%, #1A3060 100%);
  border-radius: 20px;
  padding: 52px 56px;
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 48px;
  align-items: center;
  overflow: hidden;
  position: relative;
}

/* Subtle background glow */
.ts-expert-band::before {
  content: '';
  position: absolute;
  top: -60px;
  right: -60px;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(36, 86, 216, .25) 0%, transparent 70%);
  pointer-events: none;
}

.ts-expert-illus {
  flex-shrink: 0;
  width: 220px;
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: .9;
}
.ts-expert-illus svg { width: 100%; height: 100%; }

.ts-expert-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(78, 211, 138, .15);
  color: #4ED38A;
  border-radius: 99px;
  padding: 6px 14px;
  font: 700 12px 'Hanken Grotesk', system-ui, sans-serif;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin-bottom: 16px;
}
.ts-expert-badge svg { width: 14px; height: 14px; }

.ts-expert-heading {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 28px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 12px;
  line-height: 1.2;
}

.ts-expert-lede {
  font-size: 14.5px;
  color: rgba(255, 255, 255, .75);
  margin: 0 0 24px;
  line-height: 1.65;
  max-width: 38em;
}

.ts-expert-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 16px;
}

.ts-expert-cta-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--ts-green);
  color: #fff;
  border-radius: 11px;
  padding: 13px 22px;
  font: 700 15px 'Hanken Grotesk', system-ui, sans-serif;
  text-decoration: none;
  transition: background .15s;
}
.ts-expert-cta-primary:hover { background: #128a4d; color: #fff; }
.ts-expert-cta-primary svg { width: 18px; height: 18px; }

.ts-expert-cta-secondary {
  font: 600 14px 'Hanken Grotesk', system-ui, sans-serif;
  color: rgba(255, 255, 255, .75);
  text-decoration: none;
  transition: color .15s;
}
.ts-expert-cta-secondary:hover { color: #fff; }

.ts-expert-hours {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12.5px;
  color: rgba(255, 255, 255, .45);
  margin: 0;
}
.ts-expert-hours svg { flex-shrink: 0; }

/* ────────────────────────────────────────────────────────────────────────────
   RESPONSIVE — homepage v2 additions
────────────────────────────────────────────────────────────────────────────── */

/* ── Tablet (≤ 980px) ────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
  /* Hero: stack search card below content */
  #ts-hero .ts-hero-grid { grid-template-columns: 1fr; align-items: start; }
  .ts-hero-search-col { margin-top: 28px; }
  .ts-hero-shield { width: 70px; height: 70px; top: -12px; right: -12px; }

  /* Journey: switch to vertical single column */
  .ts-journey { grid-template-columns: 1fr; }
  .ts-journey::before { display: none; }
  .ts-jstep {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    gap: 14px;
    padding-bottom: 20px;
    position: relative;
  }
  .ts-jstep:not(:last-child)::after {
    content: '';
    position: absolute;
    top: 36px;
    left: 17px;
    width: 2px;
    bottom: 0;
    background: var(--ts-line);
    z-index: 0;
  }
  .ts-jstep-badge { flex-shrink: 0; margin-bottom: 0; box-shadow: 0 0 0 4px var(--ts-surface); }
  .ts-jstep-content { align-items: flex-start; padding-top: 6px; }
  .ts-jstep-icon { margin: 0 0 8px; }

  /* Class matters: stack */
  .ts-cm-grid { grid-template-columns: 1fr; gap: 28px; }

  /* Business types: 2×4 */
  .ts-biz-grid { grid-template-columns: repeat(2, 1fr); }

  /* USP: stack */
  .ts-usp-grid { grid-template-columns: 1fr; gap: 36px; }
  .ts-usp-visual-col { order: -1; }
  .ts-usp-price { font-size: 52px; }

  /* Expert: stack */
  .ts-expert-band { grid-template-columns: 1fr; padding: 36px 28px; gap: 28px; }
  .ts-expert-illus { width: 140px; height: 120px; margin: 0 auto; }
}

/* ── Small tablet (≤ 640px) ──────────────────────────────────────────────────── */
@media (max-width: 640px) {
  /* Hero chips: allow wrapping to 2 rows */
  .ts-hero-chips { gap: 6px; }
  .ts-hero-chip { font-size: 11px; padding: 5px 10px; }

  /* Journey: compact vertical */
  .ts-jstep { padding-bottom: 16px; gap: 12px; }
  .ts-jstep-badge { width: 30px; height: 30px; font-size: 11px; }
  .ts-jstep:not(:last-child)::after { top: 30px; left: 14px; }
  .ts-jstep-title { font-size: 13px; }

  /* Class matters */
  .ts-cm-heading { font-size: 22px; }
  .ts-cm-ex-info { flex-wrap: wrap; }
  .ts-cm-ex-product, .ts-cm-ex-class { font-size: 12px; }
  .ts-cm-ex-label { font-size: 11px; }

  /* Business types: 2 cols remain on small mobile */
  .ts-biz-icon { width: 44px; height: 44px; border-radius: 12px; }
  .ts-biz-label { font-size: 12px; }

  /* USP */
  .ts-usp-price { font-size: 44px; }
  .ts-usp-currency { font-size: 28px; }
  .ts-usp-tagline { font-size: 13.5px; }

  /* Expert */
  .ts-expert-band { padding: 28px 20px; border-radius: 14px; }
  .ts-expert-heading { font-size: 22px; }
  .ts-expert-illus { display: none; } /* hide on small mobile — saves space */
  .ts-expert-actions { flex-direction: column; align-items: flex-start; }
  .ts-expert-cta-primary { width: 100%; justify-content: center; }
}

/* =============================================================================
   Contact Page — Hero
============================================================================= */

.ts-contact-hero {
  background: linear-gradient(135deg, var(--ts-bg) 0%, #EEF4FF 100%);
  border-bottom: 1px solid var(--ts-line);
  padding: 52px 0 44px;
}
.ts-contact-hero-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.ts-contact-hero-text h1 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 36px;
  font-weight: 600;
  color: var(--ts-ink);
  margin: 10px 0 12px;
}
.ts-contact-hero-text p {
  font: 400 16px/1.65 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  max-width: 520px;
}
.ts-contact-hero-ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

/* ── WhatsApp CTA button ─────────────────────────────────────────────────── */
.ts-contact-cta-wa,
.ts-contact-wa-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 10px;
  font: 600 14px 'Hanken Grotesk', system-ui, sans-serif;
  background: #25D366;
  color: #fff;
  text-decoration: none;
  transition: background .18s, box-shadow .18s;
}
.ts-contact-cta-wa:hover,
.ts-contact-wa-btn:hover {
  background: #1ebe57;
  box-shadow: 0 4px 16px rgba(37,211,102,.3);
}
.ts-contact-cta-call {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* =============================================================================
   Contact Page — Grid
============================================================================= */

.ts-contact-section { background: var(--ts-bg); }

.ts-contact-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 40px;
  align-items: start;
}

/* ── Shared card ─────────────────────────────────────────────────────────── */
.ts-contact-card {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 18px;
  padding: 36px 32px;
  box-shadow: 0 2px 24px rgba(22, 32, 58, .06);
}
.ts-contact-card-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Fraunces', Georgia, serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--ts-ink);
  margin: 0 0 24px;
}
.ts-contact-card-title svg { color: var(--ts-blue); flex-shrink: 0; }

/* ── Firm info card ──────────────────────────────────────────────────────── */
.ts-contact-info-card { margin-bottom: 16px; }

.ts-contact-info-items { display: flex; flex-direction: column; gap: 20px; }

.ts-ci-group { display: grid; grid-template-columns: 90px 1fr; gap: 4px 12px; align-items: start; }

.ts-ci-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font: 600 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  text-transform: uppercase;
  letter-spacing: .04em;
  padding-top: 2px;
}
.ts-ci-label svg { color: var(--ts-blue); flex-shrink: 0; }

.ts-ci-values {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ts-ci-link {
  font: 500 14.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-blue);
  text-decoration: none;
  word-break: break-all;
}
.ts-ci-link:hover { text-decoration: underline; }

.ts-ci-address {
  font: 400 14.5px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  font-style: normal;
}

.ts-ci-values span {
  font: 400 14.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
}

.ts-contact-info-ctas {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--ts-line);
  flex-wrap: wrap;
}

/* ── Map ─────────────────────────────────────────────────────────────────── */
.ts-contact-map {
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--ts-line);
  box-shadow: 0 2px 16px rgba(22,32,58,.06);
}
.ts-contact-map iframe { display: block; }

/* =============================================================================
   Contact Form — shared styles (rendered by shortcode)
============================================================================= */

.tmseva-cf-wrap { width: 100%; }

.tmseva-contact-form { display: flex; flex-direction: column; gap: 18px; }

.tmseva-cf-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.tmseva-cf-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.tmseva-cf-field label {
  font: 600 13.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  display: flex;
  align-items: center;
  gap: 5px;
}
.tmseva-cf-req { color: var(--ts-blue); }
.tmseva-cf-opt {
  font-weight: 400;
  color: var(--ts-ink-soft);
  font-size: 12px;
}
.tmseva-cf-field input,
.tmseva-cf-field textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--ts-line);
  border-radius: 10px;
  font: 400 14.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  background: var(--ts-surface);
  transition: border-color .15s, box-shadow .15s;
  box-sizing: border-box;
  resize: vertical;
}
.tmseva-cf-field input:focus,
.tmseva-cf-field textarea:focus {
  outline: none;
  border-color: var(--ts-blue);
  box-shadow: 0 0 0 3px rgba(36,86,216,.12);
}
.tmseva-cf-field input[aria-invalid="true"],
.tmseva-cf-field textarea[aria-invalid="true"] {
  border-color: #E53E3E;
}
.tmseva-cf-err {
  font: 400 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: #E53E3E;
  min-height: 1em;
}

.tmseva-cf-consent {
  font: 400 12px/1.55 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}
.tmseva-cf-consent a { color: var(--ts-blue); }

.tmseva-cf-error-banner {
  background: #FFF5F5;
  border: 1px solid #FED7D7;
  border-radius: 8px;
  padding: 12px 16px;
  font: 400 13.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: #C53030;
}

.tmseva-cf-submit { width: 100%; justify-content: center; padding: 14px 22px; font-size: 15px; }

/* ── Success state ───────────────────────────────────────────────────────── */
.tmseva-cf-success {
  display: flex;
  align-items: flex-start;
  gap: 18px;
  padding: 28px 24px;
  background: rgba(21,160,90,.06);
  border: 1.5px solid rgba(21,160,90,.25);
  border-radius: 14px;
}
.tmseva-cf-success svg {
  width: 44px;
  height: 44px;
  color: var(--ts-green);
  flex-shrink: 0;
}
.tmseva-cf-success h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--ts-ink);
  margin: 0 0 6px;
}
.tmseva-cf-success p { font: 400 14.5px 'Hanken Grotesk', system-ui, sans-serif; color: var(--ts-ink-soft); margin: 0; }

/* =============================================================================
   Contact Page — Responsive
============================================================================= */

@media (max-width: 980px) {
  .ts-contact-grid { grid-template-columns: 1fr; }
  .ts-contact-info-col { order: -1; }
  .ts-contact-hero-text h1 { font-size: 28px; }
  .ts-contact-hero-ctas { width: 100%; }
}

@media (max-width: 640px) {
  .ts-contact-hero { padding: 36px 0 28px; }
  .ts-contact-card { padding: 24px 20px; }
  .tmseva-cf-row { grid-template-columns: 1fr; }
  .ts-ci-group { grid-template-columns: 1fr; gap: 4px; }
  .ts-ci-label { margin-bottom: 2px; }
  .ts-contact-info-ctas { flex-direction: column; align-items: stretch; }
  .ts-contact-cta-wa, .ts-contact-wa-btn, .ts-contact-cta-call.ts-btn-primary { width: 100%; justify-content: center; }
}

/* ── Very small (≤ 380px) ────────────────────────────────────────────────────── */
@media (max-width: 380px) {
  .ts-biz-grid { grid-template-columns: 1fr 1fr; } /* keep 2 cols */
  .ts-hero-chip::before { display: none; } /* remove tick on tiny screens to save space */
}

/* =============================================================================
   About Us Page
============================================================================= */

/* ── Hero ────────────────────────────────────────────────────────────────── */
.ts-about-hero {
  background: linear-gradient(135deg, #EEF4FF 0%, var(--ts-bg) 60%, #F0FAF4 100%);
  border-bottom: 1px solid var(--ts-line);
  padding: 60px 0 52px;
}
.ts-about-hero-inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}
.ts-about-hero-text { flex: 1; min-width: 280px; }
.ts-about-hero-text h1 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 42px;
  font-weight: 600;
  color: var(--ts-ink);
  margin: 12px 0 14px;
  line-height: 1.1;
}
.ts-about-hero-sub {
  font: 500 17px/1.55 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
  max-width: 480px;
}

.ts-about-hero-badges {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex-shrink: 0;
}
.ts-about-badge {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 18px;
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 10px;
  font: 500 13.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  box-shadow: var(--ts-shadow-sm);
}
.ts-about-badge svg { color: var(--ts-blue); flex-shrink: 0; }

/* ── Who We Are ──────────────────────────────────────────────────────────── */
.ts-about-story-grid {
  display: grid;
  grid-template-columns: 1fr 400px;
  gap: 60px;
  align-items: start;
}
.ts-about-story-text h2 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 32px;
  font-weight: 600;
  color: var(--ts-ink);
  margin: 8px 0 20px;
  line-height: 1.15;
}
.ts-about-story-text p {
  font: 400 15.5px/1.7 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin-bottom: 16px;
}

.ts-about-credential-card {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 18px;
  padding: 28px 24px;
  box-shadow: var(--ts-shadow-sm);
  display: flex;
  flex-direction: column;
  gap: 0;
}
.ts-about-cred-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 0;
  border-bottom: 1px solid var(--ts-line-soft);
}
.ts-about-cred-item:last-child { border-bottom: none; padding-bottom: 0; }
.ts-about-cred-item:first-child { padding-top: 0; }

.ts-about-cred-icon {
  width: 42px; height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ts-about-cred-icon--blue   { background: var(--ts-blue-soft);   color: var(--ts-blue); }
.ts-about-cred-icon--green  { background: var(--ts-green-soft);  color: var(--ts-green); }
.ts-about-cred-icon--purple { background: var(--ts-purple-soft); color: var(--ts-purple); }
.ts-about-cred-icon--amber  { background: var(--ts-amber-soft);  color: var(--ts-amber); }

.ts-about-cred-title {
  font: 600 13.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin-bottom: 3px;
  line-height: 1.3;
}
.ts-about-cred-body {
  font: 400 12.5px/1.5 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
}

/* ── Trust section ───────────────────────────────────────────────────────── */
.ts-about-trust-section { background: var(--ts-bg); }

.ts-about-trust-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.ts-about-trust-card {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 16px;
  padding: 26px 22px;
  box-shadow: var(--ts-shadow-sm);
  transition: box-shadow .18s, transform .18s;
}
.ts-about-trust-card:hover {
  box-shadow: 0 4px 24px rgba(22,32,58,.1);
  transform: translateY(-2px);
}
.ts-about-trust-icon {
  width: 46px; height: 46px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.ts-about-trust-card--blue   .ts-about-trust-icon { background: var(--ts-blue-soft);   color: var(--ts-blue); }
.ts-about-trust-card--green  .ts-about-trust-icon { background: var(--ts-green-soft);  color: var(--ts-green); }
.ts-about-trust-card--amber  .ts-about-trust-icon { background: var(--ts-amber-soft);  color: var(--ts-amber); }
.ts-about-trust-card--purple .ts-about-trust-icon { background: var(--ts-purple-soft); color: var(--ts-purple); }

.ts-about-trust-card h3 {
  font: 600 15px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin: 0 0 8px;
  line-height: 1.3;
}
.ts-about-trust-card p {
  font: 400 13.5px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}

/* ── Values section ──────────────────────────────────────────────────────── */
.ts-about-values-section {
  background: linear-gradient(160deg, #F8FBFF 0%, var(--ts-bg) 100%);
}
.ts-about-values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.ts-about-value-card {
  padding: 24px 20px;
  border-radius: 14px;
  border: 1px solid var(--ts-line);
  background: var(--ts-surface);
}
.ts-about-value-icon {
  width: 42px; height: 42px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
}
.ts-about-value-card--blue   .ts-about-value-icon { background: var(--ts-blue-soft);   color: var(--ts-blue); }
.ts-about-value-card--green  .ts-about-value-icon { background: var(--ts-green-soft);  color: var(--ts-green); }
.ts-about-value-card--amber  .ts-about-value-icon { background: var(--ts-amber-soft);  color: var(--ts-amber); }
.ts-about-value-card--purple .ts-about-value-icon { background: var(--ts-purple-soft); color: var(--ts-purple); }

.ts-about-value-card h3 {
  font: 600 14.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin: 0 0 7px;
}
.ts-about-value-card p {
  font: 400 13px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}

/* ── Stats band ──────────────────────────────────────────────────────────── */
.ts-about-stats-band {
  background: linear-gradient(135deg, var(--ts-blue) 0%, var(--ts-blue-dark) 100%);
  padding: 52px 0 44px;
}
.ts-about-stats-inner {
  display: flex;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap;
}
.ts-about-stat {
  text-align: center;
  padding: 12px 40px;
  border-right: 1px solid rgba(255,255,255,.18);
}
.ts-about-stat:last-child { border-right: none; }
.ts-about-stat-value {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 48px;
  font-weight: 600;
  color: #fff;
  line-height: 1;
  letter-spacing: -.02em;
  margin-bottom: 6px;
}
.ts-about-stat-label {
  font: 500 13px 'Hanken Grotesk', system-ui, sans-serif;
  color: rgba(255,255,255,.75);
  text-transform: uppercase;
  letter-spacing: .06em;
}
.ts-about-stats-note {
  text-align: center;
  font: 400 12px 'Hanken Grotesk', system-ui, sans-serif;
  color: rgba(255,255,255,.5);
  margin: 20px 0 0;
}

/* ── How We Work ─────────────────────────────────────────────────────────── */
.ts-about-process-section { background: var(--ts-bg); }

.ts-about-process-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 32px;
}
.ts-about-process-step {
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 16px;
  padding: 26px 22px;
  position: relative;
}
.ts-about-step-badge {
  width: 38px; height: 38px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font: 700 13px 'Hanken Grotesk', system-ui, sans-serif;
  margin-bottom: 14px;
}
.ts-about-step-badge--blue   { background: var(--ts-blue-soft);   color: var(--ts-blue); }
.ts-about-step-badge--green  { background: var(--ts-green-soft);  color: var(--ts-green); }
.ts-about-step-badge--amber  { background: var(--ts-amber-soft);  color: var(--ts-amber); }
.ts-about-step-badge--purple { background: var(--ts-purple-soft); color: var(--ts-purple); }

.ts-about-process-step h3 {
  font: 600 15px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin: 0 0 8px;
  line-height: 1.3;
}
.ts-about-process-step p {
  font: 400 13.5px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}
.ts-about-process-cta { text-align: center; }

/* ── Testimonials ────────────────────────────────────────────────────────── */
.ts-about-testimonials-section {
  background: linear-gradient(160deg, var(--ts-bg) 0%, #EEF4FF 100%);
}
.ts-about-testi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 22px;
  margin-bottom: 16px;
}
.ts-about-tcard {
  margin: 0;
  background: var(--ts-surface);
  border: 1px solid var(--ts-line);
  border-radius: 16px;
  padding: 28px 26px;
  box-shadow: var(--ts-shadow-sm);
  position: relative;
}
.ts-about-tcard-quote {
  color: var(--ts-blue);
  width: 36px;
  height: 27px;
  margin-bottom: 12px;
  display: block;
}
.ts-about-tcard-body {
  font: 400 15px/1.7 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin: 0 0 20px;
  font-style: italic;
}
.ts-about-tcard-footer { display: flex; flex-direction: column; gap: 2px; }
.ts-about-tcard-name {
  font: 600 14px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
}
.ts-about-tcard-role {
  font: 400 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
}
.ts-about-testi-note {
  font: 400 12px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  text-align: center;
  margin: 0;
  font-style: italic;
}

/* Placeholder card (admin-only; visible when no real testimonials are configured) */
.ts-about-tcard--placeholder {
  border-style: dashed;
  border-color: var(--ts-amber);
  background: var(--ts-amber-soft);
}
.ts-about-tcard-placeholder-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font: 600 13px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-amber);
  margin: 0 0 10px;
}
.ts-about-tcard-placeholder-label svg { color: var(--ts-amber); flex-shrink: 0; }
.ts-about-tcard-placeholder-body {
  font: 400 13px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0 0 10px;
}
.ts-about-tcard-placeholder-example {
  font: 400 12px/1.5 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}
.ts-about-tcard-placeholder-example code {
  display: block;
  margin-top: 6px;
  padding: 10px 12px;
  background: rgba(0,0,0,.05);
  border-radius: 6px;
  font-size: 11px;
  word-break: break-all;
  color: var(--ts-ink);
}

/* ── Trust Signals ───────────────────────────────────────────────────────── */
.ts-about-signals-section { background: var(--ts-surface); }

.ts-about-signals-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
  margin-bottom: 20px;
}
.ts-about-signal-card {
  background: var(--ts-bg);
  border: 1px solid var(--ts-line);
  border-radius: 16px;
  padding: 26px 22px;
}
.ts-about-signal-icon {
  width: 54px; height: 54px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.ts-about-signal-icon--blue   { background: var(--ts-blue-soft);   color: var(--ts-blue); }
.ts-about-signal-icon--green  { background: var(--ts-green-soft);  color: var(--ts-green); }
.ts-about-signal-icon--purple { background: var(--ts-purple-soft); color: var(--ts-purple); }
.ts-about-signal-icon--amber  { background: var(--ts-amber-soft);  color: var(--ts-amber); }

.ts-about-signal-card h3 {
  font: 600 15px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink);
  margin: 0 0 8px;
}
.ts-about-signal-card p {
  font: 400 13.5px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}
.ts-about-signal-card--contact p,
.ts-about-signal-card--contact address { margin: 0 0 6px; }

.ts-about-contact-lines {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.ts-about-contact-lines a {
  font: 500 13.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-blue);
  text-decoration: none;
}
.ts-about-contact-lines a:hover { text-decoration: underline; }

.ts-about-address {
  font: 400 13px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  font-style: normal;
}
.ts-about-hours {
  font: 400 12.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  margin: 0;
}
.ts-about-disclaimer {
  font: 400 12px/1.6 'Hanken Grotesk', system-ui, sans-serif;
  color: var(--ts-ink-soft);
  text-align: center;
  max-width: 700px;
  margin: 0 auto;
  padding-top: 8px;
  border-top: 1px solid var(--ts-line-soft);
}

/* ── CTA band ────────────────────────────────────────────────────────────── */
.ts-about-cta-band {
  background: linear-gradient(135deg, var(--ts-blue) 0%, var(--ts-blue-dark) 100%);
  padding: 60px 0;
}
.ts-about-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  flex-wrap: wrap;
}
.ts-about-cta-text h2 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 32px;
  font-weight: 600;
  color: #fff;
  margin: 0 0 8px;
  line-height: 1.15;
}
.ts-about-cta-text p {
  font: 400 16px/1.55 'Hanken Grotesk', system-ui, sans-serif;
  color: rgba(255,255,255,.8);
  margin: 0;
}
.ts-about-cta-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.ts-about-cta-primary {
  background: #fff;
  color: var(--ts-blue) !important;
  border: 2px solid transparent;
}
.ts-about-cta-primary:hover { background: var(--ts-blue-soft); }
.ts-about-cta-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 22px;
  border-radius: 10px;
  font: 600 14.5px 'Hanken Grotesk', system-ui, sans-serif;
  color: rgba(255,255,255,.9);
  border: 1.5px solid rgba(255,255,255,.4);
  text-decoration: none;
  transition: background .18s, border-color .18s;
}
.ts-about-cta-secondary:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.7);
  color: #fff;
}

/* =============================================================================
   About Page — Responsive
============================================================================= */

@media (max-width: 1100px) {
  .ts-about-trust-grid  { grid-template-columns: repeat(2, 1fr); }
  .ts-about-values-grid { grid-template-columns: repeat(2, 1fr); }
  .ts-about-signals-grid { grid-template-columns: repeat(2, 1fr); }
  .ts-about-process-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px) {
  .ts-about-hero-text h1 { font-size: 32px; }
  .ts-about-hero-badges { flex-direction: row; flex-wrap: wrap; width: 100%; }
  .ts-about-story-grid { grid-template-columns: 1fr; gap: 36px; }
  .ts-about-cta-inner { flex-direction: column; text-align: center; }
  .ts-about-cta-actions { justify-content: center; }
  .ts-about-stat { padding: 10px 24px; }
  .ts-about-stat-value { font-size: 38px; }
}

@media (max-width: 640px) {
  .ts-about-hero { padding: 40px 0 36px; }
  .ts-about-hero-text h1 { font-size: 26px; }
  .ts-about-trust-grid,
  .ts-about-values-grid,
  .ts-about-signals-grid,
  .ts-about-process-grid { grid-template-columns: 1fr; }
  .ts-about-stats-inner { flex-direction: column; align-items: center; }
  .ts-about-stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,.15); padding: 14px 0; width: 100%; max-width: 260px; }
  .ts-about-stat:last-child { border-bottom: none; }
  .ts-about-stat-value { font-size: 40px; }
  .ts-about-cta-actions { flex-direction: column; width: 100%; }
  .ts-about-cta-primary,
  .ts-about-cta-secondary { width: 100%; justify-content: center; }
}


/* =============================================================================
   Pricing Page  (page-pricing.php)
============================================================================= */

/* ── Hero ─────────────────────────────────────────────────────────────────── */
.ts-pricing-hero {
  background: linear-gradient(135deg, var(--ts-blue) 0%, var(--ts-blue-dark) 100%);
  color: #fff;
  padding: 72px 0 60px;
  text-align: center;
}
.ts-pricing-hero-inner { max-width: 720px; margin: 0 auto; }
.ts-pricing-eyebrow-wrap { margin-bottom: 16px; }
.ts-pricing-eyebrow {
  display: inline-block;
  background: rgba(255,255,255,.15);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 16px;
  border-radius: 100px;
}
.ts-pricing-hero h1 {
  font-family: 'Fraunces', serif;
  font-size: 44px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 18px;
  line-height: 1.12;
}
.ts-pricing-hero-accent { color: #a8c3ff; }
.ts-pricing-hero-sub {
  font-size: 17px;
  color: rgba(255,255,255,.88);
  margin: 0 0 28px;
  line-height: 1.65;
}
.ts-pricing-hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}
.ts-pricing-pill {
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.28);
  color: #fff;
  font-size: 13px;
  font-weight: 600;
  padding: 5px 14px;
  border-radius: 100px;
}

/* ── Section common ───────────────────────────────────────────────────────── */
.ts-pricing-cards-section,
.ts-pricing-included-section,
.ts-pricing-faq-section { padding: 72px 0; background: #fff; }
.ts-pricing-calc-section,
.ts-pricing-compare-section { padding: 72px 0; background: var(--ts-bg); }
.ts-pricing-section-head {
  text-align: center;
  max-width: 620px;
  margin: 0 auto 48px;
}
.ts-pricing-section-head h2 {
  font-family: 'Fraunces', serif;
  font-size: 32px;
  font-weight: 600;
  color: var(--ts-ink);
  margin: 0 0 12px;
}
.ts-pricing-section-head p {
  font-size: 16px;
  color: #5a6275;
  margin: 0;
  line-height: 1.65;
}

/* ── At-a-glance cards ────────────────────────────────────────────────────── */
.ts-pricing-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  max-width: 780px;
  margin: 0 auto 20px;
}
.ts-pricing-card {
  background: #fff;
  border: 2px solid #e8eaf2;
  border-radius: 16px;
  padding: 32px 28px;
}
.ts-pricing-card--highlight {
  border-color: var(--ts-blue);
  box-shadow: 0 0 0 4px rgba(36,86,216,.07);
}
.ts-pricing-card-tag {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: #7c8499;
  margin-bottom: 14px;
}
.ts-pricing-card--highlight .ts-pricing-card-tag { color: var(--ts-blue); }
.ts-pricing-card-total {
  font-family: 'Fraunces', serif;
  font-size: 42px;
  font-weight: 700;
  color: var(--ts-ink);
  line-height: 1;
  margin-bottom: 4px;
}
.ts-pricing-card-total-sub {
  font-size: 13px;
  color: #7c8499;
  margin-bottom: 20px;
}
.ts-pricing-card-breakdown {
  list-style: none;
  padding: 16px 0 0;
  margin: 0 0 24px;
  border-top: 1px solid #eef0f7;
}
.ts-pricing-card-breakdown li {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  padding: 6px 0;
}
.ts-pricing-card-breakdown li span { color: #5a6275; }
.ts-pricing-card-breakdown li strong { font-weight: 700; color: var(--ts-ink); }
.ts-pricing-card-cta {
  display: block;
  background: var(--ts-blue);
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  padding: 11px 20px;
  border-radius: 8px;
  text-decoration: none;
  text-align: center;
  transition: background .18s;
}
.ts-pricing-card-cta:hover { background: var(--ts-blue-dark); color: #fff; }
.ts-pricing-cards-note {
  text-align: center;
  font-size: 13px;
  color: #7c8499;
  margin: 0;
}

/* ── Quote calculator wrapper ─────────────────────────────────────────────── */
.ts-pricing-calc-wrap { max-width: 780px; margin: 0 auto; }

/* ── What's included ──────────────────────────────────────────────────────── */
.ts-pricing-included-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 920px;
  margin: 0 auto 28px;
}
.ts-pricing-included-card {
  background: #fff;
  border: 1px solid #e8eaf2;
  border-radius: 14px;
  padding: 28px 24px;
}
.ts-pricing-included-card--standout {
  border-color: var(--ts-green);
  background: #f4fbf7;
}
.ts-pricing-included-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
}
.ts-pricing-icon--blue { background: #e8eefa; }
.ts-pricing-icon--blue svg { stroke: var(--ts-blue); }
.ts-pricing-icon--green { background: #e6f7ee; }
.ts-pricing-icon--green svg { stroke: var(--ts-green); }
.ts-pricing-included-card h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--ts-ink);
  margin: 0 0 8px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  line-height: 1.3;
}
.ts-pricing-included-badge {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  background: var(--ts-green);
  color: #fff;
  padding: 2px 9px;
  border-radius: 100px;
  line-height: 1.6;
}
.ts-pricing-included-card p {
  font-size: 14px;
  color: #5a6275;
  line-height: 1.65;
  margin: 0;
}
.ts-pricing-included-note {
  text-align: center;
  max-width: 580px;
  margin: 0 auto;
}
.ts-pricing-included-note p {
  font-size: 13px;
  color: #7c8499;
  margin: 0;
  border-top: 1px solid #eef0f7;
  padding-top: 20px;
}

/* ── Comparison ───────────────────────────────────────────────────────────── */
.ts-pricing-compare-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  max-width: 780px;
  margin: 0 auto 20px;
}
.ts-pricing-compare-col {
  border-radius: 14px;
  padding: 28px 24px;
}
.ts-pricing-compare-col--red  { background: #fff5f5; border: 1px solid #f9cccc; }
.ts-pricing-compare-col--green { background: #f3fbf6; border: 1px solid #c3e8d2; }
.ts-pricing-compare-head {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 15px;
  font-weight: 700;
  margin-bottom: 20px;
  line-height: 1.3;
}
.ts-pricing-compare-col--red  .ts-pricing-compare-head { color: #b83030; }
.ts-pricing-compare-col--green .ts-pricing-compare-head { color: #1a7a44; }
.ts-pricing-compare-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.ts-pricing-compare-col--red  .ts-pricing-compare-icon { background: #fad4d4; }
.ts-pricing-compare-col--green .ts-pricing-compare-icon { background: #c3e8d2; }
.ts-pricing-compare-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ts-pricing-compare-list li {
  font-size: 14px;
  color: var(--ts-ink);
  padding: 9px 0;
  border-bottom: 1px solid rgba(0,0,0,.06);
  display: flex;
  align-items: center;
  gap: 10px;
}
.ts-pricing-compare-list li:last-child { border-bottom: none; }
.ts-pricing-compare-list--red  li::before { content: '\2715'; color: #c0392b; font-weight: 900; font-size: 13px; flex-shrink: 0; }
.ts-pricing-compare-list--green li::before { content: '\2713'; color: var(--ts-green); font-weight: 900; font-size: 14px; flex-shrink: 0; }
.ts-pricing-compare-note {
  text-align: center;
  font-size: 12px;
  color: #9aa0b2;
  margin: 0;
}

/* ── Stats band ───────────────────────────────────────────────────────────── */
.ts-pricing-stats-band {
  background: linear-gradient(135deg, var(--ts-blue) 0%, var(--ts-blue-dark) 100%);
  padding: 52px 0;
}
.ts-pricing-stats-inner {
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex-wrap: wrap;
}
.ts-pricing-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 44px;
  border-right: 1px solid rgba(255,255,255,.18);
}
.ts-pricing-stat:last-child { border-right: none; }
.ts-pricing-stat-value {
  font-family: 'Fraunces', serif;
  font-size: 42px;
  font-weight: 700;
  color: #fff;
  line-height: 1;
  margin-bottom: 6px;
}
.ts-pricing-stat-label {
  font-size: 13px;
  font-weight: 500;
  color: rgba(255,255,255,.8);
  text-align: center;
}

/* ── FAQ ──────────────────────────────────────────────────────────────────── */
.ts-pricing-faq-list { max-width: 720px; margin: 0 auto; }
.ts-pricing-faq-item { border-bottom: 1px solid #eef0f7; }
.ts-pricing-faq-item:first-child { border-top: 1px solid #eef0f7; }
.ts-pricing-faq-q {
  font-size: 16px;
  font-weight: 600;
  color: var(--ts-ink);
  padding: 20px 44px 20px 0;
  cursor: pointer;
  list-style: none;
  position: relative;
  user-select: none;
  line-height: 1.4;
}
.ts-pricing-faq-q::-webkit-details-marker { display: none; }
.ts-pricing-faq-q::after {
  content: '+';
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 24px;
  font-weight: 300;
  color: var(--ts-blue);
  transition: transform .2s;
  line-height: 1;
}
.ts-pricing-faq-item[open] .ts-pricing-faq-q::after {
  transform: translateY(-50%) rotate(45deg);
}
.ts-pricing-faq-a { padding: 0 0 20px; }
.ts-pricing-faq-a p {
  font-size: 15px;
  color: #5a6275;
  line-height: 1.7;
  margin: 0;
}

/* ── CTA band ─────────────────────────────────────────────────────────────── */
.ts-pricing-cta-section {
  background: linear-gradient(135deg, var(--ts-ink) 0%, #253358 100%);
  padding: 72px 0;
  text-align: center;
}
.ts-pricing-cta-inner { max-width: 600px; margin: 0 auto; }
.ts-pricing-cta-inner h2 {
  font-family: 'Fraunces', serif;
  font-size: 36px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 16px;
}
.ts-pricing-cta-inner p {
  font-size: 17px;
  color: rgba(255,255,255,.82);
  margin: 0 0 32px;
  line-height: 1.55;
}
.ts-pricing-cta-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}
.ts-pricing-cta-primary {
  display: inline-flex;
  align-items: center;
  background: var(--ts-blue);
  color: #fff;
  font-weight: 700;
  font-size: 16px;
  padding: 14px 30px;
  border-radius: 10px;
  text-decoration: none;
  transition: background .18s;
}
.ts-pricing-cta-primary:hover { background: var(--ts-blue-dark); color: #fff; }
.ts-pricing-cta-secondary {
  display: inline-flex;
  align-items: center;
  background: rgba(255,255,255,.12);
  border: 1.5px solid rgba(255,255,255,.3);
  color: #fff;
  font-weight: 600;
  font-size: 16px;
  padding: 14px 30px;
  border-radius: 10px;
  text-decoration: none;
  transition: background .18s;
}
.ts-pricing-cta-secondary:hover { background: rgba(255,255,255,.2); color: #fff; }

/* ── Disclaimer ───────────────────────────────────────────────────────────── */
.ts-pricing-disclaimer {
  background: var(--ts-bg);
  padding: 24px 0;
  border-top: 1px solid #e8eaf2;
}
.ts-pricing-disclaimer p {
  font-size: 12px;
  color: #7c8499;
  line-height: 1.7;
  margin: 0 auto;
  text-align: center;
  max-width: 860px;
}

/* ── Pricing section shared head ─────────────────────────────────────────── */
.ts-pricing-section-head {
  text-align: center;
  margin-bottom: 48px;
}
.ts-pricing-section-head h2 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--ts-ink);
  margin: 0 0 12px;
}
.ts-pricing-section-head p {
  font-size: 16px;
  color: #5a6278;
  max-width: 600px;
  margin: 0 auto;
}
.ts-pricing-cards-section { padding: 80px 0; background: #fff; }
.ts-pricing-cards-note {
  text-align: center;
  font-size: 14px;
  color: #7c8499;
  margin: 24px auto 0;
  max-width: 600px;
}
.ts-pricing-compare-section { padding: 80px 0; background: #fff; }
.ts-pricing-compare-note {
  text-align: center;
  font-size: 13px;
  color: #9aa0b0;
  margin-top: 28px;
}

/* ── Wizard redirect section ─────────────────────────────────────────────── */
.ts-pricing-wizard-section {
  padding: 60px 0 72px;
  background: var(--ts-bg);
}
.ts-pricing-wizard-card {
  background: linear-gradient(135deg, var(--ts-blue) 0%, var(--ts-blue-dark) 100%);
  border-radius: 20px;
  padding: 52px 56px;
  display: grid;
  grid-template-columns: 1fr 220px;
  gap: 48px;
  align-items: center;
  position: relative;
  overflow: hidden;
  box-shadow: 0 16px 48px rgba(36,86,216,.22);
}
.ts-pricing-wizard-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 80% 20%, rgba(255,255,255,.07) 0%, transparent 60%);
  pointer-events: none;
}
.ts-pricing-wizard-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
  margin-bottom: 14px;
}
.ts-pricing-wizard-headline {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 30px;
  font-weight: 700;
  color: #fff;
  line-height: 1.25;
  margin: 0 0 16px;
}
.ts-pricing-wizard-sub {
  font-size: 15px;
  color: rgba(255,255,255,.82);
  line-height: 1.65;
  margin: 0 0 28px;
}
.ts-pricing-wizard-features {
  list-style: none;
  padding: 0;
  margin: 0 0 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 24px;
}
.ts-pricing-wizard-feature {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13.5px;
  color: rgba(255,255,255,.88);
}
.ts-pricing-wizard-feature-icon {
  display: flex;
  align-items: center;
  flex-shrink: 0;
  color: rgba(255,255,255,.7);
}
.ts-pricing-wizard-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}
.ts-pricing-wizard-btn-primary {
  display: inline-flex;
  align-items: center;
  background: #fff;
  color: var(--ts-blue);
  font-size: 15px;
  font-weight: 700;
  padding: 14px 28px;
  border-radius: 8px;
  text-decoration: none;
  transition: transform .15s, box-shadow .15s;
  box-shadow: 0 4px 16px rgba(0,0,0,.15);
}
.ts-pricing-wizard-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(0,0,0,.2);
  color: var(--ts-blue-dark);
}
.ts-pricing-wizard-btn-secondary {
  display: inline-flex;
  align-items: center;
  background: rgba(255,255,255,.12);
  color: rgba(255,255,255,.9);
  font-size: 14px;
  font-weight: 600;
  padding: 13px 22px;
  border-radius: 8px;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.25);
  transition: background .15s;
}
.ts-pricing-wizard-btn-secondary:hover {
  background: rgba(255,255,255,.2);
  color: #fff;
}

/* Right-side visual */
.ts-pricing-wizard-right {
  display: flex;
  align-items: center;
  justify-content: center;
}
.ts-pricing-wizard-visual {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 16px;
  padding: 28px 24px;
  width: 180px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}
.ts-pricing-wizard-visual-icon {
  width: 64px;
  height: 64px;
  background: rgba(255,255,255,.15);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.ts-pricing-wizard-visual-lines {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.ts-pricing-visual-bar {
  height: 7px;
  border-radius: 4px;
  background: rgba(255,255,255,.25);
}
.ts-pricing-visual-bar--full { width: 100%; background: rgba(255,255,255,.55); }
.ts-pricing-visual-bar--lg   { width: 78%; }
.ts-pricing-visual-bar--md   { width: 55%; }
.ts-pricing-visual-bar--sm   { width: 35%; }
.ts-pricing-wizard-visual-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--ts-green);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 10px;
  border-radius: 20px;
}

/* ── Expedited examination subsection ───────────────────────────────────── */
.ts-pricing-expedited {
  margin-top: 48px;
  background: #fff8e6;
  border: 1px solid #f0d97a;
  border-radius: 14px;
  padding: 36px 40px;
}
.ts-pricing-expedited-head {
  margin-bottom: 24px;
}
.ts-pricing-expedited-badge {
  display: inline-block;
  background: #f5c518;
  color: #5a4500;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 20px;
  margin-bottom: 10px;
}
.ts-pricing-expedited-head h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--ts-ink);
  margin: 0 0 8px;
}
.ts-pricing-expedited-head p {
  font-size: 14px;
  color: #6b6030;
  margin: 0;
}
.ts-pricing-expedited-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.ts-pricing-expedited-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(255,255,255,.7);
  border: 1px solid #eacf6e;
  border-radius: 8px;
  padding: 12px 18px;
  gap: 16px;
}
.ts-pricing-expedited-type {
  font-size: 14px;
  color: var(--ts-ink);
  font-weight: 500;
}
.ts-pricing-expedited-fee {
  font-size: 15px;
  font-weight: 700;
  color: #8a6000;
  white-space: nowrap;
}
.ts-pricing-expedited-caveat {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 13px;
  color: #6b5e30;
  line-height: 1.6;
  margin: 0;
  padding: 14px 16px;
  background: rgba(255,255,255,.5);
  border-radius: 8px;
  border-left: 3px solid #f5c518;
}

/* ── Trust signals section ───────────────────────────────────────────────── */
.ts-pricing-trust-section {
  padding: 80px 0;
  background: var(--ts-bg);
}
.ts-pricing-trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
}
.ts-pricing-trust-card {
  background: #fff;
  border: 1px solid #e8eaf2;
  border-radius: 14px;
  padding: 28px 24px;
}
.ts-pricing-trust-card h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--ts-ink);
  margin: 0 0 10px;
}
.ts-pricing-trust-card p {
  font-size: 13.5px;
  color: #5a6278;
  line-height: 1.6;
  margin: 0;
}
.ts-pricing-trust-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
}
.ts-pricing-trust-icon--blue   { background: #e8eeff; color: var(--ts-blue); }
.ts-pricing-trust-icon--purple { background: #f0eaff; color: #7c4dff; }
.ts-pricing-trust-icon--green  { background: #e6f9f0; color: var(--ts-green); }
.ts-pricing-trust-icon--amber  { background: #fff5e0; color: #d97706; }

/* ── CTA actions update ───────────────────────────────────────────────────── */
.ts-pricing-cta-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
  margin-top: 32px;
}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
  .ts-pricing-hero h1 { font-size: 34px; }
  .ts-pricing-cards { grid-template-columns: 1fr; max-width: 420px; }
  .ts-pricing-included-grid { grid-template-columns: 1fr; }
  .ts-pricing-compare-wrap { grid-template-columns: 1fr; }
  .ts-pricing-cta-inner h2 { font-size: 28px; }
  .ts-pricing-wizard-card {
    grid-template-columns: 1fr;
    padding: 40px 36px;
  }
  .ts-pricing-wizard-right { display: none; }
  .ts-pricing-wizard-features { grid-template-columns: 1fr; }
  .ts-pricing-trust-grid { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 640px) {
  .ts-pricing-hero { padding: 48px 0 40px; }
  .ts-pricing-hero h1 { font-size: 26px; }
  .ts-pricing-cards-section,
  .ts-pricing-included-section,
  .ts-pricing-compare-section,
  .ts-pricing-wizard-section,
  .ts-pricing-trust-section,
  .ts-pricing-faq-section,
  .ts-pricing-cta-section { padding: 48px 0; }
  .ts-pricing-stats-inner { flex-direction: column; align-items: center; }
  .ts-pricing-stat { border-right: none; border-bottom: 1px solid rgba(255,255,255,.15); padding: 14px 0; width: 100%; max-width: 240px; }
  .ts-pricing-stat:last-child { border-bottom: none; }
  .ts-pricing-cta-actions { flex-direction: column; }
  .ts-pricing-cta-primary,
  .ts-pricing-cta-secondary,
  .ts-pricing-wizard-btn-primary,
  .ts-pricing-wizard-btn-secondary { width: 100%; justify-content: center; }
  .ts-pricing-wizard-card { padding: 28px 22px; border-radius: 14px; }
  .ts-pricing-wizard-headline { font-size: 22px; }
  .ts-pricing-trust-grid { grid-template-columns: 1fr; }
  .ts-pricing-expedited { padding: 24px 20px; }
  .ts-pricing-expedited-row { flex-direction: column; align-items: flex-start; gap: 4px; }
  .ts-pricing-section-head h2 { font-size: 26px; }
}

/* =============================================================
   3-TIER PLAN CARDS (File / Protect / Complete)
   Prefix: ts-plans-  ts-plan-
   ============================================================= */

/* Hero tweak for 3-tier page */
.ts-plans-hero h1 { font-size: clamp( 28px, 4vw, 46px ); }

/* ── Plans section ─────────────────────────────────────────── */
.ts-plans-section {
  padding: 64px 0 48px;
  background: var( --ts-bg, #f5f7fc );
}

/* ── Plan cards grid ───────────────────────────────────────── */
.ts-plans-grid {
  display: grid;
  grid-template-columns: repeat( 3, 1fr );
  gap: 20px;
  align-items: stretch;
  margin-bottom: 32px;
}

/* ── Individual plan card ──────────────────────────────────── */
.ts-plan-card {
  display: flex;
  flex-direction: column;
  border: 2px solid #d0d5dd;
  border-radius: 14px;
  background: #fff;
  overflow: hidden;
  transition: box-shadow .2s;
}
.ts-plan-card:hover {
  box-shadow: 0 4px 20px rgba( 26, 60, 143, .10 );
}

/* ── Popular (Protect) hero card ───────────────────────────── */
.ts-plan-card--popular {
  border-color: #1a3c8f;
  box-shadow: 0 6px 32px rgba( 26, 60, 143, .18 );
  position: relative;
  z-index: 1;
  /* Slightly taller via scaling context */
}

/* ── Badge strip at top ────────────────────────────────────── */
.ts-plan-badge {
  display: block;
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 6px 12px;
  background: #eef2fb;
  color: #1a3c8f;
}
.ts-plan-badge--protect {
  background: #1a3c8f;
  color: #fff;
}
.ts-plan-badge--file    { background: #f0f0f4; color: #666; }
.ts-plan-badge--complete { background: #e8f5e9; color: #1a6a2e; }

/* ── Card body ─────────────────────────────────────────────── */
.ts-plan-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 22px 22px 20px;
}

.ts-plan-name {
  font-size: 1.25rem;
  font-weight: 800;
  color: #1a3c8f;
  margin-bottom: 6px;
}

.ts-plan-price {
  font-size: 2rem;
  font-weight: 900;
  color: #111;
  margin-bottom: 4px;
  line-height: 1.1;
}
.ts-plan-price-symbol { font-size: 1.2rem; font-weight: 700; vertical-align: top; margin-top: 6px; display: inline-block; }
.ts-plan-price-per    { font-size: .85rem; font-weight: 400; color: #666; }

.ts-plan-best-for {
  font-size: .88rem;
  color: #444;
  margin-bottom: 12px;
}
.ts-plan-best-for strong { color: #222; }

.ts-plan-desc {
  font-size: .82rem;
  color: #555;
  line-height: 1.55;
  margin-bottom: 14px;
}

/* ── Inclusion checklist ───────────────────────────────────── */
.ts-plan-checklist {
  list-style: none;
  margin: 0 0 12px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.ts-plan-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 7px;
  font-size: .82rem;
  line-height: 1.4;
}
.ts-plan-checklist li.included { color: #222; }
.ts-plan-checklist li.excluded { color: #aaa; }

.ts-plan-chk {
  flex-shrink: 0;
  width: 16px;
  text-align: center;
  font-style: normal;
  font-weight: 700;
}
.ts-plan-checklist li.included .ts-plan-chk { color: #1a7a44; }
.ts-plan-checklist li.excluded .ts-plan-chk { color: #ccc; }

/* ── File-plan note ────────────────────────────────────────── */
.ts-plan-note {
  font-size: .78rem;
  color: #e07000;
  background: #fff8ee;
  border: 1px solid #fcd08a;
  border-radius: 6px;
  padding: 7px 10px;
  margin-bottom: 10px;
  line-height: 1.45;
}

/* ── Govt note inside card ─────────────────────────────────── */
.ts-plan-govt-note {
  font-size: .78rem;
  color: #666;
  background: #f5f7fc;
  border-radius: 5px;
  padding: 6px 10px;
  margin-bottom: 14px;
  line-height: 1.4;
}

/* ── CTAs inside card ──────────────────────────────────────── */
.ts-plan-ctas {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: auto;
}
.ts-plan-cta-primary {
  display: block;
  background: #1a3c8f;
  color: #fff;
  border-radius: 7px;
  padding: 11px 16px;
  font-size: .9rem;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  transition: background .15s;
}
.ts-plan-cta-primary:hover  { background: #142d6e; color: #fff; }
.ts-plan-card--popular .ts-plan-cta-primary { background: #1a3c8f; }

.ts-plan-cta-secondary {
  display: block;
  border: 1.5px solid #d0d5dd;
  color: #444;
  border-radius: 7px;
  padding: 9px 16px;
  font-size: .85rem;
  font-weight: 600;
  text-align: center;
  text-decoration: none;
  transition: border-color .15s, color .15s;
}
.ts-plan-cta-secondary:hover { border-color: #1a3c8f; color: #1a3c8f; }

/* ── Honest nudge ──────────────────────────────────────────── */
.ts-plans-nudge {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  background: #eef2fb;
  border-left: 4px solid #1a3c8f;
  border-radius: 8px;
  padding: 14px 18px;
  margin-bottom: 18px;
  color: #1a1a2e;
}
.ts-plans-nudge svg { flex-shrink: 0; margin-top: 3px; color: #1a3c8f; }
.ts-plans-nudge p { margin: 0; font-size: .9rem; line-height: 1.6; }

/* ── Govt fee clarity block ────────────────────────────────── */
.ts-plans-govt-clarity {
  text-align: center;
  font-size: .9rem;
  color: #444;
  background: #fff;
  border: 1px solid #d0d5dd;
  border-radius: 8px;
  padding: 14px 20px;
  line-height: 1.6;
}
.ts-plans-govt-clarity strong { color: #111; display: block; margin-bottom: 3px; }

/* ── Comparison table section ──────────────────────────────── */
.ts-plans-compare-section {
  padding: 64px 0;
  background: #fff;
}

.ts-plans-compare-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.ts-plans-compare-table {
  width: 100%;
  min-width: 540px;
  border-collapse: collapse;
  font-size: .9rem;
  border-radius: 10px;
  overflow: hidden;
}

.ts-plans-compare-table thead tr {
  background: #1a3c8f;
  color: #fff;
}
.ts-plans-compare-table thead th {
  padding: 14px 16px;
  text-align: center;
  font-weight: 700;
  vertical-align: bottom;
}
.ts-plans-compare-table thead th.ts-cmp-process-col {
  text-align: left;
  width: 40%;
}

.ts-cmp-plan-name { display: block; font-size: .95rem; }
.ts-cmp-plan-fee  { display: block; font-size: .78rem; font-weight: 400; opacity: .85; margin-top: 2px; }
.ts-cmp-popular-tag {
  display: inline-block;
  margin-top: 5px;
  background: #fff;
  color: #1a3c8f;
  border-radius: 20px;
  padding: 2px 8px;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* Protect column highlight */
.ts-plans-compare-table .col-protect {
  background: #eef2fb;
}
.ts-plans-compare-table thead th.col-protect {
  background: #2a4fa0;
}

.ts-plans-compare-table tbody tr {
  border-bottom: 1px solid #e8eaf0;
}
.ts-plans-compare-table tbody tr:nth-child(even) {
  background: #f8fafe;
}
.ts-plans-compare-table tbody tr:nth-child(even) .col-protect {
  background: #e6ecf8;
}

.ts-cmp-process {
  padding: 11px 16px;
  font-size: .88rem;
  color: #333;
  text-align: left;
}
.ts-cmp-process-sub {
  display: block;
  font-size: .76rem;
  color: #888;
  margin-top: 2px;
}
.ts-cmp-cell {
  padding: 11px 12px;
  text-align: center;
  font-size: 1rem;
  font-weight: 700;
  vertical-align: middle;
}
.ts-cmp-yes { color: #1a7a44; }
.ts-cmp-no  { color: #bbb;    }

.ts-cmp-govt-row { background: #f0f4ff !important; font-size: .85rem; }
.ts-cmp-govt-row .ts-cmp-process { color: #555; font-weight: 600; }
.ts-cmp-govt-cell { font-size: .82rem; font-weight: 400; color: #555; }
.ts-cmp-govt-row .col-protect { background: #e3eaf8 !important; }

.ts-plans-compare-note {
  font-size: .82rem;
  color: #777;
  margin-top: 14px;
  text-align: center;
  line-height: 1.5;
}

/* ── Awareness hook ────────────────────────────────────────── */
.ts-plans-awareness-section {
  padding: 32px 0;
  background: var( --ts-bg, #f5f7fc );
}
.ts-plans-awareness-hook {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  background: #fff;
  border: 1px solid #e0e4ec;
  border-radius: 10px;
  padding: 18px 22px;
  max-width: 800px;
  margin: 0 auto;
}
.ts-plans-awareness-hook svg { flex-shrink: 0; margin-top: 2px; color: #1a3c8f; }
.ts-plans-awareness-hook p   { margin: 0; font-size: .9rem; line-height: 1.65; color: #333; }
.ts-plans-awareness-hook a   { color: #1a3c8f; font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }

/* ── Responsive ────────────────────────────────────────────── */
@media ( max-width: 860px ) {
  .ts-plans-grid {
    grid-template-columns: 1fr;
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
  }
  .ts-plan-card--popular {
    order: -1; /* Protect first on mobile */
  }
}

@media ( max-width: 640px ) {
  .ts-plans-section { padding: 48px 0 36px; }
  .ts-plans-compare-section { padding: 48px 0; }
  .ts-plan-body { padding: 18px 16px 16px; }
  .ts-plan-price { font-size: 1.6rem; }
  .ts-plans-awareness-section { padding: 24px 0; }
  .ts-plans-compare-table { font-size: .82rem; }
  .ts-cmp-process, .ts-cmp-cell { padding: 9px 10px; }
}

/* =============================================================
   HOMEPAGE 3-TIER TEASER (compact cards)
   Prefix: ts-tiers-  ts-tier-
   ============================================================= */

/* ── Grid ──────────────────────────────────────────────────── */
.ts-tiers-grid {
  display: grid;
  grid-template-columns: repeat( 3, 1fr );
  gap: 16px;
  margin-bottom: 20px;
}

/* ── Card ──────────────────────────────────────────────────── */
.ts-tier-card {
  border: 2px solid #d0d5dd;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
  transition: box-shadow .18s;
}
.ts-tier-card:hover {
  box-shadow: 0 4px 18px rgba( 26, 60, 143, .10 );
}

/* Popular (Protect) highlighted */
.ts-tier-card--popular {
  border-color: #1a3c8f;
  box-shadow: 0 4px 24px rgba( 26, 60, 143, .16 );
}

/* ── Badge strip ───────────────────────────────────────────── */
.ts-tier-badge {
  display: block;
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 5px 10px;
}
.ts-tier-badge--file     { background: #f0f0f4; color: #666; }
.ts-tier-badge--protect  { background: #1a3c8f; color: #fff; }
.ts-tier-badge--complete { background: #e8f5e9; color: #1a6a2e; }

/* ── Card body ─────────────────────────────────────────────── */
.ts-tier-body {
  padding: 18px 18px 20px;
}

.ts-tier-name {
  font-size: 1.05rem;
  font-weight: 800;
  color: #1a3c8f;
  margin-bottom: 4px;
}

.ts-tier-fee {
  font-size: 1.7rem;
  font-weight: 900;
  color: #111;
  line-height: 1.1;
  margin-bottom: 4px;
}
.ts-tier-per {
  font-size: .8rem;
  font-weight: 400;
  color: #777;
}

.ts-tier-best {
  font-size: .82rem;
  color: #555;
  margin-bottom: 8px;
}

.ts-tier-value {
  font-size: .82rem;
  color: #444;
  line-height: 1.5;
  margin: 0;
}

/* ── Honest nudge ──────────────────────────────────────────── */
.ts-tiers-nudge {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: #eef2fb;
  border-left: 3px solid #1a3c8f;
  border-radius: 6px;
  padding: 11px 16px;
  font-size: .88rem;
  color: #1a1a2e;
  line-height: 1.55;
  margin-bottom: 12px;
}

/* ── Govt fee note ─────────────────────────────────────────── */
.ts-tiers-govt {
  font-size: .82rem;
  color: #666;
  text-align: center;
  margin-bottom: 20px;
  line-height: 1.5;
}

/* ── CTAs ──────────────────────────────────────────────────── */
.ts-tiers-ctas {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Responsive ────────────────────────────────────────────── */
@media ( max-width: 720px ) {
  .ts-tiers-grid {
    grid-template-columns: 1fr;
    max-width: 380px;
    margin-left: auto;
    margin-right: auto;
  }
  .ts-tier-card--popular { order: -1; }
}

@media ( max-width: 480px ) {
  .ts-tiers-ctas { flex-direction: column; align-items: center; }
  .ts-tier-fee { font-size: 1.45rem; }
}
