/* ══════════════════════════════════════════════════
   CONTENT CALENDAR — NEOBRUTALIST
   ══════════════════════════════════════════════════ */

.cal-container { max-width: 1100px; }

/* ── Summary strip ───────────────────────────────── */

.cal-summary-strip {
    display: flex; gap: 8px; margin-bottom: 20px;
    padding: 14px 18px;
    background: var(--bg-card); border: var(--border);
    box-shadow: var(--shadow-sm);
    border-radius: var(--r);
}
.cal-summary-item { flex: 1; text-align: center; padding: 4px 0; }
.cal-summary-value { display: block; font-size: 22px; font-weight: 900; line-height: 1.2; }
.cal-summary-label { font-size: 9px; color: var(--text-dim); text-transform: uppercase; letter-spacing: .8px; font-weight: 800; }

/* ── Controls bar ────────────────────────────────── */

.cal-controls {
    display: flex; align-items: center;
    justify-content: space-between;
    margin-bottom: 20px; gap: 12px;
    flex-wrap: wrap;
}
.cal-controls-left { display: flex; align-items: center; gap: 8px; }
.cal-controls-right { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }

.cal-title {
    font-size: 20px; font-weight: 900; margin-left: 10px;
    color: var(--black); text-transform: uppercase;
    letter-spacing: -0.5px;
}

.cal-view-toggle {
    display: flex;
    border: var(--border-thin); overflow: hidden;
    border-radius: var(--r);
}
.cal-view-btn {
    padding: 6px 16px; font-size: 11px; font-weight: 800;
    background: var(--white); color: var(--text-dim);
    border: none; cursor: pointer;
    text-transform: uppercase;
    letter-spacing: .3px;
    transition: all .1s;
    border-right: var(--border-thin);
}
.cal-view-btn:last-child { border-right: none; }
.cal-view-btn:hover { color: var(--text); background: var(--cream); }
.cal-view-btn.active { background: var(--black); color: var(--yellow); }

.cal-profile-indicator { display: flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 700; }

/* ── Month grid ──────────────────────────────────── */

.cal-month-grid {
    display: grid; grid-template-columns: repeat(7, 1fr);
    gap: 2px; background: var(--black);
    border: var(--border);
    overflow: hidden;
    box-shadow: var(--shadow);
    border-radius: var(--r);
}
.cal-day-header {
    background: var(--black); padding: 10px;
    text-align: center; font-size: 10px; font-weight: 800;
    color: var(--yellow); text-transform: uppercase; letter-spacing: 1px;
}
.cal-cell {
    background: var(--bg-card); min-height: 110px;
    padding: 8px; cursor: pointer; transition: background .1s;
}
.cal-cell:hover { background: var(--cream); }
.cal-cell-empty { background: #F5F5F0; cursor: default; }
.cal-cell-empty:hover { background: #F5F5F0; }
.cal-cell-today { background: rgba(74,144,255,.05); }
.cal-cell-date { font-size: 13px; font-weight: 800; color: var(--text-dim); margin-bottom: 6px; }
.cal-today-badge {
    display: inline-flex; align-items: center; justify-content: center;
    width: 26px; height: 26px;
    background: var(--blue); color: #fff; font-weight: 800; font-size: 12px;
    border: 2px solid var(--black);
    border-radius: 50%;
}

.cal-cell-events { display: flex; flex-direction: column; gap: 3px; }
.cal-event-chip {
    display: flex; align-items: center; gap: 4px;
    padding: 3px 6px; border-radius: var(--r);
    cursor: pointer; font-size: 10px; line-height: 1.3;
    overflow: hidden; font-weight: 600;
    border-left: 3px solid;
}
.cal-event-chip:hover { opacity: .75; }
.cal-event-time { font-weight: 800; white-space: nowrap; flex-shrink: 0; }
.cal-event-icon { flex-shrink: 0; }
.cal-event-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text-dim); }
.cal-more-count { font-size: 10px; color: var(--text-dim); text-align: center; padding: 2px 0; font-weight: 700; }

