@font-face {
    font-family: Vazirmatn;
    src: url("assets/fonts/Vazirmatn-Regular.woff2") format("woff2");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: Vazirmatn;
    src: url("assets/fonts/Vazirmatn-Bold.woff2") format("woff2");
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    --font: Vazirmatn, sans-serif;
    --card-radius-sm: 5px;
    --card-radius-md: 10px;
    --clr-theme-toggle-text: #e0e0ed;
    --clr-theme-toggle-a-hover: #5c5c64;
    --clr-theme-toggle-bg: #44444d;
}

[data-theme='dark'] {
    --clr-bg: #181922;
    --clr-text-main: #d4d4de;
    --clr-text-a: #cfcfed;
    --clr-text-username: #4588ec;
    --clr-text-pronouns: #99c7f7;
    --clr-text-section-title: #adb0eb;
    --clr-text-section-info: #979de5;
    --clr-text-card: #e0e0ed;
    --clr-text-card-info: #d4d4de;
    --clr-text-footer: #d4d4de;
    --clr-bd-footer: rgba(212, 212, 222, 0.5);
    --clr-card-bg: rgba(26, 40, 81, 0.25);
    --clr-card-bg-hover: rgba(26, 40, 81, 0.5);
    --clr-card-bg-active: rgba(26, 40, 81, 0.75);
    --clr-card-icons: #818baa;
    --clr-card-border: #818baa;
    --clr-red: #851d22;
    --clr-green: #167533;
    --clr-yellow: #af7f3c;
    --clr-blue: #3267b5;
    --clr-gray: #808080;
}

