/* ============================================================
   KEYRO HELP CENTER — style.css
   Phase 2 design — aligned with keyro.fr brand
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fira+Sans:wght@300;400;500;600;700&display=swap');

/* ================================
   DESIGN TOKENS
   ================================ */
:root {
  /* Primary brand */
  --k-primary:       #473c90;
  --k-primary-dark:  #2d2470;
  --k-secondary:     #aa4693;

  /* Pastel accents (from keyro.fr) */
  --k-pink:          #ebbae0;
  --k-blue:          #97d0f2;
  --k-lavender:      #e0e8ff;
  --k-blue-gray:     #dce5ed;

  /* Surfaces */
  --k-bg:            #f5f6fa;
  --k-surface:       #ffffff;

  /* Text */
  --k-text:          #0c162f;
  --k-text-muted:    #636975;

  /* Borders */
  --k-border:        #e5e7eb;
  --k-border-hover:  #c4c8d1;

  /* Shape */
  --k-radius-sm:     4px;
  --k-radius:        8px;
  --k-radius-lg:     12px;
  --k-radius-pill:   999px;

  /* Shadows */
  --k-shadow:        0 2px 10px rgba(12,22,47,.06);
  --k-shadow-md:     0 6px 20px rgba(12,22,47,.08);
  --k-shadow-hover:  0 12px 32px rgba(12,22,47,.12);

  /* Typography */
  --k-font:          'Fira Sans', system-ui, -apple-system, Helvetica, Arial, sans-serif;
}

/* ================================
   RESET (scoped — don't nuke form internals)
   ================================ */
*, *::before, *::after { box-sizing: border-box; }

body, h1, h2, h3, h4, h5, h6, p, figure, blockquote, dl, dd {
  margin: 0;
}

body {
  font-family: var(--k-font) !important;
  background: var(--k-bg) !important;
  color: var(--k-text) !important;
  -webkit-font-smoothing: antialiased;
  line-height: 1.5;
}

/* Strip bullet-lists in theme chrome only (navs, breadcrumbs, tiles, dropdowns) */
.header ul, .header ol,
.footer ul, .footer ol,
.nav-wrapper ul, .nav-wrapper ol,
.k-grid, .k-tiles-section ul,
.breadcrumbs, .breadcrumbs ul, .breadcrumbs ol,
.collapsible-nav-list,
.dropdown-menu,
.pagination,
.multibrand-filter-list,
.striped-list ul,
.profile-stats,
.profile-activity-list,
.profile-contribution-list,
.profile-badges-items,
.community-badge-titles,
.community-badge-achievements,
.promoted-articles,
.attachments,
.suggestion-list,
.meta-group,
.request-collaborators {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.header li, .header li::before,
.footer li, .footer li::before,
.nav-wrapper li, .nav-wrapper li::before,
.k-grid li, .k-grid li::before,
.breadcrumbs li::before,
.dropdown-menu li::before,
.collapsible-nav-list li::before {
  margin: 0 !important;
  padding: 0 !important;
  content: none !important;
}

.meta-group li { list-style: none; }

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

/* ================================
   CONTAINER
   ================================ */
.k-container {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 24px;
}

/* ================================
   HEADER
   ================================ */
.header {
  background: var(--k-surface) !important;
  border-bottom: 1px solid var(--k-border) !important;
  padding: 0 36px !important;
  height: 64px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 300 !important;
  box-shadow: var(--k-shadow) !important;
}

.header .logo {
  display: flex !important;
  align-items: center !important;
  height: 100% !important;
  max-width: 160px !important;
}

.header .logo img,
.header .brand img {
  max-height: 34px !important;
  max-width: 140px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  display: block !important;
}

.header .nav-wrapper {
  display: flex;
  align-items: center;
  gap: 12px;
}

.k-header-btn {
  background: var(--k-primary) !important;
  color: var(--k-surface) !important;
  padding: 10px 20px !important;
  border-radius: var(--k-radius) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  font-family: var(--k-font) !important;
  transition: background .2s, transform .2s !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  white-space: nowrap !important;
  text-decoration: none !important;
}

.k-header-btn:hover {
  background: var(--k-primary-dark) !important;
  color: var(--k-surface) !important;
  transform: translateY(-1px) !important;
}

.k-header-btn svg { width: 16px; height: 16px; flex-shrink: 0; }

/* Signed-in user block */
.header .user-info {
  display: flex;
  align-items: center;
  gap: 12px;
}

.header .user-profile-link {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  color: var(--k-text) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  text-decoration: none !important;
  transition: color .2s;
}

.header .user-profile-link:hover { color: var(--k-primary) !important; }

.header .user-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
}

.header .user-name {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.header .header-link {
  color: var(--k-text) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  padding: 8px 12px !important;
  border-radius: var(--k-radius-sm) !important;
  transition: color .2s, background .2s !important;
  text-decoration: none !important;
}

.header .header-link:hover {
  color: var(--k-primary) !important;
  background: var(--k-bg) !important;
}

/* Outline CTA (used for "Se connecter") */
.header-btn-outline {
  display: inline-flex !important;
  align-items: center !important;
  padding: 9px 18px !important;
  background: transparent !important;
  border: 1.5px solid var(--k-primary) !important;
  border-radius: var(--k-radius) !important;
  color: var(--k-primary) !important;
  font-family: var(--k-font) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  transition: background .15s, color .15s !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.header-btn-outline:hover {
  background: var(--k-primary) !important;
  color: var(--k-surface) !important;
}

/* Hide native Copenhagen header clutter */
.header .collapsible-nav,
.header .mobile-nav,
.header .nav-wrapper-mobile,
.header .submit-a-request,
.header [data-role="submit-a-request"] { display: none !important; }

/* ================================
   HERO
   ================================ */
.k-hero {
  background: var(--k-primary);
  padding: 88px 28px 120px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Pastel blobs — keyro.fr-style flat accents */
.k-hero::before {
  content: '';
  position: absolute;
  top: -80px; right: -80px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: var(--k-secondary);
  opacity: .30;
  pointer-events: none;
}

.k-hero::after {
  content: '';
  position: absolute;
  bottom: -140px; left: -120px;
  width: 420px; height: 420px;
  border-radius: 50%;
  background: var(--k-pink);
  opacity: .22;
  pointer-events: none;
}

.k-hero .k-container { position: relative; z-index: 2; }

.k-hero-title {
  font-family: var(--k-font);
  font-size: 52px;
  font-weight: 700;
  color: var(--k-surface);
  line-height: 1.1;
  letter-spacing: -.02em;
  margin: 0 0 16px;
}

.k-hero-title span { color: var(--k-pink); }

.k-hero-sub {
  color: rgba(255,255,255,.82);
  font-size: 18px;
  font-weight: 400;
  margin: 0 0 36px;
}

/* ================================
   SEARCH BAR
   ================================ */
.k-search-wrap { max-width: 620px; margin: 0 auto; }

.k-search-wrap form,
.k-search-wrap .search { width: 100%; }

.k-search-wrap input[type="search"],
.k-search-wrap input[type="text"],
.k-search-wrap #query {
  width: 100% !important;
  padding: 16px 22px !important;
  border-radius: var(--k-radius) !important;
  border: 1px solid transparent !important;
  font-size: 15px !important;
  font-family: var(--k-font) !important;
  box-shadow: var(--k-shadow-md) !important;
  outline: none !important;
  color: var(--k-text) !important;
  background: var(--k-surface) !important;
}

.k-search-wrap input:focus {
  box-shadow: 0 0 0 3px rgba(235,186,224,.5), var(--k-shadow-md) !important;
  border-color: var(--k-pink) !important;
}

.k-search-wrap button[type="submit"],
.k-search-wrap input[type="submit"] { display: none !important; }

/* ================================
   TILES SECTION
   ================================ */
.k-tiles-section {
  background: var(--k-bg);
  padding: 0 0 80px;
  margin-top: -60px;
  position: relative;
  z-index: 10;
}

.k-tiles-intro {
  text-align: center;
  padding: 60px 0 40px;
}

.k-tiles-intro h2 {
  font-family: var(--k-font);
  font-size: 28px;
  font-weight: 700;
  color: var(--k-text);
  letter-spacing: -.01em;
  margin-bottom: 8px;
}

.k-tiles-intro p {
  font-size: 15px;
  color: var(--k-text-muted);
}

.k-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  list-style: none;
  padding: 0;
  margin: 0;
}

/* ================================
   TILE CARD
   ================================ */
.k-card {
  background: var(--k-surface);
  border-radius: var(--k-radius);
  border: 1px solid var(--k-border);
  box-shadow: var(--k-shadow);
  padding: 28px 20px;
  text-align: center;
  text-decoration: none !important;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  color: var(--k-text) !important;
}

.k-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--k-shadow-hover);
  border-color: var(--k-primary);
  text-decoration: none !important;
}

