/* eslint-disable color-named, no-duplicate-selectors */
/* stylelint-disable plugin/use_theme_colors */
/*
 * Copyright 2026 The Chromium Authors
 * Use of this source code is governed by a BSD-style license that can be
 * found in the LICENSE file.
 */

:root {
  --gemini-logo: url("data:image/svg+xml,%0A%3Csvg%20fill%3D%22none%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%2065%2065%22%3E%3Cmask%20id%3D%22maskme%22%20style%3D%22mask-type%3Aalpha%22%20maskUnits%3D%22userSpaceOnUse%22%20x%3D%220%22%20y%3D%220%22%20width%3D%2265%22%20height%3D%2265%22%3E%3Cpath%20d%3D%22M32.447%200c.68%200%201.273.465%201.439%201.125a38.904%2038.904%200%20001.999%205.905c2.152%205%205.105%209.376%208.854%2013.125%203.751%203.75%208.126%206.703%2013.125%208.855a38.98%2038.98%200%20005.906%201.999c.66.166%201.124.758%201.124%201.438%200%20.68-.464%201.273-1.125%201.439a38.902%2038.902%200%2000-5.905%201.999c-5%202.152-9.375%205.105-13.125%208.854-3.749%203.751-6.702%208.126-8.854%2013.125a38.973%2038.973%200%2000-2%205.906%201.485%201.485%200%2001-1.438%201.124c-.68%200-1.272-.464-1.438-1.125a38.913%2038.913%200%2000-2-5.905c-2.151-5-5.103-9.375-8.854-13.125-3.75-3.749-8.125-6.702-13.125-8.854a38.973%2038.973%200%2000-5.905-2A1.485%201.485%200%20010%2032.448c0-.68.465-1.272%201.125-1.438a38.903%2038.903%200%20005.905-2c5-2.151%209.376-5.104%2013.125-8.854%203.75-3.749%206.703-8.125%208.855-13.125a38.972%2038.972%200%20001.999-5.905A1.485%201.485%200%200132.447%200z%22%20fill%3D%22%23000%22/%3E%3Cpath%20d%3D%22M32.447%200c.68%200%201.273.465%201.439%201.125a38.904%2038.904%200%20001.999%205.905c2.152%205%205.105%209.376%208.854%2013.125%203.751%203.75%208.126%206.703%2013.125%208.855a38.98%2038.98%200%20005.906%201.999c.66.166%201.124.758%201.124%201.438%200%20.68-.464%201.273-1.125%201.439a38.902%2038.902%200%2000-5.905%201.999c-5%202.152-9.375%205.105-13.125%208.854-3.749%203.751-6.702%208.126-8.854%2013.125a38.973%2038.973%200%2000-2%205.906%201.485%201.485%200%2001-1.438%201.124c-.68%200-1.272-.464-1.438-1.125a38.913%2038.913%200%2000-2-5.905c-2.151-5-5.103-9.375-8.854-13.125-3.75-3.749-8.125-6.702-13.125-8.854a38.973%2038.973%200%2000-5.905-2A1.485%201.485%200%20010%2032.448c0-.68.465-1.272%201.125-1.438a38.903%2038.903%200%20005.905-2c5-2.151%209.376-5.104%2013.125-8.854%203.75-3.749%206.703-8.125%208.855-13.125a38.972%2038.972%200%20001.999-5.905A1.485%201.485%200%200132.447%200z%22%20fill%3D%22%23000%22/%3E%3Cpath%20d%3D%22M32.447%200c.68%200%201.273.465%201.439%201.125a38.904%2038.904%200%20001.999%205.905c2.152%205%205.105%209.376%208.854%2013.125%203.751%203.75%208.126%206.703%2013.125%208.855a38.98%2038.98%200%20005.906%201.999c.66.166%201.124.758%201.124%201.438%200%20.68-.464%201.273-1.125%201.439a38.902%2038.902%200%2000-5.905%201.999c-5%202.152-9.375%205.105-13.125%208.854-3.749%203.751-6.702%208.126-8.854%2013.125a38.973%2038.973%200%2000-2%205.906%201.485%201.485%200%2001-1.438%201.124c-.68%200-1.272-.464-1.438-1.125a38.913%2038.913%200%2000-2-5.905c-2.151-5-5.103-9.375-8.854-13.125-3.75-3.749-8.125-6.702-13.125-8.854a38.973%2038.973%200%2000-5.905-2A1.485%201.485%200%20010%2032.448c0-.68.465-1.272%201.125-1.438a38.903%2038.903%200%20005.905-2c5-2.151%209.376-5.104%2013.125-8.854%203.75-3.749%206.703-8.125%208.855-13.125a38.972%2038.972%200%20001.999-5.905A1.485%201.485%200%200132.447%200z%22%20fill%3D%22%23000%22/%3E%3Cpath%20d%3D%22M32.447%200c.68%200%201.273.465%201.439%201.125a38.904%2038.904%200%20001.999%205.905c2.152%205%205.105%209.376%208.854%2013.125%203.751%203.75%208.126%206.703%2013.125%208.855a38.98%2038.98%200%20005.906%201.999c.66.166%201.124.758%201.124%201.438%200%20.68-.464%201.273-1.125%201.439a38.902%2038.902%200%2000-5.905%201.999c-5%202.152-9.375%205.105-13.125%208.854-3.749%203.751-6.702%208.126-8.854%2013.125a38.973%2038.973%200%2000-2%205.906%201.485%201.485%200%2001-1.438%201.124c-.68%200-1.272-.464-1.438-1.125a38.913%2038.913%200%2000-2-5.905c-2.151-5-5.103-9.375-8.854-13.125-3.75-3.749-8.125-6.702-13.125-8.854a38.973%2038.973%200%2000-5.905-2A1.485%201.485%200%20010%2032.448c0-.68.465-1.272%201.125-1.438a38.903%2038.903%200%20005.905-2c5-2.151%209.376-5.104%2013.125-8.854%203.75-3.749%206.703-8.125%208.855-13.125a38.972%2038.972%200%20001.999-5.905A1.485%201.485%200%200132.447%200z%22%20fill%3D%22%23000%22/%3E%3C/mask%3E%3Cg%20mask%3D%22url%28%23maskme%29%22%3E%3Cpath%20d%3D%22M32.447%200c25.437%200%2046.062%2020.625%2046.062%2046.062%200%2025.438-20.625%2046.063-46.062%2046.063-25.438%200-46.062-20.625-46.062-46.063C-13.615%2020.625%207.01%200%2032.447%200z%22%20fill%3D%22%231967D2%22/%3E%3Cpath%20d%3D%22M65%200v65H0V0h65z%22%20fill%3D%22%231967D2%22/%3E%3Cpath%20d%3D%22M63.79%2033.567L33.567%2063.79%201.21%2031.433%2031.433%201.21%2063.79%2033.567z%22%20fill%3D%22%23fff%22%20style%3D%22mix-blend-mode%3Asoft-light%22/%3E%3C/g%3E%3C/svg%3E");
}

