@import url('https://fonts.googleapis.com/css2?family=Bai+Jamjuree:wght@400;500;600;700&display=swap');

/* ===== CSS VARS ===== */
:root {
    --pfs-anfaenger:       #27ae60;
    --pfs-mittel:          #1a56a0;
    --pfs-fortgeschritten: #f1c40f;
    --pfs-profi:           #c0392b;
    --pfs-haupt:           #1a56a0;
    --pfs-dunkel:          #113073;
    --pfs-grau:            #e8edf3;
}

/* ===== BASE ===== */
.pfs-wrap,
.pfs-wrap * {
    box-sizing: border-box !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
}

.pfs-wrap {
    max-width: 100%;
    margin: 0;
    padding: 0;
    color: #333;
    overflow-x: hidden !important;
}

/* ===== TOPBAR ===== */
.pfs-topbar {
    display: flex !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 8px !important;
    margin-bottom: 16px !important;
    flex-wrap: nowrap !important;
    line-height: 1 !important;
}

.pfs-topbar-name {
    font-size: 0.85rem !important;
    color: #555 !important;
    margin-right: 4px !important;
    white-space: nowrap !important;
}

/* Text-Links in Topbar */
.pfs-topbar-link {
    font-size: 0.92rem !important;
    font-weight: 600 !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
    color: #1a56a0 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    padding: 0 6px !important;
    line-height: 1 !important;
}

.pfs-topbar-link:hover {
    color: #113073 !important;
    text-decoration: underline !important;
}

.pfs-topbar-link--primary {
    background: #1a56a0 !important;
    color: #fff !important;
    padding: 9px 18px !important;
    border-radius: 15px !important;
    text-decoration: none !important;
}

.pfs-topbar-link--primary:hover {
    background: #113073 !important;
    color: #fff !important;
    text-decoration: none !important;
}

/* Icon-Buttons — nur Brief und Logout */
.pfs-wrap .pfs-topbar-iconbtn,
.pfs-topbar .pfs-topbar-iconbtn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    min-height: 36px !important;
    max-height: 36px !important;
    border-radius: 15px !important;
    border: 1.5px solid #d0d9e8 !important;
    background: #fff !important;
    color: #1a56a0 !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    box-shadow: none !important;
    padding: 0 !important;
    margin: 0 !important;
    flex-shrink: 0 !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    text-decoration: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    align-self: center !important;
}

.pfs-topbar-iconbtn:hover {
    background: #f0f5ff !important;
    border-color: #1a56a0 !important;
}

.pfs-topbar-iconbtn--danger {
    border-color: #f5b7b1 !important;
    color: #c0392b !important;
}

.pfs-topbar-iconbtn--danger:hover {
    background: #fdf0ef !important;
    border-color: #c0392b !important;
}

/* Mobil: Name sichtbar, normale Größe */
@media (max-width: 480px) {
    .pfs-topbar { gap: 6px !important; }
}

/* ===== BUTTONS — alles überschreiben ===== */
.pfs-wrap .pfs-btn,
.pfs-wrap a.pfs-btn,
.pfs-wrap button.pfs-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #1a56a0 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 15px !important;
    -webkit-border-radius: 15px !important;
    -moz-border-radius: 15px !important;
    padding: 0 22px !important;
    font-size: 0.92rem !important;
    font-weight: 600 !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
    cursor: pointer !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    box-shadow: none !important;
    height: 44px !important;
    line-height: 1 !important;
    min-height: unset !important;
    max-height: unset !important;
    letter-spacing: normal !important;
    text-transform: none !important;
    outline: none !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: background 0.2s !important;
    margin: 0 !important;
    width: auto !important;
}

.pfs-wrap .pfs-btn:hover,
.pfs-wrap a.pfs-btn:hover,
.pfs-wrap button.pfs-btn:hover {
    background: #113073 !important;
    color: #fff !important;
}

.pfs-wrap .pfs-btn-outline,
.pfs-wrap a.pfs-btn-outline {
    background: transparent !important;
    color: #1a56a0 !important;
    border: 2px solid #1a56a0 !important;
}

.pfs-wrap .pfs-btn-outline:hover,
.pfs-wrap a.pfs-btn-outline:hover {
    background: #1a56a0 !important;
    color: #fff !important;
}