.k-card-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--k-radius);
  background: var(--k-lavender);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 26px;
  transition: background .2s, transform .2s;
  flex-shrink: 0;
}

.k-card:hover .k-card-icon {
  background: var(--k-pink);
  transform: scale(1.05);
}

.k-card-title {
  font-family: var(--k-font);
  font-size: 14px;
  font-weight: 600;
  color: var(--k-text);
  line-height: 1.35;
  margin: 0;
  transition: color .2s;
}

.k-card:hover .k-card-title { color: var(--k-primary); }

.k-card-arrow {
  font-size: 13px;
  color: var(--k-text-muted);
  font-weight: 500;
  transition: color .2s;
}

.k-card:hover .k-card-arrow { color: var(--k-secondary); }

/* ================================
   BREADCRUMBS
   ================================ */
.breadcrumbs {
  display: flex !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 4px !important;
  padding: 16px 0 !important;
  font-size: 13px !important;
  color: var(--k-text-muted) !important;
  list-style: none !important;
}

.breadcrumbs a,
.breadcrumbs li a {
  color: var(--k-primary) !important;
  font-weight: 500 !important;
  transition: color .2s !important;
  text-decoration: none !important;
}

.breadcrumbs a:hover { color: var(--k-secondary) !important; }

.breadcrumbs li::after {
  content: '›' !important;
  margin: 0 6px !important;
  color: var(--k-border-hover) !important;
  font-size: 14px !important;
}
.breadcrumbs li:last-child::after { content: none !important; }

/* ================================
   INNER PAGE SKELETON
   ================================ */
.k-inner-page {
  background: var(--k-bg);
  min-height: 60vh;
  padding-bottom: 80px;
}

.k-page-wrap {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 24px;
}

.k-page-header {
  padding: 8px 0 24px;
  margin-bottom: 28px;
  border-bottom: 1px solid var(--k-border);
}

.k-page-title {
  font-family: var(--k-font);
  font-size: 32px;
  font-weight: 700;
  color: var(--k-text);
  margin: 0 0 10px;
  line-height: 1.2;
  letter-spacing: -.02em;
}

.k-page-desc {
  color: var(--k-text-muted);
  font-size: 15px;
  line-height: 1.6;
  margin: 0;
}

.k-content-card {
  background: var(--k-surface);
  border-radius: var(--k-radius);
  border: 1px solid var(--k-border);
  box-shadow: var(--k-shadow);
  padding: 36px 40px;
}

/* ================================
   ARTICLE BODY
   ================================ */
.article-body {
  font-family: var(--k-font) !important;
  font-size: 16px !important;
  line-height: 1.75 !important;
  color: var(--k-text) !important;
}

.article-body h1,
.article-body h2,
.article-body h3 {
  font-family: var(--k-font) !important;
  color: var(--k-text) !important;
  font-weight: 700 !important;
  letter-spacing: -.01em !important;
  margin: 32px 0 12px !important;
}

.article-body h2 { font-size: 22px !important; }
.article-body h3 { font-size: 18px !important; }

.article-body p { margin: 0 0 16px 0 !important; }

.article-body a {
  color: var(--k-secondary) !important;
  font-weight: 500 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}
.article-body a:hover { color: var(--k-primary) !important; }

.article-body ul,
.article-body ol {
  list-style: disc !important;
  padding-left: 24px !important;
  margin: 12px 0 !important;
}

.article-body li { list-style: inherit !important; margin-bottom: 6px !important; }
.article-body li::before { content: none !important; }

.article-body code {
  background: var(--k-blue-gray) !important;
  color: var(--k-primary) !important;
  padding: 2px 7px !important;
  border-radius: var(--k-radius-sm) !important;
  font-size: 13px !important;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace !important;
}

.article-body pre {
  background: var(--k-blue-gray) !important;
  padding: 16px !important;
  border-radius: var(--k-radius) !important;
  overflow-x: auto !important;
  margin: 16px 0 !important;
}

.article-body pre code { background: transparent !important; padding: 0 !important; }

.article-body img {
  max-width: 100% !important;
  border-radius: var(--k-radius) !important;
  margin: 16px 0 !important;
}

.article-body blockquote {
  border-left: 3px solid var(--k-primary) !important;
  padding-left: 16px !important;
  color: var(--k-text-muted) !important;
  margin: 16px 0 !important;
}

/* ================================
   CATEGORY PAGE — SECTION TREE
   ================================ */
.section-tree { padding-top: 8px; }

.section-tree .section {
  background: var(--k-surface);
  border-radius: var(--k-radius);
  border: 1px solid var(--k-border);
  box-shadow: var(--k-shadow);
  padding: 28px 32px;
  margin-bottom: 16px;
}