.green-dev-floaty-dialog {
  width: 100%;
  height: 100%;
  background-color: #fff;
  display: flex;
  flex-direction: column;
  font-family: sans-serif;
  color: #333;
  font-size: 16px;
  box-sizing: border-box;
}

/* Header extending upwards */
.green-dev-floaty-dialog-header {
  position: relative;
  height: 70px;
  margin-top: -20px;
  background-color: #d3e3fd;
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 34px 10px 11px;
  box-sizing: border-box;
}

.green-dev-floaty-dialog-header-text {
  font-weight: bold;
  font-size: 18px;
}

.green-dev-floaty-dialog-close-button {
  width: 20px;
  height: 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23333' d='M19 6.41L17.59 5L12 10.59L6.41 5L5 6.41L10.59 12L5 17.59L6.41 19L12 13.41L17.59 19L19 17.59L13.41 12z'/%3E%3C/svg%3E");
  background-size: cover;
  cursor: pointer;
  border: none;
  background-color: transparent;
  padding: 0;
}

/* Main content area of the white card */
.green-dev-floaty-dialog-content {
  flex-grow: 1;
  padding: 20px;
  display: flex;
  flex-direction: column;
  min-height: 0; /* Important for flex-grow with overflow */
}

.green-dev-floaty-dialog-chat-container {
  flex-grow: 1;
  margin-bottom: 10px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 10px;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  background-color: #f9f9f9;
}

