/*
 * Krone Manager — layout & component styles.
 *
 * Plain CSS (no CSS Modules). Class names are human-readable so Chrome DevTools
 * → source-file mapping is direct. macOS-restraint: no shadows, no rounded
 * corners, no animations, no gradients. Solid colors only.
 */

*, *::before, *::after { box-sizing: border-box; }

html, body {
	margin: 0;
	padding: 0;
	font-family: var(--font);
	font-size: 14px;
	line-height: 1.4;
	color: var(--text);
	background: var(--bg);
	-webkit-font-smoothing: antialiased;
	-webkit-text-size-adjust: 100%;
	min-height: var(--tg-viewport-stable-height, 100vh);
}

/* ----------------------------------------------------------------- header */
.app-header {
	background: var(--bg-header);
	border-bottom: 1px solid var(--separator);
	padding: 12px 16px;
	display: flex;
	align-items: baseline;
	justify-content: space-between;
	gap: 12px;
}

.app-title {
	font-size: 16px;
	font-weight: 600;
	margin: 0;
	color: var(--text);
}

.app-subtitle {
	font-size: 12px;
	color: var(--text-subtitle);
}

/* ----------------------------------------------------------------- tabs */
.tab-bar {
	display: flex;
	background: var(--bg-secondary);
	border-bottom: 1px solid var(--separator);
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
}
.tab-bar::-webkit-scrollbar { display: none; }

.tab-btn {
	flex: 1 1 auto;
	min-width: 80px;
	padding: 10px 12px;
	background: transparent;
	border: 0;
	border-bottom: 2px solid transparent;
	color: var(--text-subtitle);
	font: inherit;
	font-size: 13px;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
}

.tab-btn.is-active {
	color: var(--text);
	border-bottom-color: var(--accent);
}

.tab-label { font-weight: 500; }

.tab-count {
	font-size: 11px;
	font-family: var(--font-mono);
	color: var(--text-hint);
	background: var(--bg-header);
	padding: 1px 6px;
	min-width: 20px;
	text-align: center;
}

.tab-btn.is-active .tab-count { color: var(--text); }

/* ----------------------------------------------------------------- view */
.view-root {
	min-height: calc(var(--tg-viewport-stable-height, 100vh) - 100px);
}

.loading,
.empty-state,
.error-state {
	padding: 32px 16px;
	text-align: center;
	color: var(--text-subtitle);
	font-size: 14px;
}

.error-state {
	color: var(--error);
	font-family: var(--font-mono);
	font-size: 12px;
	white-space: pre-wrap;
	word-break: break-word;
	text-align: left;
}

/* ----------------------------------------------------------------- list */
.row-list {
	margin: 0;
	padding: 0;
	list-style: none;
}