/* ── Week grid ───────────────────────────────────── */

.cal-week-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 8px; }
.cal-week-day {
    background: var(--bg-card); border: var(--border);
    overflow: hidden; min-height: 200px;
    box-shadow: var(--shadow-sm); transition: all .1s;
    border-radius: var(--r);
}
.cal-week-day:hover { transform: translate(-1px, -1px); box-shadow: var(--shadow); }
.cal-week-day-today { border-color: var(--blue); box-shadow: 3px 3px 0 var(--blue); }
.cal-week-day-header {
    display: flex; align-items: center; gap: 6px;
    padding: 10px 12px; background: var(--cream);
    border-bottom: var(--border-thin); cursor: pointer;
}
.cal-week-day-header:hover { background: var(--yellow); }
.cal-week-day-name { font-size: 10px; font-weight: 800; color: var(--text-dim); text-transform: uppercase; letter-spacing: .5px; }
.cal-week-day-num { font-size: 15px; font-weight: 900; }
.cal-week-day-count { font-size: 10px; color: var(--text-dim); margin-left: auto; font-weight: 700; }
.cal-week-day-events { padding: 8px; display: flex; flex-direction: column; gap: 6px; }
.cal-empty-day { text-align: center; color: var(--text-dim); font-size: 11px; padding: 24px 0; font-weight: 600; }

/* ── Day view ────────────────────────────────────── */

.cal-day-list { display: flex; flex-direction: column; gap: 10px; }
.cal-day-empty { text-align: center; color: var(--text-dim); padding: 72px 24px; font-size: 14px; font-weight: 600; }

/* ── Event card (week + day views) ───────────────── */

