/* ============================================================
   Surbias - Warm, Human, Honest
   Outfit via Google Fonts <link> in HTML head.
   ============================================================ */

/* ============================================================
   DESIGN TOKENS - Light Mode
   ============================================================ */
:root {
  /* Brand: soft sage green / warm gold - NO BLUE */
  --surbias-primary:       #4a7c59;
  --surbias-primary-hover: #3d6b4a;
  --surbias-accent:        #8fb89a;
  --surbias-warm:          #b8860b;
  --surbias-warm-light:    #f0f5f1;
  --surbias-warm-tint:     #e8f0ea;

  /* Backgrounds */
  --surbias-bg:         #f5f9f6;
  --surbias-card-bg:    #ffffff;
  --surbias-header-bg:  #f9fcfa;

  /* Text */
  --surbias-text:        #161e18;
  --surbias-text-muted:  #556b5c;
  --surbias-text-light:  #8aaa92;

  /* Borders */
  --surbias-border: #d4e3d9;

  /* Status */
  --surbias-success:       #1d7a3f;
  --surbias-success-light: #dcfce7;
  --surbias-danger:        #c0392b;
  --surbias-danger-light:  #fde8e8;

  /* Green-toned shadows */
  --shadow-sm:  0 1px 3px rgba(22,30,24,.07), 0 1px 2px rgba(22,30,24,.04);
  --shadow-md:  0 4px 14px rgba(22,30,24,.10), 0 2px 4px rgba(22,30,24,.06);
  --shadow-lg:  0 10px 32px rgba(22,30,24,.13), 0 4px 8px rgba(22,30,24,.07);
  --shadow-cta: 0 4px 18px rgba(74,124,89,.42);

  /* Radii */
  --radius-sm:   4px;
  --radius-md:   10px;
  --radius-lg:   16px;
  --radius-xl:   20px;
  --radius-pill: 9999px;

  /* Motion */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --dur-fast: 140ms;
  --dur-base: 220ms;
  --dur-slow: 360ms;

  /* Layout */
  --container-max: 960px;

  /* Pico CSS overrides */
  --pico-font-family:                'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --pico-border-radius:              var(--radius-md);
  --pico-primary:                    var(--surbias-primary);
  --pico-primary-hover:              var(--surbias-primary-hover);
  --pico-background-color:           var(--surbias-bg);
  --pico-color:                      var(--surbias-text);
  --pico-muted-color:                var(--surbias-text-muted);
  --pico-border-color:               var(--surbias-border);
  --pico-form-element-border-color:  var(--surbias-border);
  --pico-form-element-focus-color:   var(--surbias-primary);
}

/* Dark mode removed — light theme only */

/* ============================================================
   BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

body {
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background-color: var(--surbias-bg);
  color: var(--surbias-text);
  line-height: 1.65;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
}

main {
  flex: 1;
  max-width: 100%;
  margin: 0 auto;
  padding: 2rem 2.5rem;
  width: 100%;
}

a {
  color: var(--surbias-primary);
  transition: color var(--dur-fast) var(--ease-out);
}
a:hover { color: var(--surbias-primary-hover); }

h1, h2, h3, h4, h5, h6 {
  line-height: 1.22;
  letter-spacing: -0.018em;
  font-weight: 700;
  color: var(--surbias-text);
}

/* ============================================================
   SITE HEADER
   ============================================================ */
.site-header {
  background: var(--surbias-header-bg);
  border-bottom: 1px solid var(--surbias-border);
  padding: 0.8rem 0;
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 1px 0 var(--surbias-border), var(--shadow-sm);
  backdrop-filter: blur(10px) saturate(160%);
  -webkit-backdrop-filter: blur(10px) saturate(160%);
}

.site-header nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 2.5rem;
  gap: 1rem;
}

.site-logo {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--surbias-primary);
  text-decoration: none;
  letter-spacing: -0.035em;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  white-space: nowrap;
  line-height: 1;
  transition: opacity var(--dur-fast) var(--ease-out);
}
.site-logo:hover { opacity: 0.8; color: var(--surbias-primary); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 0.2rem;
  list-style: none;
  margin: 0;
  padding: 0;
  flex-wrap: wrap;
}

