.wpcf7 .screen-reader-response {
position: absolute;
overflow: hidden;
clip: rect(1px, 1px, 1px, 1px);
clip-path: inset(50%);
height: 1px;
width: 1px;
margin: -1px;
padding: 0;
border: 0;
word-wrap: normal !important;
word-break: normal !important;
}
.wpcf7 .hidden-fields-container {
display: none;
}
.wpcf7 form .wpcf7-response-output {
margin: 2em 0.5em 1em;
padding: 0.2em 1em;
border: 2px solid #00a0d2; }
.wpcf7 form.init .wpcf7-response-output,
.wpcf7 form.resetting .wpcf7-response-output,
.wpcf7 form.submitting .wpcf7-response-output {
display: none;
}
.wpcf7 form.sent .wpcf7-response-output {
border-color: #46b450; }
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
border-color: #dc3232; }
.wpcf7 form.spam .wpcf7-response-output {
border-color: #f56e28; }
.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output {
border-color: #ffb900; }
.wpcf7-form-control-wrap {
position: relative;
}
.wpcf7-not-valid-tip {
color: #dc3232; font-size: 1em;
font-weight: normal;
display: block;
}
.use-floating-validation-tip .wpcf7-not-valid-tip {
position: relative;
top: -2ex;
left: 1em;
z-index: 100;
border: 1px solid #dc3232;
background: #fff;
padding: .2em .8em;
width: 24em;
}
.wpcf7-list-item {
display: inline-block;
margin: 0 0 0 1em;
}
.wpcf7-list-item-label::before,
.wpcf7-list-item-label::after {
content: " ";
}
.wpcf7-spinner {
visibility: hidden;
display: inline-block;
background-color: #23282d; opacity: 0.75;
width: 24px;
height: 24px;
border: none;
border-radius: 100%;
padding: 0;
margin: 0 24px;
position: relative;
}
form.submitting .wpcf7-spinner {
visibility: visible;
}
.wpcf7-spinner::before {
content: '';
position: absolute;
background-color: #fbfbfc; top: 4px;
left: 4px;
width: 6px;
height: 6px;
border: none;
border-radius: 100%;
transform-origin: 8px 8px;
animation-name: spin;
animation-duration: 1000ms;
animation-timing-function: linear;
animation-iteration-count: infinite;
}
@media (prefers-reduced-motion: reduce) {
.wpcf7-spinner::before {
animation-name: blink;
animation-duration: 2000ms;
}
}
@keyframes spin {
from {
transform: rotate(0deg);
}
to {
transform: rotate(360deg);
}
}
@keyframes blink {
from {
opacity: 0;
}
50% {
opacity: 1;
}
to {
opacity: 0;
}
}
.wpcf7 [inert] {
opacity: 0.5;
}
.wpcf7 input[type="file"] {
cursor: pointer;
}
.wpcf7 input[type="file"]:disabled {
cursor: default;
}
.wpcf7 .wpcf7-submit:disabled {
cursor: not-allowed;
}
.wpcf7 input[type="url"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"] {
direction: ltr;
}
.wpcf7-reflection > output {
display: list-item;
list-style: none;
}
.wpcf7-reflection > output[hidden] {
display: none;
}.wpcf7 form{position:relative}.wpcf7 form>div,.wpcf7 form>p{margin-bottom:1.2em}.wpcf7 .wpcf7-form-control-wrap{width:100%;display:block}.wpcf7 input:not([type=submit]):focus,.wpcf7 select:focus,.wpcf7 textarea:focus{border-color:var(--ast-border-color);outline:0}.wpcf7 input:not([type=submit]),.wpcf7 select,.wpcf7 textarea{width:100%;padding:.75em}.wpcf7 input[type=file]{color:#666;height:auto;border-width:1px;border-style:solid;border-color:var(--ast-border-color);border-radius:2px;background:#fafafa;box-shadow:none;box-sizing:border-box;transition:all .2s linear}.wpcf7 input[type=checkbox],.wpcf7 input[type=radio]{display:inline-block;background:#e9eef2;color:#555;clear:none;cursor:pointer;line-height:0;height:1.2em;margin:-3px 4px 0 0;outline:0;padding:0;border-radius:.2em;text-align:center;vertical-align:middle;width:1.4em;min-width:1.4em;transition:all .2s linear}.tom-chat-widget {
max-width: 800px;
margin: 0 auto;
background: transparent;
border-radius: 4px;
border: none;
overflow: hidden;
font-family: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;
} .tom-chat-body {
padding: 24px;
overflow-y: auto;
background: transparent;
display: flex;
flex-direction: column;
gap: 16px;
} .tom-chat-body::-webkit-scrollbar {
width: 4px;
}
.tom-chat-body::-webkit-scrollbar-track {
background: transparent;
}
.tom-chat-body::-webkit-scrollbar-thumb {
background: #e5e2dd;
border-radius: 2px;
}
.tom-chat-body::-webkit-scrollbar-thumb:hover {
background: #c9a96e;
} .tom-message {
display: flex;
gap: 12px;
animation: tom-fadeIn 0.2s ease-out;
}
@keyframes tom-fadeIn {
from {
opacity: 0;
transform: translateY(6px);
}
to {
opacity: 1;
transform: translateY(0);
}
}
.tom-message-assistant {
align-items: flex-start;
}
.tom-message-user {
flex-direction: row-reverse;
}
.tom-message-avatar {
width: 32px;
height: 32px;
border-radius: 50%;
display: flex;
align-items: center;
justify-content: center;
font-weight: 600;
font-size: 0.87em;
flex-shrink: 0;
}
.tom-message-assistant .tom-message-avatar {
background: #1a1a1a;
color: #faf9f7;
}
.tom-message-user .tom-message-avatar {
display: none;
}
.tom-message-content {
flex: 1;
min-width: 0;
}
.tom-message-text {
padding: 10px 14px;
border-radius: 4px;
font-size: 0.87em;
line-height: 1.65;
word-wrap: break-word;
}
.tom-message-assistant .tom-message-text {
background: #faf9f7;
border: 1px solid #e5e2dd;
color: #1a1a1a;
max-width: 90%;
}
.tom-message-user .tom-message-text {
background: #1a1a1a;
color: #faf9f7;
border: 1px solid #1a1a1a;
max-width: 80%;
margin-left: auto;
} .tom-message-sources {
margin-top: 8px;
padding-top: 8px;
}
.tom-message-sources-title {
font-size: 0.73em;
font-weight: 600;
color: #8a8480;
margin-bottom: 4px;
text-transform: uppercase;
letter-spacing: 0.05em;
display: none;
}
.tom-message-sources-list {
display: flex;
flex-direction: column;
gap: 3px;
}
.tom-message-source-link {
font-size: 0.8em;
color: #c9a96e;
text-decoration: none !important;
display: flex;
align-items: center;
gap: 5px;
}
.tom-message-source-link:hover {
text-decoration: underline !important;
} .tom-source-link-inline {
text-decoration: underline !important;
text-underline-offset: 2px;
cursor: pointer;
}
.tom-source-link-inline:hover {
opacity: 0.75;
} .tom-chat-input-container {
padding: 16px 24px;
background: #faf9f7;
border-top: 1px solid #e5e2dd;
}
.tom-chat-welcome {
margin: 0 0 12px 0;
font-size: 0.85em;
line-height: 1.6;
color: #5a5753;
}
.tom-chat-input-wrapper {
display: flex;
gap: 10px;
align-items: flex-end;
background: #ffffff;
border: 1px solid #e5e2dd;
border-radius: 4px;
padding: 8px 12px;
transition: border-color 0.15s;
}
.tom-chat-input-wrapper:focus-within {
border-color: #c9a96e;
}
.tom-chat-input {
flex: 1;
border: none;
background: transparent;
resize: none;
font-size: 0.93em;
font-family: inherit;
line-height: 1.5;
max-height: 120px;
min-height: 48px;
outline: none;
color: #1a1a1a;
}
.tom-chat-input::placeholder {
color: #b5b0aa;
}
.tom-chat-send-btn { all: unset;
box-sizing: border-box !important; width: 34px !important;
height: 34px !important;
min-width: 34px !important;
min-height: 34px !important; border: none !important;
border-radius: 3px !important;
background: #1a1a1a !important;
color: #faf9f7 !important;
opacity: 1 !important;
visibility: visible !important; display: flex !important;
align-items: center !important;
justify-content: center !important;
flex-shrink: 0 !important; cursor: pointer !important;
transition: background-color 0.15s !important; -webkit-tap-highlight-color: transparent;
touch-action: manipulation;
}
.tom-chat-send-btn:hover {
background: #c9a96e !important;
}
.tom-chat-send-btn:active {
background: #b8924a !important;
}
.tom-chat-send-btn:disabled {
background: #e5e2dd !important;
cursor: not-allowed !important;
opacity: 0.6 !important;
} .tom-chat-send-btn svg {
display: block;
pointer-events: none;
flex-shrink: 0;
}
.tom-chat-info-text {
margin-top: 8px;
text-align: center;
font-size: 0.73em;
color: #b5b0aa;
}
.tom-chat-info-text a {
color: #c9a96e;
text-decoration: none;
}
.tom-chat-info-text a:hover {
text-decoration: underline;
} .tom-chat-loader {
padding: 16px;
display: flex;
justify-content: flex-start;
}
.tom-chat-loader-dots {
display: flex;
gap: 6px;
align-items: center;
}
.tom-chat-loader-dots span {
width: 6px;
height: 6px;
border-radius: 50%;
background: #c9a96e;
animation: tom-bounce 1.4s infinite ease-in-out both;
}
.tom-chat-loader-dots span:nth-child(1) {
animation-delay: -0.32s;
}
.tom-chat-loader-dots span:nth-child(2) {
animation-delay: -0.16s;
}
@keyframes tom-bounce {
0%, 80%, 100% {
transform: scale(0.5);
opacity: 0.4;
}
40% {
transform: scale(1);
opacity: 1;
}
} .tom-error {
padding: 14px 16px;
background: #faf9f7;
border: 1px solid #e5e2dd;
border-left: 3px solid #c9a96e;
border-radius: 4px;
color: #5a5753;
font-size: 0.93em;
}
.tom-error a {
color: #c9a96e;
text-decoration: underline;
} @media (max-width: 768px) {
.tom-chat-widget {
border-radius: 0;
border-left: none;
border-right: none;
}
.tom-chat-body {
padding: 20px 16px;
}
.tom-chat-input-container {
padding: 12px 16px;
}
.tom-chat-input-wrapper {
padding: 10px 12px;
gap: 8px;
align-items: center;
}
.tom-chat-input {
font-size: 16px; min-height: 28px;
} .tom-chat-send-btn {
width: 40px !important;
height: 40px !important;
min-width: 40px !important;
min-height: 40px !important;
border-radius: 4px !important;
}
.tom-message-user .tom-message-text {
max-width: 90%;
}
} .tom-chat-input-container {
border: 1px solid rgba(0, 0, 0, 0.12);
border-radius: 16px;
overflow: hidden;
} .tom-message-text .tom-inline-source-link {
color: inherit;
text-decoration: underline !important;
text-underline-offset: 3px;
text-decoration-thickness: 1px;
}
.tom-message-text .tom-inline-source-link:hover {
opacity: 0.8;
}
.tom-inline-source-note {
font-size: 0.92em;
opacity: 0.9;
}