/* File: est_app/static/est_app/css/style.css */

/* ==========================================================================
   1. CSS VARIABLES & THEME CONFIG
   ========================================================================== */
:root {
    /* Brand Colors */
    --primary-blue: #0d6efd;
    --primary-dark: rgb(79, 109, 138);

    /* Text Colors */
    --navbar-text: #ffffff;
    --folder-text-color: #1b0505;
    --activity-text-color: #333333;

    /* Table Colors */
    --table-bg: rgb(255, 255, 255);
    --table-header-bg: #ffffff;
    --table-row-hover: #e3f2fd;
    --formula-row-hover: #ffec9e;
    --table-odd-row: #ffffff;
    --table-even-row: #f8f9fa;
    --selected-row-bg: #d1d2d3;
    --formula-bg: #FFFEDC;

    /* Daily Calculator Colors */
    --over-color: #df5252;
    --perfect-color: #81bd65;
    --under-color: #d7ba7d;
    /* Daily calc row colors */
    --daily-calculator-icon: #6c757d;
    --daily-calculator-bg: #353535;
    /* Daily calc form colors */
    --daily-calculator-form-bg: #d1d1d1;

    /* Special Column Colors */
    --weekend-header-bg: #D6EAF8;
    --holiday-header-bg: #F9CFA2;

    /* Icon Colors */
    --activity-color: #34972b;
    --star-color: #ffc107;

    /* Tree Control Colors */
    --folder-expand-bg: #ffffff;
    --folder-expand-border: #044e9c;
    --folder-expand-button: #044e9c;

    /* Button Colors */
    --btn-add: #0d6efd;
    --btn-save: #0d6efd;
    --btn-cancel: #6c757d;
    --btn-delete: #dc3545;
    --btn-edit: #ffc107;
    --btn-formula: #fd7e14;
    --btn-filter: #6f42c1;
    --btn-update: #007BFF;
    --btn-reset: #17a2b8;
    --btn-duplicate: #17a2b8;

    /* UI Measurements */
    --filter-height: 31px;
    --filter-font-size: 0.875rem;

    /* Misc Colors */
    --form-border: #cfcfcf;
    --body-bg: #f8f9fa;
    --card-bg: #ffffff;
    --modal-bg: #ffffff;
    --modal-text: #212529;
    --filter-controls-bg: #ffffff;

    /* Border Values */
    --border-color: #dee2e6;
    /* Main Outer Border Color */
    --border-color-light: #eeeeee;
    /* Header Boarder Color */
    --header-border-color: #dee2e6;
    --cell-border-color: #cfcfcf;


    /* Loading Row Colors - light theme */
    --loading-row-bg: rgba(240, 240, 240, 0.7);
    --loading-row-text: #333333;

    /* Loading Overlay Colors */
    --loading-overlay-bg: rgba(255, 255, 255, 0.8);

    /* Icon Colors */
    --icon-color: #BFD8FE;
}

