/* ==================================
   COMPONENTS
   ================================== */

button, .button{
    transition: 0.2s;
    background-color: var(--color-primary);
    border-radius: var(--border-radius);
    padding: 4px 32px 4px 32px;
    color: var(--color-bg) !important;
    font-weight: var(--fw-semibold) !important;
    border: none;
    cursor: pointer;
    display: inline-block;
    text-align: center;
    justify-content: center;
    align-items: center;
    gap: var(--space-xs);
}

.button-secondary{
    transition: 0.2s;
    border-radius: var(--border-radius);
    padding: 4px 32px 4px 32px;
    background-color: var(--color-secondary);
    color: var(--color-text) !important;
    font-weight: var(--fw-semibold) !important;
    border: none;
    cursor: pointer;
    display: inline-block;
    text-align: center;
    justify-content: center;
    align-items: center;
    gap: var(--space-xs);
}

.button-third{
    transition: 0.2s;
    background-color: var(--color-bg);
    border-radius: var(--border-radius);
    padding: 4px 32px 4px 32px;
    color: var(--color-primary);
    font-weight: var(--fw-semibold);
    border: 1px solid var(--color-primary) !important;
    cursor: pointer;
    display: inline-block;
    text-align: center;
    justify-content: center;
    align-items: center;
    gap: var(--space-xs);
}

/* Scroll-to-top button */
.scroll-to-top {
    position: fixed;
    right: calc(var(--space-l) + env(safe-area-inset-right, 0px));
    bottom: calc(var(--space-l) + env(safe-area-inset-bottom, 0px));
    width: 48px;
    height: 48px;
    padding: 0;
    border-radius: 50%;
    background-color: var(--color-primary);
    color: var(--color-secondary);
    font-size: var(--fs-h4);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 6px 20px rgba(var(--color-primary-rgb), 0.35);
    cursor: pointer;
    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;
    z-index: 9999;
    transition: opacity 180ms ease, transform 180ms ease, background-color 120ms ease;
}

.scroll-to-top:hover {
    background-color: rgba(var(--color-primary-rgb), 0.9);
}

.scroll-to-top.is-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

@media (prefers-reduced-motion: reduce) {
    .scroll-to-top {
        transition: none;
    }
}

.button-white{
    transition: 0.2s;
    background-color: var(--color-bg);
    border-radius: var(--border-radius);
    padding: 4px 32px 4px 32px;
    color: var(--color-text) !important;
    font-weight: var(--fw-semibold) !important;
    border: none;
    cursor: pointer;
    display: inline-block;
    text-align: center;
    justify-content: center;
    align-items: center;
    gap: var(--space-xs);
}

button:hover, .button:hover, .button-secondary:hover, .button-third:hover, .button-white:hover{
    transition: 0.2s;
    text-decoration: none;
    transform: scale(1.03);
}

button:active:hover, .button:active:hover, .button-secondary:active:hover, .button-third:active:hover, .button-white:active:hover{
    transition: 0.2s;
    transform: scale(0.98);
}

.shadow{
    box-shadow: rgba(149, 157, 165, 0.2) 0px 8px 24px;
}

.box-container{
    transition: 0.2s;
    border-radius: 8px;
    border: var(--border-primary);
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
    padding: 1.5rem;
}

.box-container:hover{
    transition: 0.2s;
    transform: scale(1.02);
}

.box-container h3{
    margin-top: 1rem;
}

.box-container svg{
    border-radius: 4px;
    padding: 8px;
    background-color: var(--color-primary-bg-20);
}

.background-primary{
    background: var(--color-text);
    color: var(--color-bg);
}

.container-3-spaced{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 300px), 1fr));
    gap: var(--space-xxl);
    padding-top: var(--space-section);
}

.container-2-spaced{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-xxl);
    padding-top: var(--space-section);
}

.container-1-2-spaced{
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: var(--space-xxl);
    padding-top: var(--space-section);
}

.container-2-spaced > :last-child {
    justify-self: end;
    align-self: start;
}

.point-container{
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: var(--space-xs);
}

.point-container > *{
    margin: 0;
}

.point-container h3{
    font-size: var(--fs-h4);
}

.point-container p{
    color: var(--color-text-muted);
}

.circle{
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: var(--color-primary);
    width: 60px;
    height: 60px;
    border-radius: 50%;
    color: var(--color-bg);
    font-weight: var(--fw-semibold);
    font-size: var(--fs-h3);
}

.before-introduction{
    margin-top: var(--space-m);
    margin-bottom: var(--space-m);
}

.intro-container .tag{
    margin-bottom: var(--space-m);
}

.tag{
    display: inline-block;
    margin: 0;
    background-color: var(--color-secondary);
    border-radius: 32px;
    padding: 2px 16px 2px 16px;
    font-weight: var(--fw-semibold);
    color: var(--text-color) !important;
    font-size: var(--fs-base) !important;
}

.tag-2{
    display: inline-block;
    margin: 0;
    background-color: var(--color-primary-bg-20);
    border-radius: 32px;
    padding: 2px 16px 2px 16px;
    font-weight: var(--fw-semibold);
    color: var(--color-primary) !important;
    font-size: var(--fs-base) !important;
}

.expert-container p{
    font-size: var(--fs-base);
}

.expert-container .tag, .tag-2{
    font-size: var(--fs-small) !important;
}

.expertise-list{
    padding-left: 0;
    display: flex;
    gap: var(--space-m);
}

.expert-name{
   font-size: var(--fs-h4);
}

.expert-header{
    display: flex;
    align-items: center;
    gap: var(--space-l);
}

.expert-header img{
    height: 100px;
}


/* ========= MEDIA QUERIES ========= */

/* Extra small devices (phones) */
@media (max-width: 480px) {}

/* Small devices (large phones) */
@media (max-width: 640px) {}

/* Tablets */
@media (max-width: 768px) {
    .container-2-spaced {
        grid-template-columns: 1fr;
    }

    .container-2-spaced > :last-child {
        justify-self: start;
        align-self: start;
    }

    .container-1-2-spaced{
        grid-template-columns: 1fr;
    }
}

/* Small laptops */
@media (max-width: 1024px) {
    .container-3-spaced{
        grid-template-columns: 1fr;
    }
}