.message {
  padding: 8px 12px;
  border-radius: 12px;
  max-width: 85%;
  overflow-wrap: break-word;
  line-height: 1.4;
  white-space: pre-wrap; /* Preserve newlines */
}

.user-message {
  align-self: flex-end;
  background-color: #d3e3fd;
  color: #0b57d0;
  border-bottom-right-radius: 2px;
}

.ai-message {
  align-self: flex-start;
  background-color: #fff;
  color: #333;
  border: 1px solid #e0e0e0;
  border-bottom-left-radius: 2px;
}

.message-details-toggle {
  font-size: 11px;
  color: #0b57d0;
  cursor: pointer;
  margin-top: 4px;
  text-decoration: underline;
}

.message-details-toggle:hover {
  color: #0842a0;
}

.message-details {
  font-size: 11px;
  color: #666;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid #eee;
  font-family: monospace;
}

.thought, .action {
  margin-bottom: 6px;
  white-space: pre-wrap;
}

.thought {
  font-style: italic;
}

.green-dev-floaty-dialog-top-row {
  display: flex;
  align-items: center;
  margin-bottom: 15px; /* Space between top row and blue card */
}

.green-dev-floaty-dialog-gemini-icon {
  width: 24px;
  height: 24px;
  background-image: var(--gemini-logo);
  background-size: cover;
  margin-right: 10px;
}

.green-dev-floaty-dialog-checkmark-icon {
  width: 20px;
  height: 20px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%234CAF50' d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");
  background-size: cover;
  margin-right: 5px;
}

.green-dev-floaty-dialog-context-text {
  font-weight: bold;
}

/* Blue card at the bottom */
.green-dev-floaty-dialog-blue-card {
  position: relative;
  background-color: #edf2fa; /* Light blue */
  border-radius: 12px;
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  border: 1px solid #d3e3fd;
}

.green-dev-floaty-dialog-node-description {
  font-size: 11px;
  font-family: monospace;
  color: #0b57d0;
  background-color: #d3e3fd;
  padding: 2px 8px;
  margin-bottom: 10px;
  border-radius: 4px;
  align-self: flex-start;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.input-row {
  display: flex;
  align-items: center;
  width: 100%;
}

.green-dev-floaty-dialog-text-field {
  flex-grow: 1;
  background-color: #fff;
  border: 1px solid #a7d9f0;
  border-radius: 20px; /* Pill shape */
  padding: 8px 16px;
  font-size: 14px;
  color: #333;
  margin-right: 8px;
  outline: none;
  transition: border-color 0.2s;
}

.green-dev-floaty-dialog-text-field:focus {
  border-color: #0b57d0;
}

.green-dev-floaty-dialog-play-button {
  width: 30px;
  height: 30px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%231976D2' d='M8 5v14l11-7z'/%3E%3C/svg%3E");
  background-size: cover;
  cursor: pointer;
  border: none;
  background-color: transparent;
  padding: 0;
}

.green-dev-floaty-minimal {
  position: absolute;
  width: 40px;
  height: 40px;
  background-color: #fff;
  background-image: var(--gemini-logo);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 32px;
  cursor: pointer;
  pointer-events: all;
  z-index: 1001;
  border-radius: 12px;
  box-shadow: 0 4px 8px rgb(0 0 0 / 20%);
  padding: 5px;
}

.green-dev-floaty-disclaimer {
  font-size: 15px;
  color: #666;
  text-align: center;
  margin-top: 8px;
  position: relative; /* For tooltip positioning */
}

.disclaimer-link {
  color: #666; /* Match text color */
  text-decoration: underline;
  cursor: pointer;
}

.disclaimer-tooltip {
  display: none;
  position: absolute;
  bottom: 100%; /* Position above */
  left: 50%;
  transform: translateX(-50%);
  width: 300px;
  padding: 12px;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 8px;
  box-shadow: 0 2px 10px rgb(0 0 0 / 20%);
  z-index: 1000;
  text-align: left;
  font-size: 16px;
  line-height: 1.4;
  color: #333;
  white-space: normal; /* Ensure text wraps */
}

.disclaimer-link:hover + .disclaimer-tooltip,
.disclaimer-tooltip:hover {
  display: block;
}

.learn-more-link {
  color: #0b57d0;
  text-decoration: none;
}

.learn-more-link:hover {
  text-decoration: underline;
}
