/* /Components/BottomNav.razor.rz.scp.css */
.bottom-nav[b-3m0dydzfwn] {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 60px;
    background-color: var(--gastro-primary); /* Ciemne tło */
    color: white;
    display: flex;
    justify-content: space-around;
    align-items: center;
    box-shadow: 0 -2px 5px rgba(0,0,0,0.1);
    z-index: 1000;
}

    .bottom-nav a.nav-item[b-3m0dydzfwn] {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        color: rgba(255, 255, 255, 0.7); /* Jasnoszary dla nieaktywnych */
        text-decoration: none;
        flex-grow: 1;
        height: 100%;
    }

        .bottom-nav a.nav-item.active[b-3m0dydzfwn] {
            color: white; /* Biały dla aktywnego */
            background-color: rgba(255, 255, 255, 0.1);
        }

        .bottom-nav a.nav-item i[b-3m0dydzfwn] {
            font-size: 1.5rem;
            margin-bottom: 2px;
        }

        .bottom-nav a.nav-item span[b-3m0dydzfwn] {
            font-size: 0.7rem;
            font-family: var(--gastro-font-heading);
        }

@media (min-width: 768px) { /* Ukrywamy dolne menu na desktopie */
    .bottom-nav[b-3m0dydzfwn] {
        display: none;
    }
}
/* /Components/CommentDisplay.razor.rz.scp.css */
.comment-item[b-jlej6elky2] {
    position: relative;
    margin-top: 16px;
}

.comment-layout[b-jlej6elky2] {
    display: flex;
    position: relative;
}

/* Kolumna na awatar i linię pionową */
.avatar-line-col[b-jlej6elky2] {
    flex-shrink: 0;
    width: 44px; /* 32px awatar + 12px margines */
    position: relative;
    display: flex;
    justify-content: center;
    padding-top: 0px;
}

.comment-avatar[b-jlej6elky2] {
    width: 32px;
    height: 32px;
    border-radius: 4px;
    background-color: #6c757d;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.replies-section .comment-avatar[b-jlej6elky2] {
    width: 26px;
    height: 26px;
    border-radius: 4px; /* Kanciaste rogi zamiast okrągłych */
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    margin-top: 3px;
}

/* vertical thread - pozwalamy JS ustawić wysokość inline lub zostawiamy fallback */
.vertical-thread-line[b-jlej6elky2] {
    position: absolute;
    top: 40px;
    left: 20px;
    width: 2px;
    background: #e9ecef;
    height: var(--vertical-thread-height, calc(100% - 40px));
    z-index: 0;
}

.comment-main-content[b-jlej6elky2] {
    flex-grow: 1;
    min-width: 0;
}

/* --- Sekcja z odpowiedziami --- */
.replies-section[b-jlej6elky2] {
    margin-top: 1rem;
    position: relative;
}

    /* Każda pojedyncza odpowiedź */
    .replies-section[b-jlej6elky2] >  .comment-item {
        position: relative;
        padding-left: 32px;
        margin-top: 1rem;
    }

        /* łącznik korzystający z CSS-vars które ustawi JS */
        .replies-section[b-jlej6elky2] >  .comment-item::before {
            content: '';
            position: absolute;
            top: 16px;
            left: var(--connector-left, -12px);
            width: var(--connector-width, 20px);
            height: 2px;
            background: #e9ecef;
        }

     

    

/* --- Pozostałe style --- */
.comment-frame[b-jlej6elky2] {
    width: 100%;
}

.main-comment-bg[b-jlej6elky2] {
    background-color: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 12px;
    padding: 0.75rem 1rem;
}

.comment-body[b-jlej6elky2] {
    display: flex;
    flex-direction: column;
}

.comment-header[b-jlej6elky2] {
    display: flex;
    align-items: baseline;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.comment-author[b-jlej6elky2] {
    font-weight: 600;
}

.comment-date[b-jlej6elky2] {
    font-size: 0.75rem;
    color: #6c757d;
}

.comment-content[b-jlej6elky2] {
    line-height: 1.5;
    word-break: break-word;
}

.comment-actions[b-jlej6elky2] {
    margin-top: 0.25rem;
    display: flex;
    gap: 1rem;
}

.action-button[b-jlej6elky2] {
    background: none;
    border: none;
    color: #6c757d;
    font-size: 0.8rem;
    font-weight: 600;
    padding: 0.25rem 0;
    cursor: pointer;
}

    .action-button:hover[b-jlej6elky2] {
        color: #0d6efd;
    }

.like-button.liked[b-jlej6elky2] {
    color: #0d6efd;
}

.reply-form-wrapper[b-jlej6elky2] {
    margin-top: 0.75rem;
}

.reply-form-actions[b-jlej6elky2] {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.show-more-replies[b-jlej6elky2] {
    background: none;
    border: none;
    padding: 0;
    font-size: 0.85rem;
    font-weight: 600;
    color: #6c757d;
    cursor: pointer;
    margin-top: 0.5rem;
    margin-bottom: 1rem;
    text-decoration: none;
}

    .show-more-replies:hover[b-jlej6elky2] {
        text-decoration: underline;
    }
/* /Components/CommentSection.razor.rz.scp.css */
.comment-section[b-76dvtz1nru] {
    padding: 0 1.25rem 1rem 1.25rem;
    margin-top: 1rem;
}

.comment-form[b-76dvtz1nru] {
    margin-bottom: 1.5rem;
}

/* /Components/InventoryPanel.razor.rz.scp.css */
.inventory-panel[b-tcs7s02r06] {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 40vh;
    max-height: 300px;
    background-color: white;
    z-index: 1010;
    transform: translateY(100%);
    transition: transform 0.3s ease-in-out;
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.15);
    display: flex;
    flex-direction: column;
}

    .inventory-panel.visible[b-tcs7s02r06] {
        transform: translateY(0);
    }

.panel-header[b-tcs7s02r06] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem;
    border-bottom: 1px solid #dee2e6;
    flex-shrink: 0;
}

.panel-content[b-tcs7s02r06] {
    padding: 1rem;
    overflow-y: auto;
    flex-grow: 1;
}

.inventory-grid[b-tcs7s02r06] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 1rem;
}

.inventory-slot[b-tcs7s02r06] {
    border: 2px dashed #ccc;
    border-radius: 8px;
    height: 120px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 0.5rem;
}

    .inventory-slot.empty[b-tcs7s02r06] {
        color: #aaa;
    }

    .inventory-slot.occupied[b-tcs7s02r06] {
        border-style: solid;
        border-color: #a9a9a9;
        background-color: #f8f9fa;
    }

.chest-icon[b-tcs7s02r06] {
    width: 48px;
    height: 48px;
    margin-bottom: 0.5rem;
}
/* /Components/Notifications/NotificationBell.razor.rz.scp.css */
.notification-bell[b-gq096csucs] {
    position: relative;
    cursor: pointer;
    font-size: 1.5rem;
    color: var(--bs-body-color);
}

    .notification-bell .badge[b-gq096csucs] {
        position: absolute;
        top: -5px;
        right: -10px;
        font-size: 0.65rem;
    }
/* /Components/Notifications/NotificationPanel.razor.rz.scp.css */
.notification-panel-overlay[b-1lzzt8mori] {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 1040;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

    .notification-panel-overlay.show[b-1lzzt8mori] {
        opacity: 1;
        visibility: visible;
    }

.notification-panel[b-1lzzt8mori] {
    position: fixed;
    top: 0;
    right: -350px; /* Start outside the screen */
    width: 350px;
    height: 100%;
    background-color: #fff;
    z-index: 1050;
    box-shadow: -5px 0 15px rgba(0,0,0,0.1);
    transition: right 0.3s ease-in-out;
    display: flex;
    flex-direction: column;
}

    .notification-panel.show[b-1lzzt8mori] {
        right: 0; /* Slide in */
    }

.panel-header[b-1lzzt8mori] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #dee2e6;
}

.panel-body[b-1lzzt8mori] {
    overflow-y: auto;
    flex-grow: 1;
}

.notification-item[b-1lzzt8mori] {
    display: flex;
    align-items: center;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid #f0f0f0;
    cursor: pointer;
    transition: background-color 0.2s ease;
}

    .notification-item:hover[b-1lzzt8mori] {
        background-color: #f8f9fa;
    }

    .notification-item.is-read .notification-content p[b-1lzzt8mori] {
        font-weight: normal;
        color: #6c757d;
    }

.notification-icon[b-1lzzt8mori] {
    font-size: 1.5rem;
    margin-right: 1rem;
    width: 30px;
    text-align: center;
}

.notification-content p[b-1lzzt8mori] {
    margin: 0;
    font-weight: 600;
    font-size: 0.9rem;
    color: #212529;
}
/* /Components/OpeningHoursEditor.razor.rz.scp.css */
.day-row[b-sgggyklp84] {
    display: flex; /* Używamy Flexbox zamiast Grid */
    flex-wrap: wrap; /* To jest klucz! Pozwól elementom zawijać się do nowej linii */
    align-items: center;
    gap: 0.75rem; /* Odstęp między elementami */
    padding: 0.5rem 0;
    border-bottom: 1px solid #f0f0f0;
}

    .day-row:last-of-type[b-sgggyklp84] {
        border-bottom: none;
    }

.day-name[b-sgggyklp84] {
    font-weight: 500;
    flex-basis: 105px; /* Zwiększona szerokość dla "Poniedziałek" */
    flex-shrink: 0;
    text-align: right; /* Wyrównanie do prawej dla spójności */
    padding-right: 0.5rem;
}

.time-inputs[b-sgggyklp84] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
   
}

.form-switch[b-sgggyklp84] {
    margin-left: 1rem; /* Domyślny, mniejszy margines na desktopie */
}



    /* Nadpisujemy styl, aby napis "Zamknięte" MÓGŁ się zawijać */
    .closed-switch .form-check-label[b-sgggyklp84] {
        white-space: normal !important;
    }

.day-row .form-switch .form-check-input[b-sgggyklp84] {
    background-color: var(--gastro-danger);
    border-color: var(--gastro-danger);
}

    .day-row .form-switch .form-check-input:checked[b-sgggyklp84] {
        background-color: var(--gastro-success);
        border-color: var(--gastro-success);
    }

.day-row.is-closed .day-name[b-sgggyklp84] {
     color: var(--gastro-text-medium);
    
}

.time-inputs .form-control[b-sgggyklp84] {
    width: 100px; /* Stała, węższa szerokość dla pól godzin */
    flex-grow: 0; /* Zapobiega rozciąganiu */
    
}

/* Na mniejszych ekranach, jeśli elementy się nie mieszczą,
   przełącznik zostanie wypchnięty na prawo */
 @media (max-width: 480px) {
     .form-switch[b-sgggyklp84]

{
    margin-left: auto;
    
}


}
/* /Components/PlacePreviewPanel.razor.rz.scp.css */
.place-preview-panel[b-kb6c2kjjcu] {
    display: flex;
    flex-direction: column;
    height: 100%;
    background-color: var(--gastro-bg-panel);
    overflow: hidden;
}

.panel-header[b-kb6c2kjjcu] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid #dee2e6;
    padding: 1rem;
    background-color: var(--gastro-bg-panel);
    flex-shrink: 0;
}

    .panel-header h5[b-kb6c2kjjcu] {
        font-family: var(--gastro-font-heading);
        color: var(--gastro-text-light);
    }

