:root {
  --tsp-primary:        #0066cc;
  --tsp-primary-dark:   #004c99;
  --tsp-primary-light:  #e8f0fb;
  --tsp-accent:         #0f172a;

  --tsp-text:           #222222;
  --tsp-text-muted:     #666666;
  --tsp-text-light:     #999999;
  --tsp-heading:        #0f172a;

  --tsp-bg:             #ffffff;
  --tsp-bg-alt:         #f5f7fa;
  --tsp-surface:        #f8fafc;
  --tsp-surface-raised: #ffffff;
  --tsp-border:         #e0e4ea;
  --tsp-focus-ring:     rgba(0,102,204,.2);

  --tsp-font-sans:      system-ui, -apple-system, 'Segoe UI', sans-serif;
  --tsp-font-size-base: 16px;
  --tsp-line-height:    1.6;

  --tsp-gap:            1.5rem;
  --tsp-gap-lg:         3rem;
  --tsp-radius:         6px;
  --tsp-radius-lg:      12px;

  --tsp-container-max:  1200px;
  --tsp-container-pad:  1rem;

  --tsp-transition:     0.2s ease;

  --tsp-shadow-sm:      0 1px 3px rgba(0,0,0,.08);
  --tsp-shadow:         0 4px 16px rgba(0,0,0,.10);
  --tsp-shadow-lg:      0 18px 48px rgba(15,23,42,.12);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--tsp-font-sans);
  font-size: var(--tsp-font-size-base);
  line-height: var(--tsp-line-height);
  color: var(--tsp-text);
  background:
    radial-gradient(circle at top, rgba(0,102,204,.06), transparent 32%),
    var(--tsp-bg);
}

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

a { color: var(--tsp-primary); text-decoration: none; transition: color var(--tsp-transition); }
a:hover { color: var(--tsp-primary-dark); }
a:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 4px var(--tsp-focus-ring);
  border-radius: var(--tsp-radius);
}

ul, ol { list-style: none; }

.tsp-container {
  width: 100%;
  max-width: var(--tsp-container-max);
  margin-inline: auto;
  padding-inline: var(--tsp-container-pad);
}

.tsp-section {
  padding-block: var(--tsp-gap-lg);
}

.tsp-section--alt {
  background: var(--tsp-bg-alt);
}

.tsp-page {
  min-height: 60vh;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--tsp-heading);
  line-height: 1.3;
  font-weight: 700;
}

h1 { font-size: clamp(1.75rem, 4vw, 2.5rem); }
h2 { font-size: clamp(1.4rem, 3vw, 2rem); }
h3 { font-size: clamp(1.15rem, 2.5vw, 1.5rem); }
h4 { font-size: 1.15rem; }

p { margin-bottom: 1em; }
p:last-child { margin-bottom: 0; }

.tsp-section-title {
  text-align: center;
  margin-bottom: var(--tsp-gap);
  max-width: 40rem;
  margin-inline: auto;
}

.tsp-section-title h2 { margin-bottom: .5rem; }
.tsp-section-title p  { color: var(--tsp-text-muted); }

.tsp-btn {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  padding: .65rem 1.4rem;
  border-radius: var(--tsp-radius);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  border: 2px solid transparent;
  transition: background var(--tsp-transition), color var(--tsp-transition), border-color var(--tsp-transition);
}

.tsp-btn--primary {
  background: var(--tsp-primary);
  color: #fff;
}
.tsp-btn--primary:hover {
  background: var(--tsp-primary-dark);
  color: #fff;
}

.tsp-btn--outline {
  background: transparent;
  color: var(--tsp-primary);
  border-color: var(--tsp-primary);
}
.tsp-btn--outline:hover {
  background: var(--tsp-primary);
  color: #fff;
}

.tsp-inquiry-btn {
  display: inline-flex;
  align-items: center;
  padding: .5rem 1.2rem;
  background: var(--tsp-primary);
  color: #fff;
  border-radius: var(--tsp-radius);
  font-weight: 600;
  font-size: .9rem;
  transition: background var(--tsp-transition);
}
.tsp-inquiry-btn:hover {
  background: var(--tsp-primary-dark);
  color: #fff;
}

