﻿
/*
    USAGE:

       <div class="tabs">
            <input type="radio" id="tab1" name="tab-control" checked>
            <input type="radio" id="tab2" name="tab-control">
            <input type="radio" id="tab3" name="tab-control">
            <ul class="tabs-list">
                <li>
                    <label for="tab1" role="button">
                        <i class="fa-solid fa-images"></i>
                        <span>Immagine del badge</span>
                    </label>
                </li>
                <li>
                    <label for="tab2" role="button">
                        <i class="fa-solid fa-link"></i>
                        <span>URL del badge</span>
                    </label>
                </li>
                <li>
                    <label for="tab3" role="button">
                        <i class="fa-solid fa-file-code"></i>
                        <span>Json file del badge</span>
                    </label>
                </li>
            </ul>

            <div class="slider"><div class="indicator"></div></div>
            <div class="content">
                <section>
                    <h2>Immagine</h2>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Ea dolorem sequi, quo tempore in eum obcaecati atque quibusdam officiis est dolorum minima deleniti ratione molestias numquam. Voluptas voluptates quibusdam cum?
                </section>
                <section>
                    <h2>URL</h2>
                    Lorem ipsum dolor sit amet, consectetur adipisicing elit. Autem quas adipisci a accusantium eius ut voluptatibus ad impedit nulla, ipsa qui. Quasi temporibus eos commodi aliquid impedit amet, similique nulla.
                </section>
                <section>
                    <h2>Json file</h2>
                    Lorem ipsum dolor sit amet, consectetur adipisicing elit. Quam nemo ducimus eius, magnam error quisquam sunt voluptate labore, excepturi numquam! Alias libero optio sed harum debitis! Veniam, quia in eum.
                </section>
            </div>
        </div>


*/

.tabs input[name=tab-control] {
    display: none;
}

.tabs .tab-content section h2,
.tabs ul.tabs-list li label {
    font-weight: bold;
    font-size: 18px;
    color: var(--iqcblue);
}

.tabs ul.tabs-list {
    list-style-type: none;
    padding-left: 0;
    display: flex;
    flex-direction: row;
    margin-bottom: 10px;
    justify-content: space-between;
    align-items: flex-end;
    flex-wrap: wrap;
}

    .tabs ul.tabs-list li {
        box-sizing: border-box;
        flex: 1;
        width: 25%;
        padding: 0 10px;
        text-align: center;
    }

        .tabs ul.tabs-list li label {
            transition: all 0.3s ease-in-out;
            /*color: #929daf;*/
            color: #4d5460 !important; /* Contrasto migliorato */
            padding: 5px auto;
            overflow: hidden;
            text-overflow: ellipsis;
            display: block;
            cursor: pointer;
            transition: all 0.2s ease-in-out;
            white-space: nowrap;
            -webkit-touch-callout: none;
            -webkit-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            user-select: none;
        }

            .tabs ul.tabs-list li label br {
                display: none;
            }

            .tabs ul.tabs-list li label i {
                vertical-align: central;
                margin-right: 0.2em;
                transition: all 0.2s ease-in-out;
            }

            .tabs ul.tabs-list li label:hover, .tabs ul.tabs-list li label:focus, .tabs ul.tabs-list li label:active {
                outline: 0;
                /*color: #bec5cf;*/
                color: #5a6270 !important; /* Miglior contrasto nell'hover */
            }

                .tabs ul.tabs-list li label:hover svg, .tabs ul.tabs-list li label:focus svg, .tabs ul.tabs-list li label:active svg {
                    fill: #bec5cf;
                }

.tabs .slider {
    position: relative;
    width: 25%;
    transition: all 0.33s cubic-bezier(0.38, 0.8, 0.32, 1.07);
}

    .tabs .slider .indicator {
        position: relative;
        width: 50px;
        max-width: 100%;
        margin: 0 auto;
        height: 4px;
        background: var(--iqcblue);
        border-radius: 1px;
    }
    .tabs .tab-content section {
        display: none;
        -webkit-animation-name: content;
        animation-name: content;
        -webkit-animation-direction: normal;
        animation-direction: normal;
        -webkit-animation-duration: 0.3s;
        animation-duration: 0.3s;
        -webkit-animation-timing-function: ease-in-out;
        animation-timing-function: ease-in-out;
        -webkit-animation-iteration-count: 1;
        animation-iteration-count: 1;
        line-height: 1.4;
    }

        .tabs .tab-content section h2 {
            color: var(--iqcblue);
            display: none;
        }

            .tabs .tab-content section h2::after {
                content: "";
                position: relative;
                display: block;
                width: 30px;
                height: 3px;
                background: var(--iqcblue);
                margin-top: 10px;
                left: 46%;
            }

