/* =============================================================================
   IENA Frontend Calendar
   ============================================================================= */

/* -----------------------------------------------------------------------------
   Variables
   ----------------------------------------------------------------------------- */

.iena-calendar-container {
	--iena-radius:       6px;
	--iena-radius-sm:    4px;
	--iena-font:         -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	--iena-border:       #e5e7eb;
	--iena-bg:           #ffffff;
	--iena-bg-subtle:    #f9fafb;
	--iena-text:         #111827;
	--iena-text-muted:   #6b7280;
	--iena-today-bg:     rgba(175, 196, 3, 0.07);
	--iena-shadow:       0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
	--iena-shadow-lg:    0 10px 25px rgba(0,0,0,.12), 0 4px 10px rgba(0,0,0,.06);
	--iena-block-color:  #ef4444;
	--iena-block-stripe: rgba(239,68,68,.18);
	--iena-accent:       #afc403;
	--iena-accent-dark:  #8a9902;
	--iena-accent-text:  #2a2d00;
	--iena-accent-bg:    rgba(175,196,3,.10);

	position: relative;
	font-family: var(--iena-font);
}

/* -----------------------------------------------------------------------------
   Infrastructure filter bar
   ----------------------------------------------------------------------------- */

.iena-filter-bar {
	display: flex;
	align-items: center;
	gap: .65rem;
	padding: .6rem 1.25rem;
	background: var(--iena-bg-subtle);
	border: 1px solid var(--iena-border);
	border-bottom: none;
	border-radius: var(--iena-radius) var(--iena-radius) 0 0;
}

.iena-filter__label {
	font-size: .8rem;
	font-weight: 500;
	color: var(--iena-text-muted);
	white-space: nowrap;
	flex-shrink: 0;
}

.iena-filter__select {
	flex: 1;
	min-width: 0;
	max-width: 300px;
	font-size: .85rem;
	font-family: var(--iena-font);
	padding: .3rem .55rem;
	border: 1px solid var(--iena-border);
	border-radius: var(--iena-radius-sm);
	background: var(--iena-bg);
	color: var(--iena-text);
	cursor: pointer;
	transition: border-color .12s;
}

.iena-filter__select:hover  { border-color: #d1d5db; }
.iena-filter__select:focus  {
	outline: 2px solid var(--iena-accent);
	outline-offset: 1px;
	border-color: var(--iena-accent);
}

/* Fuse filter bar + calendar: remove duplicate border and top radius. */
.iena-filter-bar + .iena-calendar-wrap {
	border-top-left-radius:  0;
	border-top-right-radius: 0;
}

/* Mobile: stack vertically, full width. */
@media ( max-width: 640px ) {
	.iena-filter-bar {
		flex-direction: column;
		align-items: stretch;
		gap: .4rem;
		padding: .6rem .85rem;
	}

	.iena-filter__select {
		max-width: 100%;
		width: 100%;
		font-size: 1rem; /* prevents iOS auto-zoom on focus */
	}
}

/* -----------------------------------------------------------------------------
   Calendar wrapper
   NOTE: FullCalendar adds its own classes (fc, fc-media-screen…) directly on
   this element, so child selectors must skip the `.fc` level — use
   `.iena-calendar-wrap .fc-*` not `.iena-calendar-wrap .fc .fc-*`.
   ----------------------------------------------------------------------------- */

.iena-calendar-wrap {
	background: var(--iena-bg);
	border: 1px solid var(--iena-border);
	border-radius: var(--iena-radius);
	box-shadow: var(--iena-shadow);
	padding: 1rem 1.25rem 1.25rem;
	transition: opacity .2s ease;
}

.iena-calendar-wrap.iena-calendar--loading {
	opacity: .5;
	pointer-events: none;
}

/* Error banner */
.iena-calendar-error {
	margin: 0 0 .75rem;
	padding: .55rem 1rem;
	background: #fef2f2;
	border-left: 3px solid var(--iena-block-color);
	color: #991b1b;
	border-radius: var(--iena-radius-sm);
	font-size: .875rem;
}

/* -----------------------------------------------------------------------------
   FullCalendar toolbar
   ----------------------------------------------------------------------------- */

.iena-calendar-wrap .fc-toolbar {
	gap: .5rem;
	flex-wrap: wrap;
	margin-bottom: 1rem;
}

.iena-calendar-wrap .fc-toolbar-title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--iena-text);
	letter-spacing: -.01em;
}

