﻿header,footer {
    width: 100%;
}

header {
    position: relative;
    z-index: 100;
    padding: 0;
    clip-path: polygon(
        0 0, 
        100% 0, 
        100% calc(100% - 15px), 
        calc(100% - 15px) 100%, 
        15px 100%, 
        0 calc(100% - 15px)
    );
    margin-top: 0;
    overflow: visible;
    background: linear-gradient(120deg, rgb(165,159,166) 0%, rgb(121,116,127) 100%);
}

.key-course-program-info .container {
    padding: 0 2rem;
    margin: 0 auto;
    position: relative;
    max-width: 1200px;
    z-index: 1;
}

.key-course-program-info h2::after {
    bottom: 0;
    content: "";
    background: linear-gradient(90deg, rgb(165,159,166), rgb(121,116,127));
    left: 0;
    height: 4px;
    transform-origin: left;
    transition: transform 0.5s cubic-bezier(0.215, 0.61, 0.355, 1);
    width: 100px;
    position: absolute;
}

.key-course-program-info .key-paragraph-holder {
    flex-direction: column;
    position: relative;
    display: flex;
    gap: 2rem;
    transform: perspective(1000px) translateZ(0);
}

.key-course-program-info .description:last-of-type {
    padding-top: 1rem;
}

.key-course-program-info .description:hover {
    opacity: 1;
}

.key-privacy-compartment ul {
    padding: 0;
    list-style-type: none;
    margin: 1rem 0;
}

.key-privacy-compartment li {
    font-size: 13px;
    border-radius: 10px;
    align-items: center;
    background-color: rgba(0, 0, 0, 0.5);
    padding: 15px;
    display: flex;
    margin-bottom: 15px;
}

.key-privacy-compartment a {
    color: rgb(121,116,127);
    font-weight: 600;
    text-decoration: none;
    border-bottom: 1px dashed rgb(121,116,127);
}

header .key-top-teach::before {
    bottom: 3px;
    content: '';
    border: 1px dashed rgba(255, 255, 255, 0.3);
    top: 3px;
    z-index: -1;
    position: absolute;
    left: 3px;
    right: 3px;
    clip-path: polygon(
        0 0,
        calc(100% - 10px) 0,
        100% 10px,
        100% 100%,
        10px 100%,
        0 calc(100% - 10px)
    );
}

header .key-top-mentor {
    display: flex;
    margin: 0;
    list-style: none;
    padding: 0;
    z-index: 2;
    position: relative;
}

header .key-top-base a:hover::before {
    left: 100%;
}

header .key-top-base::after {
    transition: width 0.3s ease;
    position: absolute;
    content: '';
    bottom: -5px;
    transform: translateX(-50%);
    width: 0;
    background: #ffffff;
    height: 2px;
    left: 50%;
}

header .key-main-primary {
    position: relative;
    padding-top: 2rem;
    background: rgb(198,198,181);
    margin-top: -15px;
    z-index: 1;
}



header::after {
    box-shadow: 0 0 10px #ffffff;
    content: '';
    height: 8px;
    animation: pulse 2s infinite;
    background: #ffffff;
    right: 15px;
    top: 15px;
    width: 8px;
    position: absolute;
    border-radius: 50%;
}

.key-join-now .key-study-program::before {
    position: absolute;
    width: 100%;
    left: 0;
    z-index: -1;
    background: linear-gradient(
        to bottom,
        rgba(255, 255, 255, 0.08) 0%,
        rgba(255, 255, 255, 0) 50%,
        rgba(255, 255, 255, 0.05) 100%
    );
    top: 0;
    content: '';
    height: 100%;
}

.key-join-now h3::before {
    width: 40px;
    position: absolute;
    transform: translateX(-50%);
    background: rgba(255, 255, 255, 0.3);
    height: 1px;
    content: '';
    left: 50%;
    bottom: -25px;
}

.key-join-now .key-send-info::before {
    transition: opacity 0.4s ease;
    background: linear-gradient(
        to right,
        rgb(165,159,166),
        rgb(121,116,127)
    );
    position: absolute;
    top: 0;
    z-index: -1;
    opacity: 0;
    height: 100%;
    width: 100%;
    left: 0;
    content: '';
}

.key-join-now .key-send-info:hover::after {
    transition: width 0.6s ease, height 0.6s ease, opacity 0.6s ease 0.2s;
    width: 300px;
    height: 300px;
    opacity: 0;
}