[data-theme='light'] {
    --clr-bg: linear-gradient(45deg, #182e4d, #094089, #289dbc);
    --clr-text-main: #ededfb;
    --clr-text-a: #cfcfed;
    --clr-text-username: #ededfb;
    --clr-text-pronouns: #e0e0ed;
    --clr-text-section-title: #ededfb;
    --clr-text-section-info: #e0e0ed;
    --clr-text-card: #e0e0ed;
    --clr-text-card-info: #d4d4de;
    --clr-text-footer: #c7c7d0;
    --clr-bd-footer: rgb(199 199 208 / 50%);
    --clr-card-bg: rgb(0 0 0 / 20%);
    --clr-card-bg-hover: rgb(0 0 0 / 35%);
    --clr-card-bg-active: rgb(0 0 0 / 55%);
    --clr-card-icons: #e0e0ed;
    --clr-card-border: #e0e0ed;
    --clr-red: #b41c2b;
    --clr-green: #009f42;
    --clr-yellow: #f0ad4e;
    --clr-blue: #388cfa;
    --clr-gray: #808080;
}


html {
    margin: 0;
    height: 100%;
    background: var(--clr-bg);
    background-repeat: no-repeat;
    background-size: cover;
    background-attachment: fixed;
    display: flex;
    direction: rtl;
    flex-direction: column;
    align-items: center;
    font-family: var(--font);
}

body {
    margin: 0;
    padding: 0;
    height: fit-content;
    min-height: 100%;
    width: min(97%, 550px);
}

header,
main,
footer {
    display: flex;
    flex-direction: column;
}

a {
    color: var(--clr-text-a);
    text-decoration: none;
}

* {
    scrollbar-width: thin;
    scrollbar-color: #b3b3b3 #ffffff;
}

*::-webkit-scrollbar {
    width: 16px;
}

*::-webkit-scrollbar-track {
    background: #ffffff;
}

*::-webkit-scrollbar-thumb {
    background-color: #b3b3b3;
    border-radius: 10px;
    border: 3px solid #ffffff;
}

/* ---------- theme-toggle ---------- */
.theme-toggle {
    position: fixed;
    top: 1rem;
    right: 1rem;
    font-size: 16px;
    z-index: 1000;
    transition: opacity .3s ease-in-out;
}

.theme-toggle-dropdown {
    position: relative;
    display: inline-block;
}

.theme-toggle-dropbtn {
    font-family: var(--font);
    background-color: var(--clr-bg);
    color: var(--clr-text-main);
    padding: 10px;
    font-size: 14px;
    border: 0;
    cursor: pointer;
    border-radius: 5px;
}

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

.theme-toggle-dropdown-content {
    display: none;
    position: absolute;
    background-color: var(--clr-theme-toggle-bg);
    min-width: 160px;
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
    z-index: 1;
    border-radius: 5px;
}

.theme-toggle-dropdown-content a {
    color: var(--clr-theme-toggle-text);
    padding: 12px 16px;
    text-decoration: none;
    display: block;
    font-size: 14px;
    border-radius: 5px;
}

.theme-toggle-dropdown-content a:hover {
    background-color: var(--clr-theme-toggle-a-hover);
}

.theme-toggle-dropdown.open .theme-toggle-dropdown-content {
    display: block;
}

.theme-toggle.hidden {
    opacity: 0;
    pointer-events: none;
}

/* ---------- theme-toggle END ------- */

.username {
    color: var(--clr-text-username);
    font-size: 20px;
    font-weight: bold;
    line-height: 1.25;
    display: block;
    font-family: var(--font);
    width: 100%;
    text-align: center;
}

.pronunciation {
    color: rgb(255 255 255 / 50%);
    position: absolute;
    margin-right: 10px;
    margin-top: 6px;
    font-size: 14px;
}

.pronouns {
    font-size: 16px;
    color: var(--clr-text-pronouns);
    text-align: center;
    margin: 27px auto;
    margin-top: 3px;
    width: 90%;
    max-width: 500px;
}

.profilePicture img {
    position: relative;
    display: block;
    margin: 35px auto 20px;
    border-radius: 100%;
    outline: 2px solid #fff;
    object-fit: cover;
    width: 130px;
    height: 130px;
    box-shadow: 0 3px 0 2px rgba(0, 0, 0, 0.2);
    transition: 1s;
}

.profilePicture img:hover {
    filter: sepia(30%);
    transition: 1s;
    box-shadow: 0 5px 30px 0 rgba(0, 0, 0, 0.2);
}

.description {
    font-size: 18px;
    color: var(--clr-text-main);
    text-align: center;
    margin: 0 0 20px 0;
}

.section {
    display: flex;
    flex-direction: column;
    gap: 10px;
    width: auto;
    margin: 20px 10px;
}

.section-title {
    color: var(--clr-text-section-title);
    font-size: 20px;
    font-weight: bold;
    line-height: 1.25;
    font-family: var(--font);
    width: 100%;
    text-align: center;
    margin-bottom: -10px;
    padding-bottom: 10px;
    border-bottom: 1px dashed;
}

.section-info {
    position: relative;
    font-size: 14px;
    color: var(--clr-text-section-info);
    margin-top: 5px;
    text-align: center;
    text-decoration: none;
}

.footer {
    font-size: 14px;
    color: var(--clr-text-footer);
    text-align: center;
    margin: 10px auto 20px;
    padding-top: 5px;
    border-top: solid 1px var(--clr-bd-footer);
    width: 100%;
}

.card,
.card-dropdown-toggle,
.card-img {
    position: relative;
    background-color: var(--clr-card-bg);
    color: var(--clr-text-card);
    border: solid var(--clr-card-border) 2px;
    border-radius: var(--card-radius-md);
    font-size: 18px;
    padding: 10px;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 28px;
    align-items: center;
    transition: .3s;
}

.card i.fa,
.card i.fa-solid,
.card i.fa-brands,
.card .card-content i.fa,
.card .card-content i.fa-solid,
.card .card-content i.fa-brands,
.card-dropdown-toggle i.fa,
.card-dropdown-toggle i.fa-solid,
.card-dropdown-toggle i.fa-brands,
.card-img i.fa,
.card-img i.fa-solid,
.card-img i.fa-brands {
    color: var(--clr-card-icons);
}

.card[disabled] i.fa,
.card[disabled] i.fa-solid,
.card[disabled] i.fa-brands,
.card[disabled] .card-content i.fa,
.card[disabled] .card-content i.fa-solid,
.card[disabled] .card-content i.fa-brands,
.card-dropdown-toggle[disabled] i.fa,
.card-dropdown-toggle[disabled] i.fa-solid,
.card-dropdown-toggle[disabled] i.fa-brands,
.card-img[disabled] i.fa,
.card-img[disabled] i.fa-solid,
.card-img[disabled] i.fa-brands {
    color: var(--clr-gray);
}




.flex-row-reverse {
    flex-direction: row-reverse;
}

.inline-flex {
    display: inline-flex;
}

.grow1-center {
    flex-grow: 1;
    text-align: center;
}

.card[disabled],
.card[disabled] .card-info {
    border-color: var(--clr-gray);
    color: var(--clr-gray);
    pointer-events: none;
    position: relative;
}

.card[disabled] .card-content::after {
    content: "غیرفعال";
    margin-left: 5px;
    padding: 0 5px;
    text-decoration: none;
    color: rgba(221, 221, 221, 1);
    font-weight: bold;
    background-color: var(--clr-gray);
    border-radius: 3px;
    font-size: 13px;
}

.card-row-group {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}

.card-row-group .card {
    flex: 1;
}

.card-content {
    display: flex;
    align-items: center;
    gap: 5px;
    justify-content: center;
    flex-direction: row;
}

.section.card.yellow {
    border: solid var(--clr-yellow) 2px;
}

.section.card.yellow,
.section.card.yellow .card-info,
.section.card.yellow .card i.fa,
.section.card.yellow .card i.fa-solid,
.section.card.yellow .card i.fa-brands,
.section.card.yellow .card-content i.fa,
.section.card.yellow .card-content i.fa-solid,
.section.card.yellow .card-content i.fa-brands {
    color: var(--clr-yellow);
}

.section.card.blue {
    border: solid var(--clr-blue) 2px;
}

.section.card.blue,
.section.card.blue .card-info,
.section.card.blue .card i.fa,
.section.card.blue .card i.fa-solid,
.section.card.blue .card i.fa-brands,
.section.card.blue .card-content i.fa,
.section.card.blue .card-content i.fa-solid,
.section.card.blue .card-content i.fa-brands {
    color: var(--clr-blue);
}

.section.card.green {
    border: solid var(--clr-green) 2px;
}

.section.card.green,
.section.card.green .card-info,
.section.card.green .card i.fa,
.section.card.green .card i.fa-solid,
.section.card.green .card i.fa-brands,
.section.card.green .card-content i.fa,
.section.card.green .card-content i.fa-solid,
.section.card.green .card-content i.fa-brands {
    color: var(--clr-green);
}

.section.card.red {
    border: solid var(--clr-red) 2px;
}

.section.card.red,
.section.card.red .card-info,
.section.card.red .card i.fa,
.section.card.red .card i.fa-solid,
.section.card.red .card i.fa-brands,
.section.card.red .card-content i.fa,
.section.card.red .card-content i.fa-solid,
.section.card.red .card-content i.fa-brands {
    color: var(--clr-red);
}

.card-dropdown {
    display: none;
    flex-direction: column;
    gap: 10px;
    width: 90%;
    margin: 0 auto 10px;
}

.card-dropdown .card:last-child {
    margin-bottom: 0;
}

.card-dropdown-toggle:hover {
    background-color: rgba(0, 0, 0, 0.45);
}

.card-dropdown-toggle i,
.card-img i {
    font-size: 16px;
}

.card-img i {
    margin-left: 5px;
}

.card-dropdown-toggle .fa-angle-down {
    transition: transform .3s ease;
}

.card-dropdown-toggle.rotate .fa-angle-down {
    transform: rotate(180deg);
}

.show {
    display: flex;
}

.card-info {
    position: relative;
    font-size: 14px;
    color: var(--clr-text-card-info);
    text-align: center;
    text-decoration: none;
}

.card-img p {
    margin: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

.card-img img {
    border-radius: var(--card-radius-md);
    max-width: 300px;
    display: none;
    transition: opacity .3s ease;
}

.card-img img.visible {
    display: block;
    opacity: 1;
    margin: 8px auto 0;
}

#card-dropdown-arrow {
    transition: transform .3s ease;
}

#card-dropdown-arrow.rotate {
    transform: rotate(180deg);
}

