/* ============================================================
   MyMyTool AI Hub – Frontend Stylesheet
   "Scientific Instrument" – dark + electric lime
   ============================================================ */

.mmt-ai-app {
	--mmt-bg: #0a0908;
	--mmt-bg-2: #11100e;
	--mmt-bg-3: #1a1815;
	--mmt-bg-4: #221f1a;
	--mmt-line: #2a2823;
	--mmt-line-bright: #3a382f;
	--mmt-text: #e8e6df;
	--mmt-text-dim: #8a8780;
	--mmt-text-mute: #5a5750;
	--mmt-accent: #c4f25d;
	--mmt-accent-glow: rgba(196,242,93,0.25);
	--mmt-accent-dim: #8aa83d;
	--mmt-blue: #5b8def;
	--mmt-coral: #ff6b4a;
	--mmt-warn: #f5c845;
	--mmt-mono: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
	--mmt-display: 'Instrument Serif', Georgia, serif;
	--mmt-sans: 'Inter', -apple-system, sans-serif;
	--mmt-radius: 4px;

	background: var(--mmt-bg);
	color: var(--mmt-text);
	font-family: var(--mmt-sans);
	border: 1px solid var(--mmt-line);
	border-radius: 8px;
	/* Roztiahni sa na parent container, ale buď pohodlný */
	width: 100%;
	max-width: 1400px;
	margin: 32px auto;
	min-height: 700px;
	position: relative;
	overflow: hidden;
	box-shadow: 0 30px 80px rgba(0,0,0,0.4);
	/* Vynutit rozumny text-align aj v custom templates */
	text-align: left;
}

/* Desktop breakout: na sirokych viewportoch sa roztiahne mimo uzkeho page containera */
@media (min-width: 1100px) {
	.mmt-ai-app {
		width: min(calc(100vw - 80px), 1400px);
		position: relative;
		left: 50%;
		transform: translateX(-50%);
	}
}

/* Grain overlay pre lab feel */
.mmt-ai-app::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		radial-gradient(circle at 20% 30%, rgba(196,242,93,0.04) 0%, transparent 40%),
		radial-gradient(circle at 80% 70%, rgba(91,141,239,0.03) 0%, transparent 50%);
	pointer-events: none;
	z-index: 0;
}

.mmt-ai-app *,
.mmt-ai-app *::before,
.mmt-ai-app *::after { box-sizing: border-box; }

/* Loading state */
.mmt-loading {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 60px;
	font-family: var(--mmt-mono);
	font-size: 12px;
	color: var(--mmt-text-mute);
	letter-spacing: 0.1em;
}
.mmt-cursor {
	color: var(--mmt-accent);
	animation: mmt-blink 1s steps(2) infinite;
}
@keyframes mmt-blink {
	to { opacity: 0; }
}

/* Layout grid */
.mmt-app-shell {
	display: grid;
	grid-template-columns: 240px 1fr;
	min-height: 600px;
	position: relative;
	z-index: 1;
}

/* ============================================================
   SIDEBAR
   ============================================================ */
.mmt-sidebar {
	background: var(--mmt-bg-2);
	border-right: 1px solid var(--mmt-line);
	padding: 20px 0;
	display: flex;
	flex-direction: column;
}
.mmt-sidebar-brand {
	padding: 0 20px 20px;
	border-bottom: 1px solid var(--mmt-line);
	display: flex;
	align-items: center;
	gap: 10px;
}
.mmt-sidebar-mark {
	font-family: var(--mmt-mono);
	font-size: 22px;
	color: var(--mmt-accent);
	letter-spacing: -3px;
	line-height: 1;
}
.mmt-sidebar-name {
	font-family: var(--mmt-mono);
	font-size: 11px;
	color: var(--mmt-text);
	letter-spacing: 0.05em;
	line-height: 1.3;
}
.mmt-sidebar-name strong { display: block; color: var(--mmt-accent); }

.mmt-sidebar-section {
	padding: 20px 20px 8px;
	font-family: var(--mmt-mono);
	font-size: 9px;
	color: var(--mmt-text-mute);
	letter-spacing: 0.15em;
	text-transform: uppercase;
}