.tabs input[name=tab-control]:nth-of-type(1):checked ~ ul.tabs-list > li:nth-child(1) > label {
    cursor: default;
    color: var(--iqcblue);
}


    .tabs input[name=tab-control]:nth-of-type(1):checked ~ ul.tabs-list > li:nth-child(1) > label svg {
        fill: var(--iqcblue);
    }

@media (max-width: 600px) {
    .tabs input[name=tab-control]:nth-of-type(1):checked ~ ul.tabs-list > li:nth-child(1) > label {
        background: #e8eaf1c4;
    }
}

.tabs input[name=tab-control]:nth-of-type(1):checked ~ .slider {
    transform: translateX(20%);
}

.tabs input[name=tab-control]:nth-of-type(1):checked ~ .tab-content > section:nth-child(1) {
    display: block;
}

.tabs input[name=tab-control]:nth-of-type(2):checked ~ ul.tabs-list > li:nth-child(2) > label {
    cursor: default;
    color: var(--iqcblue);
}

    .tabs input[name=tab-control]:nth-of-type(2):checked ~ ul.tabs-list > li:nth-child(2) > label svg {
        fill: var(--iqcblue);
    }

@media (max-width: 600px) {
    .tabs input[name=tab-control]:nth-of-type(2):checked ~ ul.tabs-list > li:nth-child(2) > label {
        background: #e8eaf1c4;
    }
}

.tabs input[name=tab-control]:nth-of-type(2):checked ~ .slider {
    transform: translateX(150%);
}

.tabs input[name=tab-control]:nth-of-type(2):checked ~ .tab-content > section:nth-child(2) {
    display: block;
}

.tabs input[name=tab-control]:nth-of-type(3):checked ~ ul.tabs-list > li:nth-child(3) > label {
    cursor: default;
    color: var(--iqcblue);
}

    .tabs input[name=tab-control]:nth-of-type(3):checked ~ ul.tabs-list > li:nth-child(3) > label svg {
        fill: var(--iqcblue);
    }

@media (max-width: 600px) {
    .tabs input[name=tab-control]:nth-of-type(3):checked ~ ul.tabs-list > li:nth-child(3) > label {
        background: #e8eaf1c4;
    }
}

.tabs input[name=tab-control]:nth-of-type(3):checked ~ .slider {
    transform: translateX(285%);
}

.tabs input[name=tab-control]:nth-of-type(3):checked ~ .tab-content > section:nth-child(3) {
    display: block;
}

@-webkit-keyframes content {
    from {
        opacity: 0;
        transform: translateY(5%);
    }

    to {
        opacity: 1;
        transform: translateY(0%);
    }
}

@keyframes content {
    from {
        opacity: 0;
        transform: translateY(5%);
    }

    to {
        opacity: 1;
        transform: translateY(0%);
    }
}

@media (max-width: 1000px) {
    .tabs ul.tabs-list li label {
        white-space: initial;
    }

        .tabs ul.tabs-list li label br {
            display: initial;
        }

        .tabs ul.tabs-list li label svg {
            height: 1.5em;
        }
}

@media (max-width: 600px) {
    .tabs ul.tabs-list li label {
        padding: 5px;
        border-radius: 5px;
    }

        .tabs ul.tabs-list li label span {
            /*display: none;*/ /*check su interferenze di questo commment*/
        }

    .tabs .slider {
        display: none;
    }

    .tabs .tab-content {
        margin-top: 20px;
    }

        .tabs .tab-content section h2 {
            display: block;
        }
}



.tabs ul.tabs-list li a{
        display:block;
        padding: 20pt 10px;

}
.tab-content{
    margin-top:20px;
}
.tabs ul.tabs-list li {
    box-sizing: border-box;
    flex: 1;
    width: 25%;
    text-align: center;
    border-top: 4px solid #f0f4fdc9;
    border-radius: 10px;
    transition: .5s ease;
    -webkit-animation: context-show 0.4s ease-in;
    animation: context-show 0.4s ease-in;
    font-size: 24px;
    font-weight: 600;
    margin: 0 5px;
}

    .tabs ul.tabs-list li.active ,
    .tabs ul.tabs-list li:hover {
        transition: 1s ease;
        background-color: #f0f4fdb3;
    }
