html {
    font-family: 'Montserrat',sans-serif !important;
    font-size: 14px;
    position: relative;
    min-height: 100%;
}

body {
    margin-bottom: 60px;
}

hr {
    opacity: 1 !important;
}

a {
    color : var(--tsm-dark-color2) !important;
}

    a:active, a:hover {
        color: var(--tsm-dark-color1) !important;
        font-weight: bold;
    }

input:focus {
    border-color: var(--tsm-dark-color2) !important;
    box-shadow: 0 0 0 0.2rem var(--tsm-dark-color2-25) !important;
    outline: none;
}

section video,
section iframe {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.nav-pills .nav-link.active, .nav-pills .show > .nav-link {
    color: var(--tsm-light-color1) !important;
    background-color: var(--tsm-dark-color1);
}

label {
    display: inline-block;
    color: var(--tsm-dark-color2) !important;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}


.btn-primary {
    background: var(--tsm-dark-color2) !important;
    color: var(--tsm-light-color1) !important;
    border-color: var(--tsm-dark-color2) !important;
}

    .btn-primary:hover {
        outline: 3px dashed var(--tsm-dark-color2);
        outline-offset: 3px;
    }

.dropdown-menu {
    padding: 10px !important;
}

.nav-link {
    padding: 10px;
    border-radius: 10px;
}

    .nav-link:hover {
        background: var(--tsm-dark-color2);
        color: var(--tsm-light-color1) !important;
        font-weight: bold;
    }

.nav-text-middle {
    position: relative; top: -5px;
}

.img-thumbnail {
    border-radius: 0.5rem; /* Matches rounded corners */
}

    .img-thumbnail:hover,
    .img-thumbnail:focus {
        outline: 3px solid var(--tsm-light-color2-25) !important;
        outline-offset: 3px;
    }


/** Site Editor */
[contenteditable="true"] {
    background-color: var(--tsm-dark-color2-25);
    outline: 1px dashed var(--tsm-dark-color2-25);
    padding: 5px;
    border-radius: 5px;
    transition: background-color 0.3s ease;
}

    [contenteditable="true"] * {
        background-color: inherit;
        outline: inherit;
    }

.editable-wrapper {
    position: relative;
    display: inline-block;
    background: var(--tsm-dark-color2-25);
    padding: 10px;
    border: 1px dashed var(--tsm-dark-color1);
}

.editable-wrapper-image, .editable-wrapper-video {
    position: relative !important;
    display: inline-block;
    background: var(--tsm-dark-color2-25);
    padding: 10px;
    border: 1px dashed var(--tsm-dark-color1);
    width: inherit;
}

.editable-wrapper-background-parent {
    height: 40px;
    background: var(--tsm-light-color2-25);
    width: 100%;
    z-index: 2;
    text-align: center;
    padding: 10px;
    color: var(--tsm-dark-color1);
}

    .editable-wrapper-background-parent:hover {
        cursor : pointer;
    }

    .editable-text, .editable-text-display {
        display: inline;
        cursor: default;
        margin-right: 50px;
    }


.edit-btn {
    position: absolute;
    top: 2rem;
    right: 0;
    font-size: 1rem;
    padding: 2px 6px;
    background: var(--tsm-light-color2-25);
    color: var(--tsm-dark-color1);
    border: none;
    border-radius: 3px;
    display: none;
    z-index: 1000;
}

.add-btn {
    font-size: 1.5rem;
    padding: 10px;
    background: var(--tsm-light-color2-25);
    color: var(--tsm-dark-color1);
    border: none;
    border-radius: 10px;
}

.toggle-btn {
    font-size: 1.5rem;
    padding: 10px;
    background: var(--tsm-light-color2-25);
    color: var(--tsm-dark-color1);
    border: none;
    border-radius: 10px;
}

    .add-btn:hover {
        cursor: pointer;
        border: 3px dashed var(--tsm-dark-color1)
    }

    .editable-wrapper:hover .edit-btn {
        display: inline-block;
    }

.youtube-border {
    border : 3px dashed red;
}

.image-picker {
    background: var(--tsm-light-color2-25);
    padding: 10px;
}

.image-picker img:hover {
    outline: 2px solid var(--tsm-light-color2-25);
    outline-offset: 2px;
}

.moveable-component {
    border: 1px var(--tsm-dark-color1) dashed;
    cursor: grab;
    border-radius: 10px;
}

    .moveable-component:active {
        background: var(--tsm-light-color2-25);
        cursor: grabbing;
    }

.icon-thumb {
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #ccc;
    border-radius: 8px;
    cursor: pointer;
    margin: 4px;
}

    .icon-thumb:hover {
        background: #f8f9fa;
    }

.json .key {
    color: brown;
}

.json .string {
    color: green;
}

.json .number {
    color: darkorange;
}

.json .boolean {
    color: blue;
}

.json .null {
    color: magenta;
}

.video-display {
    height :30vh;
}

.image-display {
    height: 50vh;
}

.btn-outline-custom {
    color: red;
    background-color: white;
    border: 1px solid var(--tsm-dark-color2);
    border-radius: 0.5rem;
    font-weight: 500;
    padding: 0.5rem 1rem;
    transition: all 0.3s;
}

    /* Hover */
    .btn-outline-custom:hover {
        background-color: var(--gp);
        color: white;
        border-color: var(--tsm-dark-color2);
        cursor: pointer;
    }

/* Selected / active */
.btn-check:checked + .btn-outline-custom {
    background-color: var(--tsm-dark-color2-25);
    color: white;
    border-color: var(--tsm-dark-color2);
}

/* Remove all focus/active outlines for toggle labels */
.btn-outline-custom:focus,
.btn-outline-custom:focus-visible,
.btn-outline-custom:active,
.btn-outline-custom:active:focus,
.btn-check:checked + .btn-outline-custom {
    outline: none !important;
    box-shadow: none !important;
}

.btn-outline-custom:focus,
.btn-outline-custom:focus-visible {
    outline: none;
    box-shadow: 0 0 0 0.2rem var(--tsm-dark-color2-25);
}