/* Calent — front-end views.
 * Virtucom canon, scoped to .calent-root so it inherits the host theme gracefully
 * and pollutes nothing global. The "date as hero" spine threads Month / Grid / List
 * and the single-event page.
 *
 * Banned (workspace .claude/DESIGN.md §3): purple→blue gradients, glassmorphism,
 * shadow-on-everything, rounded-2xl, colored event blobs, emoji.
 */

.calent-root {
	/* Virtucom canon (light) — local scope, no global :root pollution. */
	--paper:      #FFFFFF;
	--paper-deep: #F5F7FA;
	--ink:        #1A2332;
	--ink-soft:   #3D5166;
	--ink-mute:   #6B7B8D;
	--line:       #E5E9EF;
	--line-soft:  #EDF0F4;
	--card:       #FAFBFC;
	--accent:     #7CA99B;   /* sage */
	--accent-deep:#5E8A7B;
	--accent-soft:#D8E5DC;
	--premium:    #C49A2A;   /* gold */
	--radius:     4px;
	--ease:       cubic-bezier(.22, 1, .36, 1);
	/* Prefer the Virtucom faces if the host already loads them; never call a font CDN. */
	--calent-display: 'Raleway', system-ui, sans-serif;
	--calent-body:    'Geist', system-ui, -apple-system, sans-serif;

	font-family: var(--calent-body);
	color: var(--ink);
	font-size: 15px;
	line-height: 1.5;
	max-width: 1040px;
	margin-inline: auto;
}
.calent-root *, .calent-root *::before, .calent-root *::after { box-sizing: border-box; }
.calent-root a { color: inherit; text-decoration: none; }

/* ── top bar: view switcher (segmented control, sliding sage ink) ── */
.calent-bar { display: flex; justify-content: flex-end; margin-bottom: 18px; }
.calent-switch {
	position: relative;
	display: inline-flex;
	gap: 2px;
	padding: 3px;
	background: var(--paper-deep);
	border: 1px solid var(--line);
	border-radius: var(--radius);
}
.calent-switch__btn {
	position: relative;
	z-index: 1;
	font: 500 13px/1 var(--calent-body);
	letter-spacing: .01em;
	color: var(--ink-mute);
	padding: 8px 16px;
	border-radius: 3px;
	background: none; border: 0; cursor: pointer;
	transition: color .25s var(--ease);
}
.calent-switch__btn[aria-selected="true"] { color: var(--ink); }
.calent-switch__btn:hover { color: var(--ink-soft); }
.calent-switch__btn:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }
.calent-switch__ink {
	position: absolute; top: 3px; bottom: 3px; left: 3px;
	width: 0; /* set by JS */
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: 3px;
	transition: left .32s var(--ease), width .32s var(--ease);
	z-index: 0;
}

/* ── month grid: hairline wall-planner, never boxed-shadow cells ── */
.calent-monthbar {
	display: flex; align-items: center; justify-content: center; gap: 22px;
	margin-bottom: 14px;
}
.calent-monthlabel {
	font: 600 22px/1 var(--calent-display);
	letter-spacing: -.01em; color: var(--ink); margin: 0;
}
.calent-nav {
	display: inline-flex; align-items: center; justify-content: center;
	width: 34px; height: 34px; border: 1px solid var(--line);
	border-radius: var(--radius); color: var(--ink-soft);
	font-size: 16px; transition: border-color .2s var(--ease), color .2s var(--ease);
}
.calent-nav:hover { border-color: var(--accent); color: var(--accent-deep); }

