:root {
    /* Darkmode colors */
    --clr-white: #ffffff;
    --clr-white-80: #ffffffc6;
    --clr-white-40: #ffffff73;
    --clr-white-20: #ffffff31;
    --clr-white-10: #ffffff0e;

    --clr-black: #000000;
    --clr-black-80: #000000b2;
    --clr-black-70: #0000009b;
    --clr-black-40: #00000081;
    --clr-black-30: #0000003b;
    --clr-black-20: #00000030;
    --clr-black-10: #0000000e;

    --clr-red: #ff3224;
    --clr-red-sheer: #fe11001e;
    --clr-yellow: #EDAF5E;
    --clr-yellow-sheer: #edaf5e26;
    --clr-blue: #8EBFFF;
    --clr-blue-sheer: #8ebfff20;
    --clr-green: #85c0a3;

    --clr-dark-background: #0C0F12;
    --clr-dark-background-40: #0c0f126b;
    --clr-dark-background-20: #0c0f1227;
    --clr-medium-background: #13181F;
    --clr-light-background: #20252C;
    --clr-light-background-40: #20252c6c;
    --clr-light-background-20: #20252ca1;

	--clr-text-input-outline: #30353B;
    --clr-pb-img-border: #b6bdc56e;
    --clr-code-block-top-bar: #20252C;

	--clr-code-font: #daddf3;
	--clr-link: #4F94FF;

    --clr-spinner-1: #ffffff;
    --clr-spinner-2: #aef8ff;
    --clr-spinner-3: #a8beff;
    --clr-spinner-4: #ffcfa5;
    --clr-spinner-5: #ffb0aa;
    --clr-spinner-6: #f0a2ff;
    --clr-spinner-7: #ff98f8;

    --clr-paywall-effect-1: #1B1B1B;
    --clr-paywall-effect-2: #1B1B1B;
    --clr-paywall-effect-3: #110431;
    --clr-paywall-effect-4: #2A0101;

    /* lightmode colors */
    --clrlight-black: #000000d1;
    --clrlight-red: #cf4a4a;
    --clrlight-red-sheer: #f66e6e20;
    --clrlight-yellow: #7f4b07;
    --clrlight-yellow-sheer: #edaf5e42;
    --clrlight-blue: #073c82;
    --clrlight-blue-sheer: #4195ff1f;
    --clrlight-green: #82a493;

    --clrlight-prompt-button-outline: #CED5E1;
    --clrlight-dark-background: #DAE1ED;
    --clrlight-dark-background-40: #ced5e167;
    --clrlight-dark-background-20: #ced5e122;
    --clrlight-medium-background: #F1F3F7;
    --clrlight-light-background: #F9FCFF;
    --clrlight-light-background-40: #f9fcff54;
    --clrlight-light-background-20: #ffffff31;

	--clrlight-text-input-outline: #bebebe;
    --clrlight-pb-img-border: #84848459;
    --clrlight-code-block-top-bar: #e4eaf0;

	--clrlight-code-font: #262734;
	--clrlight-link: #0066ff;

    --clrlight-spinner-1: #383838;
    --clrlight-spinner-2: #4D7FFF;
    --clrlight-spinner-3: #00E5FF;
    --clrlight-spinner-4: #FFA500;
    --clrlight-spinner-5: #FF5555;
    --clrlight-spinner-6: #FF00E5;
    --clrlight-spinner-7: #B300FF;

    --clrlight-paywall-effect-1: #e0e0e0;
    --clrlight-paywall-effect-2: #cdcccc;
    --clrlight-paywall-effect-3: #e4daf8;
    --clrlight-paywall-effect-4: #fde0e0;
    

    /* Setting variables to lightmode */
    --clr-var-primary-background: var(--clrlight-medium-background);
    --clr-var-light-background: var(--clrlight-light-background);
    --clr-var-light-background-40: var(--clrlight-light-background-40);
    --clr-var-light-background-20: var(--clrlight-light-background-20);
    --clr-var-dark-background: var(--clrlight-dark-background);
    --clr-var-dark-background-40: var(--clrlight-dark-background-40);
    --clr-var-dark-background-20: var(--clrlight-dark-background-20);
    --clr-var-side-nav-border: #CED5E1;

    --clr-var-text: var(--clrlight-black);
    --clr-var-text-80: var(--clr-black-80);
    --clr-var-text-40: var(--clr-black-40);
    --clr-var-text-20: var(--clr-black-20);
    --clr-var-highlight-text: var(--clr-white);
    --clr-var-highlight-text-80: var(--clr-white-80);
    --clr-var-highlight-text-40: var(--clr-white-40);

    --clr-var-red-alert: var(--clrlight-red);
    --clr-var-red-sheer: var(--clrlight-red-sheer);
    --clr-var-yellow-warning: var(--clrlight-yellow);
    --clr-var-yellow-sheer: var(--clrlight-yellow-sheer);
    --clr-var-blue-notification: var(--clrlight-blue);
    --clr-var-blue-sheer: var(--clrlight-blue-sheer);
    --clr-var-green-alert: var(--clrlight-green);
    --clr-var-green-static: #28a745;
    --clr-var-faint-background: rgba(0, 0, 0, 0.03);
    
    --clr-var-text-input-outline: var(--clrlight-text-input-outline);
    --clr-var-prompt-button-outline: var(--clrlight-prompt-button-outline);
    --clr-var-pb-img-border: var(--clrlight-prompt-button-outline);
    --clr-var-hr: var(--clr-black-10);
    --clr-var-button-hover: var(--clr-black-10);
    --clr-var-math-highlight: var(--clr-white);
    --clr-var-toggle-button-outline: var(--clr-black-10);
    --clr-var-code-block-top-bar: var(--clrlight-code-block-top-bar);

    --clr-var-code-font: var(--clrlight-code-font);
    --clr-var-link: var(--clrlight-link);
    --clr-var-box-shadow: var(--clr-black-20);

    --clr-var-spinner-1: var(--clrlight-spinner-1);
    --clr-var-spinner-2: var(--clrlight-spinner-2);
    --clr-var-spinner-3: var(--clrlight-spinner-3);
    --clr-var-spinner-4: var(--clrlight-spinner-4);
    --clr-var-spinner-5: var(--clrlight-spinner-5);
    --clr-var-spinner-6: var(--clrlight-spinner-6);
    --clr-var-spinner-7: var(--clrlight-spinner-7);

    --clr-var-paywall-effect-1: var(--clrlight-paywall-effect-1);
    --clr-var-paywall-effect-2: var(--clrlight-paywall-effect-2);
    --clr-var-paywall-effect-3: var(--clrlight-paywall-effect-3);
    --clr-var-paywall-effect-4: var(--clrlight-paywall-effect-4);

    /* font sizes */
    --fs-h1: 1.3rem;
    --fs-h2: 1.1rem;
    --fs-h3: 1.05rem;
    --fs-h4: 1rem;
    --fs-p: 1rem;
    --fs-button: 1rem;
    --fs-code: 0.9rem;
    --fs-mini: 0.8rem;
    --fs-onboarding-header: 1.3rem;
    --fs-paywall-price: 1.5rem;
    --fs-huge: 4rem;

    /*font weights */
	--fw-h1: 500;
	--fw-h2: 500;
	--fw-h3: 500;
	--fw-h4: 500;
	--fw-p: 300;
	--fw-button: 500;
	--fw-nav: 700;
	--fw-very-light: 200;
    --fw-light: 300;
    --fw-normal: 400;
    --fw-semi: 500;
    --fw-bold: 600;
    --fw-heavy: 800;

    /* border opacity */
    --border-opacity: 0.6;

    --ff: -apple-system, BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Ubuntu";
    --ff-code: 'SF Mono', Monaco, 'Cascadia Code', 'Roboto Mono', Consolas, 'Courier New', monospace;
}
.icon-button img {
    filter: invert(0.7) !important;
    transition: all 0.2s ease;
}
.icon-button.no-invert img {
    filter: invert(0) !important;
    transition: all 0.2s ease;
}
.icon-button:disabled img {
    filter: brightness(0.7) !important;
}
img.color-flip-100 {
    filter: invert(1) !important;
    transition: all 0.2s ease;
}
img.color-flip-80 {
    filter: invert(0.7) !important;
    transition: all 0.2s ease;
}
img.color-flip-60 {
    filter: invert(0.5) !important;
    transition: all 0.2s ease;
}
img.color-flip-30 {
    filter: invert(0.3) !important;
    transition: all 0.2s ease;
}
/* check if they prefer darkmode */
@media (prefers-color-scheme: dark) {
    :root {
    --clr-var-primary-background: var(--clr-medium-background);
    --clr-var-light-background: var(--clr-light-background);
    --clr-var-light-background-40: var(--clr-light-background-40);
    --clr-var-light-background-20: var(--clr-light-background-20);
    --clr-var-dark-background: var(--clr-dark-background);
    --clr-var-dark-background-40: var(--clr-dark-background-40);
    --clr-var-dark-background-20: var(--clr-dark-background-20);
    --clr-var-side-nav-border: #30353B;

    --clr-var-text: var(--clr-white);
    --clr-var-text-80: var(--clr-white-80);
    --clr-var-text-40: var(--clr-white-40);
    --clr-var-text-20: var(--clr-white-20);
    --clr-var-highlight-text: var(--clr-black);
    --clr-var-highlight-text-80: var(--clr-black-80);
    --clr-var-highlight-text-40: var(--clr-black-40);

    --clr-var-red-alert: var(--clr-red);
    --clr-var-red-sheer: var(--clr-red-sheer);
    --clr-var-yellow-warning: var(--clr-yellow);
    --clr-var-yellow-sheer: var(--clr-yellow-sheer);
    --clr-var-blue-notification: var(--clr-blue);
    --clr-var-blue-sheer: var(--clr-blue-sheer);
    --clr-var-green-alert: var(--clr-green);
    --clr-var-faint-background: rgba(255, 255, 255, 0.03);

    --clr-var-text-input-outline: var(--clr-text-input-outline);
    --clr-var-prompt-button-outline: var(--clr-text-input-outline);
    --clr-var-pb-img-border: var(--clr-text-input-outline);
    --clr-var-hr: var(--clr-white-10);
    --clr-var-button-hover: var(--clr-white-10);
    --clr-var-math-highlight: var(--clr-light-background-20);
    --clr-var-toggle-button-outline: var(--clr-black);
    --clr-var-code-block-top-bar: var(--clr-code-block-top-bar);

    --clr-var-code-font: var(--clr-code-font);
    --clr-var-link: var(--clr-link);
    --clr-var-box-shadow: var(--clr-black-70);

    --clr-var-spinner-1: var(--clr-spinner-1);
    --clr-var-spinner-2: var(--clr-spinner-2);
    --clr-var-spinner-3: var(--clr-spinner-3);
    --clr-var-spinner-4: var(--clr-spinner-4);
    --clr-var-spinner-5: var(--clr-spinner-5);
    --clr-var-spinner-6: var(--clr-spinner-6);
    --clr-var-spinner-7: var(--clr-spinner-7);

    --clr-var-paywall-effect-1: var(--clr-paywall-effect-1);
    --clr-var-paywall-effect-2: var(--clr-paywall-effect-2);
    --clr-var-paywall-effect-3: var(--clr-paywall-effect-3);
    --clr-var-paywall-effect-4: var(--clr-paywall-effect-4);
    }
    .icon-button img {
        filter: brightness(0.8) !important;
    }
    .icon-button:disabled img {
        filter: brightness(0.5) !important;
    }
    img.color-flip-100 {
        filter: brightness(1) !important;
    }
    img.color-flip-80 {
        filter: brightness(0.8) !important;
    }
    img.color-flip-60 {
        filter: brightness(0.6) !important;
    }
    img.color-flip-30 {
        filter: brightness(0.3) !important;
    }
    .chevron-button img {
        filter: invert(1) !important;
    }
    .chevron-button.secondary img {
        filter: invert(0) !important;
    }
    .chevron-button.text img {
        filter: invert(0) !important;
    }
    .chevron-button.text.back img {
        filter: invert(0.2) !important;
    }
}

