/* ============================================================
   Richmond Round PWA -- App Styles
   Palette: Richmond Green #1a3a2a | Warm Off-white #f7f5ee
            Charcoal #2d2c28 | Warm Gold #b08d3a | Cream #e8e4d4
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --green:       #1a3a2a;
  --green-mid:   #2a5040;
  --green-light: #e8f0eb;
  --gold:        #b08d3a;
  --gold-light:  #f0e6c8;
  --cream:       #f7f5ee;
  --cream-dark:  #e8e4d4;
  --charcoal:    #2d2c28;
  --mid:         #6b6960;
  --light:       #a8a59c;
  --white:       #ffffff;
  --danger:      #c0392b;
  --success:     #1a6b3a;

  --font-serif:  'Libre Baskerville', Georgia, serif;
  --font-sans:   'Source Sans 3', 'Segoe UI', sans-serif;

  --radius:      6px;
  --radius-lg:   12px;
  --shadow-sm:   0 1px 3px rgba(0,0,0,.08);
  --shadow:      0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:   0 8px 32px rgba(0,0,0,.14);

  --header-h:    56px;
  --bottom-nav:  64px;
}

html { font-size: 16px; -webkit-text-size-adjust: 100%; }

body {
  font-family: var(--font-sans);
  background: var(--cream);
  color: var(--charcoal);
  line-height: 1.5;
  min-height: 100vh;
  overflow-x: hidden;
}

/* ============================================================
   APP SHELL
   ============================================================ */

#rr-app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  min-height: 100dvh;
}

/* ============================================================
   HEADER
   ============================================================ */

.rr-app-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--green);
  height: var(--header-h);
  display: flex;
  align-items: center;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
}

.rr-header-inner {
  width: 100%;
  max-width: 680px;
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.rr-wordmark {
  font-family: var(--font-serif);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--cream);
  text-decoration: none;
  letter-spacing: .01em;
  flex-shrink: 0;
}

.rr-app-nav {
  display: flex;
  gap: 4px;
}

.rr-nav-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  background: none;
  border: none;
  color: rgba(247,245,238,.6);
  font-family: var(--font-sans);
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  padding: 6px 10px;
  border-radius: var(--radius);
  transition: color .15s, background .15s;
}

.rr-nav-btn svg {
  width: 20px; height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.rr-nav-btn:hover,
.rr-nav-btn.rr-nav-active {
  color: var(--cream);
  background: rgba(255,255,255,.1);
}

.rr-sign-out-btn {
  background: none;
  border: 1px solid rgba(247,245,238,.35);
  color: rgba(247,245,238,.75);
  font-family: var(--font-sans);
  font-size: .75rem;
  padding: 5px 12px;
  border-radius: 20px;
  cursor: pointer;
  transition: all .15s;
}

.rr-sign-out-btn:hover {
  background: rgba(255,255,255,.1);
  color: var(--cream);
}

/* ============================================================
   MAIN CONTENT AREA
   ============================================================ */

.rr-app-main {
  flex: 1;
  padding-top: var(--header-h);
  padding-bottom: var(--bottom-nav);
}

.rr-view {
  min-height: calc(100vh - var(--header-h) - var(--bottom-nav));
}

.rr-view-inner {
  max-width: 680px;
  margin: 0 auto;
  padding: 24px 16px 32px;
}

.rr-hidden { display: none !important; }

/* ============================================================
   AUTH SCREEN
   ============================================================ */

.rr-view-auth {
  background: var(--green);
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 0;
}

.rr-auth-container {
  width: 100%;
  max-width: 420px;
  padding: 32px 20px 40px;
}

.rr-auth-brand {
  text-align: center;
  margin-bottom: 32px;
}

.rr-auth-wordmark {
  font-family: var(--font-serif);
  font-size: 2rem;
  font-weight: 700;
  color: var(--cream);
  letter-spacing: .02em;
  line-height: 1.1;
}

.rr-auth-tagline {
  color: rgba(247,245,238,.6);
  font-size: .85rem;
  margin-top: 6px;
  letter-spacing: .02em;
}

/* Tabs */

.rr-auth-tabs {
  display: flex;
  background: rgba(0,0,0,.2);
  border-radius: var(--radius);
  padding: 3px;
  margin-bottom: 24px;
}

.rr-tab {
  flex: 1;
  background: none;
  border: none;
  color: rgba(247,245,238,.55);
  font-family: var(--font-sans);
  font-size: .85rem;
  font-weight: 600;
  padding: 9px 12px;
  border-radius: 4px;
  cursor: pointer;
  transition: all .2s;
}

.rr-tab-active {
  background: var(--cream);
  color: var(--green);
}

/* Auth panels */

.rr-auth-panel {
  animation: fadeIn .2s ease;
}

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

.rr-form-group {
  margin-bottom: 14px;
}

.rr-form-group label {
  display: block;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: rgba(247,245,238,.6);
  margin-bottom: 5px;
}

/* Override label colour inside cards (light bg) */
.rr-card .rr-form-group label,
.rr-card label {
  color: var(--mid);
}

.rr-auth-panel input[type="email"],
.rr-auth-panel input[type="password"],
.rr-auth-panel input[type="text"] {
  width: 100%;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(247,245,238,.2);
  border-radius: var(--radius);
  padding: 12px 14px;
  color: var(--cream);
  font-family: var(--font-sans);
  font-size: 1rem;
  outline: none;
  transition: border-color .15s;
}

.rr-auth-panel input::placeholder { color: rgba(247,245,238,.3); }

.rr-auth-panel input:focus {
  border-color: var(--gold);
  background: rgba(255,255,255,.12);
}

.rr-insider-pitch {
  background: rgba(176,141,58,.12);
  border-left: 3px solid var(--gold);
  border-radius: 0 var(--radius) var(--radius) 0;
  padding: 12px 14px;
  margin-bottom: 18px;
}

.rr-pitch-lead {
  font-family: var(--font-serif);
  font-size: 1rem;
  font-style: italic;
  color: var(--gold-light);
  margin-bottom: 4px;
}

.rr-insider-pitch p {
  color: rgba(247,245,238,.7);
  font-size: .85rem;
  line-height: 1.5;
}

.rr-auth-link, .rr-auth-note {
  font-size: .8rem;
  color: rgba(247,245,238,.5);
  margin-top: 10px;
  text-align: center;
}

.rr-auth-link a, .rr-auth-note a {
  color: var(--gold-light);
  text-decoration: underline;
}

/* ============================================================
   BUTTONS
   ============================================================ */

.rr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  border: none;
  border-radius: var(--radius);
  font-family: var(--font-sans);
  font-weight: 600;
  cursor: pointer;
  transition: all .15s;
  text-decoration: none;
  padding: 13px 20px;
  font-size: .95rem;
  letter-spacing: .01em;
}