/* Dark theme variables */
html.dark-theme {
    /* Brand Colors - keep primary colors for recognition */
    --primary-blue: #2b7bfa;
    --primary-dark: rgb(120, 150, 180);

    /* Text Colors - lighter for better contrast on dark backgrounds */
    --navbar-text: #ffffff;
    --folder-text-color: #e1e1e1;
    --activity-text-color: #d0d0d0;

    /* Table Colors - dark backgrounds, light text */
    --table-bg: #1e1e1e;
    --table-header-bg: #252525;
    --table-row-hover: #353535;
    --formula-row-hover: #ffec9e;
    --table-odd-row: #1e1e1e;
    --table-even-row: #252525;
    --selected-row-bg: #3a4556;
    --formula-bg: #FFFEDC;

    /* Adjust calculator colors for better visibility */
    --over-color: #ff6b6b;
    --perfect-color: #92d675;
    --under-color: #e8ce8e;
    /* Daily calc row colors */
    --daily-calculator-icon: #6c757d;
    --daily-calculator-bg: #353535;
    /* Daily calc form colors */
    --daily-calculator-form-bg: #353535;


    /* Special Column Colors */
    --weekend-header-bg: #D6EAF8;
    --holiday-header-bg: #F9CFA2;

    /* Icon Colors - brighter for contrast */
    --activity-color: #4db742;
    --star-color: #ffc107;

    /* Tree Control Colors */
    --folder-expand-bg: #252525;
    --folder-expand-border: #044e9c;
    --folder-expand-button: #044e9c;

    /* Button Colors - adjusted for dark theme contrast */
    --btn-add: #0d6efd;
    --btn-save: #0d6efd;
    --btn-cancel: #6c757d;
    --btn-delete: #dc3545;
    --btn-edit: #ffc107;
    --btn-formula: #fd7e14;
    --btn-filter: #6f42c1;
    --btn-update: #007BFF;
    --btn-reset: #17a2b8;
    --btn-duplicate: #17a2b8;

    /* Misc Colors - dark theme backgrounds and borders */
    --form-border: #444444;
    --body-bg: #121212;
    --card-bg: #252525;
    --modal-bg: #252525;
    --modal-text: #e1e1e1;
    --filter-controls-bg: #252525;
    /* Dark theme value for filter controls */

    /* Add these border color variables */
    --border-color: #444444;
    --border-color-light: #555555;
    --header-border-color: #666666;
    --cell-border-color: #333333;

    /* Loading Row Colors - dark theme */
    --loading-row-bg: rgba(53, 53, 53);
    --loading-row-text: #cccccc;

    /* Loading Overlay Colors */
    --loading-overlay-bg: rgba(150, 150, 150, 0.8);

    /* Icon Colors */
    --icon-color: #BFD8FE;
}

/* ==========================================================================
   2. BASE STYLES & LAYOUT
   ========================================================================== */
body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    background-color: var(--body-bg);
    color: var(--activity-text-color);
}

.content-container {
    height: calc(100vh - 56px);
    /* Assuming navbar is 56px */
    overflow: hidden;
    margin-top: 0;
    /* Remove margin */
    padding-top: 20px;
    /* Use padding instead */
    display: flex;
    flex-direction: column;
}

/* For non-tabulator pages, enable scrolling in content-container */
body:not([data-page-type="reports"]):not([data-page-type="data_entry"]):not([data-page-type="search"]) .content-container {
    overflow-y: auto;
}

/* Special handling for pages that need scrolling but don't use tabulator */
.users-page .content-container,
.holidays-page .content-container {
    overflow-y: auto !important;
}

.filter-controls {
    padding: 1rem;
    background-color: var(--filter-controls-bg);
    border-radius: 4px;
}

.form-control {
    border-color: var(--form-border);
}

.form-select {
    border-color: var(--form-border);
}

.filter-controls .form-control {
    height: var(--filter-height);
    font-size: var(--filter-font-size);
    padding: 0.25rem 0.5rem;
    min-width: 120px;
}

.filter-controls .form-select {
    height: var(--filter-height);
    font-size: var(--filter-font-size);
    padding: 0.25rem 0.5rem;
    min-width: 120px;
}

.filter-controls label {
    font-size: var(--filter-font-size);
    margin-bottom: 0.25rem;
    white-space: nowrap;
}

/* Add these styles to apply theme to modals */
.modal-content {
    background-color: var(--modal-bg);
    color: var(--modal-text);
}

.card,
.card-section {
    background-color: var(--card-bg);
}

/* Theme toggle button */
.theme-toggle {
    display: flex;
    align-items: center;
    padding: 4px 8px;
    font-size: 14px;
    color: var(--navbar-text);
    background-color: transparent;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 4px;
    cursor: pointer;
    margin-right: 15px;
    transition: 0.2s;
}

.theme-toggle:hover {
    background-color: rgba(255, 255, 255, 0.1);
}

.theme-toggle i {
    margin-right: 6px;
}

/* ==========================================================================
   3. NAVIGATION
   ========================================================================== */
.navbar {
    background-color: var(--primary-blue) !important;
}

.navbar a,
.navbar span {
    color: var(--navbar-text) !important;
    opacity: 0.7;
    /* Dim all links by default */
    transition: opacity 0.2s ease;
    /* Smooth transition */
}


