/* ============================================================
   Борове — Village Site  |  Modern Redesign
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,600;0,700;0,900;1,600&family=Inter:wght@400;500;600;700&display=optional');

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

/* Always reserve scrollbar space → no layout shift on tall/short pages */
html {
  overflow-y: scroll;
  scrollbar-gutter: stable;
}

/* ── Design Tokens ───────────────────────────────────────── */
:root {
  --bg:          #EEF2EE;
  --surface:     #FFFFFF;
  --surface-2:   #F5F8F5;

  --p:           #1A4731;   /* primary dark */
  --p-mid:       #2C6E49;   /* primary mid  */
  --p-light:     #52A875;   /* primary light*/
  --p-xlight:    #D6EDE1;   /* tint         */

  --accent:      #E9A227;
  --accent-lt:   #FEF3DC;

  --red:         #C53030;
  --red-lt:      #FDECEA;
  --blue:        #1A5276;
  --blue-lt:     #D6EAF8;
  --amber:       #7D6608;
  --amber-lt:    #FEF9E7;

  --text:        #18202C;
  --muted:       #5A6472;
  --border:      #D3DDD3;

  --sh-xs: 0 1px 3px rgba(0,0,0,.07);
  --sh-sm: 0 2px 10px rgba(0,0,0,.09);
  --sh:    0 4px 22px rgba(0,0,0,.11);
  --sh-lg: 0 12px 42px rgba(0,0,0,.15);

  --r-sm:  8px;
  --r:     14px;
  --r-lg:  22px;
  --r-xl:  32px;

  --font-h: 'Playfair Display', Georgia, 'Times New Roman', serif;
  --font-b: 'Inter', 'Segoe UI', system-ui, sans-serif;

  --ease: cubic-bezier(.4,0,.2,1);
  --dur:  .22s;
}

/* ── Base ────────────────────────────────────────────────── */
html { font-size: 16px; scroll-behavior: smooth; }

body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
}

a { color: var(--p-mid); text-decoration: none; -webkit-transition: color var(--dur) var(--ease); transition: color var(--dur) var(--ease); }
a:hover, a:focus { color: var(--p); text-decoration: none; }
.article-content a:hover, .article-content a:focus { text-decoration: underline; }
img { max-width: 100%; height: auto; display: block; }
ul { list-style: none; }

/* ── HEADER ──────────────────────────────────────────────── */
.site-header {
  color: #fff;
  border-bottom: 3px solid var(--accent);
  position: relative;
  overflow: hidden;
  min-height: 200px;
}

/* Background photo layer */
.header-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.header-bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center 35%;
  object-position: center 35%;
  display: block;
}
.header-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10,40,22,.88) 0%, rgba(10,28,18,.75) 100%);
}

/* subtle dot pattern over photo */
.site-header::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background-image: radial-gradient(circle, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}

.header-top {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  max-width: 1240px;
  margin: 0 auto;
  padding: 22px 24px 12px;
  min-height: 102px;
  gap: 20px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

/* Village stats bar inside header */
.header-stats-bar {
  position: relative;
  z-index: 2;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px 24px;
  min-height: 72px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 32px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.header-tagline {
  font-size: .82rem;
  opacity: .7;
  letter-spacing: .5px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.header-stats {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.h-stat {
  text-align: center;
  border-left: 2px solid rgba(233,162,39,.4);
  padding-left: 16px;
}
.h-stat strong {
  display: block;
  font-family: var(--font-h);
  font-size: 1.5rem;
  color: var(--accent);
  line-height: 1.1;
}
.h-stat span {
  font-size: .72rem;
  opacity: .7;
  letter-spacing: 1px;
  text-transform: uppercase;
}

.site-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  color: #fff;
  text-decoration: none;
}
.site-logo:hover { text-decoration: none; opacity: .9; }

.logo-icon {
  width: 58px;
  height: 58px;
  background: linear-gradient(135deg, var(--accent) 0%, #c07f10 100%);
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 28px;
  box-shadow: 0 4px 14px rgba(233,162,39,.4);
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.logo-text-main {
  font-family: var(--font-h);
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: .5px;
  display: block;
  line-height: 1.1;
}

.logo-text-sub {
  font-size: .75rem;
  opacity: .7;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  display: block;
  margin-top: 3px;
}

.header-date {
  font-size: .82rem;
  opacity: .65;
  text-align: right;
  font-style: italic;
  letter-spacing: .3px;
}

/* ── NAV ─────────────────────────────────────────────────── */
.site-nav {
  background: rgba(10,28,18,.92);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.site-nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.site-nav ul li a {
  display: block;
  padding: 14px 20px;
  color: rgba(255,255,255,.75);
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: .6px;
  text-transform: uppercase;
  border-bottom: 3px solid transparent;
  -webkit-transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  text-decoration: none;
}

.site-nav ul li a:hover,
.site-nav ul li a:focus,
.site-nav ul li a.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
  text-decoration: none;
}

.nav-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 12px 24px;
  color: rgba(255,255,255,.8);
  font-size: 1.4rem;
  line-height: 1;
}

/* ── TICKER ──────────────────────────────────────────────── */
.news-ticker {
  background: var(--accent-lt);
  border-bottom: 1px solid rgba(233,162,39,.3);
  padding: 9px 0;
  overflow: hidden;
  white-space: nowrap;
}

.ticker-inner {
  display: inline-block;
  padding-left: 100%;
  -webkit-animation: ticker 36s linear infinite;
  animation: ticker 36s linear infinite;
  font-size: .84rem;
  color: #5a3e00;
  font-weight: 500;
}

@-webkit-keyframes ticker {
  0%   { -webkit-transform: translateX(0); transform: translateX(0); }
  100% { -webkit-transform: translateX(-100%); transform: translateX(-100%); }
}
@keyframes ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-100%); }
}

.ticker-label {
  display: inline-block;
  background: var(--accent);
  color: #fff;
  padding: 2px 12px;
  border-radius: 20px;
  margin-right: 14px;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  vertical-align: middle;
}

.ticker-item { display: inline-block; }
.ticker-type {
  color: var(--p);
  font-weight: 800;
}
.ticker-sep {
  color: rgba(90,62,0,.55);
  margin: 0 8px;
}

/* ── LAYOUT ──────────────────────────────────────────────── */
.container {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 24px;
}

.main-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 32px;
  padding: 36px 0;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}

.content-main  { -webkit-box-flex: 1; -ms-flex: 1 1 0%; flex: 1 1 0%; min-width: 0; }
.content-sidebar { width: 308px; -ms-flex-negative: 0; flex-shrink: 0; }

/* ── SECTION TITLE ───────────────────────────────────────── */
.section-title {
  font-family: var(--font-h);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--p);
  margin-bottom: 22px;
  padding-bottom: 10px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  position: relative;
}

.section-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(to right, var(--p) 0%, var(--p-light) 40%, transparent 100%);
  border-radius: 2px;
}

/* ── FEATURED ARTICLE ────────────────────────────────────── */
.featured-article {
  background: var(--surface);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--sh);
  margin-bottom: 36px;
  border: 1px solid var(--border);
}

.featured-article .article-image {
  width: 100%;
  height: 360px;
  display: block;
  -o-object-fit: cover;
  object-fit: cover;
  -o-object-position: center;
  object-position: center;
  -webkit-transition: -webkit-transform .5s var(--ease);
  transition: transform .5s var(--ease);
}
.featured-article:hover .article-image {
  -webkit-transform: scale(1.02);
  transform: scale(1.02);
}

.featured-article .article-body {
  padding: 28px 32px 32px;
}

.article-category {
  display: inline-block;
  background: linear-gradient(135deg, var(--p-mid), var(--p));
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: 1.6px;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 14px;
}

.featured-article h2 {
  font-family: var(--font-h);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.22;
  margin-bottom: 12px;
  color: var(--text);
}

.article-meta {
  font-size: .8rem;
  color: var(--muted);
  margin-bottom: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 16px;
}

.featured-article p {
  font-size: 1.02rem;
  color: var(--muted);
  line-height: 1.75;
  margin-bottom: 18px;
}

/* ── ARTICLE GRID ────────────────────────────────────────── */
.article-grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  margin-bottom: 36px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

/* ── ARTICLES NEWSPAPER LAYOUT ──────────────────────────── */
.articles-newspaper {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  grid-auto-rows: 360px;
  grid-auto-flow: dense;
  gap: 22px;
  margin: 40px 0 36px;
  padding: 8px 4px 0;
}
.articles-list-pagination {
  padding: 12px 0 56px;
  display: flex;
  justify-content: center;
}

/* card-body must accommodate footer in tight 1x1 cells */
.articles-newspaper .article-card .card-body {
  padding: 14px 16px 12px;
  min-height: 0;
}
.articles-newspaper .article-card .card-footer {
  margin-top: auto;
  margin-bottom: 0;
  padding-top: 10px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

/* ── Profile pending banner ──────────────────────────────── */
.profile-pending-banner {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 14px 18px;
  margin: 0 0 22px;
  background: var(--accent-lt);
  border: 1px solid var(--accent);
  border-radius: var(--r);
  color: var(--amber);
}
.profile-pending-icon { font-size: 1.5rem; line-height: 1; }
.profile-pending-title { font-weight: 700; font-size: .95rem; margin-bottom: 4px; color: var(--text); }
.profile-pending-text { font-size: .85rem; color: var(--muted); }
.profile-pending-fields {
  margin-top: 8px;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text);
  background: rgba(255,255,255,.55);
  padding: 6px 10px;
  border-radius: var(--r-sm);
  display: inline-block;
}

/* ── Profile change moderation cards ─────────────────────── */
.prof-req-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px 18px;
  margin-bottom: 14px;
  box-shadow: var(--sh-xs);
}
.prof-req-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
}
.prof-req-name { font-weight: 700; }
.prof-req-nick { font-size: .8rem; color: var(--muted); }
.prof-req-date { font-size: .78rem; color: var(--muted); white-space: nowrap; }
.prof-diff-table { width: 100%; border-collapse: collapse; margin: 8px 0; }
.prof-diff-table td { padding: 7px 10px; font-size: .85rem; vertical-align: top; }
.prof-diff-table tr { border-top: 1px solid var(--border); }
.prof-diff-table tr:first-child { border-top: none; }
.prof-diff-label { color: var(--muted); width: 120px; }
.prof-diff-old { color: var(--muted); text-decoration: line-through; max-width: 200px; word-break: break-word; }
.prof-diff-new { color: var(--p); font-weight: 600; max-width: 200px; word-break: break-word; }
.prof-diff-arrow { color: var(--muted); width: 16px; text-align: center; }
.prof-avatar-diff {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 8px 0 14px;
  padding: 10px;
  background: var(--surface-2);
  border-radius: var(--r-sm);
}
.prof-avatar-diff-col { text-align: center; }
.prof-avatar-diff-cap { font-size: .72rem; color: var(--muted); margin-bottom: 6px; }
.prof-av {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}
.prof-av--empty {
  background: var(--p-mid);
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
}

.art-image-current {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  padding: 8px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
}
.art-image-current img {
  width: 80px;
  height: 60px;
  object-fit: cover;
  border-radius: 4px;
  display: block;
}

/* gradient fallback when picsum/uploaded image fails */
.articles-newspaper .article-card .card-img.card-img--no-img {
  background: linear-gradient(135deg, var(--p), var(--p-mid) 60%, var(--p-light));
}
.articles-newspaper .article-card .card-img.card-img--no-img::before {
  content: '\1F4F0';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  opacity: .35;
  color: #fff;
  z-index: 0;
}

@media (min-width: 900px) {
  .articles-newspaper { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 360px; }
}