.tsp-card {
  background: var(--tsp-surface-raised);
  border: 1px solid var(--tsp-border);
  border-radius: var(--tsp-radius-lg);
  overflow: hidden;
  transition: box-shadow var(--tsp-transition), transform var(--tsp-transition);
}
.tsp-card:hover {
  box-shadow: var(--tsp-shadow-lg);
  transform: translateY(-4px);
}

.tsp-card__thumb { display: block; overflow: hidden; aspect-ratio: 4/3; }
.tsp-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.tsp-card:hover .tsp-card__thumb img { transform: scale(1.04); }

.tsp-card__body { padding: var(--tsp-gap); }
.tsp-card__title { margin-bottom: .5rem; font-size: 1.05rem; }
.tsp-card__title a { color: var(--tsp-text); }
.tsp-card__title a:hover { color: var(--tsp-primary); }
.tsp-card__excerpt { color: var(--tsp-text-muted); font-size: .9rem; margin-bottom: var(--tsp-gap); }
.tsp-card__meta { color: var(--tsp-text-light); font-size: .8rem; margin-bottom: .5rem; }

.tsp-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: center;
  background: linear-gradient(135deg, var(--tsp-primary-dark) 0%, var(--tsp-primary) 100%);
  background-size: cover;
  background-position: center;
  color: #fff;
  overflow: hidden;
}

.tsp-hero__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.38);
}

.tsp-hero__content {
  position: relative;
  z-index: 1;
  max-width: 640px;
}

.tsp-hero__title {
  color: #fff;
  font-size: clamp(2rem, 5vw, 3rem);
  margin-bottom: 1rem;
}

.tsp-hero__subtitle {
  font-size: 1.15rem;
  opacity: .9;
  margin-bottom: 2rem;
}

.tsp-hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; }

.tsp-advantages__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--tsp-gap);
}

.tsp-advantage-item {
  text-align: center;
  padding: var(--tsp-gap);
  border-radius: var(--tsp-radius-lg);
  background: var(--tsp-bg);
  box-shadow: var(--tsp-shadow-sm);
}

.tsp-advantage-item__icon {
  font-size: 2.5rem;
  margin-bottom: .75rem;
}

.tsp-advantage-item__title {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: .4rem;
}

.tsp-advantage-item__desc {
  color: var(--tsp-text-muted);
  font-size: .875rem;
}

.tsp-product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--tsp-gap);
}

.tsp-product-archive {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--tsp-gap-lg);
  align-items: start;
}

.tsp-news-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--tsp-gap);
}

.tsp-product-single {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--tsp-gap-lg);
  align-items: start;
}

.tsp-product-gallery__main {
  border-radius: var(--tsp-radius-lg);
  overflow: hidden;
  margin-bottom: 1rem;
  aspect-ratio: 4/3;
}
.tsp-product-gallery__main img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.tsp-product-gallery__thumbs {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
}

.tsp-product-gallery__thumb {
  width: 72px;
  height: 72px;
  border-radius: var(--tsp-radius);
  overflow: hidden;
  border: 2px solid transparent;
  cursor: pointer;
  transition: border-color var(--tsp-transition);
}
.tsp-product-gallery__thumb.is-active,
.tsp-product-gallery__thumb:hover {
  border-color: var(--tsp-primary);
}
.tsp-product-gallery__thumb img { width: 100%; height: 100%; object-fit: cover; }

.tsp-product-meta__title { margin-bottom: .5rem; }
.tsp-product-meta__part-number {
  color: var(--tsp-text-muted);
  margin-bottom: 1rem;
  font-size: .95rem;
}
.tsp-product-meta__subtitle { color: var(--tsp-text-muted); margin-bottom: 1.5rem; }

.tsp-product-specs { width: 100%; border-collapse: collapse; margin-bottom: 1.5rem; }
.tsp-product-specs th,
.tsp-product-specs td {
  padding: .6rem .8rem;
  text-align: left;
  border-bottom: 1px solid var(--tsp-border);
  font-size: .9rem;
}
.tsp-product-specs th { color: var(--tsp-text-muted); width: 40%; background: var(--tsp-bg-alt); }