.navbar-brand {
    font-weight: bold;
    color: var(--navbar-text) !important;
    padding-left: 20px;
    opacity: 1 !important;
}

.navbar span {
    color: var(--navbar-text) !important;
    opacity: 0.7;
    /* Dim all links by default */
    transition: opacity 0.2s ease;
    /* Smooth transition */
}

.navbar a:hover {
    opacity: 1;
    /* Full opacity on hover */
}

.navbar .nav-link.active {
    font-weight: bold;
    opacity: 1;
    /* Full opacity for active link */
}

.navbar .ms-auto .nav-item:first-child span,
/* Hello, username */
.navbar .ms-auto .nav-item:last-child a {
    /* Logout link */
    opacity: 1 !important;
}


/* ==========================================================================
   4. TABLE STYLES (NON-TABULATOR)
   ========================================================================== */
/*
   For regular <table> usage in user-management or holiday pages:
   .user-management-table, .public-holiday-table, etc.
*/
.user-management-table,
.public-holiday-table,
.other-page-table {
    width: 100%;
    background-color: #ffffff;
    border: none;
}

.user-management-table th,
.public-holiday-table th,
.other-page-table th {
    color: #1b1b1b;
    padding: 0.5rem;
    text-align: left;
}

.user-management-table td,
.public-holiday-table td,
.other-page-table td {
    padding: 0.5rem;
    border-bottom: 1px solid #dee2e6;
}

.user-management-table tr:hover,
.public-holiday-table tr:hover,
.other-page-table tr:hover {
    background-color: #f0f0f0;
}



/* ==========================================================================
   5. TABULATOR CONTAINER + TABLE
   ========================================================================== */
.table-container {
    flex: 1;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    margin: 0 20px;
    /* Keep horizontal margin, remove vertical */
    padding: 0 0 20px 0;
    /* Add padding at bottom instead */
}

/* Tabulator container - .tabulator is Tabulator's default root class */
.tabulator {
    border: 1px solid var(--border-color);
    border-radius: 4px;
    overflow: hidden;
    color: var(--activity-text-color) !important;
    /* Also fixing color inheritance */
    background-color: var(--table-bg) !important;
    contain: content;
    /* Use CSS containment to limit reflows */
    will-change: transform;
    /* Hardware acceleration hint */
}

.tabulator-table{
    background-color: var(--table-bg) !important;
}
.tabulator-tableholder {
    color: var(--table-bg) !important;
    scrollbar-color: var(--border-color) transparent;
}

/* Tabulator header */
.tabulator .tabulator-header {
    background-color: var(--table-header-bg);
    border-bottom: 2px solid var(--header-border-color);
}

/* Hover color for rows */
.tabulator .tabulator-row:hover {
    background-color: var(--table-row-hover) !important;
}

/* Hover color specifically for formula rows - override the default hover */
.tabulator .tabulator-row.formula-row:hover {
    background-color: var(--formula-row-hover) !important;
}

/* Apply same color for selected formula rows */
.tabulator .tabulator-row.formula-row.tabulator-selected {
    background-color: var(--formula-row-hover) !important;
}


/* Odd/Even Row color in Tabulator */
.tabulator .tabulator-row.tabulator-selectable:nth-of-type(odd) {
    background-color: var(--table-odd-row);
}

.tabulator .tabulator-row.tabulator-selectable:nth-of-type(even) {
    background-color: var(--table-even-row);
}

/* Weekend / Holiday columns in Tabulator */
.tabulator .tabulator-header .tabulator-col.weekend-column {
    background-color: var(--weekend-header-bg);
}

.tabulator .tabulator-header .tabulator-col.holiday-column {
    background-color: var(--holiday-header-bg);
}

.tabulator-menu-item {
    color: #222 !important;
}

/* Hide Tabulator Footer */
.tabulator-footer {
    display: none !important;
}

.tabulator-cell {
    border-right: 1px solid var(--cell-border-color) !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    contain: content;
    will-change: transform;
}

/* Add styling for column borders */
.tabulator .tabulator-header .tabulator-col {
    border-right: 1px solid var(--border-color-light);
}