.section-tree-title {
  font-family: var(--k-font);
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 16px !important;
}

.section-tree-title a {
  color: var(--k-text) !important;
  transition: color .15s;
}

.section-tree-title a:hover { color: var(--k-primary) !important; }

/* Article list inside a section */
.section-tree .article-list { padding: 0; margin: 0; }

.section-tree .article-list-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 0;
  border-top: 1px solid var(--k-border);
}

.section-tree .article-list-item:first-child { border-top: none; }

.article-list-link {
  color: var(--k-primary) !important;
  font-size: 15px;
  font-weight: 500;
  flex: 1;
  transition: color .15s;
}

.article-list-link:hover { color: var(--k-secondary) !important; }

.see-all-articles {
  display: inline-block;
  margin-top: 14px;
  color: var(--k-secondary) !important;
  font-weight: 500;
  font-size: 14px;
  transition: color .15s;
}

.see-all-articles:hover { color: var(--k-primary) !important; }

.category-empty {
  color: var(--k-text-muted);
  font-style: italic;
}

/* ================================
   SECTION PAGE — ARTICLE LIST
   ================================ */
.section-container .article-list {
  background: var(--k-surface);
  border-radius: var(--k-radius);
  border: 1px solid var(--k-border);
  box-shadow: var(--k-shadow);
  overflow: hidden;
}

.section-container .article-list li {
  border-top: 1px solid var(--k-border);
}

.section-container .article-list li:first-child { border-top: none; }

.section-container .article-list a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 24px;
  color: var(--k-text) !important;
  font-size: 15px;
  font-weight: 500;
  transition: background .15s, color .15s;
}

.section-container .article-list a:hover {
  background: var(--k-bg);
  color: var(--k-primary) !important;
}

/* ================================
   FOOTER CTA
   ================================ */
.k-footer-cta {
  background: var(--k-primary);
  padding: 48px 28px;
  color: var(--k-surface);
  position: relative;
  overflow: hidden;
}

.k-footer-cta::before {
  content: '';
  position: absolute;
  top: -100px; right: -80px;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: var(--k-pink);
  opacity: .18;
  pointer-events: none;
}

.k-footer-cta::after {
  content: '';
  position: absolute;
  bottom: -120px; left: 30%;
  width: 260px; height: 260px;
  border-radius: 50%;
  background: var(--k-secondary);
  opacity: .25;
  pointer-events: none;
}

.k-footer-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}

.k-footer-text h3 {
  font-family: var(--k-font);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -.01em;
  margin-bottom: 6px;
}

.k-footer-text p { opacity: .8; font-size: 15px; }

.k-footer-btn {
  background: var(--k-surface);
  color: var(--k-primary) !important;
  padding: 13px 28px;
  border-radius: var(--k-radius);
  font-family: var(--k-font);
  font-weight: 600;
  font-size: 15px;
  white-space: nowrap;
  box-shadow: var(--k-shadow);
  transition: transform .2s, box-shadow .2s;
  display: inline-block;
  text-decoration: none !important;
}

.k-footer-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--k-shadow-hover);
  color: var(--k-primary) !important;
}

/* ================================
   FOOTER
   ================================ */
.footer {
  background: var(--k-surface);
  border-top: 1px solid var(--k-border);
  padding: 28px 0;
  color: var(--k-text-muted);
  font-size: 14px;
}

.footer-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.footer-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.footer-brand-name {
  color: var(--k-text) !important;
  font-weight: 600 !important;
  transition: color .2s;
}

.footer-brand-name:hover { color: var(--k-primary) !important; }

.footer-sep { color: var(--k-border-hover); user-select: none; }

.footer-link {
  color: var(--k-primary) !important;
  font-weight: 500 !important;
  transition: color .2s;
}

.footer-link:hover { color: var(--k-secondary) !important; }

/* Language selector dropdown */
.footer-language { position: relative; }

.footer-language .dropdown-toggle {
  background: transparent;
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 7px 12px;
  color: var(--k-text);
  font-family: var(--k-font);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: border-color .15s, background .15s, color .15s;
}

.footer-language .dropdown-toggle:hover {
  border-color: var(--k-primary);
  background: var(--k-bg);
  color: var(--k-primary);
}

.footer-language .dropdown-menu {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow-md);
  padding: 6px;
  min-width: 180px;
  max-height: 280px;
  overflow-y: auto;
}

.footer-language .dropdown-menu a {
  display: block;
  padding: 8px 12px;
  color: var(--k-text) !important;
  font-size: 13px;
  border-radius: var(--k-radius-sm);
  transition: background .12s, color .12s;
}

.footer-language .dropdown-menu a:hover {
  background: var(--k-bg);
  color: var(--k-primary) !important;
}

/* ================================
   RESPONSIVE
   ================================ */
@media (max-width: 1024px) {
  .k-grid { grid-template-columns: repeat(3, 1fr); }
  .k-hero-title { font-size: 42px; }
}

@media (max-width: 640px) {
  .k-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
  .k-hero { padding: 60px 16px 100px; }
  .k-hero-title { font-size: 32px; }
  .k-hero-sub { font-size: 16px; }
  .k-tiles-section { padding-bottom: 48px; }
  .k-footer-inner { flex-direction: column; text-align: center; }
  .k-footer-btn { width: 100%; }
  .header { padding: 0 16px !important; }
  .k-page-title { font-size: 26px; }
  .k-content-card { padding: 24px 20px; }
  .section-tree .section { padding: 20px 22px; }

  .header .user-name { display: none; }
  .footer-inner { flex-direction: column; text-align: center; }
  .k-header-btn { padding: 8px 14px !important; font-size: 13px !important; }
  .header .header-link { padding: 6px 8px !important; font-size: 13px !important; }
  .header-btn-outline { padding: 7px 12px !important; font-size: 13px !important; }
  .header .nav-wrapper { gap: 8px !important; }

  /* Collapse "Mes demandes" text on very small screens, keep the link */
}

@media (max-width: 480px) {
  .header .header-link { display: none !important; }
  .k-header-btn span,
  .k-header-btn { font-size: 12px !important; padding: 8px 12px !important; }
}

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

/* ============================================================
   COMPONENTS — buttons, forms, tables, community, profile, etc.
   ============================================================ */

/* ================================
   BUTTONS (Copenhagen native .button)
   ================================ */
.button,
button.button,
a.button,
.hbs-form input[type="submit"] {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  padding: 10px 20px !important;
  background: var(--k-primary) !important;
  color: var(--k-surface) !important;
  border: 1px solid var(--k-primary) !important;
  border-radius: var(--k-radius) !important;
  font-family: var(--k-font) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.2 !important;
  cursor: pointer !important;
  transition: background .2s, border-color .2s, transform .15s !important;
  text-decoration: none !important;
  white-space: nowrap;
}

