/**
 * components.css
 * Reusable UI components: cards, hero, widgets, badges, forms, article body.
 * Depends on: tokens.css, base.css
 */

/* ══════════════════════════════════════════════
   CATEGORY BADGES
══════════════════════════════════════════════ */
.badge {
  display: inline-flex;
  align-items: center;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: var(--radius-sm);
  color: var(--c-white);
  line-height: 1.4;
  white-space: nowrap;
  flex-shrink: 0;
}
.badge--politics    { background: var(--c-cat-politics); }
.badge--business    { background: var(--c-cat-business); }
.badge--sports      { background: var(--c-cat-sports); }
.badge--technology  { background: var(--c-cat-tech); }
.badge--entertainment { background: var(--c-cat-entertain); }
.badge--world       { background: var(--c-cat-world); }
.badge--health      { background: var(--c-cat-health); }
.badge--education   { background: var(--c-cat-education); color: var(--c-white); }
.badge--lifestyle   { background: var(--c-cat-lifestyle); }
.badge--science     { background: var(--c-cat-science); }
.badge--default     { background: var(--c-charcoal); }

/* Floating badge (over image) */
.badge--float {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  z-index: var(--z-card);
}

/* ══════════════════════════════════════════════
   NEWS CARD — GRID VARIANT
══════════════════════════════════════════════ */
.news-card {
  display: flex;
  flex-direction: column;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  height: 100%;
  cursor: pointer;
  transition:
    box-shadow var(--duration-sm) var(--ease),
    transform var(--duration-sm) var(--ease),
    border-color var(--duration-sm) var(--ease);
  text-decoration: none;
  color: inherit;
}
.news-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
  border-color: var(--c-border-dark);
}
.news-card:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
}

.news-card__thumb {
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--c-border);
}
.news-card__thumb-img {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
  transition: transform var(--duration-lg) var(--ease);
}
.news-card:hover .news-card__thumb-img {
  transform: scale(1.05);
}
/* skeleton placeholder while image loads */
.news-card__thumb-img[data-loading="true"] {
  background: var(--c-border);
}

.news-card__body {
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  flex: 1;
  gap: var(--space-2);
}
.news-card__meta-top {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.news-card__title {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 700;
  line-height: 1.4;
  color: var(--c-text-primary);
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color var(--duration-xs);
}
.news-card:hover .news-card__title { color: var(--c-red); }
.news-card__excerpt {
  font-size: var(--text-sm);
  color: var(--c-text-muted);
  line-height: 1.55;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-card__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-top: auto;
  padding-top: var(--space-2);
  border-top: 1px solid var(--c-border);
  font-size: var(--text-xs);
  color: var(--c-text-muted);
}
.news-card__author {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-weight: 600;
  color: var(--c-text-primary);
}
.news-card__time {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  white-space: nowrap;
}

/* ── Card size variants ─────────────────────── */
.news-card--large .news-card__title  { font-size: var(--text-lg); -webkit-line-clamp: 4; }
.news-card--large .news-card__excerpt { -webkit-line-clamp: 3; }
.news-card--compact .news-card__excerpt { display: none; }
.news-card--compact .news-card__title { font-size: var(--text-sm); -webkit-line-clamp: 2; }

/* ══════════════════════════════════════════════
   NEWS LIST ITEM — HORIZONTAL VARIANT
══════════════════════════════════════════════ */
.news-list-item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  cursor: pointer;
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--c-border);
  text-decoration: none;
  color: inherit;
  transition: opacity var(--duration-xs);
}
.news-list-item:last-child { border-bottom: none; }
.news-list-item:hover { opacity: 0.8; }
.news-list-item:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.news-list-item__thumb {
  width: 90px;
  height: 68px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  background: var(--c-border);
}
.news-list-item__content { flex: 1; min-width: 0; }
.news-list-item__title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1.35;
  color: var(--c-text-primary);
  margin: 0 0 var(--space-1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-list-item__meta {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* ══════════════════════════════════════════════
   HERO SECTION
══════════════════════════════════════════════ */
.hero-section {
  padding-top: var(--space-6);
  padding-bottom: var(--space-2);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: var(--space-3);
  min-height: 420px;
}
@media (max-width: 767px) {
  .hero-grid { grid-template-columns: 1fr; }
}

/* Main hero card */
.hero-main {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--c-charcoal);
  cursor: pointer;
  height: 100%;
  min-height: 320px;
  display: flex;
}
.hero-main__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.82;
  transition: transform var(--duration-lg) var(--ease), opacity var(--duration-md) var(--ease);
}
.hero-main:hover .hero-main__img {
  transform: scale(1.04);
  opacity: 0.72;
}
.hero-main__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.3) 50%, transparent 100%);
}
.hero-main__body {
  position: relative;
  z-index: 2;
  padding: var(--space-6);
  margin-top: auto;
  width: 100%;
}
.hero-main__badge { margin-bottom: var(--space-2); }
.hero-main__title {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.8vw, 1.75rem);
  font-weight: 800;
  color: var(--c-white);
  line-height: 1.25;
  margin: 0 0 var(--space-2);
}
.hero-main__meta {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.6);
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}
.hero-main__meta i { color: rgba(255,255,255,0.4); }
.hero-main:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
}