.nav-links a {
  text-decoration: none;
  color: var(--surbias-text-muted);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 0.375rem 0.625rem;
  border-radius: var(--radius-sm);
  transition: color var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.nav-links a:hover {
  color: var(--surbias-text);
  background: rgba(74,124,89,.10);
}
.nav-links a[aria-current="page"] {
  color: var(--surbias-primary);
  font-weight: 600;
  background: rgba(74,124,89,.10);
}

/* ============================================================
   CTA BUTTON
   ============================================================ */
.btn-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  background: var(--surbias-primary);
  color: #fff !important;
  padding: 0.65rem 1.5rem;
  border-radius: var(--radius-pill);
  text-decoration: none;
  font-weight: 700;
  font-size: 0.9375rem;
  letter-spacing: 0.008em;
  border: none;
  cursor: pointer;
  box-shadow: var(--shadow-cta);
  font-family: inherit;
  white-space: nowrap;
  transition: background var(--dur-base) var(--ease-out),
              transform  var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.btn-cta:hover {
  background: var(--surbias-primary-hover);
  transform: translateY(-2px);
  box-shadow: 0 6px 22px rgba(74,124,89,.52);
  color: #fff !important;
}
.btn-cta:active {
  transform: translateY(0);
  box-shadow: var(--shadow-cta);
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero {
  text-align: center;
  padding: 4.25rem 1.5rem 3.25rem;
  margin-bottom: 2.5rem;
  background: linear-gradient(150deg, #f2f8f4 0%, #ebf4ee 45%, #f0f7f2 100%);
  border-radius: var(--radius-xl);
  border: 1.5px solid var(--surbias-border);
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

/* dark mode hero removed */

/* dot grid texture */
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, var(--surbias-border) 1px, transparent 1px);
  background-size: 26px 26px;
  opacity: 0.55;
  pointer-events: none;
}

/* top warm accent bar */
.hero::after {
  content: '';
  position: absolute;
  top: 0; left: 10%; right: 10%;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--surbias-primary), var(--surbias-accent), transparent);
  border-radius: 0 0 9999px 9999px;
  opacity: 0.6;
}

.hero-emoji {
  font-size: 3.5rem;
  line-height: 1;
  margin-bottom: 1rem;
  display: block;
  position: relative;
  filter: drop-shadow(0 2px 6px rgba(74,124,89,.25));
}

.hero h1 {
  font-size: clamp(2rem, 5.5vw, 3rem);
  font-weight: 800;
  margin-bottom: 0.75rem;
  color: var(--surbias-text);
  letter-spacing: -0.035em;
  line-height: 1.15;
  position: relative;
}

.hero .tagline {
  font-size: clamp(0.975rem, 2.5vw, 1.2rem);
  color: var(--surbias-text-muted);
  margin: 0 auto 2.25rem;
  max-width: 520px;
  line-height: 1.65;
  position: relative;
}

.hero-cta-group {
  display: flex;
  gap: 1rem;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
}

.hero-stat {
  font-size: 0.84rem;
  color: var(--surbias-text-muted);
  font-weight: 500;
}

/* Statement bar — replaces compact hero */
.statement-bar {
  padding: 1.5rem 2rem;
  margin-bottom: 1.5rem;
  background: #000000;
}

.statement-bar .statement-text {
  font-size: clamp(1rem, 2.2vw, 1.15rem);
  color: #ffffff;
  line-height: 1.7;
  margin: 0;
}

.statement-bar .statement-text strong {
  color: #4a7c59;
  font-weight: 700;
}

@media (max-width: 640px) {
  .statement-bar {
    padding: 1.1rem 1.25rem;
  }
}

/* Inline form section */
.inline-form-section {
  margin-bottom: 1.5rem;
}
.inline-form-section .post-form-inline {
  max-width: 100%;
  background: var(--surbias-card-bg);
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-lg);
  padding: 1rem;
  box-shadow: var(--shadow-sm);
}
.inline-form-row {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
.inline-title {
  min-width: 0;
  font-family: inherit;
  flex: 1;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  background: var(--surbias-bg);
}
.inline-category {
  width: 140px;
  flex-shrink: 0;
  font-family: inherit;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  background: var(--surbias-bg);
}
.inline-body {
  width: 100%;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  font-size: 0.9rem;
  font-family: inherit;
  resize: vertical;
  min-height: 50px;
  background: var(--surbias-bg);
  margin-bottom: 0.75rem;
}
.inline-title:focus, .inline-category:focus, .inline-body:focus {
  outline: none;
  border-color: var(--surbias-primary);
  box-shadow: 0 0 0 2px rgba(74,124,89,.15);
}

@media (max-width: 640px) {
  .inline-form-row {
    flex-direction: column;
  }
  .inline-category {
    width: 100%;
  }
}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.section-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--surbias-text-muted);
}

/* ============================================================
   CATEGORY FILTER PILLS
   ============================================================ */
.category-filter {
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-bottom: 2rem;
  padding: 0;
  list-style: none;
  align-items: center;
}