.mmt-task-list {
	display: flex;
	flex-direction: column;
}
.mmt-task-item {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 20px;
	cursor: pointer;
	border: none;
	background: transparent;
	color: var(--mmt-text-dim);
	font-family: var(--mmt-mono);
	font-size: 12px;
	letter-spacing: 0.02em;
	text-align: left;
	transition: all 0.15s;
	border-left: 2px solid transparent;
}
.mmt-task-item:hover {
	background: var(--mmt-bg-3);
	color: var(--mmt-text);
}
.mmt-task-item.active {
	background: var(--mmt-bg-3);
	color: var(--mmt-accent);
	border-left-color: var(--mmt-accent);
}
.mmt-task-icon {
	width: 16px;
	text-align: center;
	font-size: 14px;
}
.mmt-task-key {
	margin-left: auto;
	font-size: 9px;
	color: var(--mmt-text-mute);
	background: var(--mmt-bg);
	padding: 2px 5px;
	border-radius: 2px;
}

/* History sidebar list */
.mmt-history-list {
	flex: 1;
	overflow-y: auto;
	padding: 4px 0 20px;
}
.mmt-history-item {
	padding: 10px 20px;
	border-bottom: 1px solid var(--mmt-line);
	cursor: pointer;
	transition: background 0.15s;
}
.mmt-history-item:hover {
	background: var(--mmt-bg-3);
}
.mmt-history-meta {
	font-family: var(--mmt-mono);
	font-size: 9px;
	color: var(--mmt-text-mute);
	letter-spacing: 0.05em;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.mmt-history-prompt {
	font-size: 11px;
	color: var(--mmt-text-dim);
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

/* ============================================================
   MAIN
   ============================================================ */
.mmt-main {
	display: flex;
	flex-direction: column;
	min-height: 600px;
}

.mmt-main-header {
	padding: 24px 32px 16px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	border-bottom: 1px solid var(--mmt-line);
	gap: 20px;
}
.mmt-main-title {
	flex: 1;
}
.mmt-main-eyebrow {
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-accent);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	margin-bottom: 4px;
}
.mmt-main-headline {
	font-family: var(--mmt-display);
	font-size: 36px;
	font-weight: 400;
	color: var(--mmt-text);
	line-height: 1;
	letter-spacing: -0.02em;
	margin: 0;
}
.mmt-main-headline em {
	font-style: italic;
	color: var(--mmt-accent);
}
.mmt-main-meta {
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-text-mute);
	text-align: right;
	letter-spacing: 0.05em;
}
.mmt-main-meta span { display: block; }

/* Conversation area */
.mmt-conversation {
	flex: 1;
	padding: 24px 32px;
	overflow-y: auto;
	min-height: 200px;
}