.articles-newspaper .article-card {
  -webkit-box-flex: 0;
  -ms-flex: none;
  flex: none;
  width: auto;
  height: 100%;
  min-height: 0;
  -webkit-transform: rotate(-0.4deg);
  transform: rotate(-0.4deg);
  -webkit-transition: -webkit-transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.articles-newspaper .article-card:nth-child(2n) { -webkit-transform: rotate(0.5deg); transform: rotate(0.5deg); }
.articles-newspaper .article-card:nth-child(3n) { -webkit-transform: rotate(-0.7deg); transform: rotate(-0.7deg); }
.articles-newspaper .article-card:nth-child(5n) { -webkit-transform: rotate(0.3deg); transform: rotate(0.3deg); }

/* Featured big card every 7th */
.articles-newspaper .article-card:nth-child(7n+1) {
  grid-column: span 2;
  grid-row: span 2;
}
.articles-newspaper .article-card:nth-child(7n+1) .card-img { height: 60%; }
.articles-newspaper .article-card:nth-child(7n+1) h3 {
  font-size: 1.45rem;
  line-height: 1.25;
  -webkit-line-clamp: 3;
}
.articles-newspaper .article-card:nth-child(7n+1) p {
  font-size: .95rem;
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Wide card */
@media (min-width: 900px) {
  .articles-newspaper .article-card:nth-child(11n+4) { grid-column: span 2; }
  .articles-newspaper .article-card:nth-child(11n+4) .card-img { height: 50%; }
  .articles-newspaper .article-card:nth-child(11n+4) h3 { font-size: 1.18rem; -webkit-line-clamp: 2; }
  .articles-newspaper .article-card:nth-child(11n+4) p { -webkit-line-clamp: 2; }
  /* Tall card */
  .articles-newspaper .article-card:nth-child(13n+6) { grid-row: span 2; }
  .articles-newspaper .article-card:nth-child(13n+6) .card-img { height: 55%; }
  .articles-newspaper .article-card:nth-child(13n+6) h3 { -webkit-line-clamp: 4; }
  .articles-newspaper .article-card:nth-child(13n+6) p { -webkit-line-clamp: 5; }
}

.articles-newspaper .article-card .card-img {
  height: 50%;
  min-height: 140px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.articles-newspaper .article-card h3 {
  font-size: 1.02rem;
  line-height: 1.3;
  margin-bottom: 6px;
  -webkit-line-clamp: 3;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.articles-newspaper .article-card p {
  font-size: .82rem;
  line-height: 1.45;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-box-flex: 0;
  -ms-flex: 0 1 auto;
  flex: 0 1 auto;
}

.articles-newspaper .article-card:hover {
  -webkit-transform: translateY(-6px) rotate(0deg) !important;
  transform: translateY(-6px) rotate(0deg) !important;
  z-index: 2;
  box-shadow: var(--sh-lg);
}

@media (max-width: 700px) {
  .articles-newspaper {
    grid-template-columns: 1fr;
    grid-auto-rows: minmax(300px, auto);
    gap: 18px;
  }
  .articles-newspaper .article-card,
  .articles-newspaper .article-card:nth-child(7n+1),
  .articles-newspaper .article-card:nth-child(11n+4),
  .articles-newspaper .article-card:nth-child(13n+6) {
    grid-column: span 1;
    grid-row: span 1;
    -webkit-transform: none;
    transform: none;
  }
  .articles-newspaper .article-card:nth-child(7n+1) h3 { font-size: 1.15rem; }
  .articles-newspaper .article-card:nth-child(7n+1) p { font-size: .9rem; }
}

.article-card {
  background: var(--surface);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--sh-sm);
  border: 1px solid var(--border);
  -webkit-box-flex: 1;
  -ms-flex: 1 1 210px;
  flex: 1 1 210px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-transition: -webkit-transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.article-card:hover {
  -webkit-transform: translateY(-5px);
  transform: translateY(-5px);
  box-shadow: var(--sh-lg);
}

.article-card .card-img {
  height: 190px;
  position: relative;
  overflow: hidden;
  background: #1a4731;
}

.article-card .card-img img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
  -webkit-transition: -webkit-transform .45s var(--ease);
  transition: transform .45s var(--ease);
}

.article-card:hover .card-img img {
  -webkit-transform: scale(1.07);
  transform: scale(1.07);
}

/* gradient fade at bottom of card image */
.article-card .card-img::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 70px;
  background: linear-gradient(to top, rgba(0,0,0,.45), transparent);
  pointer-events: none;
}

.article-card .card-img .article-category {
  position: absolute;
  bottom: 12px;
  left: 12px;
  margin: 0;
  z-index: 1;
}

.article-card .card-body {
  padding: 18px 18px 14px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
}

/* hide the category inside card-body since we moved it to image */
.article-card .card-body > .article-category { display: none; }

.article-card h3 {
  font-family: var(--font-h);
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 8px;
  color: var(--text);
}

.article-card p {
  font-size: .87rem;
  color: var(--muted);
  line-height: 1.55;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}

.card-footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}

.card-date { font-size: .75rem; color: var(--muted); }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn-read {
  display: inline-block;
  font-size: .8rem;
  color: var(--p-mid);
  font-weight: 600;
  text-decoration: none;
  border: 1.5px solid var(--p-mid);
  padding: 5px 14px;
  border-radius: 20px;
  -webkit-transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-read:hover {
  background: var(--p-mid);
  color: #fff;
  text-decoration: none;
}

.file-upload-input {
  display: none;
}
.file-upload-label {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 7px;
  cursor: pointer;
  padding: 8px 14px;
  border: 1.5px dashed var(--border);
  border-radius: var(--r-sm);
  font-size: .85rem;
  color: var(--muted);
  background: var(--bg-alt);
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease), background var(--dur) var(--ease);
  transition: border-color var(--dur) var(--ease), color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.file-upload-label:hover {
  border-color: var(--p-mid);
  color: var(--p);
  background: #f0f7f3;
}
.file-upload-label.has-file {
  border-style: solid;
  border-color: var(--p-mid);
  color: var(--p);
  background: #f0f7f3;
}

.btn-submit {
  background: linear-gradient(135deg, var(--p-mid) 0%, var(--p) 100%);
  color: #fff;
  border: none;
  padding: 12px 28px;
  border-radius: var(--r-xl);
  font-size: .95rem;
  font-weight: 700;
  cursor: pointer;
  width: 100%;
  letter-spacing: .4px;
  box-shadow: 0 4px 14px rgba(44,110,73,.35);
  -webkit-transition: box-shadow var(--dur) var(--ease), -webkit-transform var(--dur) var(--ease);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.btn-submit:hover {
  box-shadow: 0 6px 20px rgba(44,110,73,.45);
  -webkit-transform: translateY(-1px);
  transform: translateY(-1px);
}
.btn-submit:disabled {
  opacity: .75;
  cursor: not-allowed;
  -webkit-transform: none;
  transform: none;
  box-shadow: none;
}
.btn-submit .btn-spinner {
  display: inline-block;
  width: 14px;
  height: 14px;
  border: 2px solid rgba(255,255,255,.35);
  border-top-color: #fff;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 7px;
  -webkit-animation: spin .7s linear infinite;
  animation: spin .7s linear infinite;
}
@-webkit-keyframes spin { to { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
@keyframes spin { to { -webkit-transform: rotate(360deg); transform: rotate(360deg); } }
.btn-submit:active { -webkit-transform: translateY(0); transform: translateY(0); }

/* ── DIVIDER ─────────────────────────────────────────────── */
.divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 30px 0;
}

/* ── SIDEBAR WIDGETS ─────────────────────────────────────── */
.widget {
  background: var(--surface);
  border-radius: var(--r);
  margin-bottom: 24px;
  overflow: hidden;
  box-shadow: var(--sh-sm);
  border: 1px solid var(--border);
}

.widget-header {
  background: linear-gradient(135deg, var(--p) 0%, var(--p-mid) 100%);
  color: #fff;
  padding: 12px 18px;
  font-family: var(--font-h);
  font-size: .95rem;
  font-weight: 600;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  letter-spacing: .3px;
}

.widget-body { padding: 16px; }

/* widget announce items */
.announce-item {
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
}
.announce-item:last-child { border-bottom: none; }

.announce-item .ann-tag {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .9px;
  padding: 3px 9px;
  border-radius: 20px;
  margin-bottom: 5px;
}
.ann-tag.urgent   { background: var(--red-lt);   color: var(--red);  }
.ann-tag.info     { background: var(--p-xlight); color: var(--p);    }
.ann-tag.event    { background: var(--amber-lt); color: var(--amber);}
.ann-tag.services { background: var(--blue-lt);  color: var(--blue); }

.announce-item p { font-size: .84rem; color: var(--text); line-height: 1.45; margin-bottom: 4px; }
.announce-item .ann-date { font-size: .73rem; color: var(--muted); }

/* widget ride items */
.ride-item { padding: 11px 0; border-bottom: 1px solid var(--border); }
.ride-item:last-child { border-bottom: none; }

/* index page ride cards */
.index-rides-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.index-ride-card {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  gap: 14px;
  background: #fff;
  border: 1px solid #ddeedd;
  border-left: 4px solid var(--p);
  border-radius: 10px;
  padding: 14px 16px;
  box-shadow: 0 2px 8px rgba(0,0,0,.05);
  transition: box-shadow .2s, transform .2s;
}
.index-ride-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,.1); transform: translateY(-2px); }
.irc-icon {
  font-size: 1.6rem;
  width: 44px;
  height: 44px;
  background: #eaf4ee;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.irc-body { flex: 1; min-width: 0; }
.irc-route {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 6px;
}
.irc-place {
  font-size: .97rem;
  font-weight: 700;
  color: #1a2e1a;
}
.irc-arrow {
  color: var(--p);
  font-size: 1rem;
  font-weight: 700;
  flex-shrink: 0;
}
.irc-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.irc-chip {
  font-size: .75rem;
  color: #555;
  background: #f0f5f0;
  border-radius: 20px;
  padding: 2px 9px;
  white-space: nowrap;
}
.irc-badge { flex-shrink: 0; }

.ride-route { font-size: .9rem; font-weight: 700; color: var(--p); margin-bottom: 4px; }
.ride-route .arrow { margin: 0 6px; color: var(--accent); }

.ride-info {
  font-size: .78rem;
  color: var(--muted);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 4px;
}

.ride-contact { font-size: .8rem; color: var(--p-mid); font-weight: 600; }

/* weather */
.weather-display { text-align: center; padding: 8px 0 14px; }
.weather-icon { font-size: 3.2rem; margin-bottom: 4px; }
.weather-temp { font-size: 2.2rem; font-weight: 700; color: var(--p); }
.weather-desc { font-size: .85rem; color: var(--muted); margin-bottom: 14px; }

.weather-grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.weather-grid .w-item {
  -webkit-box-flex: 1;
  -ms-flex: 1 1 72px;
  flex: 1 1 72px;
  background: var(--surface-2);
  border-radius: var(--r-sm);
  padding: 8px 6px;
  text-align: center;
  font-size: .76rem;
  color: var(--muted);
  border: 1px solid var(--border);
}
.weather-grid .w-item strong { display: block; color: var(--text); font-size: .82rem; margin-bottom: 2px; }
.weather-feel { font-size: .78rem; color: var(--muted); margin-top: -8px; margin-bottom: 14px; }
.weather-source { text-align: right; padding: 6px 0 2px; font-size: .72rem; color: var(--muted); }
.weather-source a { color: var(--muted); }
.weather-loading { padding: 20px; text-align: center; color: var(--muted); font-size: .85rem; }
.weather-error { padding: 12px; color: var(--muted); font-size: .85rem; }

@media (max-width: 960px) {
  #weatherWidgetBody { padding: 10px 14px 10px; }
  #weatherWidgetBody .weather-display {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 12px;
    padding: 0 0 8px;
    text-align: left;
  }
  #weatherWidgetBody .weather-icon {
    font-size: 2.4rem;
    margin-bottom: 0;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    line-height: 1;
  }
  #weatherWidgetBody .weather-temp { font-size: 1.6rem; line-height: 1.1; }
  #weatherWidgetBody .weather-desc { font-size: .8rem; margin-bottom: 2px; }
  #weatherWidgetBody .weather-feel { font-size: .72rem; margin: 0; }
  #weatherWidgetBody .weather-grid {
    border-top: 1px solid var(--border);
    padding-top: 8px;
    gap: 0;
  }
  #weatherWidgetBody .weather-grid .w-item {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    background: none;
    border: none;
    border-right: 1px solid var(--border);
    border-radius: 0;
    padding: 4px 6px;
    font-size: .7rem;
  }
  #weatherWidgetBody .weather-grid .w-item:last-child { border-right: none; }
  #weatherWidgetBody .weather-grid .w-item strong { font-size: .74rem; margin-bottom: 1px; }
  #weatherWidgetBody .weather-source { display: none; }
}

