/**
 * ManCountability Theme
 * A warm, masculine aesthetic for men's accountability forum
 *
 * Design Principles:
 * - Earthy, natural palette (deep browns, slate grays, warm whites)
 * - Strong, readable typography (Inter font family)
 * - Warm minimalism with purposeful whitespace
 * - Mobile-first responsive design
 * - Subtle, confident animations
 */

/* ========================================
   CSS Custom Properties (Design Tokens)
   ======================================== */

:root {
  /* Primary Colors - Earthy Browns */
  --mc-brown-900: #2D1F14;
  --mc-brown-800: #3D2B1F;
  --mc-brown-700: #4E3629;
  --mc-brown-600: #5F4233;
  --mc-brown-500: #6B4D3A;
  --mc-brown-400: #8B6B4A;
  --mc-brown-300: #A68B5B;
  --mc-brown-200: #C4A97A;
  --mc-brown-100: #E2D1B3;
  --mc-brown-50: #F5EDE0;

  /* Neutral Colors - Slate Grays */
  --mc-slate-900: #1A1D21;
  --mc-slate-800: #2D3239;
  --mc-slate-700: #3E444D;
  --mc-slate-600: #4F5660;
  --mc-slate-500: #6B7280;
  --mc-slate-400: #9CA3AF;
  --mc-slate-300: #D1D5DB;
  --mc-slate-200: #E5E7EB;
  --mc-slate-100: #F3F4F6;
  --mc-slate-50: #F9FAFB;

  /* Warm Whites */
  --mc-cream-100: #FFFBF5;
  --mc-cream-200: #FFF8ED;
  --mc-cream-300: #FFF5E6;
  --mc-cream-400: #FFEFD6;

  /* Accent Colors - For status and highlights */
  --mc-success: #3D7B4A;
  --mc-success-light: #E8F5EA;
  --mc-warning: #B8860B;
  --mc-warning-light: #FDF6E3;
  --mc-error: #A33D3D;
  --mc-error-light: #FDEDED;
  --mc-info: #3D5A80;
  --mc-info-light: #E8F0F5;

  /* Semantic Color Assignments */
  --mc-primary: var(--mc-brown-600);
  --mc-primary-hover: var(--mc-brown-700);
  --mc-primary-active: var(--mc-brown-800);
  --mc-primary-light: var(--mc-brown-100);

  --mc-secondary: var(--mc-slate-600);
  --mc-secondary-hover: var(--mc-slate-700);
  --mc-secondary-light: var(--mc-slate-100);

  --mc-background: #F5EDE0; /* Light Brown / mc-brown-50 */
  --mc-background-alt: #E2D1B3; /* mc-brown-100 */
  --mc-surface: #FCF9F5;
  --mc-surface-elevated: #FFFFFF;

  --mc-text-primary: #2D1F14; /* Deep Brown for readability */
  --mc-text-secondary: #4E3629;
  --mc-text-muted: #6B4D3A;
  --mc-text-inverse: #FFFFFF;

  --mc-border: #D1C4B0;
  --mc-border-light: #E8DFD0;
  --mc-border-dark: #B5A68D;

  /* Typography */
  --mc-font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
  --mc-font-family-mono: 'SF Mono', 'Monaco', 'Inconsolata', 'Fira Mono', 'Droid Sans Mono', 'Source Code Pro', monospace;

  /* Font Sizes */
  --mc-text-xs: 0.75rem;
  --mc-text-sm: 0.875rem;
  --mc-text-base: 1rem;
  --mc-text-lg: 1.125rem;
  --mc-text-xl: 1.25rem;
  --mc-text-2xl: 1.5rem;
  --mc-text-3xl: 1.875rem;
  --mc-text-4xl: 2.25rem;

  /* Font Weights */
  --mc-font-normal: 400;
  --mc-font-medium: 500;
  --mc-font-semibold: 600;
  --mc-font-bold: 700;

  /* Line Heights */
  --mc-leading-tight: 1.25;
  --mc-leading-normal: 1.5;
  --mc-leading-relaxed: 1.625;

  /* Spacing */
  --mc-space-1: 0.25rem;
  --mc-space-2: 0.5rem;
  --mc-space-3: 0.75rem;
  --mc-space-4: 1rem;
  --mc-space-5: 1.25rem;
  --mc-space-6: 1.5rem;
  --mc-space-8: 2rem;
  --mc-space-10: 2.5rem;
  --mc-space-12: 3rem;
  --mc-space-16: 4rem;

  /* Border Radius */
  --mc-radius-sm: 0.25rem;
  --mc-radius: 0.375rem;
  --mc-radius-md: 0.5rem;
  --mc-radius-lg: 0.75rem;
  --mc-radius-xl: 1rem;
  --mc-radius-full: 9999px;

  /* Shadows */
  --mc-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --mc-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px -1px rgba(0, 0, 0, 0.1);
  --mc-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -2px rgba(0, 0, 0, 0.1);
  --mc-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);

  /* Transitions */
  --mc-transition-fast: 150ms ease;
  --mc-transition: 200ms ease;
  --mc-transition-slow: 300ms ease;
}

/* ========================================
   Google Fonts Import - Inter
   ======================================== */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/icon?family=Material+Icons');

/* ========================================
   Base Styles
   ======================================== */

html {
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--mc-font-family) !important;
  background-color: var(--mc-background) !important;
  color: var(--mc-text-primary) !important;
  line-height: var(--mc-leading-normal);
}

/* ========================================
   Typography Overrides
   ======================================== */

h1, .h1{
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-semibold);
  color: var(--mc-slate-300);
  line-height: var(--mc-leading-tight);
}

h2, h3, h4, h5, h6,
.h2, .h3, .h4, .h5, .h6 {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-semibold);
  color: var(--mc-text-primary);
  line-height: var(--mc-leading-tight);
}

h1, .h1 { font-size: var(--mc-text-3xl); margin-left:15px !important; color:cream; }
h2, .h2 { font-size: var(--mc-text-2xl); }
h3, .h3 { font-size: var(--mc-text-xl); }
h4, .h4 { font-size: var(--mc-text-lg); }
h5, .h5 { font-size: var(--mc-text-base); font-weight: var(--mc-font-semibold); }
h6, .h6 { font-size: var(--mc-text-sm); font-weight: var(--mc-font-semibold); }

p {
  color: var(--mc-text-secondary);
  line-height: var(--mc-leading-relaxed);
}

