﻿/*html {
    font-size: 14px;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
    position: relative;
    min-height: 100%;
}

body {
    margin-bottom: 60px;
}
*/

label.required::after {
    content: " *";
    color: #dc3545; /* bootstrap danger */
    font-weight: 600;
}

/* Грид със събития */
.botc-events-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 1rem;
}

.botc-event-card {
    background-color: #ffffff;
    border-radius: 0.9rem;
    border: 1px solid var(--botc-border-soft);
    padding: 1rem 1rem 0.9rem;
    display: flex;
    flex-direction: column;
    gap: 0.35rem;
    box-shadow: 0 6px 18px rgba(37, 25, 70, 0.05);
}

.botc-event-venue {
    text-transform: uppercase;
    font-size: 0.75rem;
    letter-spacing: 0.16em;
    color: var(--botc-text-muted);
}

.botc-event-title {
    font-size: 1rem;
    margin: 0;
    color: var(--botc-text-main);
    font-weight: 600;
}

.botc-event-meta {
    font-size: 0.9rem;
    color: var(--botc-text-muted);
}

.botc-event-capacity {
    font-size: 0.88rem;
    color: var(--botc-text-muted);
}

    .botc-event-capacity strong {
        color: var(--botc-purple-soft);
    }

.botc-event-btn {
    align-self: flex-start;
    margin-top: 0.5rem;
    border-radius: 999px;
    border: 1px solid var(--botc-purple-soft);
    background-color: #f6f0ff;
    color: var(--botc-purple);
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

    .botc-event-btn:hover {
        background-color: #e9ddff;
        border-color: var(--botc-purple);
        color: var(--botc-purple);
    }



/* Row actions: equal width buttons; stack on small width */
.botc-row-actions {
    display: inline-flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: .35rem;
}

.botc-action-btn {
    width: 118px;
    border-radius: .6rem;
}

@media (max-width: 768px) {
    .botc-col-actions {
        width: 1%;
    }

    .botc-action-btn {
        width: 100%;
    }

    .botc-row-actions {
        width: 100%;
    }
}

/* align buttons on same row with Phone/BirthDate on wide screens */
.botc-row-actions-align {
    display: flex;
    gap: .5rem;
    align-items: end;
    justify-content: flex-start;
    height: 100%;
}





/* Базови настройки от шаблона */
html {
    font-size: 14px;
    position: relative;
    min-height: 100%;
}

@media (min-width: 768px) {
    html {
        font-size: 16px;
    }
}

/* Главен контейнер */
.container {
    max-width: 1600px;
}

/* _Layout и _LoginPartial */

/* Навбар – лек, но с лек лилав акцент */
.navbar-light.bg-white {
    background-color: #fdfbff !important;
    border-bottom: 1px solid #e1d5f5 !important;
}

.navbar-brand {
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--botc-purple) !important;
}

/* Navbar brand с Nosifer */
.botc-brand {
    font-family: 'Nosifer', cursive;
    font-size: 1.15rem;
    line-height: 1.2;
    letter-spacing: 0.03em;
    text-decoration: none !important;
    display: flex;
    flex-direction: column;
    align-items: center; /* ← ЦЕНТРИРА по хоризонтала */
}

    /* Основният текст – червен */
    .botc-brand .brand-main {
        color: #8b0000;
        text-transform: none;
        margin: 0;
    }

    /* “Bulgaria” – центрирано под надписа */
    .botc-brand .brand-sub {
        font-size: 0.75em;
        margin-top: -2px;
        letter-spacing: 0.15em;
        color: var(--botc-gold-soft);
        text-transform: uppercase;
        margin-left: 0; /* ← важно за абсолютното центриране */
        margin-right: 0;
        text-align: center; /* ← допълнително центриране */
    }

/* По-малък на мобилно */
@media (max-width: 576px) {
    .botc-brand {
        font-size: 0.92rem;
    }
}

.navbar-nav .nav-link {
    color: var(--botc-text-muted) !important;
    font-weight: 500;
}

    .navbar-nav .nav-link:hover,
    .navbar-nav .nav-link:focus {
        color: var(--botc-purple) !important;
    }

.nav-favicon-icon {
    width: 22px;
    height: 22px;
    display: block;
}

