.csu-calendar-wrap,
.csu-request-form-wrap,
.csu-weekend-list,
.csu-private-dashboard {
	display: grid;
	gap: 1rem;
}

.csc-calendar-card {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 18px;
	box-shadow: 0 16px 42px rgba(16, 42, 67, 0.12);
	display: grid;
	gap: 1rem;
	padding: clamp(1rem, 3vw, 1.6rem);
}

.csc-calendar-main {
	display: grid;
	gap: 1rem;
	min-width: 0;
}

.csc-calendar-toolbar {
	align-items: center;
	display: grid;
	gap: 0.75rem;
	grid-template-columns: auto 1fr auto;
}

.csc-calendar-heading {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: clamp(1.35rem, 4vw, 2rem);
	font-weight: 800;
	letter-spacing: -0.035em;
	line-height: 1;
	text-align: center;
}

.csc-calendar-nav {
	align-items: center;
	background: var(--cs-teal, #1398a7);
	border: 0;
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-size: 1.6rem;
	font-weight: 800;
	height: 2.4rem;
	justify-content: center;
	line-height: 1;
	width: 2.4rem;
	transition: background-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.csc-calendar-nav:hover,
.csc-calendar-nav:focus {
	background: var(--cs-teal-dark, #087987);
	box-shadow: 0 8px 18px rgba(16, 42, 67, 0.16);
	transform: translateY(-1px);
}

.csc-calendar-message {
	background: rgba(19, 152, 167, 0.1);
	border: 1px solid rgba(19, 152, 167, 0.2);
	border-radius: 999px;
	color: var(--cs-navy, #102a43);
	font-weight: 800;
	padding: 0.75rem 1rem;
	text-align: center;
}

.csc-calendar-message.is-active {
	background: #fff;
	box-shadow: 0 10px 24px rgba(16, 42, 67, 0.1);
}

.csc-calendar-preview {
	border-radius: 20px;
	box-shadow: none;
	padding: 0;
}

.csc-calendar-preview .csc-calendar-toolbar {
	display: none;
}

.csc-calendar-preview .csc-calendar-message,
.csc-calendar-preview .csu-calendar-legend {
	display: none;
}

.csu-calendar-legend {
	display: flex;
	flex-wrap: wrap;
	gap: 0.55rem 1rem;
	margin-bottom: 0.4rem;
}

.csu-calendar-legend span {
	align-items: center;
	color: var(--cs-muted, #66788a);
	display: inline-flex;
	font-size: 0.88rem;
	font-weight: 800;
	gap: 0.38rem;
}

.csu-status-dot {
	border-radius: 999px;
	display: inline-block;
	height: 0.85rem;
	width: 0.85rem;
}

.csu-calendar-months {
	display: grid;
	gap: 1rem;
}

.csu-calendar-month {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 18px;
	padding: 1rem;
}

.csu-calendar-month h3 {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: 1.25rem;
	line-height: 1;
	margin: 0 0 0.8rem;
	text-align: center;
}

.csc-calendar-card:not(.csc-calendar-preview) .csu-calendar-month h3 {
	display: none;
}

.csu-calendar-grid {
	display: grid;
	gap: clamp(0.18rem, 1vw, 0.35rem);
	grid-template-columns: repeat(7, minmax(0, 1fr));
}

.csu-calendar-weekdays {
	color: var(--cs-muted, #66788a);
	font-size: 0.7rem;
	font-weight: 900;
	letter-spacing: 0.05em;
	margin-bottom: 0.35rem;
	text-align: center;
	text-transform: uppercase;
}

.csu-calendar-day {
	align-items: center;
	aspect-ratio: 1;
	border: 1px solid rgba(255, 255, 255, 0.65);
	border-radius: 10px;
	display: inline-flex;
	font-size: 0.86rem;
	font-weight: 900;
	justify-content: center;
	min-height: clamp(1.9rem, 6vw, 2.6rem);
	padding: 0;
	transition: box-shadow 160ms ease, transform 160ms ease;
	width: 100%;
}

button.csu-calendar-day {
	cursor: pointer;
}

button.csu-calendar-day:hover,
button.csu-calendar-day:focus {
	box-shadow: 0 8px 18px rgba(16, 42, 67, 0.16);
	outline: 2px solid rgba(19, 152, 167, 0.35);
	outline-offset: 2px;
	transform: translateY(-1px);
}

.csu-calendar-empty {
	background: transparent;
	border-color: transparent;
}

.csu-status-available {
	background: var(--cs-green, #bde7b8);
	color: #225a2a;
}

.csu-status-confirmed {
	background: var(--cs-red, #ffb1a8);
	color: #8a2632;
}

.csu-status-tentative {
	background: var(--cs-yellow, #ffe28a);
	color: #755a00;
}

.csu-status-blocked,
.csu-status-pending,
.csu-status-declined {
	background: var(--cs-gray, #d8dce2);
	color: #38465d;
}

.csu-status-family_only {
	background:
		repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.36) 0 6px, rgba(216, 220, 226, 0.78) 6px 12px),
		#ccefed;
	color: #0b5d67;
}

.csu-weekend-list {
	margin-bottom: 1rem;
}

.csu-weekend-row,
.csu-dashboard-row {
	align-items: center;
	background: rgba(255, 255, 255, 0.72);
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 14px;
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	padding: 0.8rem 0.9rem;
}

.csu-weekend-row strong,
.csu-dashboard-row strong {
	color: var(--cs-navy, #102a43);
	display: block;
	line-height: 1.15;
}

.csu-weekend-row span,
.csu-dashboard-row span {
	color: var(--cs-muted, #66788a);
	display: block;
	font-size: 0.86rem;
}

.csu-status-pill {
	border-radius: 999px;
	flex: 0 0 auto;
	font-size: 0.75rem !important;
	font-weight: 900;
	line-height: 1;
	padding: 0.5rem 0.65rem;
}

.csc-open-weekends {
	display: grid;
	gap: 1rem;
}

.csc-open-weekends-title {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: clamp(1.25rem, 3vw, 1.65rem);
	line-height: 1.05;
	margin: 0;
}

.csc-open-weekends-list {
	display: grid;
	gap: 0.75rem;
}

.csc-open-weekend {
	align-items: center;
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 16px;
	display: flex;
	gap: 0.85rem;
	justify-content: space-between;
	padding: 0.85rem;
}

.csc-open-weekend strong {
	color: var(--cs-navy, #102a43);
	display: block;
	font-size: 1rem;
	line-height: 1.15;
	margin-bottom: 0.4rem;
}

.csc-open-weekend-link {
	background: var(--cs-coral, #ff6a3d);
	border-radius: 999px;
	color: #fff;
	flex: 0 0 auto;
	font-size: 0.82rem;
	font-weight: 900;
	line-height: 1;
	padding: 0.72rem 0.9rem;
	text-align: center;
}

.csc-open-weekend-link:hover,
.csc-open-weekend-link:focus {
	background: var(--cs-coral-dark, #e9562c);
	color: #fff;
}

.csc-open-weekends-empty {
	background: rgba(255, 255, 255, 0.78);
	border: 1px dashed var(--cs-border, #e8dfd2);
	border-radius: 16px;
	color: var(--cs-muted, #66788a);
	font-weight: 800;
	margin: 0;
	padding: 1rem;
}

.csc-open-weekends.is-compact {
	gap: 0.75rem;
}

.csc-open-weekends.is-compact .csc-open-weekends-title {
	font-size: 1.2rem;
}

.csc-open-weekends.is-compact .csc-open-weekend {
	padding: 0.72rem;
}

.csu-request-form {
	display: grid;
	gap: 0.8rem;
}

.csc-request-form-header {
	display: grid;
	gap: 0.45rem;
	margin-bottom: 0.2rem;
}

.csc-request-form-header h3 {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: clamp(1.35rem, 4vw, 2rem);
	line-height: 1.05;
	margin: 0;
}

.csc-request-form-header p {
	color: var(--cs-muted, #66788a);
	margin: 0;
}

.csc-sleeping-note {
	background: rgba(19, 152, 167, 0.1);
	border: 1px solid rgba(19, 152, 167, 0.2);
	border-radius: 14px;
	color: var(--cs-navy, #102a43) !important;
	font-weight: 800;
	padding: 0.8rem 0.9rem;
}

.csu-request-form label {
	display: block;
}

.csu-request-form label span,
.csc-date-pair > span {
	color: var(--cs-navy, #102a43);
	display: block;
	font-size: 0.88rem;
	font-weight: 900;
	margin-bottom: 0.35rem;
}

.csc-date-pair > div {
	display: grid;
	gap: 0.5rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.csu-request-form input,
.csu-request-form select,
.csu-request-form textarea {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 12px;
	box-shadow: inset 0 1px 2px rgba(16, 42, 67, 0.04);
	color: var(--cs-navy, #102a43);
	font: inherit;
	padding: 0.85rem 0.95rem;
	width: 100%;
}

.csu-request-form input:focus,
.csu-request-form select:focus,
.csu-request-form textarea:focus,
.csc-dashboard-form input:focus,
.csc-dashboard-form select:focus,
.csc-dashboard-form textarea:focus {
	border-color: var(--cs-teal, #1398a7);
	box-shadow: 0 0 0 4px rgba(19, 152, 167, 0.14);
	outline: none;
}

.csu-request-form textarea {
	resize: vertical;
}

.csu-request-form .csu-submit {
	justify-self: center;
	min-width: min(100%, 260px);
}

.csu-form-wide {
	grid-column: 1 / -1;
}

.csu-form-message {
	border-radius: 14px;
	font-weight: 800;
	padding: 0.8rem 1rem;
}

.csu-form-success {
	background: #dff7f5;
	color: #087b80;
}

.csu-form-error {
	background: #ffe0d7;
	color: #9f391f;
}

.csu-form-warning {
	background: #fff0c2;
	color: #715600;
}

.csu-private-dashboard {
	grid-template-columns: minmax(0, 1fr);
}

.csu-private-dashboard h2 {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	line-height: 1;
	margin: 0 0 1rem;
}

.csu-dashboard-list {
	display: grid;
	gap: 0.75rem;
}

.csc-dashboard {
	display: grid;
	gap: 1.1rem;
}

.csc-dashboard-hero {
	background:
		linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(251, 247, 239, 0.94)),
		radial-gradient(circle at 92% 20%, rgba(19, 152, 167, 0.16), transparent 16rem);
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 18px;
	box-shadow: 0 16px 42px rgba(16, 42, 67, 0.12);
	padding: clamp(1.3rem, 4vw, 2rem);
}

.csc-dashboard-hero h2 {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: clamp(2rem, 7vw, 4rem);
	letter-spacing: -0.05em;
	line-height: 0.98;
	margin: 0;
}

.csc-dashboard-hero p:not(.eyebrow) {
	color: var(--cs-muted, #66788a);
	font-size: 1.05rem;
	margin: 0.8rem 0 0;
	max-width: 720px;
}

.csc-dashboard-actions {
	display: grid;
	gap: 0.85rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.csc-action-card,
.csc-dashboard-card {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 18px;
	box-shadow: 0 14px 32px rgba(16, 42, 67, 0.1);
}

.csc-action-card {
	align-items: center;
	color: var(--cs-navy, #102a43);
	display: flex;
	font-weight: 900;
	gap: 0.7rem;
	padding: 1rem;
}

.csc-action-card span {
	align-items: center;
	background: rgba(19, 152, 167, 0.12);
	border-radius: 999px;
	color: var(--cs-teal-dark, #087987);
	display: inline-flex;
	flex: 0 0 auto;
	font-size: 0.78rem;
	font-weight: 900;
	height: 2.25rem;
	justify-content: center;
	text-transform: uppercase;
	width: 2.25rem;
}

.csc-action-card:hover,
.csc-action-card:focus {
	color: var(--cs-coral-dark, #e9562c);
	transform: translateY(-1px);
}

.csc-dashboard-card {
	display: grid;
	gap: 1rem;
	padding: clamp(1rem, 3vw, 1.5rem);
}

.csc-dashboard-card h3 {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: clamp(1.35rem, 4vw, 2rem);
	line-height: 1;
	margin: 0;
}

.csc-request-card-list,
.csc-dashboard-list {
	display: grid;
	gap: 0.85rem;
}

.csc-request-card,
.csc-dashboard-row {
	background: var(--cs-sand-soft, #fbf7ef);
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 18px;
	display: grid;
	gap: 0.9rem;
	padding: 1rem;
}

.csc-request-card h4 {
	align-items: center;
	color: var(--cs-navy, #102a43);
	display: flex;
	flex-wrap: wrap;
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: 1.25rem;
	gap: 0.5rem;
	line-height: 1;
	margin: 0;
}

.csc-request-card p,
.csc-dashboard-row span {
	color: var(--cs-muted, #66788a);
	margin: 0;
}

.csc-request-meta {
	display: flex;
	flex-wrap: wrap;
	font-weight: 800;
	gap: 0.5rem 0.9rem;
}

.csc-request-actions {
	display: grid;
	gap: 0.55rem;
}

.csc-overlap-badge {
	background: var(--cs-yellow, #ffe28a);
	border-radius: 999px;
	color: #715600;
	font-family: var(--cs-body-font, Arial, sans-serif);
	font-size: 0.7rem;
	font-weight: 900;
	letter-spacing: 0.04em;
	line-height: 1;
	padding: 0.45rem 0.55rem;
	text-transform: uppercase;
}

.csc-overlap-note {
	background: #fff0c2;
	border: 1px solid rgba(255, 226, 138, 0.9);
	border-radius: 12px;
	color: #715600 !important;
	font-weight: 900;
	padding: 0.65rem 0.75rem;
}

.csc-request-action-form {
	display: grid;
	gap: 0.55rem;
}

.csc-action-select span,
.csc-checkbox-field span {
	color: var(--cs-navy, #102a43);
	display: block;
	font-size: 0.78rem;
	font-weight: 900;
	margin-bottom: 0.3rem;
}

.csc-action-select select {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 12px;
	color: var(--cs-navy, #102a43);
	font: inherit;
	padding: 0.72rem 0.8rem;
	width: 100%;
}

.csc-checkbox-field {
	align-items: start;
	display: grid;
	gap: 0.55rem;
	grid-template-columns: auto minmax(0, 1fr);
}

.csc-checkbox-field input {
	margin-top: 0.25rem;
	width: auto;
}

.csc-checkbox-field span {
	margin: 0;
}

.csc-dashboard-button {
	background: var(--cs-coral, #ff6a3d);
	border: 0;
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	font-weight: 900;
	line-height: 1;
	padding: 0.78rem 0.95rem;
}

.csc-dashboard-button:hover,
.csc-dashboard-button:focus {
	background: var(--cs-coral-dark, #e9562c);
}

.csc-dashboard-button.is-secondary {
	background: var(--cs-teal, #1398a7);
}

.csc-dashboard-button.is-secondary:hover,
.csc-dashboard-button.is-secondary:focus {
	background: var(--cs-teal-dark, #087987);
}

.csc-dashboard-row {
	align-items: center;
	grid-template-columns: minmax(0, 1fr) auto;
}

.csc-dashboard-row strong {
	color: var(--cs-navy, #102a43);
	display: block;
	line-height: 1.15;
}

.csc-dashboard-empty {
	background: rgba(251, 247, 239, 0.72);
	border: 1px dashed var(--cs-border, #e8dfd2);
	border-radius: 16px;
	color: var(--cs-muted, #66788a);
	font-weight: 800;
	margin: 0;
	padding: 1rem;
}

.csc-dashboard-form {
	display: grid;
	gap: 0.85rem;
}

.csc-dashboard-form label span {
	color: var(--cs-navy, #102a43);
	display: block;
	font-size: 0.88rem;
	font-weight: 900;
	margin-bottom: 0.35rem;
}

.csc-dashboard-form input,
.csc-dashboard-form select,
.csc-dashboard-form textarea {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 12px;
	box-shadow: inset 0 1px 2px rgba(16, 42, 67, 0.04);
	color: var(--cs-navy, #102a43);
	font: inherit;
	padding: 0.85rem 0.95rem;
	width: 100%;
}

.csc-guest-book {
	display: grid;
	gap: 1rem;
}

.csc-guest-book-card {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 18px;
	box-shadow: 0 14px 32px rgba(16, 42, 67, 0.1);
	display: grid;
	gap: 0.9rem;
	padding: clamp(1rem, 3vw, 1.4rem);
}

.csc-guest-book-header {
	display: grid;
	gap: 0.45rem;
}

.csc-guest-book-header h3,
.csc-guest-book-card > h3 {
	color: var(--cs-navy, #102a43);
	font-family: var(--cs-heading-font, Georgia, serif);
	font-size: clamp(1.35rem, 4vw, 2rem);
	line-height: 1;
	margin: 0;
}

.csc-guest-book-header p {
	color: var(--cs-muted, #66788a);
	margin: 0;
}

.csc-guest-book-form {
	display: grid;
	gap: 0.85rem;
}

.csc-guest-book-form label span {
	color: var(--cs-navy, #102a43);
	display: block;
	font-size: 0.88rem;
	font-weight: 900;
	margin-bottom: 0.35rem;
}

.csc-guest-book-form input[type="file"],
.csc-guest-book-form textarea {
	background: #fff;
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 12px;
	color: var(--cs-navy, #102a43);
	font: inherit;
	padding: 0.8rem 0.9rem;
	width: 100%;
}

.csc-guest-book-form textarea {
	resize: vertical;
}

.csc-guest-book-form input[type="file"]:focus,
.csc-guest-book-form textarea:focus {
	border-color: var(--cs-teal, #1398a7);
	box-shadow: 0 0 0 4px rgba(19, 152, 167, 0.14);
	outline: none;
}

.csc-guest-book-list {
	display: grid;
	gap: 0.85rem;
}

.csc-guest-book-entry {
	background: var(--cs-sand-soft, #fbf7ef);
	border: 1px solid var(--cs-border, #e8dfd2);
	border-radius: 16px;
	display: grid;
	gap: 0.7rem;
	padding: 0.95rem;
}

.csc-guest-book-entry-head {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.45rem 0.8rem;
	justify-content: space-between;
}

.csc-guest-book-entry-head strong {
	color: var(--cs-navy, #102a43);
}

.csc-guest-book-entry-head time {
	color: var(--cs-muted, #66788a);
	font-size: 0.85rem;
	font-weight: 800;
}

.csc-guest-book-entry-body p {
	color: var(--cs-navy, #102a43);
	margin: 0;
}

.csc-guest-book-media-grid {
	display: grid;
	gap: 0.75rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.csc-guest-book-media-item {
	background: linear-gradient(150deg, rgba(19, 152, 167, 0.18), rgba(255, 106, 61, 0.15));
	border: 1px solid rgba(255, 255, 255, 0.55);
	border-radius: 16px;
	box-shadow: 0 12px 24px rgba(16, 42, 67, 0.14);
	overflow: hidden;
	position: relative;
}

.csc-guest-book-media-trigger {
	background: transparent;
	border: 0;
	cursor: pointer;
	display: block;
	padding: 0;
	position: relative;
	width: 100%;
}

.csc-guest-book-media-trigger::after {
	background: linear-gradient(to top, rgba(16, 42, 67, 0.46), transparent 54%);
	content: "";
	inset: 0;
	position: absolute;
}

.csc-guest-book-media-chip {
	background: rgba(255, 255, 255, 0.93);
	border-radius: 999px;
	bottom: 0.6rem;
	color: var(--cs-navy, #102a43);
	font-size: 0.72rem;
	font-weight: 900;
	left: 0.6rem;
	letter-spacing: 0.03em;
	line-height: 1;
	padding: 0.42rem 0.6rem;
	position: absolute;
	text-transform: uppercase;
	z-index: 2;
}

.csc-guest-book-media-trigger.is-video .csc-guest-book-media-chip {
	background: rgba(255, 106, 61, 0.92);
	color: #fff;
}

.csc-guest-book-media-trigger:hover,
.csc-guest-book-media-trigger:focus {
	outline: none;
}

.csc-guest-book-media-trigger:hover img,
.csc-guest-book-media-trigger:hover video,
.csc-guest-book-media-trigger:focus img,
.csc-guest-book-media-trigger:focus video {
	transform: scale(1.04);
}

.csc-guest-book-media-item img,
.csc-guest-book-media-item video {
	display: block;
	height: clamp(180px, 22vw, 290px);
	object-fit: cover;
	transition: transform 220ms ease;
	width: 100%;
}

.csc-guest-book-media-item:nth-child(5n + 1) {
	grid-column: span 2;
}

.csc-guest-book-media-item:nth-child(5n + 1) img,
.csc-guest-book-media-item:nth-child(5n + 1) video {
	height: clamp(220px, 30vw, 380px);
}

.csc-lightbox {
	inset: 0;
	position: fixed;
	z-index: 1000;
}

.csc-lightbox-backdrop {
	background: rgba(6, 16, 28, 0.86);
	inset: 0;
	position: absolute;
}

.csc-lightbox-dialog {
	align-items: center;
	display: grid;
	gap: 0.8rem;
	grid-template-columns: auto minmax(0, 1fr) auto;
	inset: 0;
	padding: clamp(0.8rem, 3vw, 1.6rem);
	position: absolute;
}

.csc-lightbox-stage {
	align-items: center;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 20px;
	display: grid;
	min-height: min(78vh, 760px);
	overflow: hidden;
}

.csc-lightbox-image,
.csc-lightbox-video {
	display: block;
	max-height: 78vh;
	object-fit: contain;
	width: 100%;
}

.csc-lightbox-nav,
.csc-lightbox-close {
	align-items: center;
	background: rgba(255, 255, 255, 0.18);
	border: 1px solid rgba(255, 255, 255, 0.38);
	border-radius: 999px;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-size: 1.65rem;
	font-weight: 800;
	height: 2.85rem;
	justify-content: center;
	line-height: 1;
	transition: background-color 160ms ease, transform 160ms ease;
	width: 2.85rem;
}

.csc-lightbox-close {
	font-size: 2rem;
	position: absolute;
	right: clamp(0.9rem, 3vw, 1.6rem);
	top: clamp(0.9rem, 3vw, 1.6rem);
	z-index: 2;
}

.csc-lightbox-nav:hover,
.csc-lightbox-nav:focus,
.csc-lightbox-close:hover,
.csc-lightbox-close:focus {
	background: rgba(255, 255, 255, 0.28);
	outline: none;
	transform: translateY(-1px);
}

.csc-lightbox-meta {
	bottom: clamp(0.9rem, 3vw, 1.4rem);
	color: #fff;
	font-size: 0.84rem;
	font-weight: 900;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
}

.csc-lightbox-open {
	overflow: hidden;
}

@media (min-width: 720px) {
	.csu-private-dashboard {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.csc-calendar-card:not(.csc-calendar-preview) {
		align-items: start;
		grid-template-columns: minmax(0, 1fr) minmax(170px, 0.32fr);
	}

	.csc-calendar-card:not(.csc-calendar-preview) .csu-calendar-legend {
		align-content: start;
		background: rgba(251, 247, 239, 0.72);
		border: 1px solid var(--cs-border, #e8dfd2);
		border-radius: 18px;
		display: grid;
		margin: 0;
		padding: 1rem;
	}

	.csu-request-form,
	.csu-request-form-compact {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.csc-dashboard-actions {
		grid-template-columns: repeat(4, minmax(0, 1fr));
	}

	.csc-request-card {
		align-items: center;
		grid-template-columns: minmax(0, 1fr) auto;
	}

	.csc-request-actions {
		min-width: 260px;
	}

	.csc-dashboard-form {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.csc-guest-book-media-grid {
		grid-template-columns: repeat(3, minmax(0, 1fr));
	}
}

@media (max-width: 719px) {
	.csc-calendar-nav {
		height: 2.75rem;
		width: 2.75rem;
	}

	.csu-calendar-weekdays {
		font-size: 0.74rem;
	}

	.csu-calendar-day {
		min-height: clamp(2.1rem, 10vw, 2.8rem);
	}

	.csc-open-weekend {
		align-items: stretch;
		display: grid;
	}

	.csc-open-weekend-link {
		min-height: 44px;
		width: 100%;
	}

	.csc-dashboard-actions {
		grid-template-columns: 1fr;
	}

	.csc-request-actions,
	.csc-request-actions form,
	.csc-dashboard-button {
		width: 100%;
	}

	.csc-dashboard-button {
		min-height: 44px;
	}

	.csc-guest-book-form .csu-submit {
		min-height: 44px;
		width: 100%;
	}

	.csc-guest-book-media-chip {
		font-size: 0.78rem;
		padding: 0.48rem 0.66rem;
	}

	.csc-lightbox-stage {
		min-height: 68vh;
	}
}

@media (max-width: 520px) {
	.csc-calendar-card {
		padding: 0.8rem;
	}

	.csu-calendar-month {
		padding: 0.7rem;
	}

	.csu-calendar-grid {
		gap: 0.22rem;
	}

	.csu-calendar-day {
		border-radius: 7px;
		font-size: clamp(0.68rem, 3vw, 0.78rem);
		min-height: 1.72rem;
	}

	.csc-date-pair > div {
		grid-template-columns: 1fr;
	}

	.csc-dashboard-row {
		grid-template-columns: 1fr;
	}

	.csc-guest-book-media-grid {
		grid-template-columns: 1fr;
	}

	.csc-guest-book-media-item:nth-child(5n + 1) {
		grid-column: auto;
	}

	.csc-lightbox-dialog {
		grid-template-columns: 1fr;
		grid-template-rows: auto minmax(0, 1fr) auto;
	}

	.csc-lightbox-nav {
		bottom: 0.9rem;
		position: absolute;
		z-index: 2;
	}

	.csc-lightbox-nav.is-prev {
		left: 0.9rem;
	}

	.csc-lightbox-nav.is-next {
		right: 0.9rem;
	}
}
