/* Community page specific styles — lean and complementary to base.css */
:root {
  --c-bg-elev: rgba(12, 22, 18, 0.6);
  --c-accent: #3aa37e;
  --c-accent-2: #2f7e63;
  --c-text: #e6efe9;
  --c-muted: #b6c4bd;
  --c-border: rgba(255, 255, 255, 0.08);
}

.community-hero {
  background: radial-gradient(1200px 600px at 10% 10%, rgba(58,163,126,0.10), transparent), linear-gradient(180deg, rgba(6,10,9,0.9), rgba(6,10,9,0.7));
  padding: clamp(2rem, 3vw, 3rem) 0;
  border-bottom: 1px solid var(--c-border);
}
.community-hero__inner { 
  display: grid; 
  grid-template-columns: 1.2fr 1fr; 
  gap: clamp(1rem, 3vw, 2.5rem); 
  align-items: center; 
  width: min(1200px, 92vw); 
  margin: 0 auto; 
}
.community-hero__copy .eyebrow { color: var(--c-accent); letter-spacing: .06em; text-transform: uppercase; font-size: .85rem; margin: 0 0 .5rem; }
.community-hero__copy .lead { color: var(--c-muted); max-width: 60ch; }
.community-hero__media img { width: 100%; height: auto; border-radius: 12px; box-shadow: 0 8px 32px rgba(0,0,0,.45); }

.community-quicknav ul { display: flex; flex-wrap: wrap; gap: .5rem; padding: 0; margin-top: 1rem; list-style: none; }
.community-quicknav a { display: inline-block; padding: .5rem .8rem; border: 1px solid var(--c-border); border-radius: 999px; color: var(--c-text); text-decoration: none; backdrop-filter: blur(4px); }
.community-quicknav a:hover, .community-quicknav a:focus { outline: none; border-color: var(--c-accent); color: var(--c-accent); }

.community-section { padding: clamp(2rem, 5vw, 3.5rem) 0; border-bottom: 1px solid var(--c-border); }
.community-container { width: min(1100px, 92vw); margin: 0 auto; }
.section-header { margin-bottom: 1rem; }

.community-list { margin-top: 1rem; display: grid; gap: 1rem; }
.community-grid { display: grid; gap: 1rem; margin-top: 1rem; }
.community-grid.two { grid-template-columns: repeat(2, 1fr); }
.community-grid.three { grid-template-columns: repeat(3, 1fr); }
.community-grid.align-start { align-items: start; }

.community-card { background: var(--c-bg-elev); border: 1px solid var(--c-border); border-radius: 12px; padding: 1rem; box-shadow: 0 6px 24px rgba(0,0,0,.25); }
.community-card h3 { margin-top: 0; }
.community-card.topic h3 a { color: var(--c-text); text-decoration: none; }
.community-card.topic h3 a:hover { color: var(--c-accent); }
.community-card .meta { color: var(--c-muted); font-size: .9rem; }

.events-wrap { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; align-items: start; }
.events-media img { width: 100%; height: auto; border-radius: 12px; }
.events-list { display: grid; gap: 1rem; padding: 0; list-style: none; }

.guidelines-list { display: grid; gap: .5rem; padding-left: 1rem; }
.guidelines-list li { padding-left: .25rem; }

.calendar-controls { display: flex; flex-wrap: wrap; gap: .5rem; margin: .5rem 0 1rem; }
.calendar-list { display: grid; gap: .75rem; padding: 0; list-style: none; }
.calendar-item { background: var(--c-bg-elev); border: 1px solid var(--c-border); border-radius: 10px; padding: .8rem 1rem; }

/* Forms */
.community-inline-form .input-row { display: grid; grid-template-columns: 1fr auto; gap: .5rem; }
.community-form { display: grid; gap: .75rem; margin-top: 1rem; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.form-field { display: grid; gap: .35rem; }
.form-field input, .form-field select, .form-field textarea { 
  width: 100%; padding: .7rem .8rem; border-radius: 10px; color: var(--c-text); 
  background: rgba(20, 30, 26, 0.6); border: 1px solid var(--c-border); 
}
.form-field input:focus, .form-field select:focus, .form-field textarea:focus { outline: 2px solid var(--c-accent); outline-offset: 2px; border-color: var(--c-accent-2); }
.form-consent { align-items: start; grid-template-columns: auto 1fr; }
.helper { color: var(--c-muted); font-size: .85rem; margin: 0; }
.form-status { margin: 0; font-size: .95rem; }

/* Buttons */
.c-btn { appearance: none; border: 1px solid transparent; background: var(--c-accent); color: #07140f; padding: .6rem 1rem; border-radius: 999px; font-weight: 600; cursor: pointer; text-decoration: none; text-align: center; }
.c-btn:hover, .c-btn:focus { background: #45b58d; outline: none; }
.c-btn--ghost { background: transparent; color: var(--c-text); border-color: var(--c-border); }
.c-btn--ghost:hover, .c-btn--ghost:focus { border-color: var(--c-accent); color: var(--c-accent); }

/* Responsive */
@media (max-width: 980px) {
  .community-hero__inner { grid-template-columns: 1fr; }
  .events-wrap { grid-template-columns: 1fr; }
  .community-grid.two { grid-template-columns: 1fr; }
  .community-grid.three { grid-template-columns: 1fr; }
  .community-inline-form .input-row { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
}