.category-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.4rem 1rem;
  border-radius: var(--radius-pill);
  font-size: 0.84rem;
  font-weight: 500;
  text-decoration: none;
  background: var(--surbias-card-bg);
  color: var(--surbias-text-muted);
  border: 1.5px solid var(--surbias-border);
  cursor: pointer;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
  line-height: 1;
  transition: background    var(--dur-base) var(--ease-out),
              color         var(--dur-fast) var(--ease-out),
              border-color  var(--dur-base) var(--ease-out),
              box-shadow    var(--dur-base) var(--ease-out),
              transform     var(--dur-fast) var(--ease-out);
}
.category-pill:hover {
  background: rgba(74,124,89,.10);
  color: var(--surbias-primary);
  border-color: rgba(74,124,89,.30);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.category-pill.active {
  background: var(--surbias-primary);
  color: #fff;
  border-color: var(--surbias-primary);
  box-shadow: 0 2px 10px rgba(74,124,89,.35);
  font-weight: 600;
  transform: translateY(-1px);
}

.category-pill .cat-emoji {
  font-size: 0.95em;
  line-height: 1;
}

/* ============================================================
   POST CARDS
   ============================================================ */
.posts-grid {
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}

.post-card {
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.5rem 1.4rem 1.75rem;
  position: relative;
  overflow: hidden;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: box-shadow    var(--dur-base) var(--ease-out),
              border-color  var(--dur-base) var(--ease-out),
              transform     var(--dur-base) var(--ease-out);
}

.post-card-link {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.post-card h3 a,
.post-card .read-more-link,
.post-card .reaction-btn {
  position: relative;
  z-index: 2;
}

/* left color accent stripe */
.post-card-accent {
  position: absolute;
  top: 0; left: 0;
  width: 4px;
  height: 100%;
  background: linear-gradient(to bottom, var(--surbias-primary), var(--surbias-accent));
  border-radius: var(--radius-lg) 0 0 var(--radius-lg);
  opacity: 0.5;
  transition: opacity var(--dur-base) var(--ease-out);
}

.post-card:hover {
  box-shadow: var(--shadow-md);
  border-color: rgba(143,184,154,.40);
  transform: translateY(-2px);
}
.post-card:hover .post-card-accent { opacity: 1; }

.post-card h3 {
  margin: 0 0 0.55rem 0;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.35;
}
.post-card h3 a {
  text-decoration: none;
  color: var(--surbias-text);
  transition: color var(--dur-fast) var(--ease-out);
}
.post-card h3 a:hover { color: var(--surbias-primary); }

/* ============================================================
   POST META AND BADGE
   ============================================================ */
.post-meta {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.78rem;
  color: var(--surbias-text-muted);
  margin-bottom: 0.75rem;
  flex-wrap: wrap;
  line-height: 1;
}

.post-meta-sep {
  color: var(--surbias-border);
  font-size: 0.7rem;
}

.post-meta .category-badge {
  display: inline-flex;
  align-items: center;
  background: var(--surbias-warm-light);
  color: var(--surbias-primary);
  padding: 0.18rem 0.6rem;
  border-radius: var(--radius-pill);
  font-size: 0.74rem;
  font-weight: 600;
  border: 1px solid rgba(143,184,154,.28);
  text-transform: capitalize;
  letter-spacing: 0.01em;
}

.post-body-preview {
  color: var(--surbias-text-muted);
  line-height: 1.68;
  margin-bottom: 1.1rem;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  font-size: 0.9rem;
}

.post-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.read-more-link {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--surbias-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.2rem;
  transition: color var(--dur-fast) var(--ease-out);
}
.read-more-link:hover { color: var(--surbias-primary-hover); }

/* ============================================================
   REACTION BAR
   ============================================================ */
.reaction-bar {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  align-items: center;
}

.reaction-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.38rem 0.8rem;
  border-radius: var(--radius-pill);
  font-size: 0.82rem;
  font-weight: 500;
  background: var(--surbias-warm-light);
  border: 1.5px solid var(--surbias-border);
  cursor: pointer;
  color: var(--surbias-text-muted);
  line-height: 1;
  font-family: inherit;
  transition: background    var(--dur-base) var(--ease-out),
              border-color  var(--dur-fast) var(--ease-out),
              color         var(--dur-fast) var(--ease-out),
              transform     var(--dur-fast) var(--ease-out),
              box-shadow    var(--dur-base) var(--ease-out);
}

.reaction-label {
  font-size: 0.8rem;
  font-weight: 500;
}

.reaction-btn:hover {
  background: rgba(74,124,89,.10);
  border-color: rgba(74,124,89,.35);
  color: var(--surbias-primary);
  transform: scale(1.06) translateY(-1px);
  box-shadow: 0 2px 8px rgba(74,124,89,.20);
}
.reaction-btn:active { transform: scale(0.96); }

.reaction-btn.reacted {
  background: rgba(74,124,89,.12);
  border-color: var(--surbias-primary);
  color: var(--surbias-primary);
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(74,124,89,.20);
}

.reaction-count {
  font-weight: 700;
  font-size: 0.8em;
  min-width: 1ch;
  text-align: center;
}

/* ============================================================
   REPORT BUTTON
   ============================================================ */
.report-btn {
  background: none;
  border: none;
  color: var(--surbias-text-light);
  font-size: 0.76rem;
  font-weight: 500;
  cursor: pointer;
  padding: 0.3rem 0.55rem;
  border-radius: var(--radius-sm);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-family: inherit;
  transition: color      var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.report-btn:hover {
  color: var(--surbias-danger);
  background: var(--surbias-danger-light);
}

/* ============================================================
   POST DETAIL
   ============================================================ */
.post-detail-card {
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-xl);
  padding: 2.5rem;
  position: relative;
  overflow: hidden;
  box-shadow: var(--shadow-md);
}

.post-detail-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(to right, var(--surbias-primary), var(--surbias-accent), var(--surbias-warm));
}