.pfs-wrap .pfs-btn-sm {
    height: 36px !important;
    padding: 0 16px !important;
    font-size: 0.85rem !important;
}

.pfs-wrap .pfs-btn-danger {
    background: #c0392b !important;
}

.pfs-wrap .pfs-btn-danger:hover {
    background: #a93226 !important;
}

/* ===== SUCHMASKE ===== */
.pfs-suchmaske {
    background: #fff !important;
    border-radius: 15px !important;
    -webkit-border-radius: 15px !important;
    padding: 14px 20px !important;
    box-shadow: 0 2px 12px rgba(26,86,160,0.08) !important;
    margin-bottom: 24px !important;
    overflow: visible !important;
}

.pfs-suchmaske h2 {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    color: #113073 !important;
    margin: 0 0 20px 0 !important;
}

.pfs-form-row {
    display: flex !important;
    gap: 12px !important;
    flex-wrap: nowrap !important;
    align-items: flex-end !important;
}

.pfs-form-group {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    flex: 1 !important;
    min-width: 0 !important;
}

.pfs-form-group label {
    font-size: 0.78rem !important;
    font-weight: 700 !important;
    color: #555 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.05em !important;
    white-space: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
    background: none !important;
    border: none !important;
}

/* ===== ALLE INPUTS — Flatsome killer ===== */
.pfs-wrap input[type="text"],
.pfs-wrap input[type="email"],
.pfs-wrap input[type="password"],
.pfs-wrap input[type="tel"],
.pfs-wrap input[type="search"],
.pfs-wrap textarea {
    display: block !important;
    width: 100% !important;
    height: 44px !important;
    padding: 0 14px !important;
    font-size: 0.95rem !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
    font-weight: 400 !important;
    color: #333 !important;
    background: #f7f9fc !important;
    background-color: #f7f9fc !important;
    border: 1.5px solid #d0d9e8 !important;
    border-radius: 15px !important;
    -webkit-border-radius: 15px !important;
    -moz-border-radius: 15px !important;
    outline: none !important;
    box-shadow: none !important;
    -webkit-box-shadow: none !important;
    line-height: 1.4 !important;
    margin: 0 !important;
    -webkit-appearance: none !important;
    appearance: none !important;
    transition: border-color 0.2s, background 0.2s !important;
}

.pfs-wrap input[type="text"]:focus,
.pfs-wrap input[type="email"]:focus,
.pfs-wrap input[type="password"]:focus,
.pfs-wrap input[type="tel"]:focus {
    border-color: #1a56a0 !important;
    background: #fff !important;
    background-color: #fff !important;
    box-shadow: none !important;
    outline: none !important;
}

.pfs-wrap textarea {
    height: auto !important;
    min-height: 80px !important;
    padding: 10px 14px !important;
    resize: vertical !important;
    line-height: 1.5 !important;
}

.pfs-wrap textarea:focus {
    border-color: #1a56a0 !important;
    background: #fff !important;
    box-shadow: none !important;
    outline: none !important;
}
/* ===== PLACEHOLDER — hell & klar als Platzhalter erkennbar ===== */
.pfs-wrap input::placeholder,
.pfs-wrap textarea::placeholder {
    color: #b0bec5 !important;
    opacity: 1 !important;
    font-style: italic !important;
    font-weight: 400 !important;
}

