/* ==========================================================================
   CORE STYLES
   ========================================================================== */

/* Core Application CSS
 * This file imports global styles and serves as the main entry point.
 * All component CSS is concatenated after this file during build.
 */

/* Design System Tokens */
/* Design Tokens - Production Style */

:root {
  /* Typography - System fonts for production */
  --font-family-base: 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-size-base: 1.2em; /* Production uses 1.2em */
  --font-size-small: 0.9em;
  --line-height-base: 1.6;
  --font-weight-normal: 400;
  --font-weight-bold: 700;

  /* Colors - Simplified Production Palette */
  --color-canvas: #ffffff;
  --color-surface: #efefef; /* Card backgrounds on profile */
  --color-surface-hover: #e8e8e8; /* Slightly darker on hover */
  --color-text-primary: #333333;
  --color-text-secondary: #999999;
  --color-interactive: #007aff; /* Blue for underlined links */
  --color-button: #1A1A1A; /* Black buttons */
  --color-button-hover: #333333; /* Lighter on hover */
  --color-button-text: #ffffff;
  --color-avatar-green: #2E7D32; /* Avatar placeholder */

  /* Borders */
  --color-border: #e0e0e0;

  /* Spacing - Simplified scale */
  --spacing-xs: 8px;
  --spacing-sm: 16px;
  --spacing-md: 24px;
  --spacing-lg: 48px;
  --spacing-xl: 64px;

  /* Layout */
  --wrapper-max-width: 1200px;
  --card-padding: 24px;
  --border-radius: 0; /* Production has no rounded corners */

  /* Breakpoints - Production responsive behavior */
  --breakpoint-mobile: 768px;
  --breakpoint-tablet: 1024px;

  /* Transitions */
  --transition-fast: 0.2s ease;
}


/* Base Reset and Global Styles */
/* Base Styles - Production System */

/* No font imports - using system fonts (Helvetica Neue) */

/* Reset and Base Styles */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
}

body {
  font-family: var(--font-family-base);
  background-color: var(--color-canvas);
  color: var(--color-text-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-weight: var(--font-weight-bold);
  line-height: 1.3;
  margin-bottom: var(--spacing-sm);
  color: var(--color-text-primary);
}

h1 { font-size: 2.5rem; }
h2 { font-size: 2rem; }
h3 { font-size: 1.5rem; }
h4 { font-size: 1.25rem; }
h5 { font-size: 1.125rem; }
h6 { font-size: 1rem; }

p {
  margin-bottom: var(--spacing-sm);
  line-height: var(--line-height-base);
}

/* Links */
a {
  color: var(--color-interactive);
  text-decoration: underline;
  transition: opacity var(--transition-fast);
}

a:hover {
  opacity: 0.8;
}

/* Layout Utilities */
.wrapper {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
}

/* Main Content - Standard Page Layout */
.main-content {
  background-color: var(--color-canvas);
  min-height: calc(100vh - 200px);
  padding: var(--spacing-lg) var(--spacing-md);
}

.main-content-container {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
}

.main-content h1 {
  margin-bottom: var(--spacing-md);
}

.main-content p {
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-md);
  line-height: 1.7;
}

/* Responsive Grid System - Production style */
.grid {
  display: grid;
  gap: 24px;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}

/* Responsive breakpoints */
@media (max-width: 1024px) {
  .grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

  .wrapper {
    padding: 0 var(--spacing-md);
  }
}

/* Card Component */
.card {
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  padding: var(--card-padding);
  transition: background-color var(--transition-fast);
}

.card:hover {
  background-color: var(--color-surface-hover);
}

/* Buttons - Production style */
.btn {
  display: inline-block;
  padding: 12px 32px;
  border: none;
  border-radius: var(--border-radius);
  font-family: var(--font-family-base);
  font-size: 1em;
  font-weight: var(--font-weight-normal);
  text-decoration: none;
  cursor: pointer;
  transition: background-color var(--transition-fast);
  background-color: var(--color-button);
  color: var(--color-button-text);
}

.btn:hover {
  background-color: var(--color-button-hover);
  text-decoration: none;
  opacity: 1;
}

.btn-primary {
  background-color: var(--color-button);
  color: var(--color-button-text);
}

.btn-primary:hover {
  background-color: var(--color-button-hover);
}

.btn-secondary {
  background-color: var(--color-text-secondary);
  color: var(--color-button-text);
}

.btn-secondary:hover {
  background-color: #777777;
}

/* Form Elements */
.form-group {
  margin-bottom: var(--spacing-md);
}