a {
  color: var(--mc-brown-600); /* Medium Brown */
  text-decoration: none;
  transition: color var(--mc-transition-fast);
}

a:hover,
a:focus {
  color: var(--mc-brown-800);
  text-decoration: underline;
}

/* ========================================
   Navbar / Navigation
   ======================================== */

.navbar,
.navbar-misago,
.misago-navbar {
  background-color: var(--mc-brown-800) !important;
  border-bottom: 1px solid var(--mc-brown-700);
  box-shadow: var(--mc-shadow-sm);
}

.navbar-brand,
.navbar .brand,
.site-branding {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-bold);
  color: var(--mc-cream-100) !important;
  letter-spacing: -0.02em;
}

.navbar a,
.navbar .nav-link,
.navbar-nav .nav-link {
  color: var(--mc-cream-200) !important;
  font-weight: var(--mc-font-medium);
  transition: color var(--mc-transition-fast);
}

.navbar a:hover,
.navbar .nav-link:hover,
.navbar-nav .nav-link:hover {
  color: #FFFFFF !important;
  text-decoration: none;
}

.navbar .nav-link.active,
.navbar-nav .nav-link.active {
  color: #FFFFFF !important;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: var(--mc-radius);
}

/* User menu / dropdown */
.navbar .dropdown-menu,
.user-nav-dropdown {
  background-color: var(--mc-brown-800);
  border: 1px solid var(--mc-brown-700);
  border-radius: var(--mc-radius-md);
  box-shadow: var(--mc-shadow-lg);
}

.navbar .dropdown-item {
  color: var(--mc-text-inverse);
  padding: var(--mc-space-2) var(--mc-space-4);
}

.navbar .dropdown-item:hover {
  background-color: var(--mc-brown-700);
  color: var(--mc-cream-100);
}

/* ========================================
   Jumbotron / Header Banner
   ======================================== */

.jumbotron,
.page-header-banner,
.hero-section {
  background: linear-gradient(135deg, var(--mc-brown-700) 0%, var(--mc-brown-800) 100%) !important;
  color: var(--mc-cream-100) !important;
  border-bottom: 3px solid var(--mc-brown-400);
}

.jumbotron h1,
.jumbotron h2,
.jumbotron .title {
  color: #FFFFFF !important;
  font-weight: var(--mc-font-bold);
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}

.jumbotron p,
.jumbotron .lead {
  color: var(--mc-cream-200) !important;
}

/* ========================================
   Buttons
   ======================================== */

.btn {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-medium);
  border-radius: var(--mc-radius);
  padding: var(--mc-space-2) var(--mc-space-4);
  transition: all var(--mc-transition-fast);
  text-transform: none;
  letter-spacing: 0;
}

/* Primary Button - Medium Brown */
.btn-primary {
  background-color: var(--mc-brown-600) !important;
  border-color: var(--mc-brown-600) !important;
  color: #FFFFFF !important;
}

.btn-primary:hover,
.btn-primary:focus {
  background-color: var(--mc-brown-700) !important;
  border-color: var(--mc-brown-700) !important;
  box-shadow: var(--mc-shadow-md);
  transform: translateY(-1px);
}

.btn-primary:active {
  background-color: var(--mc-brown-800) !important;
  border-color: var(--mc-brown-800) !important;
  transform: translateY(0);
}

/* Secondary Button */
.btn-secondary,
.btn-default {
  background-color: var(--mc-surface) !important;
  border-color: var(--mc-border) !important;
  color: var(--mc-text-primary) !important;
}

.btn-secondary:hover,
.btn-secondary:focus,
.btn-default:hover,
.btn-default:focus {
  background-color: var(--mc-slate-50) !important;
  border-color: var(--mc-border-dark) !important;
  color: var(--mc-text-primary) !important;
}

/* Success Button */
.btn-success {
  background-color: var(--mc-success) !important;
  border-color: var(--mc-success) !important;
  color: #FFFFFF !important;
}

.btn-success:hover,
.btn-success:focus {
  background-color: #2D5E38 !important;
  border-color: #2D5E38 !important;
}

/* Warning Button */
.btn-warning {
  background-color: var(--mc-warning) !important;
  border-color: var(--mc-warning) !important;
  color: #FFFFFF !important;
}

/* Danger Button */
.btn-danger {
  background-color: var(--mc-error) !important;
  border-color: var(--mc-error) !important;
  color: #FFFFFF !important;
}

/* Outline Buttons */
.btn-outline-primary {
  color: var(--mc-primary) !important;
  border-color: var(--mc-primary) !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover {
  background-color: var(--mc-primary) !important;
  color: #FFFFFF !important;
}

/* ========================================
   Cards & Panels
   ======================================== */

.card,
.panel,
.thread-card,
.post-card {
  background-color: var(--mc-surface);
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius-lg);
  box-shadow: var(--mc-shadow-sm);
  transition: box-shadow var(--mc-transition);
}

.card:hover,
.panel:hover,
.thread-card:hover {
  box-shadow: var(--mc-shadow-md);
}

.card-header,
.panel-heading {
  background-color: var(--mc-background-alt);
  border-bottom: 1px solid var(--mc-border);
  font-weight: var(--mc-font-semibold);
  padding: var(--mc-space-4);
}

.card-body,
.panel-body {
  padding: var(--mc-space-4);
}

.card-footer,
.panel-footer {
  background-color: var(--mc-slate-50);
  border-top: 1px solid var(--mc-border);
  padding: var(--mc-space-3) var(--mc-space-4);
}

/* ========================================
   Forum Categories List
   ======================================== */

.categories-list,
.category-list,
.forum-categories {
  background-color: var(--mc-surface);
  border-radius: var(--mc-radius-lg);
  overflow: hidden;
}

.category-card,
.category-item,
.forum-category {
  border-bottom: 1px solid var(--mc-border-light);
  padding: var(--mc-space-4);
  transition: background-color var(--mc-transition-fast);
}

.category-card:hover,
.category-item:hover {
  background-color: var(--mc-brown-50);
}

.category-card:last-child,
.category-item:last-child {
  border-bottom: none;
}

.category-name,
.category-title {
  font-weight: var(--mc-font-semibold);
  color: var(--mc-brown-700);
  font-size: var(--mc-text-lg);
}

.category-description {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
  margin-top: var(--mc-space-1);
}

.category-stats,
.category-meta {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
}