footer .info_item:hover {
    transform: translateY(-5px);
    background-color: #ffffff;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.05);
}

footer .info_item::before {
    width: 3px;
    content: "";
    transition: opacity 0.3s ease;
    left: 0;
    height: 100%;
    background-color: rgb(165,159,166);
    opacity: 0;
    position: absolute;
    border-radius: 3px 0 0 3px;
    top: 0;
}

footer .info_item a:hover {
    color: rgb(165,159,166);
}

footer .key-top-teach {
    padding: 0 30px;
    position: relative;
}

footer .key-quiz-links {
    line-height: 1.6;
    color: #000000;
    max-width: 330px;
    font-size: 16px;
}

footer .key-top-mentor h5 {
    position: relative;
    font-weight: 600;
    margin-bottom: 20px;
    display: inline-block;
    color: #000000;
    font-size: 21px;
}

footer .key-head-pagewrap a {
    position: relative;
    text-decoration: none;
    transition: all 0.3s ease;
    display: inline-block;
    color: #000000;
    font-size: 12px;
    padding: 8px 0;
}

footer .subscribe_holder h5 {
    font-size: 21px;
    font-weight: 600;
    color: #ffffff;
    margin-bottom: 15px;
}

footer .input_holder {
    flex-direction: column;
    gap: 15px;
    position: relative;
    display: flex;
}

footer .key-free-trial {
    font-size: 17px;
    border: none;
    cursor: pointer;
    transition: all 0.3s ease;
    font-weight: 600;
    background-color: #000000;
    color: #ffffff;
    border-radius: 10px;
    padding: 14px 20px;
}

.key-subscribe-to-newsletter .container {
    margin: 0 auto;
    max-width: 1140px;
    z-index: 1;
    position: relative;
}

.key-subscribe-to-newsletter .key-study-program::before {
    position: absolute;
    white-space: nowrap;
    left: 50%;
    font-weight: 700;
    font-family: Arial, sans-serif;
    opacity: 0.04;
    letter-spacing: 0.5rem;
    top: 50%;
    color: rgb(165,159,166);
    transform: translate(-50%, -50%);
    z-index: -1;
    font-size: 12rem;
}

.key-subscribe-to-newsletter .input_holder:hover::before {
    transform: translate(5px, 5px);
}

.key-subscribe-to-newsletter .key-subscribe-title:focus {
    border-color: rgb(165,159,166);
}

.key-subscribe-to-newsletter .key-feedback-box::after {
    opacity: 0;
    width: 200%;
    content: "";
    border-radius: 50%;
    height: 200%;
    background: rgb(165,159,166);
    top: -50%;
    left: -50%;
    z-index: -1;
    position: absolute;
    transition: transform 0.5s ease, opacity 0.5s ease;
    transform: scale(0);
}

.key-education-framework::after {
    position: absolute;
    height: 100%;
    content: "";
    opacity: 0.2;
    background: radial-gradient(
        circle at 75% 25%,
        rgb(165,159,166,0.5) 0%,
        transparent 60%
    );
    left: 0;
    top: 0;
    z-index: 0;
    width: 100%;
}

.key-education-framework .container.key-study-program > div {
    position: relative;
    padding: 3.5rem;
    overflow: hidden;
}

.key-education-framework h3::after {
    content: "";
    background: rgb(121,116,127);
    width: 0;
    bottom: -10px;
    height: 3px;
    position: absolute;
    transition: width 0.6s cubic-bezier(0.19, 1, 0.22, 1);
    left: 0;
}

.key-contact {
    padding: 100px 0;
    z-index: 1;
    overflow: hidden;
    position: relative;
    background: linear-gradient(125deg, rgb(198,198,181) 0%, rgb(121,116,127,0.5) 50%, rgb(198,198,181) 100%);
}

.key-contact .key-img-zoom {
    width: 100%;
    opacity: 0.15;
    mix-blend-mode: luminosity;
    z-index: 0;
    filter: contrast(120%) brightness(110%) blur(5px);
    left: 0;
    height: 100%;
    position: absolute;
    top: 0;
}

.key-contact h3::before {
    position: absolute;
    left: 50%;
    top: -15px;
    width: 40px;
    background: rgb(165,159,166);
    content: '';
    border-radius: 10px;
    height: 4px;
    transform: translateX(-50%);
}