.form-label {
  display: block;
  margin-bottom: var(--spacing-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
}

.form-control {
  width: 100%;
  padding: var(--spacing-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius);
  font-family: var(--font-family-base);
  font-size: var(--font-size-base);
  background-color: var(--color-canvas);
  color: var(--color-text-primary);
  transition: border-color var(--transition-fast);
}

.form-control:focus {
  outline: none;
  border-color: var(--color-interactive);
  box-shadow: 0 0 0 2px rgba(0, 122, 255, 0.1);
}

textarea.form-control {
  resize: vertical;
  min-height: 120px;
  line-height: var(--line-height-base);
}

/* Utility Classes */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.text-primary { color: var(--color-text-primary); }
.text-secondary { color: var(--color-text-secondary); }
.text-interactive { color: var(--color-interactive); }

.bg-canvas { background-color: var(--color-canvas); }
.bg-surface { background-color: var(--color-surface); }

.mb-sm { margin-bottom: var(--spacing-sm); }
.mb-md { margin-bottom: var(--spacing-md); }
.mb-lg { margin-bottom: var(--spacing-lg); }

/* Loading States */
.htmx-indicator {
  display: none;
}

.htmx-request .htmx-indicator {
  display: inline-flex;
}

.htmx-request.htmx-indicator {
  display: inline-flex;
}

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

/* Focus styles */
:focus-visible {
  outline: 2px solid var(--color-interactive);
  outline-offset: 2px;
}


/* ==========================================================================
   COMPONENT STYLES
   ========================================================================== */

/* --------------------------------------------------------------------------
   Component: components/about/css/about.css
   -------------------------------------------------------------------------- */

/* About Page Styles */

.about-page {
  padding: var(--spacing-lg, 32px) 0;
  background-color: var(--color-canvas, #FFFFFF);
}

/* Hero Section */
.about-hero {
  background-color: var(--color-surface, #F9F9F9);
  padding: var(--spacing-xl, 64px) var(--spacing-lg, 32px);
  text-align: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.about-hero-content {
  max-width: 900px;
  margin: 0 auto;
}

.about-hero h1 {
  font-size: 2.5rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-md, 16px);
  line-height: 1.2;
}

.about-hero .about-lead {
  font-size: 1.25rem;
  color: var(--color-text-secondary, #666666);
  line-height: 1.65;
  font-weight: 500;
}

/* Main Container */
.about-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg, 32px);
}

/* Sections */
.about-section {
  padding: var(--spacing-xl, 64px) 0;
  background-color: var(--color-canvas, #FFFFFF);
}

.about-section-alt {
  background-color: var(--color-surface, #F9F9F9);
}

.about-section h2 {
  font-size: 2rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-lg, 32px);
  line-height: 1.3;
}

.about-section p {
  font-size: 1rem;
  color: var(--color-text-primary, #1A1A1A);
  line-height: 1.8;
  margin-bottom: var(--spacing-md, 16px);
}

.about-section strong {
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
}

/* Code blocks in about text */
.about-section code {
  background-color: rgba(0, 85, 255, 0.05);
  padding: 2px 6px;
  border-radius: 3px;
  font-family: 'Courier New', monospace;
  color: var(--color-interactive, #0055FF);
  font-size: 0.9em;
}

/* Features Grid */
.about-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--spacing-lg, 32px);
  margin-top: var(--spacing-lg, 32px);
}

.feature-item {
  background-color: var(--color-canvas, #FFFFFF);
  padding: var(--spacing-md, 24px);
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.05);
  transition: all 0.2s ease;
}

.about-section-alt .feature-item {
  background-color: rgba(255, 255, 255, 0.7);
}

.feature-item:hover {
  background-color: var(--color-surface, #F9F9F9);
  transform: translateY(-2px);
  border-color: rgba(0, 85, 255, 0.1);
}

.feature-item h3 {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-sm, 12px);
}

.feature-item p {
  font-size: 0.95rem;
  color: var(--color-text-secondary, #666666);
  line-height: 1.65;
  margin-bottom: 0;
}

/* Values Grid */
.about-values {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  gap: var(--spacing-lg, 32px);
  margin-top: var(--spacing-lg, 32px);
}

.value-item {
  padding: var(--spacing-md, 24px) 0;
}

.value-item h3 {
  font-size: 1.2rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-sm, 12px);
}

.value-item p {
  font-size: 0.95rem;
  color: var(--color-text-secondary, #666666);
  line-height: 1.7;
  margin-bottom: 0;
}

/* CTA Section */
.about-section-cta {
  text-align: center;
  padding: var(--spacing-xl, 64px) var(--spacing-lg, 32px);
}

.about-section-cta .about-container {
  max-width: 700px;
}

.about-section-cta h2 {
  margin-bottom: var(--spacing-lg, 32px);
}

.about-section-cta p {
  font-size: 1.1rem;
  margin-bottom: var(--spacing-lg, 32px);
  color: var(--color-text-secondary, #666666);
}

.cta-button {
  display: inline-block;
  padding: var(--spacing-sm, 12px) var(--spacing-lg, 32px);
  background-color: var(--color-button, #333333);
  color: white;
  text-decoration: none;
  border-radius: var(--border-radius);
  font-weight: 600;
  font-size: 1rem;
  transition: all 0.2s ease;
  border: 2px solid var(--color-button, #333333);
}

.cta-button:hover {
  background-color: var(--color-button-hover, #555555);
  border-color: var(--color-button-hover, #555555);
  transform: translateY(-2px);
}

/* Responsive */
@media (max-width: 768px) {
  .about-hero h1 {
    font-size: 1.75rem;
  }

  .about-hero .about-lead {
    font-size: 1rem;
  }

  .about-section h2 {
    font-size: 1.5rem;
  }

  .about-features {
    grid-template-columns: 1fr;
    gap: var(--spacing-md, 16px);
  }

  .about-values {
    grid-template-columns: 1fr;
  }

  .about-section {
    padding: var(--spacing-lg, 32px) 0;
  }

  .about-hero {
    padding: var(--spacing-lg, 32px);
  }
}

@media (max-width: 480px) {
  .about-hero h1 {
    font-size: 1.5rem;
  }

  .about-section p {
    font-size: 0.95rem;
  }

  .cta-button {
    display: block;
    width: 100%;
    text-align: center;
  }
}


/* --------------------------------------------------------------------------
   Component: components/faq/css/faq.css
   -------------------------------------------------------------------------- */

/* FAQ Component Styles */

.faq-page {
  background-color: var(--color-canvas);
  min-height: 100vh;
}

/* Hero Section */
.faq-hero {
  background-color: var(--color-surface);
  padding: var(--spacing-xl) var(--spacing-lg);
  text-align: center;
  border-bottom: 1px solid var(--color-border);
}

.faq-hero-content {
  max-width: 600px;
  margin: 0 auto;
}

.faq-hero h1 {
  font-size: 2.25rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--spacing-sm) 0;
}

.faq-lead {
  font-size: 1.125rem;
  color: var(--color-text-secondary);
  margin: 0;
  line-height: 1.6;
}

/* FAQ Section */
.faq-section {
  padding: var(--spacing-xl) var(--spacing-lg);
}

.faq-container {
  max-width: 800px;
  margin: 0 auto;
}

/* FAQ Category */
.faq-category {
  margin-bottom: var(--spacing-xl);
}

.faq-category:last-child {
  margin-bottom: 0;
}

.faq-category-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--spacing-md) 0;
  padding-bottom: var(--spacing-sm);
  border-bottom: 2px solid var(--color-interactive);
}

/* FAQ Item */
.faq-item {
  background-color: var(--color-surface);
  border-radius: 6px;
  padding: var(--spacing-md);
  margin-bottom: var(--spacing-sm);
  transition: transform 0.2s, box-shadow 0.2s;
}

.faq-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.faq-item:last-child {
  margin-bottom: 0;
}

.faq-question {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--spacing-sm) 0;
  line-height: 1.4;
}

.faq-answer {
  color: var(--color-text-secondary);
  line-height: 1.65;
}

.faq-answer p {
  margin: 0 0 var(--spacing-sm) 0;
}

.faq-answer p:last-child {
  margin-bottom: 0;
}

.faq-answer a {
  color: var(--color-interactive);
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 85, 255, 0.2);
  transition: border-color 0.2s;
}

.faq-answer a:hover {
  border-bottom-color: var(--color-interactive);
}

/* Responsive */
@media (max-width: 768px) {
  .faq-hero {
    padding: var(--spacing-lg) var(--spacing-md);
  }

  .faq-hero h1 {
    font-size: 1.75rem;
  }

  .faq-section {
    padding: var(--spacing-lg) var(--spacing-md);
  }

  .faq-category-title {
    font-size: 1.25rem;
  }

  .faq-question {
    font-size: 1rem;
  }
}


/* --------------------------------------------------------------------------
   Component: components/global/css/footer.css
   -------------------------------------------------------------------------- */

/* Global Footer - Professional Social Broadcasting Style */

.global-footer {
  background-color: var(--color-canvas);
  border-top: 1px solid var(--color-border);
  margin-top: var(--spacing-xl);
}

.footer-wrapper {
  padding: var(--spacing-lg) var(--spacing-md);
}

.footer-container {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
}

.footer-links-group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--spacing-xl);
  margin-bottom: var(--spacing-lg);
}

.footer-column {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.footer-column-title {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  font-size: 0.9em;
  margin: 0 0 var(--spacing-sm) 0;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
}

.footer-links li {
  margin: 0;
}

.footer-links a {
  color: var(--color-text-secondary);
  text-decoration: none;
  font-size: 0.9em;
  transition: color var(--transition-fast);
  border-bottom: 1px solid rgba(0, 85, 255, 0.2);
  padding-bottom: 2px;
  display: inline-block;
}

.footer-links a:hover {
  color: var(--color-interactive);
  border-bottom-color: var(--color-interactive);
}

.footer-bottom {
  background-color: rgba(0, 0, 0, 0.02);
  padding: var(--spacing-md) var(--spacing-md);
  border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.footer-bottom-container {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
  text-align: center;
}

.footer-bottom p {
  color: var(--color-text-secondary);
  font-size: 0.85em;
  margin: 0;
}

@media (max-width: 768px) {
  .footer-links-group {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-lg);
  }
}

@media (max-width: 480px) {
  .footer-links-group {
    grid-template-columns: 1fr;
    gap: var(--spacing-md);
  }
}


/* --------------------------------------------------------------------------
   Component: components/global/css/header.css
   -------------------------------------------------------------------------- */

/* Global Header - Refined Bytes Design */

.global-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: var(--color-canvas);
  border-bottom: 1px solid var(--color-border);
}

.header-wrapper {
  padding: var(--spacing-sm) var(--spacing-md);
}

.header-container {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-md);
}

/* ============ BRAND ============ */

.brand-link {
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
  text-decoration: none;
}

img.brand-icon {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: block;
}

/* Fallback for text-based icon */
div.brand-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-color: var(--color-brand-accent);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--font-weight-bold);
  font-size: 0.9em;
}

.brand-text {
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  font-size: 1.125em;
}

.brand-link:hover .brand-text {
  color: var(--color-interactive);
}

/* ============ NAVIGATION ============ */

.main-nav {
  display: flex;
  gap: var(--spacing-md);
  align-items: center;
}

.nav-link {
  text-decoration: none;
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-fast);
  padding: 8px 16px;
  border-radius: 4px;
  font-size: 0.9em;
  white-space: nowrap;
}