/* -----------------------------------------------------------------------------
   Buttons — clean modern style, accent = #afc403
   ----------------------------------------------------------------------------- */

.iena-calendar-wrap .fc-button,
.iena-calendar-wrap .fc-button-primary {
	font-family: var(--iena-font) !important;
	font-size: .8rem !important;
	font-weight: 500 !important;
	padding: .4rem .8rem !important;
	border-radius: var(--iena-radius-sm) !important;
	border: 1px solid var(--iena-border) !important;
	background: var(--iena-bg) !important;
	color: var(--iena-text) !important;
	box-shadow: none !important;
	text-shadow: none !important;
	transition: background .15s, border-color .15s, color .15s !important;
}

.iena-calendar-wrap .fc-button:hover,
.iena-calendar-wrap .fc-button-primary:hover {
	background: var(--iena-accent-bg) !important;
	border-color: var(--iena-accent) !important;
	color: var(--iena-accent-text) !important;
}

.iena-calendar-wrap .fc-button:focus,
.iena-calendar-wrap .fc-button-primary:focus {
	outline: 2px solid var(--iena-accent) !important;
	outline-offset: 1px !important;
	box-shadow: none !important;
}

/* Active / selected view button */
.iena-calendar-wrap .fc-button-primary:not(:disabled).fc-button-active,
.iena-calendar-wrap .fc-button-primary:not(:disabled):active {
	background: var(--iena-accent) !important;
	border-color: var(--iena-accent-dark) !important;
	color: var(--iena-accent-text) !important;
	font-weight: 600 !important;
	box-shadow: none !important;
}

/* "Today" — slightly bolder border to stand out */
.iena-calendar-wrap .fc-today-button {
	border-color: var(--iena-accent) !important;
	color: var(--iena-accent-text) !important;
	font-weight: 600 !important;
}

.iena-calendar-wrap .fc-today-button:hover {
	background: var(--iena-accent) !important;
	color: var(--iena-accent-text) !important;
}

.iena-calendar-wrap .fc-today-button:disabled {
	background: var(--iena-accent) !important;
	border-color: var(--iena-accent-dark) !important;
	color: var(--iena-accent-text) !important;
	opacity: .9 !important;
	cursor: default !important;
}

/* Button groups: fuse borders */
.iena-calendar-wrap .fc-button-group .fc-button {
	border-radius: 0 !important;
}
.iena-calendar-wrap .fc-button-group .fc-button:first-child {
	border-radius: var(--iena-radius-sm) 0 0 var(--iena-radius-sm) !important;
}
.iena-calendar-wrap .fc-button-group .fc-button:last-child {
	border-radius: 0 var(--iena-radius-sm) var(--iena-radius-sm) 0 !important;
}
.iena-calendar-wrap .fc-button-group .fc-button + .fc-button {
	border-left-width: 0 !important;
}

/* Fix prev/next icons: FullCalendar's fcicons font conflicts with Elementor Eicons.
   Override with plain Unicode single-angle quotes — no icon font needed. */
.iena-calendar-wrap .fc-icon-chevron-left,
.iena-calendar-wrap .fc-icon-chevron-right {
	font-family: sans-serif !important;
	font-style: normal !important;
}
.iena-calendar-wrap .fc-icon-chevron-left::before  { content: '\2039' !important; font-family: sans-serif !important; } /* ‹ */
.iena-calendar-wrap .fc-icon-chevron-right::before { content: '\203a' !important; font-family: sans-serif !important; } /* › */

/* -----------------------------------------------------------------------------
   Grid
   ----------------------------------------------------------------------------- */

/* Column headers */
.iena-calendar-wrap .fc-col-header-cell {
	background: var(--iena-bg-subtle);
	border-color: var(--iena-border);
}
.iena-calendar-wrap .fc-col-header-cell-cushion {
	font-size: .78rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .04em;
	color: var(--iena-text-muted);
	padding: .45rem .4rem;
	text-decoration: none;
}

/* Day numbers (month grid) */
.iena-calendar-wrap .fc-daygrid-day-number {
	font-size: .8rem;
	font-weight: 500;
	color: var(--iena-text-muted);
	padding: .3rem .4rem;
	text-decoration: none;
}