.key-contact .key-connect-message::after {
    inset: 0;
    animation: pulse-border 4s infinite alternate;
    border: 1px solid rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 25px rgb(165,159,166,0.5);
    position: absolute;
    border-radius: 27px;
    content: '';
    pointer-events: none;
}

.key-contact .key-feedback-inquiry h3 {
    margin-bottom: 40px;
    letter-spacing: 1px;
    text-align: left;
    font-weight: 600;
    font-size: 24px;
    color: #000000;
    text-transform: uppercase;
}

.key-contact .key-feedback-inquiry input[type="text"]:focus,
.key-contact .key-feedback-inquiry textarea:focus {
    outline: none;
    box-shadow: 
        0 2px 5px rgba(0, 0, 0, 0.03) inset,
        0 0 0 3px rgb(165,159,166,0.5);
    border-color: rgb(165,159,166);
    background-color: #ffffff;
}

.key-contact .key-feedback-inquiry .key-support-section label::after {
    transform: scale(0.6);
    border-radius: calc(10px - 2px);
    height: 15px;
    position: absolute;
    background-color: rgb(165,159,166);
    opacity: 0;
    left: 5px;
    content: '';
    top: 2px;
    transition: all 0.3s ease;
    width: 15px;
}

.key-contact .key-feedback-inquiry .key-support-section a:hover {
    color: rgb(121,116,127);
}

.key-contact .key-feedback-inquiry .key-feedback-box {
    cursor: pointer;
    overflow: hidden;
    font-weight: 600;
    transition: all 0.3s ease;
    border: none;
    padding: 16px 35px;
    box-shadow: 
        0 5px 15px rgb(165,159,166,0.5),
        0 0 0 1px rgb(165,159,166,0.5) inset;
    display: inline-block;
    font-size: 19px;
    text-transform: uppercase;
    border-radius: 27px;
    color: #ffffff;
    letter-spacing: 1px;
    position: relative;
    background: linear-gradient(135deg, rgb(165,159,166) 0%, rgb(121,116,127) 100%);
}

.key-contact .key-connect-reach h4 {
    font-weight: 600;
    color: #ffffff;
    text-transform: uppercase;
    z-index: 1;
    margin-bottom: 40px;
    letter-spacing: 1px;
    font-size: 24px;
    position: relative;
}

.key-contact .key-connect-reach .key-message-help li {
    margin-bottom: 30px;
    align-items: flex-start;
    padding-bottom: 20px;
    display: flex;
    position: relative;
}

.key-contact .key-connect-reach .key-message-help li:hover svg {
    transform: scale(1.1);
    transition: transform 0.3s ease;
}

.key-contact .key-connect-reach .key-message-help li a {
    text-decoration: none;
    position: relative;
    color: #ffffff;
    transition: all 0.3s ease;
}

.key-plan-card {
    overflow: hidden;
    padding: 120px 0;
    background: rgb(198,198,181);
    position: relative;
}

.key-plan-card .container {
    margin: 0 auto;
    position: relative;
    max-width: 1400px;
    padding: 0 20px;
    z-index: 1;
}

.key-plan-card .key-value-rates {
    margin-bottom: 20px;
    z-index: 2;
    transform: translateX(5%);
    order: -1;
    position: relative;
}

.key-plan-card .key-value-rates:hover .key-pricing-tiers {
    transform: translateY(3px);
}

.key-plan-card .key-trial-pricing {
    position: relative;
    text-decoration: none;
    height: 100%;
    transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
    display: block;
    transform: translateZ(0) scale(1);
    overflow: hidden;
    transform-style: preserve-3d;
}

.key-plan-card .key-trial-pricing:hover .key-price-sheet::before {
    transform: scaleX(1);
}

.key-plan-card .key-pricing-schemes h3 {
    transition: transform 0.4s ease, color 0.3s ease;
    color: #000000;
    position: relative;
    overflow-wrap: break-word;
    transform: translateY(0);
    font-weight: 600;
    word-break: break-word;
    font-size: calc(22px + 2px);
    margin-bottom: 15px;
}

.key-plan-card .key-pricing-schemes p {
    flex-grow: 1;
    font-size: 13px;
    word-break: break-word;
    line-height: 1.7;
    overflow-wrap: break-word;
    color: #000000;
    margin-top: 10px;
    white-space: normal;
    transition: opacity 0.3s ease;
    opacity: 0.85;
}

.key-cookie-gate {
    margin: auto;
    padding: 0 20px;
    max-width: 1200px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: nowrap;
}