.nav-link-primary {
  background-color: #000000;
  color: white;
}

.nav-link-primary:hover {
  background-color: #1a1a1a;
}

.nav-link-secondary {
  background-color: #000000;
  color: white;
  margin-left: var(--spacing-xs);
}

.nav-link-secondary:hover {
  background-color: #1a1a1a;
}

/* ============ RESPONSIVE ============ */

@media (max-width: 768px) {
  .header-container {
    padding: 0 var(--spacing-sm);
  }

  .main-nav {
    gap: var(--spacing-sm);
  }

  .brand-text {
    font-size: 1em;
  }

  /* Hide username text on mobile, keep avatar */
  .nav-username {
    display: none;
  }
}

@media (max-width: 480px) {
  .global-header {
    padding: var(--spacing-sm) 0;
  }

  .brand-icon {
    width: 24px;
    height: 24px;
    font-size: 0.85em;
  }

  .brand-text {
    font-size: 0.95em;
  }

  .nav-avatar {
    width: 28px;
    height: 28px;
  }

  .nav-link {
    font-size: 0.9em;
  }
}


/* --------------------------------------------------------------------------
   Component: components/homepage/css/homepage.css
   -------------------------------------------------------------------------- */

/* Homepage Component - Ultra Minimal + Extended Styles */

/* ============ HOMEPAGE MAIN LAYOUT ============ */

.homepage-main {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  background-color: var(--color-canvas);
  padding: var(--spacing-lg);
}

.homepage-content {
  text-align: center;
  max-width: 600px;
}

.homepage-brand {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-sm);
  margin-bottom: var(--spacing-sm);
}

.homepage-logo {
  width: 64px;
  height: 64px;
}

.homepage-title {
  font-size: 3em;
  font-weight: var(--font-weight-bold);
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.2;
}

.homepage-subtitle {
  font-size: 1.2em;
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-lg);
  line-height: 1.5;
}

/* ============ HERO SECTION (EXTENDED) ============ */

.hero-section {
  padding: var(--spacing-xxl) var(--spacing-lg);
  text-align: center;
  background-color: var(--color-canvas);
}

.hero-content {
  max-width: 800px;
  margin: 0 auto;
}

.hero-title {
  font-size: 3rem;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-md);
  line-height: 1.2;
}

.hero-subtitle {
  font-size: 1.25rem;
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-xl);
  line-height: var(--line-height-base);
}

.hero-cta {
  display: flex;
  justify-content: center;
  gap: var(--spacing-md);
}

/* ============ POST CREATION SECTION ============ */

.post-creation-section {
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  padding: var(--spacing-xl);
  margin-bottom: var(--spacing-xl);
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.post-creation-section h2 {
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-lg);
  text-align: center;
  font-weight: var(--font-weight-semibold);
}

/* ============ POSTS FEED SECTION ============ */

.posts-feed-section {
  padding: 0 var(--spacing-lg);
}

.posts-feed-container {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
}

.posts-feed-container h2 {
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-xl);
  text-align: center;
  font-weight: var(--font-weight-semibold);
}

/* ============ POSTS GRID - MASONRY STYLE ============ */

.posts-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--grid-gap-desktop);
  margin-bottom: var(--spacing-xl);
}

/* ============ BYTE CARD - REFINED DESIGN ============ */

.byte-card {
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  padding: var(--card-padding);
  transition: all var(--transition-medium);
  position: relative;
  overflow: hidden;
}

.byte-card:hover {
  background-color: var(--color-surface-hover);
  transform: var(--hover-transform);
}

.byte-card-header {
  margin-bottom: var(--spacing-md);
  padding-bottom: var(--spacing-sm);
  border-bottom: 1px solid var(--color-border);
}

.byte-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-small);
  color: var(--color-text-secondary);
}

.byte-author {
  font-weight: var(--font-weight-medium);
  color: var(--color-text-primary);
}

.byte-date {
  font-style: italic;
}

.byte-content {
  margin-bottom: var(--spacing-md);
  line-height: var(--line-height-base);
}

.byte-content p {
  margin: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
}

.byte-content a {
  color: var(--color-interactive);
  text-decoration: none;
  border-bottom: 1px solid var(--color-link-border);
}

.byte-content a:hover {
  border-bottom-color: var(--color-interactive);
  background-color: var(--color-link-bg-hover);
}

.byte-footer {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  padding-top: var(--spacing-sm);
  border-top: 1px solid var(--color-border);
}

.byte-action {
  color: var(--color-text-secondary);
  font-size: var(--font-size-small);
  text-decoration: none;
  border: none;
  padding: var(--spacing-xs) var(--spacing-sm);
  border-radius: var(--border-radius);
  transition: all var(--transition-fast);
  display: flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.byte-action:hover {
  color: var(--color-interactive);
  background-color: var(--color-link-bg-hover);
  border: none;
  transform: none;
}

/* ============ NO POSTS STATE ============ */

.no-posts {
  text-align: center;
  padding: var(--spacing-xxl);
  color: var(--color-text-secondary);
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
  margin: var(--spacing-lg) 0;
}

.no-posts i {
  font-size: 3rem;
  margin-bottom: var(--spacing-md);
  opacity: 0.5;
}

.no-posts p {
  margin: 0;
  font-size: var(--font-size-small);
}

/* ============ LOAD MORE ============ */

.load-more-container {
  text-align: center;
  padding: var(--spacing-lg) 0;
}

/* ============ RESPONSIVE ============ */

@media (max-width: 1100px) {
  .posts-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--grid-gap-laptop);
  }
  
  .hero-title {
    font-size: 2.5rem;
  }
}

@media (max-width: 800px) {
  .posts-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--grid-gap-tablet);
  }
  
  .hero-section {
    padding: var(--spacing-xl) var(--spacing-md);
  }
  
  .hero-title {
    font-size: 2rem;
  }
  
  .hero-subtitle {
    font-size: 1.1rem;
  }
  
  .post-creation-section {
    padding: var(--spacing-lg);
    margin: 0 var(--spacing-md) var(--spacing-lg);
  }
  
  .posts-feed-section {
    padding: 0 var(--spacing-md);
  }
}

@media (max-width: 768px) {
  .homepage-title {
    font-size: 2em;
  }

  .homepage-subtitle {
    font-size: 1em;
  }

  .homepage-main {
    padding: var(--spacing-md);
  }
}

@media (max-width: 500px) {
  .posts-grid {
    grid-template-columns: 1fr;
    gap: var(--grid-gap-mobile);
  }
  
  .hero-section {
    padding: var(--spacing-lg) var(--spacing-sm);
  }
  
  .hero-title {
    font-size: 1.75rem;
  }
  
  .hero-subtitle {
    font-size: 1rem;
    margin-bottom: var(--spacing-lg);
  }
  
  .hero-cta {
    flex-direction: column;
    align-items: center;
    gap: var(--spacing-sm);
  }
  
  .post-creation-section {
    padding: var(--spacing-md);
    margin: 0 var(--spacing-sm) var(--spacing-md);
  }
  
  .posts-feed-section {
    padding: 0 var(--spacing-sm);
  }
  
  .byte-card {
    padding: var(--spacing-md);
  }
  
  .byte-footer {
    flex-direction: column;
    gap: var(--spacing-sm);
  }
  
  .no-posts {
    padding: var(--spacing-lg);
    margin: var(--spacing-md) 0;
  }
}


/* --------------------------------------------------------------------------
   Component: components/login/css/login.css
   -------------------------------------------------------------------------- */

/* Login Component Styles */

.login-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 64px 24px;
}

.login-wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: start;
}

.login-card {
    background: var(--color-surface);
    border-radius: 6px;
    padding: 48px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.login-title {
    font-size: 28px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 12px 0;
}

.login-subtitle {
    font-size: 16px;
    color: var(--color-text-secondary);
    margin: 0 0 32px 0;
    line-height: 1.6;
}

.login-form {
    margin-bottom: 32px;
}

.form-group {
    margin-bottom: 24px;
}

.form-label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--color-text-primary);
    margin-bottom: 8px;
}