.post-detail-title {
  font-size: clamp(1.4rem, 4vw, 1.9rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.22;
  margin-bottom: 1.25rem;
  color: var(--surbias-text);
}

.post-detail-body {
  font-size: 1rem;
  line-height: 1.88;
  color: var(--surbias-text);
  white-space: pre-wrap;
  margin-bottom: 2rem;
}

.post-detail-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
  padding-top: 1.5rem;
  border-top: 1px solid var(--surbias-border);
  margin-top: 1.5rem;
}

.back-nav {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--surbias-text-muted);
  text-decoration: none;
  padding: 0.45rem 0.75rem;
  border-radius: var(--radius-md);
  transition: color      var(--dur-fast) var(--ease-out),
              background var(--dur-fast) var(--ease-out);
}
.back-nav:hover {
  color: var(--surbias-primary);
  background: rgba(74,124,89,.10);
}

/* ============================================================
   SITE FOOTER
   ============================================================ */
.site-footer {
  text-align: center;
  padding: 2.25rem 1.25rem;
  color: var(--surbias-text-muted);
  font-size: 0.84rem;
  border-top: 1px solid var(--surbias-border);
  margin-top: auto;
  background: var(--surbias-header-bg);
}
.site-footer a { color: var(--surbias-primary); font-weight: 500; }
.site-footer a:hover { color: var(--surbias-primary-hover); }

/* ============================================================
   LANGUAGE SWITCHER
   ============================================================ */
.lang-switcher {
  position: relative;
  display: inline-flex;
  align-items: center;
}

.lang-switcher::after {
  content: '';
  position: absolute;
  right: 0.6rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 3px solid transparent;
  border-right: 3px solid transparent;
  border-top: 4px solid var(--surbias-text-muted);
  pointer-events: none;
}

.lang-switcher select {
  appearance: none;
  -webkit-appearance: none;
  background: transparent;
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-md);
  padding: 0.3rem 1.75rem 0.3rem 0.6rem;
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--surbias-text-muted);
  cursor: pointer;
  font-family: inherit;
  transition: border-color var(--dur-fast) var(--ease-out),
              color        var(--dur-fast) var(--ease-out);
}
.lang-switcher select:hover {
  border-color: var(--surbias-primary);
  color: var(--surbias-text);
}

/* ============================================================
   POST FORM
   ============================================================ */
.post-form {
  max-width: 640px;
  margin: 0 auto;
}

.post-form-header { margin-bottom: 2rem; }
.post-form-header h1 {
  font-size: clamp(1.6rem, 4vw, 2rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  margin-bottom: 0.4rem;
}
.post-form-header p {
  color: var(--surbias-text-muted);
  font-size: 1rem;
  line-height: 1.6;
}

.post-form label {
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--surbias-text);
  display: block;
  margin-bottom: 0.4rem;
}

.post-form input,
.post-form textarea,
.post-form select {
  width: auto;
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-md);
  padding: 0.625rem 0.875rem;
  font-size: 0.9375rem;
  color: var(--surbias-text);
  font-family: inherit;
  box-shadow: var(--shadow-sm);
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow   var(--dur-fast) var(--ease-out);
}
.post-form input:focus,
.post-form textarea:focus,
.post-form select:focus {
  outline: none;
  border-color: var(--surbias-primary);
  box-shadow: 0 0 0 3.5px rgba(74,124,89,.18);
}

.post-form textarea {
  min-height: 200px;
  resize: vertical;
  line-height: 1.7;
  width: 100% !important;
}

.form-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin-top: 1.25rem;
  flex-wrap: wrap;
}

.anonymous-toggle {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin: 0;
  cursor: pointer;
  font-size: 0.9rem;
  color: var(--surbias-text-muted);
  font-weight: 500;
}