.calent-grid { width: 100%; border-collapse: collapse; table-layout: fixed; }
.calent-grid thead th {
	font: 500 11px/1 var(--calent-body);
	text-transform: uppercase; letter-spacing: .08em;
	color: var(--ink-mute); text-align: left;
	padding: 0 0 8px 6px; border-bottom: 1px solid var(--line);
}
.calent-cell {
	vertical-align: top;
	height: 96px;
	border-bottom: 1px solid var(--line-soft);
	border-right: 1px solid var(--line-soft);
	padding: 6px 6px 4px;
}
.calent-grid tbody tr td:first-child { border-left: 1px solid var(--line-soft); }
.calent-cell--empty { background: var(--paper-deep); }
.calent-cell__num {
	display: block; font: 600 19px/1 var(--calent-display);
	color: var(--ink-soft); margin-bottom: 6px;
	font-variant-numeric: tabular-nums;
}
/* "today" = a single sage top-rule + a sage numeral. No filled circle. */
.calent-cell--today { box-shadow: inset 0 2px 0 0 var(--accent); }
.calent-cell--today .calent-cell__num { color: var(--accent-deep); font-weight: 700; }
.calent-cell__events { list-style: none; margin: 0; padding: 0; }
.calent-cell__events li { margin-bottom: 2px; }
/* Events as compact text chips, not colored blocks. */
.calent-cell__events a {
	display: block; font-size: 12px; line-height: 1.3; color: var(--ink-soft);
	padding-left: 8px; position: relative; overflow: hidden;
	white-space: nowrap; text-overflow: ellipsis;
}
.calent-cell__events a::before {
	content: ""; position: absolute; left: 0; top: 4px; bottom: 2px;
	width: 2px; background: var(--accent);
}
.calent-cell__events time { color: var(--ink-mute); font-variant-numeric: tabular-nums; margin-right: 4px; }
.calent-cell__events a:hover { color: var(--accent-deep); }

/* ── grid view: cards (image OR date-tile fallback) ── */
.calent-cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; }
.calent-card {
	display: flex; flex-direction: column;
	border: 1px solid var(--line); border-radius: var(--radius);
	background: var(--paper); overflow: hidden;
	transition: border-color .2s var(--ease), transform .2s var(--ease);
}
.calent-card:hover { border-color: var(--accent); transform: translateY(-2px); }
.calent-card__media { display: block; aspect-ratio: 16 / 9; background: var(--paper-deep) center/cover no-repeat; }
.calent-card__tile {
	display: flex; flex-direction: column; align-items: center; justify-content: center;
	aspect-ratio: 16 / 9; background: var(--paper-deep);
	border-bottom: 1px solid var(--line);
}
.calent-card__tile-mon { font: 600 12px/1 var(--calent-body); text-transform: uppercase; letter-spacing: .12em; color: var(--accent-deep); }
.calent-card__tile-day { font: 700 44px/1 var(--calent-display); color: var(--ink); margin-top: 4px; font-variant-numeric: tabular-nums; }
.calent-card__body { display: flex; flex-direction: column; gap: 4px; padding: 14px 14px 16px; }
.calent-card__date { font: 500 12px/1.2 var(--calent-body); color: var(--accent-deep); letter-spacing: .01em; }
.calent-card__title { font: 600 16px/1.25 var(--calent-display); color: var(--ink); }
.calent-card__loc { font-size: 13px; color: var(--ink-mute); }

/* ── list view: agenda with the date-rail spine ── */
.calent-agenda { list-style: none; margin: 0; padding: 0; }
.calent-agenda__day {
	display: grid; grid-template-columns: 76px 1fr; gap: 18px;
	padding: 18px 0; border-top: 1px solid var(--line);
}
.calent-agenda__day:last-child { border-bottom: 1px solid var(--line); }
.calent-rail { text-align: center; padding-top: 2px; }
.calent-rail__dow { display: block; font: 500 11px/1 var(--calent-body); text-transform: uppercase; letter-spacing: .1em; color: var(--ink-mute); }
.calent-rail__num { display: block; font: 700 34px/1 var(--calent-display); color: var(--ink); margin: 3px 0; font-variant-numeric: tabular-nums; }
.calent-rail__mon { display: block; font: 500 11px/1 var(--calent-body); text-transform: uppercase; letter-spacing: .1em; color: var(--ink-mute); }
.calent-agenda__day.is-today .calent-rail__num { color: var(--accent-deep); }
.calent-agenda__day.is-today .calent-rail { border-left: 2px solid var(--accent); margin-left: -2px; }
.calent-agenda__events { list-style: none; margin: 0; padding: 0; }
.calent-row { border-bottom: 1px solid var(--line-soft); }
.calent-row:last-child { border-bottom: 0; }
.calent-row a { display: grid; grid-template-columns: 64px 1fr auto; gap: 14px; align-items: baseline; padding: 9px 0; }
.calent-row__time { font: 500 13px/1.4 var(--calent-body); color: var(--ink-mute); font-variant-numeric: tabular-nums; }
.calent-row__title { font: 500 15px/1.4 var(--calent-body); color: var(--ink); }
.calent-row a:hover .calent-row__title { color: var(--accent-deep); }
.calent-row__loc { font-size: 13px; color: var(--ink-mute); }

