/* Telemetrica International - Components (v1) – scoped to .tm-app
   Built on design-tokens.css. Only elements inside .tm-app receive these styles.
*/

.tm-app * { box-sizing: border-box; }

.tm-app {
  font-family: var(--font-sans);
  font-size: var(--text-body);
  line-height: 1.6;
  color: var(--color-text);
  background: var(--color-bg);
  overflow-x: hidden;
}

.tm-app img { max-width: 100%; height: auto; display: block; }
.tm-app a { color: var(--color-link); text-decoration: none; }
.tm-app a:hover { color: var(--color-link-hover); text-decoration: underline; }

.tm-app :focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
  border-radius: 6px;
}

@media (prefers-reduced-motion: reduce) {
  .tm-app * { transition: none !important; animation: none !important; }
}

/* Layout helpers */
.tm-app .tm-container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}
.tm-app .tm-section { padding: var(--space-9) 0; }
.tm-app .tm-section--compact { padding: var(--space-7) 0; }
.tm-app .tm-muted { color: var(--color-text-muted); }
.tm-app .tm-divider { border-top: 1px solid var(--color-border); }

/* Header */
.tm-app .tm-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(10, 14, 39, 0.94);
  backdrop-filter: blur(10px);
  color: var(--color-text-on-dark);
}
.tm-app .tm-header__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: 60px;
  gap: var(--space-4);
}
.tm-app .tm-header__brand { display: flex; align-items: center; gap: var(--space-3); }
.tm-app .tm-header__logo { height: 36px; width: auto; }
.tm-app .tm-nav { display: flex; align-items: center; gap: var(--space-5); flex-wrap: wrap; }
.tm-app .tm-nav a {
  color: var(--color-text-on-dark);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  opacity: 0.95;
}
.tm-app .tm-nav a:hover { opacity: 1; text-decoration: underline; }
.tm-app .tm-nav a.tm-nav--active { opacity: 1; text-decoration: underline; }

/* Breadcrumbs */
.tm-app .tm-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
.tm-app .tm-breadcrumb a { color: var(--color-text-muted); }
.tm-app .tm-breadcrumb a:hover { color: var(--color-link-hover); }
.tm-app .tm-breadcrumb__sep { opacity: 0.6; }

/* Buttons */
.tm-app .tm-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 44px;
  padding: 10px 16px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-weight: 700;
  cursor: pointer;
  user-select: none;
  transition: transform var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out),
    background var(--dur-1) var(--ease-out), border-color var(--dur-1) var(--ease-out),
    color var(--dur-1) var(--ease-out);
}
.tm-app .tm-btn:active { transform: translateY(1px); }
.tm-app .tm-btn[aria-disabled="true"],
.tm-app .tm-btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  pointer-events: none;
}
.tm-app .tm-btn--primary {
  background: var(--color-primary);
  color: #ffffff;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
}
.tm-app .tm-btn--primary:hover { box-shadow: var(--shadow-md); text-decoration: none; }
.tm-app .tm-btn--secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-border);
}
.tm-app .tm-btn--secondary:hover { box-shadow: var(--shadow-sm); }
.tm-app .tm-btn--ghost {
  background: transparent;
  color: var(--color-link);
  border-color: transparent;
}
.tm-app .tm-btn--ghost:hover { text-decoration: underline; }

/* Cards */
.tm-app .tm-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.tm-app .tm-card__pad { padding: var(--space-6); }
.tm-app .tm-card--hover {
  transition: box-shadow var(--dur-2) var(--ease-out), transform var(--dur-2) var(--ease-out);
}
.tm-app .tm-card--hover:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* Badges */
.tm-app .tm-badge {
  display: inline-flex;
  align-items: center;
  height: 26px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  font-size: var(--text-sm);
  font-weight: 700;
  background: var(--color-surface-elev);
  color: var(--color-text);
  border: 1px solid var(--color-border);
}
.tm-app .tm-badge--success { border-color: rgba(22, 163, 74, 0.35); color: #0f6b30; }
.tm-app .tm-badge--warning { border-color: rgba(245, 158, 11, 0.4); color: #8a5200; }
.tm-app .tm-badge--danger { border-color: rgba(239, 68, 68, 0.45); color: #9b1c1c; }

/* Grids */
.tm-app .tm-grid {
  display: grid;
  gap: var(--space-6);
}
.tm-app .tm-grid--2 { grid-template-columns: 1fr; }
.tm-app .tm-grid--3 { grid-template-columns: 1fr; }
@media (min-width: 768px) {
  .tm-app .tm-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .tm-app .tm-grid--3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* Product summary block */
.tm-app .tm-product-title {
  font-size: 2rem;
  line-height: var(--lh-tight);
  margin: 0 0 var(--space-3);
}
.tm-app .tm-price {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  flex-wrap: wrap;
  margin: var(--space-4) 0;
}
.tm-app .tm-price__now { font-size: 1.75rem; font-weight: 800; }
.tm-app .tm-price__old { color: var(--color-text-muted); text-decoration: line-through; }

/* Tabs */
.tm-app .tm-tabs {
  border-bottom: 1px solid var(--color-border);
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.tm-app .tm-tab {
  padding: 12px 4px;
  font-weight: 700;
  color: var(--color-text-muted);
  border-bottom: 2px solid transparent;
}
.tm-app .tm-tab[aria-selected="true"] {
  color: var(--color-text);
  border-bottom-color: var(--color-primary);
}

/* Forms */
.tm-app .tm-field { display: grid; gap: var(--space-2); }
.tm-app .tm-label { font-weight: 700; }
.tm-app .tm-input,
.tm-app .tm-textarea,
.tm-app .tm-select {
  width: 100%;
  min-height: 44px;
  padding: 10px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  font: inherit;
  color: inherit;
  transition: border-color var(--dur-1) var(--ease-out), box-shadow var(--dur-1) var(--ease-out);
}
.tm-app .tm-textarea { min-height: 120px; resize: vertical; }
.tm-app .tm-input:focus,
.tm-app .tm-textarea:focus,
.tm-app .tm-select:focus {
  outline: none;
  border-color: rgba(3, 170, 229, 0.7);
  box-shadow: var(--focus-ring);
}
.tm-app .tm-help { font-size: var(--text-sm); color: var(--color-text-muted); }
.tm-app .tm-error { font-size: var(--text-sm); color: var(--color-danger); }
