/* ============================================================
   LA MIDNIGHT BRUTALIST - RPG Dating Stylesheet
   Autor: Rogue RPG BB

   Brutalistisches Design für RPG-Dating-Modul:
   - Keine abgerundeten Ecken (border-radius: 0)
   - CSS-Variablen für Farben und Abstände
   - Dunkles Farbschema mit Orange-Akzenten
   ============================================================ */

/* --- Wrapper und Header --- */
.rpgdating-wrapper { max-width: 900px; margin: var(--space-lg, 20px) auto; padding: 0 var(--space-lg, 15px); }
.rpgdating-header { text-align: center; padding: var(--space-2xl, 30px) 0 var(--space-lg, 20px); }
.rpgdating-header h1 { font-size: 28px; margin: 0 0 var(--space-xs, 5px); }
.rpgdating-subtitle { color: var(--text-muted, #888); font-size: 14px; margin: 0; }

/* --- Navigation --- */
.rpgdating-nav-link { font-weight: bold; }
.rpgdating-menu { display: flex; justify-content: center; gap: var(--space-sm, 10px); padding: var(--space-lg, 15px) 0; border-bottom: 1px solid var(--border, #ddd); margin-bottom: var(--space-lg, 20px); flex-wrap: wrap; }
.rpgdating-menu a { padding: var(--space-sm, 8px) var(--space-md, 18px); border-radius: 0; background: var(--bg-alt, #f0f0f0); color: var(--text, #333); text-decoration: none; font-size: 14px; transition: background 0.2s, color 0.2s; }
.rpgdating-menu a:hover, .rpgdating-menu a.active { background: var(--accent, #e74c3c); color: var(--bg, #fff); }

/* --- Karten --- */
.rpgdating-card { background: var(--bg-card, #fff); border: 1px solid var(--border, #ddd); border-radius: 0; padding: var(--space-xl, 25px); margin-bottom: var(--space-lg, 20px); box-shadow: 0 2px 8px rgba(0,0,0,0.06); }

/* --- Abschnitte --- */
.rpgdating-section { margin-bottom: var(--space-lg, 20px); }
.rpgdating-section h3 { font-size: 16px; margin: 0 0 var(--space-sm, 10px); padding-bottom: var(--space-xs, 5px); border-bottom: 1px solid var(--border, #eee); }
.rpgdating-hint { font-size: 12px; color: var(--text-muted, #999); margin: 0 0 var(--space-sm, 10px); }

/* --- Eingabefelder --- */
.rpgdating-textarea { width: 100%; min-height: 100px; padding: var(--space-sm, 10px); border: 1px solid var(--border, #ddd); border-radius: 0; font-size: 14px; resize: vertical; box-sizing: border-box; }
.rpgdating-input { width: 100%; padding: var(--space-sm, 8px) var(--space-sm, 10px); border: 1px solid var(--border, #ddd); border-radius: 0; font-size: 14px; box-sizing: border-box; }
.rpgdating-select { width: 100%; padding: var(--space-sm, 8px) var(--space-sm, 10px); border: 1px solid var(--border, #ddd); border-radius: 0; font-size: 14px; }

/* --- Fotos --- */
.rpgdating-photo-slot { margin-bottom: var(--space-sm, 10px); }
.rpgdating-photo-preview { width: 80px; height: 80px; object-fit: cover; border-radius: 0; margin-top: var(--space-xs, 5px); border: 1px solid var(--border, #ddd); }

/* --- Feldgruppen --- */
.rpgdating-field-group { margin-bottom: var(--space-lg, 15px); }
.rpgdating-label { display: block; font-weight: bold; font-size: 14px; margin-bottom: var(--space-xs, 4px); }
.rpgdating-field-description { font-size: 12px; color: var(--text-muted, #888); margin-bottom: var(--space-xs, 4px); }
.rpgdating-required { color: var(--accent, #e74c3c); }
.rpgdating-fields-display { display: flex; flex-wrap: wrap; gap: var(--space-sm, 10px); margin-top: var(--space-lg, 15px); }
.rpgdating-field-item { background: var(--bg-alt, #f8f8f8); padding: var(--space-xs, 6px) var(--space-sm, 12px); border-radius: 0; font-size: 13px; }
.rpgdating-field-label { font-weight: bold; margin-right: var(--space-xs, 4px); }
.rpgdating-field-label::after { content: ":"; }

/* --- Swipe-Karten --- */
.rpgdating-discover { max-width: 450px; margin: 0 auto; }
.rpgdating-swipe-area { position: relative; min-height: 400px; }
.rpgdating-swipe-card { background: var(--bg-card, #fff); border: 1px solid var(--border, #ddd); border-radius: 0; overflow: hidden; box-shadow: 0 4px 15px rgba(0,0,0,0.1); transition: transform 0.3s, opacity 0.3s; }
.rpgdating-swipe-card.rpgdating-swiped-left { transform: translateX(-150%) rotate(-15deg); opacity: 0; }
.rpgdating-swipe-card.rpgdating-swiped-right { transform: translateX(150%) rotate(15deg); opacity: 0; }
.rpgdating-card-photo { width: 100%; height: var(--rpgdating-card-height, 350px); background-size: cover; background-position: center; position: relative; }
.rpgdating-card-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: var(--space-lg, 20px) var(--space-md, 15px) var(--space-sm, 10px); background: linear-gradient(transparent, rgba(0,0,0,0.7)); color: var(--text, #fff); }
.rpgdating-card-name { margin: 0 0 var(--space-xs, 4px); font-size: 22px; }
.rpgdating-card-bio { padding: var(--space-sm, 12px) var(--space-md, 15px); font-size: 14px; color: var(--text-dim, #555); min-height: 40px; }
.rpgdating-card-actions { display: flex; justify-content: center; gap: var(--space-xl, 20px); padding: var(--space-sm, 10px) var(--space-md, 15px) var(--space-lg, 20px); }
.rpgdating-card-field { display: inline-block; background: rgba(255,255,255,0.2); padding: var(--space-xs, 2px) var(--space-sm, 8px); border-radius: 0; font-size: 12px; margin-top: var(--space-xs, 4px); margin-right: var(--space-xs, 4px); }
.rpgdating-btn-info { background: var(--info, #3498db); color: var(--text, #fff); width: 42px; height: 42px; border-radius: 50%; font-size: 18px; display: flex; align-items: center; justify-content: center; }
.rpgdating-btn-info:hover { background: #2980b9; }
.rpgdating-profile-username { font-size: 13px; color: var(--text-muted, #888); margin-top: -5px; margin-bottom: var(--space-sm, 10px); }
.rpgdating-profile-username a { color: var(--accent, #e74c3c); }

/* --- Schaltflächen --- */
.rpgdating-btn { display: inline-block; padding: var(--space-sm, 10px) var(--space-md, 22px); border: none; border-radius: 0; font-size: 14px; cursor: pointer; text-decoration: none; text-align: center; transition: background 0.2s, transform 0.1s; }
.rpgdating-btn:active { transform: scale(0.96); }
.rpgdating-btn-primary { background: var(--accent, #e74c3c); color: var(--text, #fff); }
.rpgdating-btn-primary:hover { background: #c0392b; color: var(--text, #fff); }
.rpgdating-btn-muted { background: var(--border, #eee); color: var(--text-dim, #666); }
.rpgdating-btn-muted:hover { background: var(--border-light, #ddd); }
.rpgdating-btn-small { padding: var(--space-xs, 6px) var(--space-sm, 14px); font-size: 13px; }
.rpgdating-btn-like { width: 60px; height: 60px; border-radius: 50%; background: var(--accent, #e74c3c); color: var(--text, #fff); font-size: 26px; display: flex; align-items: center; justify-content: center; border: none; cursor: pointer; box-shadow: 0 2px 8px rgba(231,76,60,0.3); transition: transform 0.15s, box-shadow 0.15s; }
.rpgdating-btn-like:hover { transform: scale(1.1); box-shadow: 0 4px 12px rgba(231,76,60,0.4); }
.rpgdating-btn-dislike { width: 60px; height: 60px; border-radius: 50%; background: var(--text-muted, #bbb); color: var(--text, #fff); font-size: 26px; display: flex; align-items: center; justify-content: center; border: none; cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,0.1); transition: transform 0.15s; }
.rpgdating-btn-dislike:hover { transform: scale(1.1); background: var(--text-dim, #999); }

/* --- Toggle-Schalter --- */
.rpgdating-toggle { display: flex; align-items: center; gap: var(--space-sm, 10px); cursor: pointer; font-size: 14px; }
.rpgdating-toggle input[type="checkbox"] { width: 18px; height: 18px; }

/* --- Treffer-Liste --- */
.rpgdating-matches-list h2 { margin: 0 0 var(--space-lg, 15px); }
.rpgdating-match-row { display: flex; align-items: center; gap: var(--space-lg, 15px); padding: var(--space-sm, 12px); border-bottom: 1px solid var(--border, #eee); }
.rpgdating-match-row:last-child { border-bottom: none; }
.rpgdating-match-photo { width: var(--rpgdating-match-size, 60px); height: var(--rpgdating-match-size, 60px); border-radius: 50%; background-size: cover; background-position: center; flex-shrink: 0; border: 2px solid var(--accent, #e74c3c); }
.rpgdating-match-info { flex: 1; }
.rpgdating-match-name { font-weight: bold; font-size: 15px; display: block; }
.rpgdating-match-date { font-size: 12px; color: var(--text-muted, #999); }
.rpgdating-match-lastmsg { display: block; font-size: 12px; color: var(--text-dim, #777); margin-top: var(--space-xs, 2px); font-style: italic; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 300px; }
.rpgdating-match-actions { display: flex; gap: var(--space-xs, 8px); }

/* --- Chat-Bereich --- */
.rpgdating-chat-header { display: flex; align-items: center; gap: var(--space-lg, 15px); padding-bottom: var(--space-sm, 12px); border-bottom: 1px solid var(--border, #ddd); margin-bottom: var(--space-lg, 15px); }
.rpgdating-back { font-size: 14px; color: var(--text-muted, #888); text-decoration: none; }
.rpgdating-back:hover { color: var(--text, #333); }
.rpgdating-chat-header h2 { margin: 0; font-size: 18px; }
.rpgdating-chat-messages { max-height: 500px; overflow-y: auto; padding: var(--space-sm, 10px) 0; }
.rpgdating-message { margin-bottom: var(--space-sm, 12px); padding: var(--space-sm, 10px) var(--space-sm, 14px); border-radius: 0; max-width: 75%; }
.rpgdating-message-own { background: #fde8e8; margin-left: auto; border-bottom-right-radius: 0; }
.rpgdating-message-other { background: var(--bg-alt, #f0f0f0); margin-right: auto; border-bottom-left-radius: 0; }
.rpgdating-message-meta { font-size: 12px; margin-bottom: var(--space-xs, 4px); display: flex; justify-content: space-between; gap: var(--space-sm, 10px); }
.rpgdating-message-time { color: var(--text-muted, #999); }
.rpgdating-message-text { font-size: 14px; line-height: 1.5; }
.rpgdating-chat-form { margin-top: var(--space-lg, 15px); padding-top: var(--space-sm, 12px); border-top: 1px solid var(--border, #ddd); }
.rpgdating-chat-input-group { display: flex; gap: var(--space-sm, 10px); align-items: flex-end; }
.rpgdating-chat-input { flex: 1; min-height: 45px; max-height: 120px; padding: var(--space-sm, 10px); border: 1px solid var(--border, #ddd); border-radius: 0; font-size: 14px; resize: vertical; }
.rpgdating-chat-refresh { display: flex; align-items: center; gap: var(--space-sm, 10px); padding: var(--space-sm, 10px) 0; justify-content: center; }
.rpgdating-chat-refresh #rpgdating-refresh-status { font-size: 12px; color: var(--text-muted, #888); font-style: italic; }

/* --- Öffentliche Chats --- */
.rpgdating-publicchat-row { display: flex; align-items: center; gap: var(--space-lg, 15px); padding: var(--space-sm, 12px); border-bottom: 1px solid var(--border, #eee); }
.rpgdating-publicchat-photos { display: flex; gap: var(--space-xs, 5px); }
.rpgdating-publicchat-photo { width: 40px; height: 40px; border-radius: 50%; background-size: cover; background-position: center; }
.rpgdating-publicchat-info { flex: 1; }
.rpgdating-publicchat-names { display: block; font-weight: bold; font-size: 14px; }
.rpgdating-publicchat-count { font-size: 12px; color: var(--text-muted, #999); }

/* --- Leere Zustände --- */
.rpgdating-no-cards, .rpgdating-no-permission { text-align: center; padding: var(--space-3xl, 50px) var(--space-lg, 20px); color: var(--text-muted, #888); }
.rpgdating-no-cards-icon { font-size: 48px; margin-bottom: var(--space-sm, 10px); }
.rpgdating-no-cards h3, .rpgdating-no-permission h2 { margin: 0 0 var(--space-xs, 8px); color: var(--text-dim, #555); }

/* --- Filter --- */
.rpgdating-filters { margin-bottom: var(--space-lg, 20px); }
.rpgdating-filter-form { display: flex; flex-wrap: wrap; gap: var(--space-sm, 10px); align-items: flex-end; padding: var(--space-sm, 12px); background: var(--bg-alt, #f8f8f8); border-radius: 0; }
.rpgdating-filter-form .rpgdating-field-group { margin-bottom: 0; flex: 1; min-width: 140px; }

/* --- Match-Popup --- */
.rpgdating-match-popup { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.7); display: flex; align-items: center; justify-content: center; z-index: 9999; }
.rpgdating-match-popup-inner { background: var(--bg-card, #fff); border-radius: 0; padding: var(--space-2xl, 40px); text-align: center; max-width: 400px; box-shadow: 0 10px 40px rgba(0,0,0,0.3); }
.rpgdating-match-popup-icon { font-size: 60px; color: var(--accent, #e74c3c); margin-bottom: var(--space-sm, 10px); }
.rpgdating-match-popup h2 { font-size: 28px; margin: 0 0 var(--space-sm, 10px); }
.rpgdating-match-popup-actions { display: flex; gap: var(--space-sm, 10px); justify-content: center; margin-top: var(--space-lg, 20px); }

/* --- Profil-Ansicht --- */
.rpgdating-photos-gallery { display: flex; gap: var(--space-sm, 8px); overflow-x: auto; padding-bottom: var(--space-sm, 10px); margin-bottom: var(--space-lg, 15px); }
.rpgdating-photos-gallery img { width: var(--rpgdating-gallery-width, 150px); height: var(--rpgdating-gallery-height, 200px); object-fit: cover; border-radius: 0; border: 1px solid var(--border, #ddd); }
.rpgdating-profile-info h2 { margin: 0 0 var(--space-sm, 10px); }
.rpgdating-bio { font-size: 14px; line-height: 1.6; color: var(--text, #444); margin-bottom: var(--space-lg, 15px); }

/* --- Statusmeldungen --- */
.rpgdating-success { background: var(--success-bg, #d4edda); border: 1px solid #c3e6cb; color: var(--success, #155724); padding: var(--space-sm, 12px) var(--space-md, 18px); border-radius: 0; margin-bottom: var(--space-lg, 15px); }
.rpgdating-error { background: var(--error-bg, #f8d7da); border: 1px solid #f5c6cb; color: var(--error, #721c24); padding: var(--space-sm, 12px) var(--space-md, 18px); border-radius: 0; margin-bottom: var(--space-lg, 15px); }