.button:hover,
a.button:hover,
.hbs-form input[type="submit"]:hover {
  background: var(--k-primary-dark) !important;
  border-color: var(--k-primary-dark) !important;
  color: var(--k-surface) !important;
  transform: translateY(-1px) !important;
}

.button-large { padding: 12px 24px !important; font-size: 15px !important; }

.button-secondary {
  background: var(--k-surface) !important;
  color: var(--k-primary) !important;
  border-color: var(--k-border) !important;
}

.button-secondary:hover {
  background: var(--k-bg) !important;
  color: var(--k-primary-dark) !important;
  border-color: var(--k-border-hover) !important;
}

/* ================================
   FORMS
   ================================ */
.form, .hbs-form { max-width: 100%; }

.form-field { margin-bottom: 20px; }

.hbs-form label,
.form-field > label,
.form-field legend {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--k-text);
  margin-bottom: 6px;
}

.optional {
  color: var(--k-text-muted);
  font-weight: 400;
  margin-left: 4px;
  font-size: 12px;
}

/* Scoped to our Handlebars forms only — don't touch JS-rendered forms */
.hbs-form input[type="text"],
.hbs-form input[type="email"],
.hbs-form input[type="tel"],
.hbs-form input[type="url"],
.hbs-form input[type="password"],
.hbs-form input[type="number"],
.hbs-form textarea,
.hbs-form select,
.form-field input[type="text"],
.form-field input[type="email"],
.form-field textarea,
.form-field select,
.requests-table-toolbar input[type="search"],
.request-filter {
  width: 100%;
  padding: 10px 14px;
  font-family: var(--k-font);
  font-size: 14px;
  color: var(--k-text);
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  transition: border-color .15s, box-shadow .15s;
  outline: none;
}

.hbs-form input:focus,
.hbs-form textarea:focus,
.hbs-form select:focus,
.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus,
.requests-table-toolbar input:focus,
.request-filter:focus {
  border-color: var(--k-primary);
  box-shadow: 0 0 0 3px rgba(71,60,144,.12);
}

.hbs-form textarea,
.form-field textarea { min-height: 120px; resize: vertical; }

.hbs-form select,
.form-field select,
.request-filter {
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='none' stroke='%23636975' stroke-linecap='round' d='M3 4.5l2.6 2.6c.2.2.5.2.7 0L9 4.5'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  cursor: pointer;
}

/* Notifications */
.notification {
  padding: 12px 16px;
  border-radius: var(--k-radius);
  font-size: 14px;
  margin: 12px 0;
}

.notification-error {
  background: #fee2e2;
  color: #991b1b;
  border-left: 3px solid #dc2626;
}

.notification-inline { margin-top: 6px; font-size: 13px; }

/* ================================
   TABLES (Copenhagen native .table)
   ================================ */
.table {
  width: 100%;
  border-collapse: collapse;
  background: var(--k-surface);
  border-radius: var(--k-radius);
  overflow: hidden;
  box-shadow: var(--k-shadow);
  border: 1px solid var(--k-border);
}

.table thead th {
  background: var(--k-bg);
  padding: 14px 18px;
  text-align: left;
  font-size: 12px;
  font-weight: 600;
  color: var(--k-text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  border-bottom: 1px solid var(--k-border);
}

.table tbody td {
  padding: 14px 18px;
  font-size: 14px;
  color: var(--k-text);
  border-top: 1px solid var(--k-border);
  vertical-align: middle;
}

.table tbody tr:hover { background: var(--k-bg); }

.request-closed td { color: var(--k-text-muted); }

/* ================================
   STATUS LABELS
   ================================ */
.status-label {
  display: inline-block;
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 600;
  border-radius: var(--k-radius-pill);
  text-transform: uppercase;
  letter-spacing: .04em;
  white-space: nowrap;
}

.status-label-open,
.status-label-new { background: var(--k-lavender); color: var(--k-primary); }

.status-label-pending,
.status-label-hold { background: #fef3c7; color: #92400e; }

.status-label-solved,
.status-label-closed { background: #d1fae5; color: #065f46; }

.status-label-answered { background: var(--k-blue-gray); color: var(--k-primary); }

.status-label-pinned { background: var(--k-pink); color: var(--k-primary); }
.status-label-featured { background: var(--k-blue); color: var(--k-primary); }
.status-label-official { background: var(--k-primary); color: var(--k-surface); }
.status-label-pending-moderation { background: #fef3c7; color: #92400e; }

/* ================================
   STRIPED LIST (community posts/topics)
   ================================ */
.striped-list {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow);
  overflow: hidden;
  margin-bottom: 24px;
}

.striped-list ul { list-style: none; padding: 0; margin: 0; }

.striped-list-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 24px;
  border-top: 1px solid var(--k-border);
  transition: background .15s;
}

.striped-list > ul > li:first-child .striped-list-item { border-top: none; }

.striped-list-item:hover { background: var(--k-bg); }

.striped-list-info { flex: 1; min-width: 0; }

.striped-list-title {
  display: block;
  color: var(--k-text) !important;
  font-weight: 600;
  font-size: 15px;
  margin-bottom: 4px;
  transition: color .15s;
}

.striped-list-title:hover { color: var(--k-primary) !important; }

.striped-list-count {
  display: flex;
  gap: 18px;
  color: var(--k-text-muted);
  font-size: 12px;
  flex-shrink: 0;
}

.striped-list-count-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 48px;
}

.striped-list-number {
  font-size: 18px;
  font-weight: 700;
  color: var(--k-primary);
  line-height: 1;
}

.post-overview-item {
  display: inline-flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 4px;
}

.post-featured { background: rgba(151,208,242,.12); }

.no-posts-with-filter {
  padding: 32px;
  text-align: center;
  color: var(--k-text-muted);
}

/* ================================
   META DATA
   ================================ */
.meta-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
  font-size: 12px;
  color: var(--k-text-muted);
}

.meta-data { font-size: 12px; color: var(--k-text-muted); }

.meta-data + .meta-data::before {
  content: '•';
  margin-right: 8px;
  color: var(--k-border-hover);
}

/* ================================
   DROPDOWN (Copenhagen native)
   ================================ */
.dropdown { position: relative; display: inline-block; }

.dropdown > .dropdown-toggle,
.dropdown-toggle {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 8px 14px;
  color: var(--k-text);
  font-family: var(--k-font);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: border-color .15s, background .15s, color .15s;
}

.dropdown-toggle .title,
.dropdown-toggle h2.title {
  font-size: 14px;
  font-weight: 600;
  margin: 0;
}

.dropdown-toggle:hover {
  border-color: var(--k-primary);
  background: var(--k-bg);
  color: var(--k-primary);
}

.dropdown-chevron-icon { transition: transform .2s; }

