:root{
    --hbkal-accent: #d6111e;
    --hbkal-page: #ddc76d;
    --hbkal-holiday: #ffffff;
    --hbkal-bg: #0e0e10;
    --hbkal-panel: #161618;
    --hbkal-panel-2: #1b1b1e;
    --hbkal-border: #262629;
    --hbkal-text: #f5f5f7;
    --hbkal-muted: #9a9aa2;
}

.hbkal-wrap{
    max-width:1400px;
    margin:40px auto;
    background:var(--hbkal-bg);
    border-radius:20px;
    overflow:hidden;
    color:var(--hbkal-text);
    border:1px solid var(--hbkal-border);
    font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
    position:relative;
}

.hbkal-wrap.hbkal-loading{
    opacity:.6;
    pointer-events:none;
    transition:opacity .2s ease;
}

.hbkal-header{
    display:flex;
    flex-wrap:wrap;
    justify-content:space-between;
    align-items:center;
    gap:16px;
    padding:24px 28px;
    background:var(--hbkal-panel);
    border-bottom:1px solid var(--hbkal-border);
}

.hbkal-title-wrap h2{
    margin:0;
    font-size:26px;
    font-weight:700;
    letter-spacing:-0.01em;
}

.hbkal-title-wrap p{
    margin:6px 0 0;
    color:var(--hbkal-muted);
    font-size:13px;
}

.hbkal-controls{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    align-items:center;
}

.hbkal-nav{
    display:flex;
    gap:8px;
}

.hbkal-filter{
    background:var(--hbkal-panel-2);
    color:var(--hbkal-text);
    border:1px solid var(--hbkal-border);
    padding:10px 14px;
    border-radius:12px;
    font-size:14px;
    cursor:pointer;
}

.hbkal-filter:focus-visible,
.hbkal-btn:focus-visible,
.hbkal-day:focus-visible,
.hbkal-close:focus-visible{
    outline:2px solid var(--hbkal-accent);
    outline-offset:2px;
}

.hbkal-btn{
    background:var(--hbkal-panel-2);
    color:var(--hbkal-text);
    border:1px solid var(--hbkal-border);
    padding:10px 16px;
    border-radius:12px;
    cursor:pointer;
    font-weight:600;
    font-size:14px;
    transition:background .15s ease, transform .1s ease;
}

.hbkal-btn:hover{
    background:var(--hbkal-accent);
    border-color:var(--hbkal-accent);
}

.hbkal-btn:active{
    transform:scale(.96);
}

.hbkal-today{
    background:var(--hbkal-accent);
    border-color:var(--hbkal-accent);
}

.hbkal-month{
    text-align:center;
    padding:22px 18px;
    background:var(--hbkal-bg);
    color:var(--hbkal-accent);
    font-size:22px;
    font-weight:700;
    letter-spacing:.02em;
}

.hbkal-weekdays{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    background:var(--hbkal-panel);
}

.hbkal-weekdays div{
    text-align:center;
    padding:12px 4px;
    font-weight:600;
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:.06em;
    color:var(--hbkal-muted);
    border-bottom:1px solid var(--hbkal-border);
}

.hbkal-grid{
    display:grid;
    grid-template-columns:repeat(7,1fr);
    gap:1px;
    background:var(--hbkal-border);
}

.hbkal-day{
    min-height:120px;
    max-height:120px;
    overflow:hidden;
    background:var(--hbkal-bg);
    padding:10px;
    position:relative;
    cursor:pointer;
    display:flex;
    flex-direction:column;
    gap:6px;
    transition:background .15s ease;
}

.hbkal-day:hover{
    background:var(--hbkal-panel-2);
}

.hbkal-day-empty{
    cursor:default;
    background:var(--hbkal-bg);
    opacity:.4;
}

.hbkal-day-empty:hover{
    background:var(--hbkal-bg);
}

.hbkal-weekend .hbkal-day-number{
    color:var(--hbkal-muted);
}

.hbkal-today-highlight{
    background:rgba(224,36,94,.08);
    box-shadow:inset 0 0 0 2px var(--hbkal-accent);
    border-radius:10px;
}

.hbkal-day-number{
    font-weight:700;
    font-size:14px;
}

.hbkal-holiday-tag{
    font-size:10px;
    font-weight:700;
    padding:3px 8px;
    border-radius:999px;
    border:1px solid var(--hbkal-holiday);
    color:var(--hbkal-text);
    background:rgba(255,255,255,.08);
    align-self:flex-start;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:100%;
}

.hbkal-holiday .hbkal-day-number{
    color:var(--hbkal-holiday);
}

.hbkal-events{
    display:flex;
    flex-direction:column;
    gap:4px;
    margin-top:auto;
    overflow:hidden;
    min-height:0;
}

.hbkal-event{
    color:#fff;
    padding:5px 8px;
    border-radius:8px;
    font-size:11px;
    font-weight:700;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}

.hbkal-event[data-type="page"],
.hbkal-event[data-type="holiday"]{
    color:#000;
}

.hbkal-event-more{
    background:var(--hbkal-panel-2) !important;
    color:var(--hbkal-muted) !important;
    text-align:center;
}

.hbkal-legend{
    display:flex;
    flex-wrap:wrap;
    gap:18px;
    padding:16px 28px 22px;
    font-size:12px;
    color:var(--hbkal-muted);
}

.hbkal-legend-item{
    display:flex;
    align-items:center;
    gap:8px;
}

.hbkal-legend-item i{
    display:inline-block;
    width:10px;
    height:10px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.25);
}

.hbkal-error{
    grid-column:1/-1;
    padding:40px 20px;
    text-align:center;
    color:var(--hbkal-muted);
    background:var(--hbkal-bg);
}