/* ========================================
   Threads List
   ======================================== */

.threads-list,
.thread-list {
  background-color: var(--mc-surface);
  border-radius: var(--mc-radius-lg);
  box-shadow: var(--mc-shadow-sm);
}

.thread-row,
.thread-item {
  border-bottom: 1px solid var(--mc-border-light);
  padding: var(--mc-space-4);
  transition: background-color var(--mc-transition-fast);
}

.thread-row:hover,
.thread-item:hover {
  background-color: var(--mc-cream-200);
}

.thread-row:last-child,
.thread-item:last-child {
  border-bottom: none;
}

.thread-title,
.thread-name {
  font-weight: var(--mc-font-medium);
  color: var(--mc-text-primary);
  font-size: var(--mc-text-base);
}

.thread-title:hover,
.thread-name:hover {
  color: var(--mc-primary);
}

.thread-meta,
.thread-info {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
}

/* Thread badges/labels */
.thread-badge,
.label,
.badge {
  font-size: var(--mc-text-xs);
  font-weight: var(--mc-font-medium);
  padding: var(--mc-space-1) var(--mc-space-2);
  border-radius: var(--mc-radius-sm);
}

.badge-primary,
.label-primary {
  background-color: var(--mc-primary-light);
  color: var(--mc-primary);
}

/* ========================================
   Posts & Comments
   ======================================== */

.post,
.post-container,
.forum-post {
  background-color: var(--mc-surface);
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius-lg);
  margin-bottom: var(--mc-space-4);
  overflow: hidden;
}

.post-header,
.post-meta {
  background-color: var(--mc-cream-100);
  padding: var(--mc-space-3) var(--mc-space-4);
  border-bottom: 1px solid var(--mc-border-light);
}

.post-author,
.post-username {
  font-weight: var(--mc-font-semibold);
  color: var(--mc-brown-700);
}

.post-date,
.post-time {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
}

.post-body,
.post-content {
  padding: var(--mc-space-4);
  line-height: var(--mc-leading-relaxed);
  color: var(--mc-text-primary);
}

.post-body p {
  margin-bottom: var(--mc-space-4);
}

.post-body p:last-child {
  margin-bottom: 0;
}

.post-footer,
.post-actions {
  padding: var(--mc-space-3) var(--mc-space-4);
  background-color: var(--mc-slate-50);
  border-top: 1px solid var(--mc-border-light);
}

/* Post reactions/likes */
.post-likes,
.post-reactions {
  display: flex;
  align-items: center;
  gap: var(--mc-space-2);
}

.like-btn,
.reaction-btn {
  color: var(--mc-text-muted);
  transition: color var(--mc-transition-fast);
}

.like-btn:hover,
.reaction-btn:hover {
  color: var(--mc-primary);
}

.like-btn.liked,
.reaction-btn.active {
  color: var(--mc-primary);
}

/* ========================================
   User Profiles / Avatars
   ======================================== */

.avatar,
.user-avatar {
  border-radius: var(--mc-radius-full);
  border: 2px solid var(--mc-border);
}

.avatar-sm { width: 32px; height: 32px; }
.avatar-md { width: 48px; height: 48px; }
.avatar-lg { width: 64px; height: 64px; }
.avatar-xl { width: 96px; height: 96px; }

.user-card,
.profile-card {
  background-color: var(--mc-surface);
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius-lg);
  padding: var(--mc-space-6);
  text-align: center;
}

.user-name,
.profile-name {
  font-weight: var(--mc-font-bold);
  color: var(--mc-text-primary);
  font-size: var(--mc-text-xl);
  margin-top: var(--mc-space-4);
}

.user-title,
.profile-title,
.user-rank {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
}

.user-stats,
.profile-stats {
  display: flex;
  justify-content: center;
  gap: var(--mc-space-6);
  margin-top: var(--mc-space-4);
  padding-top: var(--mc-space-4);
  border-top: 1px solid var(--mc-border);
}

.stat-value {
  font-weight: var(--mc-font-bold);
  color: var(--mc-brown-700);
  font-size: var(--mc-text-lg);
}

.stat-label {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* ========================================
   Forms & Inputs
   ======================================== */

.form-control,
.form-input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="search"],
textarea,
select {
  font-family: var(--mc-font-family) !important;
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius);
  padding: var(--mc-space-2) var(--mc-space-3);
  transition: border-color var(--mc-transition-fast), box-shadow var(--mc-transition-fast);
  background-color: var(--mc-surface);
}

.form-control:focus,
.form-input:focus,
input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
textarea:focus {
  border-color: var(--mc-primary);
  box-shadow: 0 0 0 3px rgba(95, 66, 51, 0.15);
  outline: none;
}

.form-control::placeholder,
input::placeholder,
textarea::placeholder {
  color: var(--mc-text-muted);
}

label,
.form-label {
  font-weight: var(--mc-font-medium);
  color: var(--mc-text-primary);
  margin-bottom: var(--mc-space-1);
  display: block;
}

.form-group {
  margin-bottom: var(--mc-space-4);
}

/* Form validation states */
.is-invalid,
.form-control.error {
  border-color: var(--mc-error) !important;
}

.is-valid,
.form-control.success {
  border-color: var(--mc-success) !important;
}

.invalid-feedback,
.error-message {
  color: var(--mc-error);
  font-size: var(--mc-text-sm);
  margin-top: var(--mc-space-1);
}

/* ========================================
   Alerts & Notifications
   ======================================== */

.alert {
  border-radius: var(--mc-radius);
  padding: var(--mc-space-4);
  border: none;
  border-left: 4px solid;
}

.alert-success {
  background-color: var(--mc-success-light);
  border-color: var(--mc-success);
  color: var(--mc-success);
}

.alert-warning {
  background-color: var(--mc-warning-light);
  border-color: var(--mc-warning);
  color: #8B6914;
}

.alert-danger,
.alert-error {
  background-color: var(--mc-error-light);
  border-color: var(--mc-error);
  color: var(--mc-error);
}

.alert-info {
  background-color: var(--mc-info-light);
  border-color: var(--mc-info);
  color: var(--mc-info);
}

/* ========================================
   Pagination
   ======================================== */

.pagination {
  display: flex;
  gap: var(--mc-space-1);
  justify-content: center;
  margin: var(--mc-space-6) 0;
}