/* Today highlight */
.iena-calendar-wrap .fc-day-today {
	background: var(--iena-today-bg) !important;
}
.iena-calendar-wrap .fc-day-today .fc-daygrid-day-number {
	color: var(--iena-accent-dark);
	font-weight: 700;
}

/* Borders */
.iena-calendar-wrap td,
.iena-calendar-wrap th {
	border-color: var(--iena-border);
}

/* Time slots — taller for readability */
.iena-calendar-wrap .fc-timegrid-slot {
	height: 2.25rem !important;
}
.iena-calendar-wrap .fc-timegrid-slot-label-cushion {
	font-size: .75rem;
	color: var(--iena-text-muted);
}

@media ( max-width: 767px ) {
	.iena-calendar-wrap .fc-timegrid-slot {
		height: 2.75rem !important; 
	}
}

/* Now indicator */
.iena-calendar-wrap .fc-timegrid-now-indicator-line {
	border-color: var(--iena-accent-dark);
}
.iena-calendar-wrap .fc-timegrid-now-indicator-arrow {
	border-top-color:    var(--iena-accent-dark);
	border-bottom-color: var(--iena-accent-dark);
}

/* "More" link */
.iena-calendar-wrap .fc-daygrid-more-link {
	font-size: .75rem;
	font-weight: 500;
	color: var(--iena-accent-dark);
	text-transform: none;
}

/* List view */
.iena-calendar-wrap .fc-list-day-cushion {
	background: var(--iena-bg-subtle);
	font-size: .8rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .03em;
	color: var(--iena-text-muted);
}
.iena-calendar-wrap .fc-list-event:hover td {
	background: var(--iena-accent-bg);
}
.iena-calendar-wrap .fc-list-event-time {
	font-size: .8rem;
	color: var(--iena-text-muted);
}

/* -----------------------------------------------------------------------------
   Events — appointments
   ----------------------------------------------------------------------------- */

.iena-calendar-wrap .fc-event.iena-event--appointment {
	border-radius: var(--iena-radius-sm);
	border-width: 0;
	font-size: .78rem;
	font-weight: 500;
	transition: filter .1s;
}

.iena-calendar-wrap .fc-event.iena-event--admin {
	cursor: pointer;
}

.iena-calendar-wrap .fc-event.iena-event--admin:hover {
	filter: brightness(.92);
}

/* Subtle left border accent in time-grid */
.iena-calendar-wrap .fc-timegrid-event.iena-event--appointment {
	border-left: 3px solid rgba(0,0,0,.2) !important;
	border-radius: var(--iena-radius-sm);
}

/* Month grid: tighter padding */
.iena-calendar-wrap .fc-daygrid-event.iena-event--appointment {
	padding: 1px 4px;
}

/* Public (non-admin) — slightly dimmed */
.iena-calendar-wrap .fc-event.iena-event--public {
	opacity: .82;
}

/* -----------------------------------------------------------------------------
   Custom event body (time-grid views)
   ----------------------------------------------------------------------------- */

.iena-event__body {
	display: flex;
	flex-direction: column;
	gap: 2px;
	padding: 3px 5px;
	line-height: 1.25;
	overflow: hidden;
	height: 100%;
}

