/**
 * IDE Ethics Channel — Styles v2.0.2
 * Front-end and admin. BEM naming: .ide-ethics-{block}__{element}--{modifier}
 * IDE AWB palette: #283253 headings · #55669c accent · #8794b9 muted
 *                  #c0002a primary · #a81124 hover · #f2f2f2 bg · #151e26 text
 */

/* ===========================================================================
   VARIABLES & RESET
   =========================================================================== */
:root {
	/* IDE AWB brand */
	--ec-color-primary:    #c0002a;   /* IDE red — buttons, CTAs */
	--ec-color-primary-d:  #a81124;   /* IDE dark red — hover */
	--ec-color-heading:    #283253;   /* IDE dark blue — headings */
	--ec-color-accent:     #55669c;   /* IDE mid blue — links, borders, accents */
	--ec-color-text:       #151e26;   /* IDE dark — body text */
	--ec-color-muted:      #8794b9;   /* IDE secondary — muted text */
	--ec-color-bg:         #f2f2f2;   /* IDE light — card backgrounds */
	/* Functional */
	--ec-color-success:    #1a7a34;
	--ec-color-success-bg: #edfaef;
	--ec-color-error:      #8a1f1f;
	--ec-color-error-bg:   #fcf0f1;
	--ec-color-warn:       #7a4f00;
	--ec-color-warn-bg:    #fff8e1;
	/* Message bubbles */
	--ec-color-reporter:   #eef1f8;   /* reporter bubble bg (IDE blue tint) */
	--ec-color-reporter-b: #55669c;   /* reporter bubble accent */
	--ec-color-manager:    #e6f8ee;
	--ec-color-manager-b:  #1a7a34;
	/* Neutral */
	--ec-color-border:     #d0d5dd;
	--ec-radius:           6px;
	--ec-shadow:           0 1px 4px rgba(0,0,0,.08);
	--ec-font:             -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
}

/* ===========================================================================
   MAIN CONTAINER (front)
   =========================================================================== */
.ide-ethics-wrap {
	max-width: 700px;
	margin: 2rem auto;
	padding: 2rem 2.5rem;
	background: #fff;
	border: 1px solid var(--ec-color-border);
	border-radius: var(--ec-radius);
	box-shadow: var(--ec-shadow);
	box-sizing: border-box;
	font-family: var(--ec-font);
	color: var(--ec-color-text);
	line-height: 1.6;
}

.ide-ethics-title {
	margin: 0 0 .75rem;
	font-size: 1.5rem;
	color: var(--ec-color-heading);
}

.ide-ethics-intro {
	margin: 0 0 1.5rem;
	color: var(--ec-color-muted);
}

/* ===========================================================================
   ALERTS
   =========================================================================== */
.ide-ethics-alert {
	padding: .85rem 1.1rem;
	border-radius: var(--ec-radius);
	margin-bottom: 1.25rem;
	font-size: .95rem;
}

.ide-ethics-alert--success {
	background: var(--ec-color-success-bg);
	border: 1px solid #68de7c;
	color: var(--ec-color-success);
}

.ide-ethics-alert--error {
	background: var(--ec-color-error-bg);
	border: 1px solid #f86368;
	color: var(--ec-color-error);
}

.ide-ethics-alert--warning {
	background: #fef0f2;
	border: 1px solid var(--ec-color-primary);
	color: var(--ec-color-heading);
}

.ide-ethics-alert--warning strong {
	display: block;
	margin-bottom: .4rem;
	color: var(--ec-color-primary);
}

.ide-ethics-alert--warning p {
	margin: .4rem 0 0;
}

.ide-ethics-error-list {
	margin: .25rem 0 0 1rem;
	padding: 0;
}

/* ===========================================================================
   FORMS
   =========================================================================== */
.ide-ethics-field {
	margin-bottom: 1.25rem;
}

.ide-ethics-label {
	display: block;
	font-weight: 600;
	margin-bottom: .4rem;
	color: var(--ec-color-text);
}

.ide-ethics-required {
	color: #c0002a;
	margin-left: 2px;
}

.ide-ethics-input,
.ide-ethics-select,
.ide-ethics-textarea {
	width: 100%;
	padding: .55rem .75rem;
	border: 1px solid var(--ec-color-border);
	border-radius: 4px;
	font-family: var(--ec-font);
	font-size: .95rem;
	color: var(--ec-color-text);
	background: #fff;
	box-sizing: border-box;
	transition: border-color .15s;
}