.tsp-product-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.5rem;
  align-items: center;
}

.tsp-product-inquiry { margin-top: 0; }

.tsp-feature-list,
.tsp-application-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--tsp-gap);
}

.tsp-feature-item,
.tsp-application-card {
  background: var(--tsp-bg);
  border: 1px solid var(--tsp-border);
  border-radius: var(--tsp-radius-lg);
  padding: var(--tsp-gap);
  box-shadow: var(--tsp-shadow-sm);
}

.tsp-feature-item h3,
.tsp-application-card h3 {
  margin-bottom: .5rem;
}

.tsp-feature-item p,
.tsp-application-card p {
  color: var(--tsp-text-muted);
}

.tsp-application-card__icon {
  width: 56px;
  height: 56px;
  margin-bottom: .75rem;
}

.tsp-application-card__icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.tsp-product-content > * + * {
  margin-top: 1rem;
}

.tsp-news-single { max-width: 800px; margin-inline: auto; }
.tsp-news-single__header { margin-bottom: 2rem; }
.tsp-news-single__media { margin-bottom: var(--tsp-gap); }
.tsp-news-single__meta { color: var(--tsp-text-muted); font-size: .875rem; margin-bottom: .75rem; }
.tsp-news-single__content { line-height: 1.8; }
.tsp-news-single__content img { border-radius: var(--tsp-radius); margin-block: 1.5rem; }

.tsp-form-wrap { max-width: 680px; margin-inline: auto; }
.tsp-form-wrap .wpcf7 input,
.tsp-form-wrap .wpcf7 textarea,
.tsp-form-wrap .wpcf7 select {
  width: 100%;
  padding: .7rem 1rem;
  border: 1px solid var(--tsp-border);
  border-radius: var(--tsp-radius);
  font-family: var(--tsp-font-sans);
  font-size: 1rem;
  color: var(--tsp-text);
  transition: border-color var(--tsp-transition);
}
.tsp-form-wrap .wpcf7 input:focus,
.tsp-form-wrap .wpcf7 textarea:focus {
  outline: none;
  border-color: var(--tsp-primary);
}
.tsp-form-wrap .wpcf7 textarea { min-height: 140px; resize: vertical; }
.tsp-form-wrap .wpcf7-submit {
  background: var(--tsp-primary);
  color: #fff;
  border: none;
  cursor: pointer;
  font-weight: 600;
  padding: .75rem 2rem;
  border-radius: var(--tsp-radius);
  transition: background var(--tsp-transition);
}
.tsp-form-wrap .wpcf7-submit:hover { background: var(--tsp-primary-dark); }
.tsp-inquiry-panel {
  background: var(--tsp-bg);
  border: 1px solid var(--tsp-border);
  border-radius: var(--tsp-radius-lg);
  padding: var(--tsp-gap);
  box-shadow: var(--tsp-shadow-sm);
}

.tsp-inquiry-panel h2 {
  margin-bottom: .5rem;
}

.tsp-inquiry-panel__intro {
  color: var(--tsp-text-muted);
  margin-bottom: 1rem;
}

.tsp-inquiry-panel__meta {
  display: grid;
  gap: .35rem;
  margin-bottom: 1rem;
  padding: 1rem;
  background: var(--tsp-primary-light);
  border-radius: var(--tsp-radius);
}

.tsp-inquiry-panel__meta p {
  margin: 0;
}

.tsp-contact-page .tsp-section > * + *,
.tsp-inquiry-page .tsp-section > * + * {
  margin-top: var(--tsp-gap);
}

.tsp-page-panels {
  display: grid;
  gap: var(--tsp-gap);
}