.form-input {
    width: 100%;
    padding: 12px 16px;
    font-size: 16px;
    font-family: inherit;
    color: var(--color-text-primary);
    background: var(--color-canvas);
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 4px;
    transition: border-color 0.2s;
}

.form-input:focus {
    outline: none;
    border-color: var(--color-interactive);
}

.form-input::placeholder {
    color: var(--color-text-secondary);
    opacity: 0.6;
}

.form-message {
    margin: 16px 0;
    font-size: 14px;
}

.alert {
    padding: 12px 16px;
    border-radius: 4px;
    margin-bottom: 24px;
    font-size: 14px;
    line-height: 1.5;
}

.alert-error {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fecaca;
}

.alert-success {
    background: #f0fdf4;
    color: #166534;
    border: 1px solid #bbf7d0;
}

.btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 24px;
    font-size: 16px;
    font-weight: 500;
    font-family: inherit;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
    text-decoration: none;
}

.btn-primary {
    background: var(--color-button);
    color: var(--color-button-text);
}

.btn-primary:hover {
    background: var(--color-button-hover);
    transform: translateY(-1px);
}

.btn-block {
    width: 100%;
}

.btn-text {
    display: block;
}

.htmx-indicator {
    display: none;
}

.htmx-request .htmx-indicator {
    display: block;
}

.htmx-request .btn-text {
    display: none;
}

.login-footer {
    text-align: center;
    padding-top: 24px;
    border-top: 1px solid rgba(0, 0, 0, 0.05);
}

.login-footer p {
    font-size: 14px;
    color: var(--color-text-secondary);
    margin: 0;
}

.login-link {
    color: var(--color-interactive);
    text-decoration: none;
    border-bottom: 1px solid rgba(0, 85, 255, 0.2);
}

.login-link:hover {
    border-bottom-color: var(--color-interactive);
    background-color: rgba(0, 85, 255, 0.05);
}

.login-info {
    padding: 48px 0;
}

.login-info h2 {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 16px 0;
}

.login-info p {
    font-size: 16px;
    color: var(--color-text-secondary);
    line-height: 1.6;
    margin: 0 0 24px 0;
}

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

.login-benefits li {
    font-size: 16px;
    color: var(--color-text-primary);
    padding: 8px 0;
    line-height: 1.6;
}

/* Responsive Design */
@media (max-width: 768px) {
    .login-wrapper {
        grid-template-columns: 1fr;
        gap: 32px;
    }

    .login-card {
        padding: 32px 24px;
    }

    .login-info {
        padding: 0;
    }
}


/* --------------------------------------------------------------------------
   Component: components/organization/css/organization.css
   -------------------------------------------------------------------------- */

/* Organization Component Styles */

.organization-handle {
    font-size: 1rem;
    color: var(--color-text-secondary);
    font-weight: 500;
}

.organization-handle-inline {
    color: var(--color-text-secondary);
    font-weight: 400;
}

.organization-view .profile-header-wrapper {
    padding: var(--spacing-xs) 0;
}

.organization-header .profile-avatar,
.organization-header .profile-avatar-placeholder {
    width: 44px;
    height: 44px;
}

.organization-header .profile-avatar-placeholder {
    font-size: 1.1em;
}

.organization-header .profile-name {
    font-size: 1.15em;
}

.organization-header .profile-identity-row {
    gap: var(--spacing-sm);
}

.organization-view .profile-container {
    padding: var(--spacing-xs) var(--spacing-sm);
}

.organization-view .posts-section {
    margin-top: var(--spacing-sm);
}

.posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 16px;
    align-items: start;
}

/* Post Cards */
.post-card {
    background-color: #F0F0F0;
    padding: 14px 16px;
    border-radius: 4px;
    transition: background-color 0.2s ease;
    cursor: pointer;
}

.post-card:hover {
    background-color: #E8E8E8;
}

.post-content {
    color: var(--color-text-primary);
    line-height: 1.5;
    word-wrap: break-word;
}


.member-link {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    text-decoration: none;
    color: var(--color-text-primary);
}

.member-avatar,
.member-avatar-placeholder {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    flex-shrink: 0;
}

.member-avatar {
    object-fit: cover;
}

.member-avatar-placeholder {
    background-color: var(--color-brand-accent);
    color: var(--color-canvas);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 0.9rem;
}

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

.member-name {
    font-weight: 600;
    color: var(--color-text-primary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.member-username {
    font-size: 0.85rem;
    color: var(--color-text-secondary);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.member-badge {
    padding: 0.25rem 0.5rem;
    border-radius: 4px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.member-badge-owner {
    background-color: var(--color-brand-accent);
    color: var(--color-canvas);
}

.member-badge-admin {
    background-color: var(--color-interactive);
    color: var(--color-canvas);
}

/* Empty State */
.empty-state {
    background-color: var(--color-surface);
    border-radius: 6px;
    padding: var(--spacing-xl);
    text-align: center;
}

.empty-state p {
    color: var(--color-text-secondary);
    margin: 0;
}

/* Load More Trigger */
.load-more-trigger {
    padding: var(--spacing-md);
    text-align: center;
}

.load-more-spinner {
    color: var(--color-text-secondary);
    font-size: 0.9rem;
}

/* Footer */
.organization-footer {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
    padding: var(--spacing-lg) 0;
    margin-top: var(--spacing-xl);
}

.organization-footer-wrapper {
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 var(--spacing-md);
}

.organization-footer-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: var(--spacing-md);
}

.footer-left p {
    color: var(--color-text-secondary);
    font-size: 0.9rem;
    margin: 0;
}

.footer-right {
    display: flex;
    gap: var(--spacing-md);
}

.footer-right a {
    color: var(--color-text-secondary);
    font-size: 0.9rem;
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color 0.2s ease, border-bottom-color 0.2s ease;
}

.footer-right a:hover {
    color: var(--color-interactive);
    border-bottom-color: var(--color-interactive);
}

/* Responsive Design */
@media (max-width: 1100px) {
    .organization-content {
        grid-template-columns: 1fr;
    }

    .organization-members-section {
        position: static;
        order: -1; /* Show members above posts on mobile */
    }
}

@media (max-width: 1100px) {
    .posts-grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 800px) {
    .posts-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 600px) {
    .posts-grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }
}

@media (max-width: 768px) {
    .organization-identity-row {
        flex-direction: column;
        align-items: flex-start;
    }

    .organization-icon-placeholder {
        width: 56px;
        height: 56px;
        font-size: 1.25rem;
    }

    .organization-name {
        font-size: 1.5rem;
    }

    .organization-nav-right {
        width: 100%;
        justify-content: space-between;
    }

    .organization-footer-content {
        flex-direction: column;
        text-align: center;
    }
}


/* --------------------------------------------------------------------------
   Component: components/post/css/post.css
   -------------------------------------------------------------------------- */

/* Post Component - Single Post View */

.post-main {
  background-color: var(--color-canvas);
  min-height: 100vh;
  padding: var(--spacing-lg) var(--spacing-md);
}

.post-container {
  max-width: 680px;
  margin: 0 auto;
}

/* ============ ERROR STATE ============ */

.post-error {
  text-align: center;
  padding: var(--spacing-xl);
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
}

.post-error h1 {
  color: var(--color-text-primary);
  margin-bottom: var(--spacing-md);
}

.post-error p {
  color: var(--color-text-secondary);
  margin-bottom: var(--spacing-lg);
}

/* ============ POST AUTHOR ============ */

.post-author-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-md);
  margin-bottom: var(--spacing-sm);
}

.post-author-link {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  text-decoration: none;
}

.post-author-link:hover .post-author-name {
  color: var(--color-interactive);
}