.page-link,
.pagination a {
  padding: var(--mc-space-2) var(--mc-space-3);
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius);
  color: var(--mc-text-primary);
  background-color: var(--mc-surface);
  transition: all var(--mc-transition-fast);
}

.page-link:hover,
.pagination a:hover {
  background-color: var(--mc-brown-50);
  border-color: var(--mc-primary);
  color: var(--mc-primary);
  text-decoration: none;
}

.page-item.active .page-link,
.pagination .active a {
  background-color: var(--mc-primary);
  border-color: var(--mc-primary);
  color: #FFFFFF;
}

.page-item.disabled .page-link,
.pagination .disabled a {
  color: var(--mc-text-muted);
  pointer-events: none;
  opacity: 0.5;
}

/* ========================================
   Footer
   ======================================== */

footer,
.footer,
.site-footer {
  background-color: var(--mc-slate-800);
  color: var(--mc-slate-300);
  padding: var(--mc-space-8) 0;
  margin-top: var(--mc-space-12);
}

footer a,
.footer a {
  color: var(--mc-slate-300);
}

footer a:hover,
.footer a:hover {
  color: #FFFFFF;
}

.footer-brand,
.footer-logo {
  font-weight: var(--mc-font-bold);
  color: #FFFFFF;
  font-size: var(--mc-text-xl);
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li {
  margin-bottom: var(--mc-space-2);
}

.footer-copyright {
  color: var(--mc-slate-400);
  font-size: var(--mc-text-sm);
  margin-top: var(--mc-space-6);
  padding-top: var(--mc-space-6);
  border-top: 1px solid var(--mc-slate-700);
}

/* ========================================
   Modals
   ======================================== */

.modal-content {
  border: none;
  border-radius: var(--mc-radius-lg);
  box-shadow: var(--mc-shadow-lg);
}

.modal-header {
  background-color: var(--mc-slate-50);
  border-bottom: 1px solid var(--mc-border);
  border-radius: var(--mc-radius-lg) var(--mc-radius-lg) 0 0;
  padding: var(--mc-space-4);
}

.modal-title {
  font-weight: var(--mc-font-semibold);
  color: var(--mc-text-primary);
}

.modal-body {
  padding: var(--mc-space-6);
}

.modal-footer {
  background-color: var(--mc-slate-50);
  border-top: 1px solid var(--mc-border);
  border-radius: 0 0 var(--mc-radius-lg) var(--mc-radius-lg);
  padding: var(--mc-space-4);
}

/* ========================================
   Search
   ======================================== */

.search-form,
.search-box {
  position: relative;
}

.search-input {
  padding-left: var(--mc-space-10);
  padding-right: var(--mc-space-4);
}

.search-icon {
  position: absolute;
  left: var(--mc-space-3);
  top: 50%;
  transform: translateY(-50%);
  color: var(--mc-text-muted);
}

/* ========================================
   Loading States
   ======================================== */

.spinner,
.loading {
  color: var(--mc-primary);
}

.skeleton,
.placeholder {
  background: linear-gradient(90deg, var(--mc-slate-100) 25%, var(--mc-slate-200) 50%, var(--mc-slate-100) 75%);
  background-size: 200% 100%;
  animation: skeleton-loading 1.5s infinite;
  border-radius: var(--mc-radius);
}

@keyframes skeleton-loading {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ========================================
   Breadcrumbs
   ======================================== */

.breadcrumb {
  background-color: transparent;
  padding: var(--mc-space-3) 0;
  margin-bottom: var(--mc-space-4);
}

.breadcrumb-item {
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
}

.breadcrumb-item a {
  color: var(--mc-text-secondary);
}

.breadcrumb-item a:hover {
  color: var(--mc-primary);
}

.breadcrumb-item.active {
  color: var(--mc-text-primary);
}

.breadcrumb-item + .breadcrumb-item::before {
  content: "/";
  color: var(--mc-text-muted);
}

/* ========================================
   Tables
   ======================================== */

.table,
table {
  background-color: var(--mc-surface);
  border-radius: var(--mc-radius-lg);
  overflow: hidden;
}

.table th,
th {
  background-color: var(--mc-slate-50);
  font-weight: var(--mc-font-semibold);
  color: var(--mc-text-primary);
  border-bottom: 2px solid var(--mc-border);
  padding: var(--mc-space-3) var(--mc-space-4);
}

.table td,
td {
  padding: var(--mc-space-3) var(--mc-space-4);
  border-bottom: 1px solid var(--mc-border-light);
}

.table tbody tr:hover,
tbody tr:hover {
  background-color: var(--mc-cream-200);
}

/* ========================================
   Responsive / Mobile-First
   ======================================== */

/* Small devices (phones) */
@media (max-width: 575.98px) {
  html {
    font-size: 14px;
  }

  .container {
    padding-left: var(--mc-space-4);
    padding-right: var(--mc-space-4);
  }

  .card,
  .panel,
  .post {
    border-radius: var(--mc-radius);
  }

  .btn {
    padding: var(--mc-space-3) var(--mc-space-4);
    width: 100%;
    margin-bottom: var(--mc-space-2);
  }

  .user-stats,
  .profile-stats {
    flex-direction: column;
    gap: var(--mc-space-3);
  }

  .pagination {
    flex-wrap: wrap;
  }
}

/* Medium devices (tablets) */
@media (min-width: 576px) and (max-width: 991.98px) {
  .container {
    padding-left: var(--mc-space-6);
    padding-right: var(--mc-space-6);
  }
}

/* Large devices (desktops) */
@media (min-width: 992px) {
  .container {
    max-width: 1140px;
  }
}

/* ========================================
   Utility Classes
   ======================================== */

.text-primary { color: var(--mc-primary) !important; }
.text-secondary { color: var(--mc-text-secondary) !important; }
.text-muted { color: var(--mc-text-muted) !important; }
.text-success { color: var(--mc-success) !important; }
.text-warning { color: var(--mc-warning) !important; }
.text-danger { color: var(--mc-error) !important; }

.bg-primary { background-color: var(--mc-primary) !important; }
.bg-light { background-color: var(--mc-background) !important; }
.bg-white { background-color: var(--mc-surface) !important; }

.border { border: 1px solid var(--mc-border) !important; }
.border-light { border: 1px solid var(--mc-border-light) !important; }
.rounded { border-radius: var(--mc-radius) !important; }
.rounded-lg { border-radius: var(--mc-radius-lg) !important; }

.shadow-sm { box-shadow: var(--mc-shadow-sm) !important; }
.shadow { box-shadow: var(--mc-shadow) !important; }
.shadow-md { box-shadow: var(--mc-shadow-md) !important; }
.shadow-lg { box-shadow: var(--mc-shadow-lg) !important; }

/* ========================================
   Animations
   ======================================== */

/* Subtle fade-in for page elements */
.fade-in {
  animation: fadeIn var(--mc-transition-slow) ease-out;
}

@keyframes fadeIn {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Hover lift effect */
.hover-lift {
  transition: transform var(--mc-transition-fast), box-shadow var(--mc-transition-fast);
}

.hover-lift:hover {
  transform: translateY(-2px);
  box-shadow: var(--mc-shadow-md);
}

/* Focus ring for accessibility */
*:focus-visible {
  outline: 2px solid var(--mc-primary);
  outline-offset: 2px;
}

/* ========================================
   Print Styles
   ======================================== */

@media print {
  .navbar,
  .footer,
  .pagination,
  .btn {
    display: none !important;
  }

  body {
    background: white !important;
    color: black !important;
  }

  a {
    color: black !important;
    text-decoration: underline;
  }
}

/* ========================================
   Misago-Specific Overrides
   ======================================== */

/* Misago Navbar */
#misago-navbar {
  background-color: var(--mc-brown-800) !important;
  border-bottom: 1px solid var(--mc-brown-700);
  box-shadow: var(--mc-shadow-sm);
}

.navbar-container {
  padding: var(--mc-space-2) var(--mc-space-4);
}

.navbar-branding-text {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-bold);
  color: var(--mc-cream-100) !important;
  font-size: var(--mc-text-xl);
  letter-spacing: -0.02em;
  text-decoration: none !important;
}

.navbar-branding-text:hover {
  color: #FFFFFF !important;
  text-decoration: none !important;
}

.btn-navbar-icon {
  color: var(--mc-cream-200) !important;
  transition: color var(--mc-transition-fast);
}

.btn-navbar-icon:hover {
  color: #FFFFFF !important;
  background-color: rgba(255, 255, 255, 0.1) !important;
}

.btn-navbar-icon .material-icon {
  color: inherit;
}

/* Sign In / Register Buttons */
.btn-sign-in,
.btn-navbar-sign-in {
  color: var(--mc-cream-200) !important;
  border-color: var(--mc-cream-300) !important;
  background-color: transparent !important;
  font-weight: var(--mc-font-medium);
}

.btn-sign-in:hover,
.btn-navbar-sign-in:hover {
  color: #FFFFFF !important;
  border-color: #FFFFFF !important;
  background-color: rgba(255, 255, 255, 0.1) !important;
}

.btn-register,
.btn-navbar-register {
  background-color: var(--mc-brown-400) !important;
  border-color: var(--mc-brown-400) !important;
  color: #FFFFFF !important;
  font-weight: var(--mc-font-medium);
}

.btn-register:hover,
.btn-navbar-register:hover {
  background-color: var(--mc-brown-300) !important;
  border-color: var(--mc-brown-300) !important;
}

/* ========================================
   Misago Page Container
   ======================================== */

.page {
  animation: fadeIn var(--mc-transition-slow) ease-out;
}

.page-container {
  padding: var(--mc-space-6) var(--mc-space-4);
}

/* ========================================
   Misago Toolbar
   ======================================== */

.toolbar {
  margin-bottom: var(--mc-space-4);
}

.toolbar-item .btn {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-medium);
  border-color: var(--mc-border);
  background-color: var(--mc-surface);
  color: var(--mc-text-primary);
  border-radius: var(--mc-radius);
}

