html, body {
    --sd-color-primary: #0073ff;
    --sd-color-primary-highlight: #0073ff;
}

body,
.diagram-font {
    font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto,
        Helvetica Neue, Helvetica, Arial, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: Inter, -apple-system, BlinkMacSystemFont, Segoe UI, Roboto,
        Helvetica Neue, Helvetica, Arial, sans-serif;
}

.wy-side-nav-search {
    background-color: #6f67ff;
}

.wy-nav-side {
    background: #0e1214;
}

.wy-menu-vertical a {
    color: #96a7b5;
}

.wy-menu-vertical a:hover {
    color: white;
}

.wy-nav-content-wrap {
    background: white;
}

.wy-nav-content {
    max-width: 1200px;
    background: white;
}

/* Custom colors */

.rst-content .admonition,
.rst-content .admonition-todo,
.rst-content .attention,
.rst-content .caution,
.rst-content .danger,
.rst-content .error,
.rst-content .hint,
.rst-content .important,
.rst-content .note,
.rst-content .seealso,
.rst-content .tip,
.rst-content .warning,
.wy-alert {
    padding: 12px;
    line-height: 24px;
    margin-bottom: 24px;
    background: #e0f0ff;
}

.rst-content .note,
.rst-content .seealso,
.rst-content .wy-alert-info.admonition,
.rst-content .wy-alert-info.admonition-todo,
.rst-content .wy-alert-info.attention,
.rst-content .wy-alert-info.caution,
.rst-content .wy-alert-info.danger,
.rst-content .wy-alert-info.error,
.rst-content .wy-alert-info.hint,
.rst-content .wy-alert-info.important,
.rst-content .wy-alert-info.tip,
.rst-content .wy-alert-info.warning,
.wy-alert.wy-alert-info {
    background: #e0f0ff;
}

html.writer-html4 .rst-content dl:not(.docutils)>dt,
html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt {
    display: table;
    margin: 6px 0;
    font-size: 90%;
    line-height: normal;
    background: #e0f0ff;
    color: #0073ff;
    border-top: 3px solid #8cc3ff;
    padding: 6px;
    position: relative;
}

.rst-content .guilabel {
    border: 1px solid #7fbbe3;
    background: #e0f0ff;
    font-size: 80%;
    font-weight: 700;
    border-radius: 4px;
    padding: 2.4px 6px;
    margin: auto 2px;
}

.rst-content .wy-alert-neutral.admonition-todo a,
.rst-content .wy-alert-neutral.admonition a,
.rst-content .wy-alert-neutral.attention a,
.rst-content .wy-alert-neutral.caution a,
.rst-content .wy-alert-neutral.danger a,
.rst-content .wy-alert-neutral.error a,
.rst-content .wy-alert-neutral.hint a,
.rst-content .wy-alert-neutral.important a,
.rst-content .wy-alert-neutral.note a,
.rst-content .wy-alert-neutral.seealso a,
.rst-content .wy-alert-neutral.tip a,
.rst-content .wy-alert-neutral.warning a,
.wy-alert.wy-alert-neutral a {
    color: #0073ff;
}

.wy-tray-container li.wy-tray-item-info {
    background: #0073ff;
}

.btn-info {
    background-color: #0073ff !important;
}

.btn-link {
    background-color: transparent !important;
    color: #0073ff;
    box-shadow: none;
    border-color: transparent !important;
}

.wy-dropdown-menu>dd>a:hover {
    background: #0073ff;
    color: #fff;
}

.wy-dropdown.wy-dropdown-bubble .wy-dropdown-menu a:hover {
    background: #0073ff;
    color: #fff;
}

.wy-inline-validate.wy-inline-validate-info .wy-input-context {
    color: #0073ff;
}

a {
    color: #0073ff;
    text-decoration: none;
    cursor: pointer;
}

.wy-text-info {
    color: #0073ff !important;
}

.wy-menu-vertical a:active {
    background-color: #0073ff;
    cursor: pointer;
    color: #fff;
}

.wy-side-nav-search {
    display: block;
    width: 300px;
    padding: 0.809em;
    margin-bottom: 0.809em;
    z-index: 200;
    background-color: #0073ff;
    text-align: center;
    color: #fcfcfc;
}

.wy-side-nav-search img {
    display: block;
    margin: auto auto 0.809em;
    height: 45px;
    width: 45px;
    background-color: #0073ff;
    padding: 5px;
    border-radius: 100%;
}

.wy-nav .wy-menu-vertical header {
    color: #0073ff;
}

.wy-nav .wy-menu-vertical a:hover {
    background-color: #0073ff;
    color: #fff;
}

.wy-nav-top {
    display: none;
    background: #0073ff;
    color: #fff;
    padding: 0.4045em 0.809em;
    position: relative;
    line-height: 50px;
    text-align: center;
    font-size: 100%;
    zoom: 1;
}

.wy-nav-top img {
    margin-right: 12px;
    height: 45px;
    width: 45px;
    background-color: #0073ff;
    padding: 5px;
    border-radius: 100%;
}

.rst-versions a {
    color: #0073ff;
    text-decoration: none;
}

.rst-content a code,
.rst-content a tt {
    color: #0073ff;
}

html.writer-html4 .rst-content dl:not(.docutils)>dt,
html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt {
    display: table;
    margin: 6px 0;
    font-size: 90%;
    line-height: normal;
    background: #e7f2fa;
    color: #0073ff;
    border-top: 3px solid #8cc3ff;
    padding: 6px;
    position: relative;
}