.tsp-page-panels--contact {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.tsp-page-panel {
  height: 100%;
}

.tsp-page-panel .tsp-card__body > * + * {
  margin-top: .75rem;
}

.tsp-page-list {
  display: grid;
  gap: .85rem;
}

.tsp-page-list li {
  position: relative;
  padding-left: 1rem;
  color: var(--tsp-text-muted);
}

.tsp-page-list li::before {
  content: '\2022';
  position: absolute;
  left: 0;
  color: var(--tsp-primary);
}

.tsp-page-list strong {
  color: var(--tsp-text);
}

.tsp-page-list a {
  overflow-wrap: anywhere;
}

.tsp-page-list--detail {
  gap: 1rem;
}

.tsp-page-list--detail li {
  padding-left: 0;
  display: grid;
  gap: .25rem;
}

.tsp-page-list--detail li::before {
  content: none;
}

.tsp-generic-page__article {
  max-width: 880px;
  margin-inline: auto;
}

.tsp-generic-page__content {
  padding: clamp(1.5rem, 3vw, 2.5rem);
}

.tsp-generic-page__content > * + * {
  margin-top: 1.15rem;
}

.tsp-generic-page__content h2,
.tsp-generic-page__content h3,
.tsp-generic-page__content h4 {
  margin-top: 1.9rem;
}

.tsp-generic-page__content p,
.tsp-generic-page__content ul,
.tsp-generic-page__content ol,
.tsp-generic-page__content blockquote {
  color: var(--tsp-text-muted);
  line-height: 1.8;
}

.tsp-generic-page__content ul,
.tsp-generic-page__content ol {
  padding-left: 1.25rem;
}

.tsp-generic-page__content ul {
  list-style: disc;
}

.tsp-generic-page__content ol {
  list-style: decimal;
}

.tsp-generic-page__content li + li {
  margin-top: .6rem;
}

.tsp-sidebar {
  position: sticky;
  top: 1.5rem;
}

.tsp-category-nav {
  background: var(--tsp-bg);
  border: 1px solid var(--tsp-border);
  border-radius: var(--tsp-radius-lg);
  padding: var(--tsp-gap);
}

.tsp-category-nav__title {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 1rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--tsp-border);
}

.tsp-category-nav li { padding: .35rem 0; }
.tsp-category-nav li a {
  color: var(--tsp-text-muted);
  font-size: .9rem;
  display: flex;
  align-items: center;
  gap: .4rem;
}
.tsp-category-nav li a:hover,
.tsp-category-nav li.current-cat a { color: var(--tsp-primary); font-weight: 600; }

.tsp-breadcrumb {
  padding-block: 1rem;
  font-size: .875rem;
  color: var(--tsp-text-muted);
}
.tsp-breadcrumb a { color: var(--tsp-text-muted); }
.tsp-breadcrumb a:hover { color: var(--tsp-primary); }
.tsp-breadcrumb span + span::before { content: ' / '; margin-inline: .3rem; }

.tsp-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--tsp-bg);
  border-bottom: 1px solid var(--tsp-border);
  transition: box-shadow var(--tsp-transition);
}
.tsp-header.is-scrolled { box-shadow: 0 2px 12px rgba(0,0,0,.08); }

.tsp-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
  gap: 1rem;
}
.tsp-header__controls {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.tsp-header__cta {
  white-space: nowrap;
  padding-inline: 1rem;
}

.tsp-header__logo {
  display: inline-flex;
  align-items: center;
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--tsp-primary);
  white-space: nowrap;
  flex-shrink: 0;
  line-height: 1;
}
.tsp-header__logo:hover { color: var(--tsp-primary-dark); }
.tsp-header__logo-image {
  display: block;
  width: auto;
  max-width: min(320px, 42vw);
  max-height: 48px;
}

.tsp-primary-nav { display: flex; align-items: center; }