.mmt-empty-state {
	text-align: center;
	padding: 60px 20px;
	color: var(--mmt-text-mute);
}
.mmt-empty-art {
	font-family: var(--mmt-mono);
	font-size: 14px;
	color: var(--mmt-line-bright);
	margin-bottom: 20px;
	white-space: pre;
	line-height: 1.4;
}
.mmt-empty-text {
	font-family: var(--mmt-mono);
	font-size: 11px;
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

/* Message blocks */
.mmt-msg {
	margin-bottom: 24px;
	animation: mmt-fade-in 0.4s ease-out;
}
@keyframes mmt-fade-in {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}
.mmt-msg-header {
	display: flex;
	align-items: center;
	gap: 10px;
	margin-bottom: 10px;
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-text-mute);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}
.mmt-msg-tag {
	background: var(--mmt-bg-3);
	border: 1px solid var(--mmt-line);
	padding: 3px 8px;
	border-radius: 3px;
	color: var(--mmt-text);
}
.mmt-msg-tag.user { color: var(--mmt-blue); border-color: rgba(91,141,239,0.3); }
.mmt-msg-tag.ai { color: var(--mmt-accent); border-color: rgba(196,242,93,0.3); }
.mmt-msg-tag.system { color: var(--mmt-warn); border-color: rgba(245,200,69,0.3); }
.mmt-msg-time { color: var(--mmt-text-mute); }
.mmt-msg-body {
	background: var(--mmt-bg-2);
	border: 1px solid var(--mmt-line);
	border-left-width: 2px;
	border-radius: var(--mmt-radius);
	padding: 16px 20px;
	color: var(--mmt-text);
	font-size: 14px;
	line-height: 1.6;
	white-space: pre-wrap;
	word-break: break-word;
}
.mmt-msg.user .mmt-msg-body { border-left-color: var(--mmt-blue); }
.mmt-msg.ai .mmt-msg-body { border-left-color: var(--mmt-accent); }
.mmt-msg.system .mmt-msg-body {
	border-left-color: var(--mmt-warn);
	background: rgba(245,200,69,0.05);
	font-family: var(--mmt-mono);
	font-size: 12px;
	color: var(--mmt-warn);
}
.mmt-msg.error .mmt-msg-body {
	border-left-color: var(--mmt-coral);
	background: rgba(255,107,74,0.05);
	color: var(--mmt-coral);
	font-family: var(--mmt-mono);
	font-size: 11px;
	line-height: 1.6;
	white-space: pre-wrap;
	word-break: break-word;
	max-height: 300px;
	overflow-y: auto;
}
.mmt-msg-image {
	max-width: 100%;
	max-height: 600px;
	border-radius: var(--mmt-radius);
	border: 1px solid var(--mmt-line);
	margin-top: 8px;
	display: block;
	cursor: zoom-in;
	transition: transform 0.2s;
}
.mmt-msg-image:hover {
	border-color: var(--mmt-accent);
}

/* Pipeline progress block */
.mmt-pipeline {
	background: var(--mmt-bg-2);
	border: 1px solid var(--mmt-line);
	border-left: 2px solid var(--mmt-accent);
	border-radius: var(--mmt-radius);
	padding: 16px 20px;
	margin-bottom: 16px;
}
.mmt-pipeline-title {
	font-family: var(--mmt-mono);
	font-size: 11px;
	color: var(--mmt-accent);
	letter-spacing: 0.1em;
	text-transform: uppercase;
	margin-bottom: 12px;
}
.mmt-pipeline-step {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 8px 0;
	font-family: var(--mmt-mono);
	font-size: 12px;
}
.mmt-pipeline-step .step-status {
	width: 14px;
	text-align: center;
}
.mmt-pipeline-step.pending { color: var(--mmt-text-mute); }
.mmt-pipeline-step.pending .step-status::before { content: '○'; }
.mmt-pipeline-step.running { color: var(--mmt-accent); }
.mmt-pipeline-step.running .step-status::before {
	content: '◐';
	animation: mmt-spin 1s linear infinite;
	display: inline-block;
}
.mmt-pipeline-step.done { color: var(--mmt-text); }
.mmt-pipeline-step.done .step-status::before { content: '●'; color: var(--mmt-accent); }
.mmt-pipeline-step.error { color: var(--mmt-coral); }
.mmt-pipeline-step.error .step-status::before { content: '✕'; }
@keyframes mmt-spin {
	to { transform: rotate(360deg); }
}

/* ============================================================
   PROMPT BAR (bottom)
   ============================================================ */
.mmt-prompt-bar {
	border-top: 1px solid var(--mmt-line);
	background: var(--mmt-bg-2);
	padding: 16px 32px 20px;
	position: relative;
}

/* Recommend banner */
.mmt-recommend {
	display: flex;
	align-items: center;
	gap: 10px;
	padding: 10px 14px;
	margin-bottom: 12px;
	background: rgba(196,242,93,0.05);
	border: 1px solid rgba(196,242,93,0.2);
	border-radius: var(--mmt-radius);
	font-family: var(--mmt-mono);
	font-size: 11px;
	color: var(--mmt-text);
	animation: mmt-fade-in 0.3s;
}
.mmt-recommend-icon { color: var(--mmt-accent); font-size: 14px; }
.mmt-recommend-text {
	flex: 1;
}
.mmt-recommend-text strong { color: var(--mmt-accent); }
.mmt-recommend-accept {
	padding: 4px 10px;
	background: var(--mmt-accent);
	color: var(--mmt-bg);
	border: none;
	border-radius: 3px;
	font-family: var(--mmt-mono);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	cursor: pointer;
}
.mmt-recommend-dismiss {
	background: none;
	border: none;
	color: var(--mmt-text-mute);
	cursor: pointer;
	font-size: 14px;
	padding: 4px 6px;
}