/* contacts */
.contact-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  border-bottom: 1px solid var(--border);
  font-size: .86rem;
}
.contact-list li:last-child { border-bottom: none; }
.contact-list .c-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--p-xlight);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 1rem;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.contact-list .c-label { color: var(--muted); font-size: .76rem; }
.contact-list .c-val { font-weight: 700; color: var(--text); font-size: .86rem; }

.feedback-form .form-group { margin-bottom: 12px; }
.feedback-form label { font-size: .78rem; }
.feedback-form input,
.feedback-form textarea {
  font-size: .84rem;
  padding: 9px 11px;
}
.feedback-form textarea {
  min-height: 112px;
  line-height: 1.45;
}
.feedback-auth-notice {
  padding: 20px 14px;
  box-shadow: none;
}
.feedback-profile {
  background: var(--p-xlight);
  border: 1px solid var(--p-light);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  margin-bottom: 14px;
}
.feedback-profile-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 5px 0;
  border-bottom: 1px dashed rgba(82,168,117,.35);
}
.feedback-profile-row:last-child { border-bottom: none; }
.feedback-profile-row span {
  color: var(--muted);
  font-size: .72rem;
  font-weight: 600;
  text-transform: uppercase;
}
.feedback-profile-row strong {
  color: var(--text);
  font-size: .86rem;
  overflow-wrap: anywhere;
}
.feedback-form .btn-submit {
  width: 100%;
  padding: 10px 14px;
  font-size: .88rem;
}
.feedback-status {
  min-height: 18px;
  margin: 10px 0 0;
  font-size: .78rem;
  line-height: 1.35;
  color: var(--muted);
}
.feedback-status.is-success { color: #2f855a; font-weight: 600; }
.feedback-status.is-error { color: var(--red); font-weight: 600; }

/* ── Top product widget ──────────────────────────────────── */
.top-product-wrap { padding: 0; }
.top-product-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  padding: 14px 16px;
  text-decoration: none;
  color: inherit;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.top-product-link:hover { background: var(--bg-alt); }
.top-product-thumb {
  width: 76px;
  height: 76px;
  border-radius: var(--r-sm);
  overflow: hidden;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  background: var(--p-xlight);
}
.top-product-thumb img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.top-product-no-img {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 2rem;
}
.top-product-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.top-product-title {
  font-weight: 700;
  font-size: .88rem;
  color: var(--text);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  -webkit-transition: color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease);
}
.top-product-link:hover .top-product-title { color: var(--p); }
.top-product-badge {
  display: inline-block;
  background: #fff3cd;
  color: #856404;
  border-radius: 20px;
  padding: 1px 8px;
  font-size: .7rem;
  font-weight: 700;
  white-space: nowrap;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.top-product-footer {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 6px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.top-product-price { font-size: .88rem; font-weight: 700; color: var(--p); }
.top-product-price--free { color: var(--muted); font-weight: 400; font-style: italic; font-size: .8rem; }
.top-product-seller { font-size: .72rem; color: var(--muted); }

/* ── PAGE HERO ───────────────────────────────────────────── */
.page-hero {
  background: linear-gradient(135deg, #1A4731 0%, #0C2118 100%);
  color: #fff;
  padding: 48px 24px 44px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
}
.page-hero h1 {
  font-family: var(--font-h);
  font-size: 2.2rem;
  font-weight: 700;
  margin-bottom: 8px;
  position: relative;
}
.page-hero p { opacity: .75; font-size: .95rem; position: relative; }

/* ── ANNOUNCEMENTS PAGE ──────────────────────────────────── */
.ann-filters,
.rides-filters {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 24px;
  padding: 18px;
  background: var(--surface);
  border-radius: var(--r);
  border: 1px solid var(--border);
  box-shadow: var(--sh-xs);
}
.rides-filters { padding: 12px 16px; margin: 0 0 18px; }

.filter-btn {
  padding: 7px 18px;
  border: 2px solid var(--border);
  background: transparent;
  cursor: pointer;
  border-radius: 20px;
  font-size: .84rem;
  font-weight: 600;
  color: var(--muted);
  -webkit-transition: all var(--dur) var(--ease);
  transition: all var(--dur) var(--ease);
  font-family: var(--font-b);
}
.filter-btn:hover { border-color: var(--p-light); color: var(--p); }
.filter-btn.active {
  background: var(--p);
  border-color: var(--p);
  color: #fff;
  box-shadow: 0 2px 10px rgba(26,71,49,.3);
}

.ann-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 5px solid var(--p-mid);
  border-radius: var(--r);
  padding: 20px 22px;
  margin-bottom: 16px;
  box-shadow: var(--sh-xs);
  -webkit-transition: -webkit-transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.ann-card:hover { -webkit-transform: translateX(4px); transform: translateX(4px); box-shadow: var(--sh-sm); }
.ann-card.urgent   { border-left-color: var(--red);   }
.ann-card.event    { border-left-color: var(--accent); }
.ann-card.services { border-left-color: var(--blue);  }
.ann-card.info     { border-left-color: var(--p-mid); }

.ann-card-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px;
  margin-bottom: 10px;
}
.ann-card h3 { font-family: var(--font-h); font-size: 1.1rem; font-weight: 700; color: var(--text); margin-top: 4px; }
.ann-card-date { font-size: .78rem; color: var(--muted); white-space: nowrap; }
.ann-card p { font-size: .9rem; color: var(--muted); line-height: 1.65; }
.ann-card-contact { margin-top: 12px; font-size: .87rem; font-weight: 700; color: var(--p-mid); }

.ann-card-header-right {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}

.ann-card-img {
  width: 100%;
  max-height: 260px;
  -o-object-fit: cover;
  object-fit: cover;
  border-radius: var(--r-sm);
  margin: 10px 0 6px;
  display: block;
}

/* ── CARD ADMIN DELETE BUTTON ────────────────────────────── */
.card-admin-del {
  border: 1.5px solid var(--border);
  background: var(--surface);
  border-radius: var(--r-sm);
  width: 28px;
  height: 28px;
  font-size: .85rem;
  cursor: pointer;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transition: background var(--dur), border-color var(--dur);
  transition: background var(--dur), border-color var(--dur);
}
.card-admin-del:hover { background: var(--red-lt); border-color: var(--red); }

.ride-card-top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 6px;
}
.ride-card-top .ride-badge { margin-bottom: 0; }

/* ── FORM MOBILE TOGGLE ──────────────────────────────────── */
.form-mobile-toggle {
  display: none;
  width: 100%;
  padding: 13px 18px;
  background: var(--p);
  color: #fff;
  border: none;
  border-radius: var(--r);
  font-size: .95rem;
  font-weight: 600;
  font-family: var(--font-b);
  cursor: pointer;
  text-align: left;
  margin-bottom: 12px;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
  position: relative;
}
.form-mobile-toggle:hover { background: var(--p-mid); }
.form-mobile-toggle::after {
  content: '▾';
  position: absolute;
  right: 18px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: .85rem;
  -webkit-transition: -webkit-transform var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease);
}
.form-mobile-toggle[aria-expanded="true"]::after {
  -webkit-transform: translateY(-50%) rotate(180deg);
  transform: translateY(-50%) rotate(180deg);
}

/* Desktop: section always visible */
.add-form-section { display: block; }

/* Auth notice inside form area */
.form-auth-notice {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  padding: 28px 20px;
  text-align: center;
  box-shadow: var(--sh-sm);
}
.form-auth-notice .auth-notice-icon {
  font-size: 2.2rem;
  margin-bottom: 10px;
}
.form-auth-notice p {
  margin: 0;
  font-size: .95rem;
  color: var(--muted);
  line-height: 1.6;
}
.form-auth-notice a {
  color: var(--p-mid);
  font-weight: 600;
  text-decoration: underline;
  -webkit-text-decoration: underline;
}

/* ── FORMS ───────────────────────────────────────────────── */
.add-form {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 26px;
  box-shadow: var(--sh-sm);
}
.add-form h3 {
  font-family: var(--font-h);
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 20px;
  color: var(--p);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--border);
}

.form-group { margin-bottom: 16px; }
.form-group label { display: block; font-size: .82rem; font-weight: 600; margin-bottom: 5px; color: var(--text); }

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-size: .9rem;
  font-family: var(--font-b);
  background: var(--surface-2);
  color: var(--text);
  -webkit-transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--p-mid);
  box-shadow: 0 0 0 4px rgba(44,110,73,.12);
  background: var(--surface);
}
.form-group textarea { resize: vertical; min-height: 100px; }

.form-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
}
.form-row .form-group { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }

/* ── RIDES PAGE ──────────────────────────────────────────── */
.rides-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 32px;
  padding: 36px 0;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.rides-list      { -webkit-box-flex: 1; -ms-flex: 1 1 380px; flex: 1 1 380px; }
.rides-form-wrap { width: 320px; -ms-flex-negative: 0; flex-shrink: 0; }

.ride-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 18px 20px;
  margin-bottom: 14px;
  box-shadow: var(--sh-xs);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 16px;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-transition: -webkit-transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.ride-card:hover {
  -webkit-transform: translateY(-3px);
  transform: translateY(-3px);
  box-shadow: var(--sh);
}

.ride-card-icon {
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, var(--p-mid), var(--p));
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 1.5rem;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  box-shadow: 0 3px 10px rgba(44,110,73,.3);
}

.ride-card-body { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }

.ride-card-route {
  font-family: var(--font-h);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--p);
  margin-bottom: 6px;
}
.ride-card-route .sep { margin: 0 8px; color: var(--accent); font-size: 1.1em; }

.ride-card-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 12px;
  font-size: .8rem;
  color: var(--muted);
  margin-bottom: 8px;
}
.ride-card-meta .meta-item { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; gap: 4px; }

.ride-card-comment { font-size: .87rem; color: var(--muted); font-style: italic; margin-bottom: 8px; line-height: 1.5; }
.ride-card-contact { font-size: .87rem; font-weight: 700; color: var(--p-mid); }

.ride-badge {
  display: inline-block;
  font-size: .68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .8px;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--p-xlight);
  color: var(--p);
  border: 1px solid rgba(44,110,73,.25);
  margin-bottom: 8px;
}
.ride-badge.full    { background: var(--red-lt);   color: var(--red);   border-color: rgba(197,48,48,.2);  }
.ride-badge.seats-1 { background: var(--amber-lt); color: var(--amber); border-color: rgba(233,162,39,.3); }

/* ── FOOTER ──────────────────────────────────────────────── */
.site-footer {
  background: linear-gradient(160deg, #0C2118 0%, #081510 100%);
  color: #a8c4b0;
  padding: 50px 0 24px;
  margin-top: 48px;
  border-top: 3px solid var(--accent);
}

.footer-grid {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 40px;
  margin-bottom: 40px;
}

.footer-col { -webkit-box-flex: 1; -ms-flex: 1 1 180px; flex: 1 1 180px; }

.footer-col h4 {
  font-family: var(--font-h);
  color: var(--accent);
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(233,162,39,.2);
}

.footer-col p, .footer-col li {
  font-size: .84rem;
  line-height: 2;
  color: #7a9884;
}

.footer-col ul li a { color: #7a9884; -webkit-transition: color var(--dur) var(--ease); transition: color var(--dur) var(--ease); }
.footer-col ul li a:hover { color: var(--accent); text-decoration: none; }

.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.06);
  padding-top: 20px;
  text-align: center;
  font-size: .78rem;
  color: #485848;
}