.toolbar-item .btn:hover {
  border-color: var(--mc-primary);
  color: var(--mc-primary);
}

/* ========================================
   Misago Subcategories List
   ======================================== */

.subcategories-list {
  margin-bottom: var(--mc-space-4);
  padding: 0;
}

.subcategory {
  display: inline-block;
  padding: var(--mc-space-2) var(--mc-space-4);
  margin: var(--mc-space-1);
  background-color: var(--mc-surface);
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius-full);
  color: var(--mc-text-primary) !important;
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-medium);
  font-size: var(--mc-text-sm);
  text-decoration: none !important;
  transition: all var(--mc-transition-fast);
}

.subcategory:hover {
  background-color: var(--mc-brown-50);
  border-color: var(--mc-primary);
  color: var(--mc-primary) !important;
  transform: translateY(-1px);
  box-shadow: var(--mc-shadow-sm);
}

/* ========================================
   Misago Threads List
   ======================================== */

.threads-list {
  background-color: var(--mc-surface);
  border: 1px solid var(--mc-border);
  border-radius: var(--mc-radius-lg);
  overflow: hidden;
  box-shadow: var(--mc-shadow-sm);
}

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

.list-group-item,
.threads-list-item {
  border-bottom: 1px solid var(--mc-border-light) !important;
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
  background-color: var(--mc-surface);
  padding: var(--mc-space-4);
  transition: background-color var(--mc-transition-fast);
}

.list-group-item:last-child,
.threads-list-item:last-child {
  border-bottom: none !important;
}

.threads-list-item:hover {
  background-color: var(--mc-cream-200);
}

/* Thread Title */
.threads-list-item-title {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-medium);
  color: var(--mc-text-primary) !important;
  font-size: var(--mc-text-base);
  text-decoration: none !important;
  transition: color var(--mc-transition-fast);
}

.threads-list-item-title:hover {
  color: var(--mc-primary) !important;
}

/* Thread Category Label */
.threads-list-category-label,
.threads-list-item-category {
  font-size: var(--mc-text-xs);
  font-weight: var(--mc-font-medium);
  padding: var(--mc-space-1) var(--mc-space-2);
  border-radius: var(--mc-radius-sm);
  background-color: var(--mc-brown-50);
  color: var(--mc-brown-700) !important;
  text-decoration: none !important;
}

.threads-list-category-label:hover,
.threads-list-item-category:hover {
  background-color: var(--mc-brown-100);
  color: var(--mc-brown-800) !important;
}

/* Thread Starter / Last Poster */
.threads-list-item-starter,
.threads-list-item-last-poster {
  color: var(--mc-text-secondary) !important;
  font-size: var(--mc-text-sm);
  text-decoration: none !important;
}

.threads-list-item-starter:hover,
.threads-list-item-last-poster:hover {
  color: var(--mc-primary) !important;
}

