html { font-size: 17px; }
* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: #111009; color: #c9bfb0; font-family: 'Inter', sans-serif; font-size: 16px; }
header { background: #0e0d0b; border-bottom: 1px solid #3a3228; padding: 14px 24px; display: flex; align-items: center; gap: 14px; }
.logo { font-family: 'Bebas Neue', sans-serif; font-size: 28px; color: #d4a96a; letter-spacing: 3px; }
.logo span { color: #8a7a66; }
nav { margin-left: auto; display: flex; gap: 20px; }
nav a { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #5a5040; text-decoration: none; letter-spacing: 2px; text-transform: uppercase; }
nav a.active { color: #d4a96a; }

.hero { background: #0e0d0b; padding: 28px 24px 22px; border-bottom: 1px solid #2a2420; }
.hero h1 { font-family: 'Bebas Neue', sans-serif; font-size: 36px; color: #e8d5b8; margin-bottom: 6px; letter-spacing: 2px; }
.hero p { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #5a5040; margin-bottom: 18px; letter-spacing: 1px; }

.submit-form { display: flex; flex-direction: column; gap: 8px; max-width: 600px; }
.submit-form input, .submit-form textarea, .submit-form select { background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; padding: 10px 14px; color: #c9bfb0; font-size: 15px; font-family: 'Inter', sans-serif; outline: none; }
.submit-form textarea { resize: vertical; min-height: 70px; }
.submit-form button { background: #d4a96a; color: #0e0d0b; border: none; border-radius: 2px; padding: 10px 22px; font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 2px; cursor: pointer; align-self: flex-start; }

.filters { display: flex; gap: 6px; padding: 16px 24px; flex-wrap: wrap; border-bottom: 1px solid #1a1712; }
.tag { background: #1a1712; border: 1px solid #2a2420; border-radius: 2px; padding: 4px 12px; font-family: 'IBM Plex Mono', monospace; font-size: 12px; color: #5a5040; text-decoration: none; letter-spacing: 1px; text-transform: uppercase; }
.tag.active { border-color: #d4a96a; color: #d4a96a; }

.feed { padding: 20px 24px; }
.card { background: #161410; border: 1px solid #2a2420; border-left: 3px solid #3a3228; border-radius: 2px; padding: 16px; margin-bottom: 8px; display: flex; gap: 16px; }
.card:hover { border-left-color: #d4a96a; }

.vote { display: flex; flex-direction: column; align-items: center; gap: 4px; min-width: 44px; }
.vote-btn { background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; width: 36px; height: 26px; color: #d4a96a; font-size: 14px; display: flex; align-items: center; justify-content: center; text-decoration: none; }
.vote-count { font-family: 'Bebas Neue', sans-serif; font-size: 24px; color: #e8d5b8; line-height: 1; }
.vote-label { font-family: 'IBM Plex Mono', monospace; font-size: 11px; color: #3a3228; letter-spacing: 1px; text-transform: uppercase; }

.card-body { flex: 1; }
.card-title { font-family: 'Bebas Neue', sans-serif; font-size: 19px; color: #e8d5b8; margin-bottom: 4px; letter-spacing: 1px; text-decoration: none; display: block; }
.card-title:hover { color: #d4a96a; }
.card-desc { font-size: 14px; color: #6a5f50; margin-bottom: 10px; line-height: 1.5; }
.card-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }

.status { font-family: 'IBM Plex Mono', monospace; font-size: 11px; padding: 3px 8px; border-radius: 2px; text-transform: uppercase; letter-spacing: 1px; }
.status.requested { background: #1a1712; border: 1px solid #3a3228; color: #5a5040; }
.status.planned { background: #12181a; border: 1px solid #1a4a5a; color: #4a8fa8; }
.status.added { background: #121a14; border: 1px solid #1a4a28; color: #4a8f60; }
.category { font-family: 'IBM Plex Mono', monospace; font-size: 11px; color: #3a3228; text-transform: uppercase; letter-spacing: 1px; }
.divider { width: 1px; height: 10px; background: #2a2420; }

.status-form { display: flex; gap: 8px; align-items: center; }
.status-form select { background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; padding: 6px 10px; color: #c9bfb0; font-family: 'IBM Plex Mono', monospace; font-size: 13px; outline: none; cursor: pointer; }
.status-form button { background: #d4a96a; color: #0e0d0b; border: none; border-radius: 2px; padding: 6px 16px; font-family: 'Bebas Neue', sans-serif; font-size: 16px; letter-spacing: 2px; cursor: pointer; }

.hp-hero { display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; min-height: 400px; background: #0e0d0b; border-bottom: 1px solid #2a2420; background-image: repeating-linear-gradient(0deg, transparent, transparent 40px, #1a1712 40px, #1a1712 41px), repeating-linear-gradient(90deg, transparent, transparent 40px, #1a1712 40px, #1a1712 41px); }
.hp-hero-inner { flex: 1; text-align: center; z-index: 1; padding: 64px 80px 56px; }
.hp-eyebrow { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #d4a96a; letter-spacing: 3px; text-transform: uppercase; margin-bottom: 16px; }
.hp-hero h1 { font-family: 'Bebas Neue', sans-serif; font-size: 58px; color: #e8d5b8; letter-spacing: 3px; line-height: 1; margin-bottom: 16px; }
.hp-hero h1 span { color: #d4a96a; }
.hp-hero p { font-size: 16px; color: #6a5f50; max-width: 480px; margin: 0 auto 32px; line-height: 1.6; }
.hp-cta { display: inline-flex; gap: 12px; }
.hp-btn { background: #d4a96a; color: #0e0d0b; border: none; border-radius: 2px; padding: 12px 28px; font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 2px; cursor: pointer; text-decoration: none; display: inline-block; }
.hp-btn-outline { background: transparent; color: #d4a96a; border: 1px solid #d4a96a; border-radius: 2px; padding: 12px 28px; font-family: 'Bebas Neue', sans-serif; font-size: 20px; letter-spacing: 2px; cursor: pointer; text-decoration: none; display: inline-block; }
.hp-side { display: flex; align-items: center; justify-content: center; width: 300px; flex-shrink: 0; margin: 0 40px; }
.side-hero { width: 100%; height: 600px; object-fit: cover; object-position: center; border: 1px solid #2a2420; border-radius: 2px; opacity: 0; filter: brightness(0.5) sepia(0.3); transition: opacity 1s ease, transform 1s ease, filter 0.4s ease; }
.side-hero:hover { filter: brightness(1) sepia(0); border-color: #d4a96a; }
.left-side .side-hero { transform: translateX(-40px); }
.right-side .side-hero { transform: translateX(40px); }
.side-hero.visible { opacity: 1; transform: translateX(0); }

.hp-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: #2a2420; border-top: 1px solid #2a2420; border-bottom: 1px solid #2a2420; }
.hp-stat { background: #0e0d0b; padding: 28px 24px; text-align: center; }
.hp-stat-num { font-family: 'Bebas Neue', sans-serif; font-size: 48px; color: #d4a96a; line-height: 1; margin-bottom: 4px; }
.hp-stat-label { font-family: 'IBM Plex Mono', monospace; font-size: 12px; color: #5a5040; text-transform: uppercase; letter-spacing: 2px; }
.hp-top { background: #111009; padding: 32px 24px; }
.hp-top-label { font-family: 'IBM Plex Mono', monospace; font-size: 12px; color: #5a5040; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 16px; }
.hp-top-card { background: #161410; border: 1px solid #2a2420; border-left: 3px solid #3a3228; border-radius: 2px; padding: 16px; display: flex; gap: 16px; align-items: center; margin-bottom: 8px; }
.hp-top-card.highlighted { border-left-color: #d4a96a; }
.hp-top-rank { font-family: 'Bebas Neue', sans-serif; font-size: 32px; color: #3a3228; min-width: 32px; }
.hp-top-body { flex: 1; }
.hp-top-title { font-family: 'Bebas Neue', sans-serif; font-size: 18px; color: #e8d5b8; letter-spacing: 1px; margin-bottom: 4px; }
.hp-top-votes { font-family: 'IBM Plex Mono', monospace; font-size: 12px; color: #d4a96a; }

.toolbar { padding: 14px 24px; background: #0e0d0b; border-bottom: 1px solid #2a2420; }
.search-form { display: flex; gap: 8px; flex-wrap: wrap; }
.search-input { flex: 1; min-width: 200px; background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; padding: 8px 12px; color: #c9bfb0; font-family: 'IBM Plex Mono', monospace; font-size: 14px; outline: none; }
.sort-select { background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; padding: 8px 12px; color: #c9bfb0; font-family: 'IBM Plex Mono', monospace; font-size: 14px; outline: none; cursor: pointer; }
.search-btn { background: #d4a96a; color: #0e0d0b; border: none; border-radius: 2px; padding: 8px 18px; font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; cursor: pointer; }
.form-row { display: flex; gap: 8px; }

.comment-count { font-family: 'IBM Plex Mono', monospace; font-size: 11px; color: #5a5040; text-decoration: none; text-transform: uppercase; letter-spacing: 1px; }
.comment-count:hover { color: #d4a96a; }
.feature-detail { padding: 24px; max-width: 800px; }
.back-link { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #5a5040; text-decoration: none; letter-spacing: 1px; }
.back-link:hover { color: #d4a96a; }
.comments-section { margin-top: 28px; }
.comments-label { font-family: 'IBM Plex Mono', monospace; font-size: 12px; color: #5a5040; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 14px; }
.comment-form { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.comment-form textarea { background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; padding: 10px 14px; color: #c9bfb0; font-family: 'Inter', sans-serif; font-size: 15px; outline: none; resize: vertical; min-height: 80px; }
.comment-form button { background: #d4a96a; color: #0e0d0b; border: none; border-radius: 2px; padding: 8px 20px; font-family: 'Bebas Neue', sans-serif; font-size: 17px; letter-spacing: 2px; cursor: pointer; align-self: flex-start; }
.comment-card { background: #161410; border: 1px solid #2a2420; border-radius: 2px; padding: 12px 16px; margin-bottom: 8px; }
.comment-meta { display: flex; gap: 12px; margin-bottom: 6px; }
.comment-user { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #d4a96a; }
.comment-time { font-family: 'IBM Plex Mono', monospace; font-size: 12px; color: #3a3228; }
.comment-body { font-size: 15px; color: #8a7a66; line-height: 1.5; }
.login-prompt { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #5a5040; margin-bottom: 16px; }
.login-prompt a { color: #d4a96a; text-decoration: none; }

.auth-page { display: flex; justify-content: center; padding: 60px 24px; }
.auth-card { background: #161410; border: 1px solid #2a2420; border-radius: 2px; padding: 32px; width: 100%; max-width: 400px; }
.auth-card h1 { font-family: 'Bebas Neue', sans-serif; font-size: 32px; color: #e8d5b8; letter-spacing: 2px; margin-bottom: 20px; }
.auth-form { display: flex; flex-direction: column; gap: 10px; }
.auth-form input { background: #1a1712; border: 1px solid #3a3228; border-radius: 2px; padding: 10px 14px; color: #c9bfb0; font-family: 'Inter', sans-serif; font-size: 15px; outline: none; }
.auth-form input[type="password"], .auth-form input[type="text"] { padding-right: 56px; }
.auth-form button { background: #d4a96a; color: #0e0d0b; border: none; border-radius: 2px; padding: 10px; font-family: 'Bebas Neue', sans-serif; font-size: 18px; letter-spacing: 2px; cursor: pointer; margin-top: 4px; }
.auth-error { background: #1a1212; border: 1px solid #4a2020; border-radius: 2px; padding: 8px 12px; font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #8f4a4a; margin-bottom: 14px; }
.auth-switch { font-family: 'IBM Plex Mono', monospace; font-size: 13px; color: #5a5040; margin-top: 14px; }
.auth-switch a { color: #d4a96a; text-decoration: none; }

.admin-actions { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 10px; }
.admin-btn-edit { font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 1px; color: #d4a96a; border: 1px solid #d4a96a; border-radius: 2px; padding: 5px 14px; text-decoration: none; }
.admin-btn-delete { font-family: 'Bebas Neue', sans-serif; font-size: 15px; letter-spacing: 1px; color: #8f4a4a; border: 1px solid #4a2020; border-radius: 2px; padding: 5px 14px; background: transparent; cursor: pointer; }