* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

*:focus {
    outline: 1px solid rgba(116, 195, 107, 0.7);
    outline-offset: 1px;
}

body {
    font-family: Arial, sans-serif;
    height: 100vh;
    background-color: rgba(234, 235, 233, 1);
}

.container {
    display: grid;
    grid-template-columns: 1fr auto;
    height: 100vh;
    gap: 0.2rem;
}

.container:has(#settings-column-container.hidden) {
    grid-template-columns: 1fr;
}

.hidden {
    display: none;
}

.chat-column {
    display: grid;
    grid-template-rows: 1fr auto;
    padding: 0.5rem;
    max-height: 100vh;
}

.chat-history {
    background-color: rgba(254, 255, 253, 0.5);
    border: 1px solid #252f23;
    margin-bottom: 1rem;
    min-height: 200px;
    overflow-y: auto;
    padding: 0.5rem;
    font-size: 1.4rem;
}

.chat-history p.muted {
    background-color: rgba(195, 107, 116, 0.25);
    margin: 0;
    padding: 0.2em 0.4em;
}

.reply-pending-indicator {
    color: #666;
    font-size: 0.85em;
    margin-left: 0.5em;
}

#copy-history:hover {
    color: rgb(195, 107, 116);
    transform: scale(1.25);
    cursor: pointer;
}

#copy-history:focus:not(:focus-visible) {
	outline: none;
}

#copy-history {
    background-color: transparent;
    border: none;
}

.statuses {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.7rem;
    margin-right: 1rem;
}

.statusbar {
    font-style: italic;
    font-size: 0.75rem;
    padding-bottom: 0.4rem;
}

.chat-form {
    display: flex;
    flex: 0;
    flex-direction: column;
    gap: 0.5rem;
}

.chat-form fieldset {
    padding: 0.75rem;
    display: flex;
    align-items: stretch;
    gap: 0.5rem;
}

.chat-form textarea {
    flex: 1;
    background-color: rgba(254, 255, 253, 0.7);
    font-size: 1rem;
    resize: vertical;
    min-height: 60px;
}

.chat-form textarea.muted {
    background-color: rgba(0, 0, 0, 0);
}

.chat-form input[type="submit"] {
    align-self: stretch;
    padding: 0.5rem 0.75rem;
    background-color: rgba(116, 195, 107, 1);
    color: #eaebe9;
    border: none;
    cursor: pointer;
}

.chat-form input[type="submit"].muted {
    background-color: rgba(195, 107, 116);
}

.chat-form input[type="submit"].muted:hover {
    background-color: rgba(195, 107, 116, 0.4);
}

.chat-form input[type="submit"]:hover {
    background-color: rgba(116, 195, 107, 0.4);
    color: rgba(37, 47, 35, 0.8);
}


.disabled-input {
    pointer-events: none;
    opacity: 0.6;
}

.chat-history p {
    margin-bottom: 0.5rem;
    word-wrap: break-word;
}

.chat-history strong {
    color: #495057;
}

pre {
    background-color: #272822;
    color: #f8f8f2;
    padding: 0.75rem;
    border-radius: 6px;
    overflow-x: auto;
    margin: 0.75rem 0;
    font-size: 0.9rem;
    line-height: 1.5;
}

pre code {
    font-family: "Fira Code", "SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;
    display: block;
    user-select: all;
}

.chroma {
    background-color: #272822;
    color: #f8f8f2;
    display: block;
    padding: 0.75rem;
    border-radius: 6px;
    overflow-x: auto;
}