/* Thread Replies Count */
.threads-replies {
  font-family: var(--mc-font-family) !important;
  font-weight: var(--mc-font-semibold);
  color: var(--mc-text-muted);
  font-size: var(--mc-text-sm);
}

/* Thread Last Activity */
.threads-list-item-last-activity {
  font-size: var(--mc-text-xs);
  color: var(--mc-text-muted);
}

/* User Avatars in Thread List */
.threads-list-item .user-avatar {
  border-radius: var(--mc-radius-full);
  border: 2px solid var(--mc-border-light);
}

/* ========================================
   Misago Footer
   ======================================== */

.misago-footer {
  background-color: var(--mc-slate-800) !important;
  color: var(--mc-slate-300) !important;
  padding: var(--mc-space-8) 0;
  margin-top: var(--mc-space-12);
}

.footer-content {
  padding: var(--mc-space-4);
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--mc-space-4);
  list-style: none;
  padding: 0;
  margin: 0 0 var(--mc-space-4) 0;
}

.footer-nav a {
  color: var(--mc-slate-300) !important;
  font-family: var(--mc-font-family) !important;
  font-size: var(--mc-text-sm);
  text-decoration: none;
  transition: color var(--mc-transition-fast);
}

.footer-nav a:hover {
  color: #FFFFFF !important;
}

.misago-branding {
  text-align: center;
  color: var(--mc-slate-400);
  font-size: var(--mc-text-xs);
}

.misago-branding a {
  color: var(--mc-slate-400) !important;
}

.misago-branding a:hover {
  color: var(--mc-slate-200) !important;
}

.site-footnote {
  text-align: center;
  color: var(--mc-slate-500);
  font-size: var(--mc-text-xs);
  margin-top: var(--mc-space-4);
}

/* ========================================
   Misago Modals
   ======================================== */

.modal.fade .modal-dialog {
  transform: translateY(-20px);
  transition: transform var(--mc-transition);
}

.modal.fade.in .modal-dialog,
.modal.show .modal-dialog {
  transform: translateY(0);
}

.modal-backdrop {
  background-color: rgba(0, 0, 0, 0.5);
}

.modal-content {
  border: none;
  border-radius: var(--mc-radius-lg);
  box-shadow: var(--mc-shadow-lg);
  background-color: var(--mc-surface);
}

/* ========================================
   Noscript Message
   ======================================== */

.noscript-message {
  background-color: var(--mc-warning-light);
  color: var(--mc-warning);
  padding: var(--mc-space-4);
  text-align: center;
  font-family: var(--mc-font-family) !important;
}

/* ========================================
   Material Icons Styling
   ======================================== */

.material-icon,
.material-icons {
  font-family: 'Material Icons';
  font-weight: normal;
  font-style: normal;
  font-size: 1.5rem;
  display: inline-block;
  line-height: 1;
  text-transform: none;
  letter-spacing: normal;
  word-wrap: normal;
  white-space: nowrap;
  direction: ltr;
  vertical-align: middle;
  /* Support for all WebKit browsers. */
  -webkit-font-smoothing: antialiased;
  /* Support for Safari and Chrome. */
  text-rendering: optimizeLegibility;
  /* Support for Firefox. */
  -moz-osx-font-smoothing: grayscale;
  /* Support for IE. */
  font-feature-settings: 'liga';
}

/* ========================================
   Dropdown Menus
   ======================================== */

.dropdown-menu {
  background-color: var(--mc-brown-800);
  border: 1px solid var(--mc-brown-700);
  border-radius: var(--mc-radius-md);
  box-shadow: var(--mc-shadow-lg);
  padding: var(--mc-space-2) 0;
}

.dropdown-item,
.dropdown-menu li a {
  font-family: var(--mc-font-family) !important;
  color: var(--mc-text-inverse);
  padding: var(--mc-space-2) var(--mc-space-4);
  transition: background-color var(--mc-transition-fast);
}

.dropdown-item:hover,
.dropdown-menu li a:hover {
  background-color: var(--mc-brown-700);
  color: var(--mc-cream-100);
}

/* ========================================
   Enhanced Animations
   ======================================== */

/* Slide in from left for thread items */
.threads-list-item {
  animation: slideInLeft var(--mc-transition-slow) ease-out;
  animation-fill-mode: both;
}

.threads-list-item:nth-child(1) { animation-delay: 0ms; }
.threads-list-item:nth-child(2) { animation-delay: 50ms; }
.threads-list-item:nth-child(3) { animation-delay: 100ms; }
.threads-list-item:nth-child(4) { animation-delay: 150ms; }
.threads-list-item:nth-child(5) { animation-delay: 200ms; }
.threads-list-item:nth-child(6) { animation-delay: 250ms; }
.threads-list-item:nth-child(7) { animation-delay: 300ms; }
.threads-list-item:nth-child(8) { animation-delay: 350ms; }
.threads-list-item:nth-child(9) { animation-delay: 400ms; }
.threads-list-item:nth-child(10) { animation-delay: 450ms; }

@keyframes slideInLeft {
  from {
    opacity: 0;
    transform: translateX(-10px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

/* Fade in for subcategories */
.subcategory {
  animation: fadeIn var(--mc-transition) ease-out;
  animation-fill-mode: both;
}

.subcategory:nth-child(1) { animation-delay: 0ms; }
.subcategory:nth-child(2) { animation-delay: 50ms; }
.subcategory:nth-child(3) { animation-delay: 100ms; }
.subcategory:nth-child(4) { animation-delay: 150ms; }
.subcategory:nth-child(5) { animation-delay: 200ms; }
.subcategory:nth-child(6) { animation-delay: 250ms; }

/* ========================================
   Mobile-First: Additional Breakpoints
   ======================================== */

/* Extra small devices */
@media (max-width: 479.98px) {
  .navbar-branding-text {
    font-size: var(--mc-text-lg);
  }

  .btn-navbar-sign-in,
  .btn-navbar-register {
    font-size: var(--mc-text-sm);
    padding: var(--mc-space-1) var(--mc-space-2);
  }

  .subcategory {
    padding: var(--mc-space-1) var(--mc-space-3);
    font-size: var(--mc-text-xs);
  }

  .threads-list-item {
    padding: var(--mc-space-3);
  }

  .threads-list-item-title {
    font-size: var(--mc-text-sm);
  }
}

/* Small devices (landscape phones) */
@media (min-width: 480px) and (max-width: 575.98px) {
  .page-container {
    padding: var(--mc-space-4);
  }
}

/* Medium devices (tablets) */
@media (min-width: 576px) and (max-width: 991.98px) {
  .page-container {
    padding: var(--mc-space-6);
  }
}

/* Large devices and up */
@media (min-width: 992px) {
  .page-container {
    padding: var(--mc-space-8) var(--mc-space-4);
  }

  .threads-list {
    border-radius: var(--mc-radius-xl);
  }
}

/* ========================================
   Accessibility Enhancements
   ======================================== */

/* Ensure focus states are visible */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--mc-primary);
  outline-offset: 2px;
}

/* Reduce motion for users who prefer it */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}