.blank-space {
    height: 400px;
}

h1 {
	color: var( --clr-var-text);
	font-size: var( --fs-h1);
	font-weight: var(--fw-h1);
	margin: 5px 0px 5px 0px;
}

h2 {
	color: var( --clr-var-text-80);
	font-size: var(--fs-h2);
	font-weight: var(--fw-h2);
	margin: 0px;
}

h3 {
	color: var( --clr-var-text);
	font-size: var(--fs-h3);
	font-weight: var(--fw-h3);
	margin: 0px;
}

p {
	color: var( --clr-var-text-80);
	font-size: var( --fs-p);
	font-weight: var(--fw-p);
	margin-top: 10px;
}

.bold {
    font-weight: var(--fw-semi); /* Makes the text bold */
}

a {
    text-decoration: none;
    color: inherit; 
}
a.underline {
    text-decoration: underline;
}
/* remove all default styling from buttons */
button {
    background: none;
    border: none;
    padding: 0;
    font: inherit;
    cursor: pointer;
    outline: inherit;
}

.hidden {
    display: none !important;
}


html {
	font-family: -apple-system, BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Ubuntu";
	/* color: var( --clr-var-highlight-text); */
	-webkit-appearance: none;
	overflow-x: hidden;  
}

body {
	background: var(--clr-var-primary-background);
    margin: 0;
    padding: 0;
	display: block;
}
/* Global scrollbar styling */
* {
    scrollbar-width: thin;  /* For Firefox */
    scrollbar-color: var(--clr-var-text-40) transparent;  /* For Firefox */
}

