:root {
  --ink: #111827;
  --muted: #606b7b;
  --line: #d7dce5;
  --paper: #f6f8fb;
  --panel: #ffffff;
  --navy: #0f2a4a;
  --navy-strong: #081a30;
  --red: #f15a24;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
  border: 0;
}

.tl-blog-page {
  color: #0a1e3c;
  background: #fff;
}

.tl-blog-hero {
  position: relative;
  min-height: clamp(320px, 36vw, 480px);
  display: grid;
  align-items: end;
  overflow: hidden;
  color: #fff;
  background:
    linear-gradient(90deg, rgba(4, 20, 39, 0.92) 0%, rgba(4, 20, 39, 0.76) 42%, rgba(4, 20, 39, 0.26) 100%),
    var(--blog-hero-image) center / cover no-repeat,
    #0a1e3c;
}

.tl-blog-hero-inner {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: clamp(48px, 8vw, 92px) 0 clamp(42px, 6vw, 70px);
}

.tl-blog-hero p,
.tl-article-header p,
.tl-blog-card-copy p,
.tl-related-card p {
  margin: 0 0 12px;
  color: #a6ce39;
  font-size: 0.82rem;
  font-weight: 950;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tl-blog-hero h1 {
  max-width: 760px;
  margin: 0;
  color: #fff;
  font-size: clamp(3rem, 6vw, 6rem);
  line-height: 0.96;
}

.tl-blog-hero span {
  display: block;
  max-width: 640px;
  margin-top: 22px;
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(1.08rem, 1.8vw, 1.4rem);
  line-height: 1.45;
}

.tl-blog-shell,
.tl-article-shell {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto;
  padding: 30px 0 clamp(54px, 7vw, 90px);
}

.tl-blog-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 28px;
  color: #687489;
  font-size: 0.88rem;
  font-weight: 800;
}

.tl-blog-breadcrumb a {
  color: #0a1e3c;
  text-decoration: none;
}

.tl-blog-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 320px);
  gap: clamp(28px, 4vw, 48px);
  align-items: start;
}

.tl-blog-controls {
  display: grid;
  grid-template-columns: minmax(260px, 1fr) minmax(180px, 220px);
  gap: 14px;
  margin-bottom: 16px;
}

.tl-blog-search {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 52px;
}

.tl-blog-controls input,
.tl-blog-controls select {
  width: 100%;
  height: 52px;
  padding: 0 16px;
  color: #0a1e3c;
  background: #fff;
  border: 1px solid #d9e1ee;
  border-radius: 8px;
  font: inherit;
  font-weight: 750;
}

.tl-blog-search input {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}

.tl-blog-search button {
  height: 52px;
  color: #fff;
  background: #a6ce39;
  border: 0;
  border-radius: 0 8px 8px 0;
  cursor: pointer;
  font-size: 1.4rem;
}

.tl-blog-category-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}

.tl-blog-category-pills button,
.tl-blog-side-card button {
  cursor: pointer;
  font: inherit;
}

.tl-blog-category-pills button {
  min-height: 38px;
  padding: 0 14px;
  color: #0a1e3c;
  background: #f5f7fb;
  border: 1px solid #d9e1ee;
  border-radius: 999px;
  font-weight: 850;
}

.tl-blog-category-pills button.is-active {
  color: #071b3a;
  background: #a6ce39;
  border-color: #a6ce39;
}

.tl-blog-state {
  min-height: 22px;
  margin: 0 0 12px;
  color: #5b6679;
  font-weight: 800;
}

.tl-blog-list {
  display: grid;
  gap: 26px;
}

.tl-blog-card {
  display: grid;
  grid-template-columns: minmax(240px, 42%) minmax(0, 1fr);
  gap: 24px;
  align-items: center;
  padding-bottom: 26px;
  border-bottom: 1px solid #e4eaf3;
}

.tl-blog-card-image {
  display: block;
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  background: #edf2f8;
}

.tl-blog-card-image img,
.tl-popular-posts img,
.tl-related-card img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.tl-blog-card-copy h2 {
  margin: 0 0 10px;
  color: #0a1e3c;
  font-size: clamp(1.35rem, 2vw, 1.8rem);
  line-height: 1.08;
}

.tl-blog-card-copy h2 a,
.tl-related-card h3 a {
  color: inherit;
  text-decoration: none;
}

.tl-blog-card-copy > span {
  display: block;
  color: #3f4d64;
  line-height: 1.48;
}

.tl-blog-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  margin: 14px 0;
  color: #5b6679;
  font-weight: 800;
}

.tl-read-more {
  color: #6ea317;
  font-weight: 950;
  text-decoration: none;
}

.tl-blog-load-more {
  min-height: 46px;
  margin: 28px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 24px;
  color: #071b3a;
  background: #a6ce39;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  font-weight: 950;
}

.tl-blog-sidebar {
  position: sticky;
  top: 96px;
  display: grid;
  gap: 18px;
}

.tl-blog-side-card,
.tl-blog-newsletter {
  background: #fff;
  border: 1px solid #dfe6f0;
  border-radius: 8px;
  box-shadow: 0 14px 36px rgba(10, 30, 60, 0.07);
  overflow: hidden;
}

.tl-blog-side-card h2 {
  margin: 0;
  padding: 14px 18px;
  color: #fff;
  background: #0a1e3c;
  font-size: 0.95rem;
  text-transform: uppercase;
}

.tl-blog-side-card > div {
  display: grid;
  gap: 0;
  padding: 12px;
}

.tl-blog-side-card button {
  min-height: 42px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #0a1e3c;
  background: transparent;
  border: 0;
  border-radius: 8px;
  font-weight: 850;
  text-align: left;
}

.tl-blog-side-card button.is-active,
.tl-blog-side-card button:hover {
  color: #6ea317;
  background: #f5f9eb;
}

.tl-popular-posts {
  gap: 12px !important;
}

.tl-popular-posts a {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 12px;
  color: #0a1e3c;
  text-decoration: none;
}

.tl-popular-posts img {
  height: 58px;
  border-radius: 6px;
}

.tl-popular-posts strong,
.tl-popular-posts small {
  display: block;
}

.tl-popular-posts strong {
  font-size: 0.86rem;
  line-height: 1.2;
}

.tl-popular-posts small {
  margin-top: 4px;
  color: #687489;
  font-size: 0.78rem;
}

.tl-blog-newsletter {
  padding: 24px;
  color: #fff;
  text-align: center;
  background:
    linear-gradient(rgba(4, 20, 39, 0.92), rgba(4, 20, 39, 0.92)),
    url("assets/tent-launch-hero-header.png") center / cover no-repeat;
}

.tl-blog-newsletter > div {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  margin: 0 auto 14px;
  color: #fff;
  background: #a6ce39;
  border-radius: 999px;
  font-size: 1.8rem;
}

.tl-blog-newsletter h2 {
  margin: 0 0 10px;
  color: #fff;
  text-transform: uppercase;
}

.tl-blog-newsletter p {
  margin: 0 0 16px;
  color: rgba(255,255,255,.86);
  line-height: 1.45;
}

.tl-blog-newsletter form {
  display: grid;
  gap: 10px;
}

.tl-blog-newsletter input,
.tl-blog-newsletter button {
  min-height: 46px;
  border-radius: 7px;
  font: inherit;
}

.tl-blog-newsletter input {
  padding: 0 14px;
  border: 0;
}

.tl-blog-newsletter button {
  color: #071b3a;
  background: #a6ce39;
  border: 0;
  cursor: pointer;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-blog-newsletter span {
  min-height: 18px;
  color: #a6ce39;
  font-weight: 850;
}

.tl-article-shell {
  max-width: 980px;
}

.tl-article-header {
  margin-bottom: 24px;
}

.tl-article-header h1 {
  max-width: 860px;
  margin: 0;
  color: #0a1e3c;
  font-size: clamp(2.4rem, 5vw, 4.6rem);
  line-height: 0.98;
}

.tl-article-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}

.tl-article-tags span {
  padding: 7px 10px;
  color: #0a1e3c;
  background: #eef4df;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 850;
}

.tl-article-image {
  width: 100%;
  max-height: 520px;
  object-fit: cover;
  border-radius: 10px;
  margin-bottom: 28px;
}

.tl-article-content {
  color: #22314b;
  font-size: clamp(1.02rem, 1.4vw, 1.16rem);
  line-height: 1.78;
}

.tl-article-content h2,
.tl-article-content h3 {
  margin: 34px 0 12px;
  color: #0a1e3c;
  line-height: 1.1;
}

.tl-article-content p {
  margin: 0 0 18px;
}

.tl-article-content a {
  color: #6ea317;
  font-weight: 850;
}

.tl-article-cta {
  margin: 42px 0;
  padding: clamp(24px, 4vw, 42px);
  color: #fff;
  background: linear-gradient(135deg, #041427, #0a1e3c);
  border-radius: 12px;
}

.tl-article-cta h2 {
  margin: 0 0 10px;
  color: #fff;
}

.tl-article-cta p {
  max-width: 640px;
  color: rgba(255,255,255,.86);
}

.tl-article-cta a {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  padding: 0 18px;
  color: #071b3a;
  background: #a6ce39;
  border-radius: 8px;
  font-weight: 950;
  text-decoration: none;
}

.tl-related-posts h2 {
  color: #0a1e3c;
}

.tl-related-posts > div {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.tl-related-card {
  border: 1px solid #dfe6f0;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}

.tl-related-card img {
  aspect-ratio: 16 / 9;
}

.tl-related-card p,
.tl-related-card h3 {
  margin-left: 14px;
  margin-right: 14px;
}

.tl-related-card h3 {
  margin-top: 0;
  font-size: 1rem;
}

.tl-admin-heading-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.tl-blog-editor-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, 0.8fr);
  gap: 18px;
  min-width: 0;
}

.tl-blog-editor-grid .tl-blog-preview-card,
.tl-blog-editor-grid .tl-admin-savebar {
  grid-column: 1 / -1;
}

.tl-blog-editor-grid > * {
  min-width: 0;
}

.tl-checkbox-field {
  grid-template-columns: auto 1fr !important;
  align-items: center;
  justify-content: start;
}

.tl-checkbox-field input {
  width: 18px;
  min-height: 18px;
  height: 18px;
  padding: 0;
}

@media (max-width: 980px) {
  .tl-blog-layout,
  .tl-blog-editor-grid,
  .tl-related-posts > div {
    grid-template-columns: 1fr;
  }

  .tl-blog-sidebar {
    position: static;
  }
}

body[data-page="buyers-guide"] .tl-detail-icon,
body[data-page="buyers-guide"] .tl-detail-photo {
  display: none !important;
}

body[data-page="buyers-guide"] .tl-detail-feature,
body[data-page="buyers-guide"] .tl-detail-options article,
body[data-page="buyers-guide"] .tl-detail-options article:only-child {
  grid-template-columns: minmax(0, 1fr) !important;
  gap: 0 !important;
  max-width: none;
}

body[data-page="buyers-guide"] .tl-detail-choice,
body[data-page="buyers-guide"] .tl-detail-fabric-row .tl-detail-choice,
body[data-page="buyers-guide"] .tl-detail-valance-row .tl-detail-choice,
body[data-page="buyers-guide"] .tl-detail-use-row .tl-detail-choice,
body[data-page="buyers-guide"] .tl-detail-print-row .tl-detail-choice,
body[data-page="buyers-guide"] .tl-detail-bag-row .tl-detail-choice {
  grid-template-columns: 28px minmax(0, 1fr) !important;
}

@media (max-width: 680px) {
  .tl-blog-hero-inner,
  .tl-blog-shell,
  .tl-article-shell {
    width: min(100% - 28px, 720px);
  }

  .tl-blog-controls,
  .tl-blog-card {
    grid-template-columns: 1fr;
  }

  .tl-blog-card {
    gap: 14px;
  }

  .tl-blog-hero {
    min-height: 320px;
  }

  .tl-blog-hero h1 {
    font-size: clamp(2.7rem, 14vw, 4.2rem);
  }

  .tl-blog-meta {
    gap: 10px;
  }

  .tl-admin-workspace,
  .tl-admin-card {
    padding: 16px;
  }

  .tl-blog-editor-grid {
    width: 100%;
    gap: 14px;
  }

  .tl-blog-editor-grid .tl-admin-savebar {
    position: static;
    flex-direction: column;
    align-items: stretch;
  }

  .tl-blog-editor-grid .tl-admin-savebar button,
  .tl-blog-editor-grid .tl-admin-savebar a {
    width: 100%;
  }
}

.tl-order-page,
.tl-admin-page {
  color: #0a1e3c;
  background: #fff;
}

.tl-track-hero {
  display: grid;
  grid-template-columns: minmax(360px, 0.95fr) minmax(420px, 1.05fr);
  gap: clamp(24px, 4vw, 58px);
  align-items: center;
  width: min(1260px, calc(100% - 48px));
  margin: 0 auto;
  padding: clamp(42px, 6vw, 78px) 0 34px;
}

.tl-track-copy h1 {
  margin: 0 0 18px;
  color: #0a1e3c;
  font-size: clamp(3.2rem, 6vw, 6.4rem);
  line-height: 0.92;
  text-transform: uppercase;
}

.tl-track-copy h1 span,
.tl-current-status strong {
  color: #6ea317;
}

.tl-track-copy p {
  max-width: 620px;
  margin: 0 0 24px;
  color: #283854;
  font-size: clamp(1.05rem, 1.5vw, 1.28rem);
  line-height: 1.5;
}

.tl-track-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  max-width: 660px;
}

.tl-track-form label,
.tl-admin-login label,
.tl-admin-toolbar label,
.tl-admin-form-grid label,
.tl-order-edit-grid label {
  display: grid;
  gap: 7px;
  color: #4d5a70;
  font-size: 0.8rem;
  font-weight: 900;
  text-transform: uppercase;
}

.tl-track-form input,
.tl-admin-login input,
.tl-admin-toolbar input,
.tl-admin-toolbar select,
.tl-admin-form-grid input,
.tl-admin-form-grid select,
.tl-order-edit-grid input,
.tl-order-edit-grid select,
.tl-order-edit-grid textarea,
.tl-admin-table select {
  width: 100%;
  min-height: 52px;
  padding: 0 16px;
  color: #0a1e3c;
  background: #fff;
  border: 1px solid #d9e1ee;
  border-radius: 8px;
  font: inherit;
  font-size: 1rem;
  font-weight: 750;
}

.tl-order-edit-grid textarea {
  min-height: 110px;
  padding-top: 14px;
  resize: vertical;
}

.tl-track-form button,
.tl-admin-login button,
.tl-admin-toolbar button,
.tl-admin-form-grid button,
.tl-admin-savebar button,
.tl-proof-actions button,
.tl-inline-alert a,
.tl-support-strip a {
  min-height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 0 22px;
  color: #fff;
  background: #6ea317;
  border: 0;
  border-radius: 8px;
  cursor: pointer;
  font: inherit;
  font-weight: 950;
  text-decoration: none;
  text-transform: uppercase;
}