.pfs-wrap input::-webkit-input-placeholder,
.pfs-wrap textarea::-webkit-input-placeholder { color: #b0bec5 !important; font-style: italic !important; }
.pfs-wrap input::-moz-placeholder,
.pfs-wrap textarea::-moz-placeholder            { color: #b0bec5 !important; font-style: italic !important; opacity: 1 !important; }
.pfs-wrap input:-ms-input-placeholder,
.pfs-wrap textarea:-ms-input-placeholder        { color: #b0bec5 !important; font-style: italic !important; }


/* ===== CUSTOM DROPDOWN ===== */
.pfs-select-wrap {
    position: relative !important;
    width: 100% !important;
}

.pfs-select-trigger {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    width: 100% !important;
    height: 44px !important;
    padding: 0 14px !important;
    border: 1.5px solid #d0d9e8 !important;
    border-radius: 15px !important;
    -webkit-border-radius: 15px !important;
    background: #f7f9fc !important;
    font-size: 0.95rem !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
    color: #333 !important;
    cursor: pointer !important;
    user-select: none !important;
    -webkit-user-select: none !important;
    transition: border-color 0.2s, background 0.2s !important;
    white-space: nowrap !important;
    box-shadow: none !important;
    outline: none !important;
}

.pfs-select-trigger:hover,
.pfs-select-wrap.open .pfs-select-trigger {
    border-color: #1a56a0 !important;
    background: #fff !important;
}

.pfs-select-arrow {
    width: 14px !important;
    height: 14px !important;
    margin-left: 8px !important;
    flex-shrink: 0 !important;
    transition: transform 0.2s !important;
    color: #888 !important;
    stroke: #888 !important;
}

.pfs-select-wrap.open .pfs-select-arrow {
    transform: rotate(180deg) !important;
}

.pfs-select-dropdown {
    display: none;
    position: absolute !important;
    top: calc(100% + 6px) !important;
    left: 0 !important;
    right: 0 !important;
    background: #fff !important;
    border: 1.5px solid #d0d9e8 !important;
    border-radius: 15px !important;
    box-shadow: 0 4px 20px rgba(26,86,160,0.14) !important;
    z-index: 99999 !important;
    overflow: hidden !important;
    padding: 6px 0 !important;
}

.pfs-select-wrap.open .pfs-select-dropdown {
    display: block !important;
}

.pfs-select-option {
    padding: 9px 16px !important;
    font-size: 0.9rem !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
    color: #333 !important;
    cursor: pointer !important;
    transition: background 0.12s !important;
    background: transparent !important;
}

.pfs-select-option:hover {
    background: #f0f5ff !important;
    color: #1a56a0 !important;
}

.pfs-select-option.selected {
    background: #1a56a0 !important;
    color: #fff !important;
    font-weight: 600 !important;
}

/* ===== SUCHEN-BUTTON GRUPPE ===== */
.pfs-form-group--btn {
    flex: 0 !important;
    min-width: unset !important;
}

.pfs-form-group--btn .pfs-btn {
    height: 44px !important;
    padding: 0 28px !important;
    font-size: 1rem !important;
}

/* ===== CARDS GRID ===== */
.pfs-results-info {
    font-size: 0.9rem;
    color: #666;
    margin-bottom: 16px;
    font-weight: 500;
}

.pfs-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
}

@media (max-width: 900px) { .pfs-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 580px) {
    .pfs-grid { grid-template-columns: 1fr; }
    .pfs-form-row { flex-wrap: wrap !important; }
}

/* ===== SPIELER CARD ===== */
.pfs-card {
    background: #fff;
    border-radius: 15px;
    box-shadow: 0 2px 12px rgba(26,86,160,0.07);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow 0.2s, transform 0.2s;
}

.pfs-card:hover {
    box-shadow: 0 6px 24px rgba(26,86,160,0.13);
    transform: translateY(-2px);
}

.pfs-card-stripe { height: 6px; width: 100%; }
.pfs-card-stripe.anfaenger       { background: #27ae60; }
.pfs-card-stripe.mittel          { background: #1a56a0; }
.pfs-card-stripe.fortgeschritten { background: #f1c40f; }
.pfs-card-stripe.profi           { background: #c0392b; }

.pfs-card-body { padding: 20px; flex: 1; display: flex; flex-direction: column; gap: 10px; }
.pfs-card-header { display: flex; align-items: flex-start; gap: 14px; }
.pfs-avatar { width: 52px; height: 52px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.pfs-avatar svg { width: 48px; height: 48px; }
.pfs-card-names { flex: 1; }
.pfs-card-nickname { font-size: 1.05rem; font-weight: 700; color: #113073; line-height: 1.2; }
.pfs-card-teamname { font-size: 0.88rem; color: #666; margin-top: 2px; }

.pfs-aktiv-badge { display: inline-flex; align-items: center; gap: 5px; font-size: 0.78rem; font-weight: 600; color: #555; margin-top: 3px; }
.pfs-aktiv-dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; }
.pfs-aktiv-dot.aktiv   { background: #27ae60; }
.pfs-aktiv-dot.inaktiv { background: #aaa; }

.pfs-staerke-badge { display: inline-block; padding: 3px 12px; border-radius: 20px; font-size: 0.78rem; font-weight: 700; color: #fff; text-transform: uppercase; letter-spacing: 0.05em; }
.pfs-staerke-badge.anfaenger       { background: #27ae60; }
.pfs-staerke-badge.mittel          { background: #1a56a0; }
.pfs-staerke-badge.fortgeschritten { background: #f1c40f; color: #333; }
.pfs-staerke-badge.profi           { background: #c0392b; }

.pfs-card-meta { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.pfs-meta-item { display: flex; align-items: center; gap: 5px; font-size: 0.85rem; color: #555; }
.pfs-meta-item svg { width: 15px; height: 15px; flex-shrink: 0; color: #1a56a0; }

.pfs-card-anlagen { font-size: 0.82rem; color: #666; line-height: 1.5; }
.pfs-card-anlagen span { display: inline-block; background: #e8edf3; border-radius: 20px; padding: 2px 10px; margin: 2px 2px 0 0; }

.pfs-card-freitext { font-size: 0.85rem; color: #555; font-style: italic; line-height: 1.5; border-left: 3px solid #e8edf3; padding-left: 10px; }

.pfs-card-footer { padding: 14px 20px; border-top: 1px solid #f0f0f0; display: flex; justify-content: space-between; align-items: center; gap: 10px; }
.pfs-distanz { font-size: 0.82rem; color: #888; }
.pfs-login-hint { font-size: 0.82rem; color: #1a56a0; font-weight: 600; text-decoration: none; }
.pfs-login-hint:hover { text-decoration: underline; }

/* ===== MODAL ===== */
.pfs-modal-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 99999; align-items: center; justify-content: center; padding: 16px; }
.pfs-modal-overlay.open { display: flex; }
.pfs-modal { background: #fff; border-radius: 15px; padding: 28px; max-width: 480px; width: 100%; box-shadow: 0 8px 40px rgba(0,0,0,0.18); position: relative; }
.pfs-modal h3 { font-size: 1.15rem; font-weight: 700; color: #113073; margin: 0 0 18px 0; }
.pfs-modal-close {
    position: absolute !important;
    top: 12px !important;
    right: 14px !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    font-size: 1.8rem !important;
    color: #888 !important;
    line-height: 1 !important;
    padding: 6px 10px !important;
    box-shadow: none !important;
    font-weight: 300 !important;
    height: auto !important;
    min-height: unset !important;
}
.pfs-modal-close:hover { color: #333 !important; }

/* ===== AUTH FORMS ===== */
.pfs-auth-wrap { max-width: 440px; margin: 0 auto; background: #fff; border-radius: 15px; padding: 32px; box-shadow: 0 2px 16px rgba(26,86,160,0.09); }
.pfs-auth-wrap h2 { font-size: 1.4rem; font-weight: 700; color: #113073; margin: 0 0 24px 0; text-align: center; }
.pfs-auth-wrap .pfs-form-group { margin-bottom: 16px; min-width: unset; flex: unset; }
.pfs-auth-links { text-align: center; margin-top: 16px; font-size: 0.88rem; color: #666; }
.pfs-auth-links a { color: #1a56a0; text-decoration: none; font-weight: 600; }

/* ===== PROFIL FORM ===== */
.pfs-profil-wrap { background: #fff; border-radius: 15px; padding: 28px; box-shadow: 0 2px 12px rgba(26,86,160,0.08); max-width: 680px; }
.pfs-profil-wrap h2 { font-size: 1.3rem; font-weight: 700; color: #113073; margin: 0 0 24px 0; }
.pfs-profil-section { margin-bottom: 22px; }
.pfs-profil-section h3 { font-size: 0.85rem; font-weight: 700; color: #888; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 12px 0; padding-bottom: 6px; border-bottom: 1px solid #e8edf3; }

.pfs-spielstaerke-options { display: flex; gap: 10px; flex-wrap: wrap; }
.pfs-spielstaerke-options label { cursor: pointer !important; padding: 8px 18px !important; border-radius: 20px !important; border: 2px solid #d0d9e8 !important; font-size: 0.88rem !important; font-weight: 600 !important; transition: all 0.15s !important; user-select: none !important; text-transform: none !important; height: auto !important; letter-spacing: normal !important; background: transparent !important; color: #333 !important; }
.pfs-spielstaerke-options input[type=radio] { display: none !important; }
.pfs-spielstaerke-options input[type=radio]:checked + label.anfaenger       { background: #27ae60 !important; color:#fff !important; border-color: #27ae60 !important; }
.pfs-spielstaerke-options input[type=radio]:checked + label.mittel          { background: #1a56a0 !important; color:#fff !important; border-color: #1a56a0 !important; }
.pfs-spielstaerke-options input[type=radio]:checked + label.fortgeschritten { background: #f1c40f !important; color:#333 !important; border-color: #f1c40f !important; }
.pfs-spielstaerke-options input[type=radio]:checked + label.profi           { background: #c0392b !important; color:#fff !important; border-color: #c0392b !important; }

.pfs-kontakt-toggle { display: flex; gap: 12px; flex-wrap: wrap; }
.pfs-kontakt-toggle label { cursor: pointer !important; padding: 8px 18px !important; border-radius: 15px !important; border: 2px solid #d0d9e8 !important; font-size: 0.88rem !important; font-weight: 600 !important; transition: all 0.15s !important; user-select: none !important; text-transform: none !important; height: auto !important; background: transparent !important; color: #333 !important; }
.pfs-kontakt-toggle input[type=radio] { display: none !important; }
.pfs-kontakt-toggle input[type=radio]:checked + label { background: #1a56a0 !important; color: #fff !important; border-color: #1a56a0 !important; }

/* ===== NACHRICHTEN ===== */
.pfs-nachrichten-wrap { background: #fff; border-radius: 15px; padding: 24px; box-shadow: 0 2px 12px rgba(26,86,160,0.08); }
.pfs-nachrichten-wrap h2 { font-size: 1.2rem; font-weight: 700; color: #113073; margin: 0 0 20px 0; }
.pfs-tabs { display: flex; margin-bottom: 20px; border-bottom: 2px solid #e8edf3; }
.pfs-tab { padding: 8px 20px; font-size: 0.9rem; font-weight: 600; color: #888; cursor: pointer; border-bottom: 3px solid transparent; margin-bottom: -2px; transition: color 0.2s, border-color 0.2s; }
.pfs-tab.active { color: #1a56a0; border-bottom-color: #1a56a0; }
.pfs-tab-content { display: none; }
.pfs-tab-content.active { display: block; }
.pfs-nachricht-item { border: 1.5px solid #e8edf3; border-radius: 15px; padding: 16px; margin-bottom: 12px; }
.pfs-nachricht-item.ungelesen { border-color: #1a56a0; background: #f0f5ff; }
.pfs-nachricht-meta { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; flex-wrap: wrap; gap: 6px; }
.pfs-nachricht-von { font-weight: 700; color: #113073; font-size: 0.95rem; }
.pfs-nachricht-datum { font-size: 0.8rem; color: #aaa; }
.pfs-nachricht-text { font-size: 0.9rem; color: #444; line-height: 1.6; }

/* ===== ALERTS ===== */
.pfs-alert { border-radius: 15px; padding: 12px 18px; font-size: 0.9rem; font-weight: 500; margin: 12px 0; }
.pfs-alert-success { background: #eafaf1; color: #1e8449; border: 1px solid #a9dfbf; }
.pfs-alert-error   { background: #fdf0ef; color: #c0392b; border: 1px solid #f5b7b1; }
.pfs-alert-info    { background: #ebf5fb; color: #113073; border: 1px solid #aed6f1; }

/* ===== LOADING ===== */
.pfs-loading { text-align: center; padding: 40px; color: #aaa; font-size: 0.95rem; }
.pfs-spinner { display: inline-block; width: 28px; height: 28px; border: 3px solid #e0e0e0; border-top-color: #1a56a0; border-radius: 50%; animation: pfs-spin 0.7s linear infinite; margin-bottom: 8px; }
@keyframes pfs-spin { to { transform: rotate(360deg); } }

/* ===== ANLAGE TAGS ===== */
.pfs-anlage-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.pfs-anlage-tag { background: #e8edf3; border-radius: 20px; padding: 5px 14px; font-size: 0.82rem; font-weight: 600; color: #113073; cursor: pointer; border: 2px solid transparent; transition: all 0.15s; }
.pfs-anlage-tag.selected { background: #1a56a0; color: #fff; border-color: #1a56a0; }

.pfs-chars-left { font-size: 0.78rem; color: #aaa; text-align: right; margin-top: 4px; }
.pfs-char-warn  { color: #c0392b; }

@media (max-width: 580px) {
    .pfs-suchmaske { padding: 18px !important; }
    .pfs-auth-wrap { padding: 22px 16px; }
    .pfs-profil-wrap { padding: 18px; }
    .pfs-modal { padding: 20px 16px; }
    .pfs-form-row { flex-wrap: wrap !important; }
}

/* ===== AUTOFILL / BROWSER-FILL Farbe neutralisieren ===== */
.pfs-wrap input:-webkit-autofill,
.pfs-wrap input:-webkit-autofill:hover,
.pfs-wrap input:-webkit-autofill:focus,
.pfs-wrap input:-webkit-autofill:active {
    -webkit-box-shadow: 0 0 0 100px #f7f9fc inset !important;
    box-shadow: 0 0 0 100px #f7f9fc inset !important;
    -webkit-text-fill-color: #333 !important;
    border-radius: 15px !important;
    border: 1.5px solid #d0d9e8 !important;
    background-color: #f7f9fc !important;
}



/* ===== SUCHE TITEL ===== */
.pfs-suche-titel {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-size: 1.2rem !important;
}

@media (max-width: 480px) {
    .pfs-suche-titel {
        font-size: 1.05rem !important;
        white-space: normal !important;
        line-height: 1.3 !important;
        margin-bottom: 16px !important;
    }
}

/* ===== SUCHMASKE LAYOUT ===== */
.pfs-suche-ort-row {
    display: flex !important;
    gap: 10px !important;
    margin-bottom: 0 !important;
    align-items: center !important;
}

.pfs-suche-filter-row {
    display: flex !important;
    gap: 12px !important;
    align-items: flex-end !important;
}

.pfs-ort-group {
    flex: 2 !important;
    min-width: 0 !important;
}

.pfs-umkreis-group {
    flex: 1 !important;
    min-width: 90px !important;
}

/* Ort-Input mit Geo-Button */
.pfs-ort-input-wrap {
    position: relative !important;
    display: flex !important;
    align-items: center !important;
}

.pfs-ort-input-wrap input {
    flex: 1 !important;
    padding-right: 44px !important;
}

.pfs-geo-btn {
    position: absolute !important;
    right: 6px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    color: #1a56a0 !important;
    padding: 4px !important;
    height: auto !important;
    min-height: unset !important;
    box-shadow: none !important;
    display: flex !important;
    align-items: center !important;
    border-radius: 8px !important;
}

.pfs-geo-btn:hover {
    background: #f0f5ff !important;
}

.pfs-geo-btn.loading {
    animation: pfs-spin 0.8s linear infinite !important;
}

/* Mobile: alles untereinander */
@media (max-width: 580px) {
    .pfs-suche-ort-row {
        flex-wrap: wrap !important;
        gap: 8px !important;
    }
    .pfs-ort-group {
        flex: 1 1 100% !important;
        width: 100% !important;
    }
    .pfs-umkreis-group {
        flex: 1 !important;
        min-width: 100px !important;
    }
    .pfs-suchen-btn {
        flex-shrink: 0 !important;
    }
    .pfs-suchmaske {
        padding: 16px !important;
    }
}

/* ===== TITEL MOBIL — nie umbrechen, kleiner ===== */
@media (max-width: 640px) {
    .pfs-suche-titel {
        font-size: 1rem !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        margin-bottom: 14px !important;
    }
}

/* ===== PAGINATION ===== */
.pfs-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    margin-top: 28px;
    flex-wrap: wrap;
}

.pfs-page-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 38px !important;
    height: 38px !important;
    padding: 0 12px !important;
    border-radius: 15px !important;
    border: 1.5px solid #d0d9e8 !important;
    background: #fff !important;
    color: #1a56a0 !important;
    font-size: 0.88rem !important;
    font-weight: 600 !important;
    font-family: 'Bai Jamjuree', sans-serif !important;
    cursor: pointer !important;
    transition: all 0.15s !important;
    box-shadow: none !important;
    text-decoration: none !important;
    line-height: 1 !important;
}

.pfs-page-btn:hover {
    background: #f0f5ff !important;
    border-color: #1a56a0 !important;
}

.pfs-page-btn--active {
    background: #1a56a0 !important;
    color: #fff !important;
    border-color: #1a56a0 !important;
    cursor: default !important;
}

.pfs-page-dots {
    color: #aaa;
    font-size: 0.88rem;
    padding: 0 4px;
}

/* ===== MODAL TEXTAREA RADIUS ===== */
.pfs-modal textarea,
.pfs-modal .pfs-form-group textarea {
    border-radius: 15px !important;
    -webkit-border-radius: 15px !important;
    border: 1.5px solid #d0d9e8 !important;
    padding: 12px 14px !important;
}

/* ===== NACHRICHTEN ACTIONS ===== */
.pfs-nachricht-actions {
    display: flex !important;
    gap: 8px !important;
    margin-top: 10px !important;
    flex-wrap: nowrap !important;
}
.pfs-nachricht-actions .pfs-btn {
    flex: 0 0 auto !important;
    width: auto !important;
    padding: 0 16px !important;
    height: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
    font-size: 0.85rem !important;
}

/* === Kompakt-Suchleiste (mobile, nach erster Suche) === */
.pfs-suche-kompakt {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    background: #fff !important;
    border: 1px solid #dde3ee !important;
    border-radius: 12px !important;
    padding: 8px 12px !important;
    margin-bottom: 14px !important;
    font-size: 0.9rem !important;
    color: #1a2540 !important;
    font-weight: 500 !important;
    line-height: 1 !important;
}

.pfs-kompakt-edit {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    background: none !important;
    border: 1px solid #1a56a0 !important;
    color: #1a56a0 !important;
    border-radius: 8px !important;
    padding: 4px 10px !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    height: auto !important;
    min-height: unset !important;
    box-shadow: none !important;
    line-height: 1.4 !important;
    align-self: center !important;
}

.pfs-kompakt-edit:hover {
    background: #f0f5ff !important;
}

/* Suche-Ort-Row: Button inline auf Desktop */


/* === Flatsome-Override: Anfrage-Modal Button === */
#pfs-anfrage-senden {
    margin-top: 12px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    height: 48px !important;
    line-height: 48px !important;
    width: 100% !important;
    display: block !important;
    font-size: 1rem !important;
}

#pfs-anfrage-result {
    margin: 0 !important;
    padding: 0 !important;
    min-height: 0 !important;
}

.pfs-modal .pfs-form-group {
    margin-bottom: 0 !important;
}

/* === Textarea: kein seitliches Resize === */
.pfs-wrap textarea {
    resize: vertical !important;
}

/* === Browser-Default Reset für Modal-Button === */
#pfs-anfrage-senden,
.pfs-modal .pfs-btn {
    -webkit-appearance: none !important;
    appearance: none !important;
    margin: 12px 0 0 0 !important;
    padding: 0 !important;
    height: 48px !important;
    line-height: 48px !important;
    width: 100% !important;
    display: block !important;
    box-sizing: border-box !important;
}

/* === Modal Layout: flex statt loose margins === */
.pfs-modal {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
}

.pfs-modal h3 {
    margin-bottom: 16px !important;
}

#pfs-anfrage-result {
    margin: 0 !important;
    padding: 0 !important;
}

#pfs-anfrage-result:empty,
#pfs-anfrage-result.pfs-hidden {
    display: none !important;
}

#pfs-anfrage-result .pfs-alert {
    margin-top: 8px !important;
}

#pfs-anfrage-result .pfs-alert {
    margin: 0 !important;
}

#pfs-anfrage-senden,
.pfs-modal #pfs-anfrage-senden {
    margin: 12px 0 0 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    height: 48px !important;
    line-height: 48px !important;
    width: 100% !important;
    display: block !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

/* Modal padding unten reduzieren */
.pfs-modal {
    padding-bottom: 20px !important;
}

/* === Modal Send Button (div statt button, kein Flatsome-Einfluss) === */
.pfs-modal-send-btn {
    display: block !important;
    width: 100% !important;
    margin-top: 12px !important;
    height: 46px !important;
    line-height: 46px !important;
    text-align: center !important;
    cursor: pointer !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    border-radius: 50px !important;
    background: #1a56a0 !important;
    color: #fff !important;
    letter-spacing: 0.03em !important;
    user-select: none !important;
}

.pfs-modal-send-btn:hover {
    background: #154a8a !important;
}

.pfs-modal-send-btn.pfs-disabled {
    opacity: 0.6 !important;
    pointer-events: none !important;
    cursor: default !important;
}