/* ============================================================
   NOTICES AND ALERTS
   ============================================================ */
.notice {
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  padding: 0.9rem 1.1rem;
  border-radius: var(--radius-md);
  margin-bottom: 1.25rem;
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.55;
  border: 1.5px solid transparent;
}

.notice-info {
  background: var(--surbias-warm-light);
  color: #2d5a3a;
  border-color: rgba(74,124,89,.28);
}
.notice-info::before {
  content: 'i';
  font-weight: 900;
  font-style: italic;
  font-size: 0.9rem;
  color: var(--surbias-warm);
  flex-shrink: 0;
  width: 1.1em;
  text-align: center;
}

.notice-error {
  background: var(--surbias-danger-light);
  color: var(--surbias-danger);
  border-color: rgba(192,57,43,.22);
}
.notice-error::before {
  content: '!';
  font-weight: 900;
  font-size: 0.9rem;
  flex-shrink: 0;
  width: 1.1em;
  text-align: center;
}

/* dark mode notices removed */

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.45rem;
  margin-top: 2.75rem;
  flex-wrap: wrap;
}

.pagination a,
.pagination span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.3rem;
  height: 2.3rem;
  padding: 0 0.8rem;
  border-radius: var(--radius-md);
  text-decoration: none;
  font-size: 0.875rem;
  font-weight: 600;
  transition: all var(--dur-fast) var(--ease-out);
}

.pagination a {
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  color: var(--surbias-text-muted);
  box-shadow: var(--shadow-sm);
}
.pagination a:hover {
  background: rgba(74,124,89,.10);
  border-color: rgba(74,124,89,.30);
  color: var(--surbias-primary);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

/* current page - filled sage green pill - soft green */
.pagination span {
  background: var(--surbias-primary);
  color: #fff;
  border: 1.5px solid var(--surbias-primary);
  box-shadow: 0 2px 8px rgba(74,124,89,.35);
  pointer-events: none;
}

/* ============================================================
   FLAGGED NOTICE
   ============================================================ */
.flagged-notice {
  background: var(--surbias-warm-tint);
  border: 1.5px solid rgba(74,124,89,.40);
  border-radius: var(--radius-md);
  padding: 1.1rem 1.35rem;
  text-align: center;
  color: #2d5a3a;
  font-weight: 500;
  font-size: 0.9rem;
}
/* dark mode flagged removed */

/* ============================================================
   AUTH PAGE
   ============================================================ */
.auth-page {
  max-width: 430px;
  margin: 2.5rem auto;
}

.auth-header {
  text-align: center;
  margin-bottom: 2rem;
}
.auth-header .auth-emoji {
  font-size: 3rem;
  display: block;
  margin-bottom: 0.75rem;
}
.auth-header h1 {
  font-size: clamp(1.5rem, 4vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.028em;
  margin-bottom: 0.5rem;
}
.auth-header p {
  color: var(--surbias-text-muted);
  font-size: 0.95rem;
  line-height: 1.55;
}

.auth-card {
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-xl);
  padding: 2rem;
  box-shadow: var(--shadow-lg);
}

/* Auth form inputs — stack labels and inputs vertically */
.auth-card form label {
  display: block;
  margin-bottom: 1rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--surbias-text);
}

.auth-card form label input {
  display: block;
  width: 100%;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  font-size: 0.95rem;
  font-family: inherit;
  background: var(--surbias-bg);
  color: var(--surbias-text);
  margin-top: 0.35rem;
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow   var(--dur-fast) var(--ease-out);
}

.auth-card form label input:focus {
  outline: none;
  border-color: var(--surbias-primary);
  box-shadow: 0 0 0 2px rgba(74,124,89,.15);
}

.auth-divider {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin: 1.5rem 0;
  color: var(--surbias-text-light);
  font-size: 0.8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.auth-divider::before,
.auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--surbias-border);
}

.btn-google {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
  width: 100%;
  padding: 0.8rem 1rem;
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-md);
  background: var(--surbias-card-bg);
  color: var(--surbias-text);
  font-size: 0.9375rem;
  font-weight: 600;
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  text-decoration: none;
  font-family: inherit;
  transition: background    var(--dur-base) var(--ease-out),
              border-color  var(--dur-fast) var(--ease-out),
              box-shadow    var(--dur-base) var(--ease-out),
              transform     var(--dur-fast) var(--ease-out);
}
.btn-google:hover {
  background: var(--surbias-warm-light);
  border-color: rgba(143,184,154,.40);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
  color: var(--surbias-text);
}

.auth-toggle-row {
  text-align: center;
  margin-top: 1.25rem;
}
.auth-toggle-row a {
  font-size: 0.9rem;
  color: var(--surbias-primary);
  font-weight: 600;
}