/* ── TOAST ───────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 28px;
  right: 28px;
  background: linear-gradient(135deg, var(--p-mid), var(--p));
  color: #fff;
  padding: 14px 22px;
  border-radius: var(--r);
  box-shadow: var(--sh-lg);
  font-size: .9rem;
  z-index: 9999;
  -webkit-transform: translateY(80px);
  transform: translateY(80px);
  opacity: 0;
  -webkit-transition: opacity .3s var(--ease), -webkit-transform .3s var(--ease);
  transition: opacity .3s var(--ease), transform .3s var(--ease);
  max-width: 300px;
}
.toast.show { -webkit-transform: translateY(0); transform: translateY(0); opacity: 1; }

/* ── EMPTY STATE ─────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: 36px 20px;
  color: var(--muted);
  width: 100%;
  /* In CSS Grid parents — span all columns so the message stays centered */
  grid-column: 1 / -1;
  /* In flex parents — fill the line */
  flex: 1 1 100%;
}
.empty-state .empty-icon { font-size: 2.8rem; margin-bottom: 10px; opacity: .5; }
.empty-state p { font-size: .92rem; }

/* ── LEGEND ──────────────────────────────────────────────── */
.legend-list { font-size: .84rem; line-height: 1; }
.legend-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  color: var(--muted);
}
.legend-list li:last-child { border-bottom: none; }

/* ── TIPS LIST ───────────────────────────────────────────── */
.tips-list { font-size: .83rem; color: var(--muted); }
.tips-list li { padding: 7px 0; border-bottom: 1px solid var(--border); display: -webkit-box; display: -ms-flexbox; display: flex; gap: 8px; -webkit-box-align: start; -ms-flex-align: start; align-items: flex-start; }
.tips-list li:last-child { border-bottom: none; }
.tips-list li::before { content: '✓'; color: var(--p-light); font-weight: 700; -ms-flex-negative: 0; flex-shrink: 0; }

/* ── PAGINATION ──────────────────────────────────────────── */
.pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: 12px;
  margin-top: 20px;
  padding: 4px 0 8px;
}
.page-btn {
  background: var(--surface);
  border: 1.5px solid var(--border);
  color: var(--p-mid);
  font-family: var(--font-b);
  font-size: .875rem;
  font-weight: 600;
  padding: 8px 18px;
  border-radius: var(--r-sm);
  cursor: pointer;
  -webkit-transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.page-btn:hover:not(:disabled) {
  background: var(--p-xlight);
  border-color: var(--p-light);
}
.page-btn:disabled { opacity: .4; cursor: default; }
.page-info {
  font-size: .875rem;
  color: var(--muted);
  font-weight: 500;
  min-width: 56px;
  text-align: center;
}

/* ── FADE-IN ANIMATION ───────────────────────────────────── */
.fade-in {
  opacity: 0;
  -webkit-transform: translateY(18px);
  transform: translateY(18px);
  -webkit-transition: opacity .5s var(--ease), -webkit-transform .5s var(--ease);
  transition: opacity .5s var(--ease), transform .5s var(--ease);
}
.fade-in.visible { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 960px) {
  .form-mobile-toggle { display: block; }
  .add-form-section { display: none; }
  .add-form-section.open { display: block; }

  .main-layout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
  }
  /* Flatten sidebar on mobile so we can re-order individual widgets */
  .content-sidebar { display: contents; }
  .content-sidebar > .widget { width: 100%; max-width: 100%; order: -1; }
  /* Main content sits between regular widgets and the feedback widget */
  .content-main { width: 100%; max-width: 100%; order: 0; }
  /* Feedback form pinned to the very bottom on mobile (specificity > sidebar > widget) */
  .content-sidebar > .widget--feedback { order: 99; }
  .widget { margin-bottom: 16px; }

  /* Prevent nav from wrapping to a second line at tablet widths */
  .site-nav ul { -ms-flex-wrap: nowrap; flex-wrap: nowrap; }
  .site-nav ul li a { padding-left: 10px; padding-right: 10px; }
}

/* ── NAV OVERLAY ─────────────────────────────────────────── */
.nav-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 99;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity .3s var(--ease), visibility .3s var(--ease);
  transition: opacity .3s var(--ease), visibility .3s var(--ease);
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.nav-overlay.open { opacity: 1; visibility: visible; }

/* ── DRAWER HEADER (hidden on desktop, shown in mobile drawer) */
.drawer-head { display: none; }

.drawer-logo {
  font-family: var(--font-h);
  font-size: 1.2rem;
  color: var(--accent);
  font-weight: 700;
}

.drawer-close {
  background: rgba(255,255,255,.08);
  border: none;
  color: rgba(255,255,255,.7);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  font-size: 1rem;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.drawer-close:hover { background: rgba(255,255,255,.18); }

/* ── RESPONSIVE 700px ────────────────────────────────────── */
@media (max-width: 700px) {

  /* Remove backdrop-filter so it doesn't become a containing block
     for the position:fixed drawer ul */
  .site-nav {
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
  }

  .nav-toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    gap: 6px;
    font-size: 1.3rem;
  }

  /* Drawer header visible inside the panel */
  .drawer-head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding: 20px 20px 18px;
    border-bottom: 1px solid rgba(255,255,255,.08);
    -ms-flex-negative: 0;
    flex-shrink: 0;
  }

  /* Slide-in drawer panel */
  .site-nav ul {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 280px;
    max-width: 85vw;
    background: #0A1C12;
    z-index: 300;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 0;
    -webkit-transform: translateX(-100%);
    transform: translateX(-100%);
    -webkit-transition: -webkit-transform .32s var(--ease);
    transition: transform .32s var(--ease);
    overflow-y: auto;
    box-shadow: 6px 0 40px rgba(0,0,0,.5);
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }

  .site-nav ul.open {
    -webkit-transform: translateX(0);
    transform: translateX(0);
  }

  .site-nav ul li a {
    padding: 15px 24px;
    border-bottom: 1px solid rgba(255,255,255,.05);
    border-left: 3px solid transparent;
    font-size: .92rem;
    letter-spacing: .5px;
  }
  .site-nav ul li a.active,
  .site-nav ul li a:hover {
    border-left-color: var(--accent);
    border-bottom-color: rgba(255,255,255,.05);
    background: rgba(255,255,255,.04);
  }

  .logo-text-main { font-size: 1.5rem; }
  .header-date { display: none; }
  .header-stats { display: none; }
  .header-stats-bar { padding-bottom: 16px; }

  .featured-article h2 { font-size: 1.45rem; }
  .featured-article .article-image { height: 240px; }
  .featured-article .article-body { padding: 20px; }

  .article-grid {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .article-card { -ms-flex: none; flex: none; }

  .rides-layout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding: 20px 0;
  }
  .rides-form-wrap { width: 100%; -webkit-box-ordinal-group: 0; -ms-flex-order: -1; order: -1; }
  .form-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  .page-hero { padding: 36px 20px; }
  .page-hero h1 { font-size: 1.65rem; }
}

/* ── RESPONSIVE 480px ────────────────────────────────────── */
@media (max-width: 480px) {
  .container { padding: 0 16px; }
  .header-top { padding: 16px; }
  .main-layout { padding: 20px 0; }
  .add-form { padding: 18px; }
  .rides-layout { padding: 20px 0; }
}

/* ── ALBUM COVERS (homepage gallery) ────────────────────── */
.album-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 16px 1fr 16px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 36px;
}

.album-cover {
  position: relative;
  border-radius: var(--r);
  overflow: hidden;
  display: block;
  text-decoration: none;
  box-shadow: var(--sh);
  background: #0a1c12;
  aspect-ratio: 4 / 3;
  -webkit-transition: -webkit-transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}

.album-cover:hover {
  -webkit-transform: translateY(-4px);
  transform: translateY(-4px);
  box-shadow: var(--sh-lg);
  text-decoration: none;
}

.album-cover img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
  -webkit-transition: -webkit-transform .55s var(--ease);
  transition: transform .55s var(--ease);
}

.album-cover:hover img {
  -webkit-transform: scale(1.07);
  transform: scale(1.07);
}

.album-cover-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,.12) 55%, transparent 100%);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  padding: 20px;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}

.album-cover:hover .album-cover-overlay {
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.2) 60%, transparent 100%);
}

.album-cover-title {
  font-family: var(--font-h);
  font-size: 1.15rem;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
  text-shadow: 0 1px 6px rgba(0,0,0,.6);
  line-height: 1.25;
}

.album-cover-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}

.album-count {
  background: rgba(255,255,255,.18);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  border: 1px solid rgba(255,255,255,.25);
  color: #fff;
  padding: 3px 11px;
  border-radius: 20px;
  font-size: .72rem;
  font-weight: 600;
}

.album-date {
  font-size: .75rem;
  color: rgba(255,255,255,.75);
}

@media (max-width: 700px) {
  .album-grid { grid-template-columns: 1fr; }
  .album-cover { aspect-ratio: 16 / 9; }
}
@media (min-width: 701px) and (max-width: 900px) {
  .album-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── ARTICLE DETAIL PAGE ─────────────────────────────────── */
.article-hero {
  position: relative;
  height: 420px;
  overflow: hidden;
  background: #0a1c12;
}
.article-hero img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.article-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.65) 0%, transparent 60%);
}

.article-breadcrumb {
  font-size: .82rem;
  color: var(--muted);
  padding: 16px 0 4px;
}
.article-breadcrumb a { color: var(--p-mid); }
.article-breadcrumb span { margin: 0 6px; }

.article-full {
  max-width: 800px;
  margin: 0 auto;
  padding: 32px 24px 64px;
}

.article-full .article-category { margin-bottom: 14px; }

.article-full h1 {
  font-family: var(--font-h);
  font-size: 2.1rem;
  font-weight: 900;
  line-height: 1.2;
  margin-bottom: 14px;
  color: var(--text);
}

.article-full .article-meta { margin-bottom: 28px; }

.article-body-content {
  overflow-wrap: anywhere;
}

.article-body-content ul,
.article-body-content ol {
  margin: 0 0 22px 24px;
  padding-left: 18px;
  color: var(--muted);
  font-size: 1.03rem;
  line-height: 1.85;
}

.article-body-content ul { list-style: disc; }
.article-body-content ol { list-style: decimal; }
.article-body-content li { margin-bottom: 8px; }
.article-body-content a { font-weight: 600; text-decoration: underline; }
.article-body-content strong { color: var(--text); }

.article-full p {
  font-size: 1.03rem;
  line-height: 1.85;
  color: var(--muted);
  margin-bottom: 20px;
}

.article-full h2 {
  font-family: var(--font-h);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--p);
  margin: 32px 0 12px;
}

.article-full h3 {
  font-family: var(--font-h);
  font-size: 1.16rem;
  font-weight: 700;
  color: var(--p);
  margin: 28px 0 10px;
}

.article-full blockquote {
  border-left: 4px solid var(--accent);
  background: var(--accent-lt);
  padding: 16px 20px;
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  margin: 24px 0;
  font-style: italic;
  color: var(--text);
  font-size: 1.02rem;
  line-height: 1.7;
}

.article-full .article-inline-img {
  width: 100%;
  border-radius: var(--r);
  margin: 24px 0;
  box-shadow: var(--sh);
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}

.article-back {
  display: inline--webkit-box;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  color: var(--p-mid);
  font-weight: 600;
  font-size: .9rem;
  margin-bottom: 24px;
  text-decoration: none;
}
.article-back:hover { color: var(--p); text-decoration: none; }

.article-format-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 8px;
}

