/* ================================================
   vk-kalendar.css – Vinski Kalendar
   ================================================ */

:root {
    --vk-bg:          #FAF6F0;
    --vk-surface:     #ffffff;
    --vk-border:      #e8ddd4;
    --vk-wine:        #8B1A1A;
    --vk-wine-dark:   #4A0E0E;
    --vk-gold:        #C9A84C;
    --vk-text:        #1C1009;
    --vk-text-muted:  #8a7060;
    --vk-today-bg:    #fff3e0;
    --vk-today-ring:  #C9A84C;
    --vk-header-bg:   #2a1008;
    --vk-radius:      12px;
    --vk-shadow:      0 4px 24px rgba(44,10,4,.10);
}

/* ── Wrapper ─────────────────────────────────── */
.vk-kalendar {
    font-family: Georgia, 'Times New Roman', serif;
    max-width: 780px;
    margin: 0 auto;
    background: var(--vk-bg);
    border-radius: var(--vk-radius);
    box-shadow: var(--vk-shadow);
    overflow: hidden;
    border: 1px solid var(--vk-border);
}

/* ── Header – month nav ──────────────────────── */
.vk-kal__header {
    background: var(--vk-header-bg);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 18px 24px;
}

.vk-kal__nav-btn {
    background: rgba(255,255,255,.1);
    border: 1px solid rgba(255,255,255,.18);
    color: #fff;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    cursor: pointer;
    font-size: 1.1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .18s;
    padding: 0;
    line-height: 1;
}

.vk-kal__nav-btn:hover {
    background: rgba(255,255,255,.22);
}

.vk-kal__month-title {
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: .04em;
    margin: 0;
    text-align: center;
    flex: 1;
}

.vk-kal__month-title span {
    color: var(--vk-gold);
}

/* ── Day names row ───────────────────────────── */
.vk-kal__daynames {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: #3d1510;
    border-bottom: 1px solid rgba(255,255,255,.06);
}

.vk-kal__dayname {
    text-align: center;
    padding: 10px 4px;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.5);
}

.vk-kal__dayname--weekend {
    color: rgba(201,168,76,.65);
}

/* ── Grid ────────────────────────────────────── */
.vk-kal__grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    background: var(--vk-border);
    gap: 1px;
}

/* ── Day cell ────────────────────────────────── */
.vk-kal__day {
    background: var(--vk-surface);
    min-height: 72px;
    padding: 8px 6px 6px;
    position: relative;
    cursor: default;
    transition: background .15s;
}

.vk-kal__day--empty {
    background: #f5f0eb;
}

.vk-kal__day--today {
    background: var(--vk-today-bg);
}

.vk-kal__day--today .vk-kal__day-num {
    background: var(--vk-today-ring);
    color: #fff;
    border-radius: 50%;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
}

.vk-kal__day-num {
    font-size: .82rem;
    color: var(--vk-text-muted);
    font-family: Georgia, serif;
    line-height: 1;
    margin-bottom: 4px;
    display: inline-block;
    width: 26px;
    height: 26px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.vk-kal__day--weekend .vk-kal__day-num {
    color: var(--vk-wine);
}

/* ── Event chip ──────────────────────────────── */
.vk-kal__event-chip {
    display: block;
    border-radius: 4px;
    padding: 2px 6px;
    font-size: .7rem;
    line-height: 1.4;
    margin-bottom: 2px;
    color: #fff;
    cursor: pointer;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    transition: opacity .15s, transform .15s;
    position: relative;
    z-index: 1;
}

.vk-kal__event-chip:hover {
    opacity: .88;
    transform: translateY(-1px);
}

/* Event spanning – start / middle / end */
.vk-kal__event-chip--start {
    border-radius: 4px 0 0 4px;
    margin-right: -1px;
}
.vk-kal__event-chip--middle {
    border-radius: 0;
    margin-left: -1px;
    margin-right: -1px;
}
.vk-kal__event-chip--end {
    border-radius: 0 4px 4px 0;
    margin-left: -1px;
}
.vk-kal__event-chip--single {
    border-radius: 4px;
}

/* ── Tooltip ─────────────────────────────────── */
.vk-kal__tooltip {
    position: fixed;
    background: var(--vk-wine-dark);
    color: #fff;
    padding: 10px 14px;
    border-radius: 8px;
    font-size: .82rem;
    line-height: 1.55;
    max-width: 220px;
    z-index: 9999;
    pointer-events: none;
    box-shadow: 0 8px 24px rgba(0,0,0,.25);
    border: 1px solid rgba(201,168,76,.3);
    display: none;
}

.vk-kal__tooltip.is-visible {
    display: block;
}

.vk-kal__tooltip__title {
    font-weight: 700;
    font-size: .88rem;
    color: var(--vk-gold);
    margin-bottom: 4px;
}

.vk-kal__tooltip__time {
    font-size: .75rem;
    color: rgba(255,255,255,.65);
}

/* ── Legend below calendar ───────────────────── */
.vk-kal__legend {
    padding: 14px 20px;
    border-top: 1px solid var(--vk-border);
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    background: #fff;
}

.vk-kal__legend-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .78rem;
    color: var(--vk-text-muted);
}

.vk-kal__legend-dot {
    width: 12px;
    height: 12px;
    border-radius: 3px;
    flex-shrink: 0;
}

/* ── "Nema događaja" state ───────────────────── */
.vk-kal__empty-state {
    text-align: center;
    padding: 32px 24px;
    color: var(--vk-text-muted);
    font-size: .9rem;
    font-style: italic;
}

/* ── MOBILE ──────────────────────────────────── */
@media (max-width: 540px) {
    .vk-kal__header { padding: 14px 12px; }
    .vk-kal__month-title { font-size: 1rem; }
    .vk-kal__day { min-height: 52px; padding: 4px 3px; }
    .vk-kal__day-num { font-size: .72rem; width: 22px; height: 22px; }
    .vk-kal__event-chip { font-size: .6rem; padding: 1px 4px; }
    .vk-kal__dayname { font-size: .6rem; padding: 7px 2px; }
}