.row-item {
	padding: 12px 16px;
	border-bottom: 1px solid var(--separator);
	background: var(--bg);
	cursor: pointer;
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.row-item:active { background: var(--bg-secondary); }

.row-band {
	font-size: 15px;
	font-weight: 600;
	color: var(--text);
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.row-meta {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 12px;
	color: var(--text-subtitle);
}

.row-dates {
	font-family: var(--font-mono);
	color: var(--text-hint);
}

.row-summary {
	font-size: 12px;
	color: var(--text-subtitle);
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

.row-pill {
	font-size: 10px;
	font-family: var(--font-mono);
	padding: 1px 6px;
	border: 1px solid var(--separator);
	color: var(--text-subtitle);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.row-pill.is-urgent { color: var(--error); border-color: var(--error); }
.row-pill.is-waiting { color: var(--warn); border-color: var(--warn); }
.row-pill.is-fresh { color: var(--info); border-color: var(--info); }
.row-pill.is-old { color: var(--text-hint); border-color: var(--text-hint); }
.row-pill.is-confirmed { color: var(--success, #34c759); border-color: var(--success, #34c759); }

/* Phase B context blocks */
.detail-header-pills {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-top: 6px;
}

.context-state-pill {
	display: inline-block;
	font-size: 11px;
	font-family: var(--font-mono);
	padding: 2px 8px;
	border: 1px solid var(--separator);
	color: var(--text-subtitle);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.context-state-pill.is-urgent { color: var(--error); border-color: var(--error); }
.context-state-pill.is-waiting { color: var(--warn); border-color: var(--warn); }
.context-state-pill.is-fresh { color: var(--info); border-color: var(--info); }
.context-state-pill.is-old { color: var(--text-hint); border-color: var(--text-hint); }
.context-state-pill.is-confirmed { color: var(--success, #34c759); border-color: var(--success, #34c759); }

.context-intent {
	background: rgba(0,0,0,0.02);
	border-left: 3px solid var(--info);
	padding-left: 12px;
}
.intent-tag {
	display: inline-block;
	margin-left: 8px;
	font-size: 10px;
	font-family: var(--font-mono);
	padding: 1px 6px;
	border: 1px solid var(--info);
	color: var(--info);
	text-transform: uppercase;
	letter-spacing: 0.5px;
}
.intent-excerpt {
	font-style: italic;
	color: var(--text-subtitle);
	margin: 8px 0;
	line-height: 1.5;
}
.intent-hint {
	font-size: 13px;
	color: var(--success, #34c759);
	margin: 6px 0 0 0;
}

.history-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.history-list li {
	display: grid;
	grid-template-columns: 80px 1fr auto;
	gap: 8px;
	padding: 6px 0;
	font-size: 13px;
	border-bottom: 1px solid var(--separator);
	align-items: baseline;
}
.history-list li:last-child { border-bottom: none; }
.history-list li.is-future {
	color: var(--info);
	font-weight: 600;
}
.hist-date { font-family: var(--font-mono); color: var(--text-subtitle); }
.hist-title { color: var(--text); }
.hist-venue { font-size: 11px; color: var(--text-hint); text-transform: uppercase; }

.related-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.related-row {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	gap: 2px 8px;
	padding: 8px 0;
	border-bottom: 1px solid var(--separator);
	cursor: pointer;
}
.related-row:active { background: rgba(0,0,0,0.04); }
.related-row:last-child { border-bottom: none; }
.related-band {
	grid-column: 1;
	grid-row: 1;
	font-weight: 600;
	color: var(--text);
}
.related-meta {
	grid-column: 1;
	grid-row: 2;
	font-size: 11px;
	color: var(--text-hint);
	font-family: var(--font-mono);
}
.related-date {
	grid-column: 2;
	grid-row: 1 / span 2;
	font-size: 11px;
	color: var(--text-subtitle);
	font-family: var(--font-mono);
	align-self: center;
}
.related-more {
	padding: 8px 0;
	font-size: 12px;
	color: var(--text-hint);
	font-style: italic;
}

/* Days-waiting is a separate emphasis */
.row-days {
	font-size: 11px;
	font-family: var(--font-mono);
	color: var(--warn);
	margin-left: auto;
}

/* ----------------------------------------------------------------- detail */
.detail-view {
	padding: 0 0 24px 0;
}

.detail-header {
	padding: 16px;
	background: var(--bg-secondary);
	border-bottom: 1px solid var(--separator);
}

.detail-band {
	font-size: 18px;
	font-weight: 600;
	margin: 0 0 4px 0;
	color: var(--text);
}

.detail-subject {
	font-size: 13px;
	color: var(--text-subtitle);
	font-style: italic;
}

.detail-section {
	padding: 12px 16px;
	border-bottom: 1px solid var(--separator);
}

.detail-section h3 {
	font-size: 11px;
	font-weight: 600;
	margin: 0 0 8px 0;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	color: var(--text-section-header);
}

/* Date list with availability badges */
.date-list {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.date-row {
	display: flex;
	flex-direction: column;
	gap: 4px;
}

.date-row-date {
	font-size: 14px;
	font-weight: 500;
	font-family: var(--font-mono);
	color: var(--text);
}

.date-row-venues {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 16px;
}

.venue-line {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
}

.venue-name {
	color: var(--text-subtitle);
	min-width: 50px;
}

.avail-pill {
	font-family: var(--font-mono);
	font-size: 10px;
	padding: 1px 6px;
	border: 1px solid var(--separator);
	color: var(--text-subtitle);
	letter-spacing: 0.3px;
}

.avail-pill.is-free      { color: var(--ok);    border-color: var(--ok); }
.avail-pill.is-occupied  { color: var(--error); border-color: var(--error); }
.avail-pill.is-self      { color: var(--info);  border-color: var(--info); }
.avail-pill.is-noday     { color: var(--text-hint); border-color: var(--text-hint); }

/* Summary text */
.summary-text {
	margin: 0;
	font-size: 14px;
	color: var(--text);
	line-height: 1.5;
}

/* Contact + links */
.contact-row {
	font-size: 13px;
	font-family: var(--font-mono);
}
.contact-row a {
	color: var(--text-link);
	text-decoration: none;
}
.contact-row a:hover { text-decoration: underline; }

.link-row {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}

.link-pill {
	font-size: 11px;
	padding: 4px 8px;
	border: 1px solid var(--separator);
	color: var(--text-link);
	text-decoration: none;
	white-space: nowrap;
}
.link-pill:hover { background: var(--bg-secondary); }

/* Meta grid */
.meta-grid {
	display: grid;
	grid-template-columns: max-content 1fr;
	gap: 4px 12px;
	margin: 0;
	font-size: 12px;
}

.meta-grid dt {
	color: var(--text-subtitle);
	font-weight: 500;
}

.meta-grid dd {
	margin: 0;
	color: var(--text);
	word-break: break-word;
}

.notes-text {
	margin: 0;
	font-family: var(--font-mono);
	font-size: 11px;
	white-space: pre-wrap;
	word-break: break-word;
	color: var(--text-subtitle);
	background: var(--bg-secondary);
	padding: 8px;
	max-height: 200px;
	overflow-y: auto;
}

/* Message thread */
.msg-list {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.msg-item {
	padding: 10px 12px;
	background: var(--bg-secondary);
	border: 1px solid var(--separator);
	max-width: 92%;
}

.msg-item.is-benni {
	margin-left: auto;
	background: var(--bg);
	border-color: var(--accent);
}

.msg-item.is-other {
	margin-right: auto;
}

.msg-meta {
	display: flex;
	justify-content: space-between;
	gap: 12px;
	font-size: 11px;
	margin-bottom: 6px;
}

.msg-sender {
	color: var(--text-section-header);
	font-weight: 500;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.msg-date {
	color: var(--text-hint);
	font-family: var(--font-mono);
	flex-shrink: 0;
}

.msg-body {
	font-size: 13px;
	line-height: 1.5;
	color: var(--text);
	word-break: break-word;
	max-height: 600px;
	overflow-y: auto;
}

.placeholder-text {
	margin: 0;
	font-size: 12px;
	color: var(--text-hint);
	font-style: italic;
}

.detail-actions-placeholder {
	background: var(--bg-secondary);
}

/* Inline action buttons (Confirm, Draft, Reject) */
.action-btn {
	display: inline-block;
	padding: 8px 14px;
	font: inherit;
	font-size: 13px;
	font-weight: 500;
	border: 1px solid var(--separator);
	background: var(--bg-secondary);
	color: var(--text);
	cursor: pointer;
	min-height: 36px;
	white-space: nowrap;
}

.action-btn:active { opacity: 0.7; }

.action-btn.is-primary {
	background: var(--btn-bg);
	color: var(--btn-fg);
	border-color: var(--btn-bg);
	font-weight: 600;
}

.action-btn.is-secondary {
	background: var(--bg);
}

.action-btn.is-danger {
	background: var(--bg);
	color: var(--error);
	border-color: var(--error);
}

.action-btn.is-warning {
	background: var(--bg);
	color: var(--warn);
	border-color: var(--warn);
}

.action-btn.is-confirm {
	margin-left: auto;
	font-size: 12px;
	padding: 4px 10px;
	min-height: 28px;
}

.confirm-note {
	font-size: 11px;
	color: var(--text-hint);
	font-style: italic;
}

.detail-action-bar {
	background: var(--bg-secondary);
}

.action-bar-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

/* Status pill on detail header */
.detail-status-pill {
	display: inline-block;
	margin-top: 6px;
	font-size: 10px;
	font-family: var(--font-mono);
	letter-spacing: 0.5px;
	text-transform: uppercase;
	padding: 1px 6px;
	border: 1px solid var(--separator);
	color: var(--text-subtitle);
}
.detail-status-pill.is-pending  { color: var(--warn); border-color: var(--warn); }
.detail-status-pill.is-contacted { color: var(--info); border-color: var(--info); }
.detail-status-pill.is-booked   { color: var(--ok); border-color: var(--ok); }
.detail-status-pill.is-rejected { color: var(--error); border-color: var(--error); }
.detail-status-pill.is-cancelled { color: var(--text-hint); border-color: var(--text-hint); }

/* Modal */
.modal-host {
	position: fixed;
	inset: 0;
	z-index: 1000;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 16px;
}
.modal-host.is-visible { display: flex; }

.modal-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.6);
}

.modal-card {
	position: relative;
	background: var(--bg);
	border: 1px solid var(--separator);
	max-width: 480px;
	width: 100%;
	max-height: 88vh;
	max-height: calc(var(--tg-viewport-stable-height, 100vh) - 32px);
	overflow-y: auto;
	display: flex;
	flex-direction: column;
}

.modal-title {
	padding: 12px 16px;
	font-size: 15px;
	font-weight: 600;
	border-bottom: 1px solid var(--separator);
	background: var(--bg-secondary);
}

.modal-body {
	padding: 16px;
	font-size: 14px;
	color: var(--text);
}

.modal-body p { margin: 0 0 8px 0; }
.modal-body p:last-child { margin-bottom: 0; }

.modal-hint {
	font-size: 12px;
	color: var(--text-subtitle);
}

.modal-error {
	margin: 0;
	font-family: var(--font-mono);
	font-size: 12px;
	white-space: pre-wrap;
	word-break: break-word;
	color: var(--error);
}

.modal-actions {
	padding: 12px 16px;
	border-top: 1px solid var(--separator);
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	background: var(--bg-secondary);
}

.modal-progress {
	font-size: 13px;
	color: var(--text-subtitle);
	font-style: italic;
}

.modal-textarea {
	display: block;
	width: 100%;
	min-height: 160px;
	padding: 8px;
	font: inherit;
	font-family: var(--font-mono);
	font-size: 12px;
	background: var(--bg-secondary);
	color: var(--text);
	border: 1px solid var(--separator);
	resize: vertical;
}

.modal-input {
	display: block;
	width: 100%;
	margin-top: 8px;
	padding: 6px 8px;
	font: inherit;
	font-size: 13px;
	background: var(--bg-secondary);
	color: var(--text);
	border: 1px solid var(--separator);
}

.modal-checkbox {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 6px 0;
	font-size: 12px;
	color: var(--text-subtitle);
}

.preview-list {
	margin: 0;
	padding-left: 18px;
	font-size: 13px;
	line-height: 1.7;
}

.preview-list code {
	font-family: var(--font-mono);
	font-size: 11px;
	background: var(--bg-secondary);
	padding: 1px 4px;
}