.article-format-btn {
  min-width: 34px;
  height: 30px;
  padding: 0 9px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--surface-2);
  color: var(--text);
  font-family: var(--font-b);
  font-size: .78rem;
  font-weight: 700;
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.article-format-btn:hover,
.article-format-btn:focus {
  background: var(--p-xlight);
  border-color: var(--p-mid);
  color: var(--p);
}

@media (max-width: 700px) {
  .article-hero { height: 260px; }
  .article-full h1 { font-size: 1.5rem; }
  .article-full { padding: 24px 16px 48px; }
}

/* ── GALLERY & ALBUM PAGE ────────────────────────────────── */
.gallery-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 20px 1fr 20px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  padding: 32px 0;
}

.photo-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 10px 1fr 10px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding: 28px 0;
}

.photo-item {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: var(--r-sm);
  cursor: pointer;
  background: var(--border);
}

.photo-item img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
  -webkit-transition: -webkit-transform .4s var(--ease);
  transition: transform .4s var(--ease);
}

.photo-item:hover img {
  -webkit-transform: scale(1.06);
  transform: scale(1.06);
}

.photo-item-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}

.photo-item:hover .photo-item-overlay {
  background: rgba(0,0,0,.25);
}

.photo-zoom-icon {
  color: #fff;
  font-size: 1.6rem;
  opacity: 0;
  -webkit-transform: scale(.7);
  transform: scale(.7);
  -webkit-transition: opacity var(--dur) var(--ease), -webkit-transform var(--dur) var(--ease);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}

.photo-item:hover .photo-zoom-icon {
  opacity: 1;
  -webkit-transform: scale(1);
  transform: scale(1);
}

.photo-item--featured {
  grid-column: span 2;
  aspect-ratio: 16 / 9;
}

.photo-item-caption {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 6px 10px;
  background: rgba(0,0,0,.55);
  color: #fff;
  font-size: .78rem;
  line-height: 1.3;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -webkit-transition: -webkit-transform var(--dur) var(--ease);
  transition: transform var(--dur) var(--ease);
}
.photo-item:hover .photo-item-caption {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}

@media (max-width: 700px) {
  .gallery-grid { grid-template-columns: 1fr; gap: 14px; }
  .photo-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .photo-item--featured { grid-column: span 2; aspect-ratio: 16 / 9; }
}
@media (min-width: 701px) and (max-width: 900px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
  .photo-grid { grid-template-columns: repeat(2, 1fr); }
  .photo-item--featured { grid-column: span 2; }
}

/* ── LIGHTBOX ────────────────────────────────────────────── */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.93);
  z-index: 9000;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.lightbox.open { display: -webkit-box; display: -ms-flexbox; display: flex; }

.lightbox-img-wrap {
  position: relative;
  max-width: 90vw;
  max-height: 88vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.lightbox-img-wrap img {
  max-width: 100%;
  max-height: 88vh;
  -o-object-fit: contain;
  object-fit: contain;
  border-radius: var(--r-sm);
  display: block;
}

.lightbox-close {
  position: fixed;
  top: 18px;
  right: 22px;
  color: #fff;
  font-size: 1.8rem;
  background: rgba(255,255,255,.12);
  border: none;
  cursor: pointer;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.lightbox-close:hover { background: rgba(255,255,255,.25); }

.lightbox-prev,
.lightbox-next {
  position: fixed;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  color: #fff;
  font-size: 1.6rem;
  background: rgba(255,255,255,.1);
  border: none;
  cursor: pointer;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.lightbox-prev { left: 16px; }
.lightbox-next { right: 16px; }
.lightbox-prev:hover,
.lightbox-next:hover { background: rgba(255,255,255,.22); }

.lightbox-counter {
  position: fixed;
  bottom: 20px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  color: rgba(255,255,255,.7);
  font-size: .85rem;
  background: rgba(0,0,0,.4);
  padding: 5px 14px;
  border-radius: 20px;
}

/* ── AUTH PAGE ───────────────────────────────────────────── */
.auth-wrap {
  min-height: calc(100vh - 300px);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 48px 16px;
}
.auth-card {
  background: var(--surface);
  border-radius: 16px;
  box-shadow: var(--sh-lg);
  width: 100%;
  max-width: 480px;
  overflow: hidden;
}
.auth-card-header {
  background: linear-gradient(135deg, var(--p) 0%, var(--p-mid) 100%);
  padding: 28px 32px 22px;
  text-align: center;
  color: #fff;
}
.auth-card-header .auth-logo { font-size: 2.4rem; line-height: 1; margin-bottom: 8px; }
.auth-card-header h2 {
  font-family: var(--font-h);
  font-size: 1.45rem;
  font-weight: 700;
  margin: 0 0 4px;
}
.auth-card-header p { font-size: .82rem; color: rgba(255,255,255,.72); margin: 0; }

.auth-tabs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: var(--surface-2);
  border-bottom: 2px solid var(--border);
}
.auth-tab {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  padding: 14px 16px;
  background: none;
  border: none;
  font-family: var(--font-body);
  font-size: .9rem;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  -webkit-transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.auth-tab.active { color: var(--p); border-bottom-color: var(--p); background: var(--surface); }
.auth-tab:hover:not(.active) { color: var(--p-mid); background: var(--p-xlight); }

.auth-form { padding: 28px 32px 32px; }
.auth-form .form-group { margin-bottom: 18px; }
.auth-form .form-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 14px;
}
.auth-form .form-row .form-group { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; min-width: 0; }
.auth-form label {
  display: block;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
}
.auth-form label .req { color: var(--red); margin-left: 2px; }
.auth-form input[type="text"],
.auth-form input[type="tel"],
.auth-form input[type="password"] {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: .95rem;
  color: var(--text);
  background: var(--surface);
  -webkit-transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.auth-form input:focus {
  outline: none;
  border-color: var(--p-mid);
  box-shadow: 0 0 0 3px rgba(44,110,73,.15);
}
.telegram-verify-box {
  margin: 4px 0 18px;
  padding: 14px;
  border: 1px solid rgba(82,168,117,.28);
  border-radius: 8px;
  background: var(--p-xlight);
}
.telegram-verify-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}
.telegram-verify-title {
  font-weight: 700;
  font-size: .88rem;
  color: var(--text);
}
.telegram-verify-note {
  margin-top: 2px;
  font-size: .78rem;
  line-height: 1.35;
  color: var(--muted);
}
.telegram-verify-link {
  -ms-flex-negative: 0;
  flex-shrink: 0;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  min-height: 36px;
  padding: 0 12px;
  border-radius: 8px;
  background: var(--p);
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
}
.telegram-verify-link:hover { background: var(--p-mid); color: #fff; }
.telegram-code-group { margin-bottom: 0 !important; }
.pw-wrap {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.pw-wrap input[type="password"],
.pw-wrap input[type="text"] { padding-right: 44px !important; }
.btn-pw-toggle {
  position: absolute;
  right: 10px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 6px;
  color: var(--muted);
  font-size: 1.05rem;
  line-height: 1;
  -webkit-transition: color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease);
}
.btn-pw-toggle:hover { color: var(--p); }
.phone-input-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  overflow: hidden;
  background: var(--surface);
  -webkit-transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  transition: border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.phone-input-wrap:focus-within {
  border-color: var(--p-mid);
  box-shadow: 0 0 0 3px rgba(44,110,73,.15);
}
.phone-prefix {
  padding: 11px 10px 11px 14px;
  font-size: .95rem;
  font-weight: 600;
  color: var(--muted);
  background: var(--surface-2);
  border-right: 1.5px solid var(--border);
  white-space: nowrap;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  line-height: 1.4;
}
.phone-input-wrap input[type="tel"] {
  border: none !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  min-width: 0;
  padding-left: 10px !important;
  background: transparent;
}
.auth-error {
  background: var(--red-lt);
  border: 1px solid rgba(197,48,48,.25);
  border-radius: var(--r-sm);
  padding: 10px 14px;
  font-size: .85rem;
  color: var(--red);
  margin-bottom: 16px;
  display: none;
}
.auth-error.show { display: block; }
.btn-auth-submit {
  width: 100%;
  padding: 13px;
  background: var(--p);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: .3px;
  margin-top: 6px;
  -webkit-transition: background var(--dur) var(--ease), -webkit-transform var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.btn-auth-submit:hover {
  background: var(--p-mid);
  -webkit-transform: translateY(-1px);
  transform: translateY(-1px);
}
.auth-switch {
  text-align: center;
  margin-top: 16px;
  font-size: .84rem;
  color: var(--muted);
}
.auth-switch button {
  background: none;
  border: none;
  color: var(--p-mid);
  font-weight: 600;
  cursor: pointer;
  font-size: .84rem;
  text-decoration: underline;
  font-family: var(--font-body);
  padding: 0;
}
.auth-switch button:hover { color: var(--p); }

/* ── NAV USER AREA ────────────────────────────────────────── */
#navAuthLi {
  margin-left: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.btn-nav-login {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 5px;
  background: transparent;
  color: rgba(255,255,255,.9) !important;
  border: 1.5px solid rgba(255,255,255,.35);
  border-radius: 20px;
  padding: 5px 14px 5px 11px;
  font-size: .78rem !important;
  font-weight: 600 !important;
  letter-spacing: .2px !important;
  line-height: 1;
  white-space: nowrap;
  border-bottom: 1.5px solid rgba(255,255,255,.35) !important;
  -webkit-transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-nav-login:hover {
  background: rgba(255,255,255,.12) !important;
  border-color: rgba(255,255,255,.6) !important;
  color: #fff !important;
  border-bottom: 1.5px solid rgba(255,255,255,.6) !important;
}
.site-nav .nav-user-info {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  font-size: .82rem;
  color: rgba(255,255,255,.9);
  font-weight: 600;
  padding: 0 4px 0 10px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 180px;
  text-transform: none;
  letter-spacing: 0;
  border-bottom: none;
  line-height: 1;
}
.site-nav .nav-user-info:hover,
.site-nav .nav-user-info:focus {
  color: #fff;
  border-bottom: none;
}
.nav-user-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.btn-nav-logout {
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.2);
  border-radius: 6px;
  padding: 5px 12px;
  color: rgba(255,255,255,.8);
  font-size: .76rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  margin-left: 8px;
  margin-right: 16px;
  white-space: nowrap;
  -webkit-transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-nav-logout:hover { background: rgba(255,255,255,.22); color: #fff; }

@media (max-width: 700px) {
  #navAuthLi {
    margin-left: 0;
    border-top: 1px solid rgba(255,255,255,.08);
    padding-top: 8px;
    margin-top: 4px;
    width: 100%;
    display: block;
  }
  .btn-nav-login {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    padding: 13px 20px !important;
    border-radius: 0 !important;
    border: none !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
    background: rgba(255,255,255,.05) !important;
    color: rgba(255,255,255,.9) !important;
    font-size: .9rem !important;
  }
  .nav-user-info {
    display: block;
    padding: 12px 20px 4px;
    max-width: 100%;
    font-size: .9rem;
    color: rgba(255,255,255,.9);
  }
  .btn-nav-logout {
    display: block;
    width: calc(100% - 40px);
    margin: 4px 20px 12px;
    padding: 10px;
    text-align: center;
    font-size: .88rem;
  }
  .auth-form .form-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
  }
  .telegram-verify-row {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
  }
  .telegram-verify-link {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
  }
  .auth-form { padding: 20px 20px 28px; }
  .auth-card-header { padding: 22px 20px 18px; }
}

/* ── ADMIN PANEL ─────────────────────────────────────────── */
.admin-tabs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 4px;
  margin-bottom: 28px;
  border-bottom: 2px solid var(--border);
}
.admin-tab {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  font-family: var(--font-b);
  font-size: .95rem;
  font-weight: 600;
  color: var(--muted);
  padding: 10px 22px 13px;
  cursor: pointer;
  margin-bottom: -2px;
  -webkit-transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.admin-tab:hover { color: var(--p-mid); }
.admin-tab.active { color: var(--p); border-bottom-color: var(--p); }

.admin-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
}
.admin-list-wrap { -webkit-box-flex: 1; -ms-flex: 1 1 0%; flex: 1 1 0%; min-width: 0; }
.admin-form-wrap { width: 380px; -ms-flex-negative: 0; flex-shrink: 0; }

.admin-list-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 14px;
}
.admin-list-header h3 { font-size: 1.05rem; color: var(--text); }

.btn-admin-new {
  background: var(--p);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  font-family: var(--font-b);
  font-size: .875rem;
  font-weight: 600;
  padding: 7px 14px;
  cursor: pointer;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.btn-admin-new:hover { background: var(--p-mid); }

.admin-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 10px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r-sm);
  padding: 11px 14px;
  margin-bottom: 8px;
  -webkit-transition: border-color var(--dur) var(--ease);
  transition: border-color var(--dur) var(--ease);
}
.admin-row:hover { border-color: var(--p-light); }
.admin-row.selected { border-color: var(--p-mid); background: var(--p-xlight); }

.admin-row-info { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; min-width: 0; }
.admin-row-title {
  font-weight: 600;
  font-size: .875rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-row-meta { font-size: .78rem; color: var(--muted); margin-top: 2px; }

.admin-row-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 6px;
  -ms-flex-negative: 0;
  flex-shrink: 0;
}
.btn-admin-act {
  border: 1.5px solid var(--border);
  background: var(--surface);
  border-radius: var(--r-sm);
  width: 32px;
  height: 32px;
  font-size: .95rem;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background var(--dur), border-color var(--dur);
  transition: background var(--dur), border-color var(--dur);
}
.btn-admin-act.edit:hover  { background: var(--p-xlight); border-color: var(--p-light); }
.btn-admin-act.del:hover   { background: var(--red-lt);   border-color: var(--red); }
.btn-admin-act.photo:hover { background: var(--blue-lt);  border-color: var(--blue); }

.admin-form-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  margin-top: 4px;
}
.admin-form-actions .btn-submit { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }

.btn-cancel {
  background: var(--surface);
  border: 1.5px solid var(--border);
  color: var(--muted);
  font-family: var(--font-b);
  font-size: .875rem;
  font-weight: 500;
  padding: 10px 16px;
  border-radius: var(--r-sm);
  cursor: pointer;
  -webkit-transition: background var(--dur), border-color var(--dur);
  transition: background var(--dur), border-color var(--dur);
  white-space: nowrap;
}
.btn-cancel:hover { background: var(--surface-2); border-color: var(--muted); }

.admin-photo-grid {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 8px 1fr 8px 1fr;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.admin-photo-item {
  position: relative;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 1.5px solid var(--border);
}
.admin-photo-item img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
}
.admin-photo-cap {
  font-size: .72rem;
  color: var(--muted);
  padding: 4px 6px;
  background: var(--surface);
  border-top: 1px solid var(--border);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.admin-photo-del {
  position: absolute;
  top: 4px;
  right: 4px;
  background: rgba(255,255,255,.88);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  width: 26px;
  height: 26px;
  font-size: .8rem;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
}
.admin-photo-del:hover { background: var(--red-lt); border-color: var(--red); }

.admin-photo-cover {
  position: absolute;
  top: 4px;
  left: 4px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(180,180,180,.6);
  background: rgba(255,255,255,.88);
  color: #bbb;
  font-size: .85rem;
  line-height: 1;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.admin-photo-cover:hover { background: #fffbe6; color: #c8960c; border-color: #f4b731; }
.admin-photo-cover.is-cover {
  background: #f4b731;
  color: #fff;
  border-color: #c8960c;
}
.admin-photo-item.is-cover > img {
  outline: 3px solid #f4b731;
  outline-offset: -3px;
}

/* User form cover selection */
.ua-preview-thumb {
  cursor: pointer;
  -webkit-transition: outline var(--dur) var(--ease), opacity var(--dur) var(--ease);
  transition: outline var(--dur) var(--ease), opacity var(--dur) var(--ease);
  opacity: .75;
}
.ua-preview-thumb.is-cover {
  outline: 3px solid var(--p);
  outline-offset: 2px;
  opacity: 1;
}
.ua-cover-hint {
  width: 100%;
  font-size: .78rem;
  color: var(--muted);
  margin-bottom: 4px;
}

.admin-placeholder {
  text-align: center;
  padding: 40px 20px;
  color: var(--muted);
}
.admin-placeholder .empty-icon { font-size: 2.5rem; margin-bottom: 12px; }

.admin-loading { color: var(--muted); font-size: .875rem; padding: 8px 0; }

/* ── Marketplace ──────────────────────────────── */
.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  padding: 4px 0 8px;
}
.product-grid--home {
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
}
.product-grid--wide {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 22px;
}
.product-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-transition: box-shadow var(--dur) var(--ease), -webkit-transform var(--dur) var(--ease);
  transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.product-card:hover { box-shadow: var(--shadow-md); -webkit-transform: translateY(-2px); transform: translateY(-2px); }
.product-card-img {
  width: 100%;
  aspect-ratio: 4/3;
  -o-object-fit: cover;
  object-fit: cover;
  display: block;
  background: var(--bg-alt);
}
.product-card-img-placeholder {
  width: 100%;
  aspect-ratio: 4/3;
  background: var(--p-xlight);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 2.5rem;
}
.product-card-body {
  padding: 12px 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  gap: 6px;
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
}
.product-card-title {
  font-weight: 700;
  font-size: .95rem;
  color: var(--text);
  line-height: 1.3;
}
.product-card-desc {
  font-size: .8rem;
  color: var(--muted);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.product-card-price {
  font-size: .95rem;
  font-weight: 700;
  color: var(--p);
}
.product-card-price--free { color: var(--muted); font-weight: 500; font-style: italic; }
.product-card-seller {
  font-size: .76rem;
  color: var(--muted);
  margin-top: auto;
  padding-top: 4px;
}
.product-card-actions { margin-top: 10px; display: -webkit-box; display: -ms-flexbox; display: flex; gap: 6px; }
.btn-buy {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  background: var(--p);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  padding: 8px 10px;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
  white-space: nowrap;
}
.btn-buy:hover { background: var(--p-mid); }
.btn-buy:disabled { opacity: .6; cursor: default; }
.btn-buy--sent { background: #38a169; }
.btn-product-del {
  background: transparent;
  border: 1.5px solid var(--red);
  border-radius: 18px;
  padding: 6px 14px;
  font-size: .8rem;
  font-weight: 600;
  cursor: pointer;
  color: var(--red);
  -webkit-transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-product-del:hover { background: var(--red); color: #fff; }
.btn-product-del:disabled { opacity: .5; cursor: not-allowed; }
.product-card--own { border: 1.5px solid var(--p-light); }

/* Ride profile info (read-only block in ride form) */
.ride-profile-info {
  background: var(--p-xlight);
  border: 1px solid var(--p-light);
  border-radius: var(--r-sm);
  padding: 12px 14px;
  margin-bottom: 16px;
}
.ride-profile-info-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 6px 0;
  border-bottom: 1px dashed rgba(82,168,117,.35);
}
.ride-profile-info-row:last-of-type { border-bottom: none; }
.ride-profile-info-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  font-weight: 600;
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .5px;
}
.ride-profile-info-value {
  color: var(--text);
  font-weight: 700;
  font-size: .92rem;
  overflow-wrap: anywhere;
}
.ride-profile-info-hint {
  margin-top: 8px;
  font-size: .72rem;
  color: var(--muted);
  font-style: italic;
}

/* Ride owner actions */
.ride-card--own { border: 1.5px solid var(--p-light); }
.ride-card-owner-actions {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
}
.ride-card-own-tag {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--p);
  background: var(--p-xlight);
  padding: 3px 9px;
  border-radius: 10px;
}
.btn-ride-full {
  background: transparent;
  color: var(--red);
  border: 1.5px solid var(--red);
  border-radius: 18px;
  padding: 5px 12px;
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-b);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-ride-full:hover { background: var(--red); color: #fff; }
.btn-ride-full:disabled { opacity: .5; cursor: not-allowed; }
.product-card-own-tag {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--p);
  background: var(--p-xlight);
  padding: 3px 9px;
  border-radius: 10px;
  margin-right: 6px;
}

.product-card-img--clickable { cursor: zoom-in; }
.product-card-img--clickable:hover { opacity: .92; }

.product-seller-link {
  color: var(--p);
  text-decoration: none;
  font-weight: 600;
}
.product-seller-link:hover { opacity: .8; }

.shop-header-banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 16px;
  background: var(--p-xlight);
  border: 1px solid var(--p-light);
  border-radius: var(--r);
  padding: 16px 20px;
  margin-bottom: 20px;
}
.shop-header-icon { font-size: 2.2rem; line-height: 1; }
.shop-header-info { min-width: 0; }
.shop-header-name { font-size: 1.25rem; font-weight: 700; color: var(--p); margin: 0 0 4px; }
.shop-header-desc { font-size: .85rem; color: var(--muted); margin: 0 0 6px; }
.shop-header-meta { font-size: .8rem; color: var(--muted); }
.shop-header-back { color: var(--p); text-decoration: none; font-weight: 600; }
.shop-header-back:hover { opacity: .8; }

/* Shop sidebar quick links — separate visible block above the add-product form */
.shop-quick-links {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--sh-xs);
  margin-bottom: 16px;
}
.shop-settings { margin-bottom: 16px; }
.shop-settings > summary {
  cursor: pointer;
  font-weight: 600;
  font-size: .9rem;
  list-style: none;
  user-select: none;
  padding: 4px 0;
}
.shop-settings > summary::-webkit-details-marker { display: none; }
.shop-settings > summary::before {
  content: '▸';
  display: inline-block;
  margin-right: 6px;
  transition: transform .15s;
}
.shop-settings[open] > summary::before { transform: rotate(90deg); }
.shop-quick-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  text-decoration: none;
  color: var(--text);
  border-bottom: 1px solid var(--border);
  transition: background var(--dur) var(--ease);
}
.shop-quick-link:last-child { border-bottom: none; }
.shop-quick-link:hover,
.shop-quick-link:focus { background: var(--surface-2); color: var(--text); }
.shop-quick-link .sql-icon {
  font-size: 1.5rem;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--p-xlight);
  color: var(--p);
  border-radius: 50%;
  flex-shrink: 0;
}
.shop-quick-link--shop .sql-icon { background: var(--p-xlight); }
.shop-quick-link--requests .sql-icon { background: var(--accent-lt); color: var(--amber); }
.shop-quick-link--requests.has-unread .sql-icon {
  background: var(--accent);
  color: #fff;
  animation: pulse-accent 1.6s ease-in-out infinite;
}
@keyframes pulse-accent {
  0%, 100% { box-shadow: 0 0 0 0 rgba(233, 162, 39, 0); }
  50%      { box-shadow: 0 0 0 6px rgba(233, 162, 39, .25); }
}
.shop-quick-link .sql-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.shop-quick-link .sql-label {
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--muted);
}
.shop-quick-link .sql-name {
  font-size: .92rem;
  font-weight: 600;
  color: var(--text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.shop-quick-link .sql-arrow {
  font-size: 1.2rem;
  color: var(--muted);
  flex-shrink: 0;
  transition: transform var(--dur) var(--ease), color var(--dur) var(--ease);
}
.shop-quick-link:hover .sql-arrow { transform: translateX(3px); color: var(--p); }
.shop-quick-link .sql-badge { flex-shrink: 0; }

/* Shop sidebar (legacy — only used now if no shop yet) */
.shop-name-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  margin-bottom: 14px;
}
.shop-name-title {
  font-weight: 700;
  font-size: 1rem;
  color: var(--p);
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  -webkit-transition: color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease);
}
a.shop-name-title:hover,
a.shop-name-title:focus { color: var(--p-mid); }
.shop-my-products { margin: 14px 0 6px; }
.shop-my-products-header {
  font-size: .75rem;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: .5px;
  margin-bottom: 6px;
}
.shop-my-product-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 6px;
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
  font-size: .84rem;
}
.shop-my-product-row:last-child { border-bottom: none; }
.shop-my-product-title { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; color: var(--text); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.btn-product-del-side {
  background: none;
  border: none;
  cursor: pointer;
  font-size: .9rem;
  color: var(--muted);
  padding: 2px 4px;
  border-radius: var(--r-sm);
  -ms-flex-negative: 0;
  flex-shrink: 0;
  -webkit-transition: color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease);
}
.btn-product-del-side:hover { color: var(--red); }
/* Requests link in sidebar */
.shop-requests-link-wrap { margin-top: 16px; }
.btn-requests-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 8px;
  background: var(--p-xlight);
  border: 1px solid var(--p-light);
  border-radius: var(--r-sm);
  padding: 10px 14px;
  font-size: .88rem;
  font-weight: 600;
  color: var(--p);
  text-decoration: none;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.btn-requests-link:hover { background: var(--p-light); }