.ide-ethics-input:focus,
.ide-ethics-select:focus,
.ide-ethics-textarea:focus {
	outline: none;
	border-color: var(--ec-color-accent);
	box-shadow: 0 0 0 3px rgba(85,102,156,.18);
}

.ide-ethics-input--monospace {
	font-family: "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
	letter-spacing: .04em;
}

.ide-ethics-textarea {
	resize: vertical;
	min-height: 120px;
}

.ide-ethics-hint {
	font-size: .83rem;
	color: var(--ec-color-muted);
	margin: .3rem 0 0;
}

.ide-ethics-field--checkbox {
	display: flex;
	gap: .6rem;
	align-items: flex-start;
}

.ide-ethics-checkbox-label {
	display: flex;
	gap: .5rem;
	align-items: flex-start;
	font-weight: normal;
	cursor: pointer;
	color: var(--ec-color-text);
}

.ide-ethics-checkbox {
	margin-top: .2rem;
	flex-shrink: 0;
}

/* ===========================================================================
   BUTTONS
   =========================================================================== */
.ide-ethics-actions {
	margin-top: 1.5rem;
}

.ide-ethics-btn {
	display: inline-block;
	padding: .6rem 1.4rem;
	font-size: 1rem;
	font-weight: 600;
	border-radius: 4px;
	border: none;
	cursor: pointer;
	text-decoration: none;
	transition: background .15s, box-shadow .15s;
}

.ide-ethics-btn--primary {
	background: var(--ec-color-primary);
	color: #fff;
}

.ide-ethics-btn--primary:hover,
.ide-ethics-btn--primary:focus {
	background: var(--ec-color-primary-d);
	box-shadow: 0 2px 8px rgba(192,0,42,.3);
	color: #fff;
}

.ide-ethics-btn--secondary {
	background: #f0f0f1;
	color: var(--ec-color-text);
	border: 1px solid var(--ec-color-border);
}

.ide-ethics-btn--secondary:hover {
	background: #e0e0e0;
	color: var(--ec-color-text);
}

/* ===========================================================================
   PRIVACY NOTICE
   =========================================================================== */
.ide-ethics-privacy-notice {
	display: flex;
	gap: .6rem;
	align-items: flex-start;
	padding: .75rem 1rem;
	background: var(--ec-color-bg);
	border-radius: var(--ec-radius);
	font-size: .85rem;
	color: var(--ec-color-muted);
	margin-bottom: 1rem;
}

.ide-ethics-icon-lock {
	width: 18px;
	height: 18px;
	fill: var(--ec-color-muted);
	flex-shrink: 0;
	margin-top: .1rem;
}

/* ===========================================================================
   CONFIRMATION (new-case-confirm)
   =========================================================================== */
.ide-ethics-confirm__icon {
	text-align: center;
	margin-bottom: 1rem;
}

.ide-ethics-confirm__icon svg {
	width: 56px;
	height: 56px;
	fill: var(--ec-color-heading);
}

.ide-ethics-confirm__title {
	text-align: center;
	color: var(--ec-color-heading);
}

.ide-ethics-confirm__data-block {
	background: var(--ec-color-bg);
	border: 1px solid var(--ec-color-border);
	border-radius: var(--ec-radius);
	padding: 1.25rem 1.5rem;
	margin: 1.5rem 0;
}

.ide-ethics-confirm__row {
	display: flex;
	gap: 1rem;
	padding: .5rem 0;
	border-bottom: 1px dotted var(--ec-color-border);
	flex-wrap: wrap;
}

.ide-ethics-confirm__row:last-child {
	border-bottom: none;
}

.ide-ethics-confirm__key {
	font-weight: 600;
	min-width: 160px;
	color: var(--ec-color-muted);
}

.ide-ethics-confirm__value code,
.ide-ethics-token-display {
	font-family: "SFMono-Regular", Consolas, monospace;
	background: #fff;
	border: 1px solid var(--ec-color-border);
	border-radius: 3px;
	padding: .15rem .45rem;
	word-break: break-all;
	font-size: .92rem;
}

.ide-ethics-confirm__warning {
	font-size: .92rem;
}