/* Side stack */
.hero-stack {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  height: 100%;
}
.hero-stack__card {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-md);
  background: var(--c-charcoal);
  flex: 1;
  min-height: 140px;
  cursor: pointer;
  display: flex;
}
.hero-stack__card:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
}
.hero-stack__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.78;
  transition: transform var(--duration-lg) var(--ease), opacity var(--duration-md) var(--ease);
}
.hero-stack__card:hover .hero-stack__img {
  transform: scale(1.06);
  opacity: 0.65;
}
.hero-stack__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.88) 0%, transparent 65%);
}
.hero-stack__body {
  position: relative;
  z-index: 2;
  padding: var(--space-3) var(--space-4);
  margin-top: auto;
  width: 100%;
}
.hero-stack__title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--c-white);
  line-height: 1.3;
  margin: var(--space-1) 0 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.hero-stack__meta {
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.55);
  margin-top: var(--space-1);
}

/* ══════════════════════════════════════════════
   CATEGORY FILTER PILLS
══════════════════════════════════════════════ */
.cat-pills {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-1);
}
.cat-pill {
  padding: 6px var(--space-4);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0.04em;
  border: 1.5px solid var(--c-border);
  background: var(--c-surface);
  color: var(--c-text-secondary);
  cursor: pointer;
  transition:
    background var(--duration-xs),
    color var(--duration-xs),
    border-color var(--duration-xs),
    box-shadow var(--duration-xs);
  white-space: nowrap;
  user-select: none;
}
.cat-pill:hover {
  background: var(--c-red-muted);
  border-color: var(--c-red);
  color: var(--c-red);
}
.cat-pill[aria-pressed="true"],
.cat-pill--active {
  background: var(--c-red);
  color: var(--c-white);
  border-color: var(--c-red);
  box-shadow: var(--shadow-red);
}

/* ══════════════════════════════════════════════
   SIDEBAR WIDGETS
══════════════════════════════════════════════ */
.widget {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: var(--space-6);
}
.widget:last-child { margin-bottom: 0; }

.widget__header {
  background: var(--c-charcoal);
  color: var(--c-white);
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.widget__header i { color: var(--c-gold); font-size: 0.85rem; }
.widget__body { padding: var(--space-4); }
.widget__body--flush { padding: 0; }

/* Trending widget item */
.trending-item {
  display: flex;
  gap: var(--space-3);
  align-items: flex-start;
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--c-border);
  cursor: pointer;
  transition: opacity var(--duration-xs);
  text-decoration: none;
  color: inherit;
}
.trending-item:last-child { border-bottom: none; padding-bottom: 0; }
.trending-item:first-child { padding-top: 0; }
.trending-item:hover { opacity: 0.78; }
.trending-item:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.trending-item__rank {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 800;
  line-height: 1;
  min-width: 32px;
  flex-shrink: 0;
  color: var(--c-border-dark);
}
.trending-item:nth-child(1) .trending-item__rank { color: var(--c-red); }
.trending-item:nth-child(2) .trending-item__rank { color: var(--c-charcoal); opacity: 0.55; }
.trending-item:nth-child(3) .trending-item__rank { color: var(--c-charcoal); opacity: 0.38; }
.trending-item__title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1.35;
  margin: 0 0 var(--space-1);
  color: var(--c-text-primary);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.trending-item__meta {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  display: flex;
  gap: var(--space-2);
}