/* Provider chips */
.mmt-providers-row {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	margin-bottom: 10px;
}

/* ============================================================
   OPTIONS PANEL (v0.1.7)
   Rozbalovaci panel medzi providermi a prompt formom
   ============================================================ */
.mmt-options-wrap {
	margin-bottom: 10px;
}
.mmt-options-wrap:empty {
	display: none;
}
.mmt-options-header {
	display: flex;
	align-items: center;
	gap: 10px;
	width: 100%;
	padding: 8px 14px;
	background: var(--mmt-bg);
	border: 1px solid var(--mmt-line);
	border-radius: var(--mmt-radius);
	color: var(--mmt-text-dim);
	font-family: var(--mmt-mono);
	font-size: 11px;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: all 0.15s;
	text-align: left;
}
.mmt-options-header:hover {
	border-color: var(--mmt-accent);
	color: var(--mmt-text);
	background: rgba(196,242,93,0.03);
}
.mmt-options-header.expanded {
	border-color: var(--mmt-accent);
	color: var(--mmt-accent);
	border-bottom-left-radius: 0;
	border-bottom-right-radius: 0;
	border-bottom-color: var(--mmt-line);
}
.mmt-options-icon {
	color: var(--mmt-accent);
	font-size: 13px;
	width: 14px;
	display: inline-block;
	text-align: center;
}
.mmt-options-label {
	color: var(--mmt-accent);
	font-weight: 600;
}
.mmt-options-summary {
	color: var(--mmt-text-mute);
	font-style: italic;
	margin-left: auto;
	font-size: 10px;
}
.mmt-options-header.expanded .mmt-options-summary {
	color: var(--mmt-text-dim);
	font-style: normal;
}

.mmt-options-body {
	background: var(--mmt-bg-2);
	border: 1px solid var(--mmt-accent);
	border-top: none;
	border-bottom-left-radius: var(--mmt-radius);
	border-bottom-right-radius: var(--mmt-radius);
	padding: 16px 18px;
	animation: mmt-fade-in 0.2s ease-out;
}

.mmt-opt-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
	gap: 14px;
}
.mmt-opt-field {
	display: flex;
	flex-direction: column;
	gap: 6px;
}
.mmt-opt-field label {
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-text-mute);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}
.mmt-opt-select {
	background: var(--mmt-bg);
	border: 1px solid var(--mmt-line-bright);
	color: var(--mmt-text);
	padding: 9px 12px;
	font-family: var(--mmt-mono);
	font-size: 12px;
	border-radius: var(--mmt-radius);
	cursor: pointer;
	transition: all 0.15s;
	appearance: none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' fill='%23c4f25d'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	background-size: 10px;
	padding-right: 32px;
}
.mmt-opt-select:hover {
	border-color: var(--mmt-accent);
}
.mmt-opt-select:focus {
	outline: none;
	border-color: var(--mmt-accent);
	box-shadow: 0 0 0 3px rgba(196,242,93,0.1);
}
.mmt-opt-select option {
	background: var(--mmt-bg);
	color: var(--mmt-text);
	padding: 6px;
}
.mmt-opt-select optgroup {
	background: var(--mmt-bg-3);
	color: var(--mmt-accent);
	font-style: normal;
	font-weight: 600;
}
.mmt-opt-hint {
	grid-column: 1 / -1;
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-text-mute);
	line-height: 1.5;
	padding-top: 4px;
	border-top: 1px dashed var(--mmt-line);
	margin-top: 4px;
}
.mmt-provider-chip {
	padding: 5px 10px;
	background: var(--mmt-bg);
	border: 1px solid var(--mmt-line);
	border-radius: 12px;
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-text-dim);
	cursor: pointer;
	transition: all 0.15s;
	display: flex;
	align-items: center;
	gap: 5px;
}
.mmt-provider-chip:hover {
	border-color: var(--mmt-accent);
	color: var(--mmt-text);
}
.mmt-provider-chip.active {
	background: var(--mmt-accent);
	color: var(--mmt-bg);
	border-color: var(--mmt-accent);
	font-weight: 600;
}
.mmt-provider-chip.auto {
	background: rgba(196,242,93,0.1);
	border-color: rgba(196,242,93,0.3);
	color: var(--mmt-accent);
}
.mmt-provider-chip.auto.active {
	background: var(--mmt-accent);
	color: var(--mmt-bg);
}