.tsp-nav {
  display: flex;
  align-items: center;
  gap: .1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tsp-nav > li > a {
  display: block;
  padding: .45rem .7rem;
  font-size: .9rem;
  font-weight: 500;
  color: var(--tsp-text);
  border-radius: var(--tsp-radius);
  white-space: nowrap;
  transition: color var(--tsp-transition), background var(--tsp-transition);
}
.tsp-nav > li > a:hover,
.tsp-nav > li.current-menu-item > a {
  color: var(--tsp-primary);
  background: var(--tsp-primary-light);
}

.tsp-nav__has-dropdown { position: relative; }
.tsp-nav__chevron {
  display: none;
  background: none;
  border: none;
  padding: .4rem;
  cursor: pointer;
  color: var(--tsp-text-muted);
  font-size: .7rem;
  line-height: 1;
}
.tsp-nav__chevron[aria-expanded="true"] { transform: scaleY(-1); }

.tsp-nav__dropdown {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  min-width: 200px;
  background: var(--tsp-bg);
  border: 1px solid var(--tsp-border);
  border-radius: var(--tsp-radius-lg);
  box-shadow: var(--tsp-shadow);
  list-style: none;
  padding: .5rem 0;
  margin: 0;
  z-index: 300;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-6px);
  transition: opacity var(--tsp-transition), visibility var(--tsp-transition), transform var(--tsp-transition);
}

.tsp-nav__has-dropdown:hover   .tsp-nav__dropdown,
.tsp-nav__has-dropdown:focus-within .tsp-nav__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.tsp-nav__dropdown li a {
  display: block;
  padding: .45rem 1.1rem;
  font-size: .875rem;
  color: var(--tsp-text-muted);
  transition: color var(--tsp-transition), background var(--tsp-transition);
  white-space: nowrap;
}
.tsp-nav__dropdown li a:hover,
.tsp-nav__dropdown li.current-cat a {
  color: var(--tsp-primary);
  background: var(--tsp-primary-light);
}
.tsp-nav__dropdown li.current-cat a { font-weight: 600; }

.tsp-nav__dropdown-sep {
  height: 1px;
  background: var(--tsp-border);
  margin: .4rem .75rem;
  pointer-events: none;
}

.tsp-nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: .45rem;
  flex-shrink: 0;
}
.tsp-nav-toggle__bar {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--tsp-text);
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease;
}
.tsp-nav-toggle[aria-expanded="true"] .tsp-nav-toggle__bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.tsp-nav-toggle[aria-expanded="true"] .tsp-nav-toggle__bar:nth-child(2) { opacity: 0; }
.tsp-nav-toggle[aria-expanded="true"] .tsp-nav-toggle__bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.tsp-header-topbar {
  background: var(--tsp-primary-dark);
  color: rgba(255,255,255,.85);
  font-size: .8rem;
  padding-block: .4rem;
}