.panel-content[b-kb6c2kjjcu] {
    flex-grow: 1;
    overflow-y: auto;
    padding: 1rem;
    font-family: var(--gastro-font-body);
}

.dark-header[b-kb6c2kjjcu] {
    background-color: var(--gastro-primary);
    color: var(--gastro-text-light);
    padding: 1rem;
}

    .dark-header small[b-kb6c2kjjcu] {
        color: rgba(255, 255, 255, 0.7);
    }

.panel-footer[b-kb6c2kjjcu] {
    border-top: 1px solid #dee2e6;
    padding: 0.75rem 1rem;
    background-color: var(--gastro-bg-panel);
    flex-shrink: 0;
}

.panel-section[b-kb6c2kjjcu] {
    margin-bottom: 1rem;
}

    .panel-section h6.section-title[b-kb6c2kjjcu] {
        font-family: var(--gastro-font-heading);
        font-weight: 600;
        color: var(--gastro-text-dark);
        margin-bottom: 0.75rem;
    }

    .panel-section:last-of-type[b-kb6c2kjjcu] {
        margin-bottom: 0;
    }

.opening-hours-wrapper[b-kb6c2kjjcu] {
    background-color: #f8f9fa;
    border-radius: var(--gastro-border-radius);
    border: 1px solid var(--gastro-bg-light);
    overflow: hidden;
}

.opening-hours-row[b-kb6c2kjjcu] {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    font-size: 0.9rem;
    border-bottom: 1px solid var(--gastro-bg-light);
}

    .opening-hours-row:last-child[b-kb6c2kjjcu] {
        border-bottom: none;
    }

    .opening-hours-row.today[b-kb6c2kjjcu] {
        background-color: #e9ecef;
        border-left: 4px solid var(--gastro-primary);
        padding-left: calc(0.75rem - 4px);
    }

    .opening-hours-row .day-name[b-kb6c2kjjcu] {
        font-weight: 500;
    }

    .opening-hours-row .day-hours.closed[b-kb6c2kjjcu] {
        color: var(--gastro-danger);
        font-weight: 500;
    }

.toggle-hours-btn[b-kb6c2kjjcu] {
    width: 100%;
    text-align: center;
    padding: 0.5rem;
    font-size: 0.85rem;
    color: var(--gastro-primary);
    background-color: transparent;
    border: none;
    font-weight: 500;
    cursor: pointer;
}

    .toggle-hours-btn:hover[b-kb6c2kjjcu] {
        background-color: #e9ecef;
    }

    .toggle-hours-btn i[b-kb6c2kjjcu] {
        font-size: 0.7rem;
        vertical-align: middle;
    }

.delivery-icons-wrapper[b-kb6c2kjjcu] {
    display: flex;
    gap: 0.5rem;
}

.delivery-icon-box[b-kb6c2kjjcu] {
    width: 4rem;
    height: 4rem;
    background-color: var(--gastro-bg-light);
    border: 2px dashed #dee2e6;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
}

.delivery-icon[b-kb6c2kjjcu] {
    height: 100%;
    width: 100%;
    object-fit: contain;
}

.rating-badge[b-kb6c2kjjcu] {
    font-size: 1rem;
    padding: 0.5em 0.75em;
    background-color: #ffc107;
    color: #000 !important;
}

.update-info[b-kb6c2kjjcu] {
    display: flex;
    line-height: 1.2;
    flex-direction: column;
    font-size: 0.9rem;
    color: var(--gastro-text-medium);
}

    .update-info strong[b-kb6c2kjjcu] {
        font-size: 0.9em;
        font-weight: 600;
        color: var(--gastro-text-dark);
    }
.delivery-noinfo-box[b-kb6c2kjjcu] {
    width: 4rem;
    height: 4rem;
    background-color: var(--gastro-bg-light);
    border: 2px dashed #dee2e6;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
}

.delivery-icon-box.no-data-placeholder[b-kb6c2kjjcu] {
    color: var(--gastro-text-medium);
    font-size: 0.8rem;
    background-color: transparent;
    cursor: default !important;
}



.text-sm[b-kb6c2kjjcu] {
     font-size: 0.875rem;
    
}

.update-info span[b-kb6c2kjjcu] {
     font-size: 0.9em;
    
}

/* NOWE STYLE - START */
.star-rating .star-icon[b-kb6c2kjjcu] {
    color: #ffc107;
    font-size: 1rem;
    margin-right: 1px;
}

.rating-value[b-kb6c2kjjcu] {
    font-weight: 700;
    color: var(--gastro-text-dark);
}

.preview-event-list[b-kb6c2kjjcu] {
    border-top: 1px solid #eee;
    margin-top: 10px;
    padding-top: 5px;
}

.event-item-mini[b-kb6c2kjjcu] {
    padding: 8px 5px;
    border-bottom: 1px solid #f0f0f0;
}

    .event-item-mini:last-child[b-kb6c2kjjcu] {
        border-bottom: none;
        padding-bottom: 0;
    }

    .event-item-mini .event-item-title[b-kb6c2kjjcu] {
        font-size: 0.9rem; /* Mniejszy tytuł */
        font-weight: 600;
        color: #212529;
        margin-bottom: 2px;
    }

        /* Kolorowa ikonka kategorii przy tytule */
        .event-item-mini .event-item-title .bi[b-kb6c2kjjcu] {
            font-size: 0.9rem;
            margin-right: 8px;
            width: 20px;
            text-align: center;
        }

    .event-item-mini .event-item-details[b-kb6c2kjjcu] {
        font-size: 0.8rem; /* Mniejsza data */
        color: #495057;
        padding-left: 28px; /* Wyrównanie do tekstu tytułu */
    }
/* /Components/PostCard.razor.rz.scp.css */
.post-card[b-xfof4yz2kt] {
    background-color: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: 12px;
    margin-bottom: 1.5rem;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.post-header[b-xfof4yz2kt] {
    display: flex;
    align-items: center;
    padding: 1rem 1.25rem;
}

.author-avatar[b-xfof4yz2kt] {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    margin-right: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    font-weight: 600;
    color: white;
}

.author-info[b-xfof4yz2kt] {
    display: flex;
    flex-direction: column;
}

.author-name[b-xfof4yz2kt] {
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--bs-body-color);
}

.post-date[b-xfof4yz2kt] {
    font-size: 0.8rem;
    color: var(--bs-secondary-color);
}

.post-content p[b-xfof4yz2kt] {
    padding: 0 1.25rem 1rem 1.25rem;
    /* UŻYWAMY GŁÓWNEJ CZCIONKI ZDEFINIOWANEJ W app.css */
    font-size: 1rem;
    line-height: 1.6;
    color: var(--bs-body-color);
    white-space: pre-wrap;
    word-wrap: break-word;
    margin: 0;
}

.post-actions[b-xfof4yz2kt] {
    display: flex;
    padding: 0.5rem 1.25rem 1rem 1.25rem;
    border-top: 1px solid var(--bs-border-color);
    margin-top: 0.5rem;
}

.action-button[b-xfof4yz2kt] {
    background: none;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    margin-right: 1.5rem;
    color: var(--bs-secondary-color);
    font-size: 0.9rem;
    transition: color 0.2s ease-in-out, transform 0.1s ease;
}

    .action-button:hover[b-xfof4yz2kt] {
        color: var(--bs-primary);
    }

    .action-button i[b-xfof4yz2kt] {
        font-size: 1.2rem;
    }

    .action-button .action-count[b-xfof4yz2kt] {
        margin-left: 6px;
        font-weight: 500;
    }

.like-button.liked[b-xfof4yz2kt], .like-button.liked:hover[b-xfof4yz2kt] {
    color: #ed4956; /* Czerwony dla polubionego */
}
/* /Components/RangeSlider.razor.rz.scp.css */
.range-slider-container[b-a2t09qkk73] {
    padding: 1rem 0;
}

.range-values[b-a2t09qkk73] {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.5rem;
    font-weight: 500;
    color: #495057;
}

.range-inputs[b-a2t09qkk73] {
    position: relative;
    height: 20px;
}

    .range-inputs input[type="range"][b-a2t09qkk73] {
        position: absolute;
        width: 100%;
        /* Usuwamy domyślny wygląd suwaka, aby móc go ostylować */
        -webkit-appearance: none;
        appearance: none;
        width: 100%;
        background: none; /* WAŻNE: usuwamy tło z samego suwaka */
        pointer-events: none; /* Pozwala na klikanie przez warstwy */
        height: 100%;
    }

        /* Kciuk suwaka (kółko do przesuwania) */
        .range-inputs input[type="range"][b-a2t09qkk73]::-webkit-slider-thumb {
            -webkit-appearance: none;
            appearance: none;
            width: 20px;
            height: 20px;
            background: var(--gastro-primary);
            border-radius: 50%;
            cursor: pointer;
            pointer-events: auto; /* Kciuk jest klikalny */
            position: relative;
            z-index: 2;
        }

        .range-inputs input[type="range"][b-a2t09qkk73]::-moz-range-thumb {
            width: 20px;
            height: 20px;
            background: var(--gastro-primary);
            border-radius: 50%;
            cursor: pointer;
            pointer-events: auto;
            position: relative;
            z-index: 2;
        }

    /* Tło dla suwaka (belka) - widoczne pod spodem */
    .range-inputs .slider-track[b-a2t09qkk73] {
        position: absolute;
        width: 100%;
        height: 4px;
        background-color: #dee2e6;
        top: 50%;
        transform: translateY(-50%);
        border-radius: 4px;
        z-index: 1;
    }


    .range-inputs .slider-progress[b-a2t09qkk73] {
        background-color: var(--gastro-primary);
        position: absolute;
        z-index: 2;
        height: 4px;
        top: 50%;
        transform: translateY(-50%);
        border-radius: 4px;
    }


 
/* /Components/ReflexGame.razor.rz.scp.css */
.reflex-game-overlay[b-7memgh5v7e] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    z-index: 2000;
    display: flex;
    justify-content: center;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s, visibility 0.3s;
}

    .reflex-game-overlay.visible[b-7memgh5v7e] {
        opacity: 1;
        visibility: visible;
    }