.chroma .hl { background-color: rgba(255, 255, 204, 0.15); }
.chroma .c { color: #75715e; }
.chroma .c1 { color: #75715e; }
.chroma .cm { color: #75715e; }
.chroma .cp { color: #75715e; }
.chroma .cs { color: #75715e; }
.chroma .err { color: #960050; background-color: #1e0010; }
.chroma .k { color: #66d9ef; }
.chroma .kc { color: #66d9ef; }
.chroma .kd { color: #66d9ef; }
.chroma .kn { color: #f92672; }
.chroma .kp { color: #66d9ef; }
.chroma .kr { color: #66d9ef; }
.chroma .kt { color: #66d9ef; }
.chroma .m { color: #ae81ff; }
.chroma .mf { color: #ae81ff; }
.chroma .mh { color: #ae81ff; }
.chroma .mi { color: #ae81ff; }
.chroma .mo { color: #ae81ff; }
.chroma .na { color: #a6e22e; }
.chroma .nb { color: #f8f8f2; }
.chroma .nc { color: #a6e22e; }
.chroma .nd { color: #a6e22e; }
.chroma .ne { color: #a6e22e; }
.chroma .nf { color: #a6e22e; }
.chroma .ni { color: #f8f8f2; }
.chroma .nn { color: #f8f8f2; }
.chroma .no { color: #66d9ef; }
.chroma .nt { color: #f92672; }
.chroma .nv { color: #f8f8f2; }
.chroma .o { color: #f92672; }
.chroma .ow { color: #f92672; }
.chroma .p { color: #f8f8f2; }
.chroma .s { color: #e6db74; }
.chroma .s1 { color: #e6db74; }
.chroma .s2 { color: #e6db74; }
.chroma .sb { color: #e6db74; }
.chroma .sc { color: #e6db74; }
.chroma .sd { color: #e6db74; }
.chroma .se { color: #ae81ff; }
.chroma .sh { color: #e6db74; }
.chroma .si { color: #e6db74; }
.chroma .sr { color: #e6db74; }
.chroma .ss { color: #e6db74; }
.chroma .sx { color: #e6db74; }
.chroma .vc { color: #f8f8f2; }
.chroma .vg { color: #f8f8f2; }
.chroma .vi { color: #f8f8f2; }
.chroma .w { color: #f8f8f2; }
}

.locked {
    background-color: #ffebee;
    border-color: #f44336;
    cursor: not-allowed;
}

.apikey-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    padding: 2rem;
    gap: 1rem;
}

.apikey-container img {
    width: 720px;
    max-width: 100%;
    height: auto;
}

.apikey-container form {
    width: 720px;
    max-width: 100%;
}

.apikey-container fieldset {
    padding: 1.5rem;
    border: 1px solid #252f23;
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

.apikey-container legend {
    padding: 0 0.5rem;
    font-weight: bold;
    color: #495057;
}

.apikey-container input[name="apikey"] {
    width: 100%;
    padding: 0.75rem;
    border: 1px solid #252f23;
    font-size: 1rem;
}

.apikey-container input[type="submit"] {
    padding: 0.75rem 1.5rem;
    background-color: rgba(116, 195, 107, 1);
    color: #eaebe9;
    border: none;
    cursor: pointer;
}

.apikey-container input[type="submit"]:hover {
    background-color: rgba(116, 195, 107, 0.4);
    color: rgba(37, 47, 35, 0.8);
}

.about-text-box {
    width: 720px;
    max-width: 100%;
    border: 1px solid #252f23;
    padding: 1.5rem;
    text-align: left;
    box-sizing: border-box;
    background-color: white;
}

.about-text-box p {
    padding-bottom: 1rem;
}

.about-text-box h1 {
    padding-bottom: 1.5rem;
}

.person-name-view {
    cursor: pointer;
    padding: 2px 4px;
    border-radius: 3px;
}

.person-name-view:hover {
    background-color: rgba(116, 195, 107, 0.2);
}

label {
    margin-bottom: -0.8rem;
    font-weight: 600;
}

.mrlja {
    border: 1px solid #252f23;
}

.bookkeeping-panel {
    padding: 0.75rem;
    border: 1px solid #252f23;
    font-size: 0.9rem;
}

.bookkeeping-header {
    font-weight: 600;
    margin-bottom: 0.5rem;
}

.bookkeeping-row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 0.25rem;
    gap: 0.5rem;
}

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

.bookkeeping-row .total {
    font-weight: 600;
}

.bookkeeping-value {
    font-variant-numeric: tabular-nums;
}

.bookkeeping-meta {
    font-size: 0.75rem;
    color: #555;
}

.bookkeeping-footer {
    font-size: 0.75rem;
    color: #444;
    text-align: right;
}