.post-author-avatar,
.post-author-avatar-placeholder {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.post-author-avatar-placeholder {
  background-color: var(--color-avatar-green);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1em;
  font-weight: var(--font-weight-bold);
}

.post-author-name {
  font-size: 0.95em;
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  transition: color 0.2s ease;
}

.post-author-org {
  color: var(--color-text-secondary);
  font-weight: var(--font-weight-normal);
  margin-left: var(--spacing-xs);
}

.post-author-row .follow-button-wrapper {
  margin-left: auto;
}

.post-author-row .btn.btn-follow {
  font-size: 1em;
  line-height: 1;
  padding: 10px 21px;
}

/* ============ POST CARD - MATCHING PROFILE STYLE ============ */

.post-card {
  background-color: #F0F0F0;
  padding: 20px 22px;
  border-radius: 4px;
  margin-top: var(--spacing-sm);
}

/* Post Content */
.post-content {
  font-size: 1em;
  line-height: 1.5;
  color: var(--color-text-primary);
  word-wrap: break-word;
}

.post-content a {
  color: var(--color-interactive);
  text-decoration: underline;
}

.post-content a:hover {
  opacity: 0.8;
}

/* Post Footer */
.post-footer {
  display: flex;
  justify-content: flex-end;
  margin-top: var(--spacing-sm);
}

.post-share-link {
  color: #999999;
  text-decoration: none;
  font-size: 0.85em;
}

.post-share-link:hover {
  color: var(--color-text-secondary);
}

/* ============ POST META / BACK LINK ============ */

.post-meta {
  margin-top: var(--spacing-lg);
}

.post-back-link {
  color: var(--color-interactive);
  text-decoration: none;
  font-size: 0.9em;
}

.post-back-link:hover {
  text-decoration: underline;
}

/* ============ RESPONSIVE ============ */

@media (max-width: 768px) {
  .post-main {
    padding: var(--spacing-md) var(--spacing-sm);
  }
}


/* --------------------------------------------------------------------------
   Component: components/pricing/css/pricing.css
   -------------------------------------------------------------------------- */

/* Pricing Page Styles */

.pricing-page {
  background-color: var(--color-canvas, #FFFFFF);
  color: var(--color-text-primary, #1A1A1A);
}

.pricing-hero {
  background-color: var(--color-surface, #F9F9F9);
  padding: var(--spacing-xl, 64px) var(--spacing-lg, 32px);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.pricing-hero-content {
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
}

.pricing-eyebrow {
  display: inline-block;
  font-size: 0.9rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-secondary, #666666);
  margin-bottom: var(--spacing-sm, 12px);
}

.pricing-hero h1 {
  font-size: 2.6rem;
  font-weight: 600;
  line-height: 1.2;
  margin-bottom: var(--spacing-md, 16px);
}

.pricing-lead {
  font-size: 1.2rem;
  color: var(--color-text-secondary, #666666);
  line-height: 1.7;
  margin-bottom: var(--spacing-lg, 32px);
}

.pricing-hero-actions {
  display: flex;
  justify-content: center;
  gap: var(--spacing-md, 16px);
  flex-wrap: wrap;
}

.pricing-primary,
.pricing-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 28px;
  border-radius: 6px;
  font-weight: 600;
  text-decoration: none;
  transition: transform 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.pricing-primary {
  background-color: var(--color-interactive, #0055FF);
  color: #FFFFFF;
}

.pricing-primary:hover {
  transform: translateY(-2px);
  background-color: #0044cc;
}

.pricing-secondary {
  border: 1px solid rgba(0, 0, 0, 0.1);
  color: var(--color-text-primary, #1A1A1A);
  background-color: #FFFFFF;
}

.pricing-secondary:hover {
  transform: translateY(-2px);
  border-color: rgba(0, 85, 255, 0.3);
  color: var(--color-interactive, #0055FF);
}

.pricing-section {
  padding: var(--spacing-xl, 64px) 0;
}

.pricing-section-alt {
  background-color: var(--color-surface, #F9F9F9);
}

.pricing-section-cta {
  text-align: center;
}

.pricing-container {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg, 32px);
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--spacing-lg, 32px);
}

.pricing-card {
  background-color: #FFFFFF;
  border-radius: 6px;
  padding: var(--spacing-lg, 32px);
  border: 1px solid rgba(0, 0, 0, 0.05);
  display: flex;
  flex-direction: column;
  gap: var(--spacing-md, 16px);
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.pricing-card:hover {
  transform: translateY(-4px);
  border-color: rgba(0, 85, 255, 0.2);
}

.pricing-card-header h2 {
  margin: 0;
  font-size: 1.5rem;
}

.pricing-price {
  font-size: 1.4rem;
  font-weight: 600;
  margin: var(--spacing-sm, 12px) 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pricing-price small {
  font-size: 0.95rem;
  color: var(--color-text-secondary, #666666);
  font-weight: 500;
}

.pricing-tagline {
  color: var(--color-text-secondary, #666666);
  font-size: 0.95rem;
  line-height: 1.6;
}

.pricing-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
  color: var(--color-text-primary, #1A1A1A);
}

.pricing-list li::before {
  content: "✓";
  margin-right: 8px;
  color: var(--color-interactive, #0055FF);
}

.pricing-cta {
  margin-top: auto;
  text-align: center;
  padding: 12px 18px;
  border-radius: 6px;
  background-color: var(--color-interactive, #0055FF);
  color: #FFFFFF;
  text-decoration: none;
  font-weight: 600;
}

.pricing-cta:hover {
  background-color: #0044cc;
}

.pricing-cta-secondary {
  background-color: #111111;
}

.pricing-cta-secondary:hover {
  background-color: #333333;
}

.pricing-note {
  margin-top: var(--spacing-lg, 32px);
  color: var(--color-text-secondary, #666666);
  font-size: 0.95rem;
  text-align: center;
}

.pricing-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--spacing-lg, 32px);
}

.pricing-feature h3 {
  font-size: 1.1rem;
  margin-bottom: var(--spacing-sm, 12px);
}

.pricing-feature p {
  color: var(--color-text-secondary, #666666);
  line-height: 1.7;
}

.pricing-two-column {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--spacing-xl, 48px);
  align-items: start;
}

.pricing-reasons {
  list-style: none;
  padding: 0;
  margin: var(--spacing-md, 16px) 0 0;
  display: grid;
  gap: 12px;
}

.pricing-reasons li::before {
  content: "•";
  margin-right: 8px;
  color: var(--color-interactive, #0055FF);
}

.pricing-panel {
  background-color: #FFFFFF;
  padding: var(--spacing-lg, 32px);
  border-radius: 6px;
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.pricing-panel ul {
  padding-left: 18px;
  margin: 16px 0 24px;
  color: var(--color-text-secondary, #666666);
}

.pricing-faq {
  display: grid;
  gap: var(--spacing-md, 16px);
}

.pricing-faq details {
  background-color: #FFFFFF;
  border-radius: 6px;
  padding: 16px 20px;
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.pricing-faq summary {
  font-weight: 600;
  cursor: pointer;
}

.pricing-faq p {
  margin: 12px 0 0;
  color: var(--color-text-secondary, #666666);
  line-height: 1.7;
}

@media (max-width: 768px) {
  .pricing-hero h1 {
    font-size: 2rem;
  }

  .pricing-lead {
    font-size: 1rem;
  }
}

@media (max-width: 480px) {
  .pricing-primary,
  .pricing-secondary,
  .pricing-cta {
    width: 100%;
  }
}


/* --------------------------------------------------------------------------
   Component: components/privacy/css/privacy.css
   -------------------------------------------------------------------------- */

/* Legal Pages Styles (Privacy & Terms) */

.legal-page {
  padding: var(--spacing-lg, 32px) 0;
  background-color: var(--color-canvas, #FFFFFF);
}

/* Hero Section */
.legal-hero {
  background-color: var(--color-surface, #F9F9F9);
  padding: var(--spacing-xl, 64px) var(--spacing-lg, 32px);
  text-align: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.legal-hero-content {
  max-width: 900px;
  margin: 0 auto;
}

.legal-hero h1 {
  font-size: 2.5rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-sm, 12px);
  line-height: 1.2;
}

.legal-meta {
  font-size: 0.9rem;
  color: var(--color-text-secondary, #666666);
  margin-bottom: var(--spacing-md, 16px);
  font-weight: 500;
}

.legal-hero .legal-lead {
  font-size: 1.1rem;
  color: var(--color-text-secondary, #666666);
  line-height: 1.65;
  font-weight: 500;
}

/* Main Container */
.legal-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg, 32px);
}

/* Sections */
.legal-section {
  padding: var(--spacing-xl, 64px) 0;
  background-color: var(--color-canvas, #FFFFFF);
}

.legal-section-alt {
  background-color: var(--color-surface, #F9F9F9);
}

.legal-section h2 {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-md, 16px);
  margin-top: 0;
  line-height: 1.3;
}

.legal-section h3 {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-top: var(--spacing-md, 16px);
  margin-bottom: var(--spacing-sm, 12px);
  line-height: 1.3;
}

.legal-section h3:first-child {
  margin-top: var(--spacing-md, 16px);
}

.legal-section p {
  font-size: 1rem;
  color: var(--color-text-primary, #1A1A1A);
  line-height: 1.8;
  margin-bottom: var(--spacing-md, 16px);
}

.legal-section p:last-child {
  margin-bottom: 0;
}

.legal-section strong {
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
}

/* Lists */
.legal-list {
  list-style: none;
  padding-left: 0;
  margin-bottom: var(--spacing-md, 16px);
}

.legal-list li {
  font-size: 1rem;
  color: var(--color-text-primary, #1A1A1A);
  line-height: 1.8;
  margin-bottom: var(--spacing-sm, 12px);
  padding-left: var(--spacing-md, 16px);
  position: relative;
}

.legal-list li:before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--color-interactive, #0055FF);
  font-weight: bold;
}

.legal-list li strong {
  font-weight: 600;
}

/* Links */
.legal-section a {
  color: var(--color-interactive, #0055FF);
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 85, 255, 0.2);
  transition: all 0.2s ease;
}

.legal-section a:hover {
  border-bottom-color: var(--color-interactive, #0055FF);
  background-color: rgba(0, 85, 255, 0.05);
}

/* Responsive */
@media (max-width: 768px) {
  .legal-hero h1 {
    font-size: 1.75rem;
  }

  .legal-section h2 {
    font-size: 1.4rem;
  }

  .legal-section h3 {
    font-size: 1.05rem;
  }

  .legal-section {
    padding: var(--spacing-lg, 32px) 0;
  }

  .legal-hero {
    padding: var(--spacing-lg, 32px);
  }
}

@media (max-width: 480px) {
  .legal-hero h1 {
    font-size: 1.5rem;
  }

  .legal-section h2 {
    font-size: 1.2rem;
  }

  .legal-section p,
  .legal-list li {
    font-size: 0.95rem;
  }
}


/* --------------------------------------------------------------------------
   Component: components/profile/css/profile.css
   -------------------------------------------------------------------------- */

/* Profile Component - Production Match */

.profile-main {
  background-color: var(--color-canvas);
  min-height: 100vh;
}

.profile-container {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
  padding: var(--spacing-xs) var(--spacing-sm);
}

/* ============ PROFILE HEADER - PRODUCTION LAYOUT ============ */

.profile-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: var(--color-canvas);
  border-bottom: 1px solid var(--color-border);
}

.profile-header-wrapper {
  padding: var(--spacing-xs) 0;
}

.profile-header-inner {
  max-width: var(--wrapper-max-width);
  margin: 0 auto;
  padding: 0 var(--spacing-md);
  overflow: hidden;
}

/* Identity Row: Name Left, Links/Orgs Right */
.profile-identity-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-md);
}

.profile-identity-left {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.profile-avatar-link {
  text-decoration: none;
}

.profile-avatar,
.profile-avatar-placeholder {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.profile-avatar-placeholder {
  background-color: var(--color-avatar-green);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1em;
  font-weight: var(--font-weight-bold);
}

.profile-name {
  font-size: 1.15em;
  margin: 0;
  line-height: 1.2;
}

.profile-name a {
  color: var(--color-text-primary);
  text-decoration: none;
}

.profile-name a:hover {
  color: var(--color-interactive);
}

/* Navigation Right */
.profile-nav-right {
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
  flex-wrap: wrap;
}

.profile-nav-link {
  color: var(--color-text-secondary);
  text-decoration: none;
  font-size: 0.95em;
  white-space: nowrap;
}

.profile-nav-link--with-icon {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
}

.profile-nav-link--with-icon .icon {
  font-size: 1.1em;
  line-height: 1;
}

.profile-nav-link:hover {
  color: var(--color-interactive);
}

.profile-nav-link--desktop {
  /* Visible on desktop, hidden on mobile */
}

.profile-nav-more-orgs {
  color: var(--color-text-secondary);
  font-size: 0.85em;
}

.profile-org-link {
  color: var(--color-interactive);
}

.profile-nav-more {
  background: none;
  border: none;
  color: var(--color-interactive);
  font-size: 0.95em;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
}

.profile-nav-links-summary {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-xs);
  text-decoration: none;
}

.profile-nav-links-summary .chevron {
  font-size: 0.9em;
}

.profile-nav-more:hover {
  opacity: 0.8;
}

/* More Links Container - Horizontal Centered Pill Flow */
.profile-more-links {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--spacing-xs);
  margin-top: var(--spacing-sm);
  padding: var(--spacing-sm) 0;
  border-top: 1px solid var(--color-border);
}

.profile-more-link-item {
  display: inline-flex;
}

.profile-nav-link-expanded {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  background-color: var(--color-surface);
  border-radius: 16px;
  text-decoration: none;
  color: var(--color-text-primary);
  font-size: 0.85em;
  transition: all 0.15s ease;
  border: 1px solid var(--color-border);
}
}

.profile-nav-link-expanded:hover {
  background-color: var(--color-surface-hover);
  border-color: var(--color-interactive);
  color: var(--color-interactive);
}

.profile-nav-link-expanded .icon {
  font-size: 0.9em;
  line-height: 1;
  flex-shrink: 0;
}

.profile-nav-link-expanded .label {
  font-size: 0.85em;
  color: inherit;
  white-space: nowrap;
}

/* Org links in expanded panel get blue tint */
.profile-nav-link-expanded.profile-org-link {
  background-color: rgba(0, 85, 255, 0.08);
  border-color: rgba(0, 85, 255, 0.2);
  color: var(--color-interactive);
}

.profile-nav-link-expanded.profile-org-link:hover {
  background-color: rgba(0, 85, 255, 0.15);
}

/* Profile Bio - Subtle description below header */
.profile-bio {
  margin-top: var(--spacing-xs);
}

.profile-bio-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-xs);
  max-width: 100%;
  overflow: hidden;
}

.profile-bio {
  flex: 1;
  min-width: 0;
  overflow: hidden;
}

.profile-bio p {
  font-size: 0.85em;
  color: var(--color-text-secondary);
  line-height: 1.5;
  margin: 0;
  font-style: italic;
  overflow: hidden;
  text-overflow: ellipsis;
}

.follow-button-wrapper {
  display: flex;
  justify-content: flex-end;
  flex-shrink: 0;
}

.btn.btn-follow {
  background-color: var(--color-text-primary);
  color: #ffffff;
  border: 1px solid var(--color-text-primary);
  border-radius: var(--border-radius);
  padding: 10px 21px;
  font-size: 0.9em;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.2s ease;
}

.btn.btn-follow:hover {
  background-color: #333333;
  border-color: #333333;
}

.btn.btn-follow.is-following {
  background-color: #ffffff;
  color: var(--color-text-primary);
  border-color: #dcdcdc;
}

.btn.btn-follow.is-following:hover {
  color: var(--color-text-primary);
  border-color: #bdbdbd;
  background-color: #f3f3f3;
}

/* ============ POST CREATION ============ */

.post-creation-section {
  background-color: var(--color-surface);
  padding: var(--card-padding);
  margin-bottom: var(--spacing-xl);
  border-radius: var(--border-radius);
}

.post-creation-section h2 {
  font-size: 1.25em;
  margin-bottom: var(--spacing-md);
  color: var(--color-text-primary);
}

.character-count {
  text-align: right;
  font-size: 0.9em;
  color: var(--color-text-secondary);
  margin-top: var(--spacing-xs);
}

.form-actions {
  display: flex;
  gap: var(--spacing-sm);
  align-items: center;
}

/* ============ POSTS GRID - PRODUCTION MATCH ============ */

.posts-section {
  margin-top: var(--spacing-md);
}

.posts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px;
  align-items: start;
}

.post-card {
  background-color: #F0F0F0;
  padding: 16px 20px;
  border-radius: 4px;
  transition: background-color 0.2s ease;
  cursor: pointer;
}

.post-card:hover {
  background-color: #E8E8E8;
}

/* Post Content */
.post-content {
  font-size: 1em;
  line-height: 1.5;
  color: var(--color-text-primary);
  word-wrap: break-word;
}

.post-content p {
  margin: 0 0 0.5em 0;
}

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

.post-content a {
  color: var(--color-interactive);
  text-decoration: underline;
  position: relative;
  z-index: 1;
}

.post-content a:hover {
  opacity: 0.8;
}

.post-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--spacing-sm);
  font-size: 0.85em;
  color: var(--color-text-secondary);
}

.post-author {
  color: var(--color-text-secondary);
  text-decoration: none;
}

.post-author:hover {
  color: var(--color-interactive);
}

.post-date {
  color: var(--color-text-secondary);
}

.post-expand {
  color: var(--color-interactive);
  text-decoration: underline;
  font-size: 1em;
  margin-left: 4px;
}

.post-expand:hover {
  opacity: 0.8;
}

/* Post Footer */
.post-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-sm);
  margin-top: var(--spacing-sm);
}

.post-footer-left {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.post-org-label {
  font-size: 0.85em;
  color: var(--color-text-secondary);
  text-decoration: none;
}

.post-org-label:hover {
  color: var(--color-interactive);
}

.post-visibility-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 0.85em;
  color: var(--color-text-secondary);
}

.post-visibility-toggle input {
  margin: 0;
}

.post-share-link {
  color: #999999;
  text-decoration: none;
  font-size: 0.85em;
}

.post-share-link:hover {
  color: var(--color-text-secondary);
}

/* No Posts State */
.no-posts {
  text-align: center;
  padding: var(--spacing-xl);
  color: var(--color-text-secondary);
  background-color: var(--color-surface);
  border-radius: var(--border-radius);
}

/* Infinite Scroll Loading */
.posts-loading {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--spacing-lg);
  color: var(--color-text-secondary);
  font-size: 0.9em;
}

/* ============ RESPONSIVE ============ */

@media (max-width: 1100px) {
  .posts-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 800px) {
  .posts-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .profile-identity-row {
    gap: var(--spacing-sm);
  }

  .profile-nav-right {
    gap: var(--spacing-xs);
  }
  
  /* Hide desktop-only links on mobile */
  .profile-nav-link--desktop {
    display: none;
  }
  
  .profile-avatar,
  .profile-avatar-placeholder {
    width: 40px;
    height: 40px;
  }
  
  .profile-avatar-placeholder {
    font-size: 1em;
  }
  
  .profile-name {
    font-size: 1.1em;
  }
}

@media (max-width: 600px) {
  .posts-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

@media (max-width: 500px) {
  .posts-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .profile-main {
    padding: var(--spacing-sm) var(--spacing-xs);
  }
  
  .profile-header-inner {
    padding: 0 var(--spacing-sm);
  }

  /* Keep horizontal layout on mobile */
  .profile-identity-row {
    flex-direction: row;
    align-items: center;
    text-align: left;
  }

  .profile-identity-left {
    flex-direction: row;
    gap: var(--spacing-xs);
  }
  
  .profile-avatar,
  .profile-avatar-placeholder {
    width: 36px;
    height: 36px;
  }
  
  .profile-avatar-placeholder {
    font-size: 0.9em;
  }
  
  .profile-name {
    font-size: 1em;
  }

  .profile-nav-right {
    flex-direction: row;
    align-items: center;
  }

  .profile-more-links {
    justify-content: center;
  }
  
  .profile-bio p {
    font-size: 0.8em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
  }

  .post-card {
    padding: 16px;
  }
}

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

/* ============ USER NOT FOUND PAGE ============ */

.not-found-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  background-color: var(--color-canvas);
}

.not-found-header {
  padding: var(--spacing-md) var(--spacing-lg);
  border-bottom: 1px solid var(--color-border);
}

.not-found-brand {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-sm);
  text-decoration: none;
  color: var(--color-text-primary);
  font-weight: 600;
  font-size: 1.125rem;
}

.not-found-brand img {
  display: block;
}

.not-found-main {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--spacing-xl) var(--spacing-lg);
}

.not-found-content {
  text-align: center;
  max-width: 420px;
}

.not-found-illustration {
  margin-bottom: var(--spacing-md);
}

.not-found-emoji {
  font-size: 4rem;
  display: inline-block;
  animation: wave 2s ease-in-out infinite;
  transform-origin: 70% 70%;
}

@keyframes wave {
  0%, 100% { transform: rotate(0deg); }
  10%, 30% { transform: rotate(14deg); }
  20% { transform: rotate(-8deg); }
  40% { transform: rotate(-4deg); }
  50%, 100% { transform: rotate(0deg); }
}

.not-found-title {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0 0 var(--spacing-sm) 0;
}

.not-found-message {
  font-size: 1rem;
  color: var(--color-text-secondary);
  line-height: 1.6;
  margin: 0 0 var(--spacing-lg) 0;
}

.not-found-actions {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  align-items: center;
}

.not-found-btn-primary {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background-color: var(--color-text-primary);
  color: white;
  text-decoration: none;
  border-radius: var(--border-radius);
  font-weight: 500;
  font-size: 1rem;
  transition: background-color 0.2s, transform 0.1s;
  min-width: 200px;
}

.not-found-btn-primary:hover {
  background-color: #1f1f1f;
  transform: translateY(-1px);
}

.not-found-btn-secondary {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background-color: transparent;
  color: var(--color-text-primary);
  text-decoration: none;
  border: 1px solid var(--color-text-primary);
  border-radius: var(--border-radius);
  font-weight: 500;
  font-size: 1rem;
  transition: background-color 0.2s, color 0.2s;
  min-width: 200px;
}

.not-found-btn-secondary:hover {
  background-color: var(--color-text-primary);
  color: #ffffff;
}

.not-found-footer {
  padding: var(--spacing-md) var(--spacing-lg);
  border-top: 1px solid var(--color-border);
  text-align: center;
  color: var(--color-text-secondary);
  font-size: 0.875rem;
}

.not-found-footer p {
  margin: 0;
}

@media (max-width: 480px) {
  .not-found-main {
    padding: var(--spacing-lg) var(--spacing-md);
  }

  .not-found-title {
    font-size: 1.5rem;
  }

  .not-found-emoji {
    font-size: 3rem;
  }

  .not-found-btn-primary,
  .not-found-btn-secondary {
    width: 100%;
    min-width: auto;
  }
}


/* --------------------------------------------------------------------------
   Component: components/registration/css/registration.css
   -------------------------------------------------------------------------- */

/* Registration Component Styles */

.registration-main {
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
    background-color: var(--color-canvas);
}

.registration-container {
    width: 100%;
    max-width: 500px;
}

.registration-card {
    background-color: var(--color-surface);
    border-radius: 6px;
    padding: var(--spacing-lg);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.registration-title {
    font-size: 1.75rem;
    font-weight: 600;
    color: var(--color-text-primary);
    margin-bottom: 0.5rem;
    line-height: 1.4;
}

.registration-subtitle {
    font-size: 0.95rem;
    color: var(--color-text-secondary);
    margin-bottom: var(--spacing-md);
}

/* Form Styles */
.registration-form {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.form-label {
    font-size: 0.95rem;
    font-weight: 500;
    color: var(--color-text-primary);
}

.form-input,
.form-textarea {
    padding: 0.75rem;
    border: 1px solid rgba(0, 0, 0, 0.1);
    border-radius: 4px;
    font-family: inherit;
    font-size: 1rem;
    color: var(--color-text-primary);
    background-color: var(--color-canvas);
    transition: border-color 0.2s, background-color 0.2s;
}

.form-input:focus,
.form-textarea:focus {
    outline: none;
    border-color: var(--color-interactive);
    background-color: var(--color-canvas);
    box-shadow: 0 0 0 3px rgba(0, 85, 255, 0.1);
}

.form-textarea {
    resize: vertical;
    font-size: 0.95rem;
    line-height: 1.5;
}

.form-help {
    font-size: 0.85rem;
    color: var(--color-text-secondary);
}

.form-button {
    padding: 0.875rem 1.5rem;
    background-color: var(--color-button);
    color: white;
    border: none;
    border-radius: var(--border-radius);
    font-size: 1rem;
    font-weight: 500;
    cursor: pointer;
    transition: background-color 0.2s, transform 0.1s;
}

.form-button:hover {
    background-color: var(--color-button-hover);
    transform: translateY(-1px);
}

.form-button:active {
    transform: translateY(0);
}

.form-button:disabled {
    opacity: 0.6;
    cursor: not-allowed;
    transform: none;
}

.form-footer {
    text-align: center;
    font-size: 0.95rem;
    color: var(--color-text-secondary);
    margin-top: var(--spacing-md);
}

.form-link {
    color: var(--color-interactive);
    text-decoration: none;
    border-bottom: 1px solid rgba(0, 85, 255, 0.2);
    transition: border-color 0.2s;
}

.form-link:hover {
    border-bottom-color: var(--color-interactive);
    background-color: rgba(0, 85, 255, 0.05);
}

/* Error and Success Messages */
.registration-errors {
    background-color: #fee;
    border: 1px solid #fcc;
    border-radius: 4px;
    padding: var(--spacing-md);
    margin-bottom: var(--spacing-md);
}

.error-message {
    color: #c33;
    font-size: 0.95rem;
    line-height: 1.5;
    margin-bottom: 0.5rem;
}

.error-message:last-child {
    margin-bottom: 0;
}

.success-message {
    background-color: #efe;
    border: 1px solid #cfc;
    border-radius: 4px;
    padding: var(--spacing-md);
    color: #3c3;
    font-size: 0.95rem;
    line-height: 1.5;
}

/* Responsive Design */
@media (max-width: 600px) {
    .registration-main {
        padding: var(--spacing-md);
        min-height: auto;
    }

    .registration-card {
        padding: var(--spacing-md);
    }

    .registration-title {
        font-size: 1.5rem;
    }
}


/* --------------------------------------------------------------------------
   Component: components/settings/css/settings.css
   -------------------------------------------------------------------------- */

/* Settings Component Styles */

.settings-container {
    max-width: 800px;
    margin: 0 auto;
    padding: 64px 24px;
}

.settings-wrapper {
    background: var(--color-canvas);
}

.settings-title {
    font-size: 32px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 32px 0;
}

.settings-card {
    background: var(--color-surface);
    border-radius: 6px;
    padding: 48px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.settings-section-title {
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 8px 0;
}

.settings-section-description {
    font-size: 16px;
    color: var(--color-text-secondary);
    margin: 0 0 32px 0;
    line-height: 1.6;
}

.settings-form {
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.settings-section {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.settings-subsection-title {
    font-size: 18px;
    font-weight: 600;
    color: var(--color-text-primary);
    margin: 0 0 12px 0;
}

.form-checkbox {
    display: flex;
    gap: 12px;
    padding: 16px;
    border-radius: 4px;
    transition: background-color 0.2s;
}

.form-checkbox:hover {
    background: rgba(0, 0, 0, 0.02);
}

.form-checkbox input[type="checkbox"] {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.form-checkbox label {
    flex: 1;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.form-checkbox label strong {
    font-size: 16px;
    font-weight: 500;
    color: var(--color-text-primary);
}

.form-checkbox-description {
    font-size: 14px;
    color: var(--color-text-secondary);
    line-height: 1.5;
}

/* Responsive Design */
@media (max-width: 768px) {
    .settings-card {
        padding: 32px 24px;
    }

    .settings-container {
        padding: 32px 16px;
    }
}


/* --------------------------------------------------------------------------
   Component: components/terms/css/terms.css
   -------------------------------------------------------------------------- */

/* Legal Pages Styles (Privacy & Terms) */

.legal-page {
  padding: var(--spacing-lg, 32px) 0;
  background-color: var(--color-canvas, #FFFFFF);
}

/* Hero Section */
.legal-hero {
  background-color: var(--color-surface, #F9F9F9);
  padding: var(--spacing-xl, 64px) var(--spacing-lg, 32px);
  text-align: center;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}

.legal-hero-content {
  max-width: 900px;
  margin: 0 auto;
}

.legal-hero h1 {
  font-size: 2.5rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-sm, 12px);
  line-height: 1.2;
}

.legal-meta {
  font-size: 0.9rem;
  color: var(--color-text-secondary, #666666);
  margin-bottom: var(--spacing-md, 16px);
  font-weight: 500;
}

.legal-hero .legal-lead {
  font-size: 1.1rem;
  color: var(--color-text-secondary, #666666);
  line-height: 1.65;
  font-weight: 500;
}

/* Main Container */
.legal-container {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg, 32px);
}

/* Sections */
.legal-section {
  padding: var(--spacing-xl, 64px) 0;
  background-color: var(--color-canvas, #FFFFFF);
}

.legal-section-alt {
  background-color: var(--color-surface, #F9F9F9);
}

.legal-section h2 {
  font-size: 1.75rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-bottom: var(--spacing-md, 16px);
  margin-top: 0;
  line-height: 1.3;
}

.legal-section h3 {
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
  margin-top: var(--spacing-md, 16px);
  margin-bottom: var(--spacing-sm, 12px);
  line-height: 1.3;
}

.legal-section h3:first-child {
  margin-top: var(--spacing-md, 16px);
}

.legal-section p {
  font-size: 1rem;
  color: var(--color-text-primary, #1A1A1A);
  line-height: 1.8;
  margin-bottom: var(--spacing-md, 16px);
}

.legal-section p:last-child {
  margin-bottom: 0;
}

.legal-section strong {
  font-weight: 600;
  color: var(--color-text-primary, #1A1A1A);
}

/* Lists */
.legal-list {
  list-style: none;
  padding-left: 0;
  margin-bottom: var(--spacing-md, 16px);
}

.legal-list li {
  font-size: 1rem;
  color: var(--color-text-primary, #1A1A1A);
  line-height: 1.8;
  margin-bottom: var(--spacing-sm, 12px);
  padding-left: var(--spacing-md, 16px);
  position: relative;
}

.legal-list li:before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--color-interactive, #0055FF);
  font-weight: bold;
}

.legal-list li strong {
  font-weight: 600;
}

/* Links */
.legal-section a {
  color: var(--color-interactive, #0055FF);
  text-decoration: none;
  border-bottom: 1px solid rgba(0, 85, 255, 0.2);
  transition: all 0.2s ease;
}

.legal-section a:hover {
  border-bottom-color: var(--color-interactive, #0055FF);
  background-color: rgba(0, 85, 255, 0.05);
}

/* Responsive */
@media (max-width: 768px) {
  .legal-hero h1 {
    font-size: 1.75rem;
  }

  .legal-section h2 {
    font-size: 1.4rem;
  }

  .legal-section h3 {
    font-size: 1.05rem;
  }

  .legal-section {
    padding: var(--spacing-lg, 32px) 0;
  }

  .legal-hero {
    padding: var(--spacing-lg, 32px);
  }
}

@media (max-width: 480px) {
  .legal-hero h1 {
    font-size: 1.5rem;
  }

  .legal-section h2 {
    font-size: 1.2rem;
  }

  .legal-section p,
  .legal-list li {
    font-size: 0.95rem;
  }
}