/* For Webkit browsers like Chrome, Safari */
::-webkit-scrollbar {
    width: 4px;  /* Width of vertical scrollbar */
    height: 4px;  /* Height of horizontal scrollbar */
}

::-webkit-scrollbar-track {
    background: transparent;  /* Color of the tracking area */
}

::-webkit-scrollbar-thumb {
    background-color: var(--clr-var-text-40);  /* Color of the scroll thumb */
    border-radius: 4px;  /* Rounded corners of the scroll thumb */
    border: 2px solid var(--clr-var-dark-background-20);  
}

::-webkit-scrollbar-thumb:hover {
    background-color: var(--clr-var-text-80);  /* Color of the scroll thumb on hover */
}

.main-container {
    display: flex;
    height: 100%;
}
.content-container {
    /* width: calc(100% - 310px); 
    position: relative;*/
    /* height: 100%; */
}
.block-content {
    display: block;
    height: 100%;
    width: 100%;
}


/* --- Heroicon --- */
.heroicon {
    width: 16px;
    height: 16px;
    
    /* default color of icons: 80% black in light mode */
    color: rgba(0, 0, 0, 0.8); 
    transition: color 0.2s ease;
}
.heroicon.color-mode-100 {
    /* 100% black in light mode */
    color: rgba(0, 0, 0, 1); 
    transition: color 0.2s ease;
}
.heroicon.color-mode-40 {
    /* faded icons: 40% black in light mode */
    color: rgba(0, 0, 0, 0.4); 
    transition: color 0.2s ease;
}
/* Dark mode support for heroicons */
@media (prefers-color-scheme: dark) {
    .heroicon {
        /* 80% white in dark mode */
        color: rgba(255, 255, 255, 0.8); 
    }
    .heroicon.color-mode-100 {
        /* 100% white in dark mode */
        color: rgba(255, 255, 255, 1); 
    }
    .heroicon.color-mode-40 {
        /* 40% white in dark mode */
        color: rgba(255, 255, 255, 0.4); 
    }
}
/* Size variants for heroicons */
.heroicon-sm {
    width: 14px;
    height: 14px;
}
.heroicon-lg {
    width: 20px;
    height: 20px;
}
.heroicon-xl {
    width: 24px;
    height: 24px;
}
.heroicon-xxl {
    width: 30px;
    height: 30px;
}
/* ------------------------------------------ ERROR PAGES --------------------------------------------------- */
/* NOTE: these are also used on the unsubscribe page */
.error-page-container {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    overflow: auto;
}
.error-page-center-container {
    width: calc(100% - 2rem);
    max-width: 400px;
    margin-top: 10%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    row-gap: 2rem;
    /* padding: 20px; */
}
.error-page-center-container.unsubscribe {
    max-width: 440px;
}
.error-page-message-container {
    width: calc(100% - 2rem);
    display: flex;
    flex-direction: column;
    align-items: center;
}
.error-page-message-container p,
.error-page-message-container h3 {
    text-align: center;
}
.unsubscribe-form {
    display: flex;
    flex-direction: row;
    column-gap: 40px;
    margin: 30px 0;
}
/* ------------------------------------------ MODALS  ----------------------- */
.modal::backdrop {
    background-color: rgba(0,0,0,0.4);
}
dialog::backdrop {
    position: fixed;
    inset: 0px;
    background: rgba(0, 0, 0, 0.4);
}

.modal {
    border: none;
    border-radius: 10px; 
    padding: 0px; /* to ensure taps on modal body don't close the modal */
    max-height: 80%;
    background-color: var(--clr-var-light-background);
    width: calc(100dvw - 3rem);
    max-width: 900px;
    /* min-height: 380px; */
    color: var(--clr-var-text-80);
}
.modal.small {
    width: calc(100dvw - 3rem);
    max-width: 600px;
}
.modal-buttons {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    width: 100%;
    margin-top: 40px;
    column-gap: 15px;
}
.disconnect-modal-padding {
    padding: 20px;
}
.react-modal-padding {
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    position: relative;
}
.react-modal-padding.overflow-hidden {
    overflow: hidden;
}
.react-modal-content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    column-gap: 15px;
} 
.react-modal-options {
    display: flex;
    flex-direction: row;
    margin-bottom: 10px;
    row-gap: 10px;
    justify-content: flex-start;
} 
.react-modal-section-header {
    padding: 3px 0px 3px 5px;
    display: flex;
    flex-direction: row;
    align-items: center;
    column-gap: 10px;
    border-radius: 8px;
    width: 115px;
}
.react-modal-section-header.active {
    background-color: var(--clr-var-primary-background);
}
.react-modal-section-header img {
    height: 1.2rem;
}
.react-modal-section-header h1 {
    font-size: var(--fs-p);
}
.react-modal-header h1 {
    color: var(--clr-var-text);
}
.react-modal-message {}
.react-modal-message p {
    color: var(--clr-var-text-80);
    line-height: 1.6em;
}
.react-modal-buttons {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    column-gap: 20px;
}

.react-close-button {
    color: var(--clr-var-text-40);
    float: right;
    font-size: 28px;
    /* font-weight: bold; */
}

/* account settings modal */
.react-modal-bottom-buttons {
    display: flex;
    flex-direction: row;
    justify-content: flex-end;
    width: 100%;
    margin-top: 40px;
    column-gap: 10px;
}
.react-modal-content hr {
    margin: 15px 0px;
    border-radius: 5px;
    border: 1px solid var(--clr-var-hr);
    width: 100%;
}
.react-modal-body {
    flex: 1;
    width: 100%;
    margin-top: 10px;
}
.react-modal-as-element.confirmation-message {
    flex-direction: column;
}
.react-modal-as-element {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin: 0px;
    row-gap: 10px;
}
.react-modal-as-element p {
    margin: 0;
}
.react-modal-as-element p.element {
    color: var(--clr-var-text);
    font-weight: var(--fw-normal);
}
.react-modal-as-element.os-select {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin-bottom: 20px;
}
.react-modal-as-element.os-select p {
    margin: 0;
    padding: 0;
}
.react-modal-element-with-tt {
    display: flex;
    flex-direction: row;
    align-items: center;
    column-gap: 5px;
}
.confirmation-message-text {
    display: flex;
    flex-direction: column;
    row-gap: 20px;
}
.confirmation-message-buttons {
    display: flex;
    flex-direction: column;
    justify-content: space-between;;
    column-gap: 20px;
    row-gap: 30px;
    align-items: flex-start;
}
.temporary-no-delete {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    margin: 25px 0px;
    row-gap: 10px;
}
/* ------------------------------------------ BUTTON STYLING ----------------------- */