/* ============================================================
   ADMIN PANEL
   ============================================================ */
.admin-card {
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin-bottom: 1rem;
  box-shadow: var(--shadow-sm);
}

.admin-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
  flex-wrap: wrap;
}

/* ============================================================
   HONEYPOT - invisible to real users
   ============================================================ */
.ohnohoney {
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  height: 0;
  width: 0;
  z-index: -1;
  pointer-events: none;
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-content {
  max-width: 640px;
  margin: 0 auto;
  line-height: 1.8;
}

.about-header { margin-bottom: 2.5rem; }
.about-header h1 {
  font-size: clamp(1.75rem, 5vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 0;
}

.about-body {
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}
.about-body p {
  font-size: 1.04rem;
  color: var(--surbias-text);
  line-height: 1.82;
}
.about-body .about-highlight {
  background: var(--surbias-warm-light);
  border-left: 4px solid var(--surbias-primary);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
  padding: 1rem 1.25rem;
  font-weight: 600;
  color: var(--surbias-text);
}

/* ============================================================
   UTILITY
   ============================================================ */
.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;
}

/* ============================================================
   RESPONSIVE - MOBILE
   ============================================================ */
@media (max-width: 640px) {
  main { padding: 1.5rem 0.875rem; }

  .hero {
    padding: 2.75rem 1rem 2.25rem;
    border-radius: var(--radius-lg);
  }
  .hero-emoji { font-size: 2.75rem; }

  .site-header nav {
    padding: 0 0.875rem;
    flex-wrap: wrap;
    gap: 0.5rem;
  }
  .nav-links { gap: 0.1rem; }
  .nav-links a {
    font-size: 0.8125rem;
    padding: 0.3rem 0.5rem;
  }

  .post-card { padding: 1.1rem 1rem 1.1rem 1.35rem; }
  .post-detail-card { padding: 1.5rem 1.25rem; }

  .form-footer {
    flex-direction: column;
    align-items: stretch;
  }
  .form-footer .btn-cta {
    width: 100%;
    justify-content: center;
  }

  .auth-card { padding: 1.5rem 1.125rem; }
  .auth-page { margin: 1.25rem auto; }
  .admin-actions { flex-direction: column; }

  .pagination a,
  .pagination span {
    min-width: 2rem;
    height: 2rem;
    font-size: 0.8rem;
    padding: 0 0.55rem;
  }
}

@media (max-width: 380px) {
  .site-logo { font-size: 1.15rem; }
  .btn-cta   { font-size: 0.875rem; padding: 0.55rem 1.25rem; }
}

/* ============================================================
   HOMEPAGE LAYOUT — two-column with sidebar
   ============================================================ */
.home-content { display: flex; gap: 1.5rem; align-items: flex-start; }
.sidebar { width: 220px; flex-shrink: 0; position: sticky; top: calc(60px + 1rem); max-height: calc(100vh - 80px); overflow-y: auto; }
.sidebar-right { width: 220px; flex-shrink: 0; position: sticky; top: calc(60px + 1rem); max-height: calc(100vh - 80px); overflow-y: auto; }
.feed { flex: 1; min-width: 0; }

.sidebar-card {
  background: var(--surbias-card-bg);
  border: 1.5px solid var(--surbias-border);
  border-radius: var(--radius-lg);
  padding: 1rem 0.75rem;
  box-shadow: var(--shadow-sm);
}

.sidebar-title {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  color: var(--surbias-text-muted);
  margin: 0 0.5rem 0.75rem;
}

/* ============================================================
   SORT TABS
   ============================================================ */
.sort-tabs {
  display: flex;
  gap: 0.4rem;
  margin-bottom: 1.25rem;
  flex-wrap: wrap;
}

.sort-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.42rem 1.1rem;
  border-radius: var(--radius-pill);
  font-size: 0.84rem;
  font-weight: 600;
  background: var(--surbias-card-bg);
  color: var(--surbias-text-muted);
  border: 1.5px solid var(--surbias-border);
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
  transition: background    var(--dur-base) var(--ease-out),
              color         var(--dur-fast) var(--ease-out),
              border-color  var(--dur-base) var(--ease-out),
              box-shadow    var(--dur-base) var(--ease-out),
              transform     var(--dur-fast) var(--ease-out);
}

.sort-tab:hover {
  background: rgba(74,124,89,.10);
  color: var(--surbias-primary);
  border-color: rgba(74,124,89,.30);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}

.sort-tab.active {
  background: var(--surbias-primary);
  color: #fff;
  border-color: var(--surbias-primary);
  box-shadow: 0 2px 10px rgba(74,124,89,.35);
  transform: translateY(-1px);
}

/* ============================================================
   SIDEBAR CATEGORY LIST
   ============================================================ */