.rr-btn-primary {
  background: var(--gold);
  color: var(--charcoal);
}

.rr-btn-primary:hover { background: #c79e42; box-shadow: var(--shadow-sm); }
.rr-btn-primary:active { transform: scale(.98); }

.rr-btn-ghost {
  background: none;
  border: 1px solid var(--cream-dark);
  color: var(--mid);
}

.rr-btn-ghost:hover { border-color: var(--charcoal); color: var(--charcoal); }

.rr-btn-full { width: 100%; margin-top: 6px; }
.rr-btn-sm { padding: 8px 14px; font-size: .82rem; }

/* ============================================================
   MESSAGES
   ============================================================ */

.rr-message {
  font-size: .85rem;
  margin-top: 10px;
  padding: 0;
  min-height: 0;
  transition: all .2s;
}

.rr-message.rr-success {
  color: var(--success);
  background: #d4edda;
  border-radius: var(--radius);
  padding: 10px 12px;
}

.rr-message.rr-error {
  color: var(--danger);
  background: #fde8e8;
  border-radius: var(--radius);
  padding: 10px 12px;
}

/* On dark bg (auth screens) */
.rr-auth-panel .rr-message.rr-success {
  background: rgba(26,107,58,.25);
  color: #a8e6bc;
}

.rr-auth-panel .rr-message.rr-error {
  background: rgba(192,57,43,.25);
  color: #f5b7b1;
}

/* ============================================================
   LOADING DOTS
   ============================================================ */

.rr-loading {
  display: flex;
  gap: 6px;
  justify-content: center;
  padding: 32px 0;
}

.rr-loading span {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--light);
  animation: dots 1.2s infinite ease-in-out;
}

.rr-loading span:nth-child(2) { animation-delay: .2s; }
.rr-loading span:nth-child(3) { animation-delay: .4s; }

@keyframes dots {
  0%, 80%, 100% { transform: scale(.6); opacity: .4; }
  40%            { transform: scale(1);  opacity: 1; }
}

/* ============================================================
   FEED VIEW
   ============================================================ */

.rr-feed-header {
  padding: 20px 0 16px;
  border-bottom: 1px solid var(--cream-dark);
  margin-bottom: 20px;
}

.rr-feed-title {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  color: var(--green);
  margin-bottom: 2px;
}

.rr-feed-sub {
  color: var(--mid);
  font-size: .85rem;
}

.rr-article-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.rr-article-card {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  gap: 0;
  transition: box-shadow .15s;
  text-decoration: none;
  color: inherit;
}

.rr-article-card:hover { box-shadow: var(--shadow); }

.rr-article-card + .rr-article-card { margin-top: 8px; }

.rr-article-thumb {
  width: 90px;
  flex-shrink: 0;
  background: var(--cream-dark);
  overflow: hidden;
}

.rr-article-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.rr-article-body {
  padding: 12px 14px;
  flex: 1;
  min-width: 0;
}

.rr-article-cat {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 4px;
}

.rr-article-title {
  font-family: var(--font-serif);
  font-size: .95rem;
  line-height: 1.35;
  color: var(--green);
  margin-bottom: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.rr-article-excerpt {
  font-size: .78rem;
  color: var(--mid);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.rr-article-date {
  font-size: .7rem;
  color: var(--light);
  margin-top: 5px;
}

.rr-feed-footer {
  text-align: center;
  padding: 20px 0;
}

/* ============================================================
   ACCOUNT CARDS
   ============================================================ */

.rr-section-title {
  font-family: var(--font-serif);
  font-size: 1.4rem;
  color: var(--green);
  margin-bottom: 20px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--cream-dark);
}

.rr-card {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 20px;
  box-shadow: var(--shadow-sm);
  margin-bottom: 14px;
}

.rr-card-title {
  font-family: var(--font-serif);
  font-size: 1rem;
  color: var(--green);
  margin-bottom: 4px;
}

.rr-card-desc {
  font-size: .82rem;
  color: var(--mid);
  margin-bottom: 14px;
  line-height: 1.4;
}

.rr-card .rr-form-group input,
.rr-card .rr-form-group select {
  width: 100%;
  border: 1px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 10px 12px;
  font-family: var(--font-sans);
  font-size: .95rem;
  color: var(--charcoal);
  background: var(--cream);
  outline: none;
  transition: border-color .15s;
  margin-top: 4px;
}

.rr-card .rr-form-group input:focus,
.rr-card .rr-form-group select:focus {
  border-color: var(--green);
  background: var(--white);
}

.rr-pref-email-line {
  font-size: .8rem;
  color: var(--mid);
  margin-top: 10px;
}

/* Radio group */

.rr-radio-group {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rr-radio {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: .9rem;
  color: var(--charcoal);
  cursor: pointer;
}

.rr-radio input { accent-color: var(--green); width: 16px; height: 16px; cursor: pointer; }

/* Toggles */

.rr-toggle {
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  margin-bottom: 10px;
}

.rr-toggle:last-child { margin-bottom: 0; }

.rr-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }

.rr-toggle-track {
  position: relative;
  width: 42px;
  height: 24px;
  background: var(--cream-dark);
  border-radius: 12px;
  flex-shrink: 0;
  transition: background .2s;
}

.rr-toggle-track::after {
  content: '';
  position: absolute;
  width: 18px; height: 18px;
  background: var(--white);
  border-radius: 50%;
  top: 3px; left: 3px;
  transition: transform .2s;
  box-shadow: 0 1px 3px rgba(0,0,0,.2);
}

.rr-toggle input:checked ~ .rr-toggle-track { background: var(--green); }
.rr-toggle input:checked ~ .rr-toggle-track::after { transform: translateX(18px); }

.rr-toggle-label { font-size: .9rem; color: var(--charcoal); }

/* Topic list (drag to reorder) */

.rr-topic-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.rr-topic-item {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--cream);
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 10px 12px;
  transition: background .15s, box-shadow .15s;
  cursor: default;
}

