/* MINI CALENDAR CSS - Bootstrap 5 Darkmode Support + Event Dot */
/* Core structure unchanged, only minimal/modern tweaks & darkmode vars added */

:root {
	--cal-bg-light: #22252e;
	--cal-bg-dark: #181a1b;
	--cal-text-light: #fff;
	--cal-text-dark: #f3f3f3;
	--cal-accent: #ff9101;
	--cal-border-light: #ddd;
	--cal-border-dark: #444;
	--cal-date-bg-focus-light: #3f4042;
	--cal-date-bg-focus-dark: #22242a;
	--cal-footer-link-hover-light: #555;
	--cal-footer-link-hover-dark: #222;
}

/* font */
@font-face {
	font-family: "Material Icons";
	font-style: normal;
	font-weight: 400;
	src: url(https://fonts.gstatic.com/s/materialicons/v127/flUhRq6tzZclQEJ-Vdg-IuiaDsNcIhQ8tQ.woff2)
		format("woff2");
}
/* Default (light mode) */
/* Default (light mode) */
:root {
	--cal-bg: #fff;
	--cal-text: #212529; /* default text bs-body-color */
	--cal-border: #dee2e6; /* bootstrap border default */
	--cal-date-bg-focus: #e9ecef; /* soft grey highlight */
	--cal-footer-link-hover: #f8f9fa;
	--cal-nav-btn-bg: rgba(0, 0, 0, 0.05); /* tombol nav bg */
	--cal-nav-btn-hover: rgba(0, 0, 0, 0.12); /* hover bg nav */
}

/* Dark mode */
[data-bs-theme="dark"] {
	--cal-bg: #1e1e1e;
	--cal-text: #f8f9fa;
	--cal-border: #444;
	--cal-date-bg-focus: #333;
	--cal-footer-link-hover: #555;
}

/* Base container */
.mini-cal {
	user-select: none;
	font-family: Verdana, sans-serif;
	padding-bottom: 1.2em;
	background: var(--cal-bg);
	color: var(--cal-text);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	transition: background 0.25s, color 0.25s, box-shadow 0.2s;
}

/* Title bar */
#calTitle {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 1.12em;
	text-align: center;
	padding: 0.4em 1em 0.8em 1em;
}

/* Navigation buttons */
#calTitle button {
	outline: none;
	display: flex;
	margin-top: 13px;
	align-items: center;
	justify-content: center;
	border: none;
	padding: 0;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: var(--cal-nav-btn-bg);
	transition: background 0.2s;
	cursor: pointer;
}

#calTitle button svg {
	width: 22px;
	height: 22px;
	fill: var(--cal-text); /* ikuti warna teks */
}

#calTitle button:hover {
	background: var(--cal-nav-btn-hover);
}

/* Head & grid */
#calThead,
#calTbody {
	display: flex;
	flex-wrap: wrap;
	padding: 0.1em;
}
#calThead {
	color: var(--cal-text);
	margin-top: 0.4em;
	align-items: center;
	text-align: center;
	font-size: 0.88em;
}
#calThead > div,
#calTbody .a-date {
	box-sizing: border-box;
	flex: 1;
	min-width: calc(100% / 7);
	max-width: calc(100% / 7);
	width: calc(100% / 7);
	text-align: center;
	padding: 0;
}
#calThead > div {
	font-size: 1.1em;
	padding: 0.2em 0.2em;
}

/* Dates grid */
#calTbody {
	color: var(--cal-text);
	font-size: 0.9em;
}
#calTbody .a-date > span {
	display: block;
	font-size: 1em;
}

/* Date cell */
#calTbody .a-date {
	cursor: default;
	padding: 1em;
	position: relative;
	background-color: transparent;
	color: var(--cal-text);
	border: 0.1em solid transparent;
	outline: none;
	font-size: 0.9em;
	transition: background 0.18s, color 0.18s;
}

#calTbody .a-date.current {
	border-color: var(--cal-accent);
	font-weight: 600;
}

#calTbody .a-date.blurred {
	opacity: 0.2;
	pointer-events: none;
}

#calTbody .a-date.focused,
#calTbody .a-date:active {
	background: var(--cal-date-bg-focus); /* abu soft di light mode */
}

/* Event dot (above date) */
#calTbody .a-date.event > span::before {
	content: "";
	display: block;
	margin: 0 auto 2px auto;
	width: 0.38em;
	height: 0.38em;
	background-color: var(--cal-accent);
	border-radius: 50%;
}
/* Current date with event & focus */

/* Footer */
#calTFooter {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 1.1em;
	padding: 0 1em;
	margin-top: 0.5em;
}

#calTFooter #calLink {
	font-size: 0.8em;
	display: inline-block;
	padding: 0.6em 0.8em;
	font-weight: 500;
	color: var(--bs-warning);
	background-color: transparent;
	border: 1px solid var(--bs-warning);
	border-radius: 0.375rem; /* bs rounded */
	transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out,
		border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
	text-decoration: none;
	white-space: nowrap;
}

#calTFooter #calLink:hover {
	color: #fff;
	background-color: var(--bs-warning);
	border-color: var(--bs-warning);
}

/* Event title */
#calTFooter #eventTitle {
	margin: 0;
	margin-right: 0.1em;
	font-weight: normal;
	font-size: 0.95em;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* Responsive tweaks */
@media (max-width: 600px) {
	.mini-cal {
		border-radius: 7px;
		font-size: 0.95em;
	}
	#calTitle,
	#calTFooter {
		padding-left: 0.4em;
		padding-right: 0.4em;
	}
}

/* Smooth transitions for theme switches */
.mini-cal,
#calTitle,
#calTFooter,
#calTbody .a-date {
	transition: background 0.25s, color 0.25s, box-shadow 0.18s;
}