.sidebar-categories {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.sidebar-cat-item {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.48rem 0.6rem;
  border-radius: var(--radius-md);
  font-size: 0.855rem;
  font-weight: 500;
  color: var(--surbias-text-muted);
  text-decoration: none;
  cursor: pointer;
  transition: background    var(--dur-base) var(--ease-out),
              color         var(--dur-fast) var(--ease-out);
  border: 1.5px solid transparent;
}

.sidebar-cat-item:hover {
  background: rgba(74,124,89,.09);
  color: var(--surbias-primary);
}

.sidebar-cat-item.active {
  background: rgba(74,124,89,.13);
  color: var(--surbias-primary);
  font-weight: 700;
  border-color: rgba(74,124,89,.22);
}

.sidebar-cat-icon {
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  color: inherit;
  opacity: 0.75;
}

.sidebar-cat-label {
  flex: 1;
  line-height: 1.2;
}

.sidebar-cat-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.6rem;
  height: 1.25rem;
  padding: 0 0.4rem;
  border-radius: var(--radius-pill);
  font-size: 0.7rem;
  font-weight: 700;
  background: var(--surbias-warm-light);
  color: var(--surbias-text-muted);
  flex-shrink: 0;
  transition: background var(--dur-fast) var(--ease-out),
              color      var(--dur-fast) var(--ease-out);
}

.sidebar-cat-item.active .sidebar-cat-count {
  background: rgba(74,124,89,.20);
  color: var(--surbias-primary);
}

/* ============================================================
   HOMEPAGE RESPONSIVE — mobile sidebar collapses
   ============================================================ */
@media (max-width: 768px) {
  .home-content {
    flex-direction: column;
    gap: 0;
  }

  .sidebar-card {
    padding: 0.75rem 0.75rem;
  }

  .sidebar-categories {
    flex-direction: row;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: 0.4rem;
    padding-bottom: 0.25rem;
    /* hide scrollbar on mobile but keep scrollable */
    scrollbar-width: none;
  }
  .sidebar-categories::-webkit-scrollbar { display: none; }

  .sidebar-cat-item {
    flex-shrink: 0;
    white-space: nowrap;
    border: 1.5px solid var(--surbias-border);
    background: var(--surbias-card-bg);
  }

  .sidebar-cat-item.active {
    background: var(--surbias-primary);
    color: #fff;
    border-color: var(--surbias-primary);
  }

  .sidebar-cat-item.active .sidebar-cat-count {
    background: rgba(255,255,255,.25);
    color: #fff;
  }

  .sidebar-title { display: none; }
}

/* ============================================================
   Anonymous toggle checkbox
   ============================================================ */
.anonymous-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  cursor: pointer;
  font-size: 0.85rem;
  color: var(--surbias-text-muted);
  margin: 0;
}

.toggle-checkbox {
  width: 16px;
  height: 16px;
  accent-color: var(--surbias-primary);
  cursor: pointer;
  margin: 0;
}

.toggle-label {
  user-select: none;
}

/* ============================================================
   LEGAL PAGES (Terms, Privacy)
   ============================================================ */
.legal-page {
  max-width: 740px;
  margin: 0 auto;
  padding: 2rem 1rem;
  line-height: 1.8;
}
.legal-page h1 {
  margin-bottom: 0.5rem;
}
.legal-page h2 {
  margin-top: 2rem;
  margin-bottom: 0.75rem;
  font-size: 1.25rem;
}
.legal-page p, .legal-page li {
  color: var(--surbias-text-muted);
  margin-bottom: 0.75rem;
}
.legal-page ul {
  padding-left: 1.5rem;
}
.legal-page a {
  color: var(--surbias-primary);
}

/* ============================================================
   COMMENTS
   ============================================================ */
.comments-section { margin-top: 2rem; border-top: 1px solid var(--surbias-border); padding-top: 1.5rem; }
.comments-title { font-size: 1.1rem; margin-bottom: 1rem; }
.comment-form-wrapper { margin-bottom: 1.5rem; }
.comment-input { width: 100%; padding: 0.6rem 0.85rem; border: 1px solid var(--surbias-border); border-radius: var(--radius-md); font-size: 0.9rem; resize: vertical; min-height: 50px; background: var(--surbias-bg); font-family: inherit; }
.comment-input:focus { outline: none; border-color: var(--surbias-primary); box-shadow: 0 0 0 2px rgba(74,124,89,.15); }
.comment-form-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 0.5rem; }
.comment-card { padding: 0.75rem 0; border-bottom: 1px solid var(--surbias-border); }
.comment-card:last-child { border-bottom: none; }
.comment-meta { font-size: 0.8rem; color: var(--surbias-text-muted); margin-bottom: 0.35rem; display: flex; gap: 0.5rem; align-items: center; }
.comment-body { font-size: 0.9rem; line-height: 1.6; margin: 0; }