.reflex-game-container[b-7memgh5v7e] {
    background-color: white;
    padding: 2rem;
    border-radius: 12px;
    text-align: center;
    width: 90%;
    max-width: 400px;
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

.game-track[b-7memgh5v7e] {
    position: relative;
    width: 100%;
    height: 30px;
    background-color: #e9ecef;
    border-radius: 15px;
    margin-top: 1.5rem;
    border: 2px solid #ced4da;
}

.target-zone[b-7memgh5v7e] {
    position: absolute;
    top: 0;
    left: 47.5%; /* Pozycja celu */
    width: 5%; /* Szerokość celu */
    height: 100%;
    background-color: rgba(25, 135, 84, 0.5); /* Zielony kolor */
    border-radius: 15px;
}

.moving-icon[b-7memgh5v7e] {
    position: absolute;
    top: -5px; /* Lekko uniesiona */
    left: 0; /* Pozycja startowa */
    width: 40px;
    height: 40px;
    background-image: url('../icons/kebab.png'); /* Używamy ikonki kebaba */
    background-size: contain;
    background-repeat: no-repeat;
}
/* /Components/SortedResultList.razor.rz.scp.css */
.sorted-list-container[b-x58ryaxs9a] {
    overflow-y: auto; /* Pozwala na przewijanie, jeśli lista jest długa */
    height: 100%; /* Wypełnia dostępną przestrzeń */
    background-color: #f8f9fa;
}

.list-group-item[b-x58ryaxs9a] {
    cursor: pointer;
    transition: background-color 0.15s ease-in-out;
}

    .list-group-item h6[b-x58ryaxs9a] {
        font-weight: 600;
    }

    .list-group-item p[b-x58ryaxs9a] {
        color: #6c757d; /* Kolor secondary */
    }

    .list-group-item strong[b-x58ryaxs9a] {
        font-size: 1.1em;
        color: var(--gastro-primary);
    }

.price-display[b-x58ryaxs9a] {
     white-space: nowrap;
    
}


 .price-display .currency[b-x58ryaxs9a] {
     font-size: 0.8em;
     font-weight: normal;
     color: var(--gastro-text-medium);
    
}

.list-item-closing-soon[b-x58ryaxs9a] {
    background-color: #fffbe6; /* Jasnożółte tło */
    border-left: 4px solid #ffc107; /* Żółty akcent po lewej */
}

.list-item-closing-very-soon[b-x58ryaxs9a] {
    background-color: #ffe6e6; /* Bardzo jasne czerwone tło */
    border-left: 4px solid #dc3545; /* Mocny czerwony akcent po lewej */
}
/* /Components/StarRatingInput.razor.rz.scp.css */
.star-rating-input .star[b-phftgb8uq5] {
    font-size: 2rem;
    color: #e4e5e9;
    cursor: pointer;
    transition: color 0.2s ease-in-out;
}

.star-rating-input:hover .star[b-phftgb8uq5] {
    color: #ffc107;
}

.star-rating-input .star:hover ~ .star[b-phftgb8uq5] {
    color: #e4e5e9;
}

.star-rating-input .star.selected[b-phftgb8uq5] {
    color: #ffc107;
}
/* /Components/StopPickerMap.razor.rz.scp.css */
.stop-picker-overlay[b-8qoj5tp1qj] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 2000;
    display: flex;
    flex-direction: column;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;
}

    .stop-picker-overlay.visible[b-8qoj5tp1qj] {
        opacity: 1;
        visibility: visible;
    }

.stop-picker-map-container[b-8qoj5tp1qj] {
    flex-grow: 1;
    background-color: #eee;
}

.stop-picker-header[b-8qoj5tp1qj],
.stop-picker-footer[b-8qoj5tp1qj] {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    max-width: 600px;
    background-color: var(--gastro-bg-panel);
    padding: 1rem;
    border-radius: var(--gastro-border-radius);
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
    text-align: center;
    z-index: 2001;
}

.stop-picker-header[b-8qoj5tp1qj] {
    top: 20px;
}

.stop-picker-footer[b-8qoj5tp1qj] {
    bottom: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.selected-count[b-8qoj5tp1qj] {
    font-weight: 500;
}

/* Style dla markerów na mapie selektora */
.picker-marker[b-8qoj5tp1qj] {
    background-color: var(--gastro-primary);
    border: 2px solid white;
    border-radius: 50%;
    width: 20px !important;
    height: 20px !important;
    box-shadow: 0 2px 5px rgba(0,0,0,0.3);
    cursor: pointer;
    transition: transform 0.2s ease, background-color 0.2s ease;
}

    .picker-marker:hover[b-8qoj5tp1qj] {
        transform: scale(1.2);
    }

    .picker-marker.selected[b-8qoj5tp1qj] {
        background-color: var(--gastro-accent);
    }

.stop-picker-map-container.custom-add-mode[b-8qoj5tp1qj],
.stop-picker-map-container.custom-add-mode .leaflet-grab[b-8qoj5tp1qj] {
    cursor: crosshair !important;
}

/* Modal do nazywania własnego punktu */
.custom-stop-modal-overlay[b-8qoj5tp1qj] {
    position: fixed;
    inset: 0;
    background-color: rgba(0,0,0,0.4);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2002;
}

.custom-stop-modal[b-8qoj5tp1qj] {
    background: white;
    padding: 1.5rem;
    border-radius: var(--gastro-border-radius);
    box-shadow: 0 5px 20px rgba(0,0,0,0.3);
    width: 90%;
    max-width: 400px;
}

/* Styl dla markerów niestandardowych (fioletowy dla odróżnienia) */
.custom-stop-marker[b-8qoj5tp1qj] {
    background-color: #9b59b6;
    border: 2px solid white;
    border-radius: 50%;
    width: 20px !important;
    height: 20px !important;
    box-shadow: 0 2px 5px rgba(0,0,0,0.3);
}
/* /Components/VibeVoteModal.razor.rz.scp.css */
.vibe-tags-grid[b-ra0zrxav8m] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
}

.tag-item[b-ra0zrxav8m] {
    padding: 0.5rem 1rem;
    border: 1px solid #dee2e6;
    border-radius: 20px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-weight: 500;
}

    .tag-item:hover[b-ra0zrxav8m] {
        background-color: #f8f9fa;
    }

    .tag-item.selected[b-ra0zrxav8m] {
        background-color: var(--gastro-primary);
        color: white;
        border-color: var(--gastro-primary);
    }
/* /Layout/FilterPanel.razor.rz.scp.css */
.filter-items-columns[b-41tqbf78yq] {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.5rem;
}

/* --- DODAJ TEN BLOK --- */
.form-check-label .filter-icon[b-41tqbf78yq] {
    width: 20px;
    height: 20px;
    margin-right: 8px;
    vertical-align: text-bottom;
}

 .accordion-item[b-41tqbf78yq] {
     border-color: var(--gastro-bg-light);
    
}


 .accordion-button[b-41tqbf78yq] {
     font-family: var(--gastro-font-heading);
     font-weight: 600;
     color: var(--gastro-text-dark);
    
}

    .accordion-button:not(.collapsed)[b-41tqbf78yq]::after {
         background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
        
    }

    
     .accordion-button:not(.collapsed)[b-41tqbf78yq] {
         background-color: var(--gastro-primary);
         color: var(--gastro-text-light);
        
    }


 .form-check-label[b-41tqbf78yq] {
     font-family: var(--gastro-font-body);
    
}

.filter-subcategory .btn-link[b-41tqbf78yq] {
     color: var(--gastro-text-dark);
     text-decoration: none;
     padding-left: 0;
    
}

.form-check-input:checked[b-41tqbf78yq] {
    background-color: var(--gastro-success);
    border-color: var(--gastro-success);
    
}

 /* Styl dla przełączników */
 .form-switch .form-check-input[b-41tqbf78yq] {
     background-color: var(--gastro-text-medium);
     border-color: var(--gastro-text-medium);
    
}


 .form-switch .form-check-input:checked[b-41tqbf78yq] {
     background-color: var(--gastro-success);
     border-color: var(--gastro-success);
    
}


 /* Dostosowanie przycisków na dole panelu */
 .btn-outline-danger[b-41tqbf78yq] {
     color: var(--gastro-danger);
     border-color: var(--gastro-danger);
    
}


 .btn-outline-danger:hover[b-41tqbf78yq] {
     color: white;
     background-color: var(--gastro-danger);
     border-color: var(--gastro-danger);
    
}


.btn-warning[b-41tqbf78yq] {
     background-color: var(--gastro-accent);
     border-color: var(--gastro-accent);
     color: white !important; /* Ważne, aby nadpisać domyślny czarny kolor */
}

.filter-panel-wrapper[b-41tqbf78yq] {
    position: relative;
    height: 100%;
}

.loading-overlay[b-41tqbf78yq] {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.7);
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
}
/* /Layout/MainLayout.razor.rz.scp.css */
.page[b-pkakakrqph] {
    display: flex;
    flex-direction: row;
    height: 100vh;
}

.side-panel[b-pkakakrqph] {
     display: flex;
     flex-direction: column;
     height: 100%;
     background-color: var(--gastro-bg-panel);
     overflow: hidden; /* Zapobiega "wylewaniu się" treści */
    
}

.side-panel-content[b-pkakakrqph] {
     flex-grow: 1; /* Pozwala treści zająć całą dostępną przestrzeń */
     overflow-y: auto; /* To jest najważniejsze - dodaje pasek przewijania! */
     padding: 1rem;
}

.sidebar[b-pkakakrqph] {
    width: 250px;
    background-color: var(--gastro-primary);
    color: white;
    box-shadow: 2px 0 5px rgba(0,0,0,0.1);
    z-index: 100;
    flex-shrink: 0;
}

main[b-pkakakrqph] {
    flex-grow: 1;
    height: 100vh;
    overflow: hidden;
    position: relative;
    min-width: 0;
}

.content[b-pkakakrqph] {
    height: 100%;
    overflow-y: auto;
    background-color: var(--gastro-bg-light);
}

@media (max-width: 991.98px) { /* Poprawiony breakpoint */
    .sidebar[b-pkakakrqph] {
        display: none;
    }

    .page[b-pkakakrqph] {
        flex-direction: column;
    }

    .content[b-pkakakrqph] {
        padding-bottom: 60px; /* Miejsce na dolne menu */
    }
}

 .side-panel-header[b-pkakakrqph],
 .side-panel-footer[b-pkakakrqph] {
     flex-shrink: 0;
     padding: 1rem;
     background-color: var(--gastro-bg-panel);
     z-index: 10;
    
}


 .side-panel-header[b-pkakakrqph] {
     display: flex;
     justify-content: space-between;
     align-items: center;
     border-bottom: 1px solid var(--gastro-bg-light);
    
}


 .side-panel-footer[b-pkakakrqph] {
     border-top: 1px solid var(--gastro-bg-light);
     box-shadow: 0 -2px 5px rgba(0,0,0,0.05);
    
}

.footer-actions[b-pkakakrqph] {
     display: flex;
     align-items: center;
     gap: 0.5rem;
    
}


    .footer-actions .btn-link[b-pkakakrqph] {
        color: var(--gastro-text-medium);
        text-decoration: none;
        flex-shrink: 1;
        white-space: nowrap;
        padding-left: 0;
        padding-right: 0;
    }

    .footer-actions .btn-secondary[b-pkakakrqph] {
        flex-shrink: 0;
        
    }


    .footer-actions .btn-group[b-pkakakrqph],
    .footer-actions .btn-warning[b-pkakakrqph] {
        flex-grow: 1;
    }


 .btn-icon-vertical[b-pkakakrqph] {
     display: flex;
     flex-direction: column;
     align-items: center;
     justify-content: center;
     gap: 0.25rem;
     padding: 0.5rem;
    
}

    
     .btn-icon-vertical i[b-pkakakrqph] {
         font-size: 1.25rem;
        
    }