/* Tags cloud widget */
.tags-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.tag-pill {
  background: var(--c-surface-alt);
  border: 1px solid var(--c-border);
  color: var(--c-text-secondary);
  font-size: var(--text-xs);
  font-weight: 600;
  padding: 4px var(--space-3);
  border-radius: var(--radius-full);
  cursor: pointer;
  transition:
    background var(--duration-xs),
    color var(--duration-xs),
    border-color var(--duration-xs);
  user-select: none;
}
.tag-pill:hover {
  background: var(--c-red);
  color: var(--c-white);
  border-color: var(--c-red);
}

/* Newsletter widget */
.widget--newsletter {
  background: var(--c-charcoal);
  border-color: transparent;
  border-radius: var(--radius-md);
  padding: var(--space-5);
  margin-bottom: var(--space-6);
  color: var(--c-white);
}
.widget--newsletter .widget__nl-title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 800;
  margin-bottom: var(--space-2);
  line-height: 1.2;
  color: rgba(255,255,255,0.85);
}
.widget--newsletter .widget__nl-desc {
  font-size: var(--text-sm);
  color: rgba(255,255,255,0.6);
  margin-bottom: var(--space-4);
  line-height: 1.6;
}
.widget__nl-input {
  width: 100%;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-sm);
  color: var(--c-white);
  padding: 10px var(--space-4);
  font-size: var(--text-sm);
  margin-bottom: var(--space-2);
  transition: border-color var(--duration-xs), background var(--duration-xs);
}
.widget__nl-input::placeholder { color: rgba(255,255,255,0.38); }
.widget__nl-input:focus {
  outline: none;
  border-color: var(--c-gold);
  background: rgba(255,255,255,0.14);
}
.widget__nl-btn {
  width: 100%;
  background: var(--c-red);
  color: var(--c-white);
  border: none;
  border-radius: var(--radius-sm);
  padding: 10px var(--space-4);
  font-size: var(--text-sm);
  font-weight: 700;
  cursor: pointer;
  transition: background var(--duration-xs);
}
.widget__nl-btn:hover { background: var(--c-red-dark); }
.widget__nl-btn:focus-visible { outline: 3px solid var(--c-gold); outline-offset: 2px; }

/* Ad slot widget */
.widget--ad {
  background: var(--c-surface-alt);
  border: 1px dashed var(--c-border-dark);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-text-faint);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  text-align: center;
  padding: var(--space-5);
  margin-bottom: var(--space-6);
}
.widget--ad--rect  { aspect-ratio: 4/3; min-height: 200px; }
.widget--ad--half  { min-height: 280px; }
.widget--ad--skyscraper { min-height: 480px; }

/* ══════════════════════════════════════════════
   ARTICLE PAGE
══════════════════════════════════════════════ */
.article-hero-img {
  width: 100%;
  border-radius: var(--radius-lg);
  aspect-ratio: 16 / 7;
  object-fit: cover;
  margin-bottom: var(--space-6);
}
.article-meta-bar {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4);
  align-items: center;
  padding-block: var(--space-4);
  border-top: 1px solid var(--c-border);
  border-bottom: 1px solid var(--c-border);
  margin-bottom: var(--space-6);
  font-size: var(--text-sm);
  color: var(--c-text-muted);
}
.article-meta-bar__author {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: 600;
  color: var(--c-text-primary);
}
.article-meta-bar__avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--c-red);
  color: var(--c-white);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.article-meta-bar__divider {
  width: 1px;
  height: 16px;
  background: var(--c-border);
}

/* Article body typography */
.article-body { max-width: var(--content-max); }
.article-body p {
  font-size: var(--text-md);
  line-height: 1.78;
  color: var(--c-text-secondary);
  margin-bottom: var(--space-5);
}
.article-body p.lead {
  font-size: var(--text-lg);
  font-weight: 400;
  color: var(--c-text-primary);
  line-height: 1.65;
  margin-bottom: var(--space-6);
}
.article-body h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 800;
  color: var(--c-text-primary);
  margin: var(--space-8) 0 var(--space-4);
  padding-bottom: var(--space-3);
  border-bottom: 2px solid var(--c-border);
}
.article-body h3 {
  font-size: var(--text-xl);
  margin: var(--space-6) 0 var(--space-3);
}
.article-body blockquote {
  border-left: 4px solid var(--c-red);
  background: var(--c-red-muted);
  padding: var(--space-4) var(--space-6);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  margin: var(--space-6) 0;
}
.article-body blockquote p {
  font-size: var(--text-lg);
  font-style: italic;
  color: var(--c-text-primary);
  margin: 0;
  line-height: 1.6;
}
.article-body ul, .article-body ol {
  list-style: revert;
  padding-left: var(--space-6);
  margin-bottom: var(--space-5);
}
.article-body li {
  font-size: var(--text-md);
  line-height: 1.75;
  color: var(--c-text-secondary);
  margin-bottom: var(--space-2);
}
.article-body img {
  width: 100%;
  border-radius: var(--radius-md);
  margin-block: var(--space-5);
}
.article-body figcaption {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  text-align: center;
  margin-top: calc(-1 * var(--space-3));
  margin-bottom: var(--space-5);
}