/* ============================================================
   RIGHT SIDEBAR
   ============================================================ */
.sidebar-about { font-size: 0.85rem; color: var(--surbias-text-muted); line-height: 1.6; margin: 0; }
.sidebar-stats { display: flex; flex-direction: column; gap: 0.5rem; }
.stat-item { display: flex; align-items: baseline; gap: 0.4rem; }
.stat-number { font-size: 1.5rem; font-weight: 700; color: var(--surbias-primary); }
.stat-label { font-size: 0.85rem; color: var(--surbias-text-muted); }

@media (max-width: 1024px) {
  .sidebar-right { display: none; }
}
@media (max-width: 768px) {
  .sidebar { display: none; }
}

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s;
}
.modal-overlay.is-open {
  opacity: 1;
  pointer-events: auto;
}
.modal-box {
  background: var(--surbias-card-bg);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  max-width: 420px;
  width: 90%;
  box-shadow: var(--shadow-lg);
}
.modal-title {
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: 1rem;
}
.modal-body { margin-bottom: 1rem; }
.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}
.modal-btn {
  padding: 0.5rem 1rem;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--surbias-border);
  background: var(--surbias-card-bg);
  color: var(--surbias-text);
  font-family: inherit;
}
.modal-btn:hover { background: var(--surbias-warm-light); }
.modal-btn-primary {
  background: var(--surbias-primary);
  color: white;
  border-color: var(--surbias-primary);
}
.modal-btn-primary:hover { background: var(--surbias-primary-hover); }
.modal-btn-danger {
  background: var(--surbias-danger);
  color: white;
  border-color: var(--surbias-danger);
}
.modal-select {
  width: 100%;
  padding: 0.5rem;
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  font-family: inherit;
  font-size: 0.9rem;
  margin-top: 0.5rem;
}

/* ============================================================
   TOAST
   ============================================================ */
.toast-container {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 2000;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.toast {
  padding: 0.75rem 1.25rem;
  border-radius: var(--radius-md);
  font-size: 0.85rem;
  font-weight: 500;
  box-shadow: var(--shadow-md);
  animation: toast-in 0.3s ease-out;
  max-width: 350px;
}
.toast-success { background: var(--surbias-success); color: white; }
.toast-error { background: var(--surbias-danger); color: white; }
.toast-info { background: var(--surbias-primary); color: white; }
@keyframes toast-in {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
.skip-link {
  position: absolute;
  top: -100px;
  left: 0;
  background: var(--surbias-primary);
  color: white;
  padding: 0.5rem 1rem;
  z-index: 9999;
  font-size: 0.9rem;
  transition: top 0.2s;
}
.skip-link:focus {
  top: 0;
}

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

:focus-visible {
  outline: 2px solid var(--surbias-primary);
  outline-offset: 2px;
}

/* ============================================================
   LOADING SPINNER
   ============================================================ */
.loading-spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid var(--surbias-border);
  border-top-color: var(--surbias-primary);
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================
   SHARE BUTTONS
   ============================================================ */
.share-btn {
  padding: 0.4rem 0.8rem;
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  font-size: 0.8rem;
  text-decoration: none;
  color: var(--surbias-text-muted);
  transition: background 0.15s;
}
.share-btn:hover { background: var(--surbias-warm-light); color: var(--surbias-text); }

/* ============================================================
   TAG PILLS
   ============================================================ */
.tag-pill {
  padding: 0.2rem 0.6rem;
  background: var(--surbias-warm-light);
  color: var(--surbias-primary);
  border-radius: var(--radius-pill);
  font-size: 0.8rem;
  text-decoration: none;
  font-weight: 500;
}
.tag-pill:hover { background: var(--surbias-warm-tint); }

/* ============================================================
   BADGE CARDS
   ============================================================ */
.badge-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  padding: 0.75rem 1rem;
  background: var(--surbias-warm-light);
  border: 1px solid var(--surbias-border);
  border-radius: var(--radius-md);
  cursor: default;
}

/* ============================================================
   DARK MODE (user-toggled via data-theme="dark" on <html>)
   ============================================================ */
[data-theme="dark"] {
  --surbias-bg: #1a1a2e;
  --surbias-card-bg: #222240;
  --surbias-header-bg: #1a1a2e;
  --surbias-text: #e8e8f0;
  --surbias-text-muted: #9898b0;
  --surbias-text-light: #686888;
  --surbias-border: #333355;
  --surbias-warm-light: #252540;
  --surbias-warm-tint: #2a2a48;
  --surbias-success-light: #1a2e1a;
  --surbias-danger-light: #2e1a1a;
}