.key-cookie-popup-display p {
    color: #000000;
    max-width: 500px;
    font-size: 12px;
}

.key-track-edu {
    margin-left: 10px;
    transition: border 0.2s;
    text-align: center;
    font-weight: 600;
    background: rgb(165,159,166);
    text-decoration: none;
    border: 2px solid transparent;
    min-width: 140px;
    border-radius: 10px;
    padding: 12px 24px;
    color: #ffffff;
    flex-shrink: 0;
    font-size: 19px;
    text-transform: uppercase;
}

.key-thankYouBox .container {
    transform-style: preserve-3d;
    z-index: 2;
    margin: 0 auto;
    max-width: 1200px;
    position: relative;
    padding: 0 20px;
}

.key-thankYouBox h2::after {
    left: 0;
    bottom: -15px;
    background: rgb(165,159,166);
    position: absolute;
    transform-origin: left;
    content: "";
    height: 3px;
    animation: lineExpand 1.2s 0.6s forwards cubic-bezier(0.19, 1, 0.22, 1);
    transform: scaleX(0);
    width: 80px;
}

.key-thankYouBox ul {
    padding: 0;
    list-style: none;
    margin: 0;
}

.key-thankYouBox li {
    display: flex;
    position: relative;
    align-items: flex-start;
}

.key-thankYouBox li span {
    font-size: 17px;
    position: relative;
    line-height: 1.8;
    display: block;
    font-family: Arial, sans-serif;
    transform: translateX(0);
    animation: textFadeIn 0.8s 1s forwards ease-out;
    color: #000000;
    opacity: 0;
}

.key-title-section .key-knowledge-sessions {
    backdrop-filter: blur(10px);
    z-index: 3;
    background: linear-gradient(120deg, rgba(rgba(0, 0, 0, 0.5), 0.7), rgba(rgba(0, 0, 0, 0.5), 0.4));
    position: relative;
    padding: 3rem;
    max-width: 900px;
    clip-path: polygon(0 0, 100% 0, 95% 100%, 5% 100%);
    box-shadow: 0 30px 60px rgba(0,0,0,0.3);
    transform: perspective(1000px) rotateX(2deg);
}

.key-title-section .title_style_header {
    transform: translateZ(0);
    position: relative;
    margin-bottom: 2rem;
    font-weight: 700;
    font-size: calc(48px * 1.5);
    color: #ffffff;
    line-height: 1.2;
}

.key-company-overview::before {
    bottom: 0;
    background: 
        repeating-linear-gradient(
            -45deg,
            transparent,
            transparent 10px,
            rgb(165,159,166,0.5) 10px,
            rgb(165,159,166,0.5) 11px
        ),
        repeating-linear-gradient(
            45deg,
            transparent,
            transparent 10px,
            rgb(121,116,127,0.5) 10px,
            rgb(121,116,127,0.5) 11px
        );
    opacity: 0.05;
    top: 0;
    right: 0;
    z-index: -1;
    left: 0;
    content: "";
    position: absolute;
}

.key-company-overview .key-digital-education::before {
    opacity: 0.1;
    transition: all 0.5s ease;
    right: -100px;
    position: absolute;
    top: -100px;
    border-radius: 50%;
    content: "";
    background: linear-gradient(45deg, rgb(165,159,166,0.5), transparent);
    height: 200px;
    width: 200px;
}

.key-company-overview .key-digital-education:nth-child(1) h3 {
    color: rgb(165,159,166);
}

.key-company-overview .key-digital-education h3::after {
    height: 2px;
    transition: width 0.4s ease;
    position: absolute;
    left: 0;
    content: "";
    bottom: -5px;
    width: 0;
    background: currentColor;
}

.key-company-overview .container::after {
    height: 70%;
    background: linear-gradient(to bottom, rgb(121,116,127,0.5), transparent);
    right: 10%;
}

.key-academic-experience::before {
    left: 0;
    content: "";
    width: 100%;
    background-position: 0 0, 0 30px, 30px -30px, -30px 0px;
    position: absolute;
    background-image: 
        linear-gradient(45deg, rgb(165,159,166,0.5) 25%, transparent 25%),
        linear-gradient(-45deg, rgb(165,159,166,0.5) 25%, transparent 25%),
        linear-gradient(45deg, transparent 75%, rgb(165,159,166,0.5) 75%),
        linear-gradient(-45deg, transparent 75%, rgb(165,159,166,0.5) 75%);
    height: 100%;
    background-size: 60px 60px;
    top: 0;
    opacity: 0.03;
}

