.guru-tarot-app{
    background:
    radial-gradient(circle at top,#3b0066,#12001f);
    padding:80px 20px;
    border-radius:40px;
    text-align:center;
    overflow:visible;
}

/* TITLE */

.guru-title{
    font-size:64px;
    color:#ffd36d;
    margin-bottom:10px;
    font-weight:800;
}

.guru-subtitle{
    color:#c9b3d9;
    font-size:24px;
    margin-bottom:40px;
}

/* CATEGORY */

.guru-category-wrap{
    display:flex;
    justify-content:center;
    gap:20px;
    flex-wrap:wrap;
    margin-bottom:60px;
}

.guru-category{
    background:rgba(255,255,255,.08);
    border:none;
    color:#fff;
    padding:16px 34px;
    border-radius:50px;
    font-size:22px;
    cursor:pointer;
    transition:.3s;
}

.guru-category:hover{
    transform:translateY(-3px);
}

.guru-category.active{
    background:linear-gradient(135deg,#c86bff,#7d3cff);
    box-shadow:0 0 25px rgba(187,93,255,.6);
}

/* CARD GRID */

.guru-card-grid{
    overflow:hidden;
    padding-left:0;
    padding-right:0;
    box-sizing:border-box;
}

/* CARD */

.guru-card{
    width:140px;
    height:220px;
    position:absolute;
    left:50%;
    top:50%;
    transform-origin:center bottom;
    cursor:pointer;
    transition:.4s;
}

.guru-card img{
    width:100%;
    border-radius:18px;
    box-shadow:0 0 25px rgba(0,0,0,.5);
}

/* HOVER */

.guru-card:hover{
    transform:
    translateY(-20px)
    scale(1.08)
    !important;

    z-index:999;
}

/* RESULT */

.guru-result{
    display:none;
    margin-top:40px;
}

.guru-result-card-wrap{
    perspective:1200px;
    width:320px;
    margin:auto;
}

.guru-result-card{
    width:320px;
    height:520px;
    position:relative;
    transform-style:preserve-3d;
    transition:1s;
}

.guru-result-card.flipped{
    transform:rotateY(180deg);
}

.guru-card-front,
.guru-card-back{
    position:absolute;
    width:100%;
    height:100%;
    backface-visibility:hidden;
}

.guru-card-front img,
.guru-card-back img{
    width:100%;
    border-radius:24px;
    box-shadow:0 0 40px rgba(185,93,255,.5);
}

.guru-card-back{
    transform:rotateY(180deg);
}

/* RESULT TEXT */

#guru-result-name{
    color:#ffd36d;
    font-size:54px;
    margin-top:30px;
}

#guru-result-text{
    color:#fff;
    font-size:28px;
    max-width:800px;
    margin:20px auto;
    line-height:1.8;
}

/* BUTTON */

.guru-reset{
    background:linear-gradient(135deg,#c86bff,#7d3cff);
    border:none;
    color:#fff;
    padding:18px 40px;
    border-radius:50px;
    font-size:24px;
    cursor:pointer;
    margin-top:20px;
}

/* WARNING */

.guru-warning{
    margin-top:20px;
    margin-bottom:25px;

    color:#ffd95e;
    font-size:18px;
    line-height:1.9;
    text-align:center;

    opacity:1 !important;
    font-weight:700;

    text-shadow:
    0 0 12px rgba(255,217,94,.45);
}

/* =========================
   MOBILE IMPROVE
========================= */

@media(max-width:768px){

    html,
    body{
        overflow-x:hidden;
    }

    .guru-tarot-app{
        padding:40px 15px;
        border-radius:24px;
        overflow:visible;
    }

    .guru-title{
        font-size:34px;
        line-height:1.3;
        margin-bottom:15px;
    }

    .guru-subtitle{
        font-size:17px;
        margin-bottom:25px;
        line-height:1.6;
    }

    /* CATEGORY */

    .guru-category-wrap{
        gap:14px;
        margin-bottom:30px;
    }

    .guru-category{
        width:100%;
        max-width:260px;
        font-size:20px;
        padding:14px 20px;
    }

    /* CARD GRID */

    .guru-card-grid{
        position:relative;

        height:230px;

        width:100%;
        max-width:100%;

        overflow-x:auto;
        overflow-y:hidden;

        -webkit-overflow-scrolling:touch;

        padding-bottom:10px;
    }

    /* CARD */

    .guru-card{
        width:68px;
        height:105px;
    }

    .guru-card img{
        border-radius:12px;
    }

    /* RESULT */

    .guru-result{
        margin-top:20px;
    }

    .guru-result-card-wrap{
        width:220px;
    }

    .guru-result-card{
        width:220px;
        height:360px;
    }

    #guru-result-name{
        font-size:34px;
        line-height:1.3;
        margin-top:20px;
    }

    #guru-result-text{
        font-size:20px;
        line-height:1.8;
        padding:0 10px;
    }

    /* WARNING */

    .guru-warning{
        font-size:16px;
        line-height:1.8;
        padding:0 10px;
    }

    /* BUTTON */

    .guru-reset{
        width:100%;
        max-width:260px;
        font-size:22px;
        padding:16px 20px;
    }

}

/* =========================
   DESKTOP CARD FIX
========================= */

@media(min-width:769px){

    .guru-card-grid{
        position:relative;
        height:420px;
        max-width:1400px;
        margin:40px auto 0;
        overflow:hidden;
    }

}