.tl-track-form button {
  grid-column: 1 / -1;
  justify-content: space-between;
  padding-inline: 28px;
  background: linear-gradient(135deg, #6ea317, #a6ce39);
}

.tl-track-form button:disabled,
.tl-proof-actions button:disabled {
  cursor: wait;
  opacity: 0.7;
}

.tl-form-message {
  grid-column: 1 / -1;
  min-height: 20px;
  margin: 2px 0 0;
  color: #0a1e3c;
  font-weight: 800;
  text-transform: none;
}

.tl-track-visual {
  min-height: 360px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 10px;
  background: linear-gradient(110deg, rgba(255,255,255,.9), rgba(255,255,255,.45)), linear-gradient(180deg, #eaf5ff, #f4f8ee);
}

.tl-track-visual img {
  width: min(520px, 88%);
  max-height: 420px;
  object-fit: contain;
  filter: drop-shadow(0 28px 34px rgba(10,30,60,.18));
}

.tl-order-results {
  width: min(1180px, calc(100% - 48px));
  margin: 0 auto clamp(50px, 7vw, 90px);
}

.tl-order-summary-card,
.tl-info-card,
.tl-support-strip,
.tl-admin-login,
.tl-admin-workspace,
.tl-create-order,
.tl-admin-card {
  background: #fff;
  border: 1px solid #e3e9f2;
  border-radius: 10px;
  box-shadow: 0 18px 44px rgba(10, 30, 60, 0.08);
}

.tl-order-summary-card {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  padding: clamp(24px, 3vw, 40px);
}

.tl-eyebrow {
  margin: 0 0 8px;
  color: #6ea317;
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.tl-order-summary-card h2,
.tl-admin-heading h1 {
  margin: 0 0 6px;
  color: #0a1e3c;
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: 1;
}

.tl-order-summary-card p,
.tl-admin-heading p {
  margin: 0;
  color: #45536b;
  font-weight: 750;
}

.tl-current-status {
  display: flex;
  align-items: center;
  gap: 18px;
}

.tl-current-status > span {
  width: 70px;
  height: 70px;
  display: grid;
  place-items: center;
  color: #fff;
  background: #6ea317;
  border-radius: 999px;
  font-size: 2rem;
}

.tl-current-status p {
  color: #647087;
  font-size: 0.8rem;
  text-transform: uppercase;
}

.tl-current-status strong {
  display: block;
  font-size: 1.45rem;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-current-status small {
  color: #0a1e3c;
  font-weight: 800;
}

.tl-order-timeline {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  gap: 0;
  margin: 34px 0;
  padding: 0;
  list-style: none;
}

.tl-order-timeline li {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 8px;
  color: #9aa4b3;
  text-align: center;
}

.tl-order-timeline li::before {
  position: absolute;
  top: 28px;
  left: -50%;
  z-index: 0;
  width: 100%;
  height: 4px;
  background: #d9e1ee;
  content: "";
}

.tl-order-timeline li:first-child::before {
  display: none;
}

.tl-order-timeline li span {
  position: relative;
  z-index: 1;
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  background: #fff;
  border: 3px solid #d9e1ee;
  border-radius: 999px;
  font-size: 1.5rem;
}

.tl-order-timeline li strong {
  max-width: 110px;
  color: inherit;
  font-size: 0.84rem;
  font-weight: 950;
  line-height: 1.1;
  text-transform: uppercase;
}

.tl-order-timeline li small {
  min-height: 18px;
  color: #0a1e3c;
  font-weight: 750;
}

.tl-order-timeline .is-complete,
.tl-order-timeline .is-current {
  color: #0a1e3c;
}

.tl-order-timeline .is-complete::before,
.tl-order-timeline .is-current::before {
  background: #0a1e3c;
}

.tl-order-timeline .is-complete span,
.tl-order-timeline .is-current span {
  border-color: #6ea317;
}

.tl-order-timeline .is-current strong {
  color: #6ea317;
}

.tl-order-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 22px;
}

.tl-info-card {
  overflow: hidden;
}

.tl-info-card h3 {
  margin: 0;
  padding: 14px 20px;
  color: #fff;
  background: #0a1e3c;
  font-size: 1rem;
  text-transform: uppercase;
}

.tl-info-card > p,
.tl-info-card > .tl-proof-actions,
.tl-info-card > .tl-form-message {
  margin: 18px 20px;
}

.tl-order-product {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 20px;
  border-bottom: 1px solid #e3e9f2;
}

.tl-order-product img {
  width: 96px;
  height: 76px;
  object-fit: contain;
  background: #f5f7fb;
  border-radius: 8px;
}

.tl-order-product strong,
.tl-order-product span,
.tl-order-product small {
  display: block;
}

.tl-detail-list {
  margin: 0;
  padding: 4px 20px 20px;
}

.tl-detail-list div {
  display: grid;
  grid-template-columns: minmax(130px, 0.75fr) minmax(0, 1fr);
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid #edf1f6;
}

.tl-detail-list div:last-child {
  border-bottom: 0;
}

.tl-detail-list dt {
  color: #637086;
  font-size: 0.84rem;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-detail-list dd {
  margin: 0;
  color: #0a1e3c;
  font-weight: 800;
  text-align: right;
}

.tl-status-note {
  margin: 20px;
  padding: 18px;
  background: #f4fae8;
  border-radius: 8px;
}

.tl-status-note p {
  margin: 6px 0 0;
}

.tl-inline-alert {
  margin: 0 20px 20px;
  padding: 18px;
  color: #0b3f85;
  background: #eef6ff;
  border-radius: 8px;
  font-weight: 800;
}

.tl-inline-alert p {
  margin: 6px 0 14px;
}

.tl-secondary-button,
.tl-proof-actions .tl-secondary-button {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  color: #0a1e3c;
  background: #fff;
  border: 1px solid #d9e1ee;
  border-radius: 8px;
  font-weight: 900;
  text-decoration: none;
}

.tl-proof-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.tl-support-strip {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 18px;
  align-items: center;
  margin-top: 34px;
  padding: 24px;
}

.tl-support-strip strong,
.tl-support-strip span {
  display: block;
}

.tl-support-strip span {
  margin-top: 4px;
  color: #4d5a70;
}

.tl-admin-shell {
  width: min(1240px, calc(100% - 48px));
  margin: 0 auto;
  padding: clamp(34px, 5vw, 70px) 0;
}

.tl-admin-heading {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  align-items: center;
  margin-bottom: 24px;
}

.tl-admin-login,
.tl-admin-workspace,
.tl-create-order,
.tl-admin-card {
  padding: 22px;
}

.tl-admin-login {
  max-width: 460px;
}

.tl-admin-login h2,
.tl-admin-card h2,
.tl-create-order summary {
  margin: 0 0 16px;
  color: #0a1e3c;
}

.tl-admin-login form,
.tl-admin-toolbar,
.tl-admin-form-grid {
  display: grid;
  gap: 14px;
}

.tl-admin-toolbar {
  grid-template-columns: minmax(220px, 1fr) 220px auto;
  align-items: end;
  margin-bottom: 18px;
}

.tl-create-order {
  margin-bottom: 18px;
}

.tl-create-order summary {
  cursor: pointer;
  font-weight: 950;
}

.tl-admin-form-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 16px;
}

.tl-admin-table-wrap {
  overflow-x: auto;
}

.tl-admin-table {
  width: 100%;
  min-width: 820px;
  border-collapse: collapse;
}

.tl-admin-table th,
.tl-admin-table td {
  padding: 14px;
  border-bottom: 1px solid #e3e9f2;
  text-align: left;
  vertical-align: middle;
}

.tl-admin-table th {
  color: #fff;
  background: #0a1e3c;
  font-size: 0.82rem;
  text-transform: uppercase;
}

.tl-admin-table small {
  display: block;
  margin-top: 4px;
  color: #637086;
  font-weight: 750;
}

.tl-admin-table a,
.tl-admin-table button {
  margin-right: 8px;
  color: #0a1e3c;
  background: transparent;
  border: 0;
  cursor: pointer;
  font: inherit;
  font-weight: 900;
  text-decoration: underline;
}

.tl-order-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.tl-admin-card {
  display: grid;
  gap: 14px;
  align-content: start;
}

.tl-admin-history {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-admin-history li {
  padding: 12px;
  background: #f5f7fb;
  border-radius: 8px;
}

.tl-admin-history strong,
.tl-admin-history span,
.tl-admin-history p {
  display: block;
  margin: 0;
}

.tl-admin-history span {
  margin-top: 4px;
  color: #637086;
  font-size: 0.86rem;
}

.tl-admin-savebar {
  grid-column: 1 / -1;
  position: sticky;
  bottom: 18px;
  display: flex;
  gap: 16px;
  align-items: center;
  padding: 18px;
  background: rgba(255,255,255,.94);
  border: 1px solid #d9e1ee;
  border-radius: 10px;
  box-shadow: 0 16px 38px rgba(10,30,60,.12);
}

@media (max-width: 920px) {
  .tl-track-hero,
  .tl-order-card-grid,
  .tl-order-edit-grid {
    grid-template-columns: 1fr;
  }

  .tl-track-hero {
    width: min(100% - 28px, 720px);
    padding-top: 28px;
  }

  .tl-track-visual {
    min-height: 260px;
  }

  .tl-order-results,
  .tl-admin-shell {
    width: min(100% - 28px, 760px);
  }

  .tl-order-summary-card,
  .tl-current-status,
  .tl-support-strip,
  .tl-admin-heading {
    align-items: flex-start;
  }

  .tl-order-summary-card,
  .tl-support-strip,
  .tl-admin-heading {
    display: flex;
    flex-direction: column;
  }

  .tl-support-strip {
    display: grid;
    grid-template-columns: 1fr;
  }

  .tl-order-timeline {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .tl-order-timeline li {
    grid-template-columns: 56px minmax(0, 1fr);
    justify-items: start;
    gap: 12px;
    text-align: left;
  }

  .tl-order-timeline li::before {
    top: -18px;
    left: 27px;
    width: 4px;
    height: 32px;
  }

  .tl-order-timeline li span {
    grid-row: 1 / span 2;
    width: 54px;
    height: 54px;
  }

  .tl-order-timeline li strong {
    max-width: none;
    align-self: end;
  }

  .tl-admin-toolbar,
  .tl-admin-form-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .tl-track-form,
  .tl-order-product,
  .tl-detail-list div {
    grid-template-columns: 1fr;
  }

  .tl-track-copy h1 {
    font-size: clamp(2.7rem, 15vw, 4rem);
  }

  .tl-order-product b,
  .tl-detail-list dd {
    text-align: left;
  }
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  overflow-x: hidden;
  color: var(--ink);
  background: var(--paper);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

button,
input,
textarea {
  font: inherit;
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  min-height: 48px;
  padding: 5px clamp(14px, 3vw, 42px);
  background: rgba(246, 248, 251, 0.94);
  border-bottom: 1px solid rgba(17, 19, 23, 0.08);
  backdrop-filter: blur(18px);
}

.brand {
  grid-column: 2;
  justify-self: center;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}

.brand-logo {
  width: auto;
  height: clamp(24px, 2.2vw, 32px);
  object-fit: contain;
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  color: #fff;
  background: var(--navy);
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 900;
}

.brand strong,
.brand small {
  display: block;
  line-height: 1.05;
}

.brand small {
  margin-top: 2px;
  color: var(--muted);
}

.nav {
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  display: flex;
  gap: clamp(12px, 2vw, 24px);
  color: var(--ink);
  font-size: 0.82rem;
  line-height: 1;
  font-weight: 750;
  white-space: nowrap;
}

.nav a {
  color: var(--ink);
}

.nav a:hover {
  color: var(--ink);
}

.cart-button {
  grid-column: 3;
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 34px;
  padding: 7px 10px;
  color: #fff;
  background: var(--navy);
  border: 0;
  border-radius: 7px;
  font-size: 0.78rem;
  line-height: 1;
  font-weight: 800;
}

.cart-button strong {
  display: grid;
  place-items: center;
  min-width: 20px;
  height: 20px;
  color: var(--ink);
  background: #fff;
  border-radius: 999px;
  font-size: 0.72rem;
}

.eyebrow {
  margin: 0 0 12px;
  color: var(--red);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

h1,
h2,
p {
  margin-top: 0;
}

.policy-page {
  padding: clamp(42px, 7vw, 84px) clamp(18px, 4vw, 56px);
}

.policy-hero {
  max-width: 940px;
  margin-bottom: clamp(32px, 5vw, 58px);
}

.policy-hero h1 {
  max-width: 820px;
  margin-bottom: 18px;
  font-size: clamp(2.6rem, 6vw, 5.8rem);
  line-height: 0.95;
}

.policy-hero p:not(.eyebrow) {
  color: var(--muted);
  font-size: clamp(1rem, 2vw, 1.24rem);
  line-height: 1.6;
}

.policy-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.policy-grid article {
  padding: clamp(20px, 3vw, 32px);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.policy-grid h2 {
  margin-bottom: 12px;
  font-size: clamp(1.7rem, 3vw, 2.8rem);
}

.policy-grid p,
.policy-grid li {
  color: var(--muted);
  line-height: 1.6;
}

.policy-grid ul {
  display: grid;
  gap: 10px;
  margin: 18px 0 0;
  padding-left: 20px;
}

.tl-about-page {
  overflow: hidden;
  color: #071b3a;
  background: linear-gradient(180deg, #ffffff 0%, #f5f7fb 42%, #ffffff 100%);
}

.tl-about-section {
  width: min(1220px, calc(100% - 36px));
  margin: 0 auto;
}

.tl-about-hero {
  width: min(1320px, calc(100% - 36px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 0.82fr);
  align-items: center;
  gap: clamp(28px, 5vw, 76px);
  padding: clamp(48px, 7vw, 96px) 0 clamp(34px, 5vw, 70px);
}

.tl-about-hero-copy {
  min-width: 0;
}

.tl-about-hero h1 {
  max-width: 840px;
  margin: 0;
  color: var(--navy-strong);
  font-size: clamp(3rem, 6.3vw, 6.35rem);
  line-height: 0.92;
  letter-spacing: -0.035em;
}

.tl-about-subtitle {
  max-width: 760px;
  margin: 24px 0 0;
  color: #46546b;
  font-size: clamp(1.04rem, 1.55vw, 1.32rem);
  font-weight: 560;
  line-height: 1.55;
}

.tl-about-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 30px;
}

.tl-about-hero-media {
  position: relative;
  min-height: 420px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background:
    radial-gradient(circle at 50% 20%, rgba(166, 206, 57, 0.2), transparent 36%),
    linear-gradient(145deg, #edf3fb, #ffffff);
  border: 1px solid #dbe3ef;
  box-shadow: 0 26px 60px rgba(7, 27, 58, 0.1);
  overflow: hidden;
}

.tl-about-hero-media::before {
  content: "";
  position: absolute;
  inset: auto 0 -16%;
  height: 42%;
  background: #071b3a;
}

.tl-about-hero-media img {
  position: relative;
  z-index: 1;
  width: min(100%, 620px);
  height: auto;
  filter: drop-shadow(0 26px 30px rgba(4, 20, 39, 0.22));
}

.tl-about-intro {
  width: min(1220px, calc(100% - 36px));
  margin: 0 auto clamp(24px, 4vw, 46px);
  display: grid;
  grid-template-columns: minmax(280px, 0.65fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: start;
  padding: clamp(28px, 4vw, 48px) 0;
  border-top: 1px solid #dbe3ef;
  border-bottom: 1px solid #dbe3ef;
}

.tl-about-intro h2,
.tl-about-panel h2,
.tl-about-process h2,
.tl-about-fit h2,
.tl-about-cta h2 {
  margin: 0;
  color: var(--navy-strong);
  font-size: clamp(2rem, 3.9vw, 4rem);
  line-height: 0.98;
  letter-spacing: -0.025em;
}

.tl-about-story {
  display: grid;
  gap: 18px;
}

.tl-about-story p,
.tl-about-process-copy p,
.tl-process-step p,
.tl-about-card p {
  margin: 0;
  color: #46546b;
  font-size: clamp(0.96rem, 1.05vw, 1.08rem);
  line-height: 1.58;
}

.tl-about-strip {
  width: min(1220px, calc(100% - 36px));
  margin: 0 auto clamp(28px, 5vw, 60px);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border: 1px solid #dbe3ef;
  background: #fff;
  box-shadow: 0 18px 44px rgba(7, 27, 58, 0.06);
}

.tl-about-strip div {
  padding: clamp(20px, 2.4vw, 30px);
  border-right: 1px solid #dbe3ef;
}

.tl-about-strip div:last-child {
  border-right: 0;
}

.tl-about-strip strong,
.tl-about-strip span {
  display: block;
}

.tl-about-strip strong {
  color: #071b3a;
  font-size: clamp(0.94rem, 1.08vw, 1.12rem);
  font-weight: 950;
  text-transform: uppercase;
}

.tl-about-strip span {
  margin-top: 8px;
  color: #46546b;
  font-size: clamp(0.88rem, 0.98vw, 0.98rem);
  line-height: 1.35;
}

.tl-about-panel {
  margin: 0 auto clamp(28px, 5vw, 62px);
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.tl-about-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 26px;
}

.tl-about-card {
  min-height: 250px;
  padding: clamp(20px, 2vw, 26px);
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 12px 28px rgba(7, 27, 58, 0.05);
}

.tl-about-card span,
.tl-process-step span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 34px;
  height: 34px;
  margin-bottom: 18px;
  padding: 0 10px;
  color: #071b3a;
  background: #a6ce39;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 950;
}

.tl-about-card h3,
.tl-process-step h3 {
  margin: 0 0 10px;
  color: var(--navy-strong);
  font-size: clamp(1.08rem, 1.35vw, 1.32rem);
  line-height: 1.18;
}

.tl-about-process {
  display: grid;
  grid-template-columns: minmax(280px, 0.55fr) minmax(0, 1fr);
  gap: clamp(24px, 4vw, 58px);
  align-items: start;
  margin-bottom: clamp(30px, 5vw, 62px);
}

.tl-about-process-copy {
  position: sticky;
  top: 128px;
}

.tl-about-process-copy p {
  margin-top: 18px;
}

.tl-process-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin-top: 0;
}

.tl-process-step {
  min-height: 210px;
  padding: clamp(20px, 2vw, 26px);
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 12px 28px rgba(7, 27, 58, 0.05);
}

.tl-about-fit {
  display: grid;
  grid-template-columns: minmax(280px, 0.68fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: start;
  margin-bottom: clamp(30px, 5vw, 62px);
  padding: clamp(28px, 4vw, 46px);
  background: #071b3a;
  border-radius: 8px;
  box-shadow: 0 24px 56px rgba(7, 27, 58, 0.14);
}

.tl-about-fit h2 {
  color: #fff;
}

.tl-about-fit .eyebrow {
  color: #a6ce39;
}

.tl-about-fit ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-about-fit li {
  min-height: 58px;
  display: flex;
  align-items: center;
  padding: 14px 16px;
  color: rgba(255, 255, 255, 0.92);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(219, 227, 239, 0.14);
  border-radius: 8px;
  font-weight: 760;
  line-height: 1.25;
}

.tl-about-cta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  width: min(1220px, calc(100% - 36px));
  margin: 0 auto clamp(46px, 7vw, 86px);
  padding: clamp(28px, 4vw, 46px);
  color: #fff;
  background: linear-gradient(135deg, #041427, #071b3a);
  border-radius: 8px;
  box-shadow: 0 28px 70px rgba(4, 20, 39, 0.18);
}

.tl-about-cta h2 {
  color: #fff;
  max-width: 780px;
}

.tl-about-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 24px;
  color: #041427;
  background: var(--tl-lime, #a6ce39);
  border-radius: 7px;
  font-weight: 950;
  text-decoration: none;
  white-space: nowrap;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.tl-about-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 24px;
  color: #071b3a;
  background: #fff;
  border: 1px solid #cfd7e4;
  border-radius: 7px;
  font-weight: 950;
  text-decoration: none;
  white-space: nowrap;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.tl-about-button:hover,
.tl-about-button:focus-visible,
.tl-about-secondary:hover,
.tl-about-secondary:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(166, 206, 57, 0.24);
  outline: 0;
}

.tl-about-secondary:hover,
.tl-about-secondary:focus-visible {
  border-color: #a6ce39;
}

.tl-contact-page {
  color: #071b3a;
  background: linear-gradient(180deg, #ffffff 0%, #f5f7fb 48%, #ffffff 100%);
}

.tl-contact-hero {
  width: min(1320px, calc(100% - 36px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 0.78fr);
  align-items: center;
  gap: clamp(28px, 5vw, 76px);
  padding: clamp(48px, 7vw, 92px) 0 clamp(30px, 5vw, 64px);
}

.tl-contact-hero h1 {
  max-width: 780px;
  margin: 0;
  color: #071b3a;
  font-size: clamp(3rem, 6.4vw, 6.2rem);
  line-height: 0.92;
  letter-spacing: -0.035em;
}

.tl-contact-hero p {
  max-width: 720px;
  margin: 24px 0 0;
  color: #46546b;
  font-size: clamp(1.04rem, 1.45vw, 1.28rem);
  line-height: 1.55;
  font-weight: 560;
}

.tl-contact-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.tl-contact-quick a,
.tl-contact-quick span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  color: #071b3a;
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 850;
  text-decoration: none;
}

.tl-contact-quick a {
  background: #a6ce39;
  border-color: #a6ce39;
}

.tl-contact-hero-media {
  min-height: 380px;
  display: grid;
  place-items: center;
  padding: clamp(18px, 3vw, 34px);
  background:
    radial-gradient(circle at 48% 18%, rgba(166, 206, 57, 0.22), transparent 34%),
    linear-gradient(145deg, #edf3fb, #fff);
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 24px 60px rgba(7, 27, 58, 0.1);
  overflow: hidden;
}

.tl-contact-hero-media img {
  width: min(100%, 580px);
  height: auto;
  filter: drop-shadow(0 24px 28px rgba(4, 20, 39, 0.18));
}

.tl-contact-shell {
  width: min(1220px, calc(100% - 36px));
  margin: 0 auto clamp(46px, 7vw, 86px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.42fr);
  gap: 18px;
  align-items: start;
}

.tl-contact-form,
.tl-contact-sidebar article {
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 16px 38px rgba(7, 27, 58, 0.06);
}

.tl-contact-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  padding: clamp(22px, 3vw, 34px);
}

.tl-contact-form > div,
.tl-contact-full,
.tl-contact-form button,
.tl-contact-note {
  grid-column: 1 / -1;
}

.tl-contact-form h2,
.tl-contact-sidebar h2 {
  margin: 0;
  color: #071b3a;
  font-size: clamp(1.65rem, 2.8vw, 2.6rem);
  line-height: 1;
  letter-spacing: -0.02em;
}

.tl-contact-form label {
  display: grid;
  gap: 8px;
  color: #071b3a;
  font-size: 0.86rem;
  font-weight: 950;
}

.tl-contact-form input,
.tl-contact-form select,
.tl-contact-form textarea {
  width: 100%;
  min-width: 0;
  color: #071b3a;
  background: #f8fafc;
  border: 1px solid #cfd7e4;
  border-radius: 8px;
  font: inherit;
  font-size: 0.98rem;
  font-weight: 620;
  outline: 0;
  transition: border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.tl-contact-form input,
.tl-contact-form select {
  height: 48px;
  padding: 0 13px;
}

.tl-contact-form textarea {
  resize: vertical;
  padding: 13px;
  line-height: 1.45;
}

.tl-contact-form input:focus,
.tl-contact-form select:focus,
.tl-contact-form textarea:focus {
  background: #fff;
  border-color: #a6ce39;
  box-shadow: 0 0 0 4px rgba(166, 206, 57, 0.14);
}

.tl-contact-form button {
  min-height: 54px;
  color: #041427;
  background: #a6ce39;
  border: 0;
  border-radius: 8px;
  font: inherit;
  font-weight: 950;
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.tl-contact-form button:hover,
.tl-contact-form button:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 16px 30px rgba(166, 206, 57, 0.24);
  outline: 0;
}

.tl-contact-note {
  margin: -4px 0 0;
  color: #59657a;
  font-size: 0.9rem;
  line-height: 1.4;
}

.tl-contact-sidebar {
  display: grid;
  gap: 18px;
}

.tl-contact-sidebar article {
  padding: clamp(20px, 2.4vw, 28px);
}

.tl-contact-sidebar ul {
  display: grid;
  gap: 11px;
  margin: 18px 0 0;
  padding: 0;
  list-style: none;
}

.tl-contact-sidebar li {
  padding-left: 22px;
  color: #46546b;
  line-height: 1.35;
  font-weight: 700;
  position: relative;
}

.tl-contact-sidebar li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 8px;
  height: 8px;
  background: #a6ce39;
  border-radius: 999px;
}

.tl-contact-topic-list {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 18px;
}

.tl-contact-topic-list span {
  padding: 8px 10px;
  color: #071b3a;
  background: #f4f8ed;
  border: 1px solid rgba(166, 206, 57, 0.28);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 900;
}

.tl-resources-page {
  color: #071b3a;
  background: linear-gradient(180deg, #ffffff 0%, #f5f7fb 52%, #ffffff 100%);
}

.tl-resources-hero {
  width: min(1220px, calc(100% - 36px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 0.36fr);
  gap: clamp(24px, 4vw, 56px);
  align-items: end;
  padding: clamp(48px, 7vw, 96px) 0 clamp(28px, 5vw, 58px);
}

.tl-resources-hero h1 {
  max-width: 910px;
  margin: 0;
  color: #071b3a;
  font-size: clamp(3rem, 6.4vw, 6.2rem);
  line-height: 0.92;
  letter-spacing: -0.035em;
}

.tl-resources-hero p {
  max-width: 760px;
  margin: 24px 0 0;
  color: #46546b;
  font-size: clamp(1.04rem, 1.45vw, 1.28rem);
  line-height: 1.55;
  font-weight: 560;
}

.tl-resources-hero-panel {
  padding: clamp(20px, 2.5vw, 28px);
  color: #fff;
  background: #071b3a;
  border-radius: 8px;
  box-shadow: 0 20px 46px rgba(7, 27, 58, 0.14);
}

.tl-resources-hero-panel strong,
.tl-resources-hero-panel span {
  display: block;
}

.tl-resources-hero-panel strong {
  color: #a6ce39;
  font-size: 0.9rem;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-resources-hero-panel span {
  margin-top: 10px;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.45;
  font-weight: 650;
}

.tl-resources-featured,
.tl-resources-grid,
.tl-resources-checklist {
  width: min(1220px, calc(100% - 36px));
  margin-left: auto;
  margin-right: auto;
}

.tl-resources-featured {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: 16px;
}

.tl-resource-large,
.tl-resources-grid a {
  display: grid;
  align-content: start;
  color: #071b3a;
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  text-decoration: none;
  box-shadow: 0 14px 34px rgba(7, 27, 58, 0.06);
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.tl-resource-large {
  min-height: 280px;
  padding: clamp(24px, 3vw, 36px);
}

.tl-resource-large:hover,
.tl-resource-large:focus-visible,
.tl-resources-grid a:hover,
.tl-resources-grid a:focus-visible {
  transform: translateY(-3px);
  border-color: #a6ce39;
  box-shadow: 0 20px 44px rgba(7, 27, 58, 0.1);
  outline: 0;
}

.tl-resource-large span,
.tl-resources-grid span {
  color: #a6ce39;
  font-size: 0.82rem;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.tl-resource-large h2,
.tl-resources-grid h2,
.tl-resources-checklist h2 {
  margin: 14px 0 0;
  color: #071b3a;
  font-size: clamp(1.7rem, 2.6vw, 3rem);
  line-height: 1;
  letter-spacing: -0.025em;
}

.tl-resource-large p,
.tl-resources-grid p {
  margin: 16px 0 0;
  color: #46546b;
  line-height: 1.48;
  font-weight: 600;
}

.tl-resources-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-bottom: clamp(28px, 5vw, 60px);
}

.tl-resources-grid a {
  min-height: 230px;
  padding: clamp(20px, 2vw, 26px);
}

.tl-resources-grid h2 {
  font-size: clamp(1.18rem, 1.45vw, 1.38rem);
  line-height: 1.1;
}

.tl-resources-grid p {
  font-size: 0.94rem;
}

.tl-resources-checklist {
  display: grid;
  grid-template-columns: minmax(280px, 0.48fr) minmax(0, 1fr);
  gap: clamp(28px, 5vw, 70px);
  align-items: start;
  margin-bottom: clamp(46px, 7vw, 86px);
  padding: clamp(28px, 4vw, 46px);
  background: #071b3a;
  border-radius: 8px;
  box-shadow: 0 24px 56px rgba(7, 27, 58, 0.14);
}

.tl-resources-checklist h2 {
  color: #fff;
}

.tl-resources-checklist .eyebrow {
  color: #a6ce39;
}

.tl-resources-checklist ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-resources-checklist li {
  min-height: 70px;
  display: flex;
  align-items: center;
  padding: 14px 16px 14px 42px;
  color: rgba(255, 255, 255, 0.92);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(219, 227, 239, 0.14);
  border-radius: 8px;
  font-weight: 730;
  line-height: 1.3;
  position: relative;
}

.tl-resources-checklist li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  width: 10px;
  height: 10px;
  background: #a6ce39;
  border-radius: 999px;
  transform: translateY(-50%);
}

@media (max-width: 1050px) {
  .tl-resources-hero,
  .tl-resources-checklist {
    grid-template-columns: 1fr;
  }

  .tl-resources-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .tl-resources-hero,
  .tl-resources-featured,
  .tl-resources-grid,
  .tl-resources-checklist {
    width: min(100% - 28px, 1220px);
  }

  .tl-resources-hero {
    padding-top: 34px;
  }

  .tl-resources-hero h1 {
    font-size: clamp(2.55rem, 12vw, 4rem);
  }

  .tl-resources-featured,
  .tl-resources-grid,
  .tl-resources-checklist ul {
    grid-template-columns: 1fr;
  }

  .tl-resource-large {
    min-height: 0;
  }

  .tl-resources-grid a {
    min-height: 0;
  }

  .tl-resources-checklist {
    padding: 26px 18px;
  }
}

@media (max-width: 1050px) {
  .tl-contact-hero,
  .tl-contact-shell {
    grid-template-columns: 1fr;
  }

  .tl-contact-hero-media {
    min-height: 320px;
  }
}

@media (max-width: 680px) {
  .tl-contact-hero,
  .tl-contact-shell {
    width: min(100% - 28px, 1220px);
  }

  .tl-contact-hero {
    padding-top: 34px;
  }

  .tl-contact-hero h1 {
    font-size: clamp(2.55rem, 12vw, 4rem);
  }

  .tl-contact-quick,
  .tl-contact-form {
    grid-template-columns: 1fr;
  }

  .tl-contact-quick a,
  .tl-contact-quick span {
    width: 100%;
  }

  .tl-contact-form {
    padding: 20px;
  }
}

@media (max-width: 1100px) {
  .tl-about-hero,
  .tl-about-intro,
  .tl-about-process,
  .tl-about-fit {
    grid-template-columns: 1fr;
  }

  .tl-about-hero-media {
    min-height: 360px;
  }

  .tl-about-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-about-process-copy {
    position: static;
  }
}

@media (max-width: 760px) {
  .tl-about-hero,
  .tl-about-section,
  .tl-about-intro,
  .tl-about-strip,
  .tl-about-cta {
    width: min(100% - 28px, 1220px);
  }

  .tl-about-hero {
    padding-top: 34px;
  }

  .tl-about-hero h1 {
    font-size: clamp(2.55rem, 12vw, 4rem);
  }

  .tl-about-actions,
  .tl-about-cta {
    align-items: stretch;
    flex-direction: column;
  }

  .tl-about-button,
  .tl-about-secondary {
    width: 100%;
  }

  .tl-about-hero-media {
    min-height: 280px;
  }

  .tl-about-strip,
  .tl-about-card-grid,
  .tl-process-grid,
  .tl-about-fit ul {
    grid-template-columns: 1fr;
  }

  .tl-about-strip div {
    border-right: 0;
    border-bottom: 1px solid #dbe3ef;
  }

  .tl-about-strip div:last-child {
    border-bottom: 0;
  }

  .tl-about-card,
  .tl-process-step {
    min-height: 0;
  }

  .tl-about-fit {
    width: min(100% - 28px, 1220px);
    padding: 26px 18px;
  }
}

.tl-product-page {
  color: var(--navy-strong);
  background:
    radial-gradient(circle at 92% 6%, rgba(166, 206, 57, 0.14), transparent 28%),
    linear-gradient(180deg, #ffffff 0%, #f5f7fb 58%, #ffffff 100%);
}

.tl-product-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(460px, 1.08fr);
  gap: clamp(28px, 5vw, 72px);
  align-items: center;
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto;
  padding: clamp(46px, 7vw, 92px) 0 clamp(30px, 5vw, 64px);
}

.tl-product-copy h1 {
  max-width: 760px;
  margin: 0 0 18px;
  color: var(--navy-strong);
  font-size: clamp(3.2rem, 7.2vw, 7rem);
  line-height: 0.92;
  letter-spacing: 0;
}

.tl-product-hero > *,
.tl-product-shell > *,
.tl-mobile-image-note > * {
  min-width: 0;
}

.tl-product-lede {
  max-width: 680px;
  margin: 0;
  color: var(--muted);
  font-size: clamp(1.04rem, 1.55vw, 1.22rem);
  line-height: 1.62;
}

.tl-product-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.tl-product-button,
.tl-product-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 22px;
  border-radius: 8px;
  font-weight: 950;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.tl-product-button {
  color: #fff;
  background: var(--navy-strong);
  box-shadow: 0 18px 34px rgba(7, 27, 58, 0.2);
}

.tl-product-secondary {
  color: var(--navy-strong);
  background: #fff;
  border: 1px solid var(--line);
}

.tl-product-button:hover,
.tl-product-button:focus-visible,
.tl-product-secondary:hover,
.tl-product-secondary:focus-visible {
  transform: translateY(-2px);
  outline: 0;
}

.tl-product-button:hover,
.tl-product-button:focus-visible {
  box-shadow: 0 22px 40px rgba(7, 27, 58, 0.26);
}

.tl-product-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}

.tl-product-trust li {
  padding: 9px 12px;
  color: var(--navy-strong);
  background: rgba(166, 206, 57, 0.16);
  border: 1px solid rgba(166, 206, 57, 0.35);
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 850;
}

.tl-image-placeholder {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  max-width: 100%;
  min-height: 230px;
  padding: 24px;
  overflow: hidden;
  text-align: center;
  background:
    linear-gradient(135deg, rgba(166, 206, 57, 0.18), transparent 34%),
    linear-gradient(135deg, #071b3a 0%, #0b2448 55%, #041427 100%);
  border: 1px solid rgba(217, 225, 238, 0.9);
  border-radius: 8px;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06), 0 24px 60px rgba(7, 27, 58, 0.12);
}

.tl-image-placeholder::before {
  position: absolute;
  inset: 18px;
  border: 1px dashed rgba(238, 245, 255, 0.36);
  border-radius: 6px;
  content: "";
}

.tl-image-placeholder span,
.tl-image-placeholder strong,
.tl-image-placeholder small {
  position: relative;
  z-index: 1;
  display: block;
}

.tl-image-placeholder span {
  color: #a6ce39;
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tl-image-placeholder strong {
  max-width: 88%;
  margin: 8px auto;
  color: #fff;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  line-height: 1.18;
  overflow-wrap: anywhere;
}

.tl-image-placeholder small {
  color: rgba(238, 245, 255, 0.72);
  font-weight: 800;
}

.tl-hero-placeholder {
  min-height: 0;
  aspect-ratio: 16 / 9;
}

.tl-square-placeholder {
  min-height: 0;
  aspect-ratio: 1;
}

.tl-product-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
  gap: 22px;
  align-items: start;
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto;
  padding-bottom: clamp(38px, 6vw, 76px);
}

.tl-product-main {
  display: grid;
  gap: 22px;
}

.tl-product-card,
.tl-order-panel-inner,
.tl-mobile-image-note {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 22px 54px rgba(7, 27, 58, 0.07);
}

.tl-product-card {
  padding: clamp(22px, 3.2vw, 34px);
}

.tl-section-kicker,
.tl-order-label {
  margin: 0 0 10px;
  color: var(--red);
  font-size: 0.78rem;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.tl-product-card h2,
.tl-mobile-image-note h2,
.tl-order-panel h2 {
  margin: 0 0 14px;
  color: var(--navy-strong);
  font-size: clamp(1.8rem, 3vw, 3.1rem);
  line-height: 1;
}

.tl-muted-copy {
  margin: 0;
  color: var(--muted);
  line-height: 1.58;
}

.tl-product-included {
  display: grid;
  grid-template-columns: minmax(240px, 0.85fr) minmax(0, 1fr);
  gap: 24px;
  align-items: center;
}

.tl-check-list {
  display: grid;
  gap: 13px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-check-list li {
  position: relative;
  padding-left: 30px;
  color: var(--navy-strong);
  font-weight: 800;
  line-height: 1.35;
}

.tl-check-list li::before {
  position: absolute;
  left: 0;
  top: 0.1em;
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  color: var(--navy-strong);
  background: #a6ce39;
  border-radius: 999px;
  content: "✓";
  font-size: 0.82rem;
  font-weight: 950;
}

.tl-addon-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 22px;
}

.tl-addon-card {
  display: grid;
  gap: 12px;
  padding: 12px;
  background: linear-gradient(180deg, #ffffff, #f8fafd);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.tl-addon-card .tl-image-placeholder {
  min-height: 152px;
  aspect-ratio: 4 / 3;
  padding: 16px;
  box-shadow: none;
}

.tl-addon-card h3 {
  margin: 0;
  color: var(--navy-strong);
  font-size: 1.08rem;
  line-height: 1.14;
}

.tl-addon-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.93rem;
  line-height: 1.4;
}

.tl-addon-card button {
  min-height: 40px;
  color: var(--navy-strong);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 7px;
  cursor: pointer;
  font-weight: 900;
}

.tl-addon-featured {
  background: linear-gradient(180deg, #f9fbf4, #ffffff);
  border-color: rgba(166, 206, 57, 0.5);
}

.tl-proof-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0;
}

.tl-proof-grid .tl-image-placeholder {
  min-height: 210px;
  aspect-ratio: 16 / 10;
}

.tl-process-steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.tl-process-steps article {
  padding: 18px;
  background: #f8fafd;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.tl-process-steps span {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  margin-bottom: 12px;
  color: var(--navy-strong);
  background: #a6ce39;
  border-radius: 999px;
  font-weight: 950;
}

.tl-process-steps strong {
  display: block;
  margin-bottom: 6px;
  color: var(--navy-strong);
  line-height: 1.15;
}

.tl-process-steps p {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.4;
}

.tl-order-panel {
  position: sticky;
  top: 86px;
}

.tl-order-panel-inner {
  padding: 24px;
}

.tl-price-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin: 18px 0;
  padding: 18px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.tl-price-row span {
  color: var(--muted);
  font-weight: 800;
}

.tl-price-row strong {
  color: var(--navy-strong);
  font-size: 2rem;
  line-height: 1;
}

.tl-summary-lines {
  display: grid;
  gap: 10px;
  margin: 20px 0;
}

.tl-summary-lines span {
  padding: 10px 12px;
  color: var(--navy-strong);
  background: #f5f7fb;
  border: 1px solid var(--line);
  border-radius: 7px;
  font-weight: 800;
}

.tl-full-width {
  width: 100%;
}

.tl-safe-note {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.45;
}

.tl-mobile-image-note {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 360px);
  gap: 22px;
  align-items: center;
  width: min(1240px, calc(100% - 40px));
  margin: 0 auto clamp(44px, 7vw, 84px);
  padding: clamp(22px, 3.2vw, 34px);
}

.tl-mobile-placeholder {
  min-height: 320px;
  aspect-ratio: 4 / 5;
}

body[data-page="product"] {
  background: #f5f7fb;
}

.tl-commerce-page {
  color: #071b3a;
  background: #fff;
}

.tl-commerce-shell {
  display: grid;
  grid-template-columns: minmax(460px, 0.98fr) minmax(520px, 0.92fr);
  gap: clamp(26px, 3.8vw, 56px);
  width: min(1560px, calc(100% - 48px));
  margin: 0 auto;
  padding: clamp(26px, 4vw, 54px) 0 clamp(48px, 7vw, 86px);
}

.tl-gallery-column,
.tl-configurator {
  min-width: 0;
}

.tl-product-gallery,
.tl-feature-row,
.tl-review-row,
.tl-configurator {
  background: #fff;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.tl-product-gallery {
  padding: 0;
}

.tl-gallery-frame {
  position: relative;
  overflow: hidden;
  border-radius: 8px;
  background: #dfeaf7;
}

.tl-gallery-arrow {
  position: absolute;
  top: 50%;
  z-index: 3;
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  color: #071b3a;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(217, 225, 238, 0.8);
  border-radius: 999px;
  box-shadow: 0 12px 24px rgba(7, 27, 58, 0.12);
  cursor: pointer;
  font-size: 2.1rem;
  line-height: 1;
  transform: translateY(-50%);
}

.tl-gallery-prev {
  left: 18px;
}

.tl-gallery-next {
  right: 18px;
}

.tl-render {
  position: relative;
  min-height: 520px;
  margin: 0;
  overflow: hidden;
  background: linear-gradient(180deg, #8fd4ff 0%, #d8f1ff 45%, #4d963e 45%, #2f6f2e 100%);
}

.tl-render-image {
  display: grid;
  place-items: center;
  background: #fff;
}

.tl-product-main-image {
  width: auto;
  max-width: min(92%, 620px);
  height: auto;
  max-height: 560px;
  object-fit: contain;
  object-position: center;
}

.tl-render figcaption {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

.tl-render-sky {
  position: absolute;
  inset: 0 0 45%;
  background:
    radial-gradient(circle at 18% 18%, rgba(255,255,255,.9) 0 4%, transparent 11%),
    radial-gradient(circle at 72% 15%, rgba(255,255,255,.82) 0 5%, transparent 13%),
    linear-gradient(180deg, #74caff 0%, #d7efff 100%);
}

.tl-render-field {
  position: absolute;
  inset: 45% 0 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px) 0 0 / 34px 100%,
    linear-gradient(180deg, #64aa45, #2f732f);
}

.tl-render-badge {
  position: absolute;
  top: 30px;
  left: 34px;
  z-index: 2;
  width: 112px;
  height: 112px;
  display: grid;
  place-items: center;
  padding: 18px;
  color: #071b3a;
  text-align: center;
  background: #a6ce39;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 950;
  text-transform: uppercase;
  box-shadow: 0 18px 26px rgba(7, 27, 58, 0.16);
}

.tl-render-tent {
  position: absolute;
  left: 50%;
  top: 18%;
  width: min(76%, 680px);
  height: 430px;
  transform: translateX(-50%);
  filter: drop-shadow(0 22px 28px rgba(4, 20, 39, 0.26));
}

.tl-tent-peak {
  position: absolute;
  left: 50%;
  top: 0;
  width: 78%;
  height: 210px;
  background: linear-gradient(135deg, #071b3a, #0b2b55);
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  transform: translateX(-50%);
}

.tl-tent-peak::after {
  position: absolute;
  right: 9%;
  bottom: 10%;
  width: 24%;
  height: 18%;
  background: #a6ce39;
  clip-path: polygon(28% 0, 100% 0, 74% 100%, 0 100%);
  content: "";
}

.tl-tent-peak span {
  position: absolute;
  left: 48%;
  top: 40%;
  color: #fff;
  font-size: clamp(2.4rem, 5vw, 4.4rem);
  font-style: italic;
  font-weight: 950;
  transform: translate(-50%, -50%);
}

.tl-tent-valance {
  position: absolute;
  left: 0;
  right: 0;
  top: 204px;
  height: 82px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(90deg, #071b3a, #0b2448);
  font-size: clamp(1.5rem, 3.2vw, 3rem);
  font-style: italic;
  font-weight: 950;
  letter-spacing: 0;
}

.tl-tent-valance strong {
  color: #a6ce39;
}

.tl-tent-legs::before,
.tl-tent-legs::after,
.tl-tent-legs {
  position: absolute;
  top: 285px;
  width: 7px;
  height: 200px;
  background: linear-gradient(180deg, #f6f8fb, #9ba8b8);
  border-radius: 999px;
  content: "";
}

.tl-tent-legs {
  left: 9%;
}

.tl-tent-legs::before {
  left: 280px;
}

.tl-tent-legs::after {
  right: -560px;
}

.tl-render-bag {
  position: absolute;
  left: 21%;
  bottom: 10%;
  width: 70px;
  height: 220px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(180deg, #101827, #050b13);
  border-radius: 16px;
  font-size: 1.8rem;
  font-weight: 950;
  box-shadow: 0 20px 28px rgba(4, 20, 39, 0.28);
}

.tl-render-bag::after {
  position: absolute;
  bottom: 54px;
  width: 70%;
  height: 14px;
  background: #a6ce39;
  border-radius: 999px;
  content: "";
}

.tl-thumbnail-strip {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}

.tl-thumb {
  height: 82px;
  padding: 0;
  overflow: hidden;
  background: #fff;
  border: 1px solid #dde5f1;
  border-radius: 7px;
  cursor: pointer;
}

.tl-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.tl-thumb.is-active {
  border: 2px solid #a6ce39;
}

.tl-mini-scene {
  display: block;
  width: 100%;
  height: 100%;
  background:
    linear-gradient(180deg, #a5dcff 0 42%, #68a64a 42% 100%);
  position: relative;
}

.tl-mini-scene::before {
  position: absolute;
  left: 20%;
  top: 24%;
  width: 60%;
  height: 32%;
  background: #071b3a;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  content: "";
}

.tl-mini-scene::after {
  position: absolute;
  left: 18%;
  top: 54%;
  width: 64%;
  height: 14%;
  background: #071b3a;
  border-bottom: 4px solid #a6ce39;
  content: "";
}

.tl-mini-frame {
  background:
    linear-gradient(135deg, transparent 44%, #aab5c5 45% 47%, transparent 48%),
    linear-gradient(45deg, transparent 44%, #aab5c5 45% 47%, transparent 48%),
    #f6f8fb;
}

.tl-mini-bag {
  background: #f6f8fb;
}

.tl-mini-bag::before {
  left: 36%;
  top: 12%;
  width: 28%;
  height: 74%;
  background: #071b3a;
  clip-path: none;
  border-radius: 8px;
}

.tl-mini-wall::before {
  height: 42%;
}

.tl-mini-wall::after {
  height: 28%;
}

.tl-mini-accessories::before {
  left: 18%;
  top: 18%;
  width: 18%;
  height: 66%;
  background: #071b3a;
  clip-path: none;
  border-radius: 999px;
}

.tl-mini-accessories::after {
  left: 50%;
  top: 30%;
  width: 26%;
  height: 45%;
  background: #071b3a;
  border: 0;
  border-radius: 4px;
}

.tl-feature-row,
.tl-review-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  margin-top: 18px;
  overflow: hidden;
  border: 1px solid #e3eaf4;
  border-radius: 8px;
}

.tl-feature-row article,
.tl-review-row article {
  min-height: 104px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 5px;
  padding: 16px;
  text-align: center;
  background: #fff;
}

.tl-feature-row span {
  color: #a6ce39;
  font-size: 2rem;
  line-height: 1;
}

.tl-feature-row strong,
.tl-review-row strong {
  color: #071b3a;
  font-size: 0.88rem;
  font-weight: 950;
  line-height: 1.15;
}

.tl-feature-row small,
.tl-review-row small {
  color: #66758b;
  font-size: 0.78rem;
  font-weight: 750;
  line-height: 1.25;
}

.tl-configurator {
  align-self: start;
  padding: 0;
  background: #fff;
}

.tl-product-heading {
  padding-bottom: 16px;
}

.tl-product-code {
  margin: 0 0 8px;
  color: #66758b;
  font-size: 0.9rem;
  font-weight: 800;
}

.tl-product-heading h1 {
  margin: 0;
  color: #071b3a;
  font-size: clamp(1.65rem, 2.2vw, 2.25rem);
  line-height: 1.08;
  letter-spacing: 0;
}

.tl-product-heading h1 span {
  display: block;
}

.tl-reward-note {
  display: none;
  margin-top: 18px;
  padding: 12px 14px;
  color: #314a08;
  background: #edf7d3;
  border: 1px solid rgba(166, 206, 57, 0.34);
  border-radius: 7px;
  font-size: 0.88rem;
  font-weight: 850;
}

.tl-price-block {
  display: grid;
  gap: 4px;
  margin-top: 18px;
}

.tl-price-block strong {
  color: #071b3a;
  font-size: 1.7rem;
  line-height: 1;
}

.tl-price-block span {
  color: #66758b;
  font-weight: 700;
}

.tl-pricing-card {
  margin: 4px 0 4px;
  padding: 16px;
  border: 1px solid #cfd8e6;
  border-radius: 8px;
  background: #fff;
}

.tl-pricing-card h2 {
  margin: 0 0 5px;
  color: #071b3a;
  font-size: 1rem;
}

.tl-pricing-card p {
  margin: 0 0 12px;
  color: #66758b;
  font-size: 0.9rem;
}

.tl-pricing-card table {
  width: 100%;
  border-collapse: collapse;
  overflow: hidden;
  border: 1px solid #bfcada;
  border-radius: 7px;
  font-size: 0.9rem;
}

.tl-pricing-card th {
  padding: 11px;
  color: #fff;
  background: #071b3a;
  font-size: 0.8rem;
  text-transform: uppercase;
}

.tl-pricing-card td {
  padding: 11px;
  color: #071b3a;
  text-align: center;
  border: 1px solid #d7dfeb;
}

.tl-config-section {
  padding: 18px 0;
  border-bottom: 0;
}

.tl-config-section h2 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 15px;
  color: #071b3a;
  font-size: 1.02rem;
  line-height: 1.1;
  text-transform: uppercase;
}

.tl-config-section h2 span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  color: #071b3a;
  background: #a6ce39;
  border-radius: 999px;
  font-size: 0.88rem;
  font-weight: 950;
}

.tl-config-section h2 em {
  color: #66758b;
  font-size: 0.86rem;
  font-style: normal;
  font-weight: 850;
}

.tl-field-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.tl-field-grid-four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.tl-field-grid label,
.tl-radio-field {
  display: grid;
  gap: 7px;
  min-width: 0;
  margin: 0;
  color: #071b3a;
  font-size: 0.86rem;
  font-weight: 850;
}

.tl-field-grid select,
.tl-field-grid input[type="date"],
.tl-quantity-control {
  width: 100%;
  min-height: 46px;
  color: #071b3a;
  background: #fff;
  border: 1px solid #cfd8e6;
  border-radius: 7px;
  box-shadow: 0 8px 18px rgba(7, 27, 58, 0.03);
}

.tl-field-grid select,
.tl-field-grid input[type="date"] {
  padding: 0 12px;
}

.tl-field-grid select:focus,
.tl-field-grid input:focus {
  border-color: #a6ce39;
  outline: 3px solid rgba(166, 206, 57, 0.16);
}

.tl-form-note {
  margin: 10px 0 0;
  color: #66758b;
  font-size: 0.83rem;
  line-height: 1.45;
}

.tl-radio-field {
  padding: 0;
  border: 0;
}

.tl-radio-field legend {
  margin-bottom: 7px;
}

.tl-radio-field label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  color: #334155;
  font-weight: 750;
}

.tl-radio-field input {
  width: 18px;
  height: 18px;
  accent-color: #a6ce39;
}

.tl-quantity-control {
  display: grid;
  grid-template-columns: 42px 1fr 42px;
  overflow: hidden;
}

.tl-quantity-control button,
.tl-quantity-control input {
  min-width: 0;
  color: #071b3a;
  background: #fff;
  border: 0;
  text-align: center;
  font-weight: 900;
}

.tl-quantity-control button {
  cursor: pointer;
  font-size: 1.25rem;
}

.tl-sticky-actions {
  position: static;
  z-index: 10;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin: 0 -6px -6px;
  padding: 18px 6px 6px;
  background: #fff;
}

.tl-sticky-actions button,
.tl-mobile-buybar button {
  min-height: 58px;
  border: 0;
  border-radius: 7px;
  cursor: pointer;
  font-weight: 950;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.tl-sticky-actions button:hover,
.tl-sticky-actions button:focus-visible,
.tl-mobile-buybar button:hover,
.tl-mobile-buybar button:focus-visible {
  transform: translateY(-2px);
  outline: 0;
}

.tl-add-cart,
.tl-mobile-buybar button {
  color: #071b3a;
  background: #a6ce39;
  box-shadow: 0 16px 28px rgba(166, 206, 57, 0.22);
}

.tl-choose-files {
  color: #fff;
  background: #071b3a;
  box-shadow: 0 16px 28px rgba(7, 27, 58, 0.16);
}

.tl-sticky-actions p {
  grid-column: 1 / -1;
  margin: 0;
  color: #66758b;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 750;
}

.tl-mobile-buybar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 90;
  display: none;
  grid-template-columns: 1fr 1.2fr;
  gap: 12px;
  align-items: center;
  padding: 12px 14px max(12px, env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.96);
  border-top: 1px solid #dde5f1;
  box-shadow: 0 -18px 36px rgba(7, 27, 58, 0.12);
  backdrop-filter: blur(18px);
}

.tl-mobile-buybar strong,
.tl-mobile-buybar span {
  display: block;
}

.tl-mobile-buybar strong {
  color: #071b3a;
  font-size: 1.25rem;
}

.tl-mobile-buybar span {
  color: #66758b;
  font-size: 0.78rem;
  font-weight: 800;
}

/* Final approved Tent Launch hero artwork. The supplied image already contains the
   headline, CTA, booth art, feature callouts, and icons, so the generated slide
   elements are hidden underneath this full-slide artwork. */
.tl-home-hero {
  position: relative;
  min-height: clamp(470px, 40vw, 690px);
  display: grid;
  align-items: center;
  overflow: hidden;
  color: #071b3a;
  background: #fff;
  border-bottom: 0;
}

.tl-home-hero::before {
  content: "";
  position: absolute;
  inset: 0 0 0 auto;
  z-index: 0;
  width: 66%;
  background: url("assets/Alternate%20header%20shave%20ice.png") right center / 92% auto no-repeat;
}

.tl-home-hero::after {
  content: none;
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(90deg, #fff 0%, #fff 28%, rgba(255, 255, 255, 0.92) 40%, rgba(255, 255, 255, 0.42) 53%, rgba(255, 255, 255, 0.02) 66%),
    linear-gradient(180deg, rgba(7, 27, 58, 0.03) 0%, rgba(7, 27, 58, 0) 54%, rgba(7, 27, 58, 0.04) 100%);
}

.tl-home-hero-copy {
  position: relative;
  z-index: 2;
  width: min(760px, 45vw);
  margin-left: clamp(42px, 5vw, 88px);
  transform: translateY(-6%);
}

.tl-home-hero-kicker {
  display: block;
  margin: 0 0 clamp(8px, 0.9vw, 14px);
  color: #8eb928;
  font-size: clamp(0.78rem, 0.88vw, 1.02rem);
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-shadow: none;
}

.tl-home-hero-copy h1 {
  position: relative;
  margin: 0;
  color: #071b3a;
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(3.7rem, 5.9vw, 7.7rem);
  line-height: 0.82;
  font-weight: 950;
  letter-spacing: -0.045em;
  text-shadow: none;
}

.tl-home-hero-copy h1 span,
.tl-home-hero-copy h1 strong,
.tl-home-hero-copy h1 em {
  display: block;
}

.tl-home-hero-copy h1 strong {
  position: relative;
  width: max-content;
  color: #85bd05;
  font-style: normal;
}

.tl-home-hero-copy h1 strong::after {
  content: "";
  position: absolute;
  left: 62%;
  bottom: 0.08em;
  width: 1.45em;
  height: 0.95em;
  background: url("assets/Mini%20rocket%20icon.png") center / contain no-repeat;
  transform: translate(16%, -58%) rotate(18deg);
}

.tl-home-hero-copy h1 em {
  color: #071b3a;
  font-style: italic;
}

.tl-home-hero-copy h1::after {
  content: "";
  position: absolute;
  left: 32%;
  top: 1.12em;
  width: min(310px, 42%);
  height: 66px;
  border-bottom: 7px solid #85bd05;
  border-radius: 0 0 100% 100%;
  transform: rotate(-11deg);
  opacity: 0.95;
}

.tl-home-hero-copy p {
  margin: clamp(22px, 2vw, 34px) 0 0;
  color: #344155;
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(1.18rem, 1.34vw, 1.62rem);
  line-height: 1.35;
  font-weight: 650;
  letter-spacing: -0.01em;
  text-shadow: none;
}

.tl-home-hero-copy p strong {
  color: #85bd05;
  font-style: italic;
  font-weight: 950;
}

.tl-home-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 22px;
  margin-top: clamp(26px, 2.6vw, 46px);
}

.tl-home-hero-actions a {
  min-width: 240px;
  min-height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 24px;
  color: #071b3a;
  border: 3px solid #071b3a;
  text-decoration: none;
  font-size: clamp(0.88rem, 0.9vw, 1.06rem);
  font-weight: 950;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.tl-home-hero-actions a:hover,
.tl-home-hero-actions a:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(4, 20, 39, 0.18);
  outline: 0;
}

.tl-home-hero-primary {
  background: #a6ce39;
  border-color: #a6ce39 !important;
  box-shadow: 0 14px 24px rgba(166, 206, 57, 0.28);
}

.tl-home-hero-primary::after {
  content: "→";
  margin-left: 14px;
  font-size: 1.35em;
  line-height: 0;
}

.tl-home-hero-secondary {
  color: #071b3a !important;
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(7, 27, 58, 0.82) !important;
  text-shadow: none;
}

.tl-home-hero-badges {
  position: absolute;
  left: clamp(40px, 5.3vw, 108px);
  bottom: clamp(14px, 1.8vw, 28px);
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(4, minmax(118px, 1fr));
  gap: clamp(18px, 2.6vw, 52px);
  width: min(800px, 44vw);
}

.tl-home-hero-badges span {
  display: grid;
  justify-items: center;
  gap: 4px;
  color: #071b3a;
  text-align: center;
  text-shadow: none;
  text-transform: uppercase;
}

.tl-home-hero-badges svg {
  width: clamp(38px, 3vw, 56px);
  height: clamp(38px, 3vw, 56px);
  margin-bottom: 4px;
  fill: none;
  color: #a6ce39;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
  filter: none;
}

.tl-home-hero-badges strong {
  font-size: clamp(0.78rem, 0.88vw, 1.05rem);
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.02em;
}

.tl-home-hero-badges small {
  max-width: 150px;
  color: rgba(255, 255, 255, 0.94);
  font-size: clamp(0.58rem, 0.66vw, 0.78rem);
  line-height: 1.15;
  font-weight: 900;
}

.tl-home-reviews {
  color: #071b3a;
  background: #fff;
  border-bottom: 1px solid rgba(217, 225, 238, 0.88);
}

.tl-all-tents-showcase {
  background: #fff;
  padding: clamp(18px, 2.8vw, 38px) clamp(16px, 3vw, 42px) clamp(8px, 1.6vw, 20px);
}

.tl-all-tents-showcase img {
  width: min(100%, 1500px);
  height: auto;
  display: block;
  margin: 0 auto;
}

.tl-home-reviews-inner {
  width: min(100%, 1850px);
  margin: 0 auto;
  padding: clamp(26px, 3vw, 46px) clamp(18px, 3.8vw, 74px) clamp(24px, 2.5vw, 40px);
}

.tl-home-reviews-stars {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
  margin: 0 0 14px;
}

.tl-home-reviews-stars > span:not(.tl-review-stars) {
  width: 52px;
  height: 1px;
  background: #cfd7e4;
}

.tl-review-stars {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  color: #98c60d;
  font-size: clamp(1.18rem, 1.55vw, 1.58rem);
  line-height: 1;
  letter-spacing: 0;
}

.tl-home-reviews h2 {
  margin: 0;
  color: #071b3a;
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(1.92rem, 3.35vw, 3.36rem);
  line-height: 0.98;
  font-weight: 950;
  text-align: center;
  text-transform: uppercase;
}

.tl-home-reviews-subtitle {
  margin: 13px auto 0;
  max-width: 980px;
  color: #4f5b70;
  font-size: clamp(0.98rem, 1.18vw, 1.18rem);
  line-height: 1.35;
  font-weight: 520;
  text-align: center;
}

.tl-home-reviews-subtitle + .tl-home-review-grid {
  margin-top: 24px;
}

.tl-home-rating {
  display: grid;
  grid-template-columns: auto auto;
  justify-content: center;
  align-items: center;
  column-gap: 18px;
  row-gap: 4px;
  margin: 18px 0 24px;
}

.tl-home-rating strong {
  color: #071b3a;
  font-size: clamp(1.9rem, 2.65vw, 2.7rem);
  line-height: 1;
  font-weight: 950;
}

.tl-home-rating .tl-review-stars {
  font-size: clamp(1.52rem, 2vw, 2.12rem);
  gap: 8px;
}

.tl-home-rating small {
  grid-column: 1 / -1;
  color: #4f5b70;
  font-size: clamp(0.88rem, 1vw, 1rem);
  line-height: 1.25;
  font-weight: 540;
  text-align: center;
}

.tl-home-review-grid {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: clamp(245px, 22vw, 330px);
  grid-template-columns: none;
  gap: clamp(12px, 1.25vw, 22px);
  overflow-x: auto;
  overscroll-behavior-inline: contain;
  padding-bottom: 12px;
  scroll-padding-inline: clamp(18px, 3.8vw, 74px);
  scroll-snap-type: x proximity;
  scrollbar-width: thin;
  scrollbar-color: #98c60d #eef3f8;
}

.tl-home-review-grid::-webkit-scrollbar {
  height: 10px;
}

.tl-home-review-grid::-webkit-scrollbar-track {
  background: #eef3f8;
  border-radius: 999px;
}

.tl-home-review-grid::-webkit-scrollbar-thumb {
  background: #98c60d;
  border-radius: 999px;
}

.tl-home-review-grid:focus-visible {
  outline: 3px solid rgba(152, 198, 13, 0.32);
  outline-offset: 6px;
}

.tl-home-review-grid article {
  min-height: 238px;
  display: flex;
  flex-direction: column;
  scroll-snap-align: start;
  padding: clamp(18px, 1.35vw, 24px) clamp(18px, 1.45vw, 26px) 22px;
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 7px 15px rgba(7, 27, 58, 0.06);
}

.tl-home-review-grid .tl-review-stars {
  justify-content: flex-start;
  gap: 4px;
  margin-bottom: 14px;
  font-size: clamp(1.08rem, 1.25vw, 1.32rem);
}

.tl-home-review-grid h3 {
  margin: 0 0 10px;
  color: #071b3a;
  font-size: clamp(0.98rem, 1.1vw, 1.14rem);
  line-height: 1.1;
  font-weight: 950;
}

.tl-home-review-grid p {
  margin: 0;
  color: #071b3a;
  font-size: clamp(0.88rem, 0.98vw, 1rem);
  line-height: 1.35;
  font-weight: 500;
}

.tl-home-review-grid footer {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid #cfd7e4;
}

.tl-home-review-grid footer > span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: #fff;
  background: #98c60d;
  border-radius: 999px;
  font-size: 1rem;
  font-weight: 950;
}

.tl-home-review-grid footer strong,
.tl-home-review-grid footer small {
  display: block;
}

.tl-home-review-grid footer strong {
  color: #071b3a;
  font-size: clamp(0.88rem, 0.95vw, 0.98rem);
  line-height: 1.14;
  font-weight: 950;
}

.tl-home-review-grid footer small {
  margin-top: 3px;
  color: #4f5b70;
  font-size: clamp(0.78rem, 0.88vw, 0.88rem);
  line-height: 1.2;
  font-weight: 520;
}

.tl-home-review-benefits {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-top: clamp(22px, 2.2vw, 34px);
}

.tl-home-review-benefits > div {
  display: grid;
  grid-template-columns: 46px minmax(0, 1fr);
  align-items: center;
  gap: 16px;
  min-height: 62px;
  padding: 0 clamp(14px, 1.5vw, 24px);
  border-right: 1px solid #cfd7e4;
}

.tl-home-review-benefits > div:first-child {
  padding-left: clamp(6px, 1vw, 22px);
}

.tl-home-review-benefits > div:last-child {
  border-right: 0;
  padding-right: clamp(6px, 1vw, 22px);
}

.tl-home-review-benefits svg {
  width: 46px;
  height: 46px;
  fill: none;
  color: #071b3a;
  stroke: currentColor;
  stroke-width: 3;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tl-home-review-benefits svg path:nth-child(2) {
  stroke: #98c60d;
}

.tl-home-review-benefits strong,
.tl-home-review-benefits small {
  display: block;
}

.tl-home-review-benefits strong {
  color: #071b3a;
  font-size: clamp(0.8rem, 0.92vw, 0.98rem);
  line-height: 1.1;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-home-review-benefits small {
  margin-top: 5px;
  color: #4f5b70;
  font-size: clamp(0.76rem, 0.88vw, 0.9rem);
  line-height: 1.28;
  font-weight: 520;
}

@media (max-width: 1180px) {
  .tl-home-hero {
    min-height: 434px;
  }

  .tl-home-hero::before {
    width: 68%;
    background-size: 94% auto;
  }

  .tl-home-hero-copy {
    width: min(620px, 58vw);
    margin-left: 28px;
  }

  .tl-home-hero-badges {
    left: 24px;
    right: 24px;
    width: auto;
    gap: 14px;
  }

  .tl-home-review-benefits {
    grid-template-columns: repeat(4, minmax(220px, 1fr));
    overflow-x: auto;
    padding-bottom: 6px;
    scrollbar-width: thin;
  }

  .tl-home-review-benefits > div:nth-child(2) {
    border-right: 1px solid #cfd7e4;
  }

}

@media (max-width: 760px) {
  .tl-home-hero {
    min-height: 455px;
    align-items: start;
    padding: 24px 18px 104px;
  }

  .tl-home-hero::before {
    inset: auto 0 0;
    width: 100%;
    height: 58%;
    background-position: 68% center;
  }

  .tl-home-hero-copy {
    width: min(100%, 390px);
    margin: 0;
    transform: none;
  }

  .tl-home-hero-copy h1 {
    font-size: clamp(2.65rem, 11vw, 3.8rem);
  }

  .tl-home-hero-copy p {
    font-size: 1rem;
  }

  .tl-home-hero-actions {
    gap: 10px;
    margin-top: 20px;
  }

  .tl-home-hero-actions a {
    min-width: 0;
    min-height: 46px;
    flex: 1 1 150px;
    padding: 0 12px;
    border-width: 2px;
    font-size: 0.76rem;
  }

  .tl-home-hero-badges {
    left: 12px;
    right: 12px;
    bottom: 18px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
  }

  .tl-home-hero-badges svg {
    width: 30px;
    height: 30px;
  }

  .tl-home-hero-badges strong {
    font-size: 0.62rem;
  }

  .tl-home-hero-badges small {
    font-size: 0.48rem;
  }

  .tl-home-reviews-inner {
    padding: 22px 12px 22px;
  }

  .tl-home-reviews-stars {
    gap: 10px;
    margin-bottom: 9px;
  }

  .tl-home-reviews-stars .tl-review-stars {
    gap: 5px;
    font-size: 0.92rem;
  }

  .tl-home-reviews-stars > span:not(.tl-review-stars) {
    width: 28px;
  }

  .tl-home-reviews h2 {
    font-size: clamp(1.18rem, 5.7vw, 1.78rem);
    line-height: 1.02;
  }

  .tl-home-reviews-subtitle {
    margin-top: 8px;
    font-size: 0.78rem;
    line-height: 1.28;
  }

  .tl-home-rating {
    column-gap: 14px;
    margin: 24px 0 26px;
  }

  .tl-home-rating .tl-review-stars {
    gap: 5px;
    font-size: 1.85rem;
  }

  .tl-home-review-grid {
    grid-auto-columns: 226px;
    gap: 9px;
    margin-right: -12px;
    padding-right: 12px;
    padding-bottom: 8px;
  }

  .tl-home-review-grid article {
    min-height: 0;
    padding: 13px 13px 14px;
    border-radius: 7px;
  }

  .tl-home-review-grid .tl-review-stars {
    gap: 3px;
    margin-bottom: 8px;
    font-size: 0.9rem;
  }

  .tl-home-review-grid h3 {
    margin-bottom: 6px;
    font-size: 0.86rem;
    line-height: 1.08;
  }

  .tl-home-review-grid p {
    display: -webkit-box;
    overflow: hidden;
    font-size: 0.78rem;
    line-height: 1.28;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
  }

  .tl-home-review-grid footer {
    gap: 8px;
    margin-top: 14px;
    padding-top: 10px;
  }

  .tl-home-review-grid footer > span {
    width: 22px;
    height: 22px;
    font-size: 0.78rem;
  }

  .tl-home-review-grid footer strong {
    font-size: 0.78rem;
  }

  .tl-home-review-grid footer small {
    margin-top: 1px;
    font-size: 0.7rem;
  }

  .tl-home-review-benefits {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 14px;
    margin-right: 0;
    padding-right: 0;
    padding-bottom: 0;
    overflow-x: visible;
  }

  .tl-home-review-benefits > div,
  .tl-home-review-benefits > div:first-child,
  .tl-home-review-benefits > div:last-child {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 4px;
    min-height: 0;
    padding: 7px 4px;
    text-align: center;
    border-right: 1px solid #cfd7e4;
    border-bottom: 0;
  }

  .tl-home-review-benefits > div:last-child {
    border-right: 0;
  }

  .tl-home-review-benefits svg {
    width: 24px;
    height: 24px;
  }

  .tl-home-review-benefits strong {
    font-size: clamp(0.46rem, 1.85vw, 0.58rem);
    line-height: 1.02;
  }

  .tl-home-review-benefits small {
    margin-top: 0;
    font-size: clamp(0.44rem, 1.75vw, 0.54rem);
    line-height: 1.08;
  }

}

.tl-hero-carousel .tl-hero-viewport {
  aspect-ratio: 16 / 7.7 !important;
  min-height: 0 !important;
  max-height: none !important;
  background: #041427 !important;
}

.tl-hero-carousel .tl-hero-slide {
  position: absolute !important;
  inset: 0 !important;
  display: block !important;
  grid-template-columns: none !important;
  background: #041427 !important;
}

.tl-hero-carousel .tl-hero-slide > * {
  visibility: hidden !important;
}

.tl-hero-carousel .tl-hero-slide::before {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: block;
  background: #041427 url("assets/tent-launch-hero-header.png") center 46% / cover no-repeat;
  content: "";
}

.tl-hero-carousel .tl-hero-arrow,
.tl-hero-carousel .tl-hero-dots {
  z-index: 6 !important;
}

@media (max-width: 980px) {
  .policy-grid {
    grid-template-columns: 1fr;
  }

  .tl-commerce-shell {
    grid-template-columns: 1fr;
  }

  .tl-configurator {
    padding: 22px;
  }

  .tl-render {
    min-height: 520px;
  }

  .tl-field-grid,
  .tl-field-grid-four {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-product-hero,
  .tl-product-shell,
  .tl-mobile-image-note {
    grid-template-columns: 1fr;
  }

  .tl-order-panel {
    position: static;
  }

  .tl-addon-grid,
  .tl-process-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-about-card-grid,
  .tl-process-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-about-cta {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 720px) {
  .topbar {
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    min-height: 44px;
    align-items: center;
    flex-wrap: nowrap;
    gap: 6px;
    padding: 5px 8px;
    overflow: hidden;
  }

  .brand {
    grid-column: 2;
    flex: 0 1 auto;
    min-width: 0;
  }

  .brand-logo {
    height: clamp(21px, 6vw, 28px);
    max-width: 124px;
    object-fit: contain;
  }

  .nav {
    grid-column: 1;
    order: 0;
    flex: 0 1 auto;
    width: auto;
    min-width: 0;
    justify-content: flex-start;
    gap: 7px;
    font-size: 0.64rem;
    line-height: 1;
    white-space: nowrap;
  }

  .nav a {
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .cart-button {
    grid-column: 3;
    flex: 0 0 auto;
    gap: 4px;
    min-height: 31px;
    padding: 6px 7px;
    border-radius: 6px;
    font-size: 0.66rem;
    line-height: 1;
  }

  .cart-button strong {
    min-width: 17px;
    height: 17px;
    font-size: 0.62rem;
  }

  .tl-hero-carousel .tl-hero-viewport {
    aspect-ratio: 1906 / 825 !important;
  }

  .tl-hero-carousel .tl-hero-slide::before {
    background: #041427 url("assets/tent-launch-mobile-hero-header.png") center center / cover no-repeat !important;
  }

  .tl-hero-carousel .tl-hero-slide:nth-of-type(2)::before {
    background: #041427 url("assets/tent-launch-mobile-hero-header-2.png") center center / cover no-repeat !important;
  }

  .tl-hero-carousel .tl-hero-arrow {
    width: 42px !important;
    height: 42px !important;
  }

  .tl-hero-carousel .tl-hero-prev {
    left: 10px !important;
  }

  .tl-hero-carousel .tl-hero-next {
    right: 10px !important;
  }

  .tl-hero-carousel .tl-hero-dots {
    bottom: 10px !important;
  }

  .tl-about-section,
  .tl-about-cta,
  .tl-product-hero,
  .tl-product-shell,
  .tl-mobile-image-note {
    width: min(100% - 28px, 1180px);
  }

  .tl-commerce-shell {
    width: min(100% - 24px, 1180px);
    padding-top: 18px;
    padding-bottom: 92px;
  }

  .tl-product-gallery,
  .tl-configurator {
    border-radius: 8px;
  }

  .tl-render {
    min-height: 355px;
  }

  .tl-render-badge {
    top: 16px;
    left: 16px;
    width: 74px;
    height: 74px;
    padding: 12px;
    font-size: 0.62rem;
  }

  .tl-render-tent {
    top: 24%;
    width: 82%;
    height: 250px;
  }

  .tl-tent-peak {
    height: 118px;
  }

  .tl-tent-valance {
    top: 115px;
    height: 50px;
    font-size: 1.25rem;
  }

  .tl-tent-legs,
  .tl-tent-legs::before,
  .tl-tent-legs::after {
    top: 164px;
    height: 116px;
    width: 5px;
  }

  .tl-tent-legs::before {
    left: 160px;
  }

  .tl-tent-legs::after {
    right: -318px;
  }

  .tl-render-bag {
    left: 19%;
    bottom: 8%;
    width: 46px;
    height: 128px;
    border-radius: 10px;
    font-size: 1rem;
  }

  .tl-gallery-arrow {
    width: 40px;
    height: 40px;
  }

  .tl-thumbnail-strip {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .tl-feature-row,
  .tl-review-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-product-heading h1 {
    font-size: clamp(1.9rem, 8vw, 2.7rem);
  }

  .tl-field-grid,
  .tl-field-grid-four {
    grid-template-columns: 1fr;
  }

  .tl-sticky-actions {
    position: static;
    grid-template-columns: 1fr;
    margin: 0;
    padding: 18px 0 0;
    background: transparent;
  }

  .tl-mobile-buybar {
    display: grid;
  }

  .tl-product-hero {
    padding-top: 34px;
  }

  .tl-product-copy h1 {
    font-size: clamp(2.7rem, 13vw, 4.6rem);
  }

  .tl-hero-placeholder {
    min-height: 260px;
  }

  .tl-product-included,
  .tl-proof-grid {
    grid-template-columns: 1fr;
  }

  .tl-addon-grid,
  .tl-process-steps {
    grid-template-columns: 1fr;
  }

  .tl-about-card-grid,
  .tl-process-grid {
    grid-template-columns: 1fr;
  }

  .tl-about-card,
  .tl-process-step {
    min-height: 0;
    padding: 20px;
  }

  .tl-about-button {
    width: 100%;
  }
}

/* Tent Launch Pro 10x10 ecommerce configurator */
.tl-product-builder {
  --tlp-navy: #071b3a;
  --tlp-deep: #041427;
  --tlp-lime: #a6ce39;
  --tlp-line: #dbe4f0;
  --tlp-soft: #f5f7fb;
  --tlp-muted: #617086;
  --tlp-shadow: 0 18px 40px rgba(7, 27, 58, 0.08);
  color: var(--tlp-navy);
  background: linear-gradient(180deg, #fff 0%, #f7f9fc 100%);
  padding-bottom: 40px;
}

.tl-product-builder [hidden] {
  display: none !important;
}

.tl-builder-shell {
  display: grid;
  grid-template-columns: minmax(620px, 720px) minmax(420px, 520px);
  gap: clamp(34px, 3.2vw, 58px);
  width: min(1360px, calc(100% - 44px));
  margin: 0 auto;
  padding: 0 0 clamp(34px, 4vw, 56px);
  align-items: start;
  justify-content: space-between;
}

.tl-builder-gallery,
.tl-builder-config,
.tl-live-summary {
  min-width: 0;
}

.tl-builder-config {
  width: min(100%, 520px);
  margin-top: -66px;
  justify-self: end;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 14px;
  box-shadow: 0 18px 42px rgba(7, 27, 58, 0.07);
}

.tl-config-card-header {
  padding: 8px 18px 9px;
  color: #fff;
  background:
    radial-gradient(circle at 92% 8%, rgba(166, 206, 57, 0.16), transparent 34%),
    linear-gradient(135deg, #061832 0%, #071b3a 58%, #0a2348 100%);
}

.tl-config-card-header h2 {
  margin: 0;
  color: #fff;
  font-size: 0.94rem;
  line-height: 1.05;
  font-weight: 950;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.tl-config-card-header p {
  display: none;
}

.tl-builder-gallery {
  position: sticky;
  top: 74px;
  z-index: 7;
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 0 22px;
  width: min(100%, 700px);
  justify-self: start;
  align-items: start;
}

.tl-gallery-stage {
  position: relative;
  grid-column: 2;
  grid-row: 1;
  aspect-ratio: 1 / 1;
  width: min(100%, 560px);
  min-height: clamp(380px, 31vw, 500px);
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.tl-gallery-stage img {
  width: 100%;
  height: 100%;
  max-width: none;
  max-height: none;
  display: block;
  object-fit: contain;
  object-position: center;
}

.tl-gallery-stage.is-missing-image::before,
.tl-option-card.is-missing-image .tl-option-image-wrap::before,
.tl-static-option.is-missing-image .tl-option-image-wrap::before,
.tl-gallery-thumb.is-missing-image::before {
  content: "Tent Launch";
  display: grid;
  place-items: center;
  width: 100%;
  height: 100%;
  color: var(--tlp-navy);
  background:
    radial-gradient(circle at 70% 18%, rgba(166, 206, 57, 0.18), transparent 32%),
    linear-gradient(135deg, #fff, #eef3f8);
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.tl-gallery-control {
  position: absolute;
  top: 50%;
  z-index: 2;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  color: var(--tlp-navy);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(219, 228, 240, 0.9);
  border-radius: 999px;
  box-shadow: 0 12px 24px rgba(7, 27, 58, 0.14);
  cursor: pointer;
  font-size: 2rem;
  line-height: 1;
  transform: translateY(-50%);
}

.tl-gallery-control-prev {
  left: 16px;
}

.tl-gallery-control-next {
  right: 16px;
}

.tl-gallery-control:hover,
.tl-gallery-control:focus-visible {
  color: var(--tlp-deep);
  border-color: var(--tlp-lime);
  outline: 3px solid rgba(166, 206, 57, 0.16);
}

.tl-gallery-thumbs {
  display: grid;
  grid-column: 1;
  grid-row: 1;
  grid-auto-flow: row;
  grid-auto-rows: 74px;
  grid-template-columns: 74px;
  gap: 12px;
  max-height: calc((74px * 5) + (12px * 4));
  margin-top: 46px;
  padding-right: 0;
  overflow-y: auto;
  overscroll-behavior-block: contain;
  scroll-snap-type: y proximity;
  scrollbar-width: none;
}

.tl-gallery-thumb {
  width: 74px;
  min-height: 74px;
  padding: 0;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 7px;
  cursor: pointer;
  scroll-snap-align: start;
}

.tl-gallery-thumbs::-webkit-scrollbar {
  display: none;
}

.tl-gallery-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.tl-gallery-thumb.is-active {
  border-color: var(--tlp-lime);
  box-shadow: 0 0 0 2px rgba(166, 206, 57, 0.28);
}

.tl-product-feature-strip {
  grid-column: 1 / -1;
  grid-row: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin: 0 0 12px;
  overflow: hidden;
  border: 0;
  background: #fff;
}

.tl-product-feature-strip article {
  min-height: 58px;
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  justify-items: start;
  align-content: center;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: #fff;
  border-right: 0;
  text-align: left;
}

.tl-product-feature-strip article:last-child {
  border-right: 0;
}

.tl-product-feature-strip article > span {
  width: 31px;
  height: 31px;
  display: grid;
  place-items: center;
  color: var(--tlp-navy);
}

.tl-product-feature-strip svg {
  width: 25px;
  height: 25px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tl-product-feature-strip strong {
  color: var(--tlp-navy);
  max-width: 150px;
  font-size: 0.63rem;
  font-weight: 950;
  line-height: 1.14;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.tl-product-feature-strip i {
  display: none;
}

.tl-builder-heading {
  width: min(1300px, calc(100% - 48px));
  margin: 0 auto;
  padding: 10px 0 13px;
  border-bottom: 0;
}

.tl-builder-title {
  min-width: 0;
}

.tl-builder-heading h1 {
  max-width: 720px;
  margin: 0;
  color: var(--tlp-navy);
  font-size: clamp(2rem, 2.55vw, 3.15rem);
  line-height: 1.06;
  letter-spacing: 0;
}

.tl-product-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 9px;
  align-items: center;
  margin-top: 8px;
  color: #5e6470;
  font-size: 0.92rem;
  font-weight: 750;
}

.tl-product-meta-row > * + * {
  position: relative;
}

.tl-product-meta-row > * + *::before {
  content: "";
  position: absolute;
  left: -7px;
  top: 50%;
  width: 1px;
  height: 16px;
  background: #9a9ea6;
  transform: translateY(-50%);
}

.tl-product-meta-row a {
  color: #383940;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.tl-product-meta-row a:hover,
.tl-product-meta-row a:focus-visible {
  color: var(--tlp-navy);
}

.tl-review-note {
  margin: 5px 0 0;
  color: #7a8392;
  font-size: 0.72rem;
  line-height: 1.25;
  font-weight: 650;
}

.tl-live-total-pill {
  display: inline-flex;
  align-items: baseline;
  gap: 7px;
  padding: 6px 10px;
  color: #fff;
  background: rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  white-space: nowrap;
}

.tl-final-checkout-panel span {
  color: var(--tlp-muted);
  font-size: 0.68rem;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.tl-live-total-pill span {
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.7rem;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tl-live-total-pill strong {
  color: var(--tlp-lime);
  font-size: 1.08rem;
  line-height: 1;
  font-weight: 950;
}

.tl-sku-share {
  display: inline-flex;
  align-items: center;
  font-size: 0.84rem;
  white-space: nowrap;
}

.tl-trust-line {
  color: #59657a;
  font-size: 0.86rem;
  font-weight: 750;
  text-decoration: none;
  white-space: nowrap;
}

.tl-rating-stars span {
  color: #f7b500;
  font-size: 1.16rem;
  letter-spacing: 0.04em;
}

.tl-share-button {
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  padding: 0;
  color: #5f636b;
  background: transparent;
  border: 0;
  border-radius: 999px;
  cursor: pointer;
}

.tl-share-button svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tl-share-button:hover,
.tl-share-button:focus-visible {
  color: var(--tlp-navy);
  background: rgba(166, 206, 57, 0.14);
  outline: 0;
}

.tl-shipping-note {
  display: flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  max-width: 100%;
  margin-top: 8px;
  padding: 6px 10px;
  color: #766f54;
  background: linear-gradient(180deg, #fff7dc 0%, #fff1c2 100%);
  border: 1px solid rgba(194, 145, 32, 0.16);
  border-radius: 7px;
  box-shadow: none;
}

.tl-shipping-note > svg {
  width: 19px;
  height: 19px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tl-arrival-copy {
  min-width: 0;
}

.tl-arrival-topline {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-start;
  color: #766f54;
  font-size: 0.72rem;
  line-height: 1.15;
  font-weight: 650;
  white-space: nowrap;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.tl-arrival-topline::-webkit-scrollbar {
  display: none;
}

.tl-arrival-topline strong {
  color: #766f54;
  font-size: inherit;
  font-weight: 850;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.tl-arrival-date {
  color: var(--tlp-navy);
  font-size: inherit;
  line-height: inherit;
  font-weight: 950;
  letter-spacing: 0;
}

.tl-arrival-topline span {
  color: inherit;
  font-size: inherit;
  line-height: inherit;
  font-weight: inherit;
}

.tl-shipping-note > svg,
.tl-arrival-date,
.tl-arrival-topline span {
  padding-left: 8px;
  border-left: 1px solid rgba(118, 111, 84, 0.34);
}

.tl-shipping-note > svg {
  padding-left: 0;
  border-left: 0;
}

.tl-arrival-rush {
  color: #48505e !important;
}

.tl-arrival-rush strong {
  color: var(--tlp-navy);
  font-weight: 950;
}

.tl-benefit-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  margin-top: 12px;
  background: #ffffff;
  border: 0;
  border-top: 1px solid rgba(10, 30, 60, 0.1);
  border-bottom: 1px solid rgba(10, 30, 60, 0.1);
  border-radius: 0;
  overflow: hidden;
}

.tl-benefit-row article {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 5px;
  min-width: 0;
  min-height: 100%;
  padding: 8px 12px 9px;
  text-align: center;
  background: #ffffff;
  border-right: 1px solid rgba(10, 30, 60, 0.13);
}

.tl-benefit-row article:last-child {
  border-right: 0;
}

.tl-benefit-row span {
  width: 40px;
  height: 36px;
  display: grid;
  place-items: center;
  color: var(--tlp-navy);
  background: transparent;
  border: 0;
  border-radius: 0;
  font-size: 1rem;
  font-weight: 950;
}

.tl-benefit-row svg {
  width: 31px;
  height: 31px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tl-benefit-row strong {
  color: var(--tlp-navy);
  max-width: 150px;
  font-size: 0.66rem;
  line-height: 1.13;
  font-weight: 950;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.tl-benefit-row i {
  width: 26px;
  height: 2px;
  display: block;
  background: var(--tlp-lime);
  border-radius: 999px;
}

.tl-benefit-row p {
  margin: 0;
  color: #303746;
  max-width: 168px;
  font-size: 0.72rem;
  line-height: 1.34;
  font-weight: 650;
}

.tl-buyers-guide {
  --bg-navy: #071b3a;
  --bg-navy-2: #0a1e3c;
  --bg-lime: #a6ce39;
  color: var(--bg-navy);
  background: #f7f9fc;
}

.tl-detail-guide {
  padding: clamp(10px, 1.4vw, 18px);
  background: #07111f;
}

.tl-detail-board {
  position: relative;
  overflow: hidden;
  width: min(100%, 1760px);
  margin: 0 auto;
  padding: clamp(28px, 3vw, 48px) clamp(26px, 3vw, 44px) 22px;
  border: 1px solid rgba(166, 206, 57, 0.28);
  border-radius: 14px;
  background:
    linear-gradient(154deg, rgba(255, 255, 255, 0.055) 0 24%, transparent 24.2%),
    linear-gradient(337deg, rgba(255, 255, 255, 0.035) 0 18%, transparent 18.2%),
    radial-gradient(circle at 75% 12%, rgba(27, 80, 135, 0.62), transparent 36%),
    linear-gradient(135deg, #062047 0%, #071a38 42%, #06152e 100%);
  box-shadow: 0 26px 60px rgba(0, 0, 0, 0.34);
}

.tl-detail-hero {
  position: relative;
  z-index: 1;
  min-height: 0;
  margin-bottom: clamp(16px, 2vw, 28px);
}

.tl-detail-logo {
  display: block;
  width: clamp(210px, 22vw, 340px);
  height: auto;
  margin-bottom: 28px;
  object-fit: contain;
  filter: drop-shadow(0 12px 18px rgba(0, 0, 0, 0.34));
}

.tl-detail-copy {
  position: relative;
  z-index: 2;
  max-width: 940px;
}

.tl-detail-copy h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(2.15rem, 4.15vw, 4.5rem);
  line-height: 0.96;
  letter-spacing: 0;
  text-transform: uppercase;
}

.tl-detail-copy h1 span,
.tl-detail-copy h1 strong {
  display: block;
  font-weight: 950;
  text-shadow: 0 10px 22px rgba(0, 0, 0, 0.32);
}

.tl-detail-copy h1 strong {
  color: var(--bg-lime);
}

.tl-detail-copy p {
  margin: 16px 0 0;
  color: #fff;
  font-size: clamp(1rem, 1.32vw, 1.42rem);
  line-height: 1.25;
  font-weight: 850;
}

.tl-detail-tent {
  position: absolute;
  right: clamp(-32px, -1.4vw, -12px);
  top: -26px;
  width: min(52vw, 760px);
  max-height: 360px;
  object-fit: contain;
  object-position: right top;
  filter: drop-shadow(0 25px 28px rgba(0, 0, 0, 0.4));
}

.tl-detail-table {
  position: relative;
  z-index: 2;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(230px, 0.72fr) minmax(520px, 1.5fr) minmax(0, 1.5fr);
  border: 1px solid rgba(255, 255, 255, 0.9);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 22px 48px rgba(0, 0, 0, 0.28);
}

.tl-detail-row {
  display: contents;
}

.tl-detail-row > div {
  min-width: 0;
  min-height: 88px;
  padding: 10px 14px;
  border-right: 1px solid #dce3ec;
  border-bottom: 1px solid #dce3ec;
  background: #fff;
}

.tl-detail-row > div:last-child {
  border-right: 0;
}

.tl-detail-row:last-of-type > div {
  border-bottom: 0;
}

.tl-detail-fabric-row > div {
  min-height: 82px;
}

.tl-detail-fabric-row .tl-detail-options article {
  grid-template-columns: 78px minmax(0, 1fr);
  max-width: 530px;
}

.tl-detail-fabric-row .tl-detail-choice {
  grid-template-columns: 64px 28px minmax(0, 1fr);
}

.tl-detail-fabric-row .tl-detail-feature h2,
.tl-detail-fabric-row .tl-detail-options h3,
.tl-detail-fabric-row .tl-detail-choice h3 {
  letter-spacing: 0;
}

.tl-detail-valance-row > div {
  min-height: 82px;
}

.tl-detail-valance-row .tl-detail-options article {
  grid-template-columns: 78px minmax(0, 1fr);
  max-width: 520px;
}

.tl-detail-valance-row .tl-detail-choice {
  grid-template-columns: 64px 28px minmax(0, 1fr);
}

.tl-detail-valance-row .tl-detail-feature h2,
.tl-detail-valance-row .tl-detail-options h3,
.tl-detail-valance-row .tl-detail-choice h3 {
  letter-spacing: 0;
}

.tl-detail-use-row > div {
  min-height: 82px;
}

.tl-detail-use-row .tl-detail-options {
  gap: 16px;
}

.tl-detail-use-row .tl-detail-options article {
  grid-template-columns: 74px minmax(0, 1fr);
}

.tl-detail-use-row .tl-detail-choice {
  grid-template-columns: 28px minmax(0, 1fr);
  align-content: center;
}

.tl-detail-use-row .tl-detail-feature h2,
.tl-detail-use-row .tl-detail-options h3,
.tl-detail-use-row .tl-detail-choice h3 {
  letter-spacing: 0;
}

.tl-detail-print-row > div {
  min-height: 82px;
}

.tl-detail-print-row .tl-detail-options {
  gap: 16px;
}

.tl-detail-print-row .tl-detail-options article {
  grid-template-columns: 76px minmax(0, 1fr);
}

.tl-detail-print-row .tl-detail-choice {
  grid-template-columns: 64px 28px minmax(0, 1fr);
}

.tl-detail-print-row .tl-detail-feature h2,
.tl-detail-print-row .tl-detail-options h3,
.tl-detail-print-row .tl-detail-choice h3 {
  letter-spacing: 0;
}

.tl-detail-bag-row > div {
  min-height: 82px;
}

.tl-detail-bag-row .tl-detail-options {
  gap: 16px;
}

.tl-detail-bag-row .tl-detail-options article {
  grid-template-columns: 74px minmax(0, 1fr);
}

.tl-detail-bag-row .tl-detail-choice {
  grid-template-columns: 64px 28px minmax(0, 1fr);
}

.tl-detail-bag-row .tl-detail-feature h2,
.tl-detail-bag-row .tl-detail-options h3,
.tl-detail-bag-row .tl-detail-choice h3 {
  letter-spacing: 0;
}

.tl-detail-head > div {
  min-height: 35px;
  display: grid;
  place-items: center;
  padding: 7px 12px;
  color: #fff;
  border-bottom: 0;
  background: linear-gradient(180deg, #102d55, #071b3a);
  font-size: clamp(0.72rem, 0.78vw, 0.9rem);
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.02em;
  text-align: center;
  text-transform: uppercase;
}

.tl-detail-head > div:last-child {
  color: #071b3a;
  background: linear-gradient(180deg, #a9d522, #90bf13);
}

.tl-detail-feature,
.tl-detail-options,
.tl-detail-choice,
.tl-detail-options article {
  display: grid;
  align-items: center;
}

.tl-detail-feature {
  grid-template-columns: 1fr;
  gap: 0;
}

.tl-detail-options {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
}

.tl-detail-options article {
  grid-template-columns: 1fr;
  gap: 0;
}

.tl-detail-options article:only-child {
  grid-column: 1 / -1;
  grid-template-columns: minmax(0, 1fr);
  max-width: 500px;
}

.tl-detail-choice {
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px;
  overflow: hidden;
}

.tl-detail-choice > div,
.tl-detail-feature > div,
.tl-detail-options article > div {
  min-width: 0;
}

.tl-detail-choice i {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  color: #fff;
  border-radius: 999px;
  background: #98c61c;
  font-size: 0.95rem;
  font-style: normal;
  font-weight: 950;
  box-shadow: 0 10px 18px rgba(166, 206, 57, 0.22);
}

.tl-detail-feature h2,
.tl-detail-options h3,
.tl-detail-choice h3 {
  margin: 0;
  color: #071b3a;
  font-size: clamp(0.9rem, 0.94vw, 1.08rem);
  line-height: 1.02;
  font-weight: 950;
  letter-spacing: 0.01em;
  text-transform: uppercase;
}

.tl-detail-choice h3 {
  max-width: 100%;
  font-size: clamp(0.92rem, 0.94vw, 1.08rem);
  overflow-wrap: anywhere;
  word-break: normal;
}

.tl-detail-choice small {
  display: block;
  max-width: 100%;
  color: #9ac51c;
  font-size: 0.72rem;
  line-height: 1;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-detail-feature p,
.tl-detail-options p,
.tl-detail-choice p {
  max-width: 100%;
  margin: 4px 0 0;
  color: #111827;
  font-size: clamp(0.64rem, 0.68vw, 0.78rem);
  line-height: 1.18;
  font-weight: 800;
  overflow-wrap: anywhere;
  word-break: normal;
}

.tl-detail-feature p {
  color: #17253c;
}

.tl-detail-icon,
.tl-detail-photo {
  display: grid;
  place-items: center;
  overflow: hidden;
  flex: 0 0 auto;
}

.tl-detail-icon {
  width: 62px;
  height: 62px;
  color: #071b3a;
}

.tl-detail-photo {
  width: 66px;
  height: 66px;
  border-radius: 999px;
  border: 1px solid rgba(7, 27, 58, 0.12);
  background:
    radial-gradient(circle at 35% 25%, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.08) 44%, transparent 45%),
    linear-gradient(135deg, #eef2f6, #ffffff);
  box-shadow: inset 0 0 0 5px rgba(255, 255, 255, 0.7);
}

img.tl-detail-photo {
  display: block;
  object-fit: cover;
  object-position: center;
  padding: 0;
}

.tl-icon-frame::before {
  content: "";
  width: 50px;
  height: 50px;
  clip-path: polygon(25% 5%, 75% 5%, 100% 50%, 75% 95%, 25% 95%, 0 50%);
  border: 5px solid #071b3a;
  background: linear-gradient(135deg, transparent 38%, #a6ce39 39% 52%, transparent 53%);
  box-shadow: inset 0 0 0 5px #fff;
}

.tl-icon-fabric::before {
  content: "";
  width: 48px;
  height: 48px;
  background:
    repeating-linear-gradient(90deg, transparent 0 7px, #071b3a 7px 9px, transparent 9px 14px),
    repeating-linear-gradient(0deg, transparent 0 7px, #071b3a 7px 9px, transparent 9px 14px),
    linear-gradient(90deg, transparent 0 18%, #a6ce39 18% 23%, transparent 23% 48%, #a6ce39 48% 53%, transparent 53% 78%, #a6ce39 78% 83%, transparent 83%),
    linear-gradient(0deg, transparent 0 18%, #a6ce39 18% 23%, transparent 23% 48%, #a6ce39 48% 53%, transparent 53% 78%, #a6ce39 78% 83%, transparent 83%);
  border-radius: 3px;
}

.tl-icon-valance::before {
  content: "";
  width: 58px;
  height: 46px;
  border: 3px solid #071b3a;
  border-top: 0;
  background:
    linear-gradient(90deg, transparent 19%, #a6ce39 20% 23%, transparent 24% 77%, #a6ce39 78% 81%, transparent 82%),
    linear-gradient(#071b3a, #071b3a) top / 100% 3px no-repeat,
    linear-gradient(90deg, transparent 0 18%, #071b3a 18% 22%, transparent 22% 78%, #071b3a 78% 82%, transparent 82%);
  clip-path: polygon(50% 0, 100% 34%, 100% 100%, 0 100%, 0 34%);
  box-shadow: inset 0 -10px 0 rgba(166, 206, 57, 0.12);
}

.tl-icon-use::before {
  content: "☆";
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  color: #a6ce39;
  border: 3px solid #071b3a;
  border-radius: 6px;
  font-size: 2.05rem;
  box-shadow:
    inset 0 13px 0 rgba(7, 27, 58, 0.08),
    0 -8px 0 -5px #071b3a;
}

.tl-icon-print::before {
  content: "";
  width: 54px;
  height: 54px;
  background:
    radial-gradient(circle at 28% 24%, #009fe3 0 9px, transparent 10px),
    radial-gradient(circle at 72% 24%, #05070a 0 9px, transparent 10px),
    radial-gradient(circle at 28% 76%, #ec167b 0 9px, transparent 10px),
    radial-gradient(circle at 72% 76%, #a6ce39 0 9px, transparent 10px);
}

.tl-icon-bag::before {
  content: "";
  width: 54px;
  height: 54px;
  border-radius: 0;
  background:
    linear-gradient(#071b3a, #071b3a) 20% 8% / 3px 85% no-repeat,
    linear-gradient(#071b3a, #071b3a) 42% 8% / 3px 85% no-repeat,
    linear-gradient(#071b3a, #071b3a) 62% 8% / 3px 85% no-repeat,
    linear-gradient(#071b3a, #071b3a) 84% 8% / 3px 85% no-repeat,
    radial-gradient(circle at 20% 94%, #071b3a 0 4px, transparent 5px),
    radial-gradient(circle at 84% 94%, #071b3a 0 4px, transparent 5px);
  border-left: 2px solid #071b3a;
  border-right: 2px solid #071b3a;
}

.tl-photo-steel::before,
.tl-photo-aluminum::before,
.tl-photo-hex::before {
  content: "";
  width: 62px;
  height: 62px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 28% 32%, #fff 0 8%, transparent 9%),
    radial-gradient(circle at 62% 30%, #fff 0 7%, transparent 8%),
    radial-gradient(circle at 38% 66%, #fff 0 9%, transparent 10%),
    radial-gradient(circle at 72% 67%, #fff 0 8%, transparent 9%),
    linear-gradient(135deg, #0e1118, #777, #111);
}

.tl-photo-aluminum::before,
.tl-photo-hex::before {
  background:
    radial-gradient(circle at 30% 32%, #fff 0 9%, transparent 10%),
    radial-gradient(circle at 66% 34%, #fff 0 8%, transparent 9%),
    radial-gradient(circle at 48% 69%, #fff 0 10%, transparent 11%),
    linear-gradient(135deg, #f7f7f7, #777, #f3f6f8);
}

.tl-photo-hex::before {
  clip-path: polygon(25% 4%, 75% 4%, 100% 50%, 75% 96%, 25% 96%, 0 50%);
  width: 38px;
  height: 52px;
  border: 7px solid #777;
  background: linear-gradient(135deg, #fafafa, #aeb5bd);
}

.tl-photo-fabric-rolls::before,
.tl-photo-adhesive::before,
.tl-photo-dye::before,
.tl-photo-tl-print::before {
  content: "";
  width: 70px;
  height: 70px;
  border-radius: 999px;
  background:
    linear-gradient(158deg, #061834 0 18%, #102d5f 18% 31%, #df252a 31% 45%, #f1b31b 45% 59%, #a6ce39 59% 73%, #061834 73% 100%);
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.68), 0 5px 12px rgba(7, 27, 58, 0.1);
}

.tl-photo-adhesive::before {
  background:
    linear-gradient(145deg, #061834 0 21%, #f6f6f6 21% 25%, #f1b31b 25% 34%, #171a21 34% 46%, #df252a 46% 54%, #101827 54% 70%, #a6ce39 70% 76%, #061834 76% 100%);
}

.tl-photo-dye::before {
  background:
    conic-gradient(from 20deg, #f0442f, #f9b21c, #a6ce39, #16a2d8, #6c47b7, #f0442f);
}

.tl-photo-600d {
  color: #fff;
  background:
    radial-gradient(circle at 34% 20%, rgba(255,255,255,.16), transparent 24%),
    repeating-linear-gradient(38deg, rgba(255,255,255,.08) 0 2px, transparent 2px 4px),
    repeating-linear-gradient(-38deg, rgba(255,255,255,.045) 0 2px, transparent 2px 5px),
    #0b0d10;
  font-size: 1.08rem;
  font-weight: 950;
  letter-spacing: 0.02em;
  box-shadow: inset 0 0 0 2px rgba(255, 255, 255, 0.12);
}

.tl-photo-valance::before {
  content: "";
  width: 64px;
  height: 48px;
  border: 2px solid #7a8795;
  background:
    linear-gradient(90deg, transparent 46%, #f6a100 47% 53%, transparent 54%),
    linear-gradient(0deg, transparent 0 46%, rgba(7, 27, 58, 0.16) 47% 53%, transparent 54%),
    linear-gradient(#eef1f5 0 26%, #fff 27% 100%);
  position: relative;
}

.tl-photo-valance::after {
  content: "";
  position: absolute;
  width: 10px;
  height: 34px;
  border-top: 6px solid #f6a100;
  border-bottom: 6px solid #f6a100;
}

.tl-photo-17,
.tl-photo-tl-print {
  color: #fff;
  background:
    linear-gradient(90deg, transparent 46%, #a6ce39 47% 53%, transparent 54%),
    linear-gradient(135deg, rgba(166, 206, 57, 0.88), transparent 35%),
    linear-gradient(145deg, #071b3a, #183963);
  font-size: 1.1rem;
  font-weight: 950;
}

.tl-photo-tl-print {
  background:
    radial-gradient(circle at 68% 42%, rgba(255, 255, 255, 0.16), transparent 28%),
    linear-gradient(145deg, rgba(236, 22, 123, 0.65), transparent 28%),
    linear-gradient(40deg, rgba(166, 206, 57, 0.78), transparent 42%),
    linear-gradient(145deg, #071b3a, #183963 58%, #061834);
  font-size: 1.14rem;
  font-style: italic;
}

.tl-photo-light::before,
.tl-photo-heavy::before {
  content: "";
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  color: #071b3a;
  border-radius: 999px;
  background:
    radial-gradient(circle at 50% 30%, transparent 0 10px, #071b3a 11px 13px, transparent 14px),
    radial-gradient(circle at 50% 30%, #f4f6f9 0 15px, transparent 16px),
    radial-gradient(ellipse at 50% 78%, transparent 0 18px, #071b3a 19px 21px, transparent 22px),
    #f4f6f9;
}

.tl-photo-heavy::before {
  content: "★";
  width: 58px;
  height: 58px;
  color: #a6ce39;
  border: 3px solid #071b3a;
  background: #f4f6f9;
  font-size: 1.45rem;
}

.tl-photo-bag::before,
.tl-photo-wheel-bag::before {
  content: "";
  width: 32px;
  height: 54px;
  border-radius: 7px;
  background:
    linear-gradient(90deg, transparent 42%, rgba(255,255,255,.18) 43% 50%, transparent 51%),
    #101827;
}

.tl-photo-bag::after,
.tl-photo-wheel-bag::after {
  content: "TL";
  position: absolute;
  color: #a6ce39;
  font-size: 0.46rem;
  font-style: italic;
  font-weight: 950;
}

.tl-photo-wheel-bag::before {
  background:
    radial-gradient(circle at 20% 100%, #a6ce39 0 4px, transparent 5px),
    radial-gradient(circle at 80% 100%, #a6ce39 0 4px, transparent 5px),
    linear-gradient(90deg, transparent 42%, rgba(255,255,255,.18) 43% 50%, transparent 51%),
    #101827;
}

.tl-detail-footer {
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: center;
  padding: 12px 10px 0;
  color: #fff;
}

.tl-detail-footer span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  color: #a6ce39;
  border: 2px solid #a6ce39;
  border-radius: 999px;
  font-size: 0.66rem;
  font-style: italic;
  font-weight: 950;
}

.tl-detail-footer p {
  margin: 0;
  color: #fff;
  font-size: clamp(0.82rem, 1vw, 1.1rem);
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: 0.24em;
  text-align: center;
  text-transform: uppercase;
}

.tl-detail-footer strong {
  color: #a6ce39;
  font-weight: 950;
}

@media (max-width: 1180px) {
  .tl-detail-table {
    grid-template-columns: minmax(180px, 0.72fr) minmax(340px, 1.38fr) minmax(0, 1.55fr);
    overflow-x: auto;
  }

  .tl-detail-row > div {
    min-width: 0;
  }
}

@media (max-width: 820px) {
  .tl-detail-guide {
    padding: 8px;
  }

  .tl-detail-board {
    padding: 24px 14px 18px;
    border-radius: 10px;
  }

  .tl-detail-hero {
    min-height: 0;
  }

  .tl-detail-tent {
    position: static;
    width: 100%;
    max-height: 210px;
    margin-top: 20px;
  }

  .tl-detail-copy h1 {
    font-size: clamp(2rem, 10vw, 3.4rem);
  }

  .tl-detail-table {
    display: block;
    overflow: visible;
    border-radius: 8px;
    background: transparent;
    box-shadow: none;
  }

  .tl-detail-head {
    display: none;
  }

  .tl-detail-row {
    display: grid;
    gap: 0;
    margin-top: 14px;
    border: 1px solid #dce3ec;
    border-radius: 10px;
    overflow: hidden;
    background: #fff;
  }

  .tl-detail-row > div {
    border-right: 0;
  }

  .tl-detail-feature,
  .tl-detail-options,
  .tl-detail-choice,
  .tl-detail-options article,
  .tl-detail-options article:only-child {
    grid-template-columns: 72px 1fr;
    max-width: none;
  }

  .tl-detail-choice {
    grid-template-columns: 72px 32px 1fr;
  }

  .tl-detail-icon,
  .tl-detail-photo {
    width: 62px;
    height: 62px;
  }

  .tl-detail-options {
    gap: 12px;
  }

  .tl-detail-footer {
    align-items: flex-start;
  }

  .tl-detail-footer p {
    letter-spacing: 0.12em;
    text-align: left;
  }
}

@media (max-width: 560px) {
  .tl-detail-logo {
    width: 210px;
    margin-bottom: 18px;
  }

  .tl-detail-feature,
  .tl-detail-options,
  .tl-detail-choice,
  .tl-detail-options article,
  .tl-detail-options article:only-child {
    grid-template-columns: 1fr;
    justify-items: start;
  }

  .tl-detail-choice {
    grid-template-columns: 62px 1fr;
  }

  .tl-detail-choice i {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    justify-self: center;
  }

  .tl-detail-choice .tl-detail-photo {
    display: none;
  }

  .tl-detail-footer p {
    font-size: 0.72rem;
  }
}

@media (max-width: 820px) {
  .tl-detail-guide {
    padding: 4px;
  }

  .tl-detail-board {
    overflow-x: auto;
    overflow-y: hidden;
    padding: 14px 10px 12px;
    border-radius: 10px;
    -webkit-overflow-scrolling: touch;
  }

  .tl-detail-board::-webkit-scrollbar {
    height: 5px;
  }

  .tl-detail-board::-webkit-scrollbar-thumb {
    background: rgba(166, 206, 57, 0.72);
    border-radius: 999px;
  }

  .tl-detail-hero {
    min-width: 780px;
    min-height: 150px;
  }

  .tl-detail-logo {
    width: 190px;
    margin-bottom: 12px;
  }

  .tl-detail-copy {
    max-width: 460px;
  }

  .tl-detail-copy h1 {
    font-size: 2rem;
    line-height: 0.94;
  }

  .tl-detail-copy p {
    margin-top: 8px;
    max-width: 390px;
    font-size: 0.9rem;
    line-height: 1.18;
  }

  .tl-detail-tent {
    position: absolute;
    right: -10px;
    top: -10px;
    width: 380px;
    max-height: 190px;
    margin: 0;
  }

  .tl-detail-table {
    display: grid;
    grid-template-columns: 170px 330px 430px;
    width: 930px;
    min-width: 930px;
    overflow: hidden;
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 14px 32px rgba(0, 0, 0, 0.25);
  }

  .tl-detail-head {
    display: contents;
  }

  .tl-detail-row {
    display: contents;
    margin: 0;
    border: 0;
    border-radius: 0;
    overflow: visible;
    background: transparent;
  }

  .tl-detail-row > div {
    min-height: 76px;
    padding: 8px 10px;
    border-right: 1px solid #dce3ec;
    border-bottom: 1px solid #dce3ec;
  }

  .tl-detail-row > div:last-child {
    border-right: 0;
  }

  .tl-detail-head > div {
    min-height: 28px;
    padding: 6px 8px;
    font-size: 0.64rem;
  }

  .tl-detail-feature {
    grid-template-columns: 46px minmax(0, 1fr);
    gap: 8px;
  }

  .tl-detail-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .tl-detail-options article,
  .tl-detail-options article:only-child,
  .tl-detail-fabric-row .tl-detail-options article,
  .tl-detail-valance-row .tl-detail-options article,
  .tl-detail-use-row .tl-detail-options article,
  .tl-detail-print-row .tl-detail-options article,
  .tl-detail-bag-row .tl-detail-options article {
    grid-template-columns: 48px minmax(0, 1fr);
    max-width: none;
    gap: 8px;
  }

  .tl-detail-choice,
  .tl-detail-fabric-row .tl-detail-choice,
  .tl-detail-valance-row .tl-detail-choice,
  .tl-detail-print-row .tl-detail-choice,
  .tl-detail-bag-row .tl-detail-choice {
    grid-template-columns: 52px 24px minmax(0, 1fr);
    gap: 8px;
  }

  .tl-detail-use-row .tl-detail-choice {
    grid-template-columns: 24px minmax(0, 1fr);
  }

  .tl-detail-icon,
  .tl-detail-photo {
    width: 44px;
    height: 44px;
  }

  .tl-detail-icon::before {
    transform: scale(0.72);
  }

  .tl-detail-photo::before {
    transform: scale(0.72);
  }

  .tl-detail-choice .tl-detail-photo {
    display: grid;
  }

  .tl-detail-choice i {
    width: 24px;
    height: 24px;
    font-size: 0.8rem;
  }

  .tl-detail-feature h2,
  .tl-detail-options h3,
  .tl-detail-choice h3 {
    font-size: 0.76rem;
    line-height: 1.02;
  }

  .tl-detail-choice small {
    font-size: 0.58rem;
  }

  .tl-detail-feature p,
  .tl-detail-options p,
  .tl-detail-choice p {
    margin-top: 3px;
    font-size: 0.56rem;
    line-height: 1.12;
    overflow-wrap: normal;
  }

  .tl-detail-footer {
    min-width: 780px;
    justify-content: center;
    padding-top: 10px;
  }

  .tl-detail-footer p {
    font-size: 0.72rem;
    letter-spacing: 0.14em;
    text-align: center;
  }
}

@media (max-width: 430px) {
  .tl-detail-hero {
    min-width: 720px;
  }

  .tl-detail-table {
    grid-template-columns: 155px 305px 395px;
    width: 855px;
    min-width: 855px;
  }

  .tl-detail-copy h1 {
    font-size: 1.82rem;
  }

  .tl-detail-tent {
    width: 350px;
  }
}

@media (max-width: 820px) {
  .tl-detail-guide {
    padding: 0;
  }

  .tl-detail-board {
    width: 100%;
    overflow: hidden;
    padding: 10px 4px 10px;
    border-radius: 0;
  }

  .tl-detail-hero {
    min-width: 0;
    min-height: 0;
    margin-bottom: 10px;
  }

  .tl-detail-logo {
    width: 156px;
    margin-bottom: 8px;
  }

  .tl-detail-copy {
    max-width: 100%;
  }

  .tl-detail-copy h1 {
    font-size: clamp(1.28rem, 5.3vw, 1.85rem);
    line-height: 0.96;
  }

  .tl-detail-copy p {
    max-width: 250px;
    margin-top: 7px;
    font-size: clamp(0.66rem, 2.4vw, 0.82rem);
    line-height: 1.18;
  }

  .tl-detail-tent {
    position: absolute;
    right: -54px;
    top: -4px;
    width: min(56vw, 260px);
    max-height: 146px;
    margin: 0;
  }

  .tl-detail-table {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr) minmax(0, 1fr);
    width: 100%;
    min-width: 0;
    overflow: hidden;
    border-radius: 7px;
    background: #fff;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.22);
  }

  .tl-detail-row,
  .tl-detail-head {
    display: contents;
  }

  .tl-detail-row > div {
    min-height: 98px;
    padding: 6px;
    border-right: 1px solid #dce3ec;
    border-bottom: 1px solid #dce3ec;
  }

  .tl-detail-head > div {
    min-height: 25px;
    padding: 5px 3px;
    font-size: 0.5rem;
    letter-spacing: 0;
  }

  .tl-detail-feature {
    grid-template-columns: 1fr;
    gap: 3px;
    justify-items: center;
    align-content: center;
    text-align: center;
  }

  .tl-detail-feature p {
    display: none;
  }

  .tl-detail-options {
    grid-template-columns: 1fr;
    align-content: center;
    gap: 5px;
  }

  .tl-detail-options article,
  .tl-detail-options article:only-child,
  .tl-detail-fabric-row .tl-detail-options article,
  .tl-detail-valance-row .tl-detail-options article,
  .tl-detail-use-row .tl-detail-options article,
  .tl-detail-print-row .tl-detail-options article,
  .tl-detail-bag-row .tl-detail-options article {
    grid-template-columns: 28px minmax(0, 1fr);
    gap: 5px;
    max-width: none;
  }

  .tl-detail-choice,
  .tl-detail-fabric-row .tl-detail-choice,
  .tl-detail-valance-row .tl-detail-choice,
  .tl-detail-use-row .tl-detail-choice,
  .tl-detail-print-row .tl-detail-choice,
  .tl-detail-bag-row .tl-detail-choice {
    grid-template-columns: 18px minmax(0, 1fr);
    align-content: center;
    gap: 5px;
  }

  .tl-detail-choice .tl-detail-photo {
    display: none;
  }

  .tl-detail-icon,
  .tl-detail-photo {
    width: 30px;
    height: 30px;
  }

  .tl-detail-icon::before,
  .tl-detail-photo::before {
    transform: scale(0.5);
  }

  .tl-detail-choice i {
    width: 18px;
    height: 18px;
    font-size: 0.64rem;
  }

  .tl-detail-feature h2,
  .tl-detail-options h3,
  .tl-detail-choice h3 {
    font-size: clamp(0.5rem, 1.75vw, 0.64rem);
    line-height: 1.04;
    letter-spacing: 0;
  }

  .tl-detail-choice small {
    font-size: clamp(0.43rem, 1.45vw, 0.52rem);
    line-height: 1;
  }

  .tl-detail-options p,
  .tl-detail-choice p {
    margin-top: 2px;
    font-size: clamp(0.43rem, 1.45vw, 0.52rem);
    line-height: 1.12;
    font-weight: 750;
    overflow-wrap: normal;
    word-break: normal;
  }

  .tl-detail-footer {
    min-width: 0;
    gap: 7px;
    padding: 8px 4px 0;
  }

  .tl-detail-footer span {
    width: 20px;
    height: 20px;
    font-size: 0.5rem;
  }

  .tl-detail-footer p {
    font-size: clamp(0.5rem, 1.8vw, 0.64rem);
    letter-spacing: 0.08em;
    text-align: center;
  }
}

@media (max-width: 380px) {
  .tl-detail-table {
    grid-template-columns: 66px minmax(0, 1fr) minmax(0, 1fr);
  }

  .tl-detail-row > div {
    padding: 5px 4px;
  }

  .tl-detail-options article,
  .tl-detail-options article:only-child,
  .tl-detail-fabric-row .tl-detail-options article,
  .tl-detail-valance-row .tl-detail-options article,
  .tl-detail-use-row .tl-detail-options article,
  .tl-detail-print-row .tl-detail-options article,
  .tl-detail-bag-row .tl-detail-options article {
    grid-template-columns: 24px minmax(0, 1fr);
  }

  .tl-detail-icon,
  .tl-detail-photo {
    width: 26px;
    height: 26px;
  }
}

.tl-bg-hero {
  display: grid;
  grid-template-columns: minmax(300px, 0.9fr) minmax(420px, 1.45fr);
  align-items: center;
  min-height: clamp(138px, 15vw, 188px);
  padding: 18px clamp(38px, 6vw, 78px);
  overflow: hidden;
  background:
    radial-gradient(circle at 28% 20%, rgba(166, 206, 57, 0.12), transparent 26%),
    linear-gradient(90deg, rgba(7, 27, 58, 1) 0%, rgba(7, 27, 58, 0.96) 42%, rgba(7, 27, 58, 0.32) 70%, rgba(7, 27, 58, 0.06) 100%),
    #071b3a;
}

.tl-bg-hero-copy {
  position: relative;
  z-index: 2;
  max-width: 430px;
}

.tl-bg-hero-copy p,
.tl-bg-section-copy p {
  margin: 0 0 8px;
  color: var(--bg-lime);
  font-size: 0.58rem;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.tl-bg-hero-copy h1 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.5rem, 2.65vw, 2.38rem);
  line-height: 0.96;
  font-weight: 950;
  letter-spacing: 0;
  white-space: nowrap;
  text-transform: uppercase;
}

.tl-bg-hero-copy span {
  display: block;
  max-width: 380px;
  margin-top: 8px;
  color: rgba(255, 255, 255, 0.9);
  font-size: clamp(0.68rem, 0.8vw, 0.82rem);
  line-height: 1.35;
  font-weight: 750;
}

.tl-bg-hero-copy div,
.tl-bg-final-cta nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.tl-bg-primary,
.tl-bg-secondary {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  border-radius: 4px;
  font-size: 0.5rem;
  font-weight: 950;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  text-decoration: none;
}

.tl-bg-primary {
  color: #071b3a;
  background: var(--bg-lime);
  box-shadow: 0 16px 30px rgba(166, 206, 57, 0.2);
}

.tl-bg-secondary {
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.7);
  background: rgba(255, 255, 255, 0.04);
}

.tl-bg-hero-media {
  position: relative;
  z-index: 1;
  margin: -20px -54px -24px -34px;
  align-self: stretch;
  display: grid;
  place-items: center end;
}

.tl-bg-hero-media img {
  width: min(100%, 560px);
  max-height: 190px;
  object-fit: contain;
  filter: drop-shadow(0 18px 26px rgba(0, 0, 0, 0.28));
}

.tl-bg-section,
.tl-bg-final-cta {
  width: min(100% - 44px, 1180px);
  margin: 18px auto 0;
  padding: clamp(22px, 3.2vw, 34px);
  border: 1px solid rgba(10, 30, 60, 0.09);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 16px 42px rgba(7, 27, 58, 0.055);
}

.tl-bg-compare {
  display: grid;
  grid-template-columns: 0.34fr 0.66fr;
  gap: clamp(24px, 4vw, 48px);
  align-items: center;
}

.tl-bg-section-copy h2,
.tl-bg-centered h2,
.tl-bg-gallery-head h2,
.tl-bg-final-cta h2 {
  margin: 0;
  color: var(--bg-navy);
  font-size: clamp(1.7rem, 3.2vw, 2.65rem);
  line-height: 1.05;
  font-weight: 950;
  letter-spacing: 0;
  text-transform: uppercase;
}

.tl-bg-section-copy span,
.tl-bg-centered p,
.tl-bg-gallery-head p,
.tl-bg-final-cta p {
  display: block;
  margin-top: 16px;
  color: #40506a;
  font-size: 0.98rem;
  line-height: 1.6;
  font-weight: 700;
}

.tl-bg-compare-board {
  display: grid;
  grid-template-columns: minmax(210px, 1fr) minmax(150px, 0.56fr) minmax(230px, 1.16fr);
  align-items: stretch;
  overflow-x: auto;
}

.tl-bg-compare-card {
  display: grid;
  grid-template-rows: 92px repeat(9, 34px);
  min-width: 220px;
  overflow: hidden;
  border: 1px solid rgba(10, 30, 60, 0.11);
  border-radius: 8px 0 0 8px;
  background: #fff;
  text-align: center;
}

.tl-bg-compare-card header {
  display: grid;
  grid-template-columns: 1fr 104px;
  align-items: center;
  gap: 8px;
  min-width: 0;
  padding: 10px 12px;
  background: #f3f4f6;
}

.tl-bg-compare-card header div {
  min-width: 0;
}

.tl-bg-compare-card strong {
  display: block;
  color: var(--bg-navy);
  font-size: 0.84rem;
  line-height: 1.12;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-bg-compare-card strong em {
  color: var(--bg-lime);
  font-style: normal;
}

.tl-bg-compare-card header span {
  display: block;
  margin-top: 4px;
  color: #40506a;
  font-size: 0.62rem;
  line-height: 1.25;
  font-weight: 800;
}

.tl-bg-compare-card img {
  width: 100%;
  max-height: 74px;
  object-fit: contain;
}

.tl-bg-compare-card p,
.tl-bg-feature-column span {
  display: grid;
  place-items: center;
  min-width: 0;
  margin: 0;
  padding: 0 10px;
  border-top: 1px solid rgba(10, 30, 60, 0.11);
  color: var(--bg-navy);
  font-size: 0.72rem;
  line-height: 1.2;
  font-weight: 850;
}

.tl-bg-budget-card p {
  color: #25334b;
  font-weight: 750;
}

.tl-bg-feature-column {
  display: grid;
  grid-template-rows: repeat(9, 34px);
  align-self: end;
  min-width: 150px;
  margin-bottom: 0;
  border-top: 1px solid rgba(10, 30, 60, 0.11);
  border-bottom: 1px solid rgba(10, 30, 60, 0.11);
  background: #fff;
}

.tl-bg-feature-column span {
  place-items: center start;
  gap: 5px;
  padding: 0 10px;
  border-top: 0;
  border-bottom: 1px solid rgba(10, 30, 60, 0.11);
  font-size: 0.68rem;
  font-weight: 950;
  text-align: left;
  white-space: nowrap;
}

.tl-bg-feature-column span:last-child {
  border-bottom: 0;
}

.tl-bg-tl-card {
  border-color: rgba(166, 206, 57, 0.95);
  border-radius: 8px;
  box-shadow: inset 0 0 0 1px rgba(166, 206, 57, 0.18);
}

.tl-bg-tl-card header {
  grid-template-columns: 108px 1fr;
  background: linear-gradient(90deg, rgba(166, 206, 57, 0.14), rgba(166, 206, 57, 0.04));
}

.tl-bg-centered {
  text-align: center;
}

.tl-bg-guide-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-top: 16px;
}

.tl-bg-guide-card {
  border: 1px solid rgba(10, 30, 60, 0.13);
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 8px 18px rgba(7, 27, 58, 0.035);
}

.tl-bg-guide-card summary {
  min-height: 100%;
  display: grid;
  gap: 7px;
  padding: 8px;
  cursor: pointer;
  list-style: none;
}

.tl-bg-guide-card summary::before {
  content: var(--guide-index);
  width: 18px;
  height: 18px;
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--bg-lime);
  border-radius: 999px;
  font-size: 0.62rem;
  line-height: 1;
  font-weight: 950;
}

.tl-bg-guide-card summary::-webkit-details-marker {
  display: none;
}

.tl-bg-guide-card img,
.tl-bg-gallery-grid img {
  width: 100%;
  aspect-ratio: 16 / 8.8;
  object-fit: contain;
  border-radius: 6px;
  background: #f4f7fb;
}

.tl-bg-guide-card strong {
  color: var(--bg-navy);
  min-height: 32px;
  font-size: 0.74rem;
  line-height: 1.18;
  font-weight: 950;
}

.tl-bg-guide-card span {
  color: #40506a;
  font-size: 0.64rem;
  line-height: 1.32;
  font-weight: 700;
}

.tl-bg-guide-card em {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 2px;
  color: var(--bg-navy);
  font-size: 0.62rem;
  font-style: normal;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-bg-guide-card em::after {
  content: "+";
  color: var(--bg-navy);
  font-size: 1.05rem;
  line-height: 1;
  font-weight: 900;
}

.tl-bg-guide-card[open] em::after {
  content: "-";
}

.tl-bg-guide-card p {
  margin: 0;
  padding: 0 10px 12px;
  color: #40506a;
  font-size: 0.68rem;
  line-height: 1.42;
  font-weight: 700;
}

.tl-bg-use-cases {
  position: relative;
  padding-top: 12px;
}

.tl-bg-use-cases .tl-bg-centered h2 {
  font-size: clamp(1.35rem, 2.25vw, 2rem);
}

.tl-bg-use-strip {
  position: relative;
  margin-top: 6px;
}

.tl-bg-use-strip > button {
  position: absolute;
  top: 50%;
  z-index: 2;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  padding: 0;
  color: var(--bg-navy);
  border: 1px solid rgba(10, 30, 60, 0.1);
  border-radius: 999px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(7, 27, 58, 0.14);
  transform: translateY(-50%);
  font-size: 1.55rem;
  line-height: 1;
  font-weight: 650;
}

.tl-bg-use-strip > button:first-child {
  left: -18px;
}

.tl-bg-use-strip > button:last-child {
  right: -18px;
}

.tl-bg-use-grid {
  display: grid;
  grid-template-columns: repeat(8, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid rgba(10, 30, 60, 0.075);
  border-radius: 9px;
  background: #fff;
}

.tl-bg-use-grid article {
  min-height: 118px;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 5px;
  padding: 12px 10px 14px;
  text-align: center;
  border-right: 1px solid rgba(10, 30, 60, 0.09);
  transition: background 0.18s ease, transform 0.18s ease;
}

.tl-bg-use-grid article:last-child {
  border-right: 0;
}

.tl-bg-use-grid article:hover {
  background: #f8fbef;
  transform: translateY(-2px);
}

.tl-bg-use-grid span {
  color: var(--bg-lime);
  font-size: 2rem;
  line-height: 1;
}

.tl-bg-use-grid h3 {
  margin: 0;
  color: var(--bg-navy);
  font-size: 0.74rem;
  line-height: 1.14;
  font-weight: 950;
}

.tl-bg-use-grid p {
  margin: 0;
  color: #40506a;
  max-width: 108px;
  font-size: 0.62rem;
  line-height: 1.3;
  font-weight: 700;
}

.tl-bg-gallery-head {
  display: grid;
  grid-template-columns: 1fr minmax(260px, 0.9fr) auto;
  gap: 14px;
  align-items: start;
}

.tl-bg-gallery-head p {
  grid-column: 2;
  max-width: 360px;
  margin: 0 auto;
  color: #40506a;
  font-size: 0.74rem;
  line-height: 1.35;
  text-align: center;
}

.tl-bg-gallery-head a {
  grid-column: 3;
  grid-row: 1;
  color: var(--bg-navy);
  border: 1px solid rgba(10, 30, 60, 0.2);
  border-radius: 6px;
  padding: 9px 18px;
  font-size: 0.66rem;
  font-weight: 950;
  text-decoration: none;
  text-transform: uppercase;
}

.tl-bg-gallery-grid,
.tl-bg-review-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.tl-bg-review-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr)) minmax(190px, 0.9fr);
  align-items: stretch;
}

.tl-bg-review-grid article {
  display: grid;
  align-content: start;
  min-height: 126px;
  padding: 16px 18px;
  border: 1px solid rgba(10, 30, 60, 0.1);
  border-radius: 8px;
  background: #fff;
}

.tl-bg-review-grid p,
.tl-bg-review-grid small,
.tl-bg-review-grid span {
  margin: 0;
}

.tl-bg-review-grid span {
  color: #f6b800;
  font-size: 0.9rem;
  letter-spacing: 0.06em;
  line-height: 1;
}

.tl-bg-review-grid p {
  margin-top: 10px;
  color: #40506a;
  font-size: 0.72rem;
  line-height: 1.38;
  font-weight: 700;
}

.tl-bg-review-grid small {
  margin-top: 10px;
  color: var(--bg-navy);
  font-size: 0.64rem;
  line-height: 1.2;
  font-weight: 950;
}

.tl-bg-review-cta {
  display: grid;
  place-items: center;
  align-content: center !important;
  text-align: center;
  color: #fff;
  background: var(--bg-navy) !important;
}

.tl-bg-review-cta p {
  max-width: 240px;
  color: #fff;
  margin-top: 0;
  font-size: 0.76rem;
}

.tl-bg-review-cta a {
  display: inline-flex;
  margin-top: 14px;
  padding: 11px 20px;
  color: var(--bg-navy);
  border-radius: 6px;
  background: var(--bg-lime);
  font-size: 0.72rem;
  font-weight: 950;
  text-transform: uppercase;
  text-decoration: none;
}

.tl-bg-faq-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px 18px;
  margin-top: 20px;
}

.tl-bg-faq-grid details {
  border: 1px solid rgba(10, 30, 60, 0.12);
  border-radius: 8px;
  background: #fff;
}

.tl-bg-faq-grid summary {
  padding: 14px 16px;
  cursor: pointer;
  color: var(--bg-navy);
  font-size: 0.86rem;
  font-weight: 900;
}

.tl-bg-faq-grid p {
  margin: 0;
  padding: 0 16px 16px;
  color: #40506a;
  font-size: 0.84rem;
  line-height: 1.5;
  font-weight: 700;
}

.tl-bg-final-cta {
  display: grid;
  grid-template-columns: 220px 1fr auto;
  gap: 24px;
  align-items: center;
  margin-bottom: 24px;
  color: #fff;
  background:
    radial-gradient(circle at 20% 10%, rgba(166, 206, 57, 0.16), transparent 24%),
    linear-gradient(135deg, #071b3a, #0a1e3c);
}

.tl-bg-final-cta img {
  width: 100%;
  max-height: 150px;
  object-fit: contain;
}

.tl-bg-final-cta h2,
.tl-bg-final-cta p {
  color: #fff;
}

@media (max-width: 1080px) {
  .tl-bg-guide-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .tl-bg-use-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .tl-bg-use-strip > button {
    display: none;
  }
}

@media (max-width: 820px) {
  .tl-bg-hero,
  .tl-bg-compare,
  .tl-bg-final-cta {
    grid-template-columns: 1fr;
  }

  .tl-bg-hero {
    min-height: 0;
    padding: 22px;
  }

  .tl-bg-hero-media {
    margin: 10px 0 0;
    place-items: center;
  }

  .tl-bg-hero-media img {
    max-height: 170px;
  }

  .tl-bg-section,
  .tl-bg-final-cta {
    width: min(100% - 24px, 1180px);
  }

  .tl-bg-gallery-head,
  .tl-bg-review-grid,
  .tl-bg-faq-grid {
    grid-template-columns: 1fr;
  }

  .tl-bg-gallery-head p,
  .tl-bg-gallery-head a {
    grid-column: auto;
    grid-row: auto;
  }

  .tl-bg-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  .tl-bg-hero-copy h1 {
    font-size: clamp(1.72rem, 8.8vw, 2.75rem);
    white-space: normal;
  }

  .tl-bg-hero-copy div,
  .tl-bg-final-cta nav {
    display: grid;
  }

  .tl-bg-primary,
  .tl-bg-secondary {
    width: 100%;
  }

  .tl-bg-guide-grid,
  .tl-bg-use-grid,
  .tl-bg-gallery-grid {
    grid-template-columns: 1fr;
  }

  .tl-bg-use-grid article {
    border-right: 0;
    border-bottom: 1px solid rgba(10, 30, 60, 0.09);
  }

  .tl-bg-use-grid article:last-child {
    border-bottom: 0;
  }
}

.tl-config-flow {
  display: grid;
  gap: 0;
  min-width: 0;
}

.tl-config-step {
  min-width: 0;
  padding: 9px 18px;
  border-top: 1px solid var(--tlp-line);
}

.tl-config-step:first-child {
  border-top: 0;
}

.tl-config-step > header {
  display: block;
  align-items: center;
  margin-bottom: 7px;
}

.tl-config-step > header > span {
  display: none;
}

.tl-config-step h2 {
  margin: 0;
  color: var(--tlp-navy);
  font-size: 0.86rem;
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tl-config-step p {
  margin: 3px 0 0;
  color: var(--tlp-muted);
  font-size: 0.78rem;
  line-height: 1.28;
  font-weight: 700;
}

.tl-option-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.tl-option-grid-three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.tl-option-card,
.tl-static-option,
.tl-artwork-card {
  position: relative;
  min-width: 0;
  display: grid;
  gap: 12px;
  padding: 12px;
  color: var(--tlp-navy);
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(7, 27, 58, 0.035);
  text-align: left;
}

.tl-option-card,
.tl-artwork-card {
  cursor: pointer;
  font: inherit;
}

.tl-option-card:hover,
.tl-option-card:focus-visible,
.tl-artwork-card:hover,
.tl-artwork-card:focus-visible {
  border-color: rgba(166, 206, 57, 0.8);
  box-shadow: 0 16px 32px rgba(7, 27, 58, 0.08);
  outline: 0;
  transform: translateY(-1px);
}

.tl-option-card.is-selected,
.tl-artwork-card.is-selected {
  border-color: var(--tlp-lime);
  box-shadow: 0 0 0 2px rgba(166, 206, 57, 0.22), 0 18px 34px rgba(7, 27, 58, 0.08);
}

.tl-option-card.is-selected::after,
.tl-artwork-card.is-selected::after {
  content: "\2713";
  position: absolute;
  top: 10px;
  right: 10px;
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  color: var(--tlp-navy);
  background: var(--tlp-lime);
  border-radius: 999px;
  font-weight: 950;
}

.tl-option-image-wrap {
  aspect-ratio: 1 / 0.72;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: linear-gradient(135deg, #fff, #f1f5fa);
  border-radius: 9px;
}

.tl-option-image-wrap img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  object-position: center;
}

.tl-option-grid-three .tl-option-card {
  align-content: start;
  padding: 12px;
}

.tl-option-grid-three .tl-option-image-wrap {
  aspect-ratio: 1 / 1;
  padding: 8px;
  background: #fff;
  border: 1px solid rgba(205, 216, 230, 0.72);
}

.tl-option-grid-three .tl-option-image-wrap img {
  object-fit: contain;
}

.tl-option-grid-three .tl-option-card.is-selected::after {
  top: 18px;
  right: auto;
  left: 18px;
}

.tl-wall-option-row {
  grid-template-columns: repeat(5, 92px);
  justify-content: start;
  gap: 7px;
  align-items: start;
}

.tl-wall-option-row .tl-option-card {
  position: relative;
  align-content: start;
  gap: 6px;
  padding: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  text-align: center;
  width: 92px;
}

.tl-wall-option-row .tl-option-card:hover,
.tl-wall-option-row .tl-option-card:focus-visible {
  box-shadow: none;
  transform: none;
}

.tl-wall-option-row .tl-option-card.is-selected {
  box-shadow: none;
}

.tl-wall-option-row .tl-option-card.is-selected::after {
  content: none;
}

.tl-wall-option-row .tl-option-image-wrap {
  width: 82px;
  justify-self: center;
  aspect-ratio: 1 / 1;
  padding: 1px;
  border: 2px solid rgba(10, 30, 60, 0.18);
  border-radius: 10px;
  background: #fff;
}

.tl-wall-option-row .tl-option-card.is-selected .tl-option-image-wrap {
  border-color: var(--tlp-lime);
  box-shadow: 0 0 0 2px rgba(166, 206, 57, 0.22);
}

.tl-wall-option-row .tl-option-image-wrap img,
.tl-addon-option-row .tl-option-image-wrap img,
.tl-static-option .tl-option-image-wrap img {
  transform: scale(1.18);
}

.tl-wall-option-row .tl-option-body {
  align-items: center;
  gap: 3px;
  grid-template-rows: auto;
}

.tl-wall-option-row .tl-option-body strong {
  color: #626262;
  min-height: 0;
  font-size: 0.66rem;
  line-height: 1.22;
  font-weight: 750;
  text-align: center;
}

.tl-wall-option-row .tl-option-body small {
  display: none;
}

.tl-wall-option-row .tl-option-body em {
  display: none;
  align-self: start;
  justify-self: center;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  color: #090909;
  border-radius: 6px;
  background: rgba(166, 206, 57, 0.14);
  font-size: 0.88rem;
  line-height: 1;
  font-weight: 950;
  text-align: center;
}

.tl-wall-option-row .tl-option-card[data-option-id="none"] .tl-option-body em {
  display: none;
}

.tl-package-option-row {
  grid-template-columns: repeat(5, minmax(72px, 92px));
  justify-content: start;
  gap: 5px;
}

.tl-package-option-row .tl-option-card {
  position: relative;
  display: flex;
  flex-direction: column;
  align-content: start;
  gap: 6px;
  min-height: 38px;
  padding: 7px 8px;
  border: 2px solid rgba(10, 30, 60, 0.16);
  border-radius: 10px;
  box-shadow: 0 12px 24px rgba(10, 30, 60, 0.05);
  background: #fff;
  text-align: left;
  overflow: hidden;
}

.tl-package-option-row .tl-option-card > * {
  pointer-events: none;
}

.tl-package-option-row .tl-option-card:hover,
.tl-package-option-row .tl-option-card:focus-visible {
  border-color: rgba(166, 206, 57, 0.7);
  box-shadow: 0 16px 30px rgba(10, 30, 60, 0.08);
  transform: translateY(-1px);
}

.tl-package-option-row .tl-option-card.is-selected {
  border-color: var(--tlp-lime);
  box-shadow: 0 18px 34px rgba(10, 30, 60, 0.1);
}

.tl-package-option-row .tl-option-card.is-selected::after {
  content: none;
}

.tl-package-option-row .tl-option-image-wrap {
  width: 72px;
  max-width: 76%;
  justify-self: center;
  align-self: center;
  aspect-ratio: 1 / 1;
  padding: 2px;
  border: 0;
  border-radius: 8px;
  background: #fff;
}

.tl-package-option-row .tl-option-card.is-selected .tl-option-image-wrap {
  box-shadow: none;
}

.tl-package-option-row .tl-option-body {
  align-items: flex-start;
  gap: 4px;
  width: 100%;
}

.tl-package-option-row .tl-option-body strong {
  min-height: 0;
  color: var(--tlp-navy);
  font-size: 0.9rem;
  line-height: 1.16;
  font-weight: 950;
  text-align: left;
}

.tl-package-option-row .tl-option-body strong .tl-package-title-pro {
  color: var(--tlp-lime);
}

.tl-package-option-row .tl-option-body small {
  display: none;
}

.tl-package-option-row .tl-option-body em {
  display: inline-flex;
  min-height: 22px;
  align-items: center;
  justify-content: center;
  padding: 0;
  color: var(--tlp-lime-dark);
  border-radius: 0;
  background: transparent;
  font-size: 0.98rem;
  line-height: 1;
  font-weight: 950;
  text-align: left;
}

.tl-package-option-row .tl-option-body ul {
  display: grid;
  gap: 3px;
  margin: 2px 0 0;
  padding: 0;
  list-style: none;
  color: #25344f;
  font-size: 0.62rem;
  line-height: 1.25;
  font-weight: 800;
}

.tl-package-option-row .tl-option-body li {
  position: relative;
  padding-left: 13px;
}

.tl-package-option-row .tl-option-body li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: -1px;
  color: var(--tlp-lime-dark);
  font-weight: 950;
}

.tl-size-option-row {
  grid-template-columns: repeat(5, minmax(68px, 88px));
}

.tl-size-option-row .tl-option-card {
  min-height: 36px;
  justify-content: center;
  padding: 6px 8px;
  text-align: center;
}

.tl-size-option-row .tl-option-body {
  align-items: center;
}

.tl-size-option-row .tl-option-body strong {
  min-height: 0;
  font-size: 0.78rem;
  line-height: 1;
}

.tl-size-option-row .tl-package-selector {
  display: none;
}

.tl-print-side-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px 12px;
  align-items: center;
  margin-top: 10px;
  padding: 8px 10px;
  background: #f7f9fc;
  border: 1px solid var(--tlp-line);
  border-radius: 9px;
}

.tl-print-side-row[hidden] {
  display: none;
}

.tl-print-side-row p {
  margin: 0;
  color: #566278;
  font-size: 0.66rem;
  line-height: 1;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tl-print-side-options {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.tl-print-side-options button {
  min-height: 31px;
  padding: 0 11px;
  color: var(--tlp-navy);
  background: #fff;
  border: 1px solid #d7dfeb;
  border-radius: 999px;
  font: inherit;
  font-size: 0.74rem;
  font-weight: 900;
  cursor: pointer;
}

.tl-print-side-options button.is-selected {
  background: var(--tlp-lime);
  border-color: var(--tlp-lime);
}

.tl-package-badge {
  position: absolute;
  top: 0;
  left: 18px;
  right: 18px;
  z-index: 1;
  display: inline-flex;
  min-height: 20px;
  align-items: center;
  justify-content: center;
  border-radius: 0 0 7px 7px;
  background: var(--tlp-lime);
  color: var(--tlp-navy);
  font-size: 0.56rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tl-option-badge {
  position: absolute;
  top: -18px;
  left: 10px;
  right: 10px;
  z-index: 1;
  display: inline-flex;
  min-height: 20px;
  align-items: center;
  justify-content: center;
  border-radius: 0 0 7px 7px;
  background: var(--tlp-lime);
  color: var(--tlp-navy);
  font-size: 0.56rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tl-wall-option-row .tl-option-badge,
.tl-addon-option-row .tl-option-badge {
  position: absolute;
  top: -20px;
  left: 50%;
  right: auto;
  transform: translateX(-50%);
  width: max-content;
  min-height: 17px;
  margin: 0;
  padding: 0 8px;
  border-radius: 999px;
  font-size: 0.48rem;
  pointer-events: none;
}

.tl-package-selector {
  position: absolute;
  left: 50%;
  bottom: 9px;
  transform: translateX(-50%);
  width: 20px;
  height: 20px;
  border: 2px solid rgba(10, 30, 60, 0.3);
  border-radius: 999px;
  background: #fff;
}

.tl-package-card.is-selected .tl-package-selector {
  display: grid;
  place-items: center;
  border-color: var(--tlp-lime);
  background: var(--tlp-lime);
  color: var(--tlp-navy);
}

.tl-package-card.is-selected .tl-package-selector::before {
  content: "✓";
  font-size: 0.78rem;
  line-height: 1;
  font-weight: 950;
}

.tl-addon-option-row {
  grid-template-columns: repeat(5, 92px);
  justify-content: start;
  gap: 7px;
  align-items: start;
}

.tl-addon-option-row .tl-option-card {
  align-content: start;
  gap: 6px;
  padding: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  text-align: center;
  width: 92px;
}

.tl-addon-option-row .tl-option-card:hover,
.tl-addon-option-row .tl-option-card:focus-visible {
  box-shadow: none;
  transform: none;
}

.tl-addon-option-row .tl-option-card.is-selected {
  box-shadow: none;
}

.tl-addon-option-row .tl-option-card.is-selected::after {
  content: none;
}

.tl-addon-option-row .tl-option-image-wrap {
  width: 82px;
  justify-self: center;
  aspect-ratio: 1 / 1;
  padding: 1px;
  border: 2px solid rgba(10, 30, 60, 0.18);
  border-radius: 10px;
  background: #fff;
}

.tl-addon-option-row .tl-option-card.is-selected .tl-option-image-wrap {
  border-color: var(--tlp-lime);
  box-shadow: 0 0 0 2px rgba(166, 206, 57, 0.22);
}

.tl-addon-option-row .tl-option-body {
  align-items: center;
  gap: 3px;
  grid-template-rows: auto;
}

.tl-addon-option-row .tl-option-body strong {
  color: #626262;
  min-height: 0;
  font-size: 0.66rem;
  line-height: 1.22;
  font-weight: 750;
  text-align: center;
}

.tl-addon-option-row .tl-option-body small {
  display: none;
}

.tl-addon-option-row .tl-option-body em {
  display: none;
  align-self: start;
  justify-self: center;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  padding: 0 10px;
  color: #090909;
  border-radius: 6px;
  background: rgba(166, 206, 57, 0.14);
  font-size: 0.88rem;
  line-height: 1;
  font-weight: 950;
  text-align: center;
}

.tl-addon-option-row .tl-option-card[data-addon-id="none"] .tl-option-body em {
  display: none;
}

.tl-option-body,
.tl-static-option > span {
  display: grid;
  gap: 5px;
}

.tl-option-body strong,
.tl-static-option strong,
.tl-artwork-card strong {
  color: var(--tlp-navy);
  font-size: 0.98rem;
  line-height: 1.14;
  font-weight: 950;
}

.tl-option-body small,
.tl-static-option small,
.tl-artwork-card small {
  color: var(--tlp-muted);
  font-size: 0.8rem;
  line-height: 1.35;
  font-weight: 700;
}

.tl-option-body em,
.tl-static-option em {
  width: max-content;
  margin-top: 3px;
  padding: 6px 8px;
  color: var(--tlp-navy);
  background: rgba(166, 206, 57, 0.14);
  border-radius: 8px;
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 950;
}

.tl-static-option {
  width: min(100%, 92px);
  align-content: start;
  gap: 6px;
  padding: 0;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  background: transparent;
  text-align: center;
}

.tl-static-option .tl-option-image-wrap {
  width: 82px;
  justify-self: center;
  aspect-ratio: 1 / 1;
  padding: 1px;
  border: 2px solid rgba(10, 30, 60, 0.18);
  border-radius: 10px;
  background: #fff;
}

.tl-static-option > span {
  justify-items: center;
  gap: 3px;
}

.tl-static-option strong {
  color: #626262;
  min-height: 0;
  font-size: 0.66rem;
  line-height: 1.22;
  font-weight: 750;
  text-align: center;
}

.tl-static-option small {
  display: none;
}

.tl-static-option em {
  display: none;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  color: #090909;
  border-radius: 6px;
  background: rgba(166, 206, 57, 0.14);
  font-size: 1rem;
  line-height: 1;
  font-weight: 950;
  text-align: center;
}

.tl-artwork-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

.tl-artwork-card {
  min-height: 112px;
}

.tl-artwork-item {
  display: grid;
  grid-template-columns: minmax(160px, 0.85fr) auto minmax(210px, 1fr);
  gap: 10px;
  align-items: center;
  min-width: 0;
  padding: 10px;
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(7, 27, 58, 0.035);
}

.tl-artwork-item strong {
  display: block;
  color: var(--tlp-navy);
  font-size: 0.94rem;
  line-height: 1.1;
  font-weight: 950;
}

.tl-artwork-item small {
  display: block;
  margin-top: 3px;
  color: var(--tlp-muted);
  font-size: 0.74rem;
  line-height: 1.25;
  font-weight: 750;
}

.tl-artwork-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.tl-artwork-actions button {
  min-height: 32px;
  padding: 0 10px;
  color: var(--tlp-navy);
  background: #f7f9fc;
  border: 1px solid #d7dfeb;
  border-radius: 999px;
  font: inherit;
  font-size: 0.72rem;
  font-weight: 950;
  cursor: pointer;
}

.tl-artwork-actions button:hover,
.tl-artwork-actions button:focus-visible {
  border-color: rgba(166, 206, 57, 0.8);
  outline: 3px solid rgba(166, 206, 57, 0.16);
}

.tl-artwork-actions button.is-selected {
  background: var(--tlp-lime);
  border-color: var(--tlp-lime);
}

.tl-artwork-upload {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 9px 10px;
  background: #f8fafc;
  border: 1px dashed #aab7c8;
  border-radius: 9px;
  cursor: pointer;
}

.tl-artwork-upload span {
  color: var(--tlp-muted);
  font-size: 0.64rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.tl-artwork-upload strong {
  overflow: hidden;
  color: var(--tlp-navy);
  font-size: 0.82rem;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tl-artwork-item input[type="file"] {
  width: 100%;
  max-width: 100%;
  color: var(--tlp-navy);
  font-size: 0.72rem;
  font-weight: 750;
  grid-column: 3;
}

.tl-artwork-panel {
  margin-top: 12px;
  padding: 14px;
  background: var(--tlp-soft);
  border: 1px solid var(--tlp-line);
  border-radius: 12px;
}

.tl-upload-box {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.tl-upload-box label {
  display: grid;
  gap: 4px;
  padding: 16px;
  background: #fff;
  border: 1px dashed #aab7c8;
  border-radius: 10px;
  cursor: pointer;
}

.tl-upload-box label strong {
  color: var(--tlp-navy);
  font-size: 0.95rem;
}

.tl-upload-box label span {
  color: var(--tlp-muted);
  font-size: 0.82rem;
  font-weight: 750;
}

.tl-upload-box input {
  width: 100%;
  color: var(--tlp-navy);
  font-weight: 750;
}

.tl-crossbar-stepper,
.tl-product-quantity {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  overflow: hidden;
  border: 1px solid var(--tlp-line);
  border-radius: 10px;
  background: #fff;
}

.tl-crossbar-stepper {
  margin-top: 8px;
}

.tl-crossbar-stepper button,
.tl-crossbar-stepper input,
.tl-product-quantity button,
.tl-product-quantity input {
  min-height: 42px;
  min-width: 0;
  color: var(--tlp-navy);
  background: #fff;
  border: 0;
  text-align: center;
  font: inherit;
  font-weight: 950;
}

.tl-crossbar-stepper button,
.tl-product-quantity button {
  cursor: pointer;
}

.tl-crossbar-stepper input,
.tl-product-quantity input {
  border-right: 1px solid var(--tlp-line);
  border-left: 1px solid var(--tlp-line);
}

.tl-product-quantity {
  width: min(100%, 280px);
}

.tl-live-summary {
  position: sticky;
  top: 88px;
  z-index: 8;
  justify-self: end;
  width: min(100%, 270px);
}

.tl-summary-card {
  padding: 14px;
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 14px;
  box-shadow: var(--tlp-shadow);
}

.tl-summary-kicker {
  margin: 0 0 7px;
  color: var(--tlp-lime);
  font-size: 0.75rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.tl-summary-card h2 {
  margin: 0 0 14px;
  color: var(--tlp-navy);
  font-size: 1.25rem;
  line-height: 1.1;
}

.tl-summary-card ul {
  display: grid;
  gap: 9px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-summary-card li {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 10px;
  padding-bottom: 9px;
  border-bottom: 1px solid #edf1f6;
}

.tl-summary-card li span,
.tl-summary-totals span {
  color: var(--tlp-muted);
  font-size: 0.78rem;
  font-weight: 850;
}

.tl-summary-card li strong,
.tl-summary-totals strong {
  color: var(--tlp-navy);
  font-size: 0.84rem;
  line-height: 1.28;
  font-weight: 900;
}

.tl-summary-totals {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--tlp-line);
}

.tl-summary-totals > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.tl-summary-totals .tl-total-row {
  padding: 12px;
  background: var(--tlp-soft);
  border-radius: 10px;
}

.tl-summary-totals .tl-total-row strong {
  font-size: 1.35rem;
}

.tl-summary-actions,
.tl-proof-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 16px;
}

.tl-primary-action,
.tl-secondary-action,
.tl-checkout-action,
.tl-product-mobile-bar button,
.tl-product-mobile-bar a {
  min-height: 50px;
  padding: 0 18px;
  border-radius: 9px;
  cursor: pointer;
  font: inherit;
  font-size: 0.86rem;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.tl-primary-action,
.tl-checkout-action,
.tl-product-mobile-bar button,
.tl-product-mobile-bar a {
  color: var(--tlp-navy);
  background: var(--tlp-lime);
  border: 1px solid var(--tlp-lime);
  box-shadow: 0 16px 30px rgba(166, 206, 57, 0.22);
}

.tl-final-cart-actions .tl-checkout-action {
  color: var(--tlp-navy);
  background: #fff;
  border-color: var(--tlp-lime);
  box-shadow: none;
}

.tl-checkout-action,
.tl-product-mobile-bar a {
  display: grid;
  place-items: center;
}

.tl-secondary-action {
  color: var(--tlp-navy);
  background: #fff;
  border: 1px solid var(--tlp-line);
}

.tl-primary-action:disabled,
.tl-product-mobile-bar button:disabled {
  cursor: default;
  color: #5b8218;
  background: rgba(166, 206, 57, 0.16);
  border-color: rgba(166, 206, 57, 0.42);
  box-shadow: none;
}

.tl-primary-action:hover,
.tl-primary-action:focus-visible,
.tl-secondary-action:hover,
.tl-secondary-action:focus-visible,
.tl-checkout-action:hover,
.tl-checkout-action:focus-visible,
.tl-product-mobile-bar button:hover,
.tl-product-mobile-bar button:focus-visible,
.tl-product-mobile-bar a:hover,
.tl-product-mobile-bar a:focus-visible {
  transform: translateY(-2px);
  outline: 3px solid rgba(166, 206, 57, 0.16);
}

.tl-primary-action:disabled:hover,
.tl-primary-action:disabled:focus-visible,
.tl-product-mobile-bar button:disabled:hover,
.tl-product-mobile-bar button:disabled:focus-visible {
  transform: none;
  outline: 0;
}

.tl-summary-card > small {
  display: block;
  margin-top: 12px;
  color: var(--tlp-muted);
  font-size: 0.74rem;
  line-height: 1.35;
  font-weight: 750;
}

.tl-final-checkout-panel {
  display: grid;
  grid-template-columns: minmax(130px, 0.36fr) minmax(0, 1fr);
  gap: 10px 16px;
  align-items: end;
  margin: 8px 18px 15px;
  padding: 13px;
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 12px;
  box-shadow: 0 16px 36px rgba(7, 27, 58, 0.08);
}

.tl-package-summary-heading {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.tl-package-summary-heading h2 {
  margin: 0;
  color: var(--tlp-navy);
  font-size: 0.96rem;
  line-height: 1.1;
  font-weight: 950;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.tl-package-summary-heading button {
  color: #49566a;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
}

.tl-package-summary-list {
  grid-column: 1 / -1;
  display: grid;
  gap: 7px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.tl-package-summary-list li {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  color: var(--tlp-navy);
  font-size: 0.83rem;
  line-height: 1.18;
}

.tl-package-summary-list li > span {
  width: 16px;
  height: 16px;
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--tlp-lime);
  border-radius: 999px;
  font-size: 0.58rem;
  line-height: 1;
  font-weight: 950;
}

.tl-package-summary-list strong {
  font-weight: 750;
}

.tl-package-summary-list em {
  color: var(--tlp-navy);
  font-style: normal;
  font-weight: 850;
}

.tl-final-checkout-panel .tl-shipping-note {
  grid-column: 1 / -1;
  width: 100%;
  margin: 0;
}

.tl-final-checkout-panel .tl-final-total {
  display: grid;
  gap: 3px;
}

.tl-final-checkout-panel .tl-final-total strong {
  color: var(--tlp-navy);
  font-size: clamp(1.58rem, 2.2vw, 2.15rem);
  line-height: 1;
  font-weight: 950;
}

.tl-final-cart-actions {
  display: grid;
  grid-template-columns: 142px minmax(0, 1fr);
  gap: 10px;
}

.tl-final-cart-actions .tl-product-quantity {
  width: 100%;
}

.tl-final-cart-actions .tl-checkout-action {
  grid-column: 1 / -1;
}

.tl-final-checkout-panel #tlActionStatus {
  grid-column: 1 / -1;
  min-height: 0;
  margin: -4px 0 0;
  text-align: right;
}

.tl-form-status {
  min-height: 19px;
  margin: 10px 0 0;
  color: var(--tlp-muted);
  font-size: 0.82rem;
  line-height: 1.35;
  font-weight: 800;
}

.tl-form-status.is-success {
  color: #5b8218;
}

.tl-form-status.is-error {
  color: #a32828;
}

.tl-product-details {
  width: min(1280px, calc(100% - 48px));
  margin: 0 auto;
  padding: 0 0 clamp(46px, 6vw, 84px);
}

.tl-detail-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 10px;
}

.tl-detail-tabs button {
  flex: 0 0 auto;
  min-height: 42px;
  padding: 0 14px;
  color: var(--tlp-navy);
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 999px;
  cursor: pointer;
  font: inherit;
  font-size: 0.86rem;
  font-weight: 900;
}

.tl-detail-tabs button.is-active {
  color: var(--tlp-navy);
  background: var(--tlp-lime);
  border-color: var(--tlp-lime);
}

.tl-detail-panel {
  padding: clamp(22px, 3vw, 34px);
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 14px;
  box-shadow: 0 14px 36px rgba(7, 27, 58, 0.05);
}

.tl-detail-panel h2 {
  margin: 0 0 12px;
  color: var(--tlp-navy);
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1.1;
}

.tl-detail-panel p,
.tl-detail-panel li,
.tl-detail-panel dd {
  color: #39485f;
  font-size: 1rem;
  line-height: 1.62;
  font-weight: 650;
}

.tl-spec-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
}

.tl-spec-grid div {
  padding: 14px;
  background: var(--tlp-soft);
  border: 1px solid var(--tlp-line);
  border-radius: 10px;
}

.tl-spec-grid dt {
  margin-bottom: 5px;
  color: var(--tlp-muted);
  font-size: 0.78rem;
  font-weight: 950;
  text-transform: uppercase;
}

.tl-spec-grid dd {
  margin: 0;
}

.tl-setup-list {
  margin: 0;
  padding-left: 1.25rem;
}

.tl-detail-panel details {
  padding: 14px 0;
  border-bottom: 1px solid var(--tlp-line);
}

.tl-detail-panel details:last-child {
  border-bottom: 0;
}

.tl-detail-panel summary {
  color: var(--tlp-navy);
  cursor: pointer;
  font-weight: 950;
}

.tl-proof-modal {
  width: min(720px, calc(100% - 28px));
  padding: 0;
  color: var(--tlp-navy);
  background: transparent;
  border: 0;
}

.tl-proof-modal::backdrop {
  background: rgba(4, 20, 39, 0.62);
  backdrop-filter: blur(5px);
}

.tl-proof-dialog {
  position: relative;
  display: grid;
  gap: 16px;
  padding: clamp(20px, 3vw, 30px);
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 16px;
  box-shadow: 0 28px 80px rgba(4, 20, 39, 0.28);
}

.tl-proof-dialog header p {
  margin: 0 0 7px;
  color: var(--tlp-lime);
  font-size: 0.76rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.tl-proof-dialog header h2 {
  margin: 0 0 8px;
  color: var(--tlp-navy);
  font-size: clamp(1.45rem, 2vw, 2rem);
}

.tl-proof-dialog header span {
  color: var(--tlp-muted);
  font-weight: 750;
}

.tl-proof-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  display: grid;
  place-items: center;
  color: var(--tlp-navy);
  background: var(--tlp-soft);
  border: 1px solid var(--tlp-line);
  border-radius: 999px;
  cursor: pointer;
  font-size: 1.1rem;
  font-weight: 950;
}

.tl-proof-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.tl-proof-dialog label {
  display: grid;
  gap: 6px;
  color: var(--tlp-navy);
  font-size: 0.84rem;
  font-weight: 900;
}

.tl-proof-dialog input,
.tl-proof-dialog textarea {
  width: 100%;
  min-width: 0;
  padding: 12px;
  color: var(--tlp-navy);
  background: #fff;
  border: 1px solid var(--tlp-line);
  border-radius: 9px;
  font: inherit;
}

.tl-proof-dialog textarea {
  resize: vertical;
}

.tl-proof-dialog input:focus,
.tl-proof-dialog textarea:focus {
  border-color: var(--tlp-lime);
  outline: 3px solid rgba(166, 206, 57, 0.16);
}

.tl-product-mobile-bar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0 !important;
  z-index: 120;
  display: grid;
  grid-template-columns: minmax(150px, auto) minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 12px max(18px, calc((100vw - 1280px) / 2)) max(12px, env(safe-area-inset-bottom));
  background: #fff !important;
  border-top: 1px solid var(--tlp-line);
  box-shadow: 0 -12px 32px rgba(7, 27, 58, 0.12);
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.tl-product-mobile-bar::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: max(32px, env(safe-area-inset-bottom));
  background: #fff;
}

.tl-product-mobile-bar span,
.tl-product-mobile-bar strong {
  display: block;
}

.tl-mobile-cart-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(150px, 210px));
  justify-content: end;
  gap: 10px;
}

.tl-product-mobile-bar span {
  color: var(--tlp-muted);
  font-size: 0.68rem;
  font-weight: 850;
  text-transform: uppercase;
  white-space: nowrap;
}

.tl-product-mobile-bar strong {
  color: var(--tlp-navy);
  font-size: clamp(1.25rem, 2vw, 1.85rem);
  line-height: 1;
}

.tl-product-mobile-bar button {
  min-height: 48px;
  padding: 0 14px;
  border-radius: 9px;
  font-size: 0.78rem;
  line-height: 1.05;
  letter-spacing: 0.02em;
}

.tl-product-mobile-bar a {
  min-height: 48px;
  font-size: 0.78rem;
  line-height: 1.05;
  letter-spacing: 0.02em;
}

.tl-product-mobile-bar button.is-added {
  color: var(--tlp-navy);
  background: #fff;
  border: 2px solid var(--tlp-lime);
  box-shadow: none;
}

.tl-product-sticky-cart #tlActionStatus {
  grid-column: 1 / -1;
  min-height: 0;
  margin: -4px 0 0;
  text-align: right;
}

.tl-checkout-page {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
  padding: 42px 0 72px;
  color: #071b3a;
}

.tl-checkout-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 26px;
}

.tl-checkout-heading h1 {
  margin: 0;
  color: #071b3a;
  font-size: clamp(2.25rem, 4vw, 3.5rem);
  line-height: 1;
  letter-spacing: -0.035em;
}

.tl-checkout-heading p {
  margin: 8px 0 0;
  color: #68758b;
  font-weight: 760;
}

.tl-checkout-heading p span {
  color: #071b3a;
}

.tl-checkout-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
  margin: 0 0 26px;
  padding: 0;
  list-style: none;
}

.tl-checkout-steps li {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 9px;
  color: #7a8698;
  font-size: 0.86rem;
  font-weight: 850;
}

.tl-checkout-steps li::before,
.tl-checkout-steps li::after {
  content: "";
  position: absolute;
  top: 19px;
  height: 2px;
  background: #dbe3ef;
}

.tl-checkout-steps li::before {
  left: 0;
  right: calc(50% + 25px);
}

.tl-checkout-steps li::after {
  left: calc(50% + 25px);
  right: 0;
}

.tl-checkout-steps li:first-child::before,
.tl-checkout-steps li:last-child::after {
  display: none;
}

.tl-checkout-steps strong {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  color: #071b3a;
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 999px;
  box-shadow: 0 8px 20px rgba(7, 27, 58, 0.06);
}

.tl-checkout-steps .is-active {
  color: #071b3a;
}

.tl-checkout-steps .is-active strong {
  color: #fff;
  background: #071b3a;
  border-color: #071b3a;
}

.tl-checkout-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 0.46fr);
  gap: 28px;
  align-items: start;
}

.tl-checkout-form {
  display: grid;
  gap: 18px;
}

.tl-checkout-panel,
.tl-checkout-summary-card,
.tl-checkout-help,
.tl-checkout-payments {
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 14px 34px rgba(7, 27, 58, 0.05);
}

.tl-checkout-panel {
  display: grid;
  gap: 16px;
  padding: 22px;
}

.tl-checkout-panel h2,
.tl-checkout-summary-card h2,
.tl-checkout-help h2,
.tl-checkout-payments h2 {
  margin: 0;
  color: #071b3a;
  font-size: 1.18rem;
  line-height: 1.2;
}

.tl-checkout-panel h2 span,
.tl-checkout-summary-card h2 span {
  color: #071b3a;
  margin-right: 8px;
}

.tl-checkout-field-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.tl-checkout-location-grid {
  grid-template-columns: minmax(0, 1fr) minmax(150px, 0.75fr) minmax(120px, 0.55fr);
}

.tl-checkout-panel label {
  display: block;
  color: #071b3a;
  font-size: 0.84rem;
  font-weight: 950;
}

.tl-checkout-panel label strong {
  color: #e23b3b;
}

.tl-checkout-panel label small {
  color: #7a8698;
  font-weight: 700;
}

.tl-checkout-panel input,
.tl-checkout-panel select,
.tl-checkout-panel textarea,
.tl-checkout-upload {
  margin-top: 8px;
}

.tl-checkout-label-spacer {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.tl-checkout-panel input,
.tl-checkout-panel select,
.tl-checkout-panel textarea {
  width: 100%;
  min-width: 0;
  color: #071b3a;
  background: #fff;
  border: 1px solid #cfd7e4;
  border-radius: 6px;
  font: inherit;
  font-size: 0.95rem;
  font-weight: 620;
  outline: 0;
  transition: border-color 0.18s ease, box-shadow 0.18s ease;
}

.tl-checkout-panel input,
.tl-checkout-panel select {
  height: 42px;
  padding: 0 12px;
}

.tl-checkout-panel textarea {
  resize: vertical;
  padding: 12px;
  line-height: 1.45;
}

.tl-checkout-panel input:focus,
.tl-checkout-panel select:focus,
.tl-checkout-panel textarea:focus {
  border-color: #a6ce39;
  box-shadow: 0 0 0 4px rgba(166, 206, 57, 0.13);
}

.tl-checkout-checkbox {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: center;
  gap: 9px !important;
  color: #46546b !important;
  font-size: 0.9rem !important;
  font-weight: 720 !important;
}

.tl-checkout-checkbox input {
  width: 17px;
  height: 17px;
  margin-top: 0;
  accent-color: #a6ce39;
}

.tl-checkout-upload {
  min-height: 96px;
  display: grid;
  place-items: center;
  padding: 18px;
  text-align: center;
  color: #59657a;
  background: #fbfcfe;
  border: 1px dashed #b8c4d4;
  border-radius: 8px;
  cursor: pointer;
}

.tl-checkout-upload input {
  width: min(100%, 250px);
  height: auto;
  margin-bottom: 8px;
  padding: 0;
  border: 0;
}

.tl-checkout-upload span,
.tl-checkout-upload strong {
  display: block;
}

.tl-checkout-muted,
.tl-checkout-secure {
  margin: -4px 0 0;
  color: #68758b;
  font-size: 0.86rem;
  line-height: 1.4;
  font-weight: 650;
}

.tl-checkout-submit {
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  color: #071b3a;
  background: #a6ce39;
  border: 0;
  border-radius: 8px;
  box-shadow: 0 18px 32px rgba(166, 206, 57, 0.22);
  cursor: pointer;
  font: inherit;
  font-size: 1rem;
  font-weight: 950;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}

.tl-checkout-submit:hover,
.tl-checkout-submit:focus-visible {
  transform: translateY(-2px);
  box-shadow: 0 22px 40px rgba(166, 206, 57, 0.28);
  outline: 0;
}

.tl-checkout-submit:disabled {
  cursor: not-allowed;
  opacity: 0.55;
  transform: none;
  box-shadow: none;
}

.tl-checkout-secure {
  text-align: center;
}

.tl-checkout-error {
  min-height: 20px;
  margin: -4px 0 0;
  color: #b42318;
  font-size: 0.9rem;
  line-height: 1.4;
  font-weight: 780;
  text-align: center;
}

.tl-checkout-error:empty {
  display: none;
}

.tl-checkout-error a {
  color: #071b3a;
  font-weight: 950;
}

.tl-checkout-summary {
  position: sticky;
  top: 118px;
  display: grid;
  gap: 0;
}

.tl-checkout-summary-card {
  overflow: hidden;
}

.tl-checkout-summary-card header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 22px;
  border-bottom: 1px solid #dbe3ef;
}

.tl-checkout-summary-card header a {
  color: #82b800;
  font-size: 0.82rem;
  font-weight: 950;
  text-decoration: none;
}

.tl-checkout-summary-item {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr) auto;
  gap: 14px;
  padding: 18px 22px;
  border-bottom: 1px solid #e7edf5;
}

.tl-checkout-summary-item img {
  width: 74px;
  height: 74px;
  object-fit: contain;
  background: #f7f9fc;
  border: 1px solid #dbe3ef;
  border-radius: 6px;
}

.tl-checkout-summary-item h3 {
  margin: 0 0 4px;
  color: #071b3a;
  font-size: 0.98rem;
  line-height: 1.16;
}

.tl-checkout-summary-item p {
  margin: 0;
  color: #46546b;
  font-size: 0.88rem;
  font-weight: 720;
}

.tl-checkout-summary-item ul {
  display: grid;
  gap: 4px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

.tl-checkout-summary-item li {
  color: #46546b;
  font-size: 0.78rem;
  line-height: 1.25;
}

.tl-checkout-summary-item li span {
  display: block;
  color: #071b3a;
  font-weight: 900;
}

.tl-checkout-summary-item button {
  width: max-content;
  margin-top: 10px;
  padding: 0;
  color: #82b800;
  background: transparent;
  border: 0;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 950;
  cursor: pointer;
}

.tl-checkout-summary-item > strong {
  display: grid;
  justify-items: end;
  gap: 18px;
  color: #071b3a;
  font-size: 0.92rem;
  white-space: nowrap;
}

.tl-checkout-summary-item > strong span {
  color: #46546b;
  font-size: 0.84rem;
}

.tl-checkout-costs {
  display: grid;
  gap: 12px;
  padding: 20px 22px;
  border-bottom: 1px solid #dbe3ef;
}

.tl-checkout-costs > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  color: #46546b;
  font-weight: 720;
}

.tl-checkout-costs strong {
  color: #071b3a;
}

.tl-checkout-costs .is-free {
  color: #82b800;
}

.tl-checkout-grand-total {
  margin-top: 8px;
  padding-top: 14px;
  border-top: 1px solid #dbe3ef;
}

.tl-checkout-grand-total span {
  color: #071b3a;
  font-size: 1.22rem;
  font-weight: 950;
}

.tl-checkout-grand-total strong {
  font-size: 1.65rem;
  letter-spacing: -0.02em;
}

.tl-checkout-grand-total small {
  font-size: 0.9rem;
  font-weight: 760;
}

.tl-checkout-delivery {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  gap: 14px;
  margin: 18px 22px;
  padding: 16px;
  color: #071b3a;
  background: #f4fbff;
  border: 1px solid #cce5f5;
  border-radius: 8px;
}

.tl-checkout-delivery > span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  color: #071b3a;
  border: 1px solid #bfdced;
  border-radius: 8px;
}

.tl-checkout-delivery strong,
.tl-checkout-delivery time,
.tl-checkout-delivery small {
  display: block;
}

.tl-checkout-delivery time {
  margin-top: 5px;
  color: #071b3a;
  font-weight: 950;
}

.tl-checkout-delivery small {
  margin-top: 4px;
  color: #68758b;
  font-size: 0.82rem;
}

.tl-checkout-help {
  padding: 22px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-top: 0;
}

.tl-checkout-help p {
  margin: 10px 0 0;
  color: #46546b;
  font-size: 0.9rem;
  line-height: 1.45;
  font-weight: 670;
}

.tl-checkout-help a {
  color: #071b3a;
  font-weight: 950;
}

.tl-checkout-payments {
  padding: 20px 22px;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
  border-top: 0;
}

.tl-checkout-payments div {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.tl-checkout-payments span {
  min-height: 42px;
  display: grid;
  place-items: center;
  color: #071b3a;
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 6px;
  font-size: clamp(0.58rem, 0.72vw, 0.72rem);
  font-weight: 950;
  text-align: center;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.tl-checkout-empty-state {
  padding: 26px 22px;
  border-bottom: 1px solid #dbe3ef;
}

.tl-checkout-empty-state h3 {
  margin: 0;
  color: #071b3a;
  font-size: 1.3rem;
}

.tl-checkout-empty-state p {
  margin: 8px 0 16px;
  color: #59657a;
  font-weight: 680;
}

.tl-checkout-empty-state a {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0 14px;
  color: #071b3a;
  background: #a6ce39;
  border-radius: 7px;
  font-weight: 950;
  text-decoration: none;
}

.tl-checkout-result {
  width: min(900px, calc(100% - 36px));
  margin: 0 auto;
  padding: clamp(58px, 8vw, 110px) 0;
}

.tl-checkout-result section {
  padding: clamp(28px, 5vw, 54px);
  background: #fff;
  border: 1px solid #dbe3ef;
  border-radius: 8px;
  box-shadow: 0 18px 44px rgba(7, 27, 58, 0.08);
}

.tl-checkout-result h1 {
  max-width: 720px;
  margin: 0;
  color: #071b3a;
  font-size: clamp(2.5rem, 6vw, 5.4rem);
  line-height: 0.95;
  letter-spacing: -0.035em;
}

.tl-checkout-result p:not(.eyebrow) {
  max-width: 640px;
  margin: 18px 0 0;
  color: #46546b;
  font-size: clamp(1rem, 1.25vw, 1.18rem);
  line-height: 1.55;
  font-weight: 650;
}

.tl-checkout-result div {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 28px;
}

.tl-checkout-result a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

@media (max-width: 1050px) {
  .tl-checkout-layout {
    grid-template-columns: 1fr;
  }

  .tl-checkout-summary {
    position: static;
  }
}

@media (max-width: 680px) {
  .tl-checkout-page {
    width: min(100% - 28px, 1180px);
    padding-top: 30px;
  }

  .tl-checkout-steps {
    gap: 8px;
  }

  .tl-checkout-steps li {
    font-size: 0.72rem;
  }

  .tl-checkout-field-grid,
  .tl-checkout-location-grid {
    grid-template-columns: 1fr;
  }

  .tl-checkout-panel {
    padding: 18px;
  }

  .tl-checkout-summary-item {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .tl-checkout-summary-item > strong {
    grid-column: 1 / -1;
    justify-items: start;
    gap: 4px;
  }

  .tl-checkout-payments div {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1280px) {
  .tl-builder-shell {
    grid-template-columns: minmax(540px, 1fr) minmax(420px, 500px);
    gap: 30px;
  }

  .tl-builder-gallery {
    position: static;
  }

  .tl-live-summary {
    grid-column: 1 / -1;
    position: static;
    justify-self: stretch;
    width: 100%;
  }

  .tl-summary-card {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.5fr);
    column-gap: 24px;
    align-items: start;
  }

  .tl-summary-card .tl-summary-kicker,
  .tl-summary-card h2,
  .tl-summary-card ul {
    grid-column: 1;
  }

  .tl-summary-totals,
  .tl-summary-actions,
  .tl-summary-card > small,
  #tlActionStatus {
    grid-column: 2;
  }
}

@media (max-width: 980px) {
  .tl-builder-config {
    width: 100%;
    margin-top: 0;
    justify-self: stretch;
  }

  .tl-builder-shell {
    grid-template-columns: 1fr;
    width: min(100% - 32px, 1180px);
  }

  .tl-builder-heading h1 {
    font-size: clamp(1.82rem, 6vw, 2.45rem);
  }

  .tl-benefit-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-benefit-row article:nth-child(2n) {
    border-right: 0;
  }

  .tl-summary-card {
    display: block;
  }

  .tl-option-grid,
  .tl-option-grid-three {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-wall-option-row {
    grid-template-columns: repeat(5, 92px);
  }

  .tl-package-option-row {
    grid-template-columns: repeat(5, minmax(68px, 88px));
  }

  .tl-addon-option-row {
    grid-template-columns: repeat(5, 92px);
  }

  .tl-artwork-grid {
    grid-template-columns: 1fr;
  }

  .tl-spec-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

}

@media (max-width: 720px) {
  .tl-product-builder {
    padding-bottom: 40px;
  }

  .tl-builder-heading,
  .tl-builder-shell,
  .tl-product-details {
    width: min(100% - 24px, 1180px);
  }

  .tl-builder-gallery {
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 8px;
    width: 100%;
  }

  .tl-gallery-stage {
    grid-row: 2;
    min-height: 285px;
  }

  .tl-gallery-stage img {
    max-width: none;
    max-height: none;
  }

  .tl-gallery-control {
    width: 40px;
    height: 40px;
  }

  .tl-gallery-thumbs {
    grid-row: 2;
    grid-auto-rows: 54px;
    grid-template-columns: 54px;
    max-height: calc((54px * 5) + (8px * 4));
    margin-top: 0;
    padding-right: 8px;
    overflow-y: auto;
  }

  .tl-gallery-thumb {
    width: 54px;
    min-height: 54px;
  }

  .tl-builder-heading {
    padding: 9px 0 11px;
  }

  .tl-builder-heading h1 {
    font-size: clamp(1.54rem, 6vw, 1.92rem);
    line-height: 1.02;
  }

  .tl-product-meta-row {
    flex-wrap: nowrap;
    gap: 4px 7px;
    margin-top: 9px;
    font-size: clamp(0.62rem, 2.55vw, 0.82rem);
    line-height: 1;
    white-space: nowrap;
  }

  .tl-product-meta-row > * + *::before {
    left: -5px;
    height: 12px;
  }

  .tl-rating-stars span {
    font-size: clamp(0.74rem, 3.15vw, 0.94rem);
    letter-spacing: 0;
  }

  .tl-sku-share,
  .tl-trust-line {
    font-size: inherit;
  }

.tl-shipping-note {
    gap: 6px;
    margin-top: 7px;
    padding: 5px 7px;
  }

  .tl-shipping-note > svg {
    width: 17px;
    height: 17px;
  }

  .tl-arrival-topline {
    display: flex;
    gap: 6px;
    font-size: 0.58rem;
  }

  .tl-arrival-topline strong {
    font-size: inherit;
    line-height: inherit;
  }

  .tl-benefit-row {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    margin-top: 9px;
  }

  .tl-product-feature-strip {
    grid-row: 1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 0;
    margin-bottom: 8px;
  }

  .tl-product-feature-strip article {
    grid-template-columns: 1fr;
    justify-items: center;
    min-height: 54px;
    gap: 3px;
    padding: 5px 4px;
    text-align: center;
  }

  .tl-product-feature-strip article > span {
    width: 24px;
    height: 22px;
  }

  .tl-product-feature-strip svg {
    width: 21px;
    height: 21px;
  }

  .tl-product-feature-strip strong {
    max-width: 78px;
    font-size: clamp(0.46rem, 1.9vw, 0.58rem);
    line-height: 1.04;
    letter-spacing: 0;
  }

  .tl-benefit-row article {
    gap: 3px;
    padding: 6px 4px 7px;
    border-right: 1px solid rgba(10, 30, 60, 0.13);
    border-bottom: 0;
  }

  .tl-benefit-row article:nth-child(2n) {
    border-right: 1px solid rgba(10, 30, 60, 0.13);
  }

  .tl-benefit-row article:last-child {
    border-right: 0;
  }

  .tl-benefit-row span {
    width: 24px;
    height: 22px;
    font-size: 0.7rem;
  }

  .tl-benefit-row svg {
    width: 21px;
    height: 21px;
    stroke-width: 2.05;
  }

  .tl-benefit-row strong {
    max-width: 78px;
    font-size: 0;
    line-height: 1.04;
    letter-spacing: 0;
  }

  .tl-benefit-row strong::after {
    content: attr(data-mobile-label);
    font-size: clamp(0.46rem, 1.9vw, 0.58rem);
  }

  .tl-benefit-row p {
    display: none;
  }

  .tl-benefit-row i {
    width: 16px;
    height: 2px;
  }

  .tl-option-grid,
  .tl-option-grid-three {
    grid-template-columns: 1fr;
  }

  .tl-wall-option-row {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(96px, 32%);
    grid-template-columns: none;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-inline: contain;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x pan-y;
    padding: 0 16px 10px 0;
  }

  .tl-package-option-row {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(72px, 24%);
    grid-template-columns: none;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-inline: contain;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x pan-y;
    padding: 0 16px 10px 0;
  }

  .tl-addon-option-row,
  .tl-artwork-grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(96px, 32%);
    grid-template-columns: none;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-inline: contain;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x pan-y;
    padding: 0 16px 10px 0;
  }

  .tl-artwork-card {
    min-height: 92px;
  }

  .tl-artwork-grid {
    grid-auto-columns: initial;
    grid-template-columns: 1fr;
    overflow: visible;
    padding: 0;
  }

  .tl-print-side-row {
    grid-template-columns: 1fr;
  }

  .tl-artwork-item {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .tl-artwork-actions {
    justify-content: flex-start;
  }

  .tl-artwork-item input[type="file"] {
    grid-column: auto;
  }

  .tl-wall-option-row .tl-option-card,
  .tl-package-option-row .tl-option-card,
  .tl-addon-option-row .tl-option-card,
  .tl-artwork-grid .tl-artwork-card {
    width: 100%;
    touch-action: pan-x pan-y;
  }

  .tl-wall-option-row::-webkit-scrollbar,
  .tl-package-option-row::-webkit-scrollbar,
  .tl-addon-option-row::-webkit-scrollbar,
  .tl-artwork-grid::-webkit-scrollbar {
    height: 4px;
  }

  .tl-wall-option-row::-webkit-scrollbar-thumb,
  .tl-package-option-row::-webkit-scrollbar-thumb,
  .tl-addon-option-row::-webkit-scrollbar-thumb,
  .tl-artwork-grid::-webkit-scrollbar-thumb {
    background: rgba(10, 30, 60, 0.18);
    border-radius: 999px;
  }

  .tl-static-option {
    width: min(100%, 150px);
  }

  .tl-config-step {
    padding: 10px 0;
  }

  .tl-summary-card li {
    grid-template-columns: 78px minmax(0, 1fr);
  }

  .tl-proof-grid,
  .tl-spec-grid {
    grid-template-columns: 1fr;
  }

  .tl-proof-actions {
    grid-template-columns: 1fr;
  }

  .tl-product-mobile-bar {
    display: grid;
  }

  .tl-final-checkout-panel {
    grid-template-columns: 1fr;
  }

  .tl-live-total-pill {
    width: max-content;
    padding: 6px 10px;
  }

  .tl-final-cart-actions {
    grid-template-columns: 1fr;
  }

  .tl-final-checkout-panel #tlActionStatus {
    text-align: left;
  }
}

@media (max-width: 430px) {
  .tl-builder-shell {
    width: min(100% - 20px, 1180px);
  }

  .tl-gallery-stage {
    min-height: 286px;
  }

  .tl-product-feature-strip {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .tl-product-feature-strip article {
    min-height: 64px;
    padding: 7px 4px 8px;
  }

  .tl-product-feature-strip article > span {
    width: 24px;
    height: 22px;
  }

  .tl-product-feature-strip svg {
    width: 20px;
    height: 20px;
  }

  .tl-product-feature-strip strong {
    font-size: 0.48rem;
    line-height: 1.05;
  }

  .tl-product-feature-strip i {
    width: 18px;
  }

  .tl-static-option {
    width: min(100%, 142px);
  }

  .tl-option-card,
  .tl-static-option,
  .tl-artwork-card,
  .tl-summary-card,
  .tl-detail-panel {
    border-radius: 11px;
  }

}

@media (max-width: 560px) {
  .tl-product-builder {
    padding-bottom: 40px;
  }

  .tl-product-mobile-bar {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 8px 10px max(10px, env(safe-area-inset-bottom));
  }

  .tl-product-mobile-bar > div:first-child {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 12px;
  }

  .tl-mobile-cart-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-content: stretch;
  }

  .tl-product-mobile-bar button,
  .tl-product-mobile-bar a {
    min-height: 42px;
    padding: 0 8px;
    font-size: 0.68rem;
  }

  .tl-product-sticky-cart #tlActionStatus {
    margin-top: -2px;
    text-align: center;
    font-size: 0.72rem;
  }
}

@media (max-width: 860px) {
  html,
  body {
    overflow-x: hidden;
    touch-action: manipulation;
    -webkit-text-size-adjust: 100%;
  }

  a,
  button,
  input,
  select,
  textarea,
  label,
  summary,
  .tl-option-card,
  .tl-artwork-card,
  .tl-gallery-thumb,
  .tl-gallery-control,
  .tl-product-mobile-bar {
    touch-action: manipulation;
  }

  input,
  select,
  textarea {
    font-size: 16px;
  }

  .tl-wall-option-row,
  .tl-package-option-row,
  .tl-addon-option-row,
  .tl-wall-option-row .tl-option-card,
  .tl-package-option-row .tl-option-card,
  .tl-addon-option-row .tl-option-card {
    touch-action: pan-x pan-y !important;
  }
}

/* Alternate 10x10 canopy product concept page */
body[data-page="product-alt"] {
  background: #f7f8fa;
  color: #0a1e3c;
}

.tl-alt-product-page {
  background: #fff;
}

.tl-alt-product-shell {
  width: min(1500px, calc(100% - 112px));
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.72fr) minmax(360px, 0.82fr);
  gap: clamp(24px, 3vw, 44px);
  padding: clamp(22px, 2.8vw, 38px) 0 22px;
  align-items: start;
}

.tl-alt-gallery,
.tl-alt-card {
  min-width: 0;
}

.tl-alt-gallery {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  column-gap: 14px;
  align-items: start;
}

.tl-alt-product-heading {
  grid-column: 1 / -1;
}

.tl-alt-product-heading h1 {
  margin: 0 0 8px;
  color: #0a1e3c;
  font-size: clamp(1.55rem, 1.9vw, 2.18rem);
  line-height: 1;
  font-weight: 950;
  letter-spacing: -0.02em;
}

.tl-alt-benefits {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px clamp(18px, 2.4vw, 34px);
  margin-bottom: 8px;
  color: #2f3b50;
  font-size: 0.82rem;
  font-weight: 720;
}

.tl-alt-benefits span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  white-space: nowrap;
}

.tl-alt-benefits svg,
.tl-alt-helper svg,
.tl-alt-delivery svg,
.tl-alt-spec-strip svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.tl-alt-stage {
  grid-column: 2;
  grid-row: 2;
  position: relative;
  min-height: clamp(290px, 23vw, 410px);
  display: grid;
  place-items: center;
  overflow: visible;
  border-radius: 0;
  background: #fff;
}

.tl-alt-stage::after {
  display: none;
}

.tl-alt-stage img {
  position: relative;
  z-index: 1;
  align-self: start;
  width: min(62%, 560px);
  height: auto;
  max-height: 92%;
  display: block;
  object-fit: contain;
  filter: none;
}

.tl-alt-thumbs {
  grid-column: 1;
  grid-row: 2;
  width: 76px;
  height: 100%;
  margin: 0;
  position: relative;
  z-index: 4;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 8px;
}

.tl-alt-thumbs button {
  width: 76px;
  aspect-ratio: 1 / 0.82;
  padding: 0;
  overflow: hidden;
  background: #fff;
  border: 1px solid #dfe6f0;
  border-radius: 8px;
  box-shadow: 0 12px 24px rgba(7, 27, 58, 0.06);
  cursor: pointer;
}

.tl-alt-thumbs button.is-active {
  border-color: #a6ce39;
  box-shadow: 0 0 0 2px rgba(166, 206, 57, 0.2), 0 14px 28px rgba(7, 27, 58, 0.08);
}

.tl-alt-thumbs img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
}

.tl-alt-helper {
  grid-column: 2;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  margin: 8px 0 0;
  color: #526071;
  font-size: 0.82rem;
  font-weight: 680;
}

.tl-alt-card {
  position: sticky;
  top: 92px;
  overflow: hidden;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 24px 54px rgba(7, 27, 58, 0.13);
}

.tl-alt-start-tab {
  position: relative;
  z-index: 2;
  width: max-content;
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin: 0 0 -1px;
  padding: 7px 13px 6px;
  color: #0a1e3c;
  background: #a6ce39;
  border: 1px solid #0a1e3c;
  border-bottom: 0;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
}

.tl-alt-start-tab span {
  width: 17px;
  height: 17px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 999px;
  color: #a6ce39;
  background: #0a1e3c;
  font-size: 0.84rem;
  line-height: 1;
  font-weight: 950;
}

.tl-alt-start-tab strong {
  font-size: 0.78rem;
  line-height: 1;
  font-weight: 950;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.tl-alt-card h2 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0;
  padding: 14px 22px;
  color: #fff;
  background: linear-gradient(135deg, #06172f, #0a1e3c);
  font-size: 1.04rem;
  line-height: 1;
  font-weight: 900;
}

.tl-alt-running-total {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  flex: 0 0 auto;
  padding: 5px 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(255, 255, 255, 0.78);
  font-size: 0.68rem;
  line-height: 1;
  font-weight: 850;
  text-transform: uppercase;
}

.tl-alt-running-total strong {
  color: #a6ce39;
  font-size: 0.98rem;
  font-weight: 950;
}

.tl-alt-card-body {
  padding: 20px 22px 22px;
}

.tl-alt-step {
  margin-bottom: 17px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(229, 231, 235, 0.9);
}

.tl-alt-step:last-of-type {
  margin-bottom: 14px;
  border-bottom: 0;
}

.tl-alt-step h3 {
  display: flex;
  align-items: center;
  gap: 0;
  margin: 0 0 8px;
  color: #0a1e3c;
  font-size: 0.84rem;
  line-height: 1;
  font-weight: 950;
}

.tl-alt-package-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.tl-alt-package {
  min-height: 194px;
  display: grid;
  align-content: start;
  gap: 12px;
  padding: 22px 20px 18px;
  border: 1px solid #dfe6f0;
  border-radius: 8px;
  background: #fff;
  text-align: left;
  color: #0a1e3c;
  cursor: pointer;
  font-family: inherit;
  box-shadow: 0 14px 26px rgba(7, 27, 58, 0.04);
}

.tl-alt-package.is-selected {
  border-color: #a6ce39;
  background: linear-gradient(135deg, rgba(166, 206, 57, 0.08), #fff 62%);
  box-shadow: inset 0 0 0 1px rgba(166, 206, 57, 0.16), 0 18px 34px rgba(7, 27, 58, 0.06);
}

.tl-alt-package strong {
  font-size: 0.96rem;
  line-height: 1.18;
  font-weight: 950;
}

.tl-alt-package em {
  color: #0a1e3c;
  font-size: 1.16rem;
  line-height: 1;
  font-style: normal;
  font-weight: 950;
}

.tl-alt-package.is-selected em {
  color: #8cba18;
}

.tl-alt-package p {
  margin: 0;
  color: #2f3b50;
  font-size: 0.86rem;
  line-height: 1.45;
  font-weight: 610;
}

.tl-alt-package i {
  width: 27px;
  height: 27px;
  display: grid;
  place-items: center;
  justify-self: center;
  align-self: end;
  margin-top: 8px;
  color: #fff;
  background: #a6ce39;
  border: 2px solid #a6ce39;
  border-radius: 999px;
  font-size: 1rem;
  font-style: normal;
  font-weight: 950;
}

.tl-alt-package:not(.is-selected) i {
  background: #fff;
  border-color: #c7d0df;
}

.tl-alt-chip-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
}

.tl-alt-accessory-row {
  max-width: 280px;
}

.tl-alt-two-option-row {
  max-width: 190px;
}

.tl-alt-chip-row a,
.tl-alt-chip-row button {
  min-height: 26px;
  display: inline-grid;
  place-items: center;
  width: auto;
  flex: 0 0 auto;
  padding: 0 10px;
  color: #0a1e3c;
  background: #fff;
  border: 1px solid #dfe6f0;
  border-radius: 5px;
  box-shadow: 0 10px 18px rgba(7, 27, 58, 0.03);
  cursor: pointer;
  font-family: inherit;
  font-size: 0.61rem;
  font-weight: 760;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
}

.tl-alt-chip-row button span {
  color: #8cba18;
  font-weight: 950;
}

.tl-alt-package-type-row {
  margin-top: 7px;
}

.tl-alt-print-side-row {
  margin-top: 7px;
  padding-top: 0;
}

.tl-alt-print-side-row[hidden] {
  display: none !important;
}

.tl-alt-package-type-row button {
  white-space: normal;
  line-height: 1.1;
}

.tl-alt-chip-row a.is-selected,
.tl-alt-chip-row button.is-selected {
  border-color: #a6ce39;
  background: #fbfdf5;
  box-shadow: inset 0 0 0 1px rgba(166, 206, 57, 0.14);
}

.tl-alt-delivery {
  display: flex;
  gap: 9px;
  align-items: center;
  margin: 2px 0 16px;
  padding: 9px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #f7f8fa;
  color: #0a1e3c;
}

.tl-alt-delivery svg {
  flex: 0 0 auto;
  color: #0a1e3c;
}

.tl-alt-delivery p {
  margin: 0;
  color: #2f3b50;
  font-size: clamp(0.68rem, 0.86vw, 0.76rem);
  line-height: 1.24;
  font-weight: 640;
  white-space: normal;
  min-width: 0;
}

.tl-alt-delivery strong {
  display: inline;
  color: #0a1e3c;
  font-weight: 950;
}

.tl-alt-delivery span {
  display: block;
  margin-top: 2px;
}

.tl-alt-total {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  margin: 0 -22px;
  padding: 15px 22px;
  border-top: 1px solid #e5e7eb;
}

.tl-alt-total span {
  color: #0a1e3c;
  font-weight: 950;
}

.tl-alt-total strong {
  color: #0a1e3c;
  font-size: 1.45rem;
  line-height: 1;
  font-weight: 950;
}

.tl-alt-add {
  width: 100%;
  min-height: 42px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, #a6ce39, #8ebd18);
  border: 0;
  border-radius: 7px;
  box-shadow: 0 16px 28px rgba(166, 206, 57, 0.24);
  cursor: pointer;
  font-family: inherit;
  font-size: 0.82rem;
  font-weight: 950;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.tl-alt-add:disabled {
  cursor: default;
  color: #6d7a8f;
  background: #e7edf5;
  box-shadow: none;
}

.tl-alt-status {
  min-height: 20px;
  margin: 7px 0 0;
  color: #526071;
  font-size: 0.74rem;
  font-weight: 700;
  text-align: center;
}

.tl-alt-status a {
  color: #0a1e3c;
  font-weight: 950;
  text-decoration: underline;
}

.tl-alt-spec-strip {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0;
  width: 100%;
  margin: 12px 0 0;
  padding: 11px 0;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
  background: rgba(255, 255, 255, 0.74);
}

.tl-alt-spec-strip article {
  min-height: 46px;
  display: grid;
  grid-template-columns: 27px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 10px;
  align-content: center;
  padding: 0 20px;
  color: #0a1e3c;
  border-right: 1px solid #e5e7eb;
}

.tl-alt-spec-strip article:last-child {
  border-right: 0;
}

.tl-alt-spec-strip svg {
  grid-row: 1 / span 2;
  align-self: center;
  width: 20px;
  height: 20px;
}

.tl-alt-spec-strip strong,
.tl-alt-spec-strip span {
  display: block;
}

.tl-alt-spec-strip strong {
  font-size: 0.8rem;
  line-height: 1.1;
  font-weight: 950;
}

.tl-alt-spec-strip span {
  color: #2f3b50;
  font-size: 0.76rem;
  line-height: 1.18;
  font-weight: 650;
}

@media (max-width: 1180px) {
  .tl-alt-product-shell {
    grid-template-columns: 1fr;
    width: min(900px, calc(100% - 48px));
  }

  .tl-alt-card {
    position: static;
  }

  .tl-alt-stage {
    min-height: clamp(270px, 48vw, 420px);
  }

  .tl-alt-spec-strip {
    width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .tl-alt-spec-strip article {
    border-bottom: 1px solid #e5e7eb;
  }

  .tl-alt-spec-strip article:nth-child(2n) {
    border-right: 0;
  }

  .tl-alt-spec-strip article:nth-last-child(-n + 2) {
    border-bottom: 0;
  }
}

@media (max-width: 680px) {
  .tl-alt-gallery {
    display: block;
  }

  .tl-alt-product-shell {
    width: min(100% - 28px, 520px);
    gap: 16px;
    padding-top: 16px;
  }

  .tl-alt-product-heading h1 {
    margin-bottom: 9px;
    font-size: clamp(1.35rem, 7vw, 1.78rem);
  }

  .tl-alt-benefits {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 10px;
    margin-bottom: 12px;
    font-size: 0.68rem;
  }

  .tl-alt-benefits span {
    white-space: normal;
  }

  .tl-alt-benefits svg {
    width: 15px;
    height: 15px;
  }

  .tl-alt-stage {
    min-height: 210px;
    border-radius: 10px;
  }

  .tl-alt-stage img {
    width: 72%;
  }

  .tl-alt-thumbs {
    width: 100%;
    gap: 7px;
    margin-top: 8px;
    display: grid;
    overflow-x: auto;
    grid-auto-flow: column;
    grid-auto-columns: 70px;
    grid-template-columns: none;
    padding-bottom: 3px;
  }

  .tl-alt-thumbs button {
    width: 70px;
  }

  .tl-alt-helper {
    margin-top: 9px;
    font-size: 0.72rem;
  }

  .tl-alt-card {
    border-radius: 12px;
  }

  .tl-alt-start-tab {
    padding: 6px 11px 5px;
    gap: 6px;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
  }

  .tl-alt-start-tab span {
    width: 15px;
    height: 15px;
    font-size: 0.76rem;
  }

  .tl-alt-start-tab strong {
    font-size: 0.7rem;
  }

  .tl-alt-card h2 {
    padding: 13px 16px;
    font-size: 0.98rem;
  }

  .tl-alt-running-total {
    padding: 4px 7px;
    font-size: 0.62rem;
  }

  .tl-alt-running-total strong {
    font-size: 0.86rem;
  }

  .tl-alt-card-body {
    padding: 16px;
  }

  .tl-alt-package-grid,
  .tl-alt-chip-row,
  .tl-alt-accessory-row {
    max-width: none;
    gap: 8px;
  }

  .tl-alt-package {
    min-height: 0;
    padding: 16px;
  }

  .tl-alt-step {
    margin-bottom: 15px;
  }

  .tl-alt-step h3 {
    font-size: 0.82rem;
    margin-bottom: 8px;
  }

  .tl-alt-chip-row a,
  .tl-alt-chip-row button {
    min-height: 31px;
  }

  .tl-alt-total {
    margin: 0 -16px;
    padding: 14px 16px;
  }

  .tl-alt-spec-strip {
    width: 100%;
    grid-template-columns: repeat(4, minmax(82px, 1fr));
    margin: 8px 0 14px;
    padding: 8px 0;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .tl-alt-spec-strip article {
    min-height: 0;
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    justify-items: center;
    row-gap: 3px;
    padding: 0 7px;
    text-align: center;
    border-right: 1px solid #e5e7eb;
    border-bottom: 0;
  }

  .tl-alt-spec-strip::-webkit-scrollbar {
    display: none;
  }

  .tl-alt-spec-strip article:nth-child(2n) {
    border-right: 1px solid #e5e7eb;
  }

  .tl-alt-spec-strip svg {
    grid-row: auto;
    width: 18px;
    height: 18px;
    margin-bottom: 1px;
  }

  .tl-alt-spec-strip strong {
    font-size: clamp(0.56rem, 2.2vw, 0.66rem);
    line-height: 1;
    white-space: nowrap;
  }

  .tl-alt-spec-strip span {
    font-size: clamp(0.52rem, 2vw, 0.62rem);
    line-height: 1.08;
  }

  .tl-alt-spec-strip article:last-child {
    border-right: 0;
  }
}