.card:hover,
.card-dropdown-toggle:hover,
.card-img:hover {
    background-color: var(--clr-card-bg-hover);
}

.card:active,
.card-dropdown-toggle:active,
.card-img:active {
    background-color: var(--clr-card-bg-active);
}

.label-yellow {
    color: var(--clr-text-main);
    font-weight: bold;
    background-color: var(--clr-yellow);
    padding: 0 5px;
    border-radius: 3px;
    font-size: 13px;
}

.label-blue {
    color: var(--clr-text-main);
    font-weight: bold;
    background-color: var(--clr-blue);
    padding: 0 5px;
    border-radius: 3px;
    font-size: 13px;
}

.label-red {
    color: var(--clr-text-main);
    font-weight: bold;
    background-color: var(--clr-red);
    padding: 0 5px;
    border-radius: 3px;
    font-size: 13px;
}

.label-green {
    color: var(--clr-text-main);
    font-weight: bold;
    background-color: var(--clr-green);
    padding: 0 5px;
    border-radius: 3px;
    font-size: 13px;
}

.float-right {
    float: right;
}

.float-left {
    float: left;
}

.hidden {
    visibility: hidden;
}

.inline-block {
    display: inline-block;
    width: 90%;
    /* https://github.com/mmm-eskandari */
}