.tabulator .tabulator-cell[tabulator-field="title"].tabulator-frozen {
    border-right: none !important;
    box-shadow: none !important;
    padding-left: calc(var(--tree-level, 0) * 20px) !important;
}

.tabulator-col[tabulator-field^="hours_"] .tabulator-col-content {
    cursor: pointer;
}

.tabulator .tabulator-cell.tabulator-frozen {
    border-right: 2px solid var(--border-color) !important;
    box-shadow: 2px 0 3px rgba(0, 0, 0, 0.1) !important;
}

.tabulator-row .tabulator-cell.tabulator-frozen.tabulator-frozen-right {
    border-left: 2px solid var(--border-color) !important;
}

/* ==========================================================================
   6. FOLDER & ACTIVITY ROW STYLES
   ========================================================================== */
/* e.g. .folder-row, .activity-row classes added in baseTable.js */
.folder-row {
    font-weight: bold;
    color: var(--folder-text-color);
}

.folder-row,
.activity-row
.daily-calculator-row {
    /* Set fixed heights when possible to reduce layout calculations */
    box-sizing: border-box;
}

.activity-row {
    font-weight: normal;
    color: var(--activity-text-color);
}

.selected-row {
    background-color: var(--selected-row-bg) !important;
}

.tabulator-row.tabulator-selected {
    background-color: var(--selected-row-bg) !important;
}

.tabulator-row.selected-row {
    background-color: var(--selected-row-bg) !important;
}

.tabulator-row {
    contain: content;
    /* Use CSS containment to limit reflows */
    will-change: transform;
    /* Hardware acceleration hint */
}


/* Activity Icon */
.activity-icon {
    color: var(--activity-color);
    font-size: 1.25em;
}

/* Folder Text */
.folder-title {
    margin-left: 0.25rem;
}

.empty-folder .folder-expander {
    cursor: default !important;
}