.rr-topic-item.rr-dragging {
  background: var(--white);
  box-shadow: var(--shadow);
  opacity: .85;
  cursor: grabbing;
}

.rr-topic-item.rr-drag-over {
  border-color: var(--green);
  background: var(--green-light);
}

.rr-drag-handle {
  font-size: 1.1rem;
  color: var(--light);
  cursor: grab;
  padding: 0 2px;
  flex-shrink: 0;
  user-select: none;
  touch-action: none;
}

.rr-topic-name {
  flex: 1;
  font-size: .88rem;
  font-weight: 600;
  color: var(--charcoal);
}

.rr-topic-pill {
  flex-shrink: 0;
  border: 1.5px solid var(--cream-dark);
  border-radius: 20px;
  padding: 4px 12px;
  font-family: var(--font-sans);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  background: var(--white);
  color: var(--light);
  transition: all .15s;
}

.rr-topic-pill.rr-topic-on {
  background: var(--green);
  border-color: var(--green);
  color: var(--white);
}

.rr-topic-pill:hover {
  border-color: var(--green);
  color: var(--green);
}

.rr-topic-pill.rr-topic-on:hover {
  background: var(--green-mid);
  border-color: var(--green-mid);
  color: var(--white);
}

/* ============================================================
   DIRECTORY STRIP
   ============================================================ */

.rr-directory-strip {
  background: var(--green);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  margin-bottom: 20px;
}

.rr-directory-strip-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.rr-directory-eyebrow {
  display: block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(247,245,238,.5);
  margin-bottom: 2px;
}

.rr-directory-title {
  font-family: var(--font-serif);
  font-size: 1rem;
  color: var(--cream);
  font-weight: 700;
}

.rr-btn-directory {
  background: var(--gold);
  color: var(--charcoal);
  border-radius: var(--radius);
  padding: 8px 14px;
  font-size: .8rem;
  font-weight: 700;
  white-space: nowrap;
  text-decoration: none;
  flex-shrink: 0;
  font-family: var(--font-sans);
}

.rr-btn-directory:hover { background: #c79e42; }

.rr-directory-search-row {
  margin-bottom: 12px;
}

.rr-dir-search-input {
  width: 100%;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(247,245,238,.25);
  border-radius: var(--radius);
  padding: 10px 14px;
  font-family: var(--font-sans);
  font-size: .9rem;
  color: var(--cream);
  outline: none;
  transition: border-color .15s;
}

.rr-dir-search-input::placeholder { color: rgba(247,245,238,.4); }
.rr-dir-search-input:focus { border-color: var(--gold); }

.rr-directory-results {
  background: var(--white);
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 12px;
}

.rr-dir-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  text-decoration: none;
  color: inherit;
  border-bottom: 1px solid var(--cream-dark);
  transition: background .1s;
}

.rr-dir-card:last-of-type { border-bottom: none; }
.rr-dir-card:hover { background: var(--cream); }

.rr-dir-thumb {
  width: 44px;
  height: 44px;
  border-radius: 4px;
  object-fit: cover;
  flex-shrink: 0;
}

.rr-dir-thumb-placeholder {
  background: var(--cream-dark);
}

.rr-dir-body { flex: 1; min-width: 0; }

.rr-dir-name {
  font-size: .88rem;
  font-weight: 700;
  color: var(--green);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rr-dir-excerpt {
  font-size: .75rem;
  color: var(--mid);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rr-dir-more {
  display: block;
  text-align: center;
  padding: 10px;
  font-size: .8rem;
  font-weight: 600;
  color: var(--green);
  text-decoration: none;
  background: var(--cream);
  border-top: 1px solid var(--cream-dark);
}

.rr-dir-empty {
  padding: 14px;
  font-size: .82rem;
  color: var(--mid);
  text-align: center;
}

.rr-dir-cat-loading {
  font-size: .75rem;
  color: rgba(247,245,238,.4);
  font-style: italic;
}
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.rr-dir-cat {
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(247,245,238,.2);
  border-radius: 20px;
  padding: 4px 10px;
  font-size: .72rem;
  font-weight: 600;
  color: rgba(247,245,238,.8);
  text-decoration: none;
  transition: background .15s;
}

.rr-dir-cat:hover {
  background: rgba(255,255,255,.2);
  color: var(--cream);
}

.rr-directory-note {
  font-size: .7rem;
  color: rgba(247,245,238,.4);
  margin-top: 10px;
  font-style: italic;
}

/* ============================================================
   FEED PLACEHOLDER
   ============================================================ */

.rr-feed-placeholder {
  margin-top: 4px;
}

.rr-placeholder-intro {
  font-size: .88rem;
  color: var(--mid);
  margin-bottom: 14px;
  font-style: italic;
}

.rr-placeholder-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 16px;
}

.rr-placeholder-card {
  background: var(--white);
  border-radius: var(--radius);
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);
  border-left: 3px solid var(--cream-dark);
}

.rr-placeholder-cat {
  display: block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 4px;
}

.rr-placeholder-headline {
  font-family: var(--font-serif);
  font-size: .95rem;
  color: var(--green);
  line-height: 1.4;
}

.rr-placeholder-note {
  font-size: .75rem;
  color: var(--light);
  text-align: center;
  font-style: italic;
}

/* ============================================================
   QR */

.rr-qr-card {
  text-align: center;
}