/* High contrast mode support */
@media (prefers-contrast: high) {
  :root {
    --mc-border: var(--mc-slate-400);
    --mc-text-primary: #000000;
    --mc-text-secondary: #1A1D21;
  }

  .btn-primary {
    border: 2px solid #000000 !important;
  }
}

/* Quick fixes on ARIA contrast issues */
.dropdown-subheader {
    color: white !important;
}

.breadcrumbs-item {
  color: white !important
}

.breadcrumbs-item:active {
  color: mintcream !important
}

/* ========================================
   Custom Layout: Sidebar & Fixed Footer
   ======================================== */

.manc-layout-wrapper {
    padding-top: var(--mc-space-6);
    padding-bottom: var(--mc-space-12); /* Space for fixed footer */
    min-height: calc(100vh - 160px);
}

.manc-sidebar {
    padding: var(--mc-space-4);
    position: sticky;
    top: 20px;
    align-self: flex-start;
}

.manc-sidebar-inner {
    background-color: var(--mc-surface);
    border: 1px solid var(--mc-border);
    border-radius: var(--mc-radius-lg);
    padding: var(--mc-space-4);
    box-shadow: var(--mc-shadow-sm);
}

.manc-sidebar-title {
    font-size: var(--mc-text-sm);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--mc-brown-400);
    margin-bottom: var(--mc-space-4);
    font-weight: var(--mc-font-bold);
    border-bottom: 1px solid var(--mc-border-light);
    padding-bottom: var(--mc-space-2);
}

.manc-sidebar-menu {
    list-style: none;
    padding: 0;
    margin: 0;
}

.manc-sidebar-menu li {
    margin-bottom: var(--mc-space-2);
}

.manc-sidebar-menu li a {
    display: flex;
    align-items: center;
    gap: var(--mc-space-3);
    color: var(--mc-text-secondary);
    font-weight: var(--mc-font-medium);
    padding: var(--mc-space-2) var(--mc-space-3);
    border-radius: var(--mc-radius);
    transition: all var(--mc-transition-fast);
}

.manc-sidebar-menu li a:hover {
    background-color: var(--mc-brown-50);
    color: var(--mc-primary);
    text-decoration: none;
}

.manc-sidebar-menu li a .material-icon {
    font-size: 1.25rem;
}

/* Right Sidebar Ad Space */
.manc-ad-placeholder {
    background-color: var(--mc-cream-200);
    border: 1px dashed var(--mc-brown-200);
    padding: var(--mc-space-4);
    border-radius: var(--mc-radius);
    text-align: center;
}

/* Fixed Footer Implementation */
body {
    display: flex;
    flex-direction: column;
    min-height: 100vh;
}

#misago-container {
    flex: 1 0 auto;
}

.misago-footer {
    flex-shrink: 0;
    position: fixed;
    bottom: 0;
    width: 100%;
    z-index: 1000;
    padding: var(--mc-space-4) 0 !important;
    margin-top: 0 !important;
}

/* Adjust main content padding to not be hidden by footer */
.manc-layout-wrapper {
    margin-bottom: 80px; /* Adjust based on footer height */
}

/* Responsive adjustments for Sidebars */
@media (max-width: 991px) {
    .hidden-xs.hidden-sm {
        display: none !important;
    }
}

.misago-footer {
margin-bottom:0px !important;}

#misago-container {
margin-bottom:150px !important}

/* ========================================
   Accountability Dashboard Styles
   ======================================== */

.accountability-dashboard {
  max-width: 1400px;
  margin: 0 auto;
  padding: var(--mc-space-6);
}

.page-header {
  margin-bottom: var(--mc-space-8);
}

.page-header h1 {
  color: var(--mc-primary);
  font-size: 2.5rem;
  font-weight: 700;
  margin: 0;
}

.dashboard-section {
  background: var(--mc-surface);
  border-radius: var(--mc-border-radius-lg);
  padding: var(--mc-space-6);
  margin-bottom: var(--mc-space-6);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.dashboard-section h2 {
  color: var(--mc-text);
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0 0 var(--mc-space-4) 0;
  display: flex;
  align-items: center;
  gap: var(--mc-space-2);
}

.dashboard-section h2 .badge {
  background: var(--mc-primary);
  color: white;
  font-size: 0.875rem;
  padding: 2px 8px;
  border-radius: 12px;
  font-weight: 500;
}

/* Focus Areas */
.focus-badges {
  display: flex;
  gap: var(--mc-space-4);
  flex-wrap: wrap;
}

.focus-badge {
  display: flex;
  align-items: center;
  gap: var(--mc-space-3);
  padding: var(--mc-space-4);
  border-radius: var(--mc-border-radius-lg);
  background: var(--mc-surface-variant);
  border: 2px solid transparent;
  transition: all 0.2s ease;
}

.focus-badge.focus-primary {
  border-color: var(--mc-primary);
  background: rgba(92, 84, 112, 0.1);
}

.focus-badge.focus-secondary {
  border-color: var(--mc-accent);
  background: rgba(177, 98, 78, 0.1);
}

.focus-badge.focus-tertiary {
  border-color: var(--mc-text-secondary);
  background: rgba(0, 0, 0, 0.05);
}

.focus-icon {
  font-size: 2rem;
  color: var(--mc-primary);
}

.focus-info {
  display: flex;
  flex-direction: column;
}

.focus-name {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--mc-text);
}

.focus-rank {
  font-size: 0.875rem;
  color: var(--mc-text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Stats Grid */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--mc-space-4);
}

.stat-card {
  display: flex;
  align-items: center;
  gap: var(--mc-space-3);
  padding: var(--mc-space-4);
  background: var(--mc-surface-variant);
  border-radius: var(--mc-border-radius-lg);
  transition: transform 0.2s ease;
}