/* Светъл футер в стила на страницата */
.footer {
    background-color: #f5f2fb;
    border-top: 1px solid #e1d5f5;
    color: var(--botc-text-muted);
    font-size: 0.9rem;
}

    .footer a {
        color: var(--botc-purple);
        text-decoration: none;
        font-weight: 500;
    }

        .footer a:hover {
            color: var(--botc-purple-soft);
            text-decoration: underline;
        }



/* SHARED ZONE */

/* --- BOTC LIGHT THEME --- */

:root {
    --botc-purple: #5a3c88;
    --botc-purple-soft: #7b5ab0;
    --botc-gold: #d4af37;
    --botc-gold-soft: #e4c76c;
    --botc-bg-light: #faf6ff;
    --botc-border-soft: #e1d5f5;
    --botc-text-main: #2a223b;
    --botc-text-muted: #6f648b;
}

body {
    margin-bottom: 60px;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    background-color: #f5f2fb;
    background-image: linear-gradient(rgba(245, 242, 251, 0.65), rgba(245, 242, 251, 0.85)), url("/img/background.png");
    background-size: cover;
    background-position: center top;
    background-repeat: no-repeat;
}

/* Малки екрани */
@media (max-width: 576px) {
    .botc-hero {
        padding: 2rem 1.2rem;
    }

    .botc-section {
        padding: 1.3rem 1.1rem;
    }
}

/* общ тесен контейнер */
.botc-narrow {
    max-width: 960px;
    max-width: 960px;
    margin-left: auto;
    margin-right: auto;
}

.botc-narrow-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

.botc-narrow-card {
    background: #f6f0ff;
    border-radius: 1rem;
    padding: 1.5rem;
    border: 1px solid var(--botc-border-soft);
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.25);
}



.botc-form-label {
    font-weight: 600;
    color: var(--botc-text-main);
}

/* Общ стил за секции под hero */
.botc-section {
    background-color: var(--botc-bg-light);
    border-radius: 1rem;
    padding: 1.6rem 1.5rem;
    border: 1px solid var(--botc-border-soft);
    box-shadow: 0 10px 25px rgba(37, 25, 70, 0.06);
}

.botc-section-subtitle {
    font-size: 0.9rem;
    color: var(--botc-text-muted);
}


.botc-section-title {
    font-size: 1.1rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    color: var(--botc-purple);
    margin-bottom: 0.75rem;
}
/* HERO секция – end */

.botc-event-details-title {
    font-weight: 800;
    font-size: 1.4rem;
    line-height: 1.25;
}

/* Status pills */
.botc-pill {
    display: inline-flex;
    align-items: center;
    padding: .18rem .55rem;
    border-radius: 999px;
    font-weight: 900;
    font-size: .82rem;
    letter-spacing: .3px;
    white-space: nowrap;
}

.botc-pill-confirmed {
    background: rgba(25,135,84,0.14);
}

.botc-pill-pending {
    background: rgba(255,193,7,0.18);
}

/* === Divider === */
.botc-divider {
    border: 0;
    border-top: 1px solid var(--botc-border-soft);
    opacity: 1;
    margin: 1.25rem 0;
}

/* дата/час */
.botc-event-card-2-datetime {
    display: flex;
    gap: .5rem;
    flex-wrap: wrap;
    align-items: center;
    margin-top: .25rem;
    font-weight: 700;
}

/* “чип” */
.botc-dt-chip {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .35rem .65rem;
    border-radius: 999px;
    background: #f6f0ff;
    color: var(--botc-purple);
    font-weight: 700;
    font-size: .85rem;
}

    .botc-dt-chip i {
        font-size: 1rem;
        color: var(--botc-gold);
    }