.ide-ethics-steps {
	padding-left: 1.4rem;
	line-height: 2;
}

/* ===========================================================================
   PORTAL — LOGIN
   =========================================================================== */
.ide-ethics-portal-hint {
	display: flex;
	gap: .6rem;
	align-items: flex-start;
	margin-top: 1.5rem;
	padding: .75rem 1rem;
	background: var(--ec-color-bg);
	border-radius: var(--ec-radius);
	font-size: .85rem;
	color: var(--ec-color-muted);
}

/* ===========================================================================
   PORTAL — CONVERSATION THREAD
   =========================================================================== */
.ide-ethics-thread__header {
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 1px solid var(--ec-color-border);
}

.ide-ethics-thread__meta {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	flex-wrap: wrap;
	margin-bottom: .5rem;
}

.ide-ethics-thread__badges {
	display: flex;
	gap: .5rem;
	flex-wrap: wrap;
	align-items: center;
	margin-top: .3rem;
}

.ide-ethics-badge {
	display: inline-block;
	padding: .2rem .65rem;
	border-radius: 20px;
	font-size: .8rem;
	font-weight: 600;
}

.ide-ethics-badge--category {
	background: #e8ecf5;
	color: var(--ec-color-heading);
}

.ide-ethics-badge--status { background: #f0f0f1; color: var(--ec-color-muted); }
.ide-ethics-badge--status-open               { background: #e8ecf5; color: var(--ec-color-accent); }
.ide-ethics-badge--status-awaiting_manager   { background: #e8ecf5; color: var(--ec-color-heading); }
.ide-ethics-badge--status-awaiting_reporter  { background: #fce8ec; color: var(--ec-color-primary); }
.ide-ethics-badge--status-closed             { background: #f0f0f1; color: #6b7280; }

.ide-ethics-thread__subject {
	margin: .25rem 0;
	color: var(--ec-color-muted);
}

.ide-ethics-thread__dates {
	font-size: .83rem;
	color: var(--ec-color-muted);
	margin: .3rem 0 .75rem;
}

/* Turn indicator */
.ide-ethics-thread__turn-indicator {
	display: inline-flex;
	align-items: center;
	gap: .5rem;
	padding: .45rem .9rem;
	border-radius: 20px;
	font-size: .88rem;
	font-weight: 500;
	background: var(--ec-color-bg);
}

.turn-manager   { background: #e8ecf5; color: var(--ec-color-heading); }
.turn-reporter  { background: #fce8ec; color: var(--ec-color-primary); }
.turn-closed    { background: #f0f0f1; color: #6b7280; }

.ide-ethics-dot {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	display: inline-block;
	flex-shrink: 0;
}

.ide-ethics-dot--waiting { background: var(--ec-color-accent); }
.ide-ethics-dot--yours   { background: var(--ec-color-primary); }

/* ===========================================================================
   MESSAGES
   =========================================================================== */
.ide-ethics-thread__messages {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-bottom: 1.5rem;
}

.ide-ethics-msg {
	padding: 1rem 1.25rem;
	border-radius: var(--ec-radius);
	max-width: 90%;
}

.ide-ethics-msg--reporter {
	background: var(--ec-color-reporter);
	border-left: 4px solid var(--ec-color-reporter-b);
	align-self: flex-start;
}

.ide-ethics-msg--manager {
	background: var(--ec-color-manager);
	border-left: 4px solid var(--ec-color-manager-b);
	align-self: flex-end;
}

.ide-ethics-msg__meta {
	display: flex;
	justify-content: space-between;
	gap: .5rem;
	margin-bottom: .4rem;
	flex-wrap: wrap;
}

.ide-ethics-msg__sender {
	font-weight: 700;
	font-size: .85rem;
	color: var(--ec-color-muted);
}

.ide-ethics-msg__date {
	font-size: .8rem;
	color: var(--ec-color-muted);
}

.ide-ethics-msg__body {
	font-size: .97rem;
	white-space: pre-wrap;
	word-break: break-word;
}

/* ===========================================================================
   REPLY (portal)
   =========================================================================== */
.ide-ethics-thread__reply {
	border-top: 1px solid var(--ec-color-border);
	padding-top: 1.5rem;
	margin-top: .5rem;
}

.ide-ethics-thread__reply-title {
	margin: 0 0 1rem;
	font-size: 1.1rem;
	color: var(--ec-color-text);
}

.ide-ethics-thread__footer {
	margin-top: 1.5rem;
	padding-top: 1rem;
	border-top: 1px dotted var(--ec-color-border);
	font-size: .88rem;
}

.ide-ethics-link--secondary {
	color: var(--ec-color-muted);
	text-decoration: none;
}

.ide-ethics-link--secondary:hover {
	color: var(--ec-color-accent);
}

/* ===========================================================================
   ADMIN — GENERAL
   =========================================================================== */
.ide-ethics-admin .ide-ethics-detail__layout {
	display: flex;
	gap: 20px;
	align-items: flex-start;
}

.ide-ethics-admin .ide-ethics-detail__main {
	flex: 1;
	min-width: 0;
}

.ide-ethics-admin .ide-ethics-detail__sidebar {
	width: 280px;
	flex-shrink: 0;
}

.ide-ethics-meta-table {
	width: 100%;
	border-collapse: collapse;
}

.ide-ethics-meta-table th,
.ide-ethics-meta-table td {
	padding: 6px 8px;
	text-align: left;
	border-bottom: 1px solid #f0f0f1;
	font-size: .9rem;
}

.ide-ethics-meta-table th {
	width: 38%;
	color: var(--ec-color-muted);
	font-weight: 600;
}

/* Messages in admin */
.ide-ethics-thread__messages--admin .ide-ethics-msg {
	max-width: 100%;
}

/* Status badges in list */
.ide-ethics-status-badge {
	display: inline-block;
	padding: .2rem .6rem;
	border-radius: 12px;
	font-size: .8rem;
	font-weight: 600;
}

.ide-ethics-status-badge--open               { background: #e8ecf5; color: var(--ec-color-accent); }
.ide-ethics-status-badge--awaiting_manager   { background: #e8ecf5; color: var(--ec-color-heading); }
.ide-ethics-status-badge--awaiting_reporter  { background: #fce8ec; color: var(--ec-color-primary); }
.ide-ethics-status-badge--closed             { background: #f0f0f1; color: #6b7280; }

/* Cases table */
.ide-ethics-cases-table .column-public-id { width: 16%; }
.ide-ethics-cases-table .column-category  { width: 16%; }
.ide-ethics-cases-table .column-status    { width: 16%; }
.ide-ethics-cases-table .column-messages  { width: 8%;  text-align: center; }
.ide-ethics-cases-table .column-created   { width: 15%; }
.ide-ethics-cases-table .column-updated   { width: 15%; }
.ide-ethics-cases-table .column-actions   { width: 14%; }

.ide-ethics-case-subject {
	color: var(--ec-color-muted);
	font-size: .85rem;
}

/* Audit log */
.ide-ethics-audit-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.ide-ethics-audit-entry {
	padding: 6px 0;
	border-bottom: 1px dotted #f0f0f1;
	font-size: .83rem;
	display: grid;
	grid-template-columns: 1fr;
	gap: 2px;
}

.ide-ethics-audit-date   { color: var(--ec-color-muted); }
.ide-ethics-audit-action { font-weight: 600; }
.ide-ethics-audit-actor  { color: var(--ec-color-muted); font-style: italic; }
.ide-ethics-audit-details { color: var(--ec-color-text); }

/* Empty state */
.ide-ethics-empty-state,
.ide-ethics-empty {
	color: var(--ec-color-muted);
	font-style: italic;
}

/* Form field in admin */
.ide-ethics-field {
	margin-bottom: 1rem;
}

/* Case detail — header */
.ide-ethics-detail__case-id {
	font-family: "SFMono-Regular", Consolas, monospace;
	font-size: .9em;
	background: var(--ec-color-bg);
	padding: .1em .4em;
	border-radius: 3px;
}

/* Basic responsive */
@media (max-width: 660px) {
	.ide-ethics-wrap {
		padding: 1.25rem;
		margin: 1rem;
	}

	.ide-ethics-msg--manager {
		align-self: flex-start;
	}

	.ide-ethics-admin .ide-ethics-detail__layout {
		flex-direction: column;
	}

	.ide-ethics-admin .ide-ethics-detail__sidebar {
		width: 100%;
	}
}