.min {
    width: 0;
    vertical-align: middle;
    height: 100%;
}

.pointer {
    cursor: pointer;
}

.flipped {
    -webkit-transform: scaleY(-1);
    transform: scaleY(-1) rotate(-40deg);
}

.tooltip {
    position: relative;
    display: inline-flex;
    align-items: center;
}

.tooltip-link {
    display: flex;
    align-items: center;
    gap: 5px;
}

.tooltip .tooltiptext {
    visibility: hidden;
    width: 150px;
    background-color: #555555;
    color: #ffffff;
    text-align: center;
    border-radius: 6px;
    padding: 5px;
    position: absolute;
    z-index: 1;
    bottom: 95%;
    opacity: 0;
    transition: opacity .3s;
    box-shadow: 0 4px 10px rgb(0 0 0 / 30%);
}

.tooltip .tooltiptext::after {
    content: "";
    position: absolute;
    top: 100%;
    right: 50%;
    margin-right: -5px;
    border-width: 5px;
    border-style: solid;
    border-color: #555555 transparent transparent transparent;
}

.tooltip:hover .tooltiptext {
    visibility: visible;
    opacity: 1;
}

.tooltip .tooltiptext-left {
    visibility: hidden;
    width: 150px;
    background-color: #555555;
    color: #ffffff;
    text-align: center;
    border-radius: 6px;
    padding: 5px;
    position: absolute;
    z-index: 1;
    bottom: 150%;
    right: -70px;
    margin-right: -75px;
    opacity: 0;
    transition: opacity .3s;
    direction: initial;
    box-shadow: 0 4px 10px rgb(0 0 0 / 30%);
}

.tooltip .tooltiptext-left::after {
    content: "";
    position: absolute;
    top: 100%;
    right: 90%;
    border-width: 5px;
    border-style: solid;
    border-color: #555555 transparent transparent transparent;
}

.tooltip:hover .tooltiptext-left {
    visibility: visible;
    opacity: 1;
}

#qrcode {
    width: fit-content;
    background-color: #fff;
    padding: 10px;
    margin: auto;
    border-radius: 5px;
}

#qrcode img {
    margin: auto;
    border-radius: 0;
    max-width: 290px;
}

.share-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background-color: var(--clr-card-bg);
    opacity: .9;
    color: white;
    text-decoration: none;
    padding: 6px 10px;
    font-size: 12px;
    border-radius: 5px;
    transition: 0.3s;
    margin: 5px auto;
    width: 128px;
}

.share-link:hover {
    background-color: var(--clr-card-bg-hover);
}

.mycoffee {
    transition: all 5s ease-out;
}

.mycoffee:hover {
    color: #8b2c2c;
    transition: all .3s ease-in;
}