.dropdown[aria-expanded="true"] .dropdown-chevron-icon,
.dropdown-toggle[aria-expanded="true"] .dropdown-chevron-icon { transform: rotate(180deg); }

.dropdown .dropdown-menu {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow-md);
  padding: 6px;
  min-width: 180px;
  z-index: 100;
}

.dropdown-menu-end { right: 0; left: auto; }

.dropdown-menu a,
.dropdown-menu button {
  display: block;
  width: 100%;
  text-align: left;
  padding: 8px 12px;
  color: var(--k-text) !important;
  font-size: 14px;
  border-radius: var(--k-radius-sm);
  background: none;
  border: none;
  cursor: pointer;
  transition: background .12s, color .12s;
  text-decoration: none !important;
}

.dropdown-menu a:hover,
.dropdown-menu button:hover {
  background: var(--k-bg);
  color: var(--k-primary) !important;
}

.dropdown-menu a[aria-checked="true"] {
  background: var(--k-lavender);
  color: var(--k-primary) !important;
  font-weight: 600;
}

/* ================================
   COLLAPSIBLE NAV (filter tabs)
   ================================ */
.collapsible-nav:not(.header .collapsible-nav) {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 4px;
  margin-bottom: 20px;
  display: inline-block;
}

.collapsible-nav-list {
  display: flex;
  gap: 2px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
}

.collapsible-nav-list a {
  display: block;
  padding: 8px 14px;
  color: var(--k-text-muted) !important;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--k-radius-sm);
  transition: background .15s, color .15s;
  text-decoration: none !important;
}

.collapsible-nav-list a:hover {
  background: var(--k-bg);
  color: var(--k-primary) !important;
}

.collapsible-nav-list .current a,
.collapsible-nav-list a[aria-current="page"] {
  background: var(--k-primary) !important;
  color: var(--k-surface) !important;
}

.collapsible-nav-toggle { display: none; }

@media (max-width: 640px) {
  .collapsible-nav-toggle {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    background: transparent;
    border: none;
    color: var(--k-primary);
    font-family: var(--k-font);
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
  }
  .collapsible-nav-toggle-icon.x-icon { display: none; }
  .collapsible-nav[aria-expanded="true"] .x-icon { display: inline; }
  .collapsible-nav[aria-expanded="true"] .chevron-icon { display: none; }
}

/* ================================
   COMMUNITY HERO (search header on community pages)
   ================================ */
.community-hero {
  background: var(--k-primary);
  padding: 56px 24px 72px;
  text-align: center;
  position: relative;
  overflow: hidden;
  margin-bottom: 36px;
}

.community-hero::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: var(--k-pink);
  opacity: .22;
  pointer-events: none;
}

.community-hero::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -60px;
  width: 260px; height: 260px;
  border-radius: 50%;
  background: var(--k-secondary);
  opacity: .28;
  pointer-events: none;
}

.community-hero .hero-inner {
  max-width: 620px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--k-surface);
  border-radius: var(--k-radius);
  padding: 4px 14px;
  box-shadow: var(--k-shadow-md);
}

.community-hero .hero-inner .search-icon { color: var(--k-text-muted); flex-shrink: 0; }

.community-hero input[type="search"],
.community-hero input[type="text"] {
  border: none !important;
  box-shadow: none !important;
  padding: 12px 0 !important;
  font-size: 15px !important;
  background: transparent !important;
}

.community-hero input:focus { box-shadow: none !important; }

/* ================================
   COMMUNITY HEADER (title + CTA row)
   ================================ */
.community-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.community-header .title,
.community-header h2.title {
  font-family: var(--k-font);
  font-size: 20px;
  font-weight: 700;
  color: var(--k-text);
  margin: 0;
}

.community-header .page-header-description,
.community-header .k-page-desc { flex: 1; min-width: 240px; }

.community-follow { display: inline-block; }

/* ================================
   TOPIC FILTER BAR
   ================================ */
.topic-header {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding: 10px 0 16px;
  border-bottom: 1px solid var(--k-border);
  margin-bottom: 18px;
}

.topic-filters { display: flex; gap: 10px; flex-wrap: wrap; }

/* ================================
   BLOCKS (topics grid)
   ================================ */
.blocks-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.blocks-item {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow);
  transition: transform .2s, box-shadow .2s, border-color .2s;
}

.blocks-item:hover {
  transform: translateY(-3px);
  box-shadow: var(--k-shadow-hover);
  border-color: var(--k-primary);
}

.blocks-item-link {
  display: block;
  padding: 22px 24px;
  color: var(--k-text) !important;
  text-decoration: none !important;
}

.blocks-item-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--k-font);
  font-size: 16px;
  font-weight: 600;
  color: var(--k-text);
  margin-bottom: 6px;
}

.blocks-item-description {
  display: block;
  font-size: 14px;
  color: var(--k-text-muted);
  line-height: 1.5;
  margin-bottom: 10px;
}

.blocks-item .meta-group li {
  list-style: none !important;
  color: var(--k-text-muted);
}

/* ================================
   POST PAGE (community_post_page)
   ================================ */
.post-container {
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: 28px;
  align-items: start;
}

@media (max-width: 960px) {
  .post-container { grid-template-columns: 1fr; }
}

.post {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow);
  padding: 32px 36px;
}

.post-header {
  padding-bottom: 18px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--k-border);
}

.post-title {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 10px;
}

.post-title h1 {
  font-family: var(--k-font);
  font-size: 24px;
  font-weight: 700;
  color: var(--k-text);
  letter-spacing: -.01em;
  margin: 0;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.post-author,
.post-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--k-text-muted);
  margin-bottom: 8px;
}

.post-body {
  font-size: 15px;
  line-height: 1.7;
  color: var(--k-text);
}

.post-body p { margin: 0 0 14px; }

/* ================================
   VOTE WIDGET
   ================================ */
.vote {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 8px 10px;
  background: var(--k-bg);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
}

.vote-up,
.vote-down {
  background: transparent;
  border: none;
  padding: 4px;
  cursor: pointer;
  color: var(--k-text-muted);
  transition: color .15s, transform .1s;
  border-radius: var(--k-radius-sm);
}

.vote-up:hover,
.vote-down:hover {
  color: var(--k-primary);
  background: var(--k-surface);
}

.vote-voted { color: var(--k-primary) !important; }

.vote-sum {
  font-size: 15px;
  font-weight: 700;
  color: var(--k-text);
  min-width: 20px;
  text-align: center;
}

/* ================================
   COMMENTS
   ================================ */
.comment-list {
  list-style: none;
  padding: 0;
  margin: 20px 0 0;
}

.comment {
  padding: 20px 0;
  border-top: 1px solid var(--k-border);
}

.comment:first-child { border-top: none; padding-top: 8px; }

.comment-wrapper {
  display: flex;
  gap: 14px;
}

