    @import url('https://fonts.googleapis.com/css2?family=Kaisei+Tokumin:wght@400;500;700&family=Poppins:wght@300;400;500&display=swap');

    :root{
        --lg-font: 'Kaisei Tokumin', serif;
        --sm-font: 'Poppins', sans-serif;
        --pink: #e5345b;
        --light-color: #f8f9fa; /* Light color to replace green */
    }

    body{
        font-family: var(--sm-font);
    }

    /* button */
    .bg-primary{
        background-color: var(--pink)!important;
    }

    .btn:not(.nav-btns button){
        background-color: #c9c9d9;
        color: rgb(17, 5, 5);
        padding: 10px 28px;
        border-radius: 45px;
        border: 1px solid rgb(85, 85, 85);
    }

    html{
        scroll-behavior: inherit;
    }

    .btn:not(.nav-btns button):hover{
        background-color: var(--pink);
        color: #07060e;
        border-color: var(--pink);
    }

    /* text color */
    .text-primary{
        color: var(--pink)!important;
    }

    /* Navbar */
    .navbar {
        -webkit-box-shadow: 0 3px 9px 3px rgba(0, 0, 0, 0.1);
        box-shadow: 0 3px 9px 3px rgba(0, 0, 0, 0.1);
        background-color: #1f78c1; /* deep blue navbar background */
    }

    /* Navbar brand image */
    .navbar-brand img {
        width: 40px; /* slightly bigger for better visibility */
    }

    /* Navbar brand text */
    .navbar-brand span {
        letter-spacing: 2px;
        font-family: var(--lg-font);
        background-color: #e6f0fa; /* soft light background */
        border-radius: 12px;
        color: #1f78c1; /* text color matching navbar theme */
        padding: 3px 10px;
    }

    /* Navbar links hover */
    .nav-link:hover {
        color: #f78c84 !important; /* soft coral/pink hover */
    }

    /* Navbar item hover */
    .nav-item:hover {
        border-bottom: 0.5px solid rgba(255, 255, 255, 0.2); /* subtle underline */
        background-color: #dce6f1; /* light blue background on hover */
        color: #1f78c1; /* text color matching navbar */
    }


    /* header */
    #header{
        background: url("../images/img.png") no-repeat;
        background-position: left center;
        overflow: hidden;
        border: none; /* removed green border */
        border-radius: 0; /* removed round border */
        background-size: contain;
    }

    .carousel-inner h1{
        font-size: 60px;
        font-family: var(--lg-font);
    }

    .carousel-item .btn{
        border-color: #fff!important;
    }

    .carousel-item .btn:hover{
        border-color: var(--pink)!important;
    }

    /* title */
    .title h2::before{
        position: absolute;
        content: "";
        width: 4px;
        height: 50px;
        background-color: var(--pink);
        left: -20px;
        top: 50%;
        transform: translateY(-50%);
    }

    /* collection */
    .active-filter-btn{
        background-color: var(--pink)!important;
        color: #fff!important;
        border-color: var(--pink)!important;
    }

    .filter-button-group .btn:hover{
        color: #fff!important;
    }

    /* special */
    .special-img span{
        top: 20px;
        right: 20px;
    }
    .special-list .btn{
        padding: 8px 20px!important;
    }
    .special-img img{
        transition: all 0.3s ease;
    }
    .special-img:hover img{
        transform: scale(1.2);
    }

    /* offers */
    #offers{
        background: url(../images/) center/cover no-repeat;
    }
    #offers .row{
        min-height: 60vh;
    }
    .offers-content span{
        font-size: 28px;
    }
    .offers-content h2{
        font-size: 60px;
        font-family: var(--lg-font);
    }
    .offers-content .btn{
        border-color: transparent!important;
    }

    /* about */
    #about{
        background-color: rgba(179, 179, 179, 0.05);
    }

    /* newsletter */
    #newsletter{
        background-color: rgba(179, 179, 179, 0.05);
    }
    #newsletter p{
        max-width: 600px;
    }
    #newsletter .input-group{
        max-width: 500px;
    }
    #newsletter .form-control{
        border-top-left-radius: 25px;
        border-bottom-left-radius: 25px;
    }
    #newsletter .btn{
        background-color: var(--pink);
        color: #fff;
        border-color: var(--pink);
    }
    #newsletter .btn:hover{
        background-color: #000;
        border-color: #000;
    }


    /* media queries */
    @media(min-width: 992px){
        .nav-item{
            border-bottom: none;
        }
    }

    .form-control{
        width: 500px;
    }

    img{
        width: 100%;
        height: auto;
    }

    .oval-heading {
        display: inline-block;
        padding: 12px 40px; /* controls the height and width of the oval */
        background-color: #0d6efd; /* blue background */
        color: white;
        font-size: 1.5rem;
        font-weight: 700;
        border-radius: 50px; /* makes the oval shape */
        box-shadow: 0 4px 8px rgba(0,0,0,0.2); /* optional shadow for depth */
        font-family: 'Poppins', sans-serif;
    }

    .bg-pink {
        background-color: #e5345b !important;
    }

    #faq .card-header {
        font-size: 1.1rem;
        border-radius: 0.5rem 0.5rem 0 0;
    }

    #faq .card-body {
        background-color: #fff0f5;
        border-radius: 0 0 0.5rem 0.5rem;
    }

    #faq h2, #faq h4 {
        letter-spacing: 1px;
    }

    #faq .form-control:focus {
        box-shadow: none;
        border-color: #e5345b;
    }

    #faq .btn-primary {
        background-color: #e5345b;
        border-color: #e5345b;
    }

    #faq .btn-primary:hover {
        background-color: #c32c52;
        border-color: #c32c52;
    }

    /* About */
    #aboutus {
    position: relative;
    overflow: hidden;
    }

    /* Decorative shapes */
    #aboutus::before,
    #aboutus::after {
    content: "";
    position: absolute;
    border-radius: 50%;
    z-index: 0;
    }
    #aboutus::before {
    width: 280px;
    height: 280px;
    background: rgba(13,110,253,0.08);
    top: -120px;
    left: -120px;
    }
    #aboutus::after {
    width: 220px;
    height: 220px;
    background: rgba(32,201,151,0.08);
    bottom: -100px;
    right: -100px;
    }

    #aboutus .container {
    position: relative;
    z-index: 2;
    }

    /* Title */
    .section-title {
    font-size: 2.5rem;
    color: #dc3545;
    }
    .section-title::after {
    content: "";
    display: block;
    width: 80px;
    height: 4px;
    background: linear-gradient(90deg,#0d6efd,#20c997);
    margin: 12px auto;
    }

    /* Logo */
    .logo-box img {
    max-width: 260px;
    padding: 18px;
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 12px 30px rgba(0,0,0,0.08);
    }

    /* Content boxes */
    .about-box {
    background: #fff;
    border-radius: 18px;
    padding: 32px;
    margin-bottom: 30px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.07);
    transition: all 0.3s ease;
    }
    .about-box:hover {
    transform: translateY(-4px);
    }

    .about-box h4 {
    color: #0d6efd;
    font-weight: 700;
    margin-bottom: 15px;
    }

    /* Highlight */
    .about-highlight {
    background: linear-gradient(135deg,#eef6ff,#ffffff);
    border-left: 6px solid #0d6efd;
    }

    /* Values */
    .value-card {
    background: #fff;
    padding: 18px;
    border-radius: 14px;
    font-weight: 600;
    box-shadow: 0 8px 22px rgba(0,0,0,0.06);
    transition: 0.3s;
    }
    .value-card:hover {
    background: linear-gradient(135deg,#0d6efd,#20c997);
    color: #fff;
    }

    /* Licensing */
    .licensing-box {
    padding: 25px;
    border-radius: 16px;
    background: linear-gradient(135deg,#f8f9fa,#ffffff);
    border: 1px dashed rgba(13,110,253,0.4);
    }


    /* Header background */
    #header {
        position: relative;
        background-size: cover;
        min-height: 400px;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    /* Overlay for darker text visibility */
    #header .header-overlay {
        position: absolute;
        inset: 0;
        display: flex;
        background: rgba(0,0,0,0.5); /* semi-transparent dark overlay */
        z-index: 1;
    }

    /* Heading style */
    .header-title {
        position: relative;
        z-index: 2;
        color: #ffffff; /* white text */
        font-family: 'Kaisei Tokumin', serif; /* elegant serif font */
        font-size: 2.5rem;
        line-height: 1.3;
        text-shadow: 1px 1px 5px rgba(0,0,0,0.7); /* subtle shadow for readability */
    }

    /* Responsive font */
    @media (max-width: 768px) {
        .header-title {
            font-size: 1.8rem;
        }
    }

    /* Footer full-width background */
    footer.footer {
        padding: 0; /* remove default padding */
    }

    footer .footer-bg {
        background-color: #252a2e; /* your footer color */
        width: 100vw;              /* full viewport width */
        padding: 50px 0;           /* vertical spacing */
        margin-left: calc(-50vw + 50%); /* ensures full-width bg even inside container */
    }

    /* Logo */
    footer .footer-logo {
        height:150px;
        width: auto;
        display: block;
        margin: 0 auto;
    }

    /* Footer links */
    footer.footer a {
        color: #fff;
        text-decoration: none;
    }

    footer.footer a:hover {
        color: #e5345b;
    }

    /* Scroll Top Button */
    #scrollTopBtn {
        position: fixed;
        bottom: 25px;
        right: 25px;
        z-index: 999;

        width: 52px;
        height: 52px;

        display: flex;
        align-items: center;
        justify-content: center;

        border: none;
        outline: none;
        border-radius: 50%;

        background: linear-gradient(135deg, #7dc858, #696eae);
        color: #fff;

        font-size: 22px;
        font-weight: bold;

        cursor: pointer;
        display: none;

        box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
        transition: transform 0.25s ease, box-shadow 0.25s ease;
    }
    html{
    scroll-behavior: smooth; /* instead of inherit */
    }



    /* Hover Effect */
    #scrollTopBtn:hover {
        transform: translateY(-4px) scale(1.05);
        background: linear-gradient(135deg, #6d7bb0, #8a9dfc);
        box-shadow: 0 14px 30px rgba(0, 0, 0, 0.35);
    }
    /* End of Scroll Button */

    /* Contact Design*/
    .contact-card{
    background: #fff;
    padding: 35px 25px;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0,0,0,0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;

    height: 100%;

    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    }

    .contact-card p{
    margin-top: 10px;
    margin-bottom: 0;
    max-width: 260px;     /* keeps lines tidy */
    word-break: break-word; /* email won’t overflow */
    }

    .contact-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 18px 40px rgba(0,0,0,0.12);
    }


    /* Icon Circle */
    .icon-circle {
        width: 70px;
        height: 70px;
        margin: 0 auto;
        border-radius: 50%;
        border: 2px dotted #db4c4c;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .icon-circle i {
        font-size: 26px;
        color: #2936cd;
    }

    /* Register */
    .price-box .currency {
        font-weight: 700;
        font-size: 20px;
    }

    .price-box .amount {
        font-weight: 800;
        font-size: 48px;
        line-height: 1;
    }

    .price-box .per {
        font-size: 16px;
        opacity: 0.9;
    }

    /* Register  */
    .fee-row {
    display: grid;
    grid-template-columns: 1fr 260px auto;
    }

    .price {
    display: flex;
    align-items: baseline;
    justify-content: center;
    margin-top: 4px; /* micro-adjust */
    }

    .price span {
    font-weight: 700;
    font-size: 20px;
    margin-right: 6px;
    }

    .price strong {
    font-size: 48px;
    font-weight: 800;
    line-height: 1;
    }

    .price small {
    font-size: 16px;
    margin-left: 6px;
    }

    .btn-wrap {
    display: flex;
    align-items: center;
    }


    .student-bg {
    background: #e9f2ff;   /* light blue example */
    color: #0d1b4c;        /* text color */
    }

    @media (max-width: 768px){
    .fee-row{
        grid-template-columns: 1fr;   /* stack */
        gap: 12px;
        text-align: center;
    }

    .price{
        justify-content: center;
    }

    .btn-wrap{
        justify-content: center;
    }

    .btn-wrap .btn{
        width: 100%;
        max-width: 240px; /* nice tablet/mobile size */
    }
    }