.rr-qr-container {
  display: inline-block;
  background: var(--white);
  border: 2px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 16px;
  margin: 12px auto;
}

#rr-qr-display canvas,
#rr-qr-display img { display: block; }

.rr-qr-note {
  font-size: .75rem;
  color: var(--light);
  margin-top: 6px;
}

.rr-storage-note {
  font-size: .72rem;
  color: var(--light);
  text-align: center;
  margin-top: 8px;
  font-style: italic;
}

/* Save row */

.rr-save-row {
  margin-top: 8px;
  margin-bottom: 80px;
}

.rr-save-row .rr-btn {
  position: sticky;
  bottom: calc( var(--bottom-nav) + 8px );
  z-index: 10;
  box-shadow: var(--shadow);
}

/* ============================================================
   BOTTOM NAV
   ============================================================ */

.rr-bottom-nav {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: var(--bottom-nav);
  background: var(--white);
  border-top: 1px solid var(--cream-dark);
  display: flex;
  align-items: center;
  justify-content: space-around;
  z-index: 100;
  padding-bottom: env(safe-area-inset-bottom);
}

.rr-bnav-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  background: none;
  border: none;
  color: var(--light);
  font-family: var(--font-sans);
  font-size: .65rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  padding: 8px 16px;
  border-radius: var(--radius);
  transition: color .15s;
  flex: 1;
  max-width: 80px;
}

.rr-bnav-btn svg {
  width: 22px; height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.rr-bnav-btn.rr-bnav-active,
.rr-bnav-btn:hover { color: var(--green); }

/* ============================================================
   SHORTCODE FORMS (embedded in WordPress pages)
   ============================================================ */

.rr-form-wrap {
  max-width: 440px;
  margin: 0 auto;
}

.rr-form-inner {
  background: var(--white);
  border-radius: var(--radius-lg);
  padding: 28px 24px;
  box-shadow: var(--shadow);
}

.rr-form-label {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 6px;
}

.rr-form-inner input[type="email"],
.rr-form-inner input[type="password"],
.rr-form-inner input[type="text"] {
  width: 100%;
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 11px 14px;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--charcoal);
  background: var(--cream);
  outline: none;
  transition: border-color .15s;
  margin-bottom: 12px;
}

.rr-form-inner input:focus {
  border-color: var(--green);
  background: var(--white);
}

.rr-form-note {
  font-size: .8rem;
  color: var(--mid);
  margin-top: 10px;
  line-height: 1.5;
}

.rr-form-note a { color: var(--green); }

/* ============================================================
   DESKTOP
   ============================================================ */

@media (min-width: 600px) {
  .rr-auth-container { padding: 40px 32px 48px; }
  .rr-auth-wordmark  { font-size: 2.5rem; }
  .rr-bottom-nav     { display: none; }
  .rr-app-main       { padding-bottom: 0; }
  .rr-app-nav        { display: flex; }
  .rr-view-inner     { padding: 32px 24px 48px; }
}

@media (min-width: 600px) and (max-width: 599px) {
  .rr-app-nav { display: none; }
}

/* ============================================================
   CLASSIFIEDS
   ============================================================ */

.rr-classifieds-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0 16px;
  border-bottom: 1px solid var(--cream-dark);
  margin-bottom: 16px;
}

.rr-notif-btn {
  position: relative;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  color: var(--mid);
}