.avatar,
.comment-avatar,
.profile-avatar {
  flex-shrink: 0;
  position: relative;
}

.user-avatar,
.comment-avatar .user-avatar,
.avatar .user-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

.comment-info { flex: 1; min-width: 0; }

.comment-author {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}

.comment-meta {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.comment-meta > span,
.comment-meta > span a {
  font-weight: 600 !important;
  color: var(--k-text) !important;
  font-size: 14px !important;
}

.comment-body {
  font-size: 14px;
  line-height: 1.65;
  color: var(--k-text);
  margin: 6px 0 8px;
}

.comment-body p { margin: 0 0 10px; }

.comment-callout {
  background: var(--k-lavender);
  border-radius: var(--k-radius);
  padding: 14px 18px;
  font-size: 14px;
  color: var(--k-text);
  margin: 16px 0;
}

.comment-form {
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--k-border);
  display: flex;
  gap: 14px;
}

.comment-container { flex: 1; }

.comment-show-container {
  display: block;
  width: 100%;
  padding: 14px 18px;
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  color: var(--k-text-muted);
  font-family: var(--k-font);
  font-size: 14px;
  text-align: left;
  cursor: pointer;
  transition: border-color .15s, color .15s, background .15s;
}

.comment-show-container:hover {
  border-color: var(--k-primary);
  color: var(--k-primary);
  background: var(--k-bg);
}

.comment-show-container.hidden { display: none; }

.comment-fields {
  display: none;
  flex-direction: column;
  gap: 12px;
}

.comment-fields.shown { display: flex; }

.comment-form-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.comment-ccs { margin-bottom: 8px; }

.request-submit-comment { margin-left: auto; }

/* ================================
   REQUEST PAGE (sidebar + body)
   ================================ */
.request-container {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 28px;
  align-items: start;
}

@media (max-width: 960px) {
  .request-container { grid-template-columns: 1fr; }
}

.request-main {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow);
  padding: 28px 32px;
}

.request-sidebar {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow);
  padding: 22px 24px;
}

.collapsible-sidebar-title {
  font-family: var(--k-font);
  font-size: 13px;
  font-weight: 700;
  color: var(--k-text-muted);
  text-transform: uppercase;
  letter-spacing: .05em;
  margin: 0 0 16px;
}

.collapsible-sidebar-toggle { display: none; }

.request-details {
  margin: 0 0 16px;
  padding: 0;
}

.request-details dt {
  font-size: 12px;
  color: var(--k-text-muted);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: .04em;
  margin-bottom: 3px;
}

.request-details dt + dt { margin-top: 12px; }

.request-details dd {
  font-size: 14px;
  color: var(--k-text);
  margin: 0 0 10px;
  word-wrap: break-word;
}

.request-details dd a { color: var(--k-primary) !important; font-weight: 500; }

.request-collaborators {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.request-follow-up {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--k-border);
}

/* ================================
   SEARCH RESULTS PAGE
   ================================ */
.search-results {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: 28px;
  align-items: start;
}

@media (max-width: 900px) {
  .search-results { grid-template-columns: 1fr; }
}

.search-results-sidebar {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 20px 18px;
}

.filters-in-section + .filters-in-section {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--k-border);
}

.sidenav-title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--k-text-muted);
  font-weight: 700;
  margin: 0 0 10px;
}

.multibrand-filter-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.sidenav-item {
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px !important;
  border-radius: var(--k-radius-sm);
  color: var(--k-text) !important;
  font-size: 14px !important;
  transition: background .12s, color .12s;
  text-decoration: none !important;
}

.sidenav-item:hover {
  background: var(--k-bg);
  color: var(--k-primary) !important;
}

.sidenav-item.current {
  background: var(--k-primary) !important;
  color: var(--k-surface) !important;
}

.sidenav-item .doc-count {
  font-size: 12px;
  color: var(--k-text-muted);
  margin-left: 8px;
}

.sidenav-item.current .doc-count { color: rgba(255,255,255,.75); }

.see-all-filters {
  margin-top: 10px;
  padding: 6px 10px;
  background: transparent;
  border: none;
  color: var(--k-primary);
  font-family: var(--k-font);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
}

.search-results-column {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.search-results-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.search-result,
.search-results-list > li {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 20px 24px;
  transition: border-color .15s, box-shadow .15s, transform .15s;
}

.search-result:hover,
.search-results-list > li:hover {
  border-color: var(--k-primary);
  box-shadow: var(--k-shadow);
  transform: translateY(-2px);
}

.search-result-title,
.search-result a {
  font-family: var(--k-font);
  font-size: 16px;
  font-weight: 600;
  color: var(--k-text) !important;
  display: block;
  margin-bottom: 4px;
  transition: color .15s;
}

.search-result-title:hover,
.search-result a:hover { color: var(--k-primary) !important; }

.search-result-body,
.search-result p {
  font-size: 14px;
  color: var(--k-text-muted);
  line-height: 1.5;
  margin: 0;
}

.no-results {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 48px 24px;
  text-align: center;
  color: var(--k-text-muted);
}

.no-results svg { margin: 0 auto 16px; display: block; }

.no-results .headline {
  font-size: 18px;
  font-weight: 600;
  color: var(--k-text);
  margin: 8px 0;
}

.no-results .action-prompt { margin-top: 6px; }

.no-results .action-prompt a { color: var(--k-primary) !important; font-weight: 500; }

/* ================================
   USER PROFILE
   ================================ */
.profile-header {
  background: var(--k-surface);
  border-bottom: 1px solid var(--k-border);
  padding: 36px 0;
  margin-bottom: 28px;
}

.profile-info {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  flex-wrap: wrap;
}

.profile-avatar .user-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 3px solid var(--k-surface);
  box-shadow: var(--k-shadow);
}

.basic-info { flex: 1; min-width: 240px; }

.community-name-and-title-badges {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.name,
h1.name {
  font-family: var(--k-font);
  font-size: 24px;
  font-weight: 700;
  color: var(--k-text);
  margin: 0;
}

.name a { color: var(--k-text) !important; }

.description {
  color: var(--k-text-muted);
  font-size: 14px;
  margin: 8px 0 0;
}

.profile-private-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background: var(--k-bg);
  color: var(--k-text-muted);
  border-radius: var(--k-radius-pill);
  font-size: 12px;
  font-weight: 500;
}

.options {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.profile-stats {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 14px 0 0;
}

.stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  list-style: none;
}

