.prompt-input-container { @apply flex flex-col border-t; border-color: var(--border-base); background-color: var(--surface-base); } .prompt-input-wrapper { @apply grid items-stretch; grid-template-columns: minmax(0, 1fr) 64px; gap: 0; padding: 0; } .prompt-input-actions { @apply flex flex-col items-center; align-self: stretch; height: 100%; padding: 0.5rem 0.25rem; gap: 0.5rem; } .prompt-input-field-container { position: relative; width: 100%; min-height: 56px; flex: 1 1 auto; height: 100%; min-width: 0; } .prompt-input-field { position: relative; width: 100%; height: 100%; } .prompt-input { @apply w-full pl-3 pr-10 pt-2.5 border text-sm resize-none outline-none transition-colors; font-family: inherit; background-color: var(--surface-base); color: var(--text-primary); caret-color: var(--text-primary); border-color: var(--border-base); line-height: var(--line-height-normal); border-radius: 0; padding-bottom: 0; height: 100%; min-height: 100%; } .prompt-input-field-container.is-expanded { height: auto; } .prompt-input-field.is-expanded { height: auto; } .prompt-input.is-expanded { height: auto; min-height: 0; overflow-y: auto; } .prompt-input-overlay { position: absolute; bottom: 1rem; left: 0.75rem; right: 0.75rem; display: flex; flex-wrap: wrap; gap: 0.5rem; font-size: 0.75rem; line-height: 1.3; color: var(--text-muted); pointer-events: none; z-index: 1; } .prompt-input-overlay.shell-mode { color: var(--text-primary); } /* Navigation buttons container (expand, prev, next) */ .prompt-nav-buttons { position: absolute; top: 0.25rem; right: 0.25rem; bottom: 0.25rem; display: flex; flex-direction: column; justify-content: flex-start; gap: 0.125rem; z-index: 2; } .prompt-expand-button, .prompt-history-button { @apply w-7 h-7 flex items-center justify-center rounded-md; color: var(--text-muted); background-color: var(--control-ghost-bg); transition: background-color 0.15s ease, color 0.15s ease; padding: 0; flex-shrink: 0; } .prompt-expand-button:hover:not(:disabled), .prompt-history-button:hover:not(:disabled) { background-color: var(--surface-secondary); color: var(--text-primary); } .prompt-expand-button:active:not(:disabled) { background-color: var(--accent-primary); color: var(--text-inverted); transform: scale(0.95); } .prompt-expand-button:disabled, .prompt-history-button:disabled { opacity: 0.4; cursor: not-allowed; } .prompt-overlay-text { display: inline-flex; align-items: center; gap: 0.35rem; } .prompt-overlay-warning { color: var(--status-warning); font-weight: 500; } .prompt-overlay-shell-active { color: var(--status-success); font-weight: 600; } .prompt-overlay-muted { color: var(--text-muted); } .prompt-input.shell-mode { border-color: var(--status-success); box-shadow: inset 0 0 0 1px var(--status-success-ring); } .prompt-input:focus { border-color: var(--accent-primary); } .prompt-input.shell-mode:focus { border-color: var(--status-success); box-shadow: inset 0 0 0 1px var(--status-success-ring); } .prompt-input:disabled { @apply opacity-60 cursor-not-allowed; } .prompt-input::placeholder { color: var(--text-muted); } .stop-button { @apply w-10 h-10 rounded-md border-none cursor-pointer flex items-center justify-center transition-all flex-shrink-0; background-color: var(--button-danger-bg); color: var(--button-danger-text); } .stop-button:hover:not(:disabled) { background-color: var(--button-danger-hover-bg); @apply opacity-95 scale-105; } .stop-button:active:not(:disabled) { background-color: var(--button-danger-active-bg); @apply scale-95; } .stop-button:disabled { @apply opacity-60 cursor-not-allowed; } .stop-icon { width: 1rem; height: 1rem; } .send-button { @apply w-10 h-10 rounded-md border-none cursor-pointer flex items-center justify-center transition-all flex-shrink-0; background-color: var(--accent-primary); color: var(--text-inverted); margin-top: auto; } .send-button.shell-mode { background-color: var(--status-success); } .send-button.shell-mode:hover:not(:disabled) { filter: brightness(1.05); } .send-button.shell-mode:active:not(:disabled) { filter: brightness(0.95); } .send-button:hover:not(:disabled) { @apply opacity-90 scale-105; } .send-button:active:not(:disabled) { @apply scale-95; } .send-button:disabled { @apply opacity-40 cursor-not-allowed; } .send-icon { @apply text-base; } .shell-icon { width: 1rem; height: 1rem; } .hint { @apply text-xs; color: var(--text-muted); } .hint kbd { @apply inline-block px-1.5 py-0.5 text-xs font-mono rounded mx-0.5; background-color: var(--surface-secondary); border: 1px solid var(--border-base); border-radius: 3px; } .attachment-chip { @apply px-2.5 py-1 text-xs font-medium ring-1 ring-inset; background-color: var(--attachment-chip-bg); color: var(--attachment-chip-text); ring-color: var(--attachment-chip-ring); } .attachment-chip-image { position: relative; } .attachment-chip-preview { display: none; position: absolute; bottom: calc(100% + 6px); left: 0; padding: 8px; background-color: var(--surface-base); border: 1px solid var(--border-base); border-radius: 10px; box-shadow: var(--popover-shadow); z-index: 20; } .attachment-chip-preview img { display: block; max-width: 320px; max-height: 320px; border-radius: 8px; object-fit: contain; } .attachment-chip-image:hover .attachment-chip-preview { display: block; } .attachment-remove, .attachment-download, .attachment-expand { @apply ml-0.5 flex h-4 w-4 items-center justify-center rounded transition-colors; } .attachment-remove:hover, .attachment-download:hover, .attachment-expand:hover { background-color: var(--attachment-chip-ring); } @media (pointer: coarse) { .prompt-input-overlay { display: none; } .prompt-input { padding-bottom: 1.5rem; } } @media (max-width: 720px) { .prompt-input-wrapper { grid-template-columns: minmax(0, 1fr) 40px; } } @media (max-width: 640px) { .prompt-input { min-height: 64px; padding: 0.5rem 0.75rem; padding-bottom: 2.25rem; } .prompt-input-wrapper { gap: 0; padding: 0; } }