/* Share bar */
.share-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  padding-block: var(--space-5);
  border-top: 1px solid var(--c-border);
  margin-top: var(--space-6);
}
.share-bar__label {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--c-text-primary);
  margin-right: var(--space-1);
}
.share-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 7px var(--space-4);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: opacity var(--duration-xs), transform var(--duration-xs);
  color: var(--c-white);
  white-space: nowrap;
}
.share-btn:hover  { opacity: 0.88; transform: translateY(-1px); }
.share-btn:active { transform: translateY(0); }
.share-btn--fb  { background: #1877F2; }
.share-btn--tw  { background: #000; }
.share-btn--wa  { background: #25D366; }
.share-btn--tg  { background: #0088CC; }
.share-btn--copy { background: var(--c-charcoal); }

/* Tags in article */
.article-tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  margin-block: var(--space-5);
}
.article-tags__label {
  font-size: var(--text-xs);
  font-weight: 700;
  color: var(--c-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* Related article mini card */
.related-mini {
  display: flex;
  gap: var(--space-3);
  cursor: pointer;
  padding-block: var(--space-3);
  border-bottom: 1px solid var(--c-border);
  transition: opacity var(--duration-xs);
  text-decoration: none;
  color: inherit;
}
.related-mini:last-child { border-bottom: none; padding-bottom: 0; }
.related-mini:first-child { padding-top: 0; }
.related-mini:hover { opacity: 0.78; }
.related-mini:focus-visible {
  outline: 3px solid var(--c-gold);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.related-mini__thumb {
  width: 78px;
  height: 60px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  flex-shrink: 0;
  background: var(--c-border);
}
.related-mini__title {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 700;
  line-height: 1.3;
  color: var(--c-text-primary);
  margin: 0 0 var(--space-1);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.related-mini__meta {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
}

/* Comments */
.comments-section { margin-top: var(--space-8); }
.comments-section__heading {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  margin-bottom: var(--space-5);
  display: flex;
  align-items: center;
  gap: var(--space-2);
}
.comments-section__heading span {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--c-text-muted);
}
.comment-item {
  padding-block: var(--space-4);
  border-bottom: 1px solid var(--c-border);
}
.comment-item:last-child { border-bottom: none; }
.comment-item__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.comment-item__avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--c-red);
  color: var(--c-white);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: var(--text-base);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.comment-item__name {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--c-text-primary);
}
.comment-item__time {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  margin-left: auto;
}
.comment-item__body {
  font-size: var(--text-sm);
  color: var(--c-text-secondary);
  line-height: 1.6;
  padding-left: calc(34px + var(--space-3));
}
.comment-form { margin-bottom: var(--space-8); }
.comment-form__textarea {
  width: 100%;
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  resize: vertical;
  min-height: 100px;
  background: var(--c-surface);
  color: var(--c-text-primary);
  transition: border-color var(--duration-xs);
}
.comment-form__textarea:focus {
  outline: none;
  border-color: var(--c-red);
}

/* ══════════════════════════════════════════════
   FORM ELEMENTS
══════════════════════════════════════════════ */
.form-group { margin-bottom: var(--space-4); }
.form-group label {
  display: block;
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--c-text-primary);
  margin-bottom: var(--space-2);
}
.form-group label span { color: var(--c-red); margin-left: 2px; }

.form-control {
  width: 100%;
  padding: 10px var(--space-4);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  background: var(--c-surface);
  color: var(--c-text-primary);
  transition: border-color var(--duration-xs), box-shadow var(--duration-xs);
  -webkit-appearance: none;
}
.form-control::placeholder { color: var(--c-text-faint); }
.form-control:focus {
  outline: none;
  border-color: var(--c-red);
  box-shadow: 0 0 0 3px var(--c-red-muted);
}
.form-control--error {
  border-color: var(--c-red);
  box-shadow: 0 0 0 3px var(--c-red-muted);
}
.form-error-msg {
  font-size: var(--text-xs);
  color: var(--c-red);
  margin-top: var(--space-1);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 10px var(--space-6);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 700;
  font-family: var(--font-body);
  cursor: pointer;
  border: 2px solid transparent;
  transition:
    background var(--duration-xs),
    color var(--duration-xs),
    border-color var(--duration-xs),
    box-shadow var(--duration-xs),
    transform var(--duration-xs);
  white-space: nowrap;
  text-decoration: none;
}
.btn:focus-visible { outline: 3px solid var(--c-gold); outline-offset: 2px; }
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn--primary { background: var(--c-red); color: var(--c-white); border-color: var(--c-red); }
.btn--primary:hover { background: var(--c-red-dark); border-color: var(--c-red-dark); }
.btn--secondary { background: transparent; color: var(--c-charcoal); border-color: var(--c-charcoal); }
.btn--secondary:hover { background: var(--c-charcoal); color: var(--c-white); }
.btn--ghost { background: transparent; color: var(--c-red); border-color: var(--c-border); }
.btn--ghost:hover { border-color: var(--c-red); background: var(--c-red-muted); }
.btn--gold { background: var(--c-gold); color: #000; border-color: var(--c-gold); }
.btn--gold:hover { background: #d08a10; border-color: #d08a10; }
.btn--full { width: 100%; }
.btn--sm { padding: 6px var(--space-4); font-size: var(--text-xs); }
.btn--lg { padding: 14px var(--space-8); font-size: var(--text-base); }

/* ══════════════════════════════════════════════
   SEARCH COMPONENTS
══════════════════════════════════════════════ */
.search-hero {
  background: linear-gradient(135deg, var(--c-charcoal) 0%, #2A1F3D 100%);
  color: var(--c-white);
  padding: var(--space-10) 0 var(--space-8);
}
.search-hero h2 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 800;
  color: var(--c-white);
  margin-bottom: var(--space-5);
}
.search-input-wrap {
  position: relative;
  max-width: 600px;
}
.search-input-big {
  width: 100%;
  padding: var(--space-4) 52px var(--space-4) var(--space-5);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.1);
  color: var(--c-white);
  font-size: var(--text-md);
  transition: border-color var(--duration-xs), background var(--duration-xs);
}
.search-input-big::placeholder { color: rgba(255,255,255,0.42); }
.search-input-big:focus {
  outline: none;
  border-color: var(--c-gold);
  background: rgba(255,255,255,0.14);
}
.search-input-wrap__btn {
  position: absolute;
  right: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: rgba(255,255,255,0.6);
  font-size: 1.2rem;
  cursor: pointer;
  padding: var(--space-2);
  transition: color var(--duration-xs);
}
.search-input-wrap__btn:hover { color: var(--c-white); }
.search-popular {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.5);
}
.search-popular .tag-pill {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  color: rgba(255,255,255,0.8);
}
.search-popular .tag-pill:hover {
  background: var(--c-red);
  border-color: var(--c-red);
  color: var(--c-white);
}

/* ══════════════════════════════════════════════
   PAGE HERO (About, Contact, etc.)
══════════════════════════════════════════════ */
.page-hero {
  background: linear-gradient(135deg, var(--c-charcoal) 0%, #2A1F3D 100%);
  color: var(--c-white);
  padding: var(--space-12) 0 var(--space-10);
  text-align: center;
}

@media (max-width: 639px) {
  .page-hero {
    padding-top: 24px;
    padding-bottom: 24px;
  }

  .page-breadcrumb {
    margin-top: 20px;
    margin-bottom: 14px;
    justify-content: center;
    flex-wrap: wrap;
  }

  .page-hero h1 {
    margin-top: 8px;
  }
}
.page-hero h1 {
  font-family: var(--font-display);
  font-size: clamp(1.75rem, 5vw, 3rem);
  font-weight: 800;
  color: var(--c-white);
  margin-bottom: var(--space-3);
}
.page-hero p {
  font-size: var(--text-md);
  color: rgba(255,255,255,0.65);
  max-width: 520px;
  margin-inline: auto;
  line-height: 1.65;
}
.page-breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: rgba(255,255,255,0.45);
  margin-bottom: var(--space-3);
  justify-content: center;
}
.page-breadcrumb a { color: rgba(255,255,255,0.65); }
.page-breadcrumb a:hover { color: var(--c-gold); }
.page-breadcrumb__sep { opacity: 0.4; }

/* ══════════════════════════════════════════════
   EMPTY STATE
══════════════════════════════════════════════ */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-16) var(--space-4);
  color: var(--c-text-muted);
}
.empty-state__icon {
  font-size: 3rem;
  margin-bottom: var(--space-4);
  color: var(--c-border-dark);
}
.empty-state__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--c-text-primary);
  margin-bottom: var(--space-2);
}
.empty-state__desc {
  font-size: var(--text-sm);
  max-width: 380px;
  line-height: 1.65;
  margin-bottom: var(--space-5);
}