.stat-label {
  font-size: 11px;
  color: var(--k-text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 500;
}

.stat-value {
  font-family: var(--k-font);
  font-size: 18px;
  font-weight: 700;
  color: var(--k-text);
}

.profile-nav {
  background: var(--k-surface);
  border-bottom: 1px solid var(--k-border);
  margin-bottom: 24px;
}

.profile-section {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  box-shadow: var(--k-shadow);
  padding: 26px 32px;
  margin-bottom: 16px;
}

.profile-section-header {
  padding-bottom: 16px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--k-border);
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.profile-section-title {
  font-family: var(--k-font);
  font-size: 18px;
  font-weight: 700;
  color: var(--k-text);
  margin: 0;
}

.profile-section-description {
  font-size: 13px;
  color: var(--k-text-muted);
}

.profile-section-sorter { margin-left: auto; }

.profile-activity-list,
.profile-contribution-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.profile-activity,
.profile-contribution {
  display: flex;
  gap: 14px;
  padding: 16px 0;
  border-top: 1px solid var(--k-border);
}

.profile-activity-list > li:first-child,
.profile-contribution-list > li:first-child {
  border-top: none;
  padding-top: 0;
}

.profile-activity-icon,
.profile-contribution-icon {
  width: 34px;
  height: 34px;
  border-radius: var(--k-radius);
  background: var(--k-lavender);
  color: var(--k-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.profile-activity-header,
.profile-contribution-header {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}

.profile-activity-description {
  font-size: 14px;
  color: var(--k-text);
  margin: 0;
}

.profile-contribution-title {
  font-family: var(--k-font);
  font-size: 15px;
  font-weight: 600;
  margin: 0;
}

.profile-contribution-title a {
  color: var(--k-primary) !important;
  transition: color .15s;
}

.profile-contribution-title a:hover { color: var(--k-secondary) !important; }

.profile-contribution-body {
  font-size: 13px;
  color: var(--k-text-muted);
  line-height: 1.5;
  margin: 6px 0;
}

.profile-contribution-breadcrumbs {
  display: flex !important;
  flex-wrap: wrap;
  gap: 4px;
  font-size: 12px !important;
  padding: 0 !important;
  margin: 4px 0 !important;
}

.profile-contribution-breadcrumbs li a {
  color: var(--k-text-muted) !important;
  font-weight: 400 !important;
}

.profile-contribution-breadcrumbs li::after {
  content: '›' !important;
  margin: 0 4px !important;
  color: var(--k-border-hover) !important;
}

.profile-contribution-breadcrumbs li:last-child::after { content: none !important; }

.profile-activity-contribution {
  flex: 1;
  padding: 12px 14px;
  background: var(--k-bg);
  border-radius: var(--k-radius);
  margin-top: 4px;
}

.no-activity,
.private-activity {
  display: block;
  text-align: center;
  padding: 36px 20px;
  color: var(--k-text-muted);
  font-style: italic;
}

/* Badges in profile header */
.community-badge-titles,
.community-badge-achievements {
  display: inline-flex;
  gap: 6px;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
}

.community-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  background: var(--k-lavender);
  color: var(--k-primary);
  border-radius: var(--k-radius-pill);
  font-size: 12px;
  font-weight: 500;
  list-style: none;
}

.community-badge-achievement {
  background: transparent;
  padding: 0;
}

.community-badge-achievement img {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: block;
}

.community-badge-achievements-rest {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  background: var(--k-bg);
  border: 1px dashed var(--k-border-hover);
  border-radius: 50%;
  color: var(--k-text-muted) !important;
  font-size: 11px;
  font-weight: 600;
  text-decoration: none !important;
}

/* Big profile badges grid */
.profile-badges-items {
  list-style: none;
  padding: 0;
}

.profile-badges-item {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: 16px;
  align-items: center;
  padding: 16px 0;
  border-top: 1px solid var(--k-border);
}

.profile-badges-item:first-child { border-top: none; padding-top: 0; }

.profile-badges-item .badge {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: block;
}

.profile-badges-item-title {
  font-weight: 600;
  color: var(--k-text);
  margin-bottom: 2px;
  font-size: 14px;
}

.profile-badges-item-description {
  font-size: 13px;
  color: var(--k-text-muted);
  margin: 0;
  line-height: 1.5;
}

.profile-badges-item-metadata { text-align: right; }

.profile-badges-item-metadata-title {
  font-size: 11px;
  color: var(--k-text-muted);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.profile-badges-item-metadata-description {
  font-size: 13px;
  color: var(--k-text);
  margin: 2px 0 0;
}

/* ================================
   PAGINATION
   ================================ */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 6px;
  margin: 32px 0;
  list-style: none;
  padding: 0;
}

.pagination a,
.pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  border-radius: var(--k-radius-sm);
  font-size: 14px;
  font-weight: 500;
  color: var(--k-text) !important;
  transition: background .12s, color .12s;
  text-decoration: none !important;
}

.pagination a:hover {
  background: var(--k-bg);
  color: var(--k-primary) !important;
}

.pagination .current,
.pagination [aria-current],
.pagination a[aria-current="page"] {
  background: var(--k-primary) !important;
  color: var(--k-surface) !important;
}

.pagination .disabled { opacity: .4; pointer-events: none; }

/* ================================
   ATTACHMENTS
   ================================ */
.attachments {
  list-style: none;
  padding: 0;
  margin: 12px 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.attachment-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--k-bg);
  border-radius: var(--k-radius);
  font-size: 13px;
}

.attachment-icon { color: var(--k-text-muted); flex-shrink: 0; }

.attachment-item a {
  color: var(--k-primary) !important;
  font-weight: 500;
  word-break: break-word;
}

.attachment-item a:hover { color: var(--k-secondary) !important; }

.attachment-meta {
  margin-left: auto;
  display: flex;
  gap: 10px;
  font-size: 12px;
  color: var(--k-text-muted);
  flex-shrink: 0;
}

.attachment-meta-item:first-child { font-weight: 400; }

/* ================================
   MY ACTIVITIES (requests / contributions / subscriptions)
   ================================ */
.my-activities-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.my-activities-sub-nav { margin-top: 12px; }

.my-activities-nav {
  background: var(--k-surface);
  border-bottom: 1px solid var(--k-border);
  margin-bottom: 0;
  padding: 0;
}

.my-activities-nav .collapsible-nav {
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  display: block;
  border-radius: 0;
}

.my-activities-nav .collapsible-nav-list {
  gap: 0;
  border-bottom: none;
}

.my-activities-nav .collapsible-nav-list a {
  padding: 16px 0;
  margin-right: 24px;
  border-radius: 0;
  border-bottom: 2px solid transparent;
  color: var(--k-text-muted) !important;
}

.my-activities-nav .collapsible-nav-list a:hover {
  background: transparent;
  color: var(--k-primary) !important;
}

.my-activities-nav .collapsible-nav-list .current a,
.my-activities-nav .collapsible-nav-list a[aria-current="page"] {
  background: transparent !important;
  color: var(--k-primary) !important;
  border-bottom-color: var(--k-primary);
}

.my-activities-following-header {
  margin: 14px 0 18px;
}