.cal-event-card {
    background: var(--bg-card); border: var(--border-thin);
    padding: 10px 14px; cursor: pointer;
    box-shadow: var(--shadow-sm);
    transition: all .1s;
    border-radius: var(--r);
}
.cal-event-card:hover { transform: translate(-1px, -1px); box-shadow: var(--shadow); }
.cal-event-card-top { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
.cal-event-card-time { font-size: 12px; font-weight: 800; color: var(--black); }
.cal-event-card-type { font-size: 11px; color: var(--text-dim); font-weight: 600; }
.cal-event-card-status { font-size: 9px; font-weight: 800; margin-left: auto; text-transform: uppercase; letter-spacing: .4px; }
.cal-event-card-title { font-size: 13px; color: var(--text); line-height: 1.5; }
.cal-event-card-tags { display: flex; gap: 4px; margin-top: 6px; }

.cal-tag {
    font-size: 9px; padding: 2px 8px;
    font-weight: 800; text-transform: uppercase;
    border: 2px solid var(--black);
    border-radius: var(--r);
}
.cal-tag-media { background: rgba(74,144,255,.1); color: var(--blue); }
.cal-tag-visual { background: rgba(255,225,86,.3); color: #B8860B; }
.cal-tag-manual { background: rgba(176,107,255,.1); color: var(--purple); }

/* ── Drawer ──────────────────────────────────────── */

.cal-drawer-overlay {
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,.5);
    z-index: 1000; display: flex; justify-content: flex-end;
}
.cal-drawer-overlay.hidden { display: none; }

.cal-drawer {
    width: 500px; max-width: 92vw; height: 100vh;
    background: var(--cream); border-left: var(--border);
    overflow-y: auto; padding: 24px;
}
.cal-drawer-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.cal-drawer-header > div { display: flex; align-items: center; gap: 10px; }
.cal-drawer-type { font-size: 16px; font-weight: 900; text-transform: uppercase; }
.cal-drawer-status {
    font-size: 10px; font-weight: 800; padding: 3px 12px;
    text-transform: uppercase;
    border: 2px solid var(--black);
    border-radius: var(--r);
}

.cal-drawer-meta {
    display: grid; grid-template-columns: 1fr; gap: 6px;
    font-size: 13px; color: var(--text); padding: 14px 18px;
    background: var(--bg-card); border: var(--border-thin);
    margin-bottom: 18px;
    box-shadow: var(--shadow-sm);
    border-radius: var(--r);
}
.cal-drawer-meta strong { color: var(--text-dim); font-weight: 700; }

.cal-drawer-manual-status {
    display: flex; align-items: center; justify-content: space-between;
    padding: 14px 18px;
    margin-bottom: 18px; font-size: 13px; font-weight: 700;
    border: var(--border-thin);
    border-radius: var(--r);
}
.cal-drawer-manual-status.cal-posted { background: rgba(107,255,184,.15); border-color: #059669; color: #059669; }
.cal-drawer-manual-status.cal-not-posted { background: rgba(176,107,255,.1); border-color: var(--purple); color: var(--purple); }

.cal-drawer-visual {
    padding: 12px 16px; background: rgba(255,225,86,.15);
    border: 2px solid #B8860B;
    font-size: 12px; color: var(--text); margin-bottom: 18px;
    font-weight: 600;
    border-radius: var(--r);
}

.cal-drawer-section { margin-bottom: 18px; }
.cal-drawer-section-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 10px; font-size: 12px; font-weight: 800;
    color: var(--text-dim); text-transform: uppercase; letter-spacing: .5px;
}

.cal-drawer-content {
    background: var(--bg-card); border: var(--border-thin);
    padding: 16px;
    font-size: 13px; line-height: 1.7; color: var(--text);
    white-space: pre-wrap; max-height: 300px; overflow-y: auto;
    box-shadow: var(--shadow-sm);
    border-radius: var(--r);
}

.cal-article-title { font-size: 18px; font-weight: 900; color: var(--black); margin-bottom: 14px; line-height: 1.3; text-transform: uppercase; }
.cal-article-body {
    background: var(--bg-card); border: var(--border-thin);
    padding: 18px;
    font-size: 13px; line-height: 1.8; color: var(--text);
    white-space: pre-wrap; max-height: 500px; overflow-y: auto;
    box-shadow: var(--shadow-sm);
    border-radius: var(--r);
}

.cal-drawer-actions { padding-top: 14px; border-top: var(--border-thin); display: flex; gap: 10px; flex-wrap: wrap; }
.cal-drawer-error { padding: 48px; text-align: center; color: var(--coral); font-weight: 700; }

/* ── Responsive ──────────────────────────────────── */

@media (max-width: 768px) {
    .cal-month-grid { font-size: 10px; }
    .cal-cell { min-height: 65px; padding: 4px; }
    .cal-cell-date { font-size: 11px; }
    .cal-event-chip { font-size: 8px; padding: 2px 4px; }
    .cal-week-grid { grid-template-columns: 1fr; gap: 6px; }
    .cal-week-day { min-height: auto; }
    .cal-summary-strip { flex-wrap: wrap; padding: 10px 12px; }
    .cal-summary-item { min-width: 55px; }
    .cal-summary-value { font-size: 18px; }
    .cal-drawer { width: 100vw; max-width: 100vw; padding: 16px; }
    .cal-controls { gap: 8px; }
    .cal-title { font-size: 16px; margin-left: 6px; }
    .cal-view-btn { padding: 5px 12px; font-size: 10px; }
}

@media (max-width: 430px) {
    .cal-cell { min-height: 55px; padding: 3px; }
    .cal-cell-date { font-size: 10px; }
    .cal-today-badge { width: 22px; height: 22px; font-size: 10px; }
    .cal-event-chip { font-size: 7px; }
    .cal-summary-strip { gap: 4px; }
    .cal-summary-value { font-size: 16px; }
    .cal-summary-label { font-size: 8px; }
}