.key-academic-experience .name {
    padding: 0 20px 15px;
    text-align: center;
    background: linear-gradient(
        to right,
        #000000 0%,
        rgb(165,159,166) 100%
    );
    z-index: 2;
    color: #000000;
    text-fill-color: transparent;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    font-size: 47px;
    margin-bottom: 15px;
    position: relative;
    -webkit-text-fill-color: transparent;
    font-weight: 700;
}

.key-academic-experience .key-career-wrap::after {
    background: 
        linear-gradient(225deg, rgb(121,116,127,0.5) 0%, transparent 100%);
    width: 35px;
    position: absolute;
    right: 25px;
    height: 35px;
    content: "";
    border-radius: 0 0 0 10px;
    bottom: 25px;
    opacity: 0.2;
}

.key-academic-experience .key-review-testimonials:hover .key-img-zoom::before {
    transform: rotate(0deg);
    opacity: 0.5;
}

.key-academic-experience .key-review-testimonials:hover .key-img-zoom::after {
    transform: rotate(5deg);
}

.key-academic-experience .key-review-testimonials:hover span:not(.name) {
    opacity: 1;
    letter-spacing: 5px;
}



@media (min-width: 768px) {.key-course-program-info {
    padding: 8rem 0;
}.key-course-program-info h2 {
    font-size: calc(35px * 1.1);
    max-width: 70%;
}.key-course-program-info .key-career-challenge {
    gap: 4rem;
    grid-template-columns: 1fr 1fr;
    align-items: start;
}.key-course-program-info .key-img-zoom {
    clip-path: polygon(0 0, 100% 0, 95% 100%, 5% 100%);
    height: 500px;
}.key-course-program-info h2::after {
    width: 120px;
}
}



@media (min-width: 1400px) {header .key-header-base {
    margin: 0 auto;
    max-width: 1320px;
}header .key-top-base {
    margin: 0 0.7rem;
}header .key-top-base a {
    padding: 0 1.5rem;
}
}



@media (max-width: 767px) {header {
    padding: 0;
    clip-path: polygon(
            0 0, 
            100% 0, 
            100% calc(100% - 5px), 
            calc(100% - 5px) 100%, 
            5px 100%, 
            0 calc(100% - 5px)
        );
}header .key-header-base {
    padding: 0.8rem 1.5rem;
}header .key-top-teach {
    clip-path: polygon(
            0 0,
            calc(100% - 5px) 0,
            100% 5px,
            100% 100%,
            5px 100%,
            0 calc(100% - 5px)
        );
    padding: 0.5rem 0.8rem;
}header .key-top-header img {
    max-height: 35px;
}header .key-top-mentor {
    scrollbar-width: thin;
    overflow-x: auto;
    padding-bottom: 0.5rem;
    -webkit-overflow-scrolling: touch;
    justify-content: flex-start;
    margin-top: 0.8rem;
}header .key-top-mentor::-webkit-scrollbar {
    height: 3px;
}header .key-top-mentor::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.3);
    border-radius: 10px;
}header .key-top-base {
    margin: 0 0.25rem;
    flex: 0 0 auto;
}header .key-top-base a {
    font-size: calc(13px - 2px);
    clip-path: polygon(
            5px 0,
            calc(100% - 5px) 0,
            100% 5px,
            100% calc(100% - 5px),
            calc(100% - 5px) 100%,
            5px 100%,
            0 calc(100% - 5px),
            0 5px
        );
    white-space: nowrap;
    height: 32px;
    padding: 0 0.8rem;
}header .key-top-base::after {
    display: none;
}header::after {
    right: 10px;
    width: 5px;
    height: 5px;
    top: 10px;
}.key-main-primary {
    margin-top: -5px;
}
}



@media (max-width: 991.98px) {.key-education-framework {
    padding: 5rem 0;
}.key-education-framework .container.key-study-program > div {
    padding: 3rem 2.5rem;
}.key-education-framework h3 {
    font-size: 1.75rem;
    margin-bottom: 1.5rem;
}.key-education-framework p {
    max-width: 100%;
}
}