.rr-notif-btn svg {
  width: 24px; height: 24px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.75;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.rr-notif-badge {
  position: absolute;
  top: 0; right: 0;
  background: var(--gold);
  color: var(--charcoal);
  font-size: .65rem;
  font-weight: 700;
  width: 18px; height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.rr-notif-panel {
  margin-bottom: 14px;
}

.rr-notif-item {
  padding: 10px 12px;
  border-bottom: 1px solid var(--cream-dark);
}

.rr-notif-item:last-child { border-bottom: none; }

.rr-notif-unread {
  background: var(--green-light);
  border-radius: var(--radius);
  margin-bottom: 4px;
}

.rr-notif-msg {
  font-size: .88rem;
  color: var(--charcoal);
  margin-bottom: 2px;
}

.rr-notif-time {
  font-size: .72rem;
  color: var(--light);
}

/* Classifieds tabs */

.rr-classifieds-tabs {
  display: flex;
  background: var(--cream-dark);
  border-radius: var(--radius);
  padding: 3px;
  margin-bottom: 16px;
  gap: 2px;
}

.rr-cls-tab {
  flex: 1;
  background: none;
  border: none;
  color: var(--mid);
  font-family: var(--font-sans);
  font-size: .78rem;
  font-weight: 600;
  padding: 8px 6px;
  border-radius: 4px;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}

.rr-cls-tab-active {
  background: var(--white);
  color: var(--green);
  box-shadow: var(--shadow-sm);
}

/* Filters */

.rr-cls-filters {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}

.rr-cls-select {
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 9px 12px;
  font-family: var(--font-sans);
  font-size: .88rem;
  color: var(--charcoal);
  background: var(--white);
  outline: none;
  flex: 1;
}

.rr-cls-search {
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 9px 12px;
  font-family: var(--font-sans);
  font-size: .88rem;
  color: var(--charcoal);
  background: var(--white);
  outline: none;
  flex: 1.5;
}

.rr-cls-select:focus,
.rr-cls-search:focus { border-color: var(--green); }

/* Ad cards */

.rr-cls-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.rr-cls-card {
  background: var(--white);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  display: flex;
  gap: 0;
  transition: box-shadow .15s;
}

.rr-cls-card:hover { box-shadow: var(--shadow); }

.rr-cls-expired { opacity: .6; }

.rr-cls-card-img {
  width: 80px;
  flex-shrink: 0;
  object-fit: cover;
  display: block;
}

.rr-cls-card-body {
  padding: 10px 12px;
  flex: 1;
  min-width: 0;
}

.rr-cls-cat-tag {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 3px;
}

.rr-cls-title {
  font-family: var(--font-serif);
  font-size: 1rem;
  color: var(--green);
  line-height: 1.35;
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.rr-cls-meta {
  font-size: .8rem;
  color: var(--light);
}

.rr-cls-expired-badge,
.rr-cls-expiring-badge {
  display: inline-block;
  font-size: .65rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 10px;
  margin-top: 4px;
}

.rr-cls-expired-badge  { background: var(--cream-dark); color: var(--mid); }
.rr-cls-expiring-badge { background: var(--gold-light);  color: var(--charcoal); }

.rr-cls-owner-actions {
  display: flex;
  gap: 6px;
  margin-top: 8px;
  flex-wrap: wrap;
}

/* Post form */

.rr-cls-panel .rr-form-group label {
  display: block;
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 8px;
}

.rr-cls-panel .rr-form-group input[type="text"],
.rr-cls-panel .rr-form-group input[type="tel"],
.rr-cls-panel .rr-form-group textarea,
.rr-cls-panel .rr-form-group select {
  width: 100%;
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 13px 14px;
  font-family: var(--font-sans);
  font-size: 1.05rem;
  color: var(--charcoal);
  background: var(--cream);
  outline: none;
  transition: border-color .15s;
  box-sizing: border-box;
}

.rr-cls-panel .rr-form-group input:focus,
.rr-cls-panel .rr-form-group textarea:focus,
.rr-cls-panel .rr-form-group select:focus {
  border-color: var(--green);
  background: var(--white);
}

.rr-cls-panel .rr-form-group textarea {
  resize: vertical;
  min-height: 160px;
  line-height: 1.6;
}

.rr-field-hint {
  font-size: .72rem;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  color: var(--light);
}

.rr-cls-agreement {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin: 14px 0;
  font-size: .84rem;
  color: var(--mid);
  cursor: pointer;
  line-height: 1.4;
}

.rr-cls-agreement input { margin-top: 3px; flex-shrink: 0; accent-color: var(--green); }

/* Image upload */

.rr-upload-area {
  border: 1.5px dashed var(--cream-dark);
  border-radius: var(--radius);
  padding: 14px;
  background: var(--cream);
}

.rr-upload-previews {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.rr-upload-preview-img {
  width: 72px;
  height: 72px;
  object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--cream-dark);
}

/* Ad detail overlay */

.rr-ad-overlay {
  position: fixed;
  inset: 0;
  background: var(--cream);
  z-index: 200;
  overflow-y: auto;
  padding-bottom: var(--bottom-nav);
}

.rr-ad-overlay-inner {
  max-width: 680px;
  margin: 0 auto;
  padding: 16px;
}

.rr-ad-back {
  background: none;
  border: none;
  color: var(--green);
  font-family: var(--font-sans);
  font-size: 1rem;
  font-weight: 600;
  cursor: pointer;
  padding: 8px 0;
  margin-bottom: 12px;
  display: block;
}

/* Edit overlay form -- larger, full-width, readable for 50+ */

.rr-ad-overlay .rr-card-title {
  font-size: 1.3rem;
  margin-bottom: 16px;
}

.rr-ad-overlay .rr-cls-panel .rr-form-group label,
.rr-ad-overlay .rr-card .rr-form-group label {
  font-size: .9rem;
  margin-bottom: 8px;
}

.rr-ad-overlay .rr-card .rr-form-group input[type="text"],
.rr-ad-overlay .rr-card .rr-form-group input[type="tel"],
.rr-ad-overlay .rr-card .rr-form-group select {
  width: 100%;
  font-size: 1.05rem;
  padding: 13px 14px;
  border-radius: var(--radius);
  border: 1.5px solid var(--cream-dark);
  background: var(--cream);
  font-family: var(--font-sans);
  color: var(--charcoal);
  outline: none;
  box-sizing: border-box;
}

.rr-ad-overlay .rr-card .rr-form-group textarea {
  width: 100%;
  font-size: 1.05rem;
  padding: 13px 14px;
  border-radius: var(--radius);
  border: 1.5px solid var(--cream-dark);
  background: var(--cream);
  font-family: var(--font-sans);
  color: var(--charcoal);
  outline: none;
  box-sizing: border-box;
  resize: vertical;
  min-height: 220px;
  line-height: 1.6;
}

.rr-ad-overlay .rr-card .rr-form-group input:focus,
.rr-ad-overlay .rr-card .rr-form-group textarea:focus,
.rr-ad-overlay .rr-card .rr-form-group select:focus {
  border-color: var(--green);
  background: var(--white);
}

.rr-ad-hero-img {
  width: 100%;
  max-height: 260px;
  object-fit: cover;
  border-radius: var(--radius);
  margin-bottom: 14px;
}

.rr-ad-images {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin-bottom: 14px;
  padding-bottom: 4px;
}

.rr-ad-images img {
  height: 160px;
  width: auto;
  border-radius: var(--radius);
  flex-shrink: 0;
  object-fit: cover;
}

.rr-ad-detail-body { padding: 4px 0; }

.rr-ad-detail-title {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  color: var(--green);
  margin: 8px 0 4px;
  line-height: 1.3;
}

.rr-ad-detail-meta {
  font-size: .78rem;
  color: var(--light);
  margin-bottom: 14px;
}

.rr-ad-detail-desc {
  font-size: .92rem;
  color: var(--charcoal);
  line-height: 1.6;
  margin-bottom: 20px;
}

.rr-cls-call-btn {
  font-size: 1rem;
  margin-top: 4px;
  text-decoration: none;
  display: flex;
}

.rr-empty-state {
  text-align: center;
  color: var(--mid);
  font-size: .95rem;
  padding: 24px 0;
  font-style: italic;
}

.rr-cls-loading-msg {
  text-align: center;
  color: var(--light);
  font-size: .9rem;
  padding: 24px 0;
  font-style: italic;
}

/* ============================================================
   DISPLAY ADS: upsell, tiers, builder, full-page render
   ============================================================ */

/* Advertiser self-declaration */
.rr-advertiser-choice {
  display: flex;
  gap: 10px;
}
.rr-radio-card {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 12px 14px;
  cursor: pointer;
  font-size: .95rem;
  background: var(--cream);
  transition: all .15s;
}
.rr-radio-card input { accent-color: var(--green); }
.rr-radio-card:has(input:checked) {
  border-color: var(--green);
  background: var(--white);
  box-shadow: var(--shadow-sm);
}

/* Upsell panel */
.rr-upsell-head { margin-bottom: 18px; }
.rr-upsell-title {
  font-family: var(--font-serif);
  font-size: 1.5rem;
  color: var(--green);
  line-height: 1.25;
  margin-bottom: 12px;
}
.rr-upsell-intro {
  font-size: 1rem;
  color: var(--charcoal);
  line-height: 1.6;
  margin-bottom: 10px;
}
.rr-upsell-tiers {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.rr-upsell-transparency {
  font-size: .82rem;
  color: var(--mid);
  line-height: 1.55;
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--cream-dark);
}

/* Tier cards */
.rr-tier-card {
  background: var(--white);
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 18px;
  box-shadow: var(--shadow-sm);
}
.rr-tier-sponsorship {
  border-color: var(--gold);
  border-width: 2px;
  background: linear-gradient( to bottom, #fffdf6, var(--white) );
}
.rr-tier-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 8px;
}
.rr-tier-name {
  font-family: var(--font-serif);
  font-size: 1.3rem;
  color: var(--green);
}
.rr-tier-sponsorship .rr-tier-name { color: var(--gold-dark, #8a6d1a); }
.rr-tier-price {
  text-align: right;
  display: flex;
  flex-direction: column;
}
.rr-tier-first {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--charcoal);
}
.rr-tier-ongoing {
  font-size: .8rem;
  color: var(--mid);
}
.rr-tier-tagline {
  font-size: .95rem;
  color: var(--charcoal);
  line-height: 1.5;
  margin-bottom: 12px;
}
.rr-tier-includes {
  list-style: none;
  margin: 0 0 16px;
  padding: 0;
}
.rr-tier-includes li {
  position: relative;
  padding-left: 22px;
  margin-bottom: 6px;
  font-size: .9rem;
  color: var(--charcoal);
  line-height: 1.4;
}
.rr-tier-includes li:before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--green);
  font-weight: 700;
}

/* Builder */
.rr-builder-badge {
  display: inline-block;
  background: var(--gold);
  color: var(--charcoal);
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 4px 10px;
  border-radius: 12px;
  margin-bottom: 10px;
}
.rr-builder-logo-preview {
  max-width: 120px;
  max-height: 80px;
  display: block;
  margin-bottom: 10px;
  border-radius: 4px;
}
.rr-link-row {
  display: flex;
  gap: 8px;
  margin-bottom: 8px;
}
.rr-link-row .rr-link-label { flex: 1; }
.rr-link-row .rr-link-url { flex: 1.6; }
.rr-link-row input {
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 10px 12px;
  font-size: 1rem;
  font-family: var(--font-sans);
  background: var(--cream);
  outline: none;
  box-sizing: border-box;
}

/* Full-page display ad render */
.rr-display-page {
  padding: 4px 0 20px;
}
.rr-display-header {
  text-align: center;
  margin-bottom: 16px;
}
.rr-display-logo {
  max-width: 140px;
  max-height: 90px;
  margin: 0 auto 12px;
  display: block;
}
.rr-display-headline {
  font-family: var(--font-serif);
  font-size: 1.6rem;
  color: var(--green);
  line-height: 1.25;
}
.rr-display-photos {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin-bottom: 16px;
  padding-bottom: 4px;
}
.rr-display-photos img {
  height: 200px;
  width: auto;
  border-radius: var(--radius);
  flex-shrink: 0;
  object-fit: cover;
}
.rr-display-offer {
  background: var(--cream);
  border-radius: var(--radius);
  padding: 16px;
  text-align: center;
  margin-bottom: 16px;
}
.rr-display-product {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 4px;
}
.rr-display-price { font-size: 1.2rem; }
.rr-display-was {
  text-decoration: line-through;
  color: var(--light);
  font-size: 1rem;
}
.rr-display-now {
  color: var(--burnt, #96370B);
  font-weight: 700;
}
.rr-display-offer-tag {
  display: inline-block;
  background: var(--gold);
  color: var(--charcoal);
  font-size: .7rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 10px;
  vertical-align: middle;
}
.rr-display-case {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--charcoal);
  margin-bottom: 16px;
}
.rr-display-freeform {
  font-size: 1rem;
  line-height: 1.65;
  color: var(--charcoal);
  margin-bottom: 16px;
}
.rr-display-freeform img { max-width: 100%; height: auto; border-radius: var(--radius); }
.rr-display-freeform h2, .rr-display-freeform h3 {
  font-family: var(--font-serif);
  color: var(--green);
  margin: 16px 0 8px;
}
.rr-display-map {
  margin-bottom: 16px;
  border-radius: var(--radius);
  overflow: hidden;
}
.rr-display-map iframe { display: block; border: 0; }
.rr-display-contact { margin-bottom: 16px; }
.rr-display-address {
  text-align: center;
  font-size: .9rem;
  color: var(--mid);
  margin-top: 10px;
}
.rr-display-links {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rr-display-link {
  display: block;
  text-align: center;
  padding: 12px;
  background: var(--cream);
  border-radius: var(--radius);
  color: var(--green);
  text-decoration: none;
  font-weight: 600;
  font-size: .95rem;
}

/* Featured treatment on browse cards */
.rr-cls-featured {
  border: 1.5px solid var(--gold);
  box-shadow: 0 2px 12px rgba(176,141,58,0.18);
}
.rr-cls-featured-tag {
  display: inline-block;
  background: var(--gold);
  color: var(--charcoal);
  font-size: .62rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 2px 7px;
  border-radius: 10px;
  margin-bottom: 4px;
  margin-left: 6px;
}

/* Edit overlay: upgrade / manage panels */
.rr-edit-upgrade-divider {
  border-top: 1px solid var(--cream-dark);
  margin: 6px 0 16px;
}
.rr-edit-upgrade-title {
  font-family: var(--font-serif);
  font-size: 1.1rem;
  color: var(--green);
  margin-bottom: 6px;
}
.rr-edit-upgrade-desc {
  font-size: .9rem;
  color: var(--charcoal);
  line-height: 1.5;
  margin-bottom: 12px;
}
.rr-edit-manage-note {
  font-size: .9rem;
  color: var(--mid);
  line-height: 1.5;
  font-style: italic;
}

/* ============================================================
   TODAY ON THE RIVER (PWA widget + full view)
   ============================================================ */

.rr-river-mount { display: block; }

.rr-river-widget {
  background: #fff;
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  padding: 16px;
  cursor: pointer;
  transition: box-shadow .15s;
  box-shadow: var(--shadow-sm);
}
.rr-river-widget:hover { box-shadow: 0 2px 12px rgba(0,0,0,0.06); }
.rr-river-loading { cursor: default; }

.rr-river-eyebrow {
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--gold);
  font-size: .72rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.rr-river-line {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: .95rem;
  color: var(--charcoal);
  margin-bottom: 8px;
  line-height: 1.4;
}
.rr-river-tide { font-size: 1.05rem; }
.rr-river-tide strong { color: var(--green); }
.rr-river-arrow {
  font-size: 1.2rem;
  font-weight: 700;
  flex-shrink: 0;
}
.rr-river-arrow-rising { color: #1a6b3a; }
.rr-river-arrow-falling { color: #96370b; }
.rr-river-empty { color: var(--mid); font-style: italic; }
.rr-river-level-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #1a6b3a;
  display: inline-block;
  flex-shrink: 0;
}
.rr-river-level-dot.rr-river-level-low { background: #96370b; }
.rr-river-level-dot.rr-river-level-high { background: var(--gold); }
.rr-river-classification { color: var(--mid); font-style: italic; }
.rr-river-photo {
  margin-top: 12px;
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
}
.rr-river-photo img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  display: block;
}
.rr-river-photo-caption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: 10px 12px;
  background: linear-gradient(to top, rgba(0,0,0,0.75), transparent);
  color: #fff;
  font-size: .85rem;
}
.rr-river-photo-credit { color: var(--cream-dark); font-size: .78rem; margin-left: 6px; }
.rr-river-photo-empty {
  margin-top: 14px;
  text-align: right;
  font-size: .85rem;
}
.rr-river-submit-link {
  color: var(--green);
  text-decoration: none;
  border-bottom: 1px dashed var(--gold);
}

/* Full view (in overlay) */
.rr-river-full {
  padding: 4px 0 20px;
}
.rr-river-full-title {
  font-family: var(--font-serif);
  color: var(--green);
  font-size: 1.5rem;
  margin-bottom: 18px;
}
.rr-river-section { margin-bottom: 24px; }
.rr-river-section h3 {
  font-family: var(--font-serif);
  color: var(--green);
  font-size: 1.05rem;
  margin-bottom: 10px;
}
.rr-river-tide-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .94rem;
}
.rr-river-tide-table th {
  text-align: left;
  padding: 8px;
  background: var(--cream);
  color: var(--green);
  font-weight: 600;
  border-bottom: 1.5px solid var(--cream-dark);
}
.rr-river-tide-table td {
  padding: 10px 8px;
  border-bottom: 1px solid var(--cream-dark);
}
.rr-river-svg {
  width: 100%;
  height: auto;
  display: block;
  background: #fff;
  border-radius: var(--radius);
  border: 1px solid var(--cream-dark);
  padding: 4px;
  box-sizing: border-box;
}
.rr-river-photo-strip {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 6px;
}
.rr-river-photo-card {
  flex: 0 0 200px;
  margin: 0;
}
.rr-river-photo-card img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  border-radius: var(--radius);
  display: block;
}
.rr-river-photo-card figcaption {
  font-size: .85rem;
  color: var(--charcoal);
  margin-top: 6px;
  line-height: 1.4;
}
.rr-river-submit-cta { text-align: center; margin-top: 14px; }
.rr-river-submit-btn {
  display: inline-block;
  background: var(--green);
  color: #fff;
  padding: 10px 18px;
  border-radius: var(--radius);
  text-decoration: none;
  font-weight: 600;
  font-size: .92rem;
}
.rr-river-attribution {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid var(--cream-dark);
  color: var(--mid);
  font-size: .78rem;
  line-height: 1.5;
}
.rr-river-attribution p { margin: 0 0 4px; }
.rr-river-attribution a { color: var(--mid); text-decoration: underline; }

/* Photo submission modal (PWA copy of the shortcode modal styles) */
.rr-river-modal {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.rr-river-modal-inner {
  background: #fff;
  max-width: 480px;
  width: 100%;
  padding: 24px;
  border-radius: var(--radius);
  position: relative;
  max-height: 90vh;
  overflow-y: auto;
}
.rr-river-modal-close {
  position: absolute;
  top: 8px;
  right: 12px;
  background: none;
  border: 0;
  font-size: 1.6rem;
  cursor: pointer;
  color: var(--mid);
  line-height: 1;
}
.rr-river-modal h2 {
  font-family: var(--font-serif);
  color: var(--green);
  font-size: 1.3rem;
  margin: 0 0 8px;
}
.rr-river-modal-intro {
  color: var(--mid);
  font-size: .9rem;
  line-height: 1.5;
  margin-bottom: 14px;
}
.rr-river-submit-form label {
  display: block;
  margin-bottom: 12px;
  font-weight: 600;
  font-size: .92rem;
  color: var(--charcoal);
}
.rr-river-submit-form input[type=text],
.rr-river-submit-form input[type=file] {
  display: block;
  width: 100%;
  margin-top: 4px;
  padding: 10px;
  border: 1.5px solid var(--cream-dark);
  border-radius: var(--radius);
  font-size: 1rem;
  box-sizing: border-box;
  font-weight: 400;
  background: var(--cream);
}
.rr-river-modal-optional {
  font-weight: 400;
  color: var(--mid);
  font-size: .85rem;
}
.rr-river-modal-consent {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-weight: 400;
  font-size: .9rem;
  line-height: 1.4;
  margin: 14px 0 8px;
}
.rr-river-modal-consent input { margin-top: 3px; flex-shrink: 0; }
.rr-river-modal-message {
  font-size: .92rem;
  min-height: 1.4em;
  margin: 8px 0;
}
.rr-river-modal-message.error { color: #96370b; }
.rr-river-modal-message.success { color: #1a6b3a; }
.rr-river-modal-actions { margin-top: 12px; }
.rr-river-modal-submit {
  background: var(--green);
  color: #fff;
  border: 0;
  padding: 12px 22px;
  border-radius: var(--radius);
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
}
.rr-river-modal-submit:disabled { opacity: .5; cursor: not-allowed; }

/* Weather (Today in Richmond) */
.rr-river-weather { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.rr-river-weather-icon svg { vertical-align: middle; }
.rr-river-weather-block .rr-river-weather-today { font-size: 1.05rem; margin: 0; }
.rr-river-weather-sub { color: var(--mid); font-size: .9rem; margin: 4px 0 0; }
.rr-river-forecast-table { width: 100%; border-collapse: collapse; font-size: .95rem; }
.rr-river-forecast-table td { padding: 7px 6px; border-top: 1px solid #ece7d8; vertical-align: middle; }
.rr-river-forecast-day { font-weight: 600; width: 54px; }
.rr-river-forecast-icon { width: 30px; }
.rr-river-forecast-text { color: var(--ink, #3D3C37); }
.rr-river-forecast-temp { text-align: right; font-weight: 600; white-space: nowrap; }
.rr-river-forecast-min { color: #9b968a; font-weight: 400; }
.rr-river-forecast-rain { text-align: right; color: #3a6ea5; width: 48px; }

/* ---- Community groups view ---- */
.rr-groups-intro{color:#6E6A62;font-size:14px;line-height:1.5;margin:0 0 14px;max-width:640px}
.rr-groups-filters{margin:0 0 14px}
.rr-groups-chiprow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:8px}
.rr-groups-chiplabel{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#6E6A62;font-weight:700;margin-right:2px}
.rr-groups-chip{display:inline-block;padding:5px 12px;border:1px solid #d8d3bf;border-radius:14px;font-size:13px;color:#3D3C37;background:#fff;cursor:pointer}
.rr-groups-chip:hover{border-color:#2f5d3a}
.rr-groups-chip.is-active{background:#2f5d3a;color:#fff;border-color:#2f5d3a}
.rr-groups-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.rr-group-card{background:#fff;border:1px solid #e0dcc8;border-top:3px solid #2f5d3a;border-radius:6px;padding:14px 16px;display:flex;flex-direction:column}
.rr-group-type{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:#2f5d3a;font-weight:700;margin-bottom:4px}
.rr-group-name{margin:0 0 4px;font-size:1.1rem;color:#2a2a26}
.rr-group-line{font-size:13px;color:#6E6A62;margin-bottom:8px}
.rr-group-desc{font-size:14px;color:#3D3C37;line-height:1.5;margin:0 0 12px;flex:1}
.rr-group-contact{font-size:13px;color:#3D3C37;line-height:1.5;margin:0 0 12px}
.rr-group-addr{color:#6E6A62}
.rr-group-phone a{color:#2f5d3a;text-decoration:none;font-weight:600}
.rr-group-phone a:hover{text-decoration:underline}
.rr-group-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.rr-group-interest{background:#2f5d3a;color:#fff;border:0;border-radius:4px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer}
.rr-group-interest:hover{background:#244a2e}
.rr-group-web{font-size:13px;color:#B17804;text-decoration:none}
.rr-group-web:hover{text-decoration:underline}
.rr-group-form{margin-top:12px;border-top:1px solid #ece8d8;padding-top:12px}
.rr-group-form .rr-gi-hp{position:absolute;left:-9999px;width:1px;height:1px}
.rr-group-form-intro{font-size:13px;color:#6E6A62;margin:0 0 10px}
.rr-group-form input[type=text],.rr-group-form input[type=email],.rr-group-form textarea{display:block;width:100%;margin:0 0 8px;padding:8px;border:1px solid #d8d3bf;border-radius:4px;font-size:14px;box-sizing:border-box;font-family:inherit}
.rr-group-form-actions{display:flex;align-items:center;gap:12px}
.rr-group-interest-send{background:#2f5d3a;color:#fff;border:0;border-radius:4px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer}
.rr-group-interest-send:disabled{opacity:.6;cursor:default}
.rr-link-btn{background:none;border:0;color:#6E6A62;font-size:13px;cursor:pointer;text-decoration:underline}
.rr-gi-msg{font-size:13px;margin:4px 0;min-height:16px}
.rr-gi-error{color:#b3261e;font-weight:600}
.rr-gi-ok{color:#2f5d3a;font-size:14px;margin:4px 0}

/* ---- Suggest a group ---- */
.rr-groups-top{margin:0 0 12px}
.rr-group-suggest-btn{background:#fff;color:#2f5d3a;border:1px solid #2f5d3a;border-radius:4px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer}
.rr-group-suggest-btn:hover{background:#2f5d3a;color:#fff}
.rr-group-submit-panel{margin:0 0 16px}
.rr-group-submit-form{background:#fff;border:1px solid #e0dcc8;border-left:3px solid #B17804;border-radius:6px;padding:16px 18px;max-width:560px}
.rr-group-submit-form .rr-gs-hp{position:absolute;left:-9999px;width:1px;height:1px}
.rr-group-submit-form input[type=text],.rr-group-submit-form input[type=email],.rr-group-submit-form textarea{display:block;width:100%;margin:0 0 8px;padding:8px;border:1px solid #d8d3bf;border-radius:4px;font-size:14px;box-sizing:border-box;font-family:inherit}
.rr-gs-msg{font-size:13px;margin:4px 0;min-height:16px}