.stat-card:hover {
  transform: translateY(-2px);
}

.stat-icon {
  font-size: 2.5rem;
  color: var(--mc-primary);
}

.stat-content {
  display: flex;
  flex-direction: column;
}

.stat-value {
  font-size: 2rem;
  font-weight: 700;
  color: var(--mc-text);
  line-height: 1;
}

.stat-label {
  font-size: 0.875rem;
  color: var(--mc-text-secondary);
  margin-top: 4px;
}

/* Quick Actions */
.action-buttons {
  display: flex;
  gap: var(--mc-space-3);
  flex-wrap: wrap;
}

.action-buttons .btn {
  display: inline-flex;
  align-items: center;
  gap: var(--mc-space-2);
  padding: var(--mc-space-3) var(--mc-space-6);
  border-radius: var(--mc-border-radius-lg);
  font-weight: 500;
  text-decoration: none;
  transition: all 0.2s ease;
}

.action-buttons .btn-primary {
  background: var(--mc-primary);
  color: white;
}

.action-buttons .btn-primary:hover {
  background: var(--mc-primary-dark);
  transform: translateY(-1px);
}

.action-buttons .btn-secondary {
  background: var(--mc-surface-variant);
  color: var(--mc-text);
  border: 1px solid var(--mc-border);
}

.action-buttons .btn-secondary:hover {
  background: var(--mc-surface);
  transform: translateY(-1px);
}

.action-buttons .material-icons {
  font-size: 1.25rem;
}

/* Two Column Layout */
.dashboard-columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--mc-space-6);
}

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

.dashboard-column {
  display: flex;
  flex-direction: column;
  gap: var(--mc-space-6);
}

/* Connection List */
.connection-list {
  display: flex;
  flex-direction: column;
  gap: var(--mc-space-3);
}

.connection-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--mc-space-4);
  background: var(--mc-surface-variant);
  border-radius: var(--mc-border-radius-lg);
}

.user-info {
  display: flex;
  align-items: center;
  gap: var(--mc-space-3);
}

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

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

.user-details {
  display: flex;
  flex-direction: column;
}

.user-name {
  font-weight: 600;
  color: var(--mc-text);
  text-decoration: none;
}

.user-name:hover {
  color: var(--mc-primary);
}

.connection-date {
  font-size: 0.875rem;
  color: var(--mc-text-secondary);
}

.connection-actions {
  display: flex;
  gap: var(--mc-space-2);
}

.btn-sm {
  padding: 6px 12px;
  font-size: 0.875rem;
  border: none;
  border-radius: var(--mc-border-radius-md);
  cursor: pointer;
  font-weight: 500;
  transition: all 0.2s ease;
}

.btn-success {
  background: #4caf50;
  color: white;
}

.btn-success:hover {
  background: #45a049;
}

.btn-danger {
  background: #f44336;
  color: white;
}

.btn-danger:hover {
  background: #da190b;
}

/* Goal List */
.goal-list {
  display: flex;
  flex-direction: column;
  gap: var(--mc-space-3);
}

.goal-item {
  padding: var(--mc-space-4);
  background: var(--mc-surface-variant);
  border-radius: var(--mc-border-radius-lg);
}

.goal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--mc-space-3);
  flex-wrap: wrap;
  gap: var(--mc-space-2);
}

.goal-title {
  font-weight: 600;
  color: var(--mc-text);
  text-decoration: none;
  font-size: 1.125rem;
}

.goal-title:hover {
  color: var(--mc-primary);
}

.goal-deadline {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.875rem;
  color: var(--mc-text-secondary);
}

.goal-deadline .material-icons {
  font-size: 1rem;
}

.goal-progress {
  display: flex;
  align-items: center;
  gap: var(--mc-space-3);
}

.progress-bar {
  flex: 1;
  height: 8px;
  background: var(--mc-surface);
  border-radius: 4px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  background: var(--mc-primary);
  transition: width 0.3s ease;
}

.progress-text {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--mc-text);
  min-width: 40px;
  text-align: right;
}

/* Group List */
.group-list {
  display: flex;
  flex-direction: column;
  gap: var(--mc-space-3);
}

.group-item {
  padding: var(--mc-space-4);
  background: var(--mc-surface-variant);
  border-radius: var(--mc-border-radius-lg);
}

.group-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--mc-space-2);
}

.group-name {
  font-weight: 600;
  color: var(--mc-text);
  text-decoration: none;
  font-size: 1.125rem;
}

.group-name:hover {
  color: var(--mc-primary);
}

.group-members {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.875rem;
  color: var(--mc-text-secondary);
}

.group-members .material-icons {
  font-size: 1rem;
}

.group-description {
  font-size: 0.875rem;
  color: var(--mc-text-secondary);
  margin: 0;
  line-height: 1.5;
}

/* Check-in List */
.checkin-list {
  display: flex;
  flex-direction: column;
  gap: var(--mc-space-3);
}

.checkin-item {
  padding: var(--mc-space-4);
  background: var(--mc-surface-variant);
  border-radius: var(--mc-border-radius-lg);
}

.checkin-header {
  display: flex;
  align-items: center;
  gap: var(--mc-space-3);
  margin-bottom: var(--mc-space-2);
}

.checkin-meta {
  display: flex;
  flex-direction: column;
}

.checkin-date {
  font-size: 0.75rem;
  color: var(--mc-text-secondary);
}

.checkin-content {
  display: flex;
  flex-direction: column;
  gap: var(--mc-space-2);
}

.checkin-goal {
  font-weight: 600;
  color: var(--mc-primary);
  text-decoration: none;
  font-size: 1rem;
}

.checkin-goal:hover {
  text-decoration: underline;
}

.checkin-notes {
  font-size: 0.875rem;
  color: var(--mc-text);
  margin: 0;
  line-height: 1.5;
}

.progress-update {
  display: inline-block;
  padding: 4px 8px;
  background: var(--mc-primary);
  color: white;
  border-radius: var(--mc-border-radius-md);
  font-size: 0.75rem;
  font-weight: 500;
}

/* Empty State */
.empty-state {
  text-align: center;
  padding: var(--mc-space-8);
  color: var(--mc-text-secondary);
  font-size: 0.875rem;
}

.empty-state a {
  color: var(--mc-primary);
  text-decoration: none;
  font-weight: 500;
}

.empty-state a:hover {
  text-decoration: underline;
}