/* App Category Styles - CSS File */

/* Category Icons Grid Styles */
.emoji-category-grid {
    display: flex;
    flex-wrap: wrap;
    border-top: 2px solid #444;
    padding-top: 10px;
    max-width: 100%;
    font-family: sans-serif;
}

.emoji-category-item {
    width: 50%;
    padding: 8px 0;
    font-size: 1.1rem;
}

@media (max-width: 600px) {
    .emoji-category-item {
        width: 100%;
        font-weight: bold;
    }
}

.emoji-category-heading {
    font-weight: bold;
    font-size: 1.2rem;
    padding-bottom: 5px;
}

/* Single Category View Styles */
.category-title {
    font-size: 2rem;
    font-weight: 700;
    color: rgb(95, 99, 104);
    margin-bottom: 1rem;
    position: relative;
    padding: 1rem;
}

@media (max-width: 768px) {
    .category-title {
        font-size: 1.5rem;
    }
}

.fUEl2e {
    display: flex;
    gap: var(--gap-width);
    flex-wrap: wrap;
}

.app-list-grid {
    margin-left: 24px !important;
    margin-right: 24px !important;
}

@media screen and (min-width:600px) {
    .app-list-grid {
        margin-left: 48px !important;
        margin-right: 48px !important;
    }    
}

@media screen and (min-width:1280px) {
    .app-list-grid {
        margin-left: 72px !important;
        margin-right: 72px !important;
    }
}

@media screen and (min-width:1440px) {
    .app-list-grid {
        margin-left: auto !important;
        margin-right: auto !important;
        max-width: 1296px;
    }    
}

.ftgkle {
    --gap-width: 12px;
}

@media screen and (min-width:600px) {
    .ftgkle {
        --gap-width: 16px;
    }
}

@media screen and (min-width:1280px) {
    .ftgkle {
        --gap-width: 24px;
    }
}

.app-list-item {
    transition: background-color 0.2s;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    position: relative;
    outline: none;
    color: inherit;
    text-decoration: none;
    cursor: pointer;
    overflow: hidden;
    will-change: transform, opacity;
}

.TAQqTe {
    border-radius: 8px;
    margin: calc(var(--gap-width)/2*-1);
    padding: calc(var(--gap-width)/2);
}

.app-list-item:first-child {
    border-top-left-radius: inherit;
    border-top-right-radius: inherit;
}

.app-list-item:last-child {
    border-bottom-left-radius: inherit;
    border-bottom-right-radius: inherit;
}

.app-list-item:hover {
    background-color: #f5f5f5;
}

.T75of {
    background-size: contain;
}

.app-banner {
    border-width: 0;
    box-shadow: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);
    border-radius: 8px;
}

.Shbxxd, .app-banner {
    height: calc(var(--card-width)*9/16);
    object-fit: cover;
    width: var(--card-width);
}

.VfPpkd-WsjYwc {
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    position: relative;
}

.KC1dQ {
    border-radius: 8px;
    background-color: #fff;
    border-width: 0;
    box-shadow: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);
}

.Usd1Ac {
    border-radius: 8px;
    background-color: #fff;
    border: 1px solid rgb(218, 220, 224);
    box-shadow: none;
}

.Y8RQXd {
    --gap-width: 12px;
    --card-width: calc(100vw - 48px);
    border: 0;
    width: var(--card-width);
}

@media screen and (min-width:600px) {
    .Y8RQXd {
        --gap-width: 16px;
        --card-width: calc(75vw - 76px);
    }
}

@media screen and (min-width:840px) {
    .Y8RQXd {
        --card-width: calc(50vw - 56px);
    }
}

@media screen and (min-width:960px) {
    .Y8RQXd {
        --card-width: calc(33.3333333333vw - 42.6666666667px);
    }
}

@media screen and (min-width:1280px) {
    .Y8RQXd {
        --gap-width: 24px;
        --card-width: calc(33.3333333333vw - 64px);
    }
}

@media screen and (min-width:1440px) {
    .Y8RQXd {
        --card-width: 416px;
    }
}

.Si6A0c {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    outline: none;
}

.Gy4nib {
    position: relative;
}

.app-list-content {
    column-gap: 16px;
    display: grid;
    grid-template-columns: -webkit-max-content auto;
    grid-template-columns: max-content auto;
    margin: 16px 0;
}

.app-icon {
    object-fit: cover;
    border-radius: 12px;
    border-width: 0;
    box-shadow: 0 1px 2px 0 rgba(60, 64, 67, .3), 0 1px 3px 1px rgba(60, 64, 67, .15);
    height: 56px;
    width: 56px;
}

@media screen and (min-width:1280px) {
    .app-icon {
        height: 64px;
        width: 64px;
    }    
}

.app-info {
    display: grid;
    grid-template-rows: -webkit-max-content;
    grid-template-rows: max-content;
    height: -webkit-fit-content;
    height: fit-content;
    row-gap: 2px;
}

@media screen and (min-width:1280px){
    .app-info {
        row-gap: 0;
    }
}

.app-name {
    color: rgb(32, 33, 36);
    fill: rgb(32, 33, 36);
    stop-color: rgb(32, 33, 36);
    font-size: .875rem;
    font-weight: 400;
    letter-spacing: .0142857143em;
    line-height: 1.25rem;
    font-family: Roboto, Helvetica, Arial, sans-serif;
    letter-spacing: -.2px;
    margin-bottom: 0;
    white-space: nowrap;
}

@media screen and (min-width:1280px) {
    .app-name {
        font-size: 1rem;
        font-weight: 400;
        letter-spacing: .00625em;
        line-height: 1.5rem;
        letter-spacing: 0;
    }
}

.app-size {
    font-size: .75rem;
    font-weight: 400;
    line-height: 1rem;
    letter-spacing: .2px;
    color: rgb(32, 33, 36);
}

@media screen and (min-width:1280px) {
    .app-size {
        font-size: .875rem;
        font-weight: 400;
        letter-spacing: .0142857143em;
        line-height: 1.25rem;
        letter-spacing: .2px;
    }
}

.app-rating {
    font-size: .75rem;
    font-weight: 400;
    line-height: 1rem;
    letter-spacing: .2px;
    color: rgb(95, 99, 104);
}

@media screen and (min-width:1280px) {
    .app-rating {
        font-size: .875rem;
        font-weight: 400;
        letter-spacing: .0142857143em;
        line-height: 1.25rem;
        letter-spacing: .2px;
    }
}

/* Pagination Styles */
.pagination-nav {
    display: flex;
    justify-content: center;
    gap: 8px;
    padding: 2rem 0;
    font-family: Roboto, system-ui, sans-serif;
    font-size: 20px;
    user-select: none;
}

.pagination-nav .page-numbers {
    min-width: 40px;
    height: 40px;
    padding: 0 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    color: #202124;
    text-decoration: none;
    transition: background-color 0.2s ease, box-shadow 0.2s ease;
}

.pagination-nav .page-numbers:hover {
    background-color: #f1f3f4;
    box-shadow: 0 1px 3px rgba(60, 64, 67, 0.15);
}

.pagination-nav .page-numbers.current {
    background-color: #e8f0fe;
    color: #1a73e8;
    font-weight: 500;
}

.pagination-nav .page-numbers.dots {
    background: transparent;
    color: #9aa0a6;
    pointer-events: none;
}

.pagination-nav .page-numbers.prev,
.pagination-nav .page-numbers.next {
    font-size: 18px;
    padding: 0 14px;
    border-radius: 20px;
}