@media (hover: hover) {.key-education-framework .container.key-study-program {
    cursor: default;
}.key-education-framework .container.key-study-program::after {
    inset: 0;
    background: linear-gradient(
            135deg,
            rgba(255, 255, 255, 0.1) 0%,
            rgba(255, 255, 255, 0.03) 100%
        );
    opacity: 0;
    position: absolute;
    transition: opacity 0.4s ease;
    content: "";
}.key-education-framework .container.key-study-program:hover::after {
    opacity: 1;
}
}



@media (max-width: 576px) {.key-contact {
    padding: 40px 0;
}.key-contact .key-feedback-inquiry,
    .key-contact .key-connect-reach {
    padding: 30px 20px;
}.key-contact h3 {
    margin-bottom: 30px;
    font-size: calc(37px - 6px);
}.key-contact .key-feedback-inquiry .key-support-section label {
    font-size: calc(12px - 3px);
}.key-contact .key-connect-reach .key-message-help li:not(:last-child) {
    padding-bottom: 12px;
    margin-bottom: 20px;
}}



@media (max-width: 767px) {.key-plan-card {
    padding: 60px 0;
}.key-plan-card .key-plan-rates {
    grid-template-columns: 1fr;
}.key-plan-card .key-pricing-schemes {
    padding: 25px 20px;
}.key-plan-card .key-trial-pricing .key-img-zoom {
    height: 180px;
}.key-plan-card .key-value-rates h2 {
    font-size: calc(36px - 2px);
}
}



@media (max-width: 767px) {.key-thankYouBox {
    padding: 60px 0;
    perspective: 800px;
}.key-thankYouBox h2 {
    transform: translateZ(20px);
    font-size: calc(33px * 0.8);
    margin-bottom: 25px;
}.key-thankYouBox .key-study-program {
    transform: translateZ(5px) rotateX(1deg);
    padding: 30px 25px;
}.key-thankYouBox li::before {
    left: -20px;
    width: 10px;
    height: 10px;
}.key-thankYouBox li span {
    font-size: calc(17px * 0.95);
    line-height: 1.6;
}
}



@media (hover: hover) {.key-title-section .key-knowledge-sessions:hover {
    transition: transform 0.5s ease;
    transform: perspective(1000px) rotateX(1deg) translateY(-5px);
}}



@media (max-width: 992px) {.key-company-overview {
    padding: 90px 0;
}.key-company-overview h2 {
    margin-bottom: 50px;
}.key-company-overview .key-digital-education {
    padding: 30px;
}
}



@media (max-width: 576px) {.key-company-overview {
    padding: 50px 0;
}.key-company-overview h2 {
    font-size: calc(38px * 0.8);
    margin-bottom: 35px;
    letter-spacing: 1px;
}.key-company-overview h2::before {
    width: 40px;
    height: 4px;
}.key-company-overview .key-digital-education {
    padding: 20px;
}.key-company-overview .key-digital-education p {
    font-size: calc(13px * 0.95);
    line-height: 1.6;
}.key-company-overview .container::before,
    .key-company-overview .container::after {
    display: none;
}}

@keyframes pulse {
    0%, 100% { opacity: 0.5; }
    50% { opacity: 1; }
}



@keyframes floatingItem {
    0%, 100% {
        transform: translateY(0) rotate(0);
    }
    50% {
        transform: translateY(-15px) rotate(5deg);
    }
}



@keyframes patternShift {
    0% {
        background-position: 0 0;
    }
    100% {
        background-position: 100px 100px;
    }
}



@keyframes pulse-border {
    0%, 100% {
        box-shadow: 0 0 15px rgb(165,159,166,0.5);
    }
    50% {
        box-shadow: 0 0 25px rgb(121,116,127,0.5);
    }
}



@keyframes shine {
    0% {
        background-position: -200% 0;
    }
    100% {
        background-position: 200% 0;
    }
}



@keyframes slideInFromTop {
    0% { 
        opacity: 0;
        transform: translateY(-40px) translateZ(30px);
    }
    100% { 
        opacity: 1;
        transform: translateY(0) translateZ(30px);
    }
}



@keyframes dotAppear {
    0% { opacity: 0; transform: scale(0); }
    70% { opacity: 1; transform: scale(1.2); }
    100% { opacity: 1; transform: scale(1); }
}

@keyframes moveDots {
    0% {
        background-position: 0 0;
    }
    100% {
        background-position: 1000px 500px;
    }
}

@keyframes pulse-subtle {
    0% {
        transform: scale(1);
        opacity: 0.15;
    }
    100% {
        transform: scale(1.05);
        opacity: 0.25;
    }
}