/* Modal */
.hbkal-modal{
    position:fixed;
    inset:0;
    display:none;
    justify-content:center;
    align-items:center;
    z-index:2147483647;
    padding:20px;
}

.hbkal-backdrop{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.6) !important;
    backdrop-filter:blur(6px);
    opacity:1 !important;
}

.hbkal-modal-box{
    position:relative;
    width:100%;
    max-width:800px;
    max-height:85vh;
    background:var(--hbkal-panel, #161618) !important;
    color:var(--hbkal-text, #f5f5f7) !important;
    border-radius:20px;
    overflow:hidden;
    z-index:2147483647;
    border:1px solid var(--hbkal-border);
    display:flex;
    flex-direction:column;
    box-shadow:0 20px 60px rgba(0,0,0,.5);
}

.hbkal-modal-top{
    display:flex;
    justify-content:space-between;
    align-items:center;
    gap:12px;
    padding:18px 22px;
    background:var(--hbkal-panel-2);
    border-bottom:1px solid var(--hbkal-border);
    flex-shrink:0;
}

.hbkal-modal-title{
    color:var(--hbkal-accent);
    font-size:18px;
    font-weight:800;
}

.hbkal-close{
    background:none;
    border:none;
    color:var(--hbkal-muted);
    font-size:28px;
    line-height:1;
    font-weight:400;
    cursor:pointer;
    padding:4px 10px;
    border-radius:8px;
    flex-shrink:0;
}

.hbkal-close:hover{
    color:var(--hbkal-text);
    background:rgba(255,255,255,.06);
}

.hbkal-modal-content{
    padding:4px 22px 22px;
    overflow-y:auto;
    overflow-x:hidden;
    background:var(--hbkal-panel, #161618) !important;
    color:var(--hbkal-text, #f5f5f7) !important;
}

.hbkal-empty{
    color:var(--hbkal-muted);
    text-align:center;
    padding:36px 0;
    font-size:14px;
}

.hbkal-item{
    padding:18px 0;
    border-bottom:1px solid var(--hbkal-border);
}

.hbkal-item:last-child{
    border-bottom:none;
}

.hbkal-item-head{
    display:flex;
    align-items:flex-start;
    gap:10px;
}

.hbkal-item-dot{
    width:10px;
    height:10px;
    border-radius:50%;
    border:1px solid rgba(255,255,255,.25);
    flex-shrink:0;
    margin-top:6px;
}

.hbkal-item-title{
    font-size:16px;
    font-weight:700;
    color:var(--hbkal-text);
    line-height:1.4;
    word-break:break-word;
}

.hbkal-item-type{
    display:inline-block;
    margin-top:8px;
    margin-left:20px;
    padding:3px 10px;
    border-radius:999px;
    font-size:11px;
    font-weight:600;
    background:var(--hbkal-panel-2);
    color:var(--hbkal-muted);
    border:1px solid var(--hbkal-border);
}

.hbkal-item-excerpt{
    margin-top:10px;
    margin-left:20px;
    color:var(--hbkal-muted);
    line-height:1.6;
    font-size:14px;
    word-break:break-word;
}

.hbkal-item-link{
    display:inline-block;
    margin-top:14px;
    margin-left:20px;
    background:var(--hbkal-accent);
    color:#fff;
    text-decoration:none;
    padding:10px 18px;
    border-radius:10px;
    font-weight:700;
    font-size:13px;
}

.hbkal-item-link:hover{
    background:#b30e18;
}

/* ---- Responsive ---- */

@media (max-width:900px){
    .hbkal-wrap{
        margin:16px;
        border-radius:16px;
    }

    .hbkal-header{
        padding:18px 16px;
    }

    .hbkal-day{
        min-height:90px;
        padding:8px 6px;
    }
}

@media (max-width:640px){

    .hbkal-wrap{
        margin:0;
        border-radius:0;
        border-left:none;
        border-right:none;
    }

    .hbkal-header{
        flex-direction:column;
        align-items:stretch;
        gap:12px;
    }

    .hbkal-controls{
        justify-content:space-between;
    }

    .hbkal-filter{
        flex:1;
    }

    .hbkal-month{
        font-size:18px;
        padding:16px;
    }

    .hbkal-weekdays div{
        font-size:10px;
        padding:8px 2px;
    }

    /* Mobile: muutetaan ruudukko ilmavaksi listanäkymäksi */
    .hbkal-grid{
        display:flex;
        flex-direction:column;
        gap:0;
        background:transparent;
    }

    .hbkal-day-empty{
        display:none;
    }

    .hbkal-day{
        min-height:auto;
        flex-direction:row;
        align-items:center;
        gap:12px;
        padding:14px 16px;
        border-bottom:1px solid var(--hbkal-border);
        border-radius:0;
    }

    .hbkal-day:hover{
        background:var(--hbkal-panel);
    }

    .hbkal-today-highlight{
        border-radius:0;
        box-shadow:inset 4px 0 0 0 var(--hbkal-accent);
        background:rgba(224,36,94,.06);
    }

    .hbkal-day-number{
        font-size:15px;
        min-width:28px;
        flex-shrink:0;
    }

    .hbkal-holiday-tag{
        flex-shrink:0;
        max-width:140px;
    }

    .hbkal-events{
        flex-direction:row;
        flex-wrap:wrap;
        margin-top:0;
        flex:1;
    }

    .hbkal-event{
        max-width:140px;
    }

    .hbkal-legend{
        padding:14px 16px 20px;
        justify-content:center;
    }

    .hbkal-modal{
        padding:0;
        align-items:flex-end;
    }

    .hbkal-modal-box{
        max-width:100%;
        max-height:88vh;
        border-radius:20px 20px 0 0;
        width:100%;
    }
}