.stacked-buttons {
    display: flex;
    flex-direction: column;
    row-gap: 15px;
}

.profile-picture {
    display: block;
    border-radius: 10px;
}
    .profile-picture img {
        object-fit: cover;
    }
	.profile-picture.small img {
        height: 35px;
        width: 35px;
        border-radius: 20px;
    }


.button {
    background-color: var(--clr-var-text);
    color: var(--clr-var-highlight-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    /* font-family: var(--ff); */
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 13px;
    height: 35px;
    width: 120px;
    transition: all 0.3s ease;
}
.button.long {
    width: 220px;
}
.button.variable-width {
    width: fit-content;
    padding: 0px 10px;
}
.button.full-width {
    width: 100%;
}
.button p {
    color: var(--clr-var-highlight-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
}
.button span {
    color: var(--clr-var-highlight-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
}
input.button.loading-button:disabled {
    color: var(--clr-var-dark-background-20);
    z-index: 1;
}
.button:disabled {
    filter: opacity(0.3) !important;
    color: var(--clr-var-highlight-text-40);
    
}
input.button.loading-button { 
    position: relative;
    z-index: 10;
}
/* ------- small button */
.button.small {
    height: 30px;
    width: fit-content;
    padding: 0px 10px;
    border-radius: 10px;
}
.button.small-width {
    width: fit-content;
    padding: 0px 10px;
    border-radius: 10px;
}
.button.small.full-width {
    width: -webkit-fill-available;
}
.button.small img {
    height: 1rem;
}
.button.small.pressed {
    filter: opacity(0.7);
}

/* ------- secondary button */
.button.secondary {
    background-color: transparent;
    border: 1px solid var(--clr-var-text-20);
    color: var(--clr-var-text);
}
.button.secondary.artifact {
    height: 27px;
    display: flex;
    flex-direction: row;
    column-gap: 5px;
}
.button.secondary.no-shrink {
    width: fit-content;
    padding: 0px 10px;
}
.button.secondary p {
    color: var(--clr-var-text);
}
.button.secondary span {
    color: var(--clr-var-text);
}
.button.secondary.artifact span {
    color: var(--clr-var-text-80);
    font-size: var(--fs-mini);
}
.button.secondary span.light {
    color: var(--clr-var-text-80);
    font-weight: var(--fw-p);
}
.button.secondary:hover {
    background-color: var(--clr-var-button-hover);
    filter: opacity(1);
}
/* ------- text button */
.button.text {
    background-color: transparent;
    color: var(--clr-var-text);
    column-gap: 5px;
    font-weight: var(--fw-normal);
    cursor: pointer;
    white-space: nowrap;
    width: fit-content;
    min-width: 120px;
}
.button.text p {
    color: var(--clr-var-text);
}
.button.text span {
    color: var(--clr-var-text);
}
.button.text img {
    width: 1rem;
}
.button:hover {
    filter: opacity(0.7);
    cursor: pointer;
}

/* ------- delete button */
.button.delete {
    background-color: var(--clr-var-red-sheer);
    /* border: 2px solid var(--clr-var-text-40); */
    color: var(--clr-var-red-alert) ;
}
.button.delete span {
    color: var(--clr-var-red-alert);
}
.button.delete:hover {
    background-color: var(--clr-var-button-hover);
    filter: opacity(0.7);
}
/* SERIOUS FINAL DELETE BUTTON */
.alert-button {
    background-color: var(--clr-var-red-alert);
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 13px;
    height: 35px;
    padding: 0px 10px;
    /* width: 120px; */
}
.alert-button span {
    color: var(--clr-var-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
}

/* ------- buttons w chevron -----------*/
.chevron-button {
    background-color: var(--clr-var-text);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0px;
    border-radius: 13px;
    height: 35px;
    width: 120px;
    cursor: pointer;
}
.chevron-button.no-shrink {
    width: fit-content;
    min-width: 140px;
    column-gap: 5px;
}
.chevron-button p {
    color: var(--clr-var-highlight-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
    padding: 0px 0px 0px 11px;
}
.chevron-button span {
    color: var(--clr-var-highlight-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
    padding: 0px 0px 0px 11px;
    cursor: pointer;
}
.chevron-button img {
    height: 18px !important;
    margin: 0px 7px 0px 0px;
    /* invert the color */
    filter: invert(0);
    rotate: 90deg;
}
.chevron-button.back img {
    rotate: 270deg;
}
.chevron-button:hover {
    /* background-color: var(--clr-var-button-hover); */
    filter: opacity(0.7);
}

/* ------- secondary button */
.chevron-button.secondary {
    background-color: transparent;
    border: 2px solid var(--clr-var-text-40);
}
.chevron-button.secondary p {
    color: var(--clr-var-text);
}
.chevron-button.secondary img {
    filter: invert(1);
}
.chevron-button.secondary:hover {
    background-color: var(--clr-var-button-hover);
    /* filter: brightness(0.7); */
}

/* ------- text button w chevron */
.chevron-button.text {
    background-color: transparent;

    width: fit-content;
    /* min-width: 140px; */
    column-gap: 10px;
}
.chevron-button.text span {
    color: var(--clr-var-text);
}
.chevron-button.text img {
    filter: invert(1);
}
.chevron-button.text:hover {
    background-color: var(--clr-var-button-hover);
    filter: brightness(1);
}

/* for a text button "< Back" */
.chevron-button.text.back {
    margin: 0;
    padding: 0;
    column-gap: 0;
    transition: all 0.2s;
}
.chevron-button.text.back span {
    margin: 0;
    padding: 0;
    color: var(--clr-var-text-80);
    font-weight: var(--fw-normal);
}
.chevron-button.text.back img {
    filter: invert(0.8);
}
.chevron-button.text.back:hover {
    background-color: transparent;
    filter: brightness(0.8);
}

/* ------- icon that is a button (icon button) */
.icon-button {
    border-radius: 2px;
    padding: 4px;
    margin: 0px;
    cursor: pointer;

    display: flex;
    flex-direction: row;
    align-items: center;
    position: relative;
}
.icon-button img {
    height: 1rem;
    filter: brightness(0.8);
}
.icon-button.big img {
    height: 28px;
    filter: brightness(0.8);
}
.icon-button.big {
    height: fit-content;
}
.icon-button.small img {
    height: 1rem;
    filter: brightness(0.8);
}
.icon-button.refreshing img {
    animation: reverse-spin 0.6s ease-in-out infinite;
}
.grey-out img {
    opacity: 0.4;
}
@keyframes reverse-spin {
    from { transform: rotate(0deg); }
    to { transform: rotate(-360deg); }
}
.icon-button:active {
    background: var(--clr-var-dark-background);
}
.icon-button:disabled {
    /* filter: opacity(0.5) !important; */
    cursor: default !important;
}
.icon-button:hover {
    background-color: var(--clr-var-button-hover);
    border-radius: 3px;
}
.icon-button::after {
    content: attr(data-tooltip);
    position: absolute;
    /* bottom: -26px;
    left: -2px; */

    left: 50%;
    bottom: -26px;
    transform: translateX(-50%);
    max-width: 90vw;
    z-index: 20;

    background-color: var(--clr-var-dark-background);
    color: var(--clr-var-text-80);
    padding: 5px 10px;
    border-radius: 4px;
    font-size: var(--fs-code);
    white-space: nowrap;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.1s ease, visibility 0.1s ease;
    transition-delay: 0.3s;
}
.icon-button.shift-tt-right::after {
    left: 220% !important; 
}
.icon-button.shift-tt-right-zero::after {
    left: 0 !important; 
    transform: translateX(0%) !important;;
}
.icon-button.shift-tt-left::after {
    left: -105% !important; 
}
.icon-button.shift-tt-left-zero::after {
    left: unset !important;
    right: -82.2px;
}
.icon-button.code-block-button::after {
    left: -105% !important; 
}
.icon-button.img-block-button::after {}
.icon-button.small-width::after {
    /* This is for the user modal tool tip */
    bottom: -65px !important;
    right: -71px !important;
    left: auto !important;
    white-space: wrap;
    width: 190px;

}
.icon-button:hover::after {
    opacity: 1 !important;
    visibility: visible;
}
.icon-button:not([data-tooltip])::after,
.icon-button[data-tooltip=""]::after {
    display: none;
}
@keyframes pulseButton {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.2);
    }
    100% {
        transform: scale(1);
    }
}

.icon-button.no-sources-selected {
    animation: pulseButton 2s ease-in-out infinite;
}

/* Stop animation on hover */
.icon-button.no-sources-selected:hover {
    animation: none;
}
/* --- Back button --- */
.back-button {
    display: flex;
    flex-direction: row;
    align-items: center;
    column-gap: 5px;
    margin: 10px 0px 20px 0px;
    padding: 2px;
    border-radius: 5px;
    width: fit-content;
}
.back-button:hover {
    background-color: var(--clr-var-button-hover);
}
.back-button p {
    color: var(--clr-var-text);
    font-size: var(--fs-button);
    font-weight: var(--fw-normal);
    margin: 0px;
}
.back-button img {
    height: 16px;
    filter: invert(1);
}
/* ------------------------------------------ Generic STYLING ----------------------- */
img.chevron-right {
    transform: rotate(90deg);
}
img.chevron-left {
    transform: rotate(-90deg);
}
img.chevron-down {
    transform: rotate(180deg);
}
.tool-tip {
    position: relative;
    display: flex;
    align-items: center;
}

.tool-tip img {
    width: 1rem;
}

.tool-tip::after {
    content: attr(data-tooltip);
    position: absolute;
    z-index: 100;
    /* Remove fixed left positioning */
    /* left: 0px; */
    background-color: var(--clr-var-dark-background);
    color: var(--clr-var-text-80);
    padding: 5px 10px;
    border-radius: 4px;
    font-size: var(--fs-code);
    width: max-content;
    white-space: normal; /* Allow wrapping when max-width is hit */
    word-wrap: break-word;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.1s ease, visibility 0.1s ease;
    transition-delay: 0.3s;
    
    /* Add these properties for dynamic positioning */
    top: 20px;
    left: -330%;
    transform: translateX(-50%);

    max-width: 200px;
    /* width: fit-content; */
}

/* modifies all tool tips within form-title class, mostly within connect pages */
.form-title-with-tool-tip .tool-tip:after {
    left: 50%;
}

.tool-tip:hover::after {
    opacity: 1;
    visibility: visible;
}
.tool-tip.no-collapse::after {
    left: 170%;
}

.tool-tip:not([data-tooltip])::after,
.tool-tip[data-tooltip=""]::after {
    display: none;
}

.huge-text {
    font-size: var(--fs-huge);
}
/* ------------------------------------------ TOGGLE Styling */
/* The switch - the box around the toggle */
.switch {
    position: relative;
    display: inline-block;
    width: 50px;
    height: 20px;
}
.switch.small {
    width: 40px;
}
    
/* Hide default HTML checkbox */
.switch input {
    opacity: 0;
    width: 40px;
    height: 0;
}
    
/* The toggle */
.toggle {
    position: absolute;
    cursor: pointer;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: #D9D9D9;
    -webkit-transition: .4s;
    transition: .4s;
    border: 1px solid var(--clr-var-toggle-button-outline);
    padding: 10px;
    width: 18px;
}
    
.toggle:before {
    position: absolute;
    content: "";
    height: 16px;
    width: 16px;
    top: 2px;
    left: 2px;
    right: 0;
    bottom: 0;
    background-color: #FFFFFF;
    -webkit-transition: .4s;
    transition: .4s;
    box-shadow: 2px 2px 5px rgba(2, 1, 4, 0.25);
}
.toggle.disabled {
    background-color: #3D3D3D;
}    
.toggle.disabled:before {
    background-color: #4D4D4D;
}
    
input:checked + .toggle {
    background-color: #40C48A;
}
    
input:focus + .toggle {
    box-shadow: 0 0 1px #ffffff92;
}
    
input:checked + .toggle:before {
    -webkit-transform: translateX(26px);
    -ms-transform: translateX(26px);
    transform: translateX(18px);
    box-shadow: -2px 2px 5px rgba(2, 1, 4, 0.25);
}
    
/* Rounded toggles */
.toggle.round {
    border-radius: 15px;
}
    
.toggle.round:before {
    border-radius: 50%;
}

/* error message styling */

.kb-error-message,
.error-message {
    background-color: var(--clr-var-red-sheer);
    padding: 10px;
    border-radius: 8px;
    display: flex;
    /* border: 2px solid var(--clr-var-red-alert); */
    flex-direction: column;
    row-gap: 8px;
    width: -webkit-fill-available;
}
.error-message.auto-width {
    width: auto;
}
.kb-error-message p,
.kb-error-message li,
.kb-error-message span,
.error-message p,
.error-message li,
.error-message span {
    color: var(--clr-var-red-alert);
    font-size: var(--fs-code);
    font-weight: var(--fw-semi);
    margin: 0px;
}
.kb-error-message ul,
.error-message ul {
    margin: 0px;
}

.warning-message {
    background-color: var(--clr-var-yellow-sheer);
    padding: 10px;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    row-gap: 8px;
    width: -webkit-fill-available;
}
.warning-message.auto-width {
    width: auto;
}
.warning-message p,
.warning-message span {
    color: var(--clr-var-yellow-warning);
    font-size: var(--fs-code);
    font-weight: var(--fw-semi);
    margin: 0px;
    display: block !important;
}
.warning-message.mini-font p,
.warning-message.mini-font span {
    font-size: var(--fs-mini);
}
.warning-message li {
    color: var(--clr-var-yellow-warning);
    font-size: var(--fs-code);
    font-weight: var(--fw-semi);
    /* margin: 0px; */
    display: list-item !important;
}
.warning-message ul {
    margin: 0;
    padding: 0 20px !important;
    list-style-type: disc !important; 
}
/* ------------------------------------------ Generic STYLING ----------------------- */
.page-spacing {
    padding: 20px;
}
.z-index-10 {
    z-index: 10;
}
.django-messages-container {
    position: fixed; /* Keep messages fixed on screen */
    top: 10px; /* Position from the top */
    left: 50%; /* Center horizontally */
    transform: translateX(-50%); /* Adjust horizontal centering */
    z-index: 1050; /* Ensure it overlays most content (adjust as needed) */
    display: flex;
    flex-direction: column; /* Stack messages vertically */
    align-items: center; /* Center messages horizontally within the container */
    width: auto; /* Adjust width automatically */
    max-width: 80%; /* Prevent it from becoming too wide */
    pointer-events: none; /* Allow clicks to pass through the container */
}
.alert {
    padding: 10px 20px; /* Adjusted padding */
    margin: 5px 0; /* Vertical margin between alerts */
    border-radius: 4px;
    /* opacity: 1; */ /* Opacity is handled by the auto-hide script if enabled */
    transition: opacity 0.3s ease-in-out;
    pointer-events: auto; /* Make individual alerts clickable/hoverable */
    box-shadow: 0 2px 5px rgba(0,0,0,0.2); /* Add a subtle shadow */
    width: fit-content; /* Make alert width fit its content */
    max-width: 100%; /* Ensure alert doesn't exceed container width */
}
.alert.db-sharing-modal {
    width: fit-content;
    position: absolute;
    bottom: 15px;
}
.alert-success {
    background-color: #d4edda;
    color: #155724;
    border: 1px solid #c3e6cb;
}
.alert-success p,
.alert-success h3,
.alert-success span {
    color: #155724;
}
.alert-error {
    background-color: #f8d7da;
    color: #721c24;
    border: 1px solid #f5c6cb;
}
.alert-error p,
.alert-error h3,
.alert-error span {
    color: #721c24;
}
/* ------------------------------------------ PAGE: Connections STYLING ----------------------- */
.connections-page-header {
    margin: 0px 0px 30px 0px;
    display: flex;
    flex-direction: row;
    row-gap: 10px;
    width: calc(100% - 2rem);
    max-width: 66rem;
    justify-content: space-between;
    align-items: center;
}
.page-header h1 {}
.page-nav {
    display: flex;
    flex-direction: row;
    column-gap: 20px;
}
.page-nav h3 {
    color: var(--clr-var-text-40);
    font-size: var(--fs-h3);
    font-weight: var(--fw-h3);
    margin: 0px;
    position: relative;
}
.page-nav h3.active {
    color: var(--clr-var-text);
}
.page-nav h3.active::after {
    content: ""; /* Required for the pseudo-element */
    position: absolute;
    left: 0;
    right: 0;
    bottom: -5px; /* Adjust to your desired spacing */
    height: 3px; /* Height of the border */
    border-radius: 3px;
    background: linear-gradient(69deg, rgba(171, 248, 255, var(--border-opacity)), rgba(175, 193, 247, var(--border-opacity)), rgba(231, 179, 205, var(--border-opacity)), rgba(242, 165, 237, var(--border-opacity)), rgba(252, 188, 153, var(--border-opacity)), rgba(246, 152, 134, var(--border-opacity)), rgba(158, 128, 145, var(--border-opacity)));
}

/* Container for scroll indicators and items */
.scroll-container {
    position: relative;
    width: 100%;
    margin: 0 -1rem; /* Negative margin to counteract padding */
    padding: 0 1rem; /* Add padding to maintain spacing */
    margin: 0 -0.5rem;
    padding: 0 0.1rem;
}

/* Scroll indicators */
.scroll-indicator {
    position: absolute;
    top: 0;
    bottom: 1rem;
    width: 50px; /* Made smaller */
    pointer-events: none;
    z-index: 10;
    opacity: 0;
    transition: opacity 0.3s ease;
}

.scroll-indicator.left {
    left: 0;
    background: linear-gradient(to right, var(--clr-var-primary-background) 20%, transparent);
}

.scroll-indicator.right {
    right: 0;
    background: linear-gradient(to left, var(--clr-var-primary-background) 20%, transparent);
}

/* Show right indicator when content is scrollable */
.connection-category-items.is-scrollable ~ .scroll-indicator.right {
    opacity: 1;
}

/* Show left indicator when scrolled */
.connection-category-items.can-scroll-left ~ .scroll-indicator.left {
    opacity: 1;
}

/* Ensure connection containers don't grow but stay consistent */
.connection-category-items .connection-container {
    flex: 0 0 280px;
    min-width: 280px;
    scroll-snap-align: start;
}

/* Add padding to the last item specifically */
.connection-category-items .connection-container:last-child {
    margin-right: 2rem; /* Extra space after the last item */
}

.formatting-guidelines-for-sheets-container {
    width: calc(100% - 2rem);
}

/* ------------------------------------------ Login page --------------------------------------------------- */
.login-relative-container {
    height: 100dvh;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}
.login-modal-container {
    background-color: var(--clr-white);
    border-radius: 10px;
    width: 280px;
}
.login-modal-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 10px;
    padding: 40px 20px 40px 20px;
}
.login-modal-body h1 {
    color: var(--clr-black);
}
.login-modal-body p {
    color: var(--clr-black);
    text-align: center;
}
.login-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: var(--clr-black);
    border-radius: 10px;
    height: 70px;
    width: 70px;
    margin: 0px 0px 20px 0px;
}
.login-logo img {
    height: 50px;
}
.login-buttons-container {}
.login-buttons-container.mcp-auth-buttons {
    gap: 10px;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 1rem;
}
.login-button {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    border: 1px solid var(--clr-black-30);
    border-radius: 3px;
    width: 230px;
    height: 40px;

    color: var(--clr-black);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
}
.login-button.centered {
    justify-content: center;
}
.login-button.deny {
    justify-content: center;
    color: var(--clr-red);
}
.login-button img {
    height: 15px;
    margin: 10px;
}
.login-button p {
    color: var(--clr-black);
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
    margin: 0px;
}
.login-divider {
    display: flex;
    align-items: center;
    text-align: center;
    margin: 5px 0;
    width: 100%;
}
.login-divider span {
    color: var(--clr-black-70);
}
.login-divider hr {
    width: 40%;
    border-style: solid;
    border-radius: 5px;
    color: var(--clr-black-20);
}
.login-divider.mcp-auth hr {
    width: 100%;
}

.magic-link-form {
    display: flex;
    width: 100%;
    margin-bottom: 20px;
    flex-direction: column;
    align-items: center;
}
.magic-link-form-group {
    margin-bottom: 15px;
}
input.magic-link-form-item {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: flex-start;
    border: 1px solid var(--clr-black-30);
    border-radius: 3px;
    width: 210px;
    height: 40px;
    padding: 0 10px;

    font-family: -apple-system, BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Ubuntu";
    font-size: var(--fs-button);
    font-weight: var(--fw-button);
}
input.magic-link-form-item::placeholder {
    color: var(--clr-black-40);
}
input.magic-link-form-item:focus {
    border: 1px solid var(--clr-black-40);
}
.magic-link-button {
    background-color: var(--clr-black);
    color: var(--clr-white);
    justify-content: center;
}
.login-info {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.login-info p {
    margin: 0;
    text-align: center;
}
.login-temp-password-buttons {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* ------------------------------------------ PAGE: Form styling --------------------------------------------------- */
/* was called config modal */
.cm-modal-content {
    padding: 20px;
    color: var(--clr-var-text-80);
}
.add-connection-container {
    padding: 20px;
    background-color: var(--clr-var-light-background);
    color: var(--clr-var-text-80);
    border-radius: 12px;
    width: calc(100% - 3rem);
    max-width: 900px;
    margin: 0 0 2rem 0;
}

.cm-button-container {
    display: flex;
    flex-direction: row-reverse;
    column-gap: 10px;
}
h1.cm-title {
    margin: 0px 0px 20px 0px;
    color: var(--clr-var-text);
}
h1.cm-title span.grey {
    color: var(--clr-var-text-80);
}
h3.cm-form-label {
    margin: 0px 0px 10px 0px;
    color: var(--clr-var-text-80);
}
form.cm-form {
    display: flex;
    flex-direction: column;
    row-gap: 25px;
    margin: 0 0 1.5rem 0;
}
.cm-toggle-container {
    display: flex;
    flex-direction: row;
    align-items: center;
    margin: 10px 0px;
}
.cm-toggle-container p {
    margin: 0px;
}
span.cm-form-disclaimer {
    font-size: var(--fs-mini);
    color: var(--clr-var-text-40);
}
p.form-text {
    margin: 10px 0px;
    color: var(--clr-var-text-80);
}
p.form-warning {
    margin: 10px 0px;
}
.form-group {
    display: flex;
    flex-direction: column;
    row-gap: 10px;

}
.form-item {
    display: flex;
    flex-direction: column;
    row-gap: 8px;
    margin: 0 0 10px 0;
}
.form-item p {
    margin: 5px 0;
    color: var(--clr-var-text);
}
.form-item.switch {
    display: flex;
    flex-direction: row;
    row-gap: 5px;
    margin: 0 0 15px 0;
}
.form-title-with-tool-tip {
    display: flex;
    flex-direction: row;
    column-gap: 8px;
}
.form-title-with-tool-tip.link {
    column-gap: 0px;
}
.form-title-with-tool-tip.link a {
    /* text-decoration: underline; */
    color: var(--clr-var-link);
    margin: 0 0 0 4px;
    cursor: pointer;
}
.form-title {
    display: flex;
    flex-direction: column;
    row-gap: 1rem;
    margin: 0 0 1rem 0;
}
.form-title h2 {
    color: var(--clr-var-text);
    font-weight: var(--fw-normal);
}
.form-title h3 {
    color: var(--clr-var-text-80);
    font-weight: var(--fw-normal);
}
.form-group select {
    display: block;
    background-color: var(--clr-var-dark-background);
    border: 1px solid var(--clr-var-text-input-outline);
    color: var(--clr-var-text-80);
    border-radius: 8px;
    padding: 10px;
    margin: 0px;
    width: 100%;
    max-width: 500px;
    
    /* Remove default arrow */
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    
    /* Add custom chevron arrow */
    background-image: url("data:image/svg+xml;utf8,<svg fill='%23848484' height='24' viewBox='0 0 24 24' width='24' xmlns='http://www.w3.org/2000/svg'><path d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 10px top 50%;
    background-size: 20px;
    padding-right: 30px;
}


.form-group select:focus {
    outline: none;
    border-color: var(--clr-var-text);
}

/* Style the options within the select */
.form-group select option {
    color: var(--clr-var-text);
    background-color: var(--clr-var-dark-background);
    padding: 10px;
}

/* Style for when the dropdown is open */
.form-group select::-ms-expand {
    display: none;
}

.form-group select:hover {
    border-color: var(--clr-var-text-80);
}
.form-group textarea {
    margin: 10px 0px 0px 0px !important;
    border: 1px solid var(--clr-var-text-input-outline);
}
.form-group input {
    background-color: var(--clr-var-dark-background);
    border: 1px solid var(--clr-var-text-input-outline);
    border-radius: 8px;
    padding: 10px;
    color: var(--clr-var-text-80);
    font-family: -apple-system, BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Ubuntu";
    margin: 10px 0px 0px 0px;
    max-width: 500px;
}
.form-group input::placeholder {
    color: var(--clr-var-text-20);
}
.form-group.no-spacing input {
    margin: 0px 0px 0px 0px;
}
.form-group.postgres-connection-form-builder input {
    margin: 0px 0px 10px 0px;
}
.form-group input:focus {
    outline: none;
    text-decoration: none;
}
.form-group input.variable-width {
    width: calc(100% - 2rem);
}
a.link-primary {
    /* color: var(--clr-var-link);
    font-weight: var(--fw-semi); */
    text-decoration: underline;
}
a.link-primary:focus {
    text-decoration: none;
    outline: none;
}
a.link-highlight {
    color: var(--clr-var-link);
    font-weight: var(--fw-semi);
}

.cr-form-group {
    display: flex;
    flex-direction: column;
    row-gap: 0.8rem;
}
.form-group textarea {
    background-color: var(--clr-var-dark-background);
    border: 1px solid transparent;
    border-radius: 8px;
    padding: 10px;
    color: var(--clr-var-text-80);
    font-family: -apple-system, BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Ubuntu";
    margin: 0px;
    /* max-width: 500px; */
    width: calc(100% - 20px);
    height: 5rem;
    resize: none;
    border: 1px solid var(--clr-var-text-input-outline);
}
.form-group textarea::placeholder {
    color: var(--clr-var-text-20);
}
.form-group textarea {
    outline: none;
    text-decoration: none;
}

/* ------------------------------------------ base page ----------------------------------------------- */
.base-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow: auto;
    padding: 0 0 3rem 0;
}
.base-header {
    display: flex;
    flex-direction: column;
    width: calc(100% - 2rem);
    max-width: 84rem;
    row-gap: 10px;
    border-bottom: 2px solid var(--clr-var-hr);
    border-radius: 2px;
}
.base-nav {
    /* padding: 10px 0; */
    border-bottom: 2px solid var(--clr-var-hr);
    border-radius: 2px;
    display: flex;
    flex-direction: row;
    gap: 30px;
    position: relative;
}
.base-nav a {
    color: var(--clr-var-text-40);
    border-bottom: 2px solid transparent;  
    border-radius: 2px;
    padding: 10px 5px;
    margin-bottom: -2px; /* This aligns the link border with the nav border */
    position: relative; /* Needed for z-index to work */
    z-index: 1; /* Place it above the nav border */
}
.base-nav a.active {
    color: var(--clr-var-text);  
    border-bottom: 2px solid var(--clr-var-text);  
}
.base-content {
    display: flex;
    flex-direction: column;
    width: calc(100% - 2rem);
    max-width: 84rem;
    row-gap: 10px;
}
.base-subheader {}
.search-container {
    display: flex;
    flex-direction: row;
    gap: 1rem;
}
.search-container input {
    background-color: var(--clr-var-dark-background);
    border: 1px solid var(--clr-var-text-input-outline);
    border-radius: 8px;
    color: var(--clr-var-text-80);
    font-family: -apple-system, BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue","Ubuntu";
    margin: 0px;
    width: -webkit-fill-available;
    overflow-y: auto;
    padding: 4px 8px;
    font-size: var(--fs-mini);
}
.search-container input:empty:before {
    content: attr(data-placeholder);
    color: var(--clr-var-text-20);
}

.search-container input:focus {
    outline: none;
    text-decoration: none;
}
.base-table-container {
    overflow: auto;
}
table.base-table {
    width: 100%;
    border-collapse: collapse;
    border-radius: 8px;
    overflow: auto;
}
.base-table thead {
    color: var(--clr-var-text-40);
}
.base-table th {
    padding: 10px 8px;
    text-align: left;
    font-weight: var(--fw-p);
}
.base-table tbody {
    color: var(--clr-var-text-80);
    font-weight: var(--fw-p);
}
.base-table tr {
    border-bottom: 2px solid var(--clr-var-hr);
}
.base-table td {
    padding: 10px 8px;
    align-content: start;
}
/* .base-table td a {
    color: var(--clr-var-link);
    text-decoration: none;
} */
.base-table td a:hover {
    color: var(--clr-var-text);
}
.base-table-row-name {
    max-width: 130px;
    word-wrap: break-word;
}
.base-table-actions {
    display: flex;
    flex-direction: row;
    gap: 8px;
    justify-content: flex-end;
}
/* ------------ base details page ------------ */
.base-details-header {
    margin: 30px 0px;
    display: flex;
    flex-direction: row;
    row-gap: 10px;
    width: calc(100% - 2rem);
    max-width: 80rem;
    justify-content: space-between;
    align-items: center;
}
.add-connection-container.base-details {
    display: flex;
    flex-direction: column;
    row-gap: 1rem;
    width: calc(100% - 2.5rem);
    max-width: 80rem;
    /* to give some space at the bottom */
    margin: 0 0 3rem 0;
}
.base-details-header-actions {
    display: flex;
    flex-direction: row;
    gap: 1rem;
}
.base-form-checkbox-container {
    align-content: start;
}
/* ------------ base edit form page ------------ */
.base-edit-form-actions {
    display: flex;
    justify-content: flex-end;
    gap: 1rem;   
}
.base-form-select-all-container {
    margin: 1rem 0 0 8px;
}
span.base-form-toggle-label {
    padding: 0 0 0 8px;
}
.base-form-header {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
}
.collapse-toggle {
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--clr-var-link);
    font-size: var(--fs-code);
    font-weight: var(--fw-normal);
}
.collapse-toggle:hover {
    filter: opacity(0.8);
}
/* ------------------------------------------ RESPONSIVE Styling --------------------------------------------------- */
.mobile-hidden {
    display: none;
}


/* wherever dvh isn't supported */
@supports not (height: 100dvh) {
    .content {
        height: 100vh;
    }
    
    .side-nav {
        height: 100vh;
    }

    .login-relative-container {
        height: 100vh;
    }
    .onboarding-container {
        height: 100vh;
    }
}
/* wherever dvw isn't supported */
@supports not (width: 100dvw) {
    .modal {
        width: calc(100vw - 3rem);
    }
    .modal.small {
        width: calc(100vw - 3rem);
    }
}

/* for people who don't like animations */ 
@media(prefers-reduced-motion) {
	.hidden {
		transition: none;
	}
}

/* smallest phone */
@media (min-width: 370px) {
	/* ---------------------------- CONNECTION LIST ----------------------- */
    .chevron-button {
        width: 140px;
    }
    .button {
        width: 140px;
    }
	
}

@media (min-width: 400px) {
}
@media (min-width: 460px) {
    /* ---------------------------- General tool-tips ----------------------- */
    .tool-tip::after {
        left: 170%;
    }
    /* ---------------------------- Account settings modal ----------------------- */
    .confirmation-message-buttons {
        flex-direction: row;
    }
}

@media (min-width: 540px) {
    /* ---------------------------- Account settings modal ----------------------- */
    .react-modal-as-element {
        flex-direction: row;
    }
    
}

@media (min-width: 580px) {
    /* ---------------------------- User settings modal ----------------------- */
    .react-modal-content {
        flex-direction: row;
    }
    .react-modal-options {
        flex-direction: column;
    }
    .react-modal-section-header {
        width: 140px;
    }
}

@media (min-width: 640px) {
}

/* styles for tablet */
@media (min-width: 710px) {
    /* ---------------------------- CONNECTIONS PAGE ----------------------- */
    .connection-list {
        justify-content: flex-start;
    }
}

/* styles for tablet */
@media (min-width: 768px) {
}

/* styles for desktop */
@media (min-width: 991px) {
}


/* styles for xl desktop */
@media (min-width: 1330px) {}