.tsp-header-topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.tsp-header-topbar__status {
  display: flex;
  align-items: center;
  gap: .65rem;
  min-height: 1rem;
}
.tsp-header-topbar__eyebrow {
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .72rem;
  color: rgba(255,255,255,.58);
}
.tsp-header-topbar__note {
  color: rgba(255,255,255,.78);
}
.tsp-header-topbar__contact { display: flex; gap: 1.2rem; }
.tsp-header-topbar__contact a {
  color: rgba(255,255,255,.85);
  display: inline-flex;
  gap: .45rem;
}
.tsp-header-topbar__contact a:hover { color: #fff; }
.tsp-header-topbar__label {
  color: rgba(255,255,255,.56);
}

.tsp-footer {
  background: #1a1f2e;
  color: rgba(255,255,255,.7);
  padding-block: var(--tsp-gap-lg);
  font-size: .9rem;
}
.tsp-footer__intro {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(18rem, 1fr);
  gap: var(--tsp-gap-lg);
  padding-bottom: var(--tsp-gap-lg);
  margin-bottom: var(--tsp-gap-lg);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.tsp-footer__kicker {
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .74rem;
  color: rgba(255,255,255,.5);
  margin-bottom: .75rem;
}
.tsp-footer__intro-actions {
  display: grid;
  gap: 1rem;
  align-content: start;
  justify-items: start;
}
.tsp-footer__contact-list {
  display: grid;
  gap: .75rem;
}
.tsp-footer__contact-label {
  display: block;
  font-size: .72rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  margin-bottom: .15rem;
}

.tsp-footer__grid {
  display: flex;
  justify-content: flex-end;
  gap: var(--tsp-gap-lg);
}

.tsp-footer__brand-name { color: #fff; font-size: 1.15rem; font-weight: 700; margin-bottom: .75rem; }
.tsp-footer__about { line-height: 1.7; }

.tsp-footer__col { min-width: 180px; }
.tsp-footer__col-title { color: #fff; font-weight: 700; margin-bottom: 1rem; font-size: .95rem; }
.tsp-footer__links li { margin-bottom: .5rem; }
.tsp-footer__links a { color: rgba(255,255,255,.65); }
.tsp-footer__links a:hover { color: #fff; }

.tsp-footer__bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 1.5rem;
  text-align: center;
  font-size: .8rem;
  color: rgba(255,255,255,.45);
}

.tsp-floating-contact {
  position: fixed;
  right: 1.25rem;
  bottom: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .6rem;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--tsp-transition), visibility var(--tsp-transition), transform var(--tsp-transition);
}

.tsp-floating-contact.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.tsp-floating-contact__btn {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  color: #fff;
  border: none;
  cursor: pointer;
  box-shadow: var(--tsp-shadow);
  transition: transform var(--tsp-transition), box-shadow var(--tsp-transition);
}
.tsp-floating-contact__btn:hover { transform: scale(1.1); box-shadow: var(--tsp-shadow); }

.tsp-floating-contact__wa  { background: #25d366; }
.tsp-floating-contact__mail { background: var(--tsp-primary); }
.tsp-floating-contact__tel { background: #e74c3c; }
.tsp-floating-contact__top { background: #555; }

.tsp-lang-switcher { display: flex; gap: .4rem; align-items: center; }
.tsp-lang-switcher__item {
  font-size: .8rem;
  padding: .2rem .5rem;
  border-radius: 3px;
  color: rgba(255,255,255,.8);
  border: 1px solid transparent;
}
.tsp-lang-switcher__item:hover,
.tsp-lang-switcher__item.current-lang {
  color: #fff;
  background: rgba(255,255,255,.12);
  border-color: rgba(255,255,255,.16);
}
.tsp-lang-switcher__item {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
}
.tsp-lang-switcher__flag img {
  width: 16px;
  height: 12px;
  object-fit: cover;
  border-radius: 2px;
  display: block;
}

.tsp-cat-pills {
  display: flex;
  gap: .5rem;
  flex-wrap: wrap;
  padding-block: 1rem 1.25rem;
}

.tsp-cat-pill {
  display: inline-flex;
  align-items: center;
  padding: .35rem .9rem;
  border-radius: 2rem;
  border: 1px solid var(--tsp-border);
  font-size: .875rem;
  color: var(--tsp-text-muted);
  background: var(--tsp-bg);
  transition: background var(--tsp-transition), border-color var(--tsp-transition), color var(--tsp-transition);
  white-space: nowrap;
}

.tsp-cat-pill:hover {
  border-color: var(--tsp-primary);
  color: var(--tsp-primary);
  background: var(--tsp-primary-light);
}

.tsp-cat-pill.is-active {
  background: var(--tsp-primary);
  border-color: var(--tsp-primary);
  color: #fff;
  font-weight: 600;
}

.tsp-archive-header {
  margin-bottom: 1.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--tsp-border);
}

.tsp-archive-header__title { margin-bottom: .4rem; }

.tsp-archive-header__desc {
  color: var(--tsp-text-muted);
  margin-bottom: .5rem;
}

.tsp-archive-header__count {
  font-size: .875rem;
  color: var(--tsp-text-light);
  margin: 0;
}

.tsp-cat-parent > a {
  font-weight: 600;
  color: var(--tsp-text);
}

.tsp-cat-parent > a:hover,
.tsp-cat-parent.current-cat > a {
  color: var(--tsp-primary);
}

.tsp-cat-children {
  padding-left: 1rem;
  margin-top: .25rem;
  border-left: 2px solid var(--tsp-border);
}

.tsp-cat-children li { padding: .2rem 0; }

.tsp-cat-count {
  margin-left: auto;
  font-size: .7rem;
  color: var(--tsp-text-light);
  background: var(--tsp-bg-alt);
  border-radius: 2rem;
  padding: .1rem .45rem;
  line-height: 1.4;
  flex-shrink: 0;
}

.tsp-pagination {
  margin-top: var(--tsp-gap-lg);
  display: flex;
  justify-content: center;
}

.tsp-pagination .nav-links {
  display: flex;
  gap: .4rem;
  align-items: center;
  flex-wrap: wrap;
}

.tsp-pagination .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding-inline: .5rem;
  border-radius: var(--tsp-radius);
  border: 1px solid var(--tsp-border);
  font-size: .875rem;
  color: var(--tsp-text-muted);
  transition: background var(--tsp-transition), border-color var(--tsp-transition), color var(--tsp-transition);
}

.tsp-pagination .page-numbers:hover {
  border-color: var(--tsp-primary);
  color: var(--tsp-primary);
}

.tsp-pagination .page-numbers.current {
  background: var(--tsp-primary);
  border-color: var(--tsp-primary);
  color: #fff;
  font-weight: 600;
}

.tsp-pagination .page-numbers.dots {
  border-color: transparent;
  background: transparent;
  pointer-events: none;
}

.tsp-no-results {
  padding: var(--tsp-gap-lg);
  text-align: center;
  color: var(--tsp-text-muted);
  background: var(--tsp-bg-alt);
  border-radius: var(--tsp-radius-lg);
  margin: 0;
}

.tsp-card__thumb--empty {
  background: linear-gradient(135deg, var(--tsp-bg-alt) 0%, var(--tsp-border) 100%);
}

@media (max-width: 1023px) {
  .tsp-product-archive {
    grid-template-columns: 1fr;
  }
  .tsp-archive-main {
    order: 1;
  }
  .tsp-sidebar {
    order: 2;
    position: static;
  }
  .tsp-page-panels--contact {
    grid-template-columns: 1fr;
  }
  .tsp-header__cta {
    display: none;
  }
  .tsp-footer__intro,
  .tsp-footer__grid {
    grid-template-columns: 1fr;
    display: grid;
    justify-content: stretch;
  }

  .tsp-nav-toggle { display: flex; }
  .tsp-nav__chevron { display: inline-flex; }

  .tsp-primary-nav {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--tsp-bg);
    border-top: 1px solid var(--tsp-border);
    border-bottom: 1px solid var(--tsp-border);
    box-shadow: var(--tsp-shadow);
    padding: .75rem 1rem 1rem;
    display: none;
    z-index: 190;
  }
  .tsp-primary-nav.is-open { display: block; }

  .tsp-nav {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
  }

  .tsp-nav > li {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    border-bottom: 1px solid var(--tsp-border);
  }
  .tsp-nav > li:last-child { border-bottom: none; }

  .tsp-nav > li > a {
    flex: 1;
    padding: .65rem .5rem;
  }

  /* Mobile dropdown: hidden by default, block when open */
  .tsp-nav__dropdown {
    position: static;
    width: 100%;
    flex-basis: 100%;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: none;
    border-radius: 0;
    border-left: 2px solid var(--tsp-primary-light);
    padding: .25rem 0 .5rem .5rem;
    margin: 0;
    display: none;
    transition: none;
  }
  .tsp-nav__has-dropdown.is-open .tsp-nav__dropdown { display: block; }
  .tsp-nav__dropdown-sep { display: none; }
}

@media (max-width: 767px) {
  :root {
    --tsp-gap:    1rem;
    --tsp-gap-lg: 2rem;
    --tsp-container-pad: 1rem;
  }

  .tsp-hero { min-height: 360px; }

  /* Mobile pill row: horizontal scroll instead of wrap */
  .tsp-cat-pills {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: .25rem;
  }
  .tsp-cat-pills::-webkit-scrollbar { display: none; }

  .tsp-product-single {
    grid-template-columns: 1fr;
  }

  .tsp-header-topbar__inner {
    flex-direction: column;
    align-items: flex-start;
    gap: .4rem;
  }
  .tsp-header-topbar__status {
    flex-wrap: wrap;
  }

  .tsp-footer__grid { gap: var(--tsp-gap); }

  .tsp-floating-contact {
    right: .75rem;
    bottom: .75rem;
  }

  .tsp-floating-contact__btn { width: 42px; height: 42px; font-size: 1.1rem; }
}