/* /Layout/NavMenu.razor.rz.scp.css */
.nav-container[b-zi649rmqr5] {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.nav-brand[b-zi649rmqr5] {
    padding: 1.5rem 1rem;
    font-size: 2rem;
    font-family: var(--gastro-font-heading);
    font-weight: 700;
    color: white;
    text-align: center;
    cursor: pointer;
}

/* Zwiększenie specyficzności, aby nadpisać domyślne style .nav-link */
.sidebar .nav-item[b-zi649rmqr5] {
    padding: 0 0.5rem;
    
}

    .sidebar .nav-item .nav-link[b-zi649rmqr5] {
        display: flex;
        align-items: center;
        gap: 0.75rem;
        padding: 0.75rem 1rem;
     
        border-radius: var(--gastro-border-radius);
        transition: all 0.2s ease-in-out;
        font-family: var(--gastro-font-heading);
        font-weight: 500;
      
    }

        .sidebar .nav-item .nav-link:hover[b-zi649rmqr5] {
            background-color: rgba(255, 255, 255, 0.1);
   
        }

        .sidebar .nav-item .nav-link.active[b-zi649rmqr5] {
            background-color: var(--gastro-accent);
            box-shadow: 0 4px 8px rgba(0,0,0,0.2);
        }

        .sidebar .nav-item .nav-link i[b-zi649rmqr5] {
            font-size: 1.2rem;
        }


.user-profile-summary[b-zi649rmqr5] {
    margin-top: auto; /* Wypycha profil na dół */
    padding: 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    text-align: center;
    color: var(--gastro-text-light); /* BIAŁY TEKST */
}

.profile-link[b-zi649rmqr5] {
    color: var(--gastro-text-light); /* BIAŁY TEKST */
    text-decoration: none;
}

.profile-name[b-zi649rmqr5] {
    font-family: var(--gastro-font-heading);
    font-size: 1.1rem;
    font-weight: 600;
}

.profile-level[b-zi649rmqr5] {
    font-size: 0.85rem;
    color: rgba(255, 255, 255, 0.7);
}

.stats-bar[b-zi649rmqr5] {
    display: flex;
    justify-content: space-around;
    margin-top: 0.75rem;
}

.stat[b-zi649rmqr5] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.9rem;
}

/* Style dla sekcji logowania dla gości */
.guest-actions[b-zi649rmqr5] {
    margin-top: auto; /* Wypycha na dół */
    padding: 1.5rem 1rem;
    border-top: 1px solid rgba(255, 255, 255, 0.2);
    text-align: center;
    background-color: rgba(0,0,0,0.1);
}

    .guest-actions p[b-zi649rmqr5] {
        font-size: 0.9rem;
        color: rgba(255, 255, 255, 0.8);
        margin-bottom: 1rem;
    }
/* /Pages/AddDishReview.razor.rz.scp.css */
.d-none[b-f8m68qthht] {
    display: none !important;
}

.image-preview[b-f8m68qthht] {
    position: relative;
    display: inline-block;
    border: 2px solid #ddd;
    border-radius: var(--gastro-border-radius);
    padding: 0.25rem;
}

    .image-preview img[b-f8m68qthht] {
        max-width: 150px;
        max-height: 150px;
        border-radius: var(--gastro-border-radius);
    }

    .image-preview .btn-close[b-f8m68qthht] {
        position: absolute;
        top: -10px;
        right: -10px;
        background-color: white;
        border-radius: 50%;
        opacity: 1;
        box-shadow: 0 1px 3px rgba(0,0,0,0.2);
    }
/* /Pages/AddPlace.razor.rz.scp.css */
/* Ten kontener organizuje cały layout strony na 3 części: nagłówek, treść i stopkę */
.add-place-container[b-6tmp7lkuih] {
    display: flex;
    flex-direction: column;
    padding: 0 1rem;
}

.form-header[b-6tmp7lkuih] {
    padding: 0 0 1rem 0;
    margin-bottom: 1.5rem;
    border-bottom: 1px solid var(--gastro-bg-light);
    
}


.form-footer[b-6tmp7lkuih] {
    /* Używamy 'sticky', aby stopka "przykleiła się" do dołu widoku */
    position: sticky; 
    bottom: -1rem; /* Ujemny margines, aby skompensować padding rodzica */
    padding: 1rem;
    margin: 1rem -1rem -1rem -1rem; /* Magia do rozciągnięcia tła na całą szerokość */
    border-top: 1px solid #dee2e6;
    background-color: #fff;
    z-index: 10; /* Upewniamy się, że stopka jest na wierzchu */
}

.accordion-button:not(.collapsed)[b-6tmp7lkuih] {
    color: var(--gastro-text-light);
    background-color: var(--gastro-primary);
    
}

    .accordion-button:not(.collapsed)[b-6tmp7lkuih]::after {
         background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='white'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
        
    }

 .form-switch .form-check-input:checked[b-6tmp7lkuih] {
     background-color: var(--gastro-success);
     border-color: var(--gastro-success);
    
}
/* /Pages/AdminEditPlace.razor.rz.scp.css */
.admin-edit-container[b-qpv1eeq665] {
    display: flex;
    flex-direction: column;
    height: 100%;
}

.form-header[b-qpv1eeq665] {
    padding: 0 1rem 1rem 1rem;
    flex-shrink: 0;
}

.form-content-scrollable[b-qpv1eeq665] {
    flex-grow: 1;
    overflow-y: auto;
    padding: 0 1rem;
}

.form-footer[b-qpv1eeq665] {
    flex-shrink: 0;
    padding: 1rem;
    border-top: 1px solid #dee2e6;
    background-color: #fff;
    position: sticky;
    bottom: -1rem;
    margin: 1rem -1rem -1rem -1rem;
    z-index: 10;
}
/* /Pages/AdminEditTrail.razor.rz.scp.css */
.stops-list-admin[b-1p3vg8d3s5] {
    max-height: 500px;
    overflow-y: auto;
    border: 1px solid #dee2e6;
    border-radius: 0.25rem;
    padding: 0.5rem;
}

.stop-card-admin[b-1p3vg8d3s5] {
    padding: 0.5rem;
    border: 1px solid #e9ecef;
    border-radius: 0.25rem;
    margin-bottom: 0.5rem;
}

.stop-card-header[b-1p3vg8d3s5] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
}
/* /Pages/DishReviews.razor.rz.scp.css */
.dish-reviews-page[b-cr8im2pubc] {
    padding: 1.5rem;
}

.review-card[b-cr8im2pubc] {
    background-color: var(--gastro-bg-panel);
    border: 1px solid var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    margin-bottom: 1rem;
    box-shadow: 0 2px 5px rgba(0,0,0,0.05);
}

.review-header[b-cr8im2pubc] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--gastro-bg-light);
}