/* ══════════════════════════════════════════════
   LOADING SKELETON CARDS
══════════════════════════════════════════════ */
.skeleton-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.skeleton-card__thumb {
  width: 100%;
  aspect-ratio: 16/9;
}
.skeleton-card__body { padding: var(--space-4); display: flex; flex-direction: column; gap: var(--space-3); }
.skeleton-card__line { height: 14px; border-radius: var(--radius-sm); }
.skeleton-card__line--short { width: 60%; }
.skeleton-card__line--med { width: 80%; }

/* ══════════════════════════════════════════════
   VIDEO WIDGET ITEM
══════════════════════════════════════════════ */
.video-thumb {
  position: relative;
  background: var(--c-charcoal);
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  overflow: hidden;
}
.video-thumb__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; opacity: 0.7; }
.video-thumb__play {
  position: relative;
  z-index: 2;
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: rgba(200,16,46,0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-white);
  font-size: 1.2rem;
  transition: transform var(--duration-sm) var(--ease), background var(--duration-xs);
}
.video-thumb:hover .video-thumb__play {
  transform: scale(1.1);
  background: var(--c-red);
}

/* ══════════════════════════════════════════════
   ABOUT PAGE
══════════════════════════════════════════════ */
.stat-item { text-align: center; padding: var(--space-6) var(--space-4); }
.stat-item__num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 800;
  color: var(--c-red);
  line-height: 1;
  display: block;
}
.stat-item__label {
  font-size: var(--text-xs);
  color: var(--c-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: var(--space-2);
  display: block;
}
.value-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: box-shadow var(--duration-sm);
}
.value-card:hover { box-shadow: var(--shadow-lg); }
.value-card__icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem;
  margin-bottom: var(--space-4);
  flex-shrink: 0;
}
.value-card__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-2);
}
.value-card__desc { font-size: var(--text-sm); color: var(--c-text-muted); line-height: 1.65; margin: 0; }