.requests-table-toolbar {
  display: flex !important;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  padding: 14px 0 18px;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--k-border);
  background: transparent !important;
  border-top: none !important;
  border-left: none !important;
  border-right: none !important;
  box-shadow: none !important;
}

.requests-table-toolbar .search {
  position: relative;
  flex: 1;
  min-width: 240px;
}

.requests-table-toolbar .search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--k-text-muted);
  pointer-events: none;
  z-index: 2;
}

.requests-search { padding-left: 36px !important; }

.request-table-filter {
  display: flex;
  align-items: center;
  gap: 8px;
}

.request-filter-label {
  font-size: 13px;
  color: var(--k-text-muted);
  margin: 0;
  white-space: nowrap;
}

.request-filter {
  width: auto;
  min-width: 140px;
}

.requests-search-info {
  padding: 8px 0;
  font-size: 13px;
  color: var(--k-text-muted);
}

.no-activities {
  background: var(--k-surface);
  border: 1px dashed var(--k-border);
  border-radius: var(--k-radius);
  padding: 32px 24px;
  text-align: center;
  color: var(--k-text-muted);
  font-style: italic;
}

/* ================================
   SEARCH CONTAINER (inline search inside inner pages)
   ================================ */
.search-container {
  position: relative;
  margin-bottom: 18px;
  max-width: 480px;
}

.search-container .search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--k-text-muted);
  pointer-events: none;
  z-index: 2;
}

.search-container input[type="search"],
.search-container input[type="text"] {
  width: 100%;
  padding: 11px 16px 11px 40px !important;
  background: var(--k-surface) !important;
  border: 1px solid var(--k-border) !important;
  border-radius: var(--k-radius) !important;
  font-size: 14px !important;
  box-shadow: none !important;
}

.search-container input:focus {
  border-color: var(--k-primary) !important;
  box-shadow: 0 0 0 3px rgba(71,60,144,.12) !important;
}

/* ================================
   POST SIDEBAR (right column on post page)
   ================================ */
.post-sidebar {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 22px 24px;
}

.post-sidebar-title {
  font-family: var(--k-font);
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--k-text-muted);
  margin: 0 0 14px;
}

/* ================================
   COMMUNITY FOOTER (new-post CTA on community pages)
   ================================ */
.community-footer {
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  padding: 28px 32px;
  text-align: center;
  margin-top: 28px;
}

.community-footer-title {
  font-family: var(--k-font);
  font-size: 18px;
  font-weight: 700;
  color: var(--k-text);
  margin: 0 0 14px;
}

/* ================================
   FEATURED POSTS (side block)
   ================================ */
.community-featured-posts {
  background: var(--k-lavender);
  border-radius: var(--k-radius);
  padding: 22px 26px;
  margin-top: 24px;
}

.community-featured-posts .title,
.community-featured-posts h2 {
  font-family: var(--k-font);
  font-size: 15px;
  font-weight: 700;
  color: var(--k-primary);
  margin: 0 0 12px;
  text-transform: uppercase;
  letter-spacing: .04em;
}

.promoted-articles {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.promoted-articles-item a {
  display: block;
  padding: 8px 12px;
  color: var(--k-primary) !important;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--k-radius-sm);
  transition: background .12s;
  text-decoration: none !important;
}

.promoted-articles-item a:hover {
  background: var(--k-surface);
}

/* Recent community activity */
.community-activity { margin-top: 24px; }

/* ================================
   ERROR PAGE
   ================================ */
.error-page {
  text-align: center;
  padding: 56px 24px;
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  max-width: 640px;
  margin: 0 auto;
}

.error-page h1,
.error-page .k-page-title {
  font-family: var(--k-font);
  font-size: 56px;
  font-weight: 800;
  color: var(--k-primary);
  margin: 0 0 16px;
  letter-spacing: -.02em;
}

.error-page h2 {
  font-family: var(--k-font);
  font-size: 20px;
  font-weight: 600;
  color: var(--k-text);
  margin-bottom: 12px;
}

.error-page p {
  color: var(--k-text-muted);
  margin-bottom: 24px;
  font-size: 15px;
}

.error-page a {
  display: inline-block;
  margin-top: 8px;
  color: var(--k-primary) !important;
  font-weight: 500;
}

.error-page a:hover { color: var(--k-secondary) !important; }

/* ================================
   SUGGESTION LIST (new community post)
   ================================ */
.suggestion-list {
  list-style: none;
  padding: 0;
  margin: 8px 0 16px;
}

.suggestion-list li a {
  display: block;
  padding: 10px 14px;
  background: var(--k-bg);
  border-radius: var(--k-radius-sm);
  color: var(--k-primary) !important;
  font-size: 13px;
  margin-bottom: 4px;
  transition: background .12s;
}

.suggestion-list li a:hover { background: var(--k-lavender); }

/* ================================
   UTILITIES
   ================================ */
.visibility-hidden {
  position: absolute !important;
  clip: rect(0 0 0 0) !important;
  width: 1px !important;
  height: 1px !important;
  margin: -1px !important;
  padding: 0 !important;
  border: 0 !important;
  overflow: hidden !important;
}

.ccs-input,
.token-input {
  width: 100%;
  padding: 10px 14px;
  background: var(--k-surface);
  border: 1px solid var(--k-border);
  border-radius: var(--k-radius);
  font-family: var(--k-font);
  font-size: 14px;
}

/* Hide Copenhagen's hidden elements cleanly */
.hidden { display: none !important; }

/* Content tags hint */
.content-tags-add-hint {
  display: block;
  font-size: 12px;
  color: var(--k-text-muted);
  margin-bottom: 8px;
}

/* ================================
   RESPONSIVE TWEAKS (components)
   ================================ */
@media (max-width: 640px) {
  .post,
  .request-main,
  .request-sidebar,
  .profile-section { padding: 22px 20px !important; }

  .search-results-sidebar { padding: 16px 14px; }
  .profile-badges-item { grid-template-columns: 48px 1fr; }
  .profile-badges-item-metadata { grid-column: 1 / -1; text-align: left; margin-top: 4px; }
  .profile-avatar .user-avatar { width: 60px; height: 60px; }
  .name, h1.name { font-size: 20px; }
  .stat-value { font-size: 16px; }

  .striped-list-item { flex-direction: column; align-items: flex-start; gap: 10px; padding: 16px 18px; }
  .striped-list-count { align-self: stretch; justify-content: flex-start; }

  .table { font-size: 13px; }
  .table thead { display: none; }
  .table,
  .table tbody,
  .table tr,
  .table td { display: block; width: 100%; }
  .table tr {
    border-top: 1px solid var(--k-border);
    padding: 14px 18px;
  }
  .table tr:first-child { border-top: none; }
  .table td { padding: 4px 0; border: none; }
  .table td:first-child { font-weight: 600; }
}