/* Prompt input */
.mmt-prompt-form {
	display: flex;
	gap: 0;
	align-items: stretch;
	background: var(--mmt-bg);
	border: 1px solid var(--mmt-line-bright);
	border-radius: var(--mmt-radius);
	overflow: hidden;
	transition: border-color 0.15s, box-shadow 0.15s;
	min-height: 72px;
}
.mmt-prompt-form:focus-within {
	border-color: var(--mmt-accent);
	box-shadow: 0 0 0 3px rgba(196,242,93,0.15);
}
.mmt-prompt-prefix {
	padding: 20px 18px;
	font-family: var(--mmt-mono);
	font-size: 16px;
	color: var(--mmt-accent);
	user-select: none;
	border-right: 1px solid var(--mmt-line);
	display: flex;
	align-items: flex-start;
	font-weight: 700;
}
.mmt-prompt-input {
	flex: 1;
	background: transparent;
	border: none;
	color: var(--mmt-text);
	padding: 18px 16px;
	font-family: var(--mmt-sans);
	font-size: 15px;
	resize: none;
	outline: none;
	line-height: 1.6;
	min-height: 72px;
	max-height: 280px;
	width: 100%;
}
.mmt-prompt-input::placeholder {
	color: var(--mmt-text-mute);
	font-style: italic;
}
.mmt-prompt-submit {
	background: var(--mmt-accent);
	border: none;
	color: var(--mmt-bg);
	padding: 0 32px;
	font-family: var(--mmt-mono);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.15s, box-shadow 0.2s;
	display: flex;
	align-items: center;
	gap: 8px;
	min-width: 140px;
	justify-content: center;
}
.mmt-prompt-submit:hover {
	background: #d6ff70;
	box-shadow: inset 0 0 40px rgba(255,255,255,0.1);
}
.mmt-prompt-submit:disabled {
	background: var(--mmt-line-bright);
	color: var(--mmt-text-mute);
	cursor: not-allowed;
}

.mmt-prompt-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: 10px;
	font-family: var(--mmt-mono);
	font-size: 10px;
	color: var(--mmt-text-mute);
	letter-spacing: 0.05em;
}
.mmt-rate-indicator {
	display: flex;
	align-items: center;
	gap: 6px;
}
.mmt-rate-indicator::before {
	content: '●';
	color: var(--mmt-accent);
}
.mmt-warning {
	color: var(--mmt-warn) !important;
}
.mmt-warning::before { color: var(--mmt-warn) !important; }

/* Mobile */
@media (max-width: 900px) {
	.mmt-ai-app {
		width: auto;
		max-width: 100%;
		margin: 16px;
		left: auto;
		transform: none;
	}
}
@media (max-width: 768px) {
	.mmt-app-shell { grid-template-columns: 1fr; }
	.mmt-sidebar { display: none; }
	.mmt-main-header { padding: 20px; }
	.mmt-main-headline { font-size: 26px; }
	.mmt-conversation { padding: 16px 20px; }
	.mmt-prompt-bar { padding: 12px 20px 16px; }
	.mmt-prompt-submit { min-width: 100px; padding: 0 16px; font-size: 11px; }
	.mmt-prompt-input { font-size: 14px; padding: 14px 12px; }
}

/* No-keys warning */
.mmt-no-keys {
	background: rgba(255,107,74,0.05);
	border: 1px solid rgba(255,107,74,0.3);
	color: var(--mmt-coral);
	padding: 16px 20px;
	border-radius: var(--mmt-radius);
	font-family: var(--mmt-mono);
	font-size: 12px;
	text-align: center;
}
.mmt-no-keys strong { display: block; margin-bottom: 4px; }