/* влияе на Login/Register формите */
.btn:focus,
.btn:active:focus,
.btn-link.nav-link:focus,
.form-control:focus,
.form-check-input:focus {
    box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

.botc-social-link {
    font-size: 1rem;
    text-decoration: none;
}

    .botc-social-link:hover {
        text-decoration: underline;
    }

.botc-hero-btn {
    border-radius: 999px;
    padding: 0.65rem 1.7rem;
    border: none;
    background: linear-gradient(135deg, #7b5ab0, #d4af37);
    color: #fff;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    box-shadow: 0 8px 20px rgba(66, 38, 109, 0.3);
}

    .botc-hero-btn:hover {
        background: linear-gradient(135deg, #5a3c88, #c49c29);
        color: #fff;
    }

/* === Google-style login button === */
.botc-google-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.65rem;
    padding: 0.6rem 1.2rem;
    border-radius: 0.5rem;
    background: #ffffff;
    border: 1px solid #dadce0;
    color: #3c4043;
    font-weight: 500;
    font-size: 0.95rem;
    text-decoration: none;
    box-shadow: none;
    transition: box-shadow 0.15s ease, background-color 0.15s ease;
}

    .botc-google-btn:hover {
        background-color: #f8f9fa;
        box-shadow: 0 1px 3px rgba(60,64,67,.15);
        color: #3c4043;
    }

    .botc-google-btn:active {
        background-color: #f1f3f4;
    }

.botc-google-icon {
    width: 18px;
    height: 18px;
    display: block;
}


/* Следващите 3 класа са за показване на логото на мястото */
.venue-logo-box {
    width: 50px;
    height: 50px;
    border-radius: .75rem;
    overflow: hidden;
    background: #faf6ff;
    border: 1px solid var(--botc-border-soft);
    display: flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 50px;
}

.venue-logo-img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    padding: 6px;
}

.venue-logo-placeholder {
    color: var(--botc-text-muted);
    font-weight: 600;
}

/* ===== Upcoming events grid ===== */

.botc-upcoming-empty {
    font-size: 1.05rem;
    opacity: 0.9;
}

.botc-upcoming-grid {
    display: grid;
    gap: 1.25rem;
    align-items: stretch;
}

/* По подразбиране (ако не хване класовете по-долу) */
.botc-upcoming-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

/* Равни колони според брой карти (1..6). Ако имаш повече, добави още. */
.botc-upcoming-grid--1 {
    grid-template-columns: repeat(1, 1fr);
}

.botc-upcoming-grid--2 {
    grid-template-columns: repeat(2, 1fr);
}

.botc-upcoming-grid--3 {
    grid-template-columns: repeat(3, 1fr);
}

.botc-upcoming-grid--4 {
    grid-template-columns: repeat(4, 1fr);
}

.botc-upcoming-grid--5 {
    grid-template-columns: repeat(5, 1fr);
}

.botc-upcoming-grid--6 {
    grid-template-columns: repeat(6, 1fr);
}

@media (max-width: 992px) {
    .botc-upcoming-grid--4,
    .botc-upcoming-grid--5,
    .botc-upcoming-grid--6 {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 640px) {
    .botc-upcoming-grid {
        grid-template-columns: 1fr;
    }
}

.botc-upcoming-card {
    display: block;
    text-decoration: none;
    color: inherit;
    background: #f6f0ff;
    border-radius: 1rem;
    padding: 1.25rem;
    box-shadow: 0 0.25rem 0.75rem rgba(0, 0, 0, 0.25);
    transition: transform 120ms ease, box-shadow 120ms ease;
}

    .botc-upcoming-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 0.4rem 1.05rem rgba(0, 0, 0, 0.28);
    }

.botc-upcoming-venue {
    text-align: center;
    margin-bottom: 0.6rem;
    color: var(--botc-text-muted);
    letter-spacing: .04em;
    font-size: 0.9rem; /* ← една идея по-малко */
    font-weight: 600;    
}
.botc-upcoming-venue-name {
    color: var(--botc-purple);
    font-weight: 900;
    text-transform: uppercase;
}
.botc-upcoming-venue-town {
    color: var(--botc-gold);
    font-weight: 800;
    font-size: 1em;
}

.botc-upcoming-title {
    text-align: center;
    font-size: 1.35rem;
    font-weight: 700;
    margin-bottom: 0.55rem;
    font-family: 'Caveat', 'Pacifico', cursive;
    color: var(--botc-gold);
    text-shadow: 0 1px 0 rgba(255,255,255,.65), 0 2px 6px rgba(212,175,55,.35);
}

.botc-upcoming-dt {
    justify-content: center;
    margin-top: .15rem;
    margin-bottom: .9rem; /* вместо стария margin на datetime */
}

.botc-upcoming-image {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
}
.botc-upcoming-image-wrap {
    border-radius: 0.85rem;
    overflow: hidden;
    padding: 0.25rem; /* “леко отстояние от рамката” */
    background: rgba(255,255,255,0.55);
}


/* ===== BOTC Toasts (shared) ===== */

.botc-toast-host {
    position: fixed;
    top: 18px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2000;
    display: grid;
    gap: 0.75rem;
    pointer-events: none;
    max-width: min(680px, calc(100vw - 36px));
}

.botc-toast {
    pointer-events: auto; /* но самият toast да може да се клика */
    max-width: 680px;
    margin: 0.75rem auto 0;
    display: grid;
    grid-template-columns: 44px 1fr 40px;
    gap: 0.75rem;
    align-items: start;
    padding: 0.85rem 0.9rem;
    border-radius: 1rem;
    border: 1px solid var(--botc-border-soft);
    background: rgba(250, 246, 255, 0.92);
    backdrop-filter: blur(10px);
    box-shadow: 0 12px 28px rgba(37, 25, 70, 0.18);
    transform: translateY(-8px);
    opacity: 0;
    animation: botcToastIn 180ms ease forwards;
    position: relative;
    overflow: hidden;
}

@keyframes botcToastIn {
    to {
        transform: translateY(0);
        opacity: 1;
    }
}

.botc-toast__icon {
    width: 44px;
    height: 44px;
    border-radius: 0.9rem;
    display: grid;
    place-items: center;
    border: 1px solid var(--botc-border-soft);
    background: rgba(255,255,255,0.55);
    color: var(--botc-purple);
}

    .botc-toast__icon i {
        font-size: 1.15rem;
    }

.botc-toast__title {
    font-weight: 800;
    letter-spacing: 0.02em;
    color: var(--botc-text-main);
    margin-top: 0.1rem;
}

.botc-toast__message {
    color: var(--botc-text-muted);
    font-weight: 600;
    line-height: 1.3;
    margin-top: 0.15rem;
}

.botc-toast__close {
    border: 0;
    background: transparent;
    color: var(--botc-text-muted);
    width: 40px;
    height: 40px;
    border-radius: 0.8rem;
    display: grid;
    place-items: center;
    margin-top: 0.1rem;
}

    .botc-toast__close:hover {
        background: rgba(90, 60, 136, 0.08);
        color: var(--botc-purple);
    }

.botc-toast__bar {
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
    width: 100%;
    transform-origin: left;
    background: linear-gradient(90deg, var(--botc-purple-soft), var(--botc-gold-soft));
    opacity: 0.95;
}

/* Variants */
.botc-toast--info .botc-toast__icon {
    color: var(--botc-purple);
}

.botc-toast--error {
    background: rgba(255, 246, 246, 0.92);
}

    .botc-toast--error .botc-toast__icon {
        color: #8b0000;
    }

/* Autohide states */
.botc-toast.is-hiding {
    animation: botcToastOut 160ms ease forwards;
}

@keyframes botcToastOut {
    to {
        transform: translateY(-8px);
        opacity: 0;
    }
}

/* small screens */
@media (max-width: 576px) {
    .botc-toast {
        margin: 0.75rem 0.75rem 0;
        grid-template-columns: 40px 1fr 36px;
        border-radius: 0.9rem;
    }

    .botc-toast__icon {
        width: 40px;
        height: 40px;
    }
}
/* Tooltips: лилаво + златно */
.tooltip {
    --bs-tooltip-bg: rgba(246, 240, 255, 0.98); /* бледо лилаво */
    --bs-tooltip-color: #d4af37; /* златно */
    --bs-tooltip-opacity: 1;
}

    .tooltip .tooltip-inner {
        font-weight: 800;
        border: 1px solid rgba(212, 175, 55, 0.35);
        box-shadow: 0 0.25rem 0.75rem rgba(0,0,0,0.18);
    }

/* стрелката да е със същия фон */
.bs-tooltip-top .tooltip-arrow::before {
    border-top-color: rgba(246, 240, 255, 0.98);
}

.bs-tooltip-bottom .tooltip-arrow::before {
    border-bottom-color: rgba(246, 240, 255, 0.98);
}

.bs-tooltip-start .tooltip-arrow::before {
    border-left-color: rgba(246, 240, 255, 0.98);
}

.bs-tooltip-end .tooltip-arrow::before {
    border-right-color: rgba(246, 240, 255, 0.98);
}