.formula-row {
    background-color: var(--formula-bg, #f8f9fa) !important;
    font-style: italic;
    border-bottom: 2px solid var(--formula-border, #dee2e6) !important;
}

.formula-icon {
    color: var(--formula-icon, #6c757d);
    margin-right: 0.5rem;
}

.btn-operator {
    background: none;
    border: none;
    cursor: pointer;
    font-size: 1.5rem;
    margin-right: 0.5rem;
}

.btn-operator .fa-plus-circle {
    color: green;
}

.btn-operator .fa-minus-circle {
    color: red;
}

.cut-text {
    color: #999 !important;
}

.cut-text span {
    color: #999 !important;
}

/* Keep tree controls normal */
.cut-text .tabulator-data-tree-control {
    color: initial !important;
    font-style: normal !important;
}

/* Folder Statistics - ensure headings visible in both themes */
.folder-statistics .stats-card .text-muted {
    color: var(--activity-text-color) !important;
}

/* ==========================================================================
   7. ICONS & VISUAL INDICATORS
   ========================================================================== */

.fa-file {
    color: var(--activity-color);
}

.starred-icon {
    color: var(--star-color);
}

/* ==========================================================================
   8. CONTEXT MENU
   ========================================================================== */
.context-menu {
    position: fixed;
    background: var(--card-bg);
    border: 1px solid var(--form-border);
    border-radius: 4px;
    box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
    z-index: 1000;
    min-width: 150px;
    color: var(--modal-text);
}

.menu-item {
    padding: 8px 12px;
    cursor: pointer;
    transition: background-color 0.2s;
}

.menu-item:hover {
    background-color: var(--table-row-hover);
}

.menu-item:not(:last-child) {
    border-bottom: 1px solid var(--form-border);
}

/* ==========================================================================
   9. BUTTONS
   ========================================================================== */
/* All button classes referencing the color variables above */
.btn-add,
.btn-save,
.btn-delete,
.btn-edit,
.btn-formula,
.btn-filter,
.btn-reset,
.btn-cancel,
.btn-duplicate,
.btn-update,
.btn-filter-update {
    color: #fff;
    border: none;
    font-size: 12px;
    cursor: pointer;
    padding: 0.5rem 0.5rem;
    border-radius: 4px;
}

.btn-add:focus,
.btn-save:focus,
.btn-cancel:focus,
.btn-delete:focus,
.btn-duplicate:focus,
.btn-edit:focus,
.btn-formula:focus,
.btn-filter:focus,
.btn-reset:focus,
.btn-update:focus,
.btn-filter-update:focus {
    outline: none;
    position: relative;
    z-index: 5;
    box-shadow: 0 0 0 0.25rem rgba(var(--shadow-r, 255), var(--shadow-g, 255), var(--shadow-b, 255), 0.3);
}


/* Calculate RGB shadow components based on button colors */
.btn-add,
.btn-save {
    --shadow-r: 13;
    --shadow-g: 110;
    --shadow-b: 253;
}

.btn-cancel {
    --shadow-r: 108;
    --shadow-g: 117;
    --shadow-b: 125;
}

.btn-delete {
    --shadow-r: 220;
    --shadow-g: 53;
    --shadow-b: 69;
}

.btn-duplicate,
.btn-reset {
    --shadow-r: 23;
    --shadow-g: 162;
    --shadow-b: 184;
}

.btn-edit {
    --shadow-r: 255;
    --shadow-g: 193;
    --shadow-b: 7;
}

.btn-formula {
    --shadow-r: 253;
    --shadow-g: 126;
    --shadow-b: 20;
}

.btn-filter {
    --shadow-r: 111;
    --shadow-g: 66;
    --shadow-b: 193;
}

.btn-update,
.btn-filter-update {
    --shadow-r: 0;
    --shadow-g: 123;
    --shadow-b: 255;
}

.btn-add:hover,
.btn-save:hover,
.btn-cancel:hover,
.btn-delete:hover,
.btn-duplicate:hover,
.btn-edit:hover,
.btn-formula:hover,
.btn-filter:hover,
.btn-reset:hover,
.btn-update:hover,
.btn-filter-update:hover {
    filter: brightness(1.1);
}

.btn-add {
    background-color: var(--btn-add);
}

.btn-save {
    background-color: var(--btn-save);
}

.btn-cancel {
    background-color: var(--btn-cancel);
}

.btn-delete {
    background-color: var(--btn-delete);
}


.btn-duplicate {
    background-color: var(--btn-duplicate);
}


.btn-edit {
    background-color: var(--btn-edit);
}

.btn-formula {
    background-color: var(--btn-formula);
}

.btn-filter {
    background-color: var(--btn-filter);
}

.btn-reset {
    background-color: var(--btn-reset);
}

.btn-filter-update {
    background-color: var(--btn-update);
}

.btn.w-100 {
    width: 100%;
}

/* ==========================================================================
   10. LOADING SPINNER
   ========================================================================== */
.loading-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: var(--loading-overlay-bg);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 1000;
}

.spinner {
    font-size: 50px;
    color: var(--primary-blue);
    animation: spin 1s linear infinite;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

/* ==========================================================================
   11. MISCELLANEOUS
   ========================================================================== */

.settings-icon {
    cursor: pointer;
    margin-left: 8px;
    opacity: 0.7;
    transition: opacity 0.2s;
}

.settings-icon:hover {
    opacity: 1;
}

.perm-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    display: none;
    justify-content: center;
    align-items: center;
    z-index: 9999;
}

.perm-modal-content {
    background-color: #fff;
    padding: 20px;
    border-radius: 8px;
    text-align: center;
    max-width: 400px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
    position: relative;
}

.perm-modal-footer {
    display: flex;
    justify-content: flex-end;
    padding-top: 15px;
}



/* Daily Calculator Row Styling */
.daily-calculator-row {
    background-color: var(--daily-calculator-bg, #f8f9fa) !important;
    font-weight: bold;
    color: #fff;
}

.tabulator .tabulator-row.daily-calculator-row:hover {
    background-color: var(--daily-calculator-bg, #1F1F1f) !important;
}

.tabulator .tabulator-row.daily-calculator-row.tabulator-selected {
    background-color: var(--daily-calculator-bg, #1F1F1f) !important;
}

/* Status colors for daily calculator cells */
.daily-perfect {
    color: var(--perfect-color) !important;
}

.daily-under {
    color: var(--under-color) !important;
}

.daily-over {
    color: var(--over-color) !important;
}

.text-perfect {
    color: var(--perfect-color) !important;
}

.text-under {
    color: var(--under-color) !important;
}

.text-over {
    color: var(--over-color) !important;
}

.daily-calculator-hidden {
    display: none !important;
}

/* Daily calculator icon */
.daily-calculator-icon {
    margin-right: 0.5rem;
    color: var(--daily-calculator-icon, #6c757d);
}

.daily-calculator-section h6 {
    font-weight: 600;
    color: var(--primary-color, #0d6efd);
}

.daily-calculator-section .card {
    border-radius: 8px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.card-section {
    background-color: #ffffff;
    padding: 15px;
    border-radius: 8px;
    border: 1px solid #dee2e6;
}

.card-section h6 {
    font-weight: 600;
    color: var(--primary-color, #0d6efd);
}

.outside-card {
    background-color: var(--daily-calculator-form-bg);
}

.header-selected {
    background-color: var(--primary-blue) !important;
    color: white !important;
}

.modal-dimmed .modal-content {
    opacity: 0.7;
    pointer-events: none;
}

/* Ensure modals with higher z-index appear above dimmed modals */
.modal {
    pointer-events: auto;
}


.folder-expander {
    cursor: pointer;
    color: var(--folder-expand-button, #044e9c);
    font-size: large;
}

.folder-expander:hover {
    opacity: 0.8;
}


.paste-loading-indicator {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: rgba(0, 0, 0, 0.7);
    color: white;
    padding: 15px 20px;
    border-radius: 4px;
    z-index: 10000;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.3);
}

.bulk-operation-active {
    contain: strict;
    content-visibility: auto;
    pointer-events: none;
}


.bulk-operation-active .tabulator-row {
    transition: none !important;
    animation: none !important;
}

.loading-row {
    background-color: var(--loading-row-bg) !important;
    animation: pulse 1.5s infinite;
    height: 30px !important;
    cursor: progress !important;
}

.loading-row .tabulator-cell {
    color: var(--loading-row-text) !important;
}

@keyframes pulse {
    0% {
        opacity: 0.7;
    }

    50% {
        opacity: 0.9;
    }

    100% {
        opacity: 0.7;
    }
}

/* Make sure the spinner spins smoothly */
.fa-spinner {
    display: inline-block;
    animation: spin 1s infinite linear;
    transform-origin: center;
}

@keyframes spin {
    0% {
        transform: rotate(0deg);
    }

    100% {
        transform: rotate(360deg);
    }
}

.search-highlight {
    background-color: #ffff00;
    font-weight: bold;
    border-radius: 2px;
    padding: 0 2px;
}

.italic-option {
    font-style: italic;
}

.fs-smaller {
    font-size: 0.90rem !important;
}

.fa-slash-square {
    position: relative;
}

.fa-slash-square:before {
    content: "\f0c8";
    /* Square */
}

.fa-slash-square:after {
    content: "\\";
    color: var(--folder-expand-bg);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 0.8em;
    font-weight: bold;
}

#allocated-hours-display,
#total-hours-display {
  /* Always use dark text since they're on white background */
  color: #212529 !important; 
}

.icon-building {
    background: url('../images/in_office_icon.svg') no-repeat center center;
    background-size: contain;
    display: inline-block;
    width: 1.6em;
    height: 1.6em;
    color: var(--icon-color)
}

.icon-house {
    background: url('../images/house_icon.svg') no-repeat center center;
    background-size: contain;
    display: inline-block;
    width: 1.25em;
    height: 1.25em;
    color: var(--icon-color)
}

.icon-wrapper {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    width: 24px;
    height: 24px;
    line-height: 1;
    vertical-align: middle;
}

.location-toggle:focus,
.location-toggle:active {
    outline: none !important;
    box-shadow: none !important;
    border: none !important;
}

.location-toggle {
    padding: 4px;
    border: none;
    background: transparent;
}

#activity-form .icon-wrapper {
    background-color: #007BFF;
    border-radius: 50%;
    color: #fff;
    width: 30px;
    height: 30px;
    display: flex;
    justify-content: center;
    align-items: center;
}