/* "Show more" button */
.btn-show-more {
  display: block;
  width: 100%;
  margin: 20px 0;
  padding: 12px 20px;
  background: transparent;
  border: 2px solid var(--p-light);
  border-radius: var(--r);
  color: var(--p);
  font-size: .95rem;
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  -webkit-transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.btn-show-more:hover { background: var(--p-xlight); border-color: var(--p); }
.btn-show-more--sm { margin: 8px 0; padding: 8px 14px; font-size: .85rem; }

/* Requests page cards */
.request-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px 20px;
  margin-bottom: 12px;
  position: relative;
}
.request-card--unread {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), var(--sh-xs);
}
.request-card-status {
  margin-bottom: 8px;
}
.request-unread-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .4px;
  color: var(--accent);
  background: var(--accent-lt);
  padding: 3px 9px;
  border-radius: 12px;
}
.request-viewed-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .72rem;
  font-weight: 600;
  color: var(--muted);
}
.request-card-actions {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px dashed var(--border);
}
.btn-mark-viewed,
.btn-mark-all {
  background: transparent;
  color: var(--p-mid);
  border: 1.5px solid var(--p-mid);
  border-radius: 18px;
  padding: 6px 14px;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-b);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-mark-viewed:hover,
.btn-mark-all:hover { background: var(--p-mid); color: #fff; }
.btn-mark-viewed:disabled,
.btn-mark-all:disabled { opacity: .5; cursor: not-allowed; }
.requests-toolbar {
  margin-bottom: 16px;
  display: flex;
  justify-content: flex-end;
}
.request-card-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
}
.request-card-product { font-weight: 700; font-size: .95rem; color: var(--p); }
.request-card-date { font-size: .8rem; color: var(--muted); }
.request-card-buyer { font-size: .9rem; font-weight: 600; color: var(--text); margin-bottom: 4px; }
.request-card-phone a { color: var(--p-mid); font-weight: 700; text-decoration: none; font-size: .9rem; }
.request-card-phone a:hover { opacity: .8; }
.request-card-msg { font-size: .85rem; color: var(--muted); font-style: italic; margin-top: 6px; padding-top: 6px; border-top: 1px solid var(--border); }
.request-card-product-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 12px;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.request-card-thumb {
  width: 64px;
  height: 64px;
  border-radius: var(--r-sm);
  -o-object-fit: cover;
  object-fit: cover;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  background: var(--bg-alt);
}
.request-card-thumb--empty {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  font-size: 1.5rem;
  background: var(--p-xlight);
}
.request-card-product-title { font-weight: 700; font-size: .95rem; color: var(--p); }

.product-card-requests {
  font-size: .75rem;
  color: var(--muted);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  gap: 3px;
}

/* Buy modal */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1000;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  padding: 16px;
}
.modal-overlay.is-open {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.modal-box {
  background: #fff;
  border-radius: var(--r);
  padding: 24px;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
}
.modal-box h3 { margin-bottom: 6px; font-size: 1.1rem; color: var(--p); }
.modal-product-name { font-size: .9rem; color: var(--muted); margin-bottom: 16px; }
.modal-actions { display: -webkit-box; display: -ms-flexbox; display: flex; gap: 10px; margin-top: 16px; }
.modal-actions .btn-submit { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; padding: 10px; font-size: .88rem; }
.modal-actions .btn-cancel { padding: 10px 16px; font-size: .88rem; }

/* ── Gallery submit bar ───────────────────────── */
#gallerySubmitWrap {
  background: #f0f7f3;
  border-bottom: 1px solid #d4e9dc;
  padding: 14px 0;
}
.gallery-submit-bar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 12px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.gallery-submit-hint {
  font-size: .9rem;
  color: var(--p);
  font-weight: 500;
}
.gallery-submit-toggle-btn {
  background: var(--p);
  color: #fff;
  border: none;
  border-radius: var(--r-xl);
  padding: 8px 18px;
  font-size: .85rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  white-space: nowrap;
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.gallery-submit-toggle-btn:hover { background: var(--p-mid); }
.gallery-submit-form { padding: 20px 0 8px; }
.gallery-submit-note {
  font-size: .82rem;
  color: var(--muted);
  margin: -8px 0 16px;
  padding: 10px 14px;
  background: #fffbe6;
  border-left: 3px solid #f4b731;
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
}
.file-upload-label--multi { gap: 8px; }
.ua-preview {
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
.ua-preview-thumb {
  width: 72px;
  height: 72px;
  border-radius: var(--r-sm);
  -o-object-fit: cover;
  object-fit: cover;
  border: 2px solid #d4e9dc;
}

/* ── Pending album moderation cards ──────────── */
.pending-badge {
  display: inline-block;
  background: #e53e3e;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  min-width: 20px;
  height: 20px;
  line-height: 20px;
  text-align: center;
  border-radius: 10px;
  padding: 0 6px;
  margin-left: 6px;
  vertical-align: middle;
}
.pending-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 16px 18px;
  margin-bottom: 12px;
}
.pending-card-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  gap: 12px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.pending-card-info { flex: 1; min-width: 0; }
.pending-card-title {
  font-weight: 700;
  font-size: 1rem;
  color: var(--text);
  margin: 0 0 4px;
}
.pending-card-meta {
  font-size: .8rem;
  color: var(--muted);
}
.pending-card-desc {
  font-size: .85rem;
  color: var(--text-soft);
  margin: 10px 0;
}
.feedback-card-message {
  background: var(--surface-2);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  line-height: 1.55;
  overflow-wrap: anywhere;
}
.pending-card-photos {
  display: -ms-flexbox;
  display: flex;
  gap: 6px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 12px 0;
}
.pending-card-thumb {
  width: 80px;
  height: 80px;
  border-radius: var(--r-sm);
  -o-object-fit: cover;
  object-fit: cover;
  border: 1px solid var(--border);
}
.pending-card-actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-top: 12px;
}
.btn-publish {
  background: var(--p);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  padding: 7px 16px;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  -webkit-transition: background var(--dur) var(--ease);
  transition: background var(--dur) var(--ease);
}
.btn-publish:hover { background: var(--p-mid); }
.btn-reject {
  background: transparent;
  color: #c53030;
  border: 1px solid #c53030;
  border-radius: var(--r-sm);
  padding: 7px 16px;
  font-size: .82rem;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-body);
  -webkit-transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.btn-reject:hover { background: #c53030; color: #fff; }

/* Admin link in nav */
.site-nav .btn-nav-admin {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,.45) !important;
  font-size: 1rem;
  line-height: 1;
  margin-right: 4px;
  padding: 0 6px;
  text-decoration: none !important;
  text-transform: none;
  letter-spacing: 0;
  border-bottom: none;
  -webkit-transition: color var(--dur) var(--ease);
  transition: color var(--dur) var(--ease);
}
.site-nav .btn-nav-admin:hover,
.site-nav .btn-nav-admin:focus {
  color: rgba(255,255,255,.9) !important;
  border-bottom: none;
}

@media (max-width: 700px) {
  .admin-layout {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .admin-list-wrap { order: 1; min-width: 0; max-width: 100%; }
  .admin-form-wrap { order: 2; width: 100%; min-width: 0; max-width: 100%; }
  .admin-photo-grid { -ms-grid-columns: 1fr 8px 1fr; grid-template-columns: repeat(2, 1fr); }
  .admin-tab { padding: 8px 14px 11px; font-size: .875rem; }
}

@media (max-width: 480px) {
  .admin-tabs {
    gap: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .admin-tabs::-webkit-scrollbar { display: none; }
  .admin-tab { padding: 8px 12px 11px; font-size: .82rem; white-space: nowrap; }

  .admin-list-header { -ms-flex-wrap: wrap; flex-wrap: wrap; gap: 8px; }
  .admin-list-header h3 { font-size: .95rem; }
  .btn-admin-new { font-size: .8rem; padding: 6px 11px; }

  .admin-row { padding: 9px 10px; gap: 8px; }
  .admin-row-title { font-size: .82rem; }
  .admin-row-meta {
    font-size: .72rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .btn-admin-act { width: 30px; height: 30px; font-size: .85rem; }

  .admin-photo-grid { -ms-grid-columns: 1fr 6px 1fr; grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .add-form { padding: 16px; }
}

/* ── DRAWER USER CARD (mobile only) ─────────────────────── */
.drawer-user-card { display: none; }
.drawer-admin-link { display: none; }

@media (max-width: 700px) {
  .drawer-user-card {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 16px 20px;
    background: rgba(255,255,255,.08);
    border-bottom: 1px solid rgba(255,255,255,.1);
    color: #fff !important;
    text-decoration: none !important;
    -webkit-transition: background var(--dur) var(--ease);
    transition: background var(--dur) var(--ease);
  }
  .drawer-user-card:hover,
  .drawer-user-card:focus { background: rgba(255,255,255,.14); }
  .drawer-user-card .drawer-user-arrow {
    margin-left: auto;
    font-size: 1.4rem;
    opacity: .6;
  }
  .drawer-avatar {
    width: 44px !important;
    height: 44px !important;
    font-size: 1.1rem !important;
    border: 2px solid rgba(255,255,255,.4);
  }
  .drawer-user-name {
    color: #fff;
    font-size: 1rem;
    font-weight: 700;
  }
  .drawer-admin-link {
    display: block;
    padding: 13px 20px;
    color: rgba(255,255,255,.85) !important;
    font-size: .9rem;
    font-weight: 600;
    text-decoration: none !important;
    background: rgba(255,255,255,.04);
    border-bottom: 1px solid rgba(255,255,255,.08);
  }
  .drawer-admin-link:hover { background: rgba(255,255,255,.1); color: #fff !important; }
  .drawer-admin-link span { margin-left: 6px; }
  /* Hide duplicate user info inside navAuthLi on mobile */
  #navAuthLi .nav-user-info { display: none; }
  /* Hide desktop btn-nav-admin in drawer on mobile (replaced by drawer-admin-link) */
  #navAuthLi .btn-nav-admin { display: none; }
}

/* ── NAV AVATAR ─────────────────────────────────────────── */
.nav-avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(255,255,255,.5);
  flex-shrink: 0;
}
.nav-avatar--initials {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.25);
  color: #fff;
  font-size: .7rem;
  font-weight: 700;
}

/* ── PROFILE PAGE ────────────────────────────────────────── */
#profilePanel { padding-top: 28px; }

.profile-layout {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 28px;
  align-items: flex-start;
}

.profile-sidebar {
  width: 220px;
  flex-shrink: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  background: #fff;
  border: 1px solid #e3e8e3;
  border-radius: 14px;
  padding: 28px 20px 24px;
  box-shadow: 0 2px 10px rgba(0,0,0,.06);
  position: sticky;
  top: 20px;
}

.profile-avatar-wrap {
  position: relative;
}

.profile-avatar {
  position: relative;
  width: 110px;
  height: 110px;
  border-radius: 50%;
  background: #2d6a4f;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  border: 3px solid #e3e8e3;
  box-shadow: 0 3px 12px rgba(0,0,0,.12);
}

.profile-avatar.is-pending::after {
  content: 'На модерації';
  position: absolute;
  left: 50%;
  bottom: 4px;
  transform: translateX(-50%);
  background: rgba(26, 71, 49, .88);
  color: #fff;
  border-radius: 10px;
  padding: 2px 7px;
  font-size: .62rem;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}

.profile-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.profile-avatar span {
  font-size: 2.4rem;
  font-weight: 700;
  color: #fff;
  line-height: 1;
}

.profile-avatar-btn {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #2d6a4f;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  cursor: pointer;
  border: 2px solid #fff;
  box-shadow: 0 2px 6px rgba(0,0,0,.2);
  transition: background .2s;
}
.profile-avatar-btn:hover { background: #1A4731; }
.profile-avatar-btn.is-loading { pointer-events: none; opacity: .6; }

.profile-avatar-overlay {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, .55);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
  z-index: 2;
}
.profile-avatar-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid rgba(255, 255, 255, .25);
  border-top-color: #fff;
  border-radius: 50%;
  animation: profile-avatar-spin .9s linear infinite;
}
@keyframes profile-avatar-spin {
  to { transform: rotate(360deg); }
}
.profile-avatar.is-uploading { position: relative; }

.profile-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: #1a2e1a;
  text-align: center;
}

.profile-nickname {
  font-size: .85rem;
  color: #5c7a5c;
  text-align: center;
}

.profile-content {
  flex: 1;
  min-width: 0;
}

.profile-tabs {
  margin-bottom: 18px;
}

.profile-tab-section .add-form {
  margin-top: 0;
}

/* ── Activity log rows ── */
.profile-log-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 0;
  border-bottom: 1px solid #eef2ee;
  flex-wrap: wrap;
}
.profile-log-row:last-child { border-bottom: none; }