.iena-event__name {
	font-weight: 700;
	font-size: .78rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.iena-event__times {
	display: flex;
	gap: .6em;
	font-size: .72rem;
	opacity: .9;
	flex-wrap: wrap;
}

/* Week view: compact layout */
.iena-event__body--compact {
	padding: 2px 4px;
	gap: 1px;
}

.iena-event__body--compact .iena-event__name {
	font-size: .72rem;
	white-space: normal;
	word-break: break-word;
}

.iena-event__range {
	font-size: .68rem;
	opacity: .88;
	white-space: nowrap;
}

/* Admin-only: client name + phone on the tile */
.iena-event__meta {
	font-size: .70rem;
	opacity: .88;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

/* List view */
.iena-event__list {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 0;
	padding: 1px 0;
}

.iena-event__list-name {
	font-weight: 600;
	font-size: .875rem;
}

.iena-event__list-meta {
	font-size: .82rem;
	opacity: .85;
}

/* -----------------------------------------------------------------------------
   Events — GCal infrastructure blocks
   ----------------------------------------------------------------------------- */

.iena-calendar-wrap .fc-event.iena-event--gcal-block {
	border-width: 0 !important;
	border-radius: var(--iena-radius-sm);
	background-color: var(--iena-block-color) !important;
	background-image: repeating-linear-gradient(
		-45deg,
		transparent,
		transparent 5px,
		var(--iena-block-stripe) 5px,
		var(--iena-block-stripe) 10px
	) !important;
	color: #fff !important;
	font-style: italic;
	font-size: .75rem;
	opacity: .88;
	cursor: default;
}

.iena-calendar-wrap .fc-timegrid-event.iena-event--gcal-block {
	border-left: 3px solid #b91c1c !important;
}

/* -----------------------------------------------------------------------------
   Status badges (admin modal)
   ----------------------------------------------------------------------------- */

.iena-status {
	display: inline-block;
	padding: 2px 8px;
	border-radius: 99px;
	font-size: .72rem;
	font-weight: 600;
	letter-spacing: .03em;
	text-transform: uppercase;
}

.iena-status--confirmed            { background: #d1fae5; color: #065f46; }
.iena-status--paid                 { background: #dbeafe; color: #1e40af; }
.iena-status--pending-confirmation { background: #fef9c3; color: #854d0e; }
.iena-status--cancelled            { background: #fee2e2; color: #991b1b; }
.iena-status--complete             { background: #f3f4f6; color: #374151; }
.iena-status--unpaid               { background: #fef3c7; color: #92400e; }

/* -----------------------------------------------------------------------------
   Admin detail modal
   ----------------------------------------------------------------------------- */

.iena-modal {
	position: absolute;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
}

.iena-modal[hidden] { display: none; }

.iena-modal__overlay {
	position: absolute;
	inset: 0;
	background: rgba(0,0,0,.35);
	backdrop-filter: blur(2px);
	cursor: pointer;
}

.iena-modal__box {
	position: relative;
	z-index: 1;
	background: var(--iena-bg);
	border-radius: var(--iena-radius);
	box-shadow: var(--iena-shadow-lg);
	padding: 1.5rem 1.75rem 1.25rem;
	min-width: 260px;
	max-width: min(420px, 92vw);
	width: 100%;
}

.iena-modal__close {
	position: absolute;
	top: .9rem;
	right: .9rem;
	width: 1.75rem;
	height: 1.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	background: none;
	border: none;
	font-size: 1rem;
	color: var(--iena-text-muted);
	cursor: pointer;
	border-radius: var(--iena-radius-sm);
	transition: background .1s, color .1s;
}

.iena-modal__close:hover {
	background: var(--iena-bg-subtle);
	color: var(--iena-text);
}

.iena-modal__close:focus {
	outline: 2px solid var(--iena-accent);
	outline-offset: 1px;
}

.iena-modal__header {
	display: flex;
	align-items: flex-start;
	gap: .75rem;
	margin-bottom: 1rem;
	padding-right: 1.5rem;
}

.iena-modal__dot {
	flex-shrink: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	margin-top: .35rem;
	background: currentColor;
}

.iena-modal__title {
	margin: 0;
	font-size: .975rem;
	font-weight: 700;
	color: var(--iena-text);
	line-height: 1.35;
}

.iena-modal__table {
	width: 100%;
	border-collapse: collapse;
	font-size: .845rem;
}

.iena-modal__table tr + tr td,
.iena-modal__table tr + tr th {
	border-top: 1px solid var(--iena-border);
}

.iena-modal__table th,
.iena-modal__table td {
	padding: .4rem .25rem;
	text-align: left;
	vertical-align: middle;
}

.iena-modal__table th {
	color: var(--iena-text-muted);
	font-weight: 500;
	white-space: nowrap;
	width: 1%;
	padding-right: 1.25rem;
}


.fc .fc-timegrid-axis-cushion
{
	font-size: 11px;
}

.fc .fc-list-sticky .fc-list-day > *
{
	z-index: 99; 
}

/* Fix Safari issue: stretch the date picker indicator so the entire input is clickable */
.iena-date-input-overlay::-webkit-calendar-picker-indicator {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 100%;
	margin: 0;
	padding: 0;
	cursor: pointer;
	color: transparent;
	background: transparent;
}