.author-info[b-cr8im2pubc] {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.avatar[b-cr8im2pubc] {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: var(--gastro-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
}

.rating-info .star-icon[b-cr8im2pubc] {
    color: #ffc107;
    font-size: 1.1rem;
}

.review-body[b-cr8im2pubc] {
    padding: 1rem;
    padding-bottom: 0.5rem;
}

.review-image[b-cr8im2pubc] {
    max-width: 300px;
    margin-bottom: 1rem;
    border-radius: var(--gastro-border-radius);
    overflow: hidden;
    cursor: pointer;
}

    .review-image img[b-cr8im2pubc] {
        width: 100%;
        height: auto;
        display: block;
    }

.review-content[b-cr8im2pubc] {
    line-height: 1.6;
    color: var(--gastro-text-dark);
    margin-bottom: 0;
}

.review-footer[b-cr8im2pubc] {
    padding: 0.5rem 1rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.review-content-empty[b-cr8im2pubc] {
    font-style: italic;
    color: var(--gastro-text-medium);
    padding: 1rem;
    text-align: center;
    background-color: #f8f9fa;
    border-radius: var(--gastro-border-radius);
    margin: 0;
}

.review-image[b-cr8im2pubc] {
    max-width: 300px;
    margin-bottom: 1rem;
    border-radius: var(--gastro-border-radius);
    overflow: hidden;
    cursor: pointer; /* Dodajemy kursor, by wskazać, że można kliknąć */
}

.reply-image[b-cr8im2pubc] {
    max-width: 150px;
}

/* Style dla pełnoekranowego podglądu (bez zmian) */
.image-viewer-overlay[b-cr8im2pubc] {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 4000;
    padding: 1rem;
    cursor: pointer;
}

.fullscreen-image[b-cr8im2pubc] {
    max-width: 95vw;
    max-height: 95vh;
    object-fit: contain;
    border-radius: var(--gastro-border-radius);
}

.review-footer[b-cr8im2pubc] {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.btn-reply[b-cr8im2pubc] {
    background: none;
    border: none;
    font-size: 0.8rem;
    color: var(--gastro-primary);
    font-weight: 600;
    padding: 0;
    cursor: pointer;
}

.reply-form-container[b-cr8im2pubc] {
    padding: 0.75rem 1rem;
    background-color: #f8f9fa;
    border-top: 1px solid var(--gastro-bg-light);
}

    .reply-form-container .input-group[b-cr8im2pubc] {
        display: flex;
    }

    .reply-form-container textarea[b-cr8im2pubc] {
        flex-grow: 1;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .reply-form-container button[b-cr8im2pubc] {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

.replies-wrapper[b-cr8im2pubc] {
    margin: 0 1rem 1rem 1rem; /* Marginesy góra/dół/boki */
    padding-left: 1rem;
    border-left: 3px solid #e9ecef;
}


.reply-item[b-cr8im2pubc] {
    display: flex;
    gap: 0.5rem;
    padding: 0.75rem;
    background-color: #f0f2f5; /* Lekko ciemniejsze tło dla odróżnienia */
    border-radius: var(--gastro-border-radius);
}

    .reply-item:not(:last-child)[b-cr8im2pubc] {
        margin-bottom: 0.5rem;
    }

.reply-avatar[b-cr8im2pubc] {
    width: 28px;
    height: 28px;
    font-size: 1rem;
}

.reply-main-content[b-cr8im2pubc] {
    flex-grow: 1; /* Główna treść zajmuje resztę miejsca */
}


.reply-content p[b-cr8im2pubc] {
    margin-bottom: 0.25rem;
    font-size: 0.9rem;
}

.reply-content small[b-cr8im2pubc] {
    font-size: 0.75rem;
}

/* NOWY STYL: Ikona odpowiedzi */
.reply-icon[b-cr8im2pubc] {
    transform: scaleX(-1); /* Odwraca ikonę w poziomie */
    color: var(--gastro-text-medium);
    font-size: 1.2rem;
    align-self: flex-start; /* Dodatkowa poprawka, by ikona była na samej górze */
    margin-top: 12px; /* Drobne przesunięcie dla idealnego wyglądu */
}
/* /Pages/Events.razor.rz.scp.css */
.events-page[b-xds0c0ja58] {
    padding: 1.5rem;
}

.page-header[b-xds0c0ja58] {
    text-align: center;
    margin-bottom: 2rem;
}

.events-filter-panel .card-body[b-xds0c0ja58] {
    padding: 1.5rem;
}

.category-pills[b-xds0c0ja58] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.events-grid[b-xds0c0ja58] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 1.5rem;
}

.event-card[b-xds0c0ja58] {
    background: #fff;
    border-radius: var(--gastro-border-radius);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    display: flex;
    flex-direction: column;
    overflow: hidden;
    transition: transform 0.2s ease-in-out, box-shadow 0.2s ease-in-out;
}

    .event-card:hover[b-xds0c0ja58] {
        transform: translateY(-5px);
        box-shadow: 0 8px 20px rgba(0,0,0,0.12);
    }

.event-card-img[b-xds0c0ja58] {
    height: 160px;
    background-color: var(--gastro-primary-dark);
    background-size: cover;
    background-position: center;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
}

.placeholder-text[b-xds0c0ja58] {
    font-family: var(--gastro-font-heading);
    font-size: 1.5rem;
    color: white;
    background-color: rgba(0,0,0,0.4);
    padding: 0.5rem 1rem;
    border-radius: var(--gastro-border-radius);
}

.place-link-badge[b-xds0c0ja58] {
    position: absolute;
    bottom: 0.75rem;
    left: 0.75rem;
    background-color: rgba(0, 0, 0, 0.7);
    color: white;
    padding: 0.25rem 0.6rem;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 500;
    backdrop-filter: blur(4px);
    text-decoration: none;
    transition: background-color 0.2s ease;
}

    .place-link-badge:hover[b-xds0c0ja58] {
        background-color: rgba(0, 0, 0, 0.9);
        color: white;
    }

.event-card-body[b-xds0c0ja58] {
    padding: 1rem;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
}

.event-card-header[b-xds0c0ja58] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 0.75rem;
}

.event-title[b-xds0c0ja58] {
    font-family: var(--gastro-font-heading);
    margin: 0;
    font-size: 1.2rem;
    margin-right: 0.5rem;
}

.event-description[b-xds0c0ja58] {
    font-size: 0.9rem;
    color: var(--gastro-text-dark);
    flex-grow: 1;
    margin-bottom: 1rem;
}

.event-card-footer[b-xds0c0ja58] {
    padding: 0.75rem 1rem;
    background-color: #f8f9fa;
    border-top: 1px solid #dee2e6;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--gastro-primary-dark);
    text-align: right;
}

.events-filter-panel[b-xds0c0ja58] {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
}


.event-location[b-xds0c0ja58] {
    font-size: 0.9rem;
    font-weight: 500;
    color: var(--gastro-text-medium);
    margin-bottom: 1rem;
}

    .event-location a[b-xds0c0ja58] {
        text-decoration: none;
        color: var(--gastro-primary);
    }

        .event-location a:hover[b-xds0c0ja58] {
            text-decoration: underline;
        }
/* /Pages/Home.razor.rz.scp.css */
/* --- Style dla kontenera mapy (MUSZĄ TU BYĆ) --- */
#map[b-quio1jj8db] {
    height: 100%;
    width: 100%;
}

/* Kontener na wszystkie elementy interfejsu na mapie */
.map-ui-container[b-quio1jj8db] {
    position: absolute;
    top: 10px;
    left: 10px;
    right: 10px;
    bottom: 10px;
    z-index: 1000;
    pointer-events: none;
}

.place-preview-container[b-quio1jj8db] {
    position: absolute;
    bottom: 0; /* Domyślna pozycja dla widoku desktopowego */
    left: 0;
    right: 0;
    height: 50vh; /* Panel zajmuje połowę wysokości ekranu */
    max-height: 450px; /* Ale nie więcej niż 450px na bardzo wysokich ekranach */
    z-index: 1001; /* Upewnij się, że panel jest nad mapą */
    transform: translateY(100%); /* Domyślnie schowany pod ekranem */
    transition: transform 0.3s ease-in-out;
    box-shadow: 0 -4px 12px rgba(0, 0, 0, 0.15); /* Cień dla lepszego oddzielenia od mapy */
}

.place-preview-container.visible[b-quio1jj8db] {
    transform: translateY(0); /* Pokaż panel, przesuwając go w górę */
}

/* --- NOWE, NIEZALEŻNE STYLE DLA WYSZUKIWARKI --- */
.search-bar-wrapper[b-quio1jj8db] {
    position: absolute;
    top: 65px; /* Pozycja pod przyciskami zoom */
    left: 0;
    display: flex;
    align-items: center;
    height: 34px;
    max-width: 34px;
    background-color: #fff;
    border-radius: 4px;
   
    transition: max-width 0.2s ease-in-out;
    pointer-events: auto;
    border: 2px solid rgba(0, 0, 0, 0.2);
    background-clip: padding-box;
}

    .search-bar-wrapper.active[b-quio1jj8db] {
        max-width: 350px;
    }

.search-toggle-btn[b-quio1jj8db] {
    flex-shrink: 0;
    width: 30px;
    height: 100%;
    padding: 0;
    border: none;
    background-color: transparent;
    color: #333;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.search-input-container[b-quio1jj8db] {
    flex-grow: 1;
    overflow: hidden;
    height: 100%;
}

    .search-input-container .form-control[b-quio1jj8db] {
        border: none;
        box-shadow: none;
        height: 100%;
        padding: 0 10px;
        background-color: transparent;
        font-size: 14px;
        border-radius: 0 4px 4px 0;
    }

/* Wrapper na listę sugestii */
.suggestion-box-wrapper[b-quio1jj8db] {
    position: absolute;
    top: 115px;
    left: 0;
    width: 100%;
    max-width: 350px;
    pointer-events: auto;
}

.suggestion-box[b-quio1jj8db] {
    width: 100%;
    max-height: 40vh;
    overflow-y: auto;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.2);
}

/* Pływające przyciski (FAB) */
.fab-locate-btn[b-quio1jj8db], .fab-filter-btn[b-quio1jj8db] {
    position: absolute;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    box-shadow: 0 2px 6px rgba(0,0,0,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: auto;
    border: 1px solid #ccc;
    background-color: #fff;
}

/* Przycisk filtrów w prawym górnym rogu */
.fab-filter-btn[b-quio1jj8db] {
    top: 0;
    right: 0;
}

/* Przycisk geolokalizacji w prawym dolnym rogu */
.fab-locate-btn[b-quio1jj8db] {
    bottom: 0;
    right: 0;
}

/* --- Style dla ikon --- */
.bi[b-quio1jj8db] {
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}

.bi-search[b-quio1jj8db] {
    width: 1.2em;
    height: 1.2em;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-search' viewBox='0 0 16 16'%3e%3cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3e%3c/svg%3e");
}

.bi-crosshair[b-quio1jj8db], .bi-filter[b-quio1jj8db] {
    width: 1.2em;
    height: 1.2em;
}

.bi-crosshair[b-quio1jj8db] {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-crosshair' viewBox='0 0 16 16'%3e%3cpath d='M8.5.5a.5.5 0 0 0-1 0v.518A7 7 0 0 0 1.018 7.5H.5a.5.5 0 0 0 0 1h.518A7 7 0 0 0 7.5 14.982v.518a.5.5 0 0 0 1 0v-.518A7 7 0 0 0 14.982 8.5h.518a.5.5 0 0 0 0-1h-.518A7 7 0 0 0 8.5 1.018V.5Zm-6.48 7A6 6 0 0 1 7.5 2.02v5.48a.5.5 0 0 0 1 0V2.02a6 6 0 0 1 5.48 5.48h-5.48a.5.5 0 0 0 0 1h5.48A6 6 0 0 1 8.5 13.98v-5.48a.5.5 0 0 0-1 0v5.48A6 6 0 0 1 2.02 8.5h5.48a.5.5 0 0 0 0-1H2.02Z'/%3e%3c/svg%3e");
}

.bi-filter[b-quio1jj8db] {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='currentColor' class='bi bi-filter' viewBox='0 0 16 16'%3e%3cpath d='M6 10.5a.5.5 0 0 1 .5-.5h3a.5.5 0 0 1 0 1h-3a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h7a.5.5 0 0 1 0 1h-7a.5.5 0 0 1-.5-.5zm-2-3a.5.5 0 0 1 .5-.5h11a.5.5 0 0 1 0 1h-11a.5.5 0 0 1-.5-.5z'/%3e%3c/svg%3e");
}

/* --- Style dla przycisku geolokalizacji w stanie ładowania --- */
.fab-locate-btn.locating[b-quio1jj8db] {
    background-color: #e9ecef;
}

.fab-locate-btn .spinner-border[b-quio1jj8db] {
    width: 1.5rem;
    height: 1.5rem;
    border-width: .2em;
    color: #0d6efd;
}

/* GRAAAAAAAAAAAAAAAa */
.explorer-mode-toggle[b-quio1jj8db] {
    position: absolute;
    top: 10px;
    left: 10px; /* ZMIANA: z 'right' na 'left' */
    z-index: 1000;
    background-color: rgba(255, 255, 255, 0.8);
    padding: 0.5rem 1rem;
    border-radius: 8px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

.loading-overlay[b-quio1jj8db] {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.7); /* Półprzezroczyste tło */
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 2000; /* Upewnij się, że jest nad wszystkim */
}

    .loading-overlay p[b-quio1jj8db] {
        margin-top: 15px;
        font-size: 1.1em;
        color: #333;
    }

.map-notification[b-quio1jj8db] {
    position: absolute;
    top: -100px; /* Domyślnie schowany nad ekranem */
    left: 50%;
    transform: translateX(-50%);
    background-color: rgba(33, 37, 41, 0.9); /* Ciemne tło */
    color: white;
    padding: 10px 20px;
    border-radius: 20px;
    z-index: 2001; /* Nad spinnerem ładowania */
    transition: top 0.3s ease-in-out;
    box-shadow: 0 4px 8px rgba(0,0,0,0.2);
}

    .map-notification.show[b-quio1jj8db] {
        top: 20px; /* Wjeżdża na ekran */
    }

/* NOWE STYLE DLA KONTROLEK NA MAPIE */
.top-map-controls[b-quio1jj8db] {
    /* Utrzymanie stabilnej pozycji */
    position: fixed;
    top: 10px;
    /* ANCHORING: Przypięcie do prawej krawędzi z bardzo małym marginesem */
    right: 5px; /* Zmniejszamy margines do 5px, aby był bliżej krawędzi */
    /* OGRANICZENIE SZEROKOŚCI: KLUCZOWE! */
    left: auto; /* Anuluje kotwiczenie po lewej */
    width: fit-content; /* Sprawia, że pasek jest tak wąski, jak to możliwe (dopasowany do zawartości) */
    max-width: 500px;
    /* Z-INDEX: Pozostawiamy na 1030, aby panele boczne były nad nim */
    z-index: 1030;
    /* Flexbox */
    display: flex;
    /* Zawartość jest wyrównana do środka/prawa */
    align-items: center;
    gap: 10px; /* Dodajemy odstęp między elementami, jeśli dzwonek i filtry są obok siebie */
    /* WIZUALNE */
    background-color: white;
    border: 1px solid #e0e0e0;
    padding: 8px 15px;
    border-radius: 20px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

    .top-map-controls .form-check-input[b-quio1jj8db] {
        width: 3em;
        height: 1.5em;
    }

    .top-map-controls .form-check-label[b-quio1jj8db] {
        font-size: 1.2rem;
    }

    .top-map-controls .form-check-input:checked[b-quio1jj8db] {
        background-color: var(--gastro-primary);
        border-color: var(--gastro-primary);
    }

    .top-map-controls .btn-light[b-quio1jj8db] {
        display: flex;
        align-items: center;
        gap: 0.5rem;
        border-radius: var(--gastro-border-radius);
        padding: 0.5rem 1rem;
        font-weight: 500;
    }

    .top-map-controls .auth-btn[b-quio1jj8db] {
        text-shadow: 1px 1px 2px rgba(0, 0, 0, 0.5);
        box-shadow: 0 2px 4px rgba(0,0,0,0.2);
        font-weight: 500;
    }

.mobile-game-bar[b-quio1jj8db] {
    display: none; /* Domyślnie ukryty */
}

@media (min-width: 769px) {
    /* Jeśli menu boczne jest widoczne, musimy dodać margines, aby pasek się nie schował */
    .top-map-controls[b-quio1jj8db] {
        /* KLUCZOWA KOREKTA: Wymuszamy, by kotwiczenie do prawej było nadrzędne */
        right: 5px !important;
        /* Wymuszamy, by nie miał lewego kotwiczenia (może być wynikiem walki CSS) */
        left: auto !important;
        /* Upewniamy się, że szerokość jest dopasowana do zawartości */
        width: fit-content !important;
    }
}

@media (max-width: 768px) {
    .mobile-game-bar[b-quio1jj8db] {
        position: fixed;
        top: 0;
        left: 0;
        right: 0;
        height: 3.5rem;
        padding: 0 1rem;
        background-color: var(--gastro-primary);
        color: var(--gastro-text-light);
        z-index: 1002;
        display: flex;
        align-items: center;
        gap: 1rem;
        font-family: var(--gastro-font-body);
        font-weight: 500;
        box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    }

        .mobile-game-bar .game-user-info[b-quio1jj8db] {
            display: flex;
            flex-direction: column;
            line-height: 1;
            margin-right: auto; /* Wypycha statystyki i plecak w prawo */
        }

            .mobile-game-bar .game-user-info .username[b-quio1jj8db] {
                font-family: var(--gastro-font-heading);
                font-size: 1rem;
                font-weight: 700;
            }

            .mobile-game-bar .game-user-info .level[b-quio1jj8db] {
                font-size: 0.75rem;
                color: rgba(255, 255, 255, 0.7);
            }

        .mobile-game-bar .stats[b-quio1jj8db] {
            display: flex;
            gap: 0.75rem;
        }

        .mobile-game-bar .stat[b-quio1jj8db] {
            display: flex;
            align-items: center;
            gap: 0.25rem;
            font-size: 0.9rem;
        }


}
/* /Pages/PlaceDetails.razor.rz.scp.css */
.place-details-page[b-ta5f6b64ma] {
    padding: 1rem;
    /* position: relative; */
}

.details-card[b-ta5f6b64ma] {
    background-color: var(--gastro-bg-panel);
    /* padding: 1.5rem; */
    border-radius: var(--gastro-border-radius);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    overflow: hidden; /* Zapobiega "wylewaniu się" tła nagłówka */
}

.details-header[b-ta5f6b64ma] {
    display: flex;
    background-color: var(--gastro-primary);
    color: var(--gastro-text-light);
    padding: 1.5rem;
}

    .details-header .header-main-content[b-ta5f6b64ma] {
        flex-grow: 1; /* Główna treść zajmuje całą dostępną przestrzeń */
    }

    .details-header .header-action-content[b-ta5f6b64ma] {
        flex-basis: 16.67%; /* Szerokość taka sama jak col-lg-3 */
        flex-shrink: 0;
        display: flex;
        justify-content: center; /* Wyśrodkowanie przycisku w poziomie */
        align-items: center; /* Wyśrodkowanie przycisku w pionie */
        margin-left: 1rem;
    }

    .details-header h3[b-ta5f6b64ma] {
        color: white;
        margin-bottom: 0.25rem;
    }

    .details-header .text-muted[b-ta5f6b64ma] {
        color: rgba(255, 255, 255, 0.7) !important;
    }

.rating-column-content[b-ta5f6b64ma] {
    padding-top: 1.5rem; /* Ten padding "popycha" sekcję w dół */
}
/* NOWA ZAWARTOŚĆ KARTY */
.details-body[b-ta5f6b64ma] {
    padding: 1.5rem;
}

h3[b-ta5f6b64ma], h4[b-ta5f6b64ma] {
    font-family: var(--gastro-font-heading);
    color: var(--gastro-text-dark);
}

.section-title[b-ta5f6b64ma] {
    font-family: var(--gastro-font-heading);
    font-weight: 600;
    color: var(--gastro-text-dark);
    margin-bottom: 0.75rem;
}

.text-sm[b-ta5f6b64ma] {
    font-size: 0.875rem;
}

.delivery-icons-wrapper[b-ta5f6b64ma] {
    display: flex;
    gap: 0.5rem;
}

.delivery-icon-box[b-ta5f6b64ma] {
    width: 4rem;
    height: 4rem;
    background-color: var(--gastro-bg-light);
    border: 2px dashed #dee2e6;
    border-radius: 0.75rem;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0.5rem;
}

    .delivery-icon-box.no-data-placeholder[b-ta5f6b64ma] {
        color: var(--gastro-text-medium);
        font-size: 0.8rem;
        background-color: transparent;
        cursor: default !important;
    }

.delivery-icon[b-ta5f6b64ma] {
    height: 100%;
    width: 100%;
    object-fit: contain;
}

.rating-badge[b-ta5f6b64ma] {
    font-size: 1rem;
    padding: 0.5em 0.75em;
    background-color: #ffc107;
    color: #000 !important;
}

.opening-hours-wrapper[b-ta5f6b64ma] {
    background-color: #f8f9fa;
    border-radius: var(--gastro-border-radius);
    border: 1px solid var(--gastro-bg-light);
    overflow: hidden;
}

.opening-hours-row[b-ta5f6b64ma] {
    display: flex;
    justify-content: space-between;
    padding: 0.5rem 0.75rem;
    font-size: 0.9rem;
    border-bottom: 1px solid var(--gastro-bg-light);
}

    .opening-hours-row:last-child[b-ta5f6b64ma] {
        border-bottom: none;
    }

    .opening-hours-row.today[b-ta5f6b64ma] {
        background-color: #e9ecef;
        border-left: 4px solid var(--gastro-primary);
        padding-left: calc(0.75rem - 4px);
    }

    .opening-hours-row .day-name[b-ta5f6b64ma] {
        font-weight: 500;
    }

    .opening-hours-row .day-hours.closed[b-ta5f6b64ma] {
        color: var(--gastro-danger);
        font-weight: 500;
    }

.toggle-hours-btn[b-ta5f6b64ma] {
    width: 100%;
    text-align: center;
    padding: 0.5rem;
    font-size: 0.85rem;
    color: var(--gastro-primary);
    background-color: transparent;
    border: none;
    font-weight: 500;
    cursor: pointer;
}

    .toggle-hours-btn:hover[b-ta5f6b64ma] {
        background-color: #e9ecef;
    }

    .toggle-hours-btn i[b-ta5f6b64ma] {
        font-size: 0.7rem;
        vertical-align: middle;
    }

.details-footer[b-ta5f6b64ma] {
    border-top: 1px solid var(--gastro-bg-light);
    margin-top: 1.5rem;
    padding-top: 1.5rem;
}

.comment-card[b-ta5f6b64ma] {
    border: 1px solid var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    padding: 1rem;
    margin-bottom: 1rem;
}

    .comment-card:last-of-type[b-ta5f6b64ma] {
        margin-bottom: 0;
    }

.btn-back[b-ta5f6b64ma] {
    flex-shrink: 0;
    margin-left: 1rem;
    align-items: center;
    /* Usunięto margin-bottom, bo align-items: center załatwia sprawę */
}

.details-summary[b-ta5f6b64ma] {
    margin-bottom: 1.5rem;
}



.description-box[b-ta5f6b64ma] {
    background-color: var(--gastro-bg-panel);
    padding: 1rem;
    border-radius: var(--gastro-border-radius);
    border: 1px solid var(--gastro-bg-light);
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.place-description[b-ta5f6b64ma] {
    color: #495057; /* Ciemniejszy, ale wciąż stonowany szary */
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 0;
}

/* NOWE STYLE - START */
.star-rating .star-icon[b-ta5f6b64ma] {
    color: #ffc107; /* Złoty kolor gwiazdek */
    font-size: 1.1rem;
    margin-right: 2px;
}

.rating-value[b-ta5f6b64ma] {
    font-weight: 700;
    color: var(--gastro-text-dark);
}


.comment-thread[b-ta5f6b64ma] {
    position: relative;
}

.comment-container[b-ta5f6b64ma] {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.comment-avatar[b-ta5f6b64ma] {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--gastro-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 1.2rem;
    font-family: var(--gastro-font-heading);
}

.comment-card[b-ta5f6b64ma] {
    flex-grow: 1;
    background-color: var(--gastro-bg-panel);
    border: 1px solid var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    padding: 0.75rem 1rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.comment-header[b-ta5f6b64ma] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.comment-author[b-ta5f6b64ma] {
    font-weight: 600;
    color: var(--gastro-text-dark);
}

.comment-date[b-ta5f6b64ma] {
    font-size: 0.75rem;
    color: var(--gastro-text-medium);
}

.comment-card .card-body[b-ta5f6b64ma] {
    padding: 0;
}

.comment-card .card-text[b-ta5f6b64ma] {
    margin-bottom: 0.5rem;
    color: var(--gastro-text-dark);
    line-height: 1.6;
}

.comment-footer[b-ta5f6b64ma] {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    font-size: 0.8rem;
    color: var(--gastro-text-medium);
    margin-top: 0.75rem;
}

.comment-actions[b-ta5f6b64ma] {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.btn-reply[b-ta5f6b64ma], .btn-like[b-ta5f6b64ma] {
    background: none;
    border: none;
    font-size: 0.8rem;
    color: var(--gastro-primary);
    font-weight: 600;
    padding: 0;
    cursor: pointer;
}

.btn-like[b-ta5f6b64ma] {
    color: var(--gastro-text-medium);
    padding: 0.25rem 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: 20px;
    transition: all 0.2s ease;
}

    .btn-like:hover[b-ta5f6b64ma] {
        background-color: #f8d7da;
        color: var(--gastro-danger);
    }

    .btn-like.liked[b-ta5f6b64ma] {
        color: var(--gastro-danger);
        font-weight: 600;
    }

.replies-container[b-ta5f6b64ma] {
    padding-left: 20px;
    margin-left: 20px;
    border-left: 2px solid #e9ecef;
    margin-top: 1rem;
}

.reply-form[b-ta5f6b64ma] {
    padding-left: 55px;
    padding-top: 0.5rem;
    margin-bottom: 1rem;
}

/* Style obrazków */
.image-preview[b-ta5f6b64ma] {
    position: relative;
    display: inline-block;
}

    .image-preview img[b-ta5f6b64ma] {
        max-width: 120px;
        max-height: 120px;
        border-radius: var(--gastro-border-radius);
        border: 2px solid #ddd;
    }

    .image-preview .btn-close[b-ta5f6b64ma] {
        position: absolute;
        top: -8px;
        right: -8px;
        background-color: white;
        border-radius: 50%;
        opacity: 1;
        box-shadow: 0 1px 3px rgba(0,0,0,0.2);
    }

.comment-image-thumb[b-ta5f6b64ma] {
    width: 150px;
    height: 150px;
    margin-bottom: 0.75rem;
    border-radius: var(--gastro-border-radius);
    overflow: hidden;
    cursor: pointer;
    border: 1px solid #eee;
}

    .comment-image-thumb img[b-ta5f6b64ma] {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transition: transform 0.2s ease-in-out;
    }

    .comment-image-thumb:hover img[b-ta5f6b64ma] {
        transform: scale(1.05);
    }

.image-viewer-overlay[b-ta5f6b64ma] {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.85);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 4000;
    padding: 1rem;
    cursor: pointer;
}

.fullscreen-image[b-ta5f6b64ma] {
    max-width: 95vw;
    max-height: 95vh;
    object-fit: contain;
    border-radius: var(--gastro-border-radius);
}

/* --- NOWE STYLE DLA SEKCJI KOMENTARZY --- */

.comment-form-wrapper[b-ta5f6b64ma] {
    background-color: var(--gastro-bg-panel);
    border: 1px solid var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    padding: 1rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
    margin-bottom: 1.5rem;
}

.comment-form-actions[b-ta5f6b64ma] {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 0.75rem;
}

/* Ukrywamy domyślny, brzydki input pliku */
.d-none[b-ta5f6b64ma] {
    display: none !important;
}

/* Stylizujemy etykietę, aby wyglądała jak przycisk */
.btn-outline-secondary[b-ta5f6b64ma] {
    color: #6c757d;
    border-color: #6c757d;
}

    .btn-outline-secondary:hover[b-ta5f6b64ma] {
        color: #fff;
        background-color: #6c757d;
        border-color: #6c757d;
    }

.file-status-text[b-ta5f6b64ma] {
    margin-left: 0.75rem;
    font-size: 0.875rem;
    color: var(--gastro-text-medium);
}

/* Poprawiamy odstęp awatara - margines po prawej */
.comment-avatar[b-ta5f6b64ma] {
    margin-right: 0.75rem;
    flex-shrink: 0;
}

/* Poprawiamy błąd z poprzedniej iteracji - usunięcie podwójnych stylów */
.comment-card[b-ta5f6b64ma] {
    flex-grow: 1;
    background-color: var(--gastro-bg-panel);
    border: 1px solid var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    padding: 0.75rem 1rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.comment-container[b-ta5f6b64ma] {
    align-items: flex-start; /* Lepsze wyrównanie, gdy tekst komentarza ma wiele linii */
}

/* --- NOWE STYLE DLA SEKCJI RECENZJI DAŃ --- */
.dish-reviews-section[b-ta5f6b64ma] {
    margin-top: 2rem;
}

.dish-review-grid[b-ta5f6b64ma] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
    gap: 1rem;
}

.dish-review-card[b-ta5f6b64ma] {
    background-color: var(--gastro-bg-panel);
    border-radius: var(--gastro-border-radius);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
    border: 1px solid var(--gastro-bg-light);
}

    .dish-review-card:hover[b-ta5f6b64ma] {
        transform: translateY(-5px);
        box-shadow: 0 8px 20px rgba(0,0,0,0.12);
    }

.dish-card-img-container[b-ta5f6b64ma] {
    position: relative;
    height: 150px;
    overflow: hidden;
    background-color: #f0f0f0;
}

.dish-card-img[b-ta5f6b64ma] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dish-card-body[b-ta5f6b64ma] {
    padding: 0.75rem;
}

.dish-card-title[b-ta5f6b64ma] {
    font-family: var(--gastro-font-heading);
    font-size: 1.1rem;
    margin-bottom: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.dish-card-footer[b-ta5f6b64ma] {
    padding: 0.5rem 0.75rem;
    background-color: #f8f9fa;
    border-top: 1px solid #dee2e6;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8rem;
}

.stat-item[b-ta5f6b64ma] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

    .stat-item .bi-star-fill[b-ta5f6b64ma] {
        color: #ffc107;
    }

    .stat-item .bi-chat-fill[b-ta5f6b64ma] {
        color: var(--gastro-text-medium);
    }


/* Style dla placeholderów */
.placeholder-card[b-ta5f6b64ma] {
    cursor: default;
    text-align: center;
    border: 2px dashed var(--gastro-bg-light); /* Delikatna przerywana ramka */
    background-color: transparent;
    box-shadow: none;
}

    .placeholder-card:hover[b-ta5f6b64ma] {
        transform: none;
        box-shadow: none;
        /* box-shadow: 0 4px 12px rgba(0,0,0,0.08); */
        border-color: #dee2e6;
    }

.card-img-placeholder[b-ta5f6b64ma] {
    height: 150px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 4rem;
    color: var(--gastro-text-medium); /* Używamy naszego koloru */
    background-color: transparent; /* Usuwamy tło */
    font-family: var(--gastro-font-heading);
    font-weight: 700;
}

.card-body-placeholder p[b-ta5f6b64ma] {
    font-size: 0.9rem;
    color: var(--gastro-text-medium);
    padding: 0.75rem;
    margin: 0;
    background-color: #f8f9fa; /* Dopasowujemy tło do stopki karty */
    border-top: 2px dashed #e9ecef;
}

/* --- NOWY STYL DLA CENY NA KARCIE RECENZJI --- */
.price-tag[b-ta5f6b64ma] {
    position: absolute;
    top: 0.5rem;
    right: 0.5rem;
    background-color: rgba(0, 0, 0, 0.7);
    color: white;
    padding: 0.25rem 0.6rem;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
    backdrop-filter: blur(4px);
    border: 1px solid rgba(255, 255, 255, 0.2);
}

/* --- NOWE, POPRAWIONE STYLE DLA MIERNIKA KLIMATU --- */
.vibe-cloud-section[b-ta5f6b64ma] {
    margin-top: 1rem;
    padding-top: 1rem;
    margin-bottom: 1.5rem;
  /*  border-top: 1px solid var(--gastro-bg-light); */
}


.vibe-cloud-header[b-ta5f6b64ma] {
    display: flex;
    align-items: baseline; /* Wyrównuje tekst tytułu i przycisku */
    margin-bottom: 0.5rem;
}

    .vibe-cloud-header .section-title[b-ta5f6b64ma] {
        margin-bottom: 0;
        margin-right: 0.5rem;
    }

.btn-vibe-vote[b-ta5f6b64ma] {
    font-weight: 600;
    padding: 0;
    vertical-align: baseline;
    text-decoration: none;
}

.vibe-tags-display[b-ta5f6b64ma] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem; /* Odstępy pionowe i poziome */
}

.vibe-tag[b-ta5f6b64ma] {
    background-color: #e9ecef;
    color: var(--gastro-text-dark);
    padding: 0.35rem 0.8rem;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    white-space: nowrap;
}

/* --- NOWE STYLE DLA SEKCJI WYDARZEŃ W LOKALU --- */
.active-events-section[b-ta5f6b64ma] {
    margin-top: 1.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--gastro-bg-light);
}

.event-item[b-ta5f6b64ma] {
    background-color: #f8f9fa; /* Jasnoszare tło */
    border-left: 4px solid var(--gastro-accent); /* Koralowy akcent */
    padding: 0.75rem 1rem;
    border-radius: var(--gastro-border-radius);
}

    .event-item:not(:last-child)[b-ta5f6b64ma] {
        margin-bottom: 0.5rem;
    }

/* ZMIANA: Ustawiamy, aby nagłówek nie rozciągał elementów na całą szerokość */
.section-header[b-ta5f6b64ma] {
    display: flex;
    justify-content: flex-start; /* Zamiast space-between */
    align-items: baseline;
    gap: 0.75rem; /* Odstęp między tytułem a przyciskiem */
    margin-bottom: 1rem;
}

.btn-add-review[b-ta5f6b64ma] {
    font-weight: 600;
    font-size: 0.9rem;
    padding: 0;
    text-decoration: none;
}


/* --- ZAKTUALIZOWANE STYLE DLA SEKCJI VIBE I WYDARZEŃ --- */

/* Usuwamy obramowanie i marginesy, bo teraz są w kolumnach */
.vibe-cloud-section[b-ta5f6b64ma],
.active-events-section[b-ta5f6b64ma] {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    height: 100%; /* Sprawia, że kolumny mają tę samą wysokość */
}

/* Dodajemy pionową linię oddzielającą na większych ekranach */
@media (min-width: 768px) {
    .vibe-cloud-section[b-ta5f6b64ma] {
        padding-right: 1.5rem;
        border-right: 1px solid var(--gastro-bg-light);
    }
}

.vibe-cloud-header[b-ta5f6b64ma] {
    display: flex;
    align-items: baseline;
    margin-bottom: 0.5rem;
}

    .vibe-cloud-header .section-title[b-ta5f6b64ma] {
        margin-bottom: 0;
        margin-right: 0.5rem;
    }

.btn-vibe-vote[b-ta5f6b64ma] {
    font-weight: 600;
    padding: 0;
    vertical-align: baseline;
    text-decoration: none;
}

.vibe-tags-display[b-ta5f6b64ma] {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem;
    margin-top: 0.5rem;
}

.vibe-tag[b-ta5f6b64ma] {
    background-color: #e9ecef;
    color: var(--gastro-text-dark);
    padding: 0.35rem 0.8rem;
    border-radius: 20px;
    font-size: 0.9rem;
    font-weight: 500;
}

.event-item[b-ta5f6b64ma] {
    background-color: #fff3cd;
    border-left: 4px solid #ffc107;
    padding: 0.75rem 1rem;
    border-radius: var(--gastro-border-radius);
}

    .event-item:not(:last-child)[b-ta5f6b64ma] {
        margin-bottom: 0.5rem;
    }


/* NOWY/ZAKTUALIZOWANY STYL DLA PRZYCISKÓW AKCJI */
.btn-add-action[b-ta5f6b64ma] {
    font-weight: 600;
    font-size: 0.9rem;
    padding: 0;
    text-decoration: none;
    color: var(--gastro-primary-dark);
}

    .btn-add-action:hover[b-ta5f6b64ma] {
        color: var(--gastro-accent); /* Używamy koloru akcentu (koralowego) */
    }

.vibe-cloud-header .btn-add-action[b-ta5f6b64ma] {
    vertical-align: baseline; /* Lepsze wyrównanie z tytułem */
}
/* /Pages/Przewodnik.razor.rz.scp.css */
.przewodnik-page[b-d7t5agsfob] {
    padding: 1rem;
}

.przewodnik-header[b-d7t5agsfob] {
    text-align: center;
    margin-bottom: 2rem;
}

    .przewodnik-header h1[b-d7t5agsfob] {
        font-family: var(--gastro-font-heading);
        font-weight: 700;
    }

    .przewodnik-header .lead[b-d7t5agsfob] {
        color: var(--gastro-text-medium);
    }

.trails-grid[b-d7t5agsfob] {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.5rem;
}

.trail-card[b-d7t5agsfob] {
    background-color: var(--gastro-bg-panel);
    border-radius: var(--gastro-border-radius);
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    overflow: hidden;
    cursor: pointer;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

    .trail-card:hover[b-d7t5agsfob] {
        transform: translateY(-5px);
        box-shadow: 0 8px 20px rgba(0,0,0,0.12);
    }

.trail-card-img-container[b-d7t5agsfob] {
    height: 180px;
    overflow: hidden;
}

.trail-card-img[b-d7t5agsfob] {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.trail-card-body[b-d7t5agsfob] {
    padding: 1rem;
}

.trail-card-tags[b-d7t5agsfob] {
    margin-bottom: 0.5rem;
}

    .trail-card-tags .badge[b-d7t5agsfob] {
        margin-right: 0.25rem;
    }

.trail-card-title[b-d7t5agsfob] {
    font-family: var(--gastro-font-heading);
    font-size: 1.25rem;
    margin-bottom: 0.5rem;
}

.trail-card-description[b-d7t5agsfob] {
    font-size: 0.9rem;
    color: var(--gastro-text-medium);
}

.trail-card-footer[b-d7t5agsfob] {
    padding: 0.75rem 1rem;
    background-color: #f8f9fa;
    border-top: 1px solid #dee2e6;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 0.8rem;
}

.trail-stats[b-d7t5agsfob] {
    display: flex;
    align-items: center;
}

.stat-item[b-d7t5agsfob] {
    display: flex;
    align-items: center;
    gap: 0.25rem;
}

    .stat-item .bi-star-fill[b-d7t5agsfob] {
        color: #ffc107;
    }

.trail-author strong[b-d7t5agsfob] {
    color: var(--gastro-primary);
}

.stat-item .bi-chat-fill[b-d7t5agsfob] {
    color: var(--gastro-text-medium);
}
/* /Pages/SuggestEdit.razor.rz.scp.css */
/* Styl dla kontenera grup atrybutów */
.attribute-group[b-dytexn711e] {
    margin-bottom: 1.5rem; /* Zwiększa odstęp między głównymi grupami (Jedzenie, Napoje) */
    padding-bottom: 1rem;
    border-bottom: 1px solid #e9ecef; /* Delikatna linia oddzielająca na dole grupy */
}

    .attribute-group:last-of-type[b-dytexn711e] {
        border-bottom: none; /* Usuń linię dla ostatniego elementu */
        margin-bottom: 0;
    }

/* Styl dla nagłówka grupy (np. "Jedzenie") */
.attribute-group-header[b-dytexn711e] {
    font-size: 1.1rem;
    font-weight: 600;
    color: #495057;
    margin-bottom: 1rem;
}

/* Styl dla pojedynczego wiersza z atrybutem (np. "Kebab duży: [pole]") */
.attribute-row[b-dytexn711e] {
    display: flex;
    justify-content: space-between; /* Kluczowe: rozsuwa label i input na boki */
    align-items: center;
    padding: 0.5rem 0;
    border-top: 1px solid #f8f9fa; /* Bardzo delikatna linia między atrybutami */
}

    /* Styl dla etykiety atrybutu (np. "Kebab duży") */
    .attribute-row label[b-dytexn711e] {
        margin-right: 1rem; /* Odstęp od pola input */
        flex-shrink: 0; /* Zapobiega zwijaniu się tekstu etykiety */
    }

    /* Styl dla pola do wprowadzania danych */
    .attribute-row .form-control[b-dytexn711e],
    .attribute-row .form-switch[b-dytexn711e] {
        max-width: 150px; /* Ogranicza szerokość pola, aby nie było za daleko */
    }
/* /Pages/SzlakDetails.razor.rz.scp.css */
.szlak-hero[b-z80nlr8h24] {
    height: 40vh;
    background-size: cover;
    background-position: center;
    position: relative;
    color: white;
}

.szlak-hero-overlay[b-z80nlr8h24] {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0.1) 100%);
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 2rem;
}

    .szlak-hero-overlay h1[b-z80nlr8h24] {
        font-family: var(--gastro-font-heading);
        font-weight: 700;
        margin-bottom: 0.5rem;
    }

    .szlak-hero-overlay .badge[b-z80nlr8h24] {
        background-color: rgba(255, 255, 255, 0.2);
        border: 1px solid rgba(255, 255, 255, 0.5);
        margin-right: 0.5rem;
    }

.szlak-content[b-z80nlr8h24] {
    padding: 1.5rem;
}

.szlak-description[b-z80nlr8h24] {
    font-size: 1.1rem;
    line-height: 1.7;
    margin-bottom: 2rem;
}

.stops-header[b-z80nlr8h24] {
    font-family: var(--gastro-font-heading);
    margin-bottom: 1rem;
}

.stops-list[b-z80nlr8h24] {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.stop-card[b-z80nlr8h24] {
    display: flex;
    align-items: center;
    background-color: var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    padding: 1rem;
    transition: background-color 0.3s ease;
}

    .stop-card.visited[b-z80nlr8h24] {
        background-color: #d1e7dd;
    }

.stop-number[b-z80nlr8h24] {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--gastro-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 1.2rem;
    margin-right: 1rem;
}

.stop-place-name[b-z80nlr8h24] {
    font-weight: 600;
}

.stop-custom-desc[b-z80nlr8h24] {
    font-size: 0.9rem;
    color: var(--gastro-text-medium);
}

.btn-checkin[b-z80nlr8h24] {
    flex-shrink: 0;
    margin-left: 1rem;
}

.szlak-footer[b-z80nlr8h24] {
    text-align: center;
    margin-top: 2rem;
}

    .szlak-footer .btn-info[b-z80nlr8h24] {
        background-color: var(--gastro-primary);
        border-color: var(--gastro-primary);
    }

        .szlak-footer .btn-info:hover[b-z80nlr8h24] {
            background-color: #2c3e50;
            border-color: #2c3e50;
        }

.completion-overlay[b-z80nlr8h24], .image-viewer-overlay[b-z80nlr8h24] {
    position: fixed;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.8);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 4000;
    padding: 1rem;
}

.completion-popup[b-z80nlr8h24] {
    background-color: var(--gastro-bg-panel);
    padding: 2rem;
    border-radius: var(--gastro-border-radius);
    text-align: center;
    box-shadow: 0 5px 20px rgba(0,0,0,0.3);
    max-width: 400px;
    animation: popup-fade-in-b-z80nlr8h24 0.3s ease-out;
}

    .completion-popup h3[b-z80nlr8h24] {
        color: var(--gastro-primary);
    }

@keyframes popup-fade-in-b-z80nlr8h24 {
    from {
        opacity: 0;
        transform: scale(0.9);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* --- Sekcja oceny (nowy styl) --- */
.rating-section[b-z80nlr8h24] {
    padding: 1rem;
    border-radius: var(--gastro-border-radius);
    background-color: var(--gastro-bg-light); /* Używamy tła zgodnego z resztą strony */
}

    .rating-section .card-title[b-z80nlr8h24] {
        margin-bottom: 0.75rem;
    }

/* --- Sekcja komentarzy --- */
.comments-section[b-z80nlr8h24] {
    margin-top: 2rem;
}

.comment-thread[b-z80nlr8h24] {
    position: relative;
}

.comment-container[b-z80nlr8h24] {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 1rem;
}

.comment-avatar[b-z80nlr8h24] {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background-color: var(--gastro-primary);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 1.2rem;
    font-family: var(--gastro-font-heading);
}

.comment-card[b-z80nlr8h24] {
    flex-grow: 1;
    background-color: var(--gastro-bg-panel);
    border: 1px solid var(--gastro-bg-light);
    border-radius: var(--gastro-border-radius);
    padding: 0.75rem 1rem;
    box-shadow: 0 1px 3px rgba(0,0,0,0.05);
}

.comment-header[b-z80nlr8h24] {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0.5rem;
    margin-bottom: 0.25rem;
}

.comment-author[b-z80nlr8h24] {
    font-weight: 600;
    color: var(--gastro-text-dark);
}

.comment-date[b-z80nlr8h24] {
    font-size: 0.75rem;
    color: var(--gastro-text-medium);
}

.card-body[b-z80nlr8h24] {
    padding: 0;
}

.card-text[b-z80nlr8h24] {
    margin-bottom: 0.5rem;
    color: var(--gastro-text-dark);
    line-height: 1.6;
}

.comment-footer[b-z80nlr8h24] {
    display: flex;
    justify-content: flex-end; /* Akcje zawsze po prawej */
    align-items: center;
    font-size: 0.8rem;
    color: var(--gastro-text-medium);
    margin-top: 0.75rem;
}

.comment-rating[b-z80nlr8h24] {
    display: flex;
    align-items: center;
}

    .comment-rating .star-icon[b-z80nlr8h24] {
        font-size: 0.9rem;
        color: #ffc107;
    }

.comment-actions[b-z80nlr8h24] {
    display: flex;
    align-items: center;
    gap: 1rem;
}

.btn-reply[b-z80nlr8h24], .btn-like[b-z80nlr8h24] {
    background: none;
    border: none;
    font-size: 0.8rem;
    color: var(--gastro-primary);
    font-weight: 600;
    padding: 0;
    cursor: pointer;
}

.btn-like[b-z80nlr8h24] {
    color: var(--gastro-text-medium);
    padding: 0.25rem 0.5rem;
    display: flex;
    align-items: center;
    gap: 0.25rem;
    border-radius: 20px;
    transition: all 0.2s ease;
}

    .btn-like:hover[b-z80nlr8h24] {
        background-color: #f8d7da;
        color: var(--gastro-danger);
    }

    .btn-like.liked[b-z80nlr8h24] {
        color: var(--gastro-danger);
        font-weight: 600;
    }

.replies-container[b-z80nlr8h24] {
    padding-left: 1.5rem;
    margin-left: calc(20px);
    border-left: 2px solid var(--gastro-bg-light);
}

.reply-form[b-z80nlr8h24] {
    padding-left: calc(40px + 0.75rem);
    padding-top: 0.5rem;
    margin-bottom: 1rem;
}

.comment-image-thumb[b-z80nlr8h24] {
    width: 120px;
    height: 120px;
    margin-bottom: 0.75rem;
    border-radius: var(--gastro-border-radius);
    overflow: hidden;
    cursor: pointer;
}

    .comment-image-thumb img[b-z80nlr8h24] {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

.image-preview[b-z80nlr8h24] {
    position: relative;
    display: inline-block;
}

    .image-preview img[b-z80nlr8h24] {
        max-width: 100px;
        max-height: 100px;
        border-radius: var(--gastro-border-radius);
    }

    .image-preview .btn-close[b-z80nlr8h24] {
        position: absolute;
        top: -5px;
        right: -5px;
        background-color: white;
        border-radius: 50%;
        opacity: 1;
    }

.fullscreen-image[b-z80nlr8h24] {
    max-width: 95vw;
    max-height: 95vh;
    object-fit: contain;
    border-radius: var(--gastro-border-radius);
}
/* /Pages/TrailEditorForm.razor.rz.scp.css */
.search-stop-container[b-vta1ew4zxb] {
    position: relative;
}

.suggestion-box[b-vta1ew4zxb] {
    position: absolute;
    width: 100%;
    z-index: 1000;
    max-height: 200px;
    overflow-y: auto;
    border-top: none;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}
/* /Pages/UserListPage.razor.rz.scp.css */
.list-header h3[b-xfn6oghs6c] {
    font-weight: 700;
}

.edit-section[b-xfn6oghs6c] {
    background-color: var(--bs-tertiary-bg);
}

.search-results[b-xfn6oghs6c] {
    max-height: 200px;
    overflow-y: auto;
}

    .search-results .list-group-item[b-xfn6oghs6c] {
        cursor: pointer;
    }

.list-item-title[b-xfn6oghs6c] {
    font-weight: 600;
    text-decoration: none;
    color: var(--bs-body-color);
}

    .list-item-title:hover[b-xfn6oghs6c] {
        text-decoration: underline;
    }

.list-item-note[b-xfn6oghs6c] {
    font-size: 0.9rem;
    color: var(--bs-secondary-color);
    margin-top: 0.25rem;
    margin-bottom: 0;
}

.btn-like[b-xfn6oghs6c] {
    border: 1px solid var(--bs-border-color);
    color: var(--bs-body-color);
}

    .btn-like.liked[b-xfn6oghs6c] {
        background-color: #ffdde0;
        color: #ed4956;
        border-color: #ed4956;
    }