.profile-log-action {
  font-size: .82rem;
  font-weight: 600;
  color: #2d6a4f;
  white-space: nowrap;
}

.profile-log-desc {
  flex: 1;
  font-size: .86rem;
  color: #3a4a3a;
}

.profile-log-date {
  font-size: .78rem;
  color: #888;
  white-space: nowrap;
}

@media (max-width: 700px) {
  .profile-log-row {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "action date"
      "desc   desc";
    gap: 4px 10px;
    padding: 12px 0;
    align-items: center;
    flex-wrap: nowrap;
  }
  .profile-log-action {
    grid-area: action;
    font-size: .88rem;
    line-height: 1.25;
    white-space: normal;
  }
  .profile-log-date {
    grid-area: date;
    font-size: .72rem;
    color: var(--muted);
    align-self: start;
  }
  .profile-log-desc {
    grid-area: desc;
    font-size: .82rem;
    color: var(--muted);
    line-height: 1.45;
    flex: none;
    word-break: break-word;
  }
}

/* ── Profile responsive ── */
@media (max-width: 700px) {
  #profilePanel { padding-top: 20px; }
  .profile-layout { flex-direction: column; }
  .profile-sidebar {
    width: 100%;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    padding: 16px;
    position: static;
    text-align: left;
  }
  .profile-avatar { width: 70px; height: 70px; }
  .profile-avatar span { font-size: 1.6rem; }
  .profile-name, .profile-nickname { text-align: left; }

  /* keep form within viewport */
  .profile-content { width: 100%; max-width: 100%; min-width: 0; }
  .profile-tab-section { min-width: 0; }
  .profile-tab-section .add-form { padding: 18px 14px; }
  .profile-tab-section .form-row {
    flex-direction: column;
    gap: 0;
  }
  .profile-tab-section .form-row .form-group { width: 100%; }
  .profile-tab-section input,
  .profile-tab-section select,
  .profile-tab-section textarea {
    max-width: 100%;
    box-sizing: border-box;
  }
  .profile-tabs {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    flex-wrap: nowrap;
  }
  .profile-tabs::-webkit-scrollbar { display: none; }
  .profile-tabs .admin-tab { white-space: nowrap; flex-shrink: 0; }
}

/* ── DETAIL PAGES (product / announcement / ride) ─────────── */
.product-detail,
.announcement-detail,
.ride-detail {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 24px;
  box-shadow: var(--sh-xs);
}
.product-detail-img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  border-radius: var(--r);
  margin-bottom: 20px;
}
.product-detail-img--placeholder {
  height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 4rem;
  color: var(--muted);
  background: #f4f4f4;
}
.product-detail-body h1 { font-size: 1.6rem; margin: 0 0 12px; line-height: 1.25; }
.product-detail-price {
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--accent, #1A4731);
  margin-bottom: 16px;
}
.product-detail-desc {
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 20px;
  white-space: pre-wrap;
}
.product-detail-seller {
  padding: 12px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  margin-bottom: 20px;
  font-size: .95rem;
}
.product-detail-actions { display: flex; gap: 10px; flex-wrap: wrap; }

.announcement-detail h1 { font-size: 1.6rem; margin: 12px 0 16px; line-height: 1.25; }
.announcement-detail-meta {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: .85rem;
  color: var(--muted);
  margin-bottom: 4px;
}
.announcement-detail-img {
  width: 100%;
  max-height: 460px;
  object-fit: cover;
  border-radius: var(--r);
  margin: 16px 0;
}
.announcement-detail-body {
  font-size: 1rem;
  line-height: 1.65;
  white-space: pre-wrap;
  margin-bottom: 20px;
}
.announcement-detail-contact {
  padding: 12px 16px;
  background: #f9f7ee;
  border-left: 4px solid var(--accent, #1A4731);
  border-radius: 6px;
  font-size: .95rem;
}

.ride-detail h1 { font-size: 1.5rem; margin: 0 0 16px; }
.ride-detail-meta {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  padding: 16px 0;
  border-top: 1px solid var(--border);
  font-size: .95rem;
}
.ride-detail-meta a { color: var(--accent, #1A4731); text-decoration: none; }
.ride-detail-meta a:hover { text-decoration: underline; }
.ride-detail-comment {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.ride-detail-comment h3 { font-size: 1rem; margin: 0 0 8px; }
.ride-detail-comment p { line-height: 1.6; white-space: pre-wrap; margin: 0; }

.product-card,
.ann-card,
.ride-card {
  cursor: pointer;
  transition: transform .12s, box-shadow .12s;
}
.product-card:hover,
.ann-card:hover,
.ride-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-sm, 0 6px 14px rgba(0,0,0,.08));
}

/* ── PENDING / MODERATION VISUAL CUES ────────────────────── */
.product-card { position: relative; }
.product-card--pending { opacity: .85; }
.product-card--pending .product-card-img,
.product-card--pending .product-card-img-placeholder {
  filter: grayscale(.4) saturate(.8);
}
.product-card-pending-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 3;
  background: rgba(255, 173, 0, .95);
  color: #2a1500;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .3px;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 999px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, .15);
  pointer-events: none;
}

.product-detail-pending {
  margin: 12px 0 16px;
  padding: 12px 14px;
  background: rgba(255, 173, 0, .15);
  border-left: 4px solid #f5a623;
  border-radius: 6px;
  font-size: .9rem;
  color: #5a3a00;
}

/* ── PRIMARY INLINE CTA BUTTON (link-friendly) ───────────── */
.btn-cta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: linear-gradient(135deg, var(--p-mid) 0%, var(--p) 100%);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: .9rem;
  letter-spacing: .3px;
  padding: 10px 22px;
  border-radius: var(--r-xl);
  border: none;
  box-shadow: 0 4px 14px rgba(44,110,73,.35);
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
}
.btn-cta:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 18px rgba(44,110,73,.45);
  color: #fff;
}
.btn-cta:active { transform: translateY(0); }

/* ── MODERATION SUB-TABS ─────────────────────────────────── */
.mod-subtabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 8px;
  margin-bottom: 16px;
}
.mod-subtab {
  background: none;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 6px 14px;
  cursor: pointer;
  font-size: .85rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all .15s;
}
.mod-subtab:hover { background: #f4f4f0; }
.mod-subtab.active {
  background: var(--accent, #1A4731);
  border-color: var(--accent, #1A4731);
  color: #fff;
}
.mod-subtab .pending-badge { background: rgba(0,0,0,.15); color: inherit; }
.mod-subtab.active .pending-badge { background: rgba(255,255,255,.25); }

.mod-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: var(--r);
  margin-bottom: 14px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: var(--sh-xs);
}
.mod-card-img {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  background: #f4f4f0;
  flex-shrink: 0;
}
.mod-card-body {
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
  flex: 1 1 auto;
}
.mod-card-meta { font-size: .8rem; color: var(--muted); }
.mod-card-headline { margin: 0; font-size: 1.05rem; line-height: 1.3; word-break: break-word; }
.mod-card-text {
  margin: 0;
  font-size: .9rem;
  line-height: 1.5;
  color: #333;
  max-height: 6em;
  overflow: hidden;
  position: relative;
  word-break: break-word;
}
.mod-card-footer { font-size: .85rem; color: var(--muted); }
.mod-card-author { font-size: .8rem; color: var(--muted); padding-top: 4px; border-top: 1px dashed var(--border); }
.mod-card-actions { display: flex; gap: 8px; flex-wrap: wrap; padding-top: 8px; margin-top: auto; }
.mod-card-actions .btn-submit,
.mod-card-actions .btn-cancel {
  flex: 1 1 auto;
  font-size: .85rem;
  padding: 8px 12px;
}

/* Desktop layout: image on left, body on right (horizontal list look) */
@media (min-width: 768px) {
  .mod-card { flex-direction: row; align-items: stretch; }
  .mod-card-img {
    width: 220px;
    height: auto;
    max-height: none;
    align-self: stretch;
  }
  .mod-card-body { padding: 16px 20px; }
  .mod-card-actions { max-width: 360px; }
}

/* Wide screens: 2 cards per row in grid */
@media (min-width: 1280px) {
  .mod-subsection {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    align-items: start;
  }
  .mod-subsection > #adminPendingList,
  .mod-subsection > [id^="modList"] {
    display: contents;
  }
  .mod-subsection .mod-card { margin-bottom: 0; }
  .mod-subsection .empty-state { grid-column: 1 / -1; }
  .mod-card-img { width: 180px; }
}

/* ── RATING TAB ──────────────────────────────────────────── */
.rating-total {
  text-align: center;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.rating-total-num {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--accent, #1A4731);
  line-height: 1;
}
.rating-total-label { font-size: .85rem; color: var(--muted); margin-top: 4px; }

.rating-breakdown { display: flex; flex-direction: column; gap: 8px; }
.rating-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  background: #f8f8f4;
  border-radius: 6px;
  font-size: .9rem;
}
.rating-row strong { font-weight: 600; }

.rating-checks { display: flex; flex-direction: column; gap: 8px; }
.rating-status {
  display: flex;
  flex-direction: column;
  padding: 10px 12px;
  background: #f8f8f4;
  border-left: 3px solid var(--border);
  border-radius: 6px;
  font-size: .9rem;
}
.rating-status:has(span:contains("✅")),
.rating-status:first-of-type { border-left-color: var(--accent, #1A4731); }
.rating-status small { color: var(--muted); margin-top: 2px; font-size: .8rem; }

/* ── PRINT ───────────────────────────────────────────────── */
@media print {
  .site-nav, .news-ticker, .site-footer, .btn-submit,
  .add-form, .ann-filters, .rides-form-wrap { display: none !important; }
  body { background: #fff; }
  .featured-article, .article-card, .ann-card, .ride-card { box-shadow: none; border: 1px solid #ccc; }
}