.rst-content .admonition-title,
.wy-alert-title {
    font-weight: 700;
    display: block;
    color: #fff;
    background: #8cc3ff;
    padding: 6px 12px;
    margin: -12px -12px 12px;
}

.rst-content .note .admonition-title,
.rst-content .note .wy-alert-title,
.rst-content .seealso .admonition-title,
.rst-content .seealso .wy-alert-title,
.rst-content .wy-alert-info.admonition-todo .admonition-title,
.rst-content .wy-alert-info.admonition-todo .wy-alert-title,
.rst-content .wy-alert-info.admonition .admonition-title,
.rst-content .wy-alert-info.admonition .wy-alert-title,
.rst-content .wy-alert-info.attention .admonition-title,
.rst-content .wy-alert-info.attention .wy-alert-title,
.rst-content .wy-alert-info.caution .admonition-title,
.rst-content .wy-alert-info.caution .wy-alert-title,
.rst-content .wy-alert-info.danger .admonition-title,
.rst-content .wy-alert-info.danger .wy-alert-title,
.rst-content .wy-alert-info.error .admonition-title,
.rst-content .wy-alert-info.error .wy-alert-title,
.rst-content .wy-alert-info.hint .admonition-title,
.rst-content .wy-alert-info.hint .wy-alert-title,
.rst-content .wy-alert-info.important .admonition-title,
.rst-content .wy-alert-info.important .wy-alert-title,
.rst-content .wy-alert-info.tip .admonition-title,
.rst-content .wy-alert-info.tip .wy-alert-title,
.rst-content .wy-alert-info.warning .admonition-title,
.rst-content .wy-alert-info.warning .wy-alert-title,
.rst-content .wy-alert.wy-alert-info .admonition-title,
.wy-alert.wy-alert-info .rst-content .admonition-title,
.wy-alert.wy-alert-info .wy-alert-title {
    background: #8cc3ff;
}

html.writer-html4 .rst-content dl:not(.docutils)>dt,
html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt {
    display: table;
    margin: 6px 0;
    font-size: 90%;
    line-height: normal;
    background: #e7f2fa;
    color: #0073ff;
    border-top: 3px solid #8cc3ff;
    padding: 6px;
    position: relative;
}

html.writer-html4 .rst-content dl:not(.docutils)>dt:before,
html.writer-html5 .rst-content dl[class]:not(.option-list):not(.field-list):not(.footnote):not(.citation):not(.glossary):not(.simple)>dt:before {
    color: #8cc3ff;
}


.hs-button {
    background-color: rgb(143, 90, 255);
    padding: 6px 12px;
    width: fit-content;
    height: 34px;
    color: white;
    border: none;
    border-radius: 4px;
    font-size: 14px;
}

.hs-button:hover {
    background-color: rgb(88, 38, 193);
}

.hs_error_rollup {
    display: none;
}

.hs-error-msgs {
    font-size: 11px;
    line-height: 16px;
    font-weight: 400;
    letter-spacing: -0.005em;
    align-self: flex-start;
    height: 16px;
    margin-top: 4px;
    margin-bottom: 4px;
    position: absolute;
    bottom: 34px;
}

.hs-error-msg {
    color: rgb(220, 19, 44);
}

.beta {
    background: #7a41ce;
    color: white;
    border-radius: 4px;
    padding: 4px 6px;
    margin-left: 4px;
    font-size: 10px;
    line-height: 8px;
    letter-spacing: 1px;
    height: 16px !important;
}

table.custom-table {
    border-collapse: collapse;
    min-width: 400px;
}

table.custom-table td,
table.custom-table th {
    padding: 10px;
    border: 1px solid #dddddd;
    vertical-align: middle;
}

table.custom-table thead tr {
    background-color: #3170f4;
    color: #ffffff;
    text-align: center;
}

table.custom-table tbody td {
    text-align: left;
}

table.custom-table tbody tr:nth-of-type(even) {
    background-color: #f6f8fA;
}


/* .full-screen-diagram {
  width: 100%;
  max-width: 100%;
  height: auto;
  z-index: -999;
  cursor: pointer;
} */

.class-diagram-container {
    position: relative;
    perspective: 1000px;
    overflow: hidden;
    width: 100%;
    max-width: 100vw;
    transition: all 0.3s ease-in-out, all 0.3s ease-in-out;
}


.class-diagram-container:hover {
    background-color: rgba(0, 0, 0, 0.8);
    z-index: 9999;
    transform: scale(1.35) translateX(-100px);
}


blockquote {
    background-color: #f4f9ff;
    /* light blue background */
    border-left: none;
    padding: 1em;
    font-family: sans-serif;
    color: #333;
    margin: 0 !important;
    margin-bottom: 24px !important;
}

/* Header bar */
blockquote::before {
    content: 'ℹ️ Info:';
    display: block;
    background-color: #b9dafd;
    /* light blue bar */
    color: #111;
    font-weight: bold;
    padding: 0.25em;
    margin: -1em -1em 1em -1em;
    font-size: 1.05em;
    letter-spacing: 0.5px;
}

/* Title text in bold, e.g., "Note:" */
blockquote>strong {
    font-weight: bold;
    display: inline-block;
    margin-bottom: 0.25em;
    font-size: 1em;
}

.wy-table-responsive table td,
.wy-table-responsive table th {
    text-wrap-mode: wrap;
}

.rst-content table.docutils td, .wy-table td {
    vertical-align: top !important;
}