.calent-empty { color: var(--ink-mute); font-size: 15px; padding: 32px 0; text-align: center; }

/* ── single event page: letterpress poster (date as hero) ── */
.calent-single { max-width: 760px; margin-inline: auto; }
.calent-single__hero { display: grid; grid-template-columns: auto 1fr; gap: 26px; align-items: start; padding-bottom: 22px; border-bottom: 1px solid var(--line); margin-bottom: 24px; }
.calent-herodate { text-align: center; line-height: 1; }
.calent-herodate__mon { display: block; font: 600 14px/1 var(--calent-body); text-transform: uppercase; letter-spacing: .14em; color: var(--accent-deep); }
.calent-herodate__day { display: block; font: 700 72px/.9 var(--calent-display); color: var(--ink); font-variant-numeric: tabular-nums; }
.calent-herodate__yr { display: block; font: 500 13px/1 var(--calent-body); color: var(--ink-mute); letter-spacing: .08em; }
.calent-single__heading { font: 700 30px/1.12 var(--calent-display); letter-spacing: -.01em; color: var(--ink); margin: 0 0 12px; }
.calent-meta { display: grid; grid-template-columns: auto 1fr; gap: 6px 16px; margin: 0; }
.calent-meta dt { font: 600 12px/1.5 var(--calent-body); text-transform: uppercase; letter-spacing: .07em; color: var(--ink-mute); }
.calent-meta dd { font-size: 15px; color: var(--ink-soft); margin: 0; }
.calent-cta { display: inline-flex; gap: 12px; margin-top: 20px; flex-wrap: wrap; }
.calent-btn { display: inline-flex; align-items: center; padding: 11px 20px; border-radius: var(--radius); font: 600 14px/1 var(--calent-body); border: 1px solid var(--accent); transition: background .2s var(--ease), color .2s var(--ease); }
.calent-btn--primary { background: var(--accent); color: #fff; }
.calent-btn--primary:hover { background: var(--accent-deep); border-color: var(--accent-deep); }
.calent-btn--ghost { color: var(--accent-deep); background: var(--paper); }
.calent-btn--ghost:hover { background: var(--accent-soft); }

/* breadcrumbs (internal linking + BreadcrumbList rich result) */
.calent-crumbs { font: 500 12px/1.5 var(--calent-body); color: var(--ink-mute); margin-bottom: 18px; }
.calent-crumbs a { color: var(--ink-mute); }
.calent-crumbs a:hover { color: var(--accent-deep); }
.calent-crumbs span[aria-current] { color: var(--ink-soft); }
.calent-crumbs span[aria-hidden] { color: var(--line); margin: 0 4px; }

/* "More events" — upcoming cross-links that spread link equity */
.calent-more { margin-top: 38px; padding-top: 22px; border-top: 1px solid var(--line); }
.calent-more__h { font: 600 13px/1 var(--calent-display); text-transform: uppercase; letter-spacing: .1em; color: var(--ink-mute); margin: 0 0 12px; }
.calent-more__list { list-style: none; margin: 0; padding: 0; }
.calent-more__list a { display: grid; grid-template-columns: 120px 1fr; gap: 16px; align-items: baseline; padding: 9px 0; border-bottom: 1px solid var(--line-soft); }
.calent-more__list li:last-child a { border-bottom: 0; }
.calent-more__date { font: 500 13px/1.4 var(--calent-body); color: var(--accent-deep); font-variant-numeric: tabular-nums; }
.calent-more__title { font: 500 15px/1.4 var(--calent-body); color: var(--ink); }
.calent-more__list a:hover .calent-more__title { color: var(--accent-deep); }

/* ── responsive ── */
@media (max-width: 680px) {
	.calent-cell { height: auto; min-height: 64px; }
	.calent-cell__events a { font-size: 0; padding-left: 0; }
	.calent-cell__events a::before { left: 50%; top: auto; bottom: 2px; height: 4px; width: 4px; border-radius: 50%; transform: translateX(-50%); }
	.calent-single__hero { grid-template-columns: 1fr; gap: 14px; }
	.calent-herodate { text-align: left; display: flex; align-items: baseline; gap: 10px; }
	.calent-herodate__day { font-size: 52px; }
	.calent-row a { grid-template-columns: 56px 1fr; }
	.calent-row__loc { grid-column: 2; }
}