.team-card {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  text-align: center;
  transition: box-shadow var(--duration-sm);
}
.team-card:hover { box-shadow: var(--shadow-lg); }
.team-card__avatar {
  width: 80px; height: 80px;
  border-radius: 50%;
  margin: 0 auto var(--space-4);
  background: var(--c-red-muted);
  border: 3px solid var(--c-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--c-red);
}
.team-card__name { font-family: var(--font-display); font-size: var(--text-lg); font-weight: 700; margin-bottom: var(--space-1); }
.team-card__role { font-size: var(--text-sm); color: var(--c-text-muted); }

/* ══════════════════════════════════════════════
   CONTACT PAGE
══════════════════════════════════════════════ */
.contact-info-item {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding-block: var(--space-4);
  border-bottom: 1px solid var(--c-border);
}
.contact-info-item:last-child { border-bottom: none; }
.contact-info-icon {
  width: 42px; height: 42px;
  border-radius: var(--radius-md);
  background: var(--c-red-muted);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem;
  color: var(--c-red);
  flex-shrink: 0;
}
.contact-info-item__title { font-weight: 700; font-size: var(--text-sm); color: var(--c-text-primary); margin-bottom: var(--space-1); }
.contact-info-item__value { font-size: var(--text-sm); color: var(--c-text-muted); }

.tip-box {
  background: var(--c-charcoal);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  color: var(--c-white);
  margin-top: var(--space-5);
}
.tip-box__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 700;
  margin-bottom: var(--space-2);
}
.tip-box__desc { font-size: var(--text-sm); color: rgba(255,255,255,0.6); margin-bottom: var(--space-4); line-height: 1.6; }
