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

/* ================= HERO SECTION ================= */

.hero-section{
    position: relative;
    min-height: 100vh;
    padding:120px 0 90px;
    overflow:hidden;

    background:
    radial-gradient(circle at 10% 20%, #e0e7ff 0%, transparent 40%),
    radial-gradient(circle at 90% 70%, #dbeafe 0%, transparent 40%),
    linear-gradient(135deg,#f9fafb,#eef2ff,#f8fafc);
}

/* animated mesh glow */
.hero-section::before{
    content:"";
    position:absolute;
    width:600px;
    height:600px;
    background: radial-gradient(circle,#6366f1 0%,transparent 70%);
    opacity:.15;
    top:-200px;
    right:-150px;
    filter:blur(120px);
    animation: heroGlow 12s infinite alternate;
}


/* ================= TEXT ================= */

.hero-section h1{
    font-weight:800;
    color:#0f172a;
    letter-spacing:-1px;
}

.hero-section h1 span{
    background: linear-gradient(90deg,#6366f1,#06b6d4);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

.hero-section .lead{
    color:#475569;
}

.hero-section p.small{
    color:#64748b;
}

/* ================= BUTTONS ================= */

.btn-primary{
    background: linear-gradient(135deg,#6366f1,#4f46e5);
    border:none;
    border-radius:30px;
    font-weight:600;
    box-shadow:0 8px 25px rgba(79,70,229,.25);
}

.btn-outline-light{
    border:2px solid #6366f1;
    color:#6366f1;
    border-radius:30px;
}

.btn-outline-light:hover{
    background:#6366f1;
    color:#fff;
}

/* ================= HERO STATS ================= */

.hero-stats h3{
    font-weight:700;
    color:#111827;
}

.hero-stats small{
    color:#6b7280;
    letter-spacing:1px;
}

/* ================= COUNTDOWN CARD ================= */

.hack-countdown-card{
    background:rgba(255,255,255,0.65);
    backdrop-filter:blur(20px);
    border-radius:18px;
    padding:26px;
    border:1px solid rgba(255,255,255,0.6);
    box-shadow:0 15px 40px rgba(0,0,0,0.08);
}

.hack-countdown{
    display:flex;
    justify-content:space-between;
}

.hack-countdown span{
    font-size:28px;
    font-weight:700;
    color:#4f46e5;
}

.hack-countdown small{
    font-size:12px;
    color:#64748b;
}

/* ================= FLOATING LOGOS ================= */

.floating-logo1{
    width:100px;
    margin:12px;
    animation:floatLogo 6s ease-in-out infinite;
}

.floating-logo2{
    width:180px;
    margin:12px;
    animation:floatLogo 6s ease-in-out infinite;
}

.floating-logo{
    width:180px;
    margin:12px;
    animation:floatLogo 6s ease-in-out infinite;
}
.floating-logo:nth-child(2){
    animation-delay:1s;
}

.floating-logo2:nth-child(3){
    animation-delay:2s;
}

@keyframes floatLogo{
    0%{transform:translateY(0)}
    50%{transform:translateY(-15px)}
    100%{transform:translateY(0)}
}


/* ================= ABOUT SECTION ================= */

#about{
    position: relative;
    background: linear-gradient(135deg,#ffffff,#f1f5ff);
    padding:100px 0;
    overflow:hidden;
}

/* background glow shapes */

#about::before{
    content:"";
    position:absolute;
    width:450px;
    height:450px;
    background: radial-gradient(circle,#6366f1 0%,transparent 70%);
    top:-120px;
    left:-120px;
    opacity:.12;
    filter:blur(100px);
}

#about::after{
    content:"";
    position:absolute;
    width:400px;
    height:400px;
    background: radial-gradient(circle,#06b6d4 0%,transparent 70%);
    bottom:-150px;
    right:-120px;
    opacity:.12;
    filter:blur(100px);
}

/* ================= TITLE ================= */

.section-title{
    font-weight:800;
    font-size:2.3rem;
    color:#0f172a;
    position:relative;
}

.section-title::after{
    content:"";
    display:block;
    width:60px;
    height:4px;
    /* background:linear-gradient(90deg,#6366f1,#06b6d4); */
    margin-top:10px;
    border-radius:5px;
}

/* ================= TEXT ================= */

#about p{
    color:#475569;
    font-size:16px;
}

/* ================= LIST STYLE ================= */

#about ul li{
    font-weight:500;
    color:#1e293b;
    transition:all .3s;
}

#about ul li i{
    font-size:18px;
}

/* hover animation */

#about ul li:hover{
    transform:translateX(6px);
}

/* ================= IMAGE ================= */

#about img{
    border-radius:20px;
    box-shadow:0 20px 40px rgba(0,0,0,.08);
    transition:transform .4s ease;
}

#about img:hover{
    transform:scale(1.04);
}
/* ========== Speakers (Keynotes + Panel) ========== */
.avatar-circle {
    width: 64px;
    height: 64px;
    border-radius: 999px;
    background: radial-gradient(circle at 30% 30%, #38bdf8, #4f46e5);
    color: #f9fafb;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}

#keynotes,
#panelists {
    background: #020617;
}

#keynotes .card,
#panelists .card {
    background: #020617;
    border-radius: 1rem;
    border: 1px solid rgba(148, 163, 184, 0.35);
}

#keynotes .card-title,
#panelists .card-title,
#panelists h6 {
    color: #e5e7eb;
}


/* ================= AGENDA SECTION ================= */

#agenda{
    background:linear-gradient(135deg,#f8fafc,#eef2ff);
    padding:100px 0;
    position:relative;
    overflow:hidden;
}

/* background glow */

#agenda::before{
    content:"";
    position:absolute;
    width:400px;
    height:400px;
    background:radial-gradient(circle,#6366f1 0%,transparent 70%);
    top:-150px;
    left:-120px;
    opacity:.12;
    filter:blur(100px);
}

#agenda::after{
    content:"";
    position:absolute;
    width:350px;
    height:350px;
    background:radial-gradient(circle,#06b6d4 0%,transparent 70%);
    bottom:-120px;
    right:-120px;
    opacity:.12;
    filter:blur(100px);
}

/* ================= TITLE ================= */

#agenda .section-title{
    font-weight:800;
    font-size:2.2rem;
}

/* ================= DAY CARD ================= */

.agenda-day{
    border-radius:18px;
    padding:30px;
    border:none;
    transition:all .4s ease;
}

/* hover animation */

.agenda-day:hover{
    transform:translateY(-6px);
    box-shadow:0 20px 40px rgba(0,0,0,.1);
}

/* ================= CARD TITLE ================= */

.agenda-day h4{
    font-weight:700;
    color:#0f172a;
}

/* ================= LIST STYLE ================= */

.agenda-day ul{
    padding-left:0;
    list-style:none;
}

.agenda-day li{
    padding:10px 0;
    border-bottom:1px solid #f1f5f9;
    font-weight:500;
    color:#334155;
}

.agenda-day li:last-child{
    border-bottom:none;
}

/* ================= ICON STYLE ================= */

.agenda-day i{
    font-size:18px;
}

/* ================= RESPONSIVE ================= */

/* tablet */

@media (max-width:992px){

#agenda{
    padding:80px 0;
}

#agenda .section-title{
    font-size:2rem;
}

}

/* mobile */

@media (max-width:768px){

#agenda{
    padding:70px 0;
}

.agenda-day{
    padding:24px;
}

#agenda .section-title{
    font-size:1.8rem;
}

}

/* small mobile */

@media (max-width:480px){

.agenda-day{
    padding:20px;
}

.agenda-day li{
    font-size:14px;
}

#agenda .section-title{
    font-size:1.6rem;
}

}
/* ================= SPEAKERS SECTION ================= */

#keynotes{
    background:linear-gradient(135deg,#f8fafc,#eef2ff);
    padding:100px 0;
    position:relative;
    overflow:hidden;
}

/* background glow */

#keynotes::before{
    content:"";
    position:absolute;
    width:400px;
    height:400px;
    background:radial-gradient(circle,#6366f1 0%,transparent 70%);
    top:-150px;
    left:-120px;
    opacity:.12;
    filter:blur(100px);
}

#keynotes::after{
    content:"";
    position:absolute;
    width:400px;
    height:400px;
    background:radial-gradient(circle,#06b6d4 0%,transparent 70%);
    bottom:-150px;
    right:-120px;
    opacity:.12;
    filter:blur(100px);
}

/* ================= SECTION TITLE ================= */

.section-title{
    font-weight:800;
    font-size:2.2rem;
    color:#0f172a;
}

/* ================= SPEAKER CARD ================= */

#keynotes .card{
    border-radius:18px;
    background:rgba(255,255,255,0.7);
    backdrop-filter:blur(20px);
    transition:all .4s ease;
}

#keynotes .card:hover{
    transform:translateY(-8px);
    box-shadow:0 20px 40px rgba(0,0,0,.1);
}

/* ================= ICON AVATAR ================= */

.avatar-circle{
    width:70px;
    height:70px;
    margin:auto;
    border-radius:50%;
    display:flex;
    align-items:center;
    justify-content:center;
    color:white;

    background:linear-gradient(135deg,#6366f1,#06b6d4);
    box-shadow:0 8px 20px rgba(99,102,241,.3);
}

/* ================= TEXT ================= */

.card-title{
    font-weight:600;
    color:#0f172a;
}

.card-text{
    font-size:14px;
}

/* ================= RESPONSIVE ================= */

/* Tablet */

@media (max-width:992px){

.section-title{
    font-size:2rem;
}

}

/* Mobile */

@media (max-width:768px){

#keynotes{
    padding:70px 0;
}

.section-title{
    font-size:1.8rem;
}

.avatar-circle{
    width:60px;
    height:60px;
}

}

/* Small mobile */

@media (max-width:480px){

.section-title{
    font-size:1.6rem;
}

.card-text{
    font-size:13px;
}

.avatar-circle{
    width:55px;
    height:55px;
}

}
/* ================= HACKATHON SECTION ================= */

.hackathon-section{
    position:relative;
    background:linear-gradient(135deg,#f8fafc,#eef2ff);
    padding:100px 0;
    overflow:hidden;
}

/* soft AI glow background */



/* ================= TITLE ================= */

.hackathon-title{
    font-size:2.3rem;
    font-weight:800;
    color:#0f172a;
    margin-bottom:15px;
}

.hackathon-desc{
    color:#475569;
    margin-bottom:25px;
}

/* ================= FEATURES ================= */

.hackathon-features{
    list-style:none;
    padding:0;
}

.hackathon-features li{
    margin-bottom:12px;
    font-weight:500;
    color:#1e293b;
    display:flex;
    align-items:center;
    gap:10px;
    transition:.3s;
}

.hackathon-features li i{
    color:#22c55e;
    font-size:18px;
}

.hackathon-features li:hover{
    transform:translateX(6px);
}

/* ================= PRIZE BOX ================= */

.prize-box{
    background:linear-gradient(135deg,#6366f1,#4f46e5);
    color:white;
    padding:20px;
    border-radius:16px;
    margin-top:25px;
    width:fit-content;
    box-shadow:0 12px 30px rgba(79,70,229,.35);
}

.prize-label{
    font-size:12px;
    letter-spacing:1px;
    opacity:.8;
}

.prize-value{
    font-size:26px;
    font-weight:700;
    margin-top:5px;
}

.prize-sub{
    font-size:16px;
    margin:2px 0;
}

/* ================= BUTTON ================= */

.hackathon-btn{
    background:linear-gradient(135deg,#6366f1,#06b6d4);
    color:white;
    border:none;
    border-radius:30px;
    padding:12px 28px;
    font-weight:600;
    box-shadow:0 10px 25px rgba(99,102,241,.3);
}

.hackathon-btn:hover{
    transform:translateY(-3px);
    color:white;
}

/* ================= RIGHT CARD ================= */

.hackathon-card{
    background:rgba(255,255,255,0.7);
    backdrop-filter:blur(20px);
    border-radius:22px;
    padding:40px 30px;
    box-shadow:0 20px 40px rgba(0,0,0,.08);
    border:1px solid rgba(255,255,255,0.6);
    transition:.4s;
}

.hackathon-card:hover{
    transform:translateY(-6px);
}

/* ================= CARD TEXT ================= */

.flagship-title{
    font-weight:700;
    color:#0f172a;
    margin-bottom:10px;
}

.flagship-desc{
    color:#64748b;
    font-size:15px;
}

/* ================= PRIZE HIGHLIGHT ================= */

.prize-highlight{
    margin-top:20px;
    font-weight:700;
    font-size:20px;
    background:linear-gradient(135deg,#6366f1,#06b6d4);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

/* ================= CARD BUTTONS ================= */
.hackathon-buttons{
    display:flex;
    justify-content:center;
    gap:15px;
}
.register-btn1{
    background: #6366f1;
    color: #ffffff;
    border-radius: 30px;
    padding: 12px 28px;
    margin-right: 15px;
    border: none;
    font-size: 16px;
    font-weight: 500;
}

.register-btn1:hover{
    background:#4f46e5;
    color:white;
}

.rule-btn1{
    border: 2px solid #6366f1;
    color: #6366f1;
    border-radius: 30px;
    padding: 12px 28px;
    font-size: 16px;
    font-weight: 500;
    background: transparent;
}

.rule-btn1:hover{
    background:#6366f1;
    color:white;
}

@media (max-width:576px){

    .hackathon-buttons{
        flex-direction:column;
        align-items:center;
    }

    .register-btn1,
    .rule-btn1{
        width:100%;
        text-align:center;
    }
}

@media (min-width:577px) and (max-width:991px){

    .register-btn1,
    .rule-btn1{
        font-size:15px;
        padding:11px 24px;
    }
}

@media (min-width:992px){

    .register-btn1,
    .rule-btn1{
        font-size:16px;
        padding:12px 28px;
    }
}



.register-btn{
    background:#6366f1;
    color:white;
    border-radius:25px;
    padding:10px 22px;
    margin-right:10px;
}

.rule-btn{
    border:2px solid #6366f1;
    color:#6366f1;
    border-radius:25px;
    padding:10px 22px;
}

.rule-btn:hover{
    background:#6366f1;
    color:white;
} button not properly working

/* ================= LARGE DESKTOP (1400px+) ================= */

@media (min-width:1400px){

.hackathon-title{
    font-size:2.6rem;
}

.flagship-title{
    font-size:1.8rem;
}

.prize-value{
    font-size:28px;
}

}


/* ================= LAPTOP (1200px) ================= */

@media (max-width:1200px){

.hackathon-title{
    font-size:2.1rem;
}

.hackathon-card{
    padding:35px 25px;
}

.prize-value{
    font-size:24px;
}

}


/* ================= TABLET (992px) ================= */

@media (max-width:992px){

.hackathon-section{
    padding:80px 0;
}

.hackathon-title{
    font-size:2rem;
}

.hackathon-desc{
    font-size:15px;
}

.hackathon-card{
    margin-top:30px;
}

.prize-box{
    margin-top:20px;
}

}


/* ================= SMALL TABLET (768px) ================= */

@media (max-width:768px){

.hackathon-section{
    padding:70px 0;
}

.hackathon-title{
    font-size:1.8rem;
}

.hackathon-desc{
    font-size:14px;
}

.hackathon-features li{
    font-size:14px;
}

.prize-value{
    font-size:22px;
}

.prize-sub{
    font-size:14px;
}

.hackathon-card{
    padding:30px 22px;
}

.flagship-title{
    font-size:1.4rem;
}

.prize-highlight{
    font-size:18px;
}

}


/* ================= MOBILE (576px) ================= */

@media (max-width:576px){

.hackathon-section{
    padding:60px 0;
}

.hackathon-title{
    font-size:1.6rem;
}

.hackathon-desc{
    font-size:13px;
}

.hackathon-features li{
    font-size:13px;
}

.prize-box{
    padding:16px;
}

.prize-value{
    font-size:20px;
}

.prize-sub{
    font-size:13px;
}

.hackathon-card{
    padding:25px 18px;
}

.flagship-title{
    font-size:1.3rem;
}

.prize-highlight{
    font-size:16px;
}

.hackathon-buttons{
    display:flex;
    flex-direction:column;
    gap:10px;
}

.register-btn,
.rule-btn{
    width:100%;
    text-align:center;
}

.hackathon-btn{
    width:100%;
    text-align:center;
}

}


/* ================= SMALL MOBILE (400px) ================= */

@media (max-width:400px){

.hackathon-title{
    font-size:1.4rem;
}

.flagship-title{
    font-size:1.2rem;
}

.prize-highlight{
    font-size:15px;
}

.hackathon-features li{
    font-size:12px;
}

}


/* ================= SPONSORS SECTION ================= */

#sponsors{
    background:linear-gradient(135deg,#f8fafc,#eef2ff);
    padding:100px 0;
    position:relative;
    overflow:hidden;
}

/* background glow */

#sponsors::before{
    content:"";
    position:absolute;
    width:400px;
    height:400px;
    background:radial-gradient(circle,#6366f1 0%,transparent 70%);
    top:-150px;
    left:-120px;
    opacity:.12;
    filter:blur(100px);
}

#sponsors::after{
    content:"";
    position:absolute;
    width:350px;
    height:350px;
    background:radial-gradient(circle,#06b6d4 0%,transparent 70%);
    bottom:-120px;
    right:-120px;
    opacity:.12;
    filter:blur(100px);
}

/* ================= SPONSOR CARD ================= */

.sponsor-card{
    background:white;
    border-radius:16px;
    padding:20px;
    text-align:center;
    transition:all .35s ease;
    border:1px solid #f1f5f9;
}

/* hover animation */

.sponsor-card:hover{
    transform:translateY(-6px);
    box-shadow:0 18px 35px rgba(0,0,0,.1);
}

/* ================= LOGO IMAGE ================= */


/* ================= GRID SPACING ================= */

.sponsors-grid{
    margin-top:20px;
}

/* ================= RESPONSIVE ================= */

/* tablet */

@media (max-width:992px){

#sponsors{
    padding:80px 0;
}

.sponsor-card{
    padding:18px;
}

}

/* mobile */

@media (max-width:768px){

#sponsors{
    padding:70px 0;
}

.sponsor-card img{
    max-height:50px;
}

}

/* small mobile */

@media (max-width:480px){

.sponsor-card{
    padding:16px;
}

.sponsor-card img{
    max-height:45px;
}

}


/* ================= CONTACT SECTION ================= */

#contact{
    padding:100px 0;
    position:relative;
    overflow:hidden;
}

/* background glow */

#contact::before{
    content:"";
    position:absolute;
    width:350px;
    height:350px;
    background:radial-gradient(circle,#6366f1 0%,transparent 70%);
    top:-120px;
    right:-120px;
    opacity:.12;
    filter:blur(100px);
}

#contact::after{
    content:"";
    position:absolute;
    width:350px;
    height:350px;
    background:radial-gradient(circle,#06b6d4 0%,transparent 70%);
    bottom:-120px;
    left:-120px;
    opacity:.12;
    filter:blur(100px);
}

/* ================= TEXT ================= */

#contact .section-title{
    font-weight:800;
    font-size:2.2rem;
    color:#0f172a;
}

#contact p{
    color:#475569;
}

/* contact icons */

#contact i{
    font-size:18px;
}

/* ================= BUTTON ================= */

#contact .btn-primary{
    background:linear-gradient(135deg,#6366f1,#06b6d4);
    border:none;
    border-radius:30px;
    font-weight:600;
    box-shadow:0 10px 25px rgba(99,102,241,.3);
    transition:.3s;
}

#contact .btn-primary:hover{
    transform:translateY(-3px);
    box-shadow:0 16px 35px rgba(99,102,241,.35);
}

/* ================= RESPONSIVE ================= */

/* tablet */

@media (max-width:992px){

#contact{
    padding:80px 0;
}

#contact .section-title{
    font-size:2rem;
}

}

/* mobile */

@media (max-width:768px){

#contact{
    padding:70px 0;
}

#contact .section-title{
    font-size:1.8rem;
}

.col-lg-5{
    text-align:left !important;
}

#contact .btn{
    width:100%;
    margin-top:10px;
}

}

/* small mobile */

@media (max-width:480px){

#contact .section-title{
    font-size:1.6rem;
}

#contact p{
    font-size:14px;
}

}

/* ------------------------------------ NAVBAR -------------------------------------------*/
/* =========================================
SUMMIT NAVBAR
========================================= */

#summit-navbar{
    background: rgba(255, 255, 255, 0.82);
    backdrop-filter: blur(20px) saturate(180%);
    border-bottom: 1px solid rgba(102, 126, 234, 0.15);
    transition: all .35s ease;
    padding: 14px 0;
    z-index: 9999;
}

#summit-navbar.scrolled{
    padding:8px 0;
    box-shadow:0 8px 30px rgba(15,23,42,0.18);
}


/* =========================================
CONTAINER ALIGNMENT
========================================= */

#summit-navbar .container{
    display:flex;
    align-items:center;
    justify-content:space-between;
}

/* Bootstrap controls collapse display */
#navbarNav{
    width:100%;
}


/* =========================================
LOGO FIX
========================================= */

.navbar-brand{
    display:flex;
    align-items:center;
    gap:12px;
    margin:0;
    padding:0;
}

.logo-circle{
    width:42px;
    height:42px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:10px;
    overflow:hidden;
    padding:0;
}

.logo-circle img{
    width:100%;
    height:100%;
    object-fit:contain;
    display:block;
}

.logo-circle img.rounded-5{
    border-radius:8px !important;
}

.brand-text{
    font-weight:800;
    font-size:1.15rem;
    line-height:1;
    background:linear-gradient(135deg,#4f46e5,#7c3aed);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    padding: 10px 0px;
}


/* =========================================
NAV LINKS
========================================= */

.navbar-nav{
    display:flex;
    align-items:center;
    gap:8px;
}

.nav-item{
    display:flex;
    align-items:center;
}

.nav-link{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:44px;
    padding:0 18px !important;
    color:#64748b !important;
    font-weight:500;
    border-radius:999px;
    transition:all .25s ease;
}

.nav-link:hover{
    color:#4f46e5 !important;
    background:rgba(79,70,229,0.08);
    transform:translateY(-1px);
    box-shadow:0 6px 18px rgba(79,70,229,0.15);
}

.nav-link i{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    font-size:14px;
    line-height:1;
    opacity:.9;
}


/* =========================================
REGISTER BUTTON
========================================= */

.navbar-nav .btn-gradient{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    height:44px;
    padding:0 22px !important;
    border-radius:999px;
    position:relative;
    overflow:hidden;
}

.btn-gradient{
    background: linear-gradient(135deg,#6366f1,#06b6d4);
    color:#fff;
    border:none;
    font-size:14px;
    transition:all .35s ease;
    box-shadow:0 6px 18px rgba(99,102,241,.35);
}

.btn-gradient:hover{
    color:#fff;
    transform:translateY(-2px);
    box-shadow:0 10px 28px rgba(99,102,241,.45);
    background: linear-gradient(135deg,#4f46e5,#0891b2);
}

.btn-gradient:active{
    transform:scale(.96);
}

.btn-gradient::before{
    content:"";
    position:absolute;
    top:0;
    left:-75%;
    width:50%;
    height:100%;
    background:linear-gradient(
        120deg,
        transparent,
        rgba(255,255,255,.35),
        transparent
    );
    transition:all .6s;
}

.btn-gradient:hover::before{
    left:120%;
}


/* =========================================
MOBILE TOGGLER
========================================= */

.navbar-toggler{
    border:none;
    outline:none;
    box-shadow:none;
    background:none;
    padding:8px 10px;
    border-radius:10px;
}

.navbar-toggler:focus{
    box-shadow:none;
}


/* =========================================
DESKTOP NAVBAR LAYOUT
========================================= */

@media (min-width:992px){

#navbarNav{
    display:flex !important;
    align-items:center;
    justify-content:space-between;
}

.navbar-nav{
    flex:1;
    justify-content:center;
}

.navbar-nav .btn-gradient{
    margin-left:auto;
}

}


/* =========================================
MOBILE MENU
========================================= */

@media (max-width:991px){

.navbar-collapse{
    background:rgba(255,255,255,0.96);
    backdrop-filter:blur(20px);
    border-radius:18px;
    margin-top:14px;
    padding:20px;
    box-shadow:0 20px 50px rgba(0,0,0,0.15);
}

.navbar-nav{
    width:100%;
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
}

.nav-link{
    width:100%;
    justify-content:flex-start;
    height:auto;
    padding:12px 16px !important;
}

.navbar-nav .btn-gradient{
    width:100%;
    margin-left:0;
    margin-top:10px;
}

}


/* =========================================
SMALL MOBILE
========================================= */

@media (max-width:480px){

.logo-circle{
    width:36px;
    height:36px;
}

.brand-text{
    font-size:.95rem;
}

}
/* --------------------------------------------------------------       footer           ----------------------------------- */
/* ================= FOOTER ================= */

.site-footer{
    background:linear-gradient(135deg,#0f172a,#1e293b);
    color:#e2e8f0;
    position:relative;
    overflow:hidden;
}

.footer_down{
    text-decoration: none;
    align-items: center;
}

.footer_down:hover{
    text-decoration: underline;
}

a{
    text-decoration: none;
    color:inherit;
}

/* glow background */

.site-footer::before{
    content:"";
    position:absolute;
    width:400px;
    height:400px;
    background:radial-gradient(circle,#6366f1 0%,transparent 70%);
    top:-150px;
    left:-120px;
    opacity:.15;
    filter:blur(120px);
}

.site-footer::after{
    content:"";
    position:absolute;
    width:350px;
    height:350px;
    background:radial-gradient(circle,#06b6d4 0%,transparent 70%);
    bottom:-150px;
    right:-120px;
    opacity:.15;
    filter:blur(120px);
}

/* ================= LOGO ================= */

.footer-logo-circle{
    width:45px;
    height:45px;
    border-radius:50%;
    background:white;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:5px;
}

/* ================= TEXT ================= */

.site-footer h5{
    color:white;
}

.site-footer h6{
    color:#e2e8f0;
    letter-spacing:1px;
}

/* ================= LINKS ================= */

.footer-links li{
    margin-bottom:8px;
}

.footer-links a{
    text-decoration:none;
    color:#cbd5f5;
    font-size:14px;
    transition:all .3s;
}

.footer-links a:hover{
    color:#60a5fa;
    padding-left:4px;
}

/* ================= SOCIAL ICONS ================= */

.footer-social{
    display:flex;
    gap:10px;
}

.footer-social a{
    width:36px;
    height:36px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:50%;
    background:rgba(255,255,255,0.08);
    color:#e2e8f0;
    font-size:14px;
    transition:all .3s;
}

.footer-social a:hover{
    background:linear-gradient(135deg,#6366f1,#06b6d4);
    color:white;
    transform:translateY(-3px);
}

/* ================= DIVIDER ================= */

.site-footer hr{
    border-color:rgba(255,255,255,0.08);
}

/* ================= COPYRIGHT ================= */

.site-footer span{
    font-size:13px;
    color:#94a3b8;
}

/* ================= RESPONSIVE ================= */

@media (max-width:992px){

.site-footer{
    padding-top:60px;
}

}

@media (max-width:768px){

.site-footer{
    text-align:center;
}

.footer-social{
    justify-content:center;
}

.footer-links{
    padding-left:0;
}

}

@media (max-width:480px){

.site-footer h5{
    font-size:18px;
}

.site-footer h6{
    font-size:14px;
}

.footer-links a{
    font-size:13px;
}

.site-footer span{
    font-size:12px;
}

}

/* ---------------------------------Tickets------------------------------- */
.tickets-section {
    color: #e5e7eb;
}

.tickets-section .section-title {
    text-align: center;
}

.ticket-card {
    background: #020617;
    border-radius: 1rem;
    padding: 1.5rem 1.5rem 1.75rem;
    border: 1px solid rgba(148, 163, 184, 0.4);
    position: relative;
    display: flex;
    flex-direction: column;
    height: 100%;
}

.ticket-featured {
    border-color: #6366f1;
    box-shadow: 0 16px 40px rgba(79, 70, 229, 0.4) !important;
}

.ticket-badge {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: linear-gradient(135deg, #f97316, #facc15);
    color: #0f172a;
    font-size: 0.75rem;
    font-weight: 700;
    margin-top: 50px;
    padding: 0.25rem 0.75rem;
    border-radius: 999px;
    text-transform: uppercase;
}

.ticket-header {
    margin-bottom: 1rem;
    color: #ffffff;
}

.ticket-title {
    font-size: 1.1rem;
    font-weight: 700;
    margin-top: 0.15rem;
    margin-bottom: 0.15rem;
    color: #f9fafb;
}

.ticket-subtitle {
    font-size: 0.9rem;
    color: #9ca3af;
}

.ticket-price {
    margin-bottom: 1rem;
}

.ticket-price .amount {
    font-size: 1.7rem;
    font-weight: 700;
    color: #f9fafb;
    margin-right: 0.35rem;
}

.ticket-price .label {
    font-size: 0.85rem;
    color: #9ca3af;
}

.ticket-features {
    list-style: none;
    padding-left: 0;
    margin-bottom: 1.5rem;
    flex-grow: 1;
}

.ticket-features li {
    font-size: 0.9rem;
    color: #cbd5f5;
    margin-bottom: 0.4rem;
    display: flex;
    align-items: center;
}

.ticket-features i {
    color: #22c55e;
    margin-right: 0.5rem;
}

/* Buttons */
.ticket-btn {
    width: 100%;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.7);
    background: transparent;
    color: #e5e7eb;
    font-weight: 600;
    padding: 0.6rem 1rem;
    font-size: 0.95rem;
    transition: all 0.2s ease;
}

.ticket-btn:hover {
    background: linear-gradient(135deg, #4f46e5, #7c3aed);
    transform: translateY(-2px);
    color: #ffff;
}

.ticket-btn-primary {
   width: 100%;
    border-radius: 999px;
    border: 1px solid rgba(148, 163, 184, 0.7);
    background: transparent;
    color: #e5e7eb;
    font-weight: 600;
    padding: 0.6rem 1rem;
    font-size: 0.95rem;
    transition: all 0.2s ease;
}

.ticket-btn-primary:hover {
    box-shadow: 0 14px 32px rgba(79, 70, 229, 0.6);
    color: #ffff;
}

/* Responsive */
@media (max-width: 767.98px) {
    .ticket-card {
        padding: 1.25rem 1.25rem 1.5rem;
    }
}


/* -----------------------------Speakers------------------------- */

/* ================= HERO ================= */

.speakers-hero{
    padding-bottom:2rem;
    text-align:center;
}

.speakers-label{
    letter-spacing:.15em;
    font-size:.75rem;
    color:#6366f1;
    text-transform:uppercase;
}

.speakers-title{
    font-size:clamp(2.2rem,4vw,2.8rem);
    font-weight:800;
    background:linear-gradient(90deg,#6366f1,#06b6d4);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

.speakers-subtitle{
    max-width:640px;
    margin-inline:auto;
    color:#64748b;
}


/* ================= SECTION BACKGROUND ================= */

.speakers-section{
    position:relative;
    background:
    radial-gradient(circle at 10% 20%, rgba(99,102,241,.15), transparent 50%),
    radial-gradient(circle at 90% 70%, rgba(6,182,212,.15), transparent 50%),
    linear-gradient(135deg,#f8fafc,#eef2ff);
    overflow:hidden;
}


/* ================= GRID ================= */

#speakers-grid{
    margin-top:1rem;
}


/* ================= SPEAKER CARD ================= */

.speaker-card{
    position:relative;
    display:flex;
    gap:1rem;
    align-items:center;

    padding:1.4rem 1.6rem;
    border-radius:18px;

    background:#ffffff;
    border:1px solid #e5e7eb;

    overflow:hidden;

    transform-origin:center;
    transform:translateY(30px) scale(.96);
    opacity:0;

    transition:
    transform .5s ease,
    opacity .5s ease,
    box-shadow .3s ease,
    border-color .3s ease;
}

/* Gradient glow layer */

.speaker-card::before{
    content:"";
    position:absolute;
    inset:0;

    background:radial-gradient(
    circle at top right,
    rgba(99,102,241,.25),
    transparent 60%
    );

    opacity:0;
    transition:opacity .35s ease;
}

.speaker-card:hover::before{
    opacity:1;
}

/* Hover effect */

.speaker-card:hover{
    transform:translateY(-8px) scale(1.02);
    border-color:#6366f1;
    box-shadow:0 15px 40px rgba(0,0,0,.08);
}

/* Scroll animation */

.speaker-card.speaker-visible{
    opacity:1;
    transform:translateY(0) scale(1);
}


/* ================= AVATAR ================= */

.speaker-avatar{
    position:relative;

    width:80px;
    height:80px;
    min-width:80px;

    border-radius:50%;
    overflow:hidden;

    background:#f1f5f9;
}

.speaker-img{
    width:100%;
    height:100%;
    object-fit:cover;
}


/* ================= LINKEDIN HOVER ================= */

.speaker-social{
    position:absolute;
    inset:0;

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

    background:rgba(10,102,194,.9);

    color:#ffffff;
    font-size:22px;

    opacity:0;
    transition:.3s ease;
}

.speaker-avatar:hover .speaker-social{
    opacity:1;
}


/* ================= LINKEDIN BUTTON ================= */

.linkedin-btn{
    margin-top:10px;
    padding:7px 14px;

    border:none;
    border-radius:6px;

    background:#0A66C2;
    color:#ffffff;

    font-size:.85rem;
    cursor:pointer;

    transition:.25s ease;
}

.linkedin-btn:hover{
    background:#004182;
}


/* ================= CONTENT ================= */

.speaker-content{
    flex:1;
}

.speaker-name{
    font-size:1.1rem;
    font-weight:600;
    margin-bottom:.15rem;
    color:#0f172a;
}

.speaker-role{
    font-size:.9rem;
    color:#6366f1;
    margin-bottom:.15rem;
}

.speaker-org{
    font-size:.85rem;
    color:#64748b;
    margin-bottom:.4rem;
}


/* ================= TAGS ================= */

.speaker-tags span{
    display:inline-flex;
    align-items:center;
    justify-content:center;

    padding:.15rem .5rem;
    border-radius:999px;

    font-size:.72rem;

    margin-right:.25rem;
    margin-bottom:.2rem;

    background:#eef2ff;
    color:#4f46e5;

    transition:.25s ease;
}

.speaker-tags span:hover{
    background:#6366f1;
    color:#ffffff;
}


/* ================= SCROLL ANIMATION ================= */

[data-animate]{
    opacity:0;
    transform:translateY(40px);
    transition:.6s ease;
}

.animate-show{
    opacity:1;
    transform:translateY(0);
}


/* ================= RESPONSIVE ================= */

@media (max-width:991px){

.speaker-card{
    padding:1.2rem;
}

}

@media (max-width:768px){

.speaker-avatar{
    width:64px;
    height:64px;
    min-width:64px;
}

.speaker-name{
    font-size:1rem;
}

}

@media (max-width:575px){

.speaker-card{
    flex-direction:row;
    align-items:flex-start;
}

.speaker-tags span{
    font-size:.65rem;
}

}

/*------------------------- Agenda --------------------------*/
/* Hero */
.agenda-hero {
    padding-bottom: 1.5rem;
}

.agenda-label {
    letter-spacing: 0.15em;
    font-size: 0.75rem;
    color: #6366f1;
}

.agenda-title {
    font-size: clamp(2.2rem, 4vw, 2.8rem);
    font-weight: 800;
    color: #0f172a;
}

.agenda-subtitle {
    max-width: 640px;
    margin-inline: auto;
    color: #64748b;
}

/* Tabs bar */
.agenda-section {
    background: #f8fafc;
}

.agenda-tabs {
    display: inline-flex;
    border-radius: 999px;
    background: #eef2ff;
    border: 1px solid #e5e7eb;
    padding: 0.25rem;
}

.agenda-tab {
    border: none;
    background: transparent;
    color: #475569;
    font-weight: 500;
    padding: 0.5rem 1.5rem;
    border-radius: 999px;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 0.95rem;
}

.agenda-tab.active {
    background: linear-gradient(135deg, #6366f1, #06b6d4);
    color: #ffffff;
    box-shadow: 0 8px 20px rgba(99,102,241,0.35);
}

/* Day panels */
.agenda-day {
    display: none;
    margin-top: 2rem;
    animation: fadeIn 0.3s ease;
}

.agenda-day.active {
    display: block;
}

.agenda-day-header h2 {
    font-size: 1.4rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
    color: #0f172a;
}

.agenda-day-header p {
    color: #64748b;
}

/* Timeline */
.agenda-timeline {
    margin-top: 1.5rem;
    border-left: 2px solid #e2e8f0;
    padding-left: 1.2rem;
    position: relative;
}

.agenda-item {
    position: relative;
    margin-bottom: 1.5rem;
    padding-left: 0.5rem;
}

.agenda-item::before {
    content: '';
    position: absolute;
    left: -1.65rem;
    top: 0.35rem;
    width: 12px;
    height: 12px;
    border-radius: 999px;
    background: #6366f1;
    box-shadow: 0 0 0 4px rgba(99,102,241,0.25);
}

.agenda-time {
    font-size: 0.85rem;
    color: #6366f1;
    margin-bottom: 0.1rem;
}

.agenda-details h3 {
    font-size: 1.05rem;
    font-weight: 600;
    margin-bottom: 0.2rem;
    color: #0f172a;
}

.agenda-details p {
    font-size: 0.9rem;
    color: #475569;
    margin-bottom: 0.2rem;
}

.agenda-tag {
    font-size: 0.8rem;
    color: #64748b;
}

/* Download button */
.agenda-download {
    margin-top: 2rem;
    text-align: center;
}

.agenda-download a.btn-download {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    border-radius: 999px;
    border: 1px solid #e5e7eb;
    background: #ffffff;
    color: #1e293b;
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 600;
    transition: all 0.2s ease;
}

.agenda-download a.btn-download i {
    font-size: 1rem;
}

.agenda-download a.btn-download:hover {
    background: linear-gradient(135deg, #6366f1, #06b6d4);
    border-color: transparent;
    color: #fff;
    box-shadow: 0 10px 25px rgba(99,102,241,0.35);
    transform: translateY(-2px);
}

/* Animation */
@keyframes fadeIn {
    from { opacity: 0; transform: translateY(8px); }
    to   { opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 575.98px) {
    .agenda-timeline {
        border-left-width: 1px;
        padding-left: 1.25rem;
    }
}

/* ------------------------------- SPONSORS ------------------------------- */


/* ================= HERO ================= */

.sponsors-hero{
    text-align:center;
    padding-bottom:40px;
}

.sponsors-label{
    letter-spacing:.18em;
    font-size:.75rem;
    font-weight:600;
    text-transform:uppercase;
    color:#6366f1;
}

.sponsors-title{
    font-size:clamp(2.2rem,4vw,3rem);
    font-weight:800;
    margin-bottom:12px;

    background:linear-gradient(90deg,#6366f1,#06b6d4);
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
}

.sponsors-subtitle{
    max-width:640px;
    margin-inline:auto;
    font-size:.95rem;
    line-height:1.6;
    color:#64748b;
}



/* ================= SECTION BACKGROUND ================= */

.sponsors-section{
    position:relative;
    padding-top:40px;

    background:
    radial-gradient(circle at 10% 20%, rgba(99,102,241,.08), transparent 50%),
    radial-gradient(circle at 90% 70%, rgba(6,182,212,.08), transparent 50%),
    linear-gradient(135deg,#f8fafc,#eef2ff);
}



/* ================= TIER TITLE ================= */

.tier-title{
    font-size:1.6rem;
    font-weight:700;
    margin-bottom:10px;
    color:#0f172a;
}

.tier-label{
    font-size:.85rem;
    color:#64748b;
}



/* ================= SPONSOR CARD ================= */

.sponsor-card{
    position:relative;

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

    padding:24px;

    border-radius:18px;
    border:1px solid #e5e7eb;

    background:rgba(255,255,255,.9);
    backdrop-filter:blur(6px);

    overflow:hidden;

    transition:
    transform .35s ease,
    box-shadow .35s ease,
    border-color .35s ease;
}


/* soft gradient glow */

.sponsor-card::before{
    content:"";
    position:absolute;
    inset:0;

    background:radial-gradient(
        circle at top right,
        rgba(99,102,241,.15),
        transparent 60%
    );

    opacity:0;
    transition:opacity .35s ease;
}

.sponsor-card:hover::before{
    opacity:1;
}


/* hover animation */

.sponsor-card:hover{
    transform:translateY(-8px);
    border-color:#6366f1;

    box-shadow:
    0 15px 40px rgba(0,0,0,.08),
    0 5px 15px rgba(99,102,241,.12);
}



/* ================= LARGE CARD ================= */

.sponsor-card-large{
    padding:32px;
}



/* ================= LOGO STYLE ================= */

.sponsor-card img{
    max-height:65px;
    width:auto;
    object-fit:contain;
    transition:
    filter .35s ease,
    opacity .35s ease,
    transform .35s ease;
}

.sponsor-card:hover img{
    filter:grayscale(0%);
    opacity:1;
    transform:scale(1.05);
}



/* ================= CTA SECTION ================= */

.sponsors-cta{
    margin-top:50px;
}

.sponsors-cta .btn{
    border-radius:999px;
    font-weight:600;
    font-size:.9rem;
    border:1px solid #6366f1;
    padding:11px 28px;
    transition:all .3s ease;
}

.sponsors-cta .btn:hover{
    background:linear-gradient(135deg,#6366f1,#06b6d4);
    color:white;
    border-color:transparent;

    box-shadow:0 10px 25px rgba(99,102,241,.35);
}



/* =====================================================
   EXTRA SMALL DEVICES (Small Phones)
   320px – 480px
===================================================== */

@media (max-width:480px){

.sponsors-title{
    font-size:1.8rem;
}

.sponsors-subtitle{
    font-size:.85rem;
}

.sponsor-card{
    padding:16px;
}

.sponsor-card img{
    max-height:45px;
}

.tier-title{
    font-size:1.2rem;
}

.sponsors-cta .btn{
    padding:10px 22px;
    font-size:.85rem;
}

}


/* =====================================================
   SMALL DEVICES (Phones)
   481px – 767px
===================================================== */

@media (min-width:481px) and (max-width:767px){

.sponsors-title{
    font-size:2rem;
}

.sponsors-subtitle{
    font-size:.9rem;
}

.sponsor-card{
    padding:18px;
}

.sponsor-card img{
    max-height:50px;
}

.tier-title{
    font-size:1.3rem;
}

}


/* =====================================================
   MEDIUM DEVICES (Tablets)
   768px – 991px
===================================================== */

@media (min-width:768px) and (max-width:991px){

.sponsors-title{
    font-size:2.3rem;
}

.sponsor-card{
    padding:20px;
}

.sponsor-card img{
    max-height:55px;
}

.tier-title{
    font-size:1.45rem;
}

}


/* =====================================================
   LARGE DEVICES (Laptops)
   992px – 1199px
===================================================== */

@media (min-width:992px) and (max-width:1199px){

.sponsors-title{
    font-size:2.6rem;
}

.sponsor-card-large{
    padding:28px;
}

.sponsor-card img{
    max-height:60px;
}

}


/* =====================================================
   EXTRA LARGE DEVICES (Desktop)
   1200px – 1399px
===================================================== */

@media (min-width:1200px) and (max-width:1399px){

.sponsors-title{
    font-size:2.9rem;
}

.sponsor-card img{
    max-height:65px;
}

}


/* =====================================================
   ULTRA LARGE SCREENS (4K / Wide Monitors)
   1400px+
===================================================== */

@media (min-width:1400px){

.sponsors-title{
    font-size:3.2rem;
}

.sponsors-subtitle{
    font-size:1rem;
}

.sponsor-card{
    padding:28px;
}

.sponsor-card img{
    max-height:70px;
}

}
/* --------------------------------Venues----------------------------- */

/* ======================================
VENUE HERO SECTION
====================================== */

.venue-hero{
    padding:120px 0 80px;
    background:linear-gradient(180deg,#f8fafc,#ffffff);
}

.venue-label{
    color:#6366f1;
    font-weight:600;
    letter-spacing:1px;
    font-size:14px;
}

.venue-title{
    font-size:42px;
    font-weight:700;
    color:#0f172a;
}

.venue-subtitle{
    max-width:720px;
    margin:auto;
    font-size:17px;
    color:#475569;
}


/* ======================================
VENUE SECTION
====================================== */

.venue-section{
    background:#ffffff;
}


/* ======================================
VENUE CARD
====================================== */

.venue-card{
    background:#ffffff;
    border-radius:14px;
    padding:35px;
    border:1px solid #e2e8f0;
    transition:0.3s;
}

.venue-card:hover{
    transform:translateY(-4px);
    box-shadow:0 12px 35px rgba(0,0,0,0.07);
}

.venue-card h2{
    font-weight:700;
    color:#0f172a;
}


/* ======================================
VENUE LIST
====================================== */

.venue-list li{
    display:flex;
    align-items:flex-start;
    margin-bottom:12px;
    font-size:15px;
    color:#475569;
}

.venue-list i{
    margin-top:4px;
}


/* ======================================
MAP CARD
====================================== */

.venue-map-card{
    background:#ffffff;
    border-radius:14px;
    padding:35px;
    border:1px solid #e2e8f0;
    transition:0.3s;
}

.venue-map-card:hover{
    transform:translateY(-4px);
    box-shadow:0 12px 35px rgba(0,0,0,0.07);
}

.venue-map-card h2{
    font-weight:700;
    color:#0f172a;
}


/* ======================================
VENUE SPACES CARDS
====================================== */

.venue-space-card{
    background:#f8fafc;
    border-radius:12px;
    padding:25px;
    border:1px solid #e2e8f0;
    transition:0.3s;
}

.venue-space-card:hover{
    transform:translateY(-5px);
    background:#ffffff;
    box-shadow:0 10px 30px rgba(0,0,0,0.06);
}

.venue-space-card h5{
    font-weight:600;
    color:#0f172a;
    margin-bottom:8px;
}

.venue-space-card p{
    font-size:14px;
}


/* ======================================
RESPONSIVE DESIGN
====================================== */

@media (max-width:992px){

.venue-title{
    font-size:34px;
}

}

@media (max-width:768px){

.venue-title{
    font-size:28px;
}

.venue-subtitle{
    font-size:15px;
}

.venue-card,
.venue-map-card{
    padding:28px;
}

}

@media (max-width:480px){

.venue-hero{
    padding:90px 0 60px;
}

.venue-title{
    font-size:24px;
}

.venue-space-card{
    padding:20px;
}

}


/*------------------------------------------ Registration ---------------------------------*/

/* Hero with gradient + glow */
.reg-hero {
    padding-bottom: 2rem;
    background: radial-gradient(circle at top, #1d4ed8 0%, #020617 55%);
    position: relative;
    overflow: hidden;
}

.reg-hero::before {
    content: '';
    position: absolute;
    inset: -40%;
    background-image:
      radial-gradient(circle at 0% 0%, rgba(96, 165, 250,0.28) 0, transparent 55%),
      radial-gradient(circle at 80% 0%, rgba(244, 114, 182,0.22) 0, transparent 55%);
    opacity: 0.7;
    pointer-events: none;
}

.reg-hero .container {
    position: relative;
    z-index: 1;
}

.reg-label {
    letter-spacing: 0.16em;
    font-size: 0.75rem;
    color: #a5b4fc;
}

.reg-title {
    font-size: clamp(2.3rem, 4vw, 2.9rem);
    font-weight: 800;
}

.reg-subtitle {
    max-width: 640px;
    margin-inline: auto;
    color: #cbd5f5;
}

/* Section background */
.reg-section {
    background: #020617;
}

/* Form card with glow */
.reg-form {
    background: radial-gradient(circle at top left, rgba(37, 99, 235, 0.18), #020617 60%);
    border-radius: 1.5rem;
    padding: 2rem;
    border: 1px solid rgba(148, 163, 184, 0.6);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.9);
}

.reg-section-title {
    font-size: 1.1rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: #e5e7eb;
}

/* Inputs with smooth hover/focus */
.reg-form .form-label {
    font-size: 0.85rem;
    color: #cbd5f5;
}

.reg-form .form-control,
.reg-form .form-select {
    background: rgba(15, 23, 42, 0.9);
    color: #e5e7eb;
    border-radius: 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.7);
    font-size: 0.9rem;
    padding: 0.6rem 0.85rem;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, transform 0.1s ease;
}

.reg-form .form-control:hover,
.reg-form .form-select:hover {
    border-color: #818cf8;
}

.reg-form .form-control:focus,
.reg-form .form-select:focus {
    border-color: #6366f1;
    box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.6);
    background: rgba(15, 23, 42, 0.95);
    color: #e5e7eb;
    transform: translateY(-1px);
}

/* Textarea height */
#notes {
    min-height: 110px;
}

/* Team section highlight */
.reg-team {
    background: rgba(15, 23, 42, 0.85);
    border-radius: 1rem;
    padding: 1rem 1.25rem;
    border: 1px dashed rgba(129, 140, 248, 0.9);
    box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.9);
}

/* Side summary card */
.reg-summary-card {
    background: #020617;
    border-radius: 1.5rem;
    padding: 1.8rem 1.6rem;
    border: 1px solid rgba(148, 163, 184, 0.6);
    position: sticky;
    top: 100px;
}

.reg-summary-card h5 {
    font-weight: 700;
}

.reg-summary-card ul li + li {
    margin-top: 0.2rem;
}

/* Submit button styling */
#reg-submit {
    border-radius: 999px;
    background: linear-gradient(135deg, #4f46e5, #7c3aed);
    border: none;
    box-shadow: 0 10px 28px rgba(79, 70, 229, 0.6);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#reg-submit:hover {
    transform: translateY(-2px);
    box-shadow: 0 14px 36px rgba(79, 70, 229, 0.8);
}

/* Small note text */
.reg-form .small,
.reg-summary-card .small {
    color: #9ca3af;
}

/* Responsive */
@media (max-width: 991.98px) {
    .reg-form {
        padding: 1.5rem 1.25rem;
        margin-bottom: 1.5rem;
    }

    .reg-summary-card {
        position: static;
    }
}

@media (max-width: 575.98px) {
    .reg-hero {
        text-align: left;
    }
}


/* Base input style */
.form-control,
.form-select {
    background: rgba(15, 23, 42, 0.9);
    color: #e5e7eb;
    border-radius: 0.85rem;
    border: 1px solid rgba(148, 163, 184, 0.7);
    font-size: 0.9rem;
    padding: 0.6rem 0.85rem;
    transition:
        border-color 0.2s ease,
        box-shadow 0.2s ease,
        background 0.2s ease,
        transform 0.1s ease;
}

/* Hover state */
.form-control:hover,
.form-select:hover {
    border-color: #818cf8;
}

/* Focus animation: border + glow + slight lift */
.form-control:focus,
.form-select:focus {
    border-color: #6366f1;
    box-shadow: 0 0 0 1px rgba(99, 102, 241, 0.6);
    background: rgba(15, 23, 42, 0.95);
    color: #e5e7eb;
    transform: translateY(-1px);
    outline: none;
}

/*------------------------------- Hackthon Page -------------------------------*/


/* =========================================
HERO
========================================= */

.hack-hero{
    padding:120px 0 100px;
    background:
    linear-gradient(135deg,#ffffff,#eef2ff);
}

.hack-hero h1{
    color:#0f172a;
}

.hack-hero .lead{
    color:#475569;
}

.hack-hero small{
    color:#64748b;
}

/* buttons */

.btn-primary{
    background:linear-gradient(135deg,#6366f1,#4f46e5);
    border:none;
    border-radius:10px;
    font-weight:600;
}

.btn-primary:hover{
    background:linear-gradient(135deg,#4f46e5,#4338ca);
}

.btn-outline-light{
    border:2px solid #6366f1;
    color:#4f46e5;
    border-radius:10px;
}

.btn-outline-light:hover{
    background:#6366f1;
    color:white;
}

/* =========================================
STATS
========================================= */

.hack-stats h3{
    font-weight:700;
    color:#1e293b;
}

.hack-stats small{
    letter-spacing:1px;
}

/* =========================================
COUNTDOWN CARD
========================================= */

.hack-countdown-card{

    background:white;
    padding:30px;
    border-radius:16px;
    border:1px solid #e2e8f0;
}

.hack-countdown{

    display:flex;
    justify-content:space-between;
    margin-top:20px;
}

.hack-countdown div{

    text-align:center;
    background:#f1f5f9;
    padding:14px;
    border-radius:10px;
    width:70px;
}

.hack-countdown span{

    font-size:22px;
    font-weight:700;
    display:block;
}

.hack-countdown small{

    font-size:11px;
    color:#64748b;
}

/* =========================================
TRACK CARDS
========================================= */

.hack-track-card{

    background:white;
    border-radius:14px;
    padding:26px;
    border:1px solid #e2e8f0;
    transition:all .3s ease;
    height:100%;
}

.hack-track-card:hover{

    transform:translateY(-6px);
    box-shadow:0 12px 30px rgba(0,0,0,0.08);
}

.hack-track-card h5{

    font-weight:600;
    margin-bottom:10px;
}

.hack-track-card p{

    font-size:14px;
}

/* =========================================
TIMELINE
========================================= */

.hack-timeline-card{

    background:white;
    border-radius:14px;
    padding:28px;
    border:1px solid #e2e8f0;
    height:100%;
}

.hack-timeline-list{

    padding-left:18px;
}

.hack-timeline-list li{

    margin-bottom:10px;
    color:#475569;
}

/* =========================================
PRIZE CARDS
========================================= */

.prize-card{

    background:white;
    padding:28px;
    border-radius:16px;
    text-align:center;
    border:1px solid #e2e8f0;
    transition:.3s;
}

.prize-card:hover{

    transform:translateY(-6px);
    box-shadow:0 12px 30px rgba(0,0,0,0.08);
}

.prize-1{
    border-top:4px solid #facc15;
}

.prize-2{
    border-top:4px solid #94a3b8;
}

.prize-3{
    border-top:4px solid #fb923c;
}

.prize-card h5{

    font-weight:600;
}

.prize-amount{

    font-size:28px;
    font-weight:700;
    margin:10px 0;
    color:#1e293b;
}

/* =========================================
FAQ
========================================= */

#hack-faq h6{

    font-weight:600;
    color:#1e293b;
}

#hack-faq p{

    font-size:14px;
}

/* =========================================
RESPONSIVE
========================================= */

@media (max-width:992px){

.hack-hero{
    padding:100px 0 80px;
}

.section-title{
    font-size:1.8rem;
}

.hack-countdown{
    justify-content:space-around;
}

}

@media (max-width:768px){

.hack-hero h1{
    font-size:2.3rem;
}

.hack-countdown div{
    width:60px;
}

.prize-card{
    margin-bottom:20px;
}

}

@media (max-width:576px){

.hack-countdown{
    flex-wrap:wrap;
    gap:10px;
}

.hack-countdown div{
    width:48%;
}

.section-title{
    font-size:1.6rem;
}

}
/* Hackathon Registration Form */
/* ===============================
   SECTION
=================================*/

.hack-reg-section {

    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 120px 20px;

}



/* ===============================
   MAIN CARD
=================================*/

.hack-reg-card {

    max-width: 1050px;
    width: 100%;
    background: rgba(255, 255, 255, 0.9);
    border-radius: 22px;
    padding: 55px;
    backdrop-filter: blur(20px);
    border: 1px solid rgba(0, 0, 0, 0.06);

    position: relative;
    overflow: hidden;

}


/* Gradient Border */

.hack-reg-card:before {

    content: "";
    position: absolute;
    inset: -2px;
    background: linear-gradient(120deg, #6366f1, #22c55e, #6366f1);
    z-index: -1;
    filter: blur(40px);
    opacity: .2;

}



/* ===============================
   HEADER
=================================*/

.hack-reg-header {

    text-align: center;
    margin-bottom: 45px;

}

.hack-reg-header h2 {

    font-size: 36px;
    font-weight: 800;
    background: linear-gradient(90deg, #6366f1, #22c55e);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;

}

.hack-reg-header p {

    color: #64748b;
    margin-top: 10px;
    font-size: 15px;

}



/* ===============================
   FORM SECTION
=================================*/

.form-section {

    margin-bottom: 30px;
    padding: 25px;
    background: rgba(248, 250, 252, 0.8);
    border-radius: 14px;
    border: 1px solid rgba(0, 0, 0, 0.05);

}

.form-section h4 {

    margin-bottom: 20px;
    font-size: 18px;
    color: #1e293b;
    font-weight: 600;

}

.form-section h4 i {

    color: #6366f1;
    margin-right: 8px;

}



/* ===============================
   GRID
=================================*/

.form-grid {

    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;

}



/* ===============================
   FIELD
=================================*/

.form-field {

    display: flex;
    flex-direction: column;
    position: relative;

}

.form-field label {

    font-size: 13px;
    margin-bottom: 6px;
    color: #475569;

}



/* ===============================
   INPUT STYLE
=================================*/

.form-field input,
.form-field textarea,
.form-field select {

    background: #ffffff;
    border: 1px solid #cbd5e1;
    border-radius: 10px;
    padding: 14px 14px;
    font-size: 14px;
    color: #0f172a;
    transition: all .25s ease;

}

.form-field textarea {

    min-height: 100px;

}

/* Amount Section Grid */

.form-grid{
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
    gap:20px;
    margin-top:10px;
}

/* Field Container */

.form-field{
    display:flex;
    flex-direction:column;
}

/* Label */

.form-field label{
    font-size:14px;
    font-weight:600;
    margin-bottom:6px;
    color:#1e293b;
}

/* Amount Inputs */

.pass-field{
    padding:12px 14px;
    border-radius:8px;
    border:1px solid #e2e8f0;
    background:#f8fafc;
    font-size:15px;
    font-weight:600;
    text-align:center;
    color:#0f172a;
}

/* Highlight Total Amount */

#total_amount{
    background:#2563eb;
    color:white;
    border:none;
}

/* Hover Effect */

.pass-field:hover{
    background:#eef2ff;
}

/* Mobile */

@media(max-width:768px){

.form-grid{
    grid-template-columns:1fr;
}

}

/* ===============================
   INPUT HOVER
=================================*/

.form-field input:hover,
.form-field textarea:hover {

    border-color: #94a3b8;

}



/* ===============================
   INPUT FOCUS
=================================*/

.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus {

    outline: none;
    border-color: #6366f1;
    box-shadow:
        0 0 0 2px rgba(99, 102, 241, 0.15),
        0 0 15px rgba(99, 102, 241, 0.15);

    transform: translateY(-1px);

}



/* ===============================
   PASS FIELD
=================================*/

.pass-field {

    background: linear-gradient(90deg, #6366f1, #22c55e);
    border: none;
    color: white;
    font-weight: 600;
    text-align: center;
    font-size: 16px;
    letter-spacing: 0.5px;

}



/* ===============================
   BUTTON
=================================*/

.submit-area {

    text-align: center;
    margin-top: 40px;

}

.register-btn {

    background: linear-gradient(120deg, #6366f1, #22c55e);
    border: none;
    padding: 16px 42px;
    font-size: 16px;
    font-weight: 600;
    color: white;
    border-radius: 50px;
    cursor: pointer;
    transition: .35s;
    box-shadow: 0 10px 25px rgba(99, 102, 241, .25);
    position: relative;
    overflow: hidden;

}


/* Button shine effect */

.register-btn:after {

    content: "";
    position: absolute;
    top: 0;
    left: -120%;
    width: 120%;
    height: 100%;

    background: linear-gradient(120deg,
            transparent,
            rgba(255, 255, 255, .5),
            transparent);

    transition: .7s;

}

.register-btn:hover:after {

    left: 120%;

}


/* Button hover */

.register-btn:hover {

    transform: translateY(-3px);
    box-shadow:
        0 15px 35px rgba(99, 102, 241, .35);

}

.register-btn i {
    margin-right: 8px;
}



/* ===============================
   ERROR
=================================*/

.errorlist {

    list-style: none;
    margin-top: 5px;
    font-size: 12px;
    color: #ef4444;

}



/* ===============================
   RESPONSIVE
=================================*/

@media (max-width:1000px) {

    .form-grid {
        grid-template-columns: repeat(2, 1fr);
    }

}


@media (max-width:700px) {

    .form-grid {
        grid-template-columns: 1fr;
    }

    .hack-reg-card {
        padding: 35px 25px;
    }

    .hack-reg-header h2 {
        font-size: 28px;
    }

    .register-btn {
        width: 100%;
    }

}

@media (max-width:480px) {

    .hack-reg-section {
        padding: 100px 15px;
    }

    .hack-reg-header p {
        font-size: 14px;
    }

}

/* ===============================
   ULTRA WIDE SCREEN
=================================*/

@media (min-width:1600px){

.hack-reg-card{
    max-width:1200px;
    padding:65px;
}

.form-grid{
    gap:26px;
}

}



/* ===============================
   LARGE DESKTOP
=================================*/

@media (max-width:1400px){

.hack-reg-card{
    max-width:1000px;
}

}



/* ===============================
   LAPTOP
=================================*/

@media (max-width:1200px){

.hack-reg-card{
    max-width:920px;
    padding:45px;
}

.form-grid{
    gap:20px;
}

}



/* ===============================
   TABLET LANDSCAPE
=================================*/

@media (max-width:1000px){

.form-grid{
    grid-template-columns:repeat(2,1fr);
}

.hack-reg-card{
    padding:40px;
}

.hack-reg-header h2{
    font-size:32px;
}

}



/* ===============================
   TABLET
=================================*/

@media (max-width:768px){

.hack-reg-section{
    padding:110px 20px;
}

.form-section{
    padding:20px;
}

.hack-reg-card{
    padding:35px;
}

}



/* ===============================
   MOBILE LARGE
=================================*/

@media (max-width:600px){

.form-grid{
    grid-template-columns:1fr;
}

.hack-reg-header h2{
    font-size:28px;
}

.hack-reg-header p{
    font-size:14px;
}

.form-field input,
.form-field textarea,
.form-field select{
    padding:12px;
}

.register-btn{
    width:100%;
}

}



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

@media (max-width:480px){

.hack-reg-section{
    padding:100px 15px;
}

.hack-reg-card{
    padding:28px 20px;
    border-radius:18px;
}

.form-section{
    padding:18px;
}

.form-section h4{
    font-size:16px;
}

}



/* ===============================
   SMALL MOBILE
=================================*/

@media (max-width:360px){

.hack-reg-header h2{
    font-size:24px;
}

.hack-reg-header p{
    font-size:13px;
}

.form-field label{
    font-size:12px;
}

.register-btn{
    font-size:14px;
    padding:14px 20px;
}

}


/* ------------------------- Summit Regiatration Page -------------------------- */
/* ===============================
SECTION
=================================*/

.yf-enquiry-section {

    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 120px 20px;

    background: linear-gradient(180deg,#f8fafc,#eef2ff);

}


/* ===============================
WRAPPER CARD
=================================*/

.yf-wrapper {

    max-width: 900px;
    width: 100%;
    background: #ffffff;
    border-radius: 20px;
    padding: 55px;

    border: 1px solid #e2e8f0;

    box-shadow:
        0 25px 60px rgba(0,0,0,0.08);

    position: relative;
    overflow: hidden;

}

/* soft border glow */

.yf-wrapper:before {

    content: "";
    position: absolute;
    inset: -2px;

    background: linear-gradient(120deg,#6366f1,#22c55e,#6366f1);

    filter: blur(60px);
    opacity: .08;
    z-index: -1;

}


/* ===============================
FORM HEADER
=================================*/

.yf-form-head {
    text-align: center;
    margin-bottom: 45px;
}

.yf-form-title {

    font-size: 38px;
    font-weight: 800;

    background: linear-gradient(90deg,#6366f1,#22c55e);

    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;

}

.yf-form-subtitle {

    margin-top: 10px;
    color: #64748b;
    font-size: 15px;

}


/* ===============================
FORM GRID
=================================*/

.yf-enquiry-form {

    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 22px;

}


/* ===============================
FORM FIELD
=================================*/

.yf-field {
    display: flex;
    flex-direction: column;
}

.yf-field label {

    font-size: 13px;
    margin-bottom: 6px;
    color: #334155;
    font-weight: 500;

}


/* ===============================
INPUT
=================================*/

.yf-field input,
.yf-field select {

    background: #f8fafc;

    border: 1px solid #e2e8f0;

    padding: 14px;

    border-radius: 10px;

    font-size: 14px;

    color: #0f172a;

    transition: .25s;

}

/* hover */

.yf-field input:hover,
.yf-field select:hover {

    border-color: #cbd5f5;

}

/* focus */

.yf-field input:focus,
.yf-field select:focus {

    outline: none;

    border-color: #6366f1;

    box-shadow:
        0 0 0 2px rgba(99,102,241,0.15);

    transform: translateY(-1px);

}


/* ===============================
ERROR
=================================*/

.errorlist {

    list-style: none;

    margin-top: 6px;

    font-size: 12px;

    color: #ef4444;

}


/* ===============================
SUBMIT BUTTON
=================================*/

.yf-submit-wrap {
    grid-column: 1 / -1;
    text-align: center;
    margin-top: 10px;
}

.yf-submit-btn {

    background: linear-gradient(120deg,#6366f1,#22c55e);

    border: none;

    padding: 16px 45px;

    font-size: 16px;

    font-weight: 600;

    color: #fff;

    border-radius: 50px;

    cursor: pointer;

    transition: .35s;

    box-shadow: 0 10px 25px rgba(99,102,241,.35);

    position: relative;

    overflow: hidden;

}

/* shine animation */

.yf-submit-btn:after {

    content: "";

    position: absolute;

    top: 0;

    left: -120%;

    width: 120%;
    height: 100%;

    background: linear-gradient(120deg,
            transparent,
            rgba(255,255,255,.5),
            transparent);

    transition: .7s;

}

.yf-submit-btn:hover:after {
    left: 120%;
}

.yf-submit-btn:hover {

    transform: translateY(-3px);

    box-shadow:
        0 18px 40px rgba(99,102,241,.35);

}


/* ===============================
ULTRA WIDE
=================================*/

@media (min-width:1600px) {

    .yf-wrapper {
        max-width: 1000px;
        padding: 65px;
    }

}


/* ===============================
DESKTOP
=================================*/

@media (max-width:1200px) {

    .yf-wrapper {
        padding: 45px;
    }

}


/* ===============================
TABLET
=================================*/

@media (max-width:1000px) {

    .yf-enquiry-form {
        grid-template-columns: repeat(2,1fr);
    }

    .yf-form-title {
        font-size: 32px;
    }

}


/* ===============================
TABLET SMALL
=================================*/

@media (max-width:768px) {

    .yf-enquiry-section {
        padding: 110px 20px;
    }

    .yf-wrapper {
        padding: 35px;
    }

}


/* ===============================
MOBILE LARGE
=================================*/

@media (max-width:600px) {

    .yf-enquiry-form {
        grid-template-columns: 1fr;
    }

    .yf-form-title {
        font-size: 28px;
    }

    .yf-form-subtitle {
        font-size: 14px;
    }

    .yf-submit-btn {
        width: 100%;
    }

}


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

@media (max-width:480px) {

    .yf-enquiry-section {
        padding: 100px 15px;
    }

    .yf-wrapper {
        padding: 28px 20px;
        border-radius: 16px;
    }

    .yf-field input,
    .yf-field select {
        padding: 12px;
    }

}


/* ===============================
SMALL MOBILE
=================================*/

@media (max-width:360px) {

    .yf-form-title {
        font-size: 24px;
    }

    .yf-form-subtitle {
        font-size: 13px;
    }

}
/*---------------------------Hackathon Rules Page---------------------------*/
/* ===============================
   HERO
=================================*/

.hackathon-rules-section{
padding:100px 0;
background:#f8fafc;
}

.rules-title{
font-size:36px;
font-weight:800;
text-align:center;

background:linear-gradient(90deg,#6366f1,#22c55e);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
}

.rules-subtitle{
text-align:center;
color:#64748b;
margin-bottom:50px;
}

.rules-content{
max-width:900px;
margin:auto;
background:#fff;
padding:40px;
border-radius:12px;
border:1px solid #e2e8f0;
}

.rules-content h3{
margin-top:30px;
font-weight:700;
color:#6366f1;
}

.rules-content ul{
padding-left:20px;
margin-top:10px;
color:#475569;
}

.rules-content li{
margin-bottom:6px;
}

.rules-table{
width:100%;
margin-top:15px;
border-collapse:collapse;
}

.rules-table th{
background:#6366f1;
color:white;
padding:10px;
}

.rules-table td{
border:1px solid #e2e8f0;
padding:10px;
}

.rules-note{
margin-top:40px;
background:#eef2ff;
padding:20px;
border-left:5px solid #6366f1;
border-radius:8px;
color:#334155;
}


/*---------------------- Contact_Sponsors ----------------------------*/

/* Hero Section */
.contact-hero {
  background: linear-gradient(135deg, #0066ff, #00cc99);
  color: white;
  padding: 80px 0;
}

.contact-hero-title {
  font-size: 36px;
  font-weight: bold;
  margin-bottom: 20px;
}

.contact-hero-subtitle {
  font-size: 18px;
  margin-bottom: 40px;
}

.contact-hero-cta a {
  background-color: #ff9900;
  color: white;
  padding: 12px 30px;
  text-decoration: none;
  font-weight: bold;
  border-radius: 5px;
}

.contact-hero-cta a:hover {
  background-color: #e68900;
}

/* Contact Section */
.contact-overview {
  padding: 60px 0;
  background-color: #ffffff;
}

.contact-head {
  text-align: center;
  margin-bottom: 40px;
}

.contact-title {
  font-size: 32px;
  font-weight: bold;
  margin-bottom: 10px;
}

.contact-intro {
  font-size: 18px;
  color: #666;
}

.office-block {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}

.office-details {
  flex: 1;
  padding: 20px;
}

.office-title {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 10px;
}

.office-address {
  font-size: 16px;
  color: #555;
}

.address-off {
  display: flex;
  align-items: center;
  margin-top: 20px;
}

.contact-icon-box {
  background-color: #ff9900;
  padding: 8px;
  border-radius: 50%;
  color: white;
}

.contact-main a {
  font-size: 16px;
  color: #333;
}

.contact-main a:hover {
  text-decoration: underline;
}

/* Enquiry Form Section */
.enquiry-section {
  background-color: #f4f4f4;
  padding: 60px 0;
}

.enquiry-wrapper {
  max-width: 800px;
  margin: 0 auto;
  background-color: white;
  padding: 40px;
  border-radius: 8px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
}

.enquiry-form-head {
  text-align: center;
  margin-bottom: 30px;
}

.enquiry-form-title {
  font-size: 28px;
  font-weight: bold;
}

.enquiry-form-subtitle {
  font-size: 18px;
  color: #666;
}

.enquiry-field {
  margin-bottom: 20px;
}

.enquiry-field label {
  font-weight: bold;
  margin-bottom: 5px;
  display: block;
}

input, select, textarea {
  width: 100%;
  padding: 12px;
  border: 1px solid #ddd;
  border-radius: 5px;
  font-size: 16px;
}

input:focus, select:focus, textarea:focus {
  border-color: #ff9900;
  outline: none;
}

.enquiry-submit-wrap {
  text-align: center;
}

.enquiry-submit-btn {
  background-color: #ff9900;
  color: white;
  padding: 15px 30px;
  font-size: 16px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}

.enquiry-submit-btn:hover {
  background-color: #e68900;
}

/* Why Partner With Us Section */
.location-zone {
  background-color: #ffffff;
  padding: 60px 0;
}

.location-head {
  text-align: center;
  margin-bottom: 40px;
}

.location-title {
  font-size: 32px;
  font-weight: bold;
}

.location-intro {
  font-size: 18px;
  color: #666;
}

.location-grid {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}

.presence-card {
  background-color: #f4f4f4;
  padding: 30px;
  border-radius: 8px;
  text-align: center;
  width: 30%;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.05);
  transition: transform 0.3s ease;
}

.presence-card:hover {
  transform: translateY(-10px);
}

.presence-icon {
  font-size: 50px;
  margin-bottom: 20px;
}

.presence-title {
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 15px;
}

.presence-text {
  font-size: 16px;
  color: #555;
}


/* =====================================================
   LARGE DESKTOP (1400px+)
===================================================== */

@media (min-width:1400px){

.contact-hero-title{
    font-size:42px;
    margin-top: 40px;
}

.contact-title,
.location-title{
    font-size:36px;
}

}


/* =====================================================
   DESKTOP / LAPTOP (1200px – 1399px)
===================================================== */

@media (max-width:1399px){

.contact-hero-title{
    font-size:34px;
    margin-top: 30px;
}

.location-grid{
    gap:20px;
}

}


/* =====================================================
   SMALL LAPTOP / LARGE TABLET (992px – 1199px)
===================================================== */

@media (max-width:1199px){

.contact-hero-title{
    font-size:32px;
    margin-top: 30px;
}

.contact-title,
.location-title{
    font-size:28px;
}

.office-block{
    flex-direction:column;
}

.office-details{
    padding:15px;
}

.location-grid{
    gap:20px;
}

.presence-card{
    width:100%;
}

}


/* =====================================================
   TABLETS (768px – 991px)
===================================================== */

@media (max-width:991px){

.contact-hero{
    padding:60px 0;
    margin-top: 30px;
}

.contact-hero-title{
    font-size:28px;
}

.contact-hero-subtitle{
    font-size:16px;
}

.office-block{
    flex-direction:column;
}

.location-grid{
    flex-direction:column;
}

.presence-card{
    width:100%;
    margin-bottom:20px;
}

.enquiry-wrapper{
    padding:30px;
}

}


/* =====================================================
   MOBILE DEVICES (481px – 767px)
===================================================== */

@media (max-width:767px){

.contact-hero{
    padding:50px 0;
    text-align:center;
}

.contact-hero-title{
    font-size:24px;
}

.contact-hero-subtitle{
    font-size:15px;
}

.contact-hero-cta a{
    padding:10px 22px;
    font-size:14px;
}

.contact-title{
    font-size:24px;
}

.contact-intro{
    font-size:15px;
}

.office-block{
    flex-direction:column;
}

.address-off{
    flex-direction:row;
    gap:10px;
}

.location-title{
    font-size:24px;
}

.enquiry-wrapper{
    padding:25px;
}

.presence-card{
    padding:25px;
}

}


/* =====================================================
   SMALL PHONES (320px – 480px)
===================================================== */

@media (max-width:480px){

.contact-hero{
    padding:40px 0;
}

.contact-hero-title{
    font-size:22px;
}

.contact-hero-subtitle{
    font-size:14px;
}

.contact-title,
.location-title{
    font-size:22px;
}

.contact-intro,
.location-intro{
    font-size:14px;
}

.office-details{
    padding:10px;
}

.presence-card{
    padding:20px;
}

.presence-title{
    font-size:18px;
}

.presence-text{
    font-size:14px;
}

.enquiry-wrapper{
    padding:20px;
}

input,
select,
textarea{
    font-size:14px;
}

.enquiry-submit-btn{
    padding:12px 20px;
    font-size:14px;
}

}


/*------------------------ Contact_Response Page ------------------------*/

/* Enquiry Thank You Section */
.response-wrapper {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 40px;
}

.response-card {
  background-color: white;
  padding: 40px;
  border-radius: 10px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  max-width: 600px;
  width: 100%;
}

.response-icon {
  font-size: 60px;
  color: #28a745;
  margin-bottom: 20px;
}

.response-title {
  font-size: 28px;
  font-weight: bold;
  color: #333;
  margin-bottom: 20px;
}

.response-text {
  font-size: 18px;
  color: #666;
  margin-bottom: 30px;
}

.response-actions {
  display: flex;
  gap: 15px;
  justify-content: center;
  flex-wrap: wrap;
}

.btn-primary {
  padding: 12px 30px;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  border-radius: 5px;
  display: inline-block;
  background-color: #0066ff;
  color: white;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.btn-primary:hover {
  background-color: #0055cc;
}

.btn-outline {
  padding: 12px 30px;
  font-size: 16px;
  font-weight: bold;
  text-decoration: none;
  border-radius: 5px;
  display: inline-block;
  background-color: transparent;
  color: #0066ff;
  border: 2px solid #0066ff;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.btn-outline:hover {
  background-color: #0066ff;
  color: white;
}


/*--------------------------- Summit Response -----------------------------*/
/* ===============================
   Summit Success Response Page
================================ */

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

body{
    font-family: 'Poppins', sans-serif;
}

/* Section */

.summit-success-section{
    min-height: 80vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg,#f8fafc,#eef2ff);
    padding: 60px 20px;
}

/* Container */

.summit-success-container{
    max-width: 700px;
    width: 100%;
}

/* Card */

.summit-success-card{
    background: #ffffff;
    border-radius: 16px;
    padding: 50px 40px;
    text-align: center;
    box-shadow: 0 15px 45px rgba(0,0,0,0.08);
    border: 1px solid #e5e7eb;
}

/* Icon */

.summit-success-icon{
    font-size: 70px;
    color: #22c55e;
    margin-bottom: 20px;
}

/* Title */

.summit-success-title{
    font-size: 32px;
    font-weight: 600;
    color: #111827;
    margin-bottom: 15px;
}

/* Text */

.summit-success-text{
    font-size: 17px;
    color: #4b5563;
    margin-bottom: 10px;
    line-height: 1.6;
}

/* Info */

.summit-success-info{
    font-size: 15px;
    color: #6b7280;
    margin-bottom: 30px;
}

/* Button */

.summit-home-btn{
    display: inline-block;
    padding: 12px 28px;
    background: linear-gradient(135deg,#2563eb,#4f46e5);
    color: white;
    font-weight: 500;
    text-decoration: none;
    border-radius: 8px;
    transition: 0.3s ease;
}

.summit-home-btn i{
    margin-right: 6px;
}

.summit-home-btn:hover{
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(37,99,235,0.3);
}

/* ===============================
   Responsive
================================ */

@media (max-width:768px){

    .summit-success-card{
        padding:40px 25px;
    }

    .summit-success-title{
        font-size:26px;
    }

    .summit-success-icon{
        font-size:60px;
    }

}


/* ============================
   Hackathon Response Page
============================ */

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

body{
    font-family: 'Poppins', sans-serif;
}

/* Section */

.hack-response-section{
    min-height: 85vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;

    background: linear-gradient(135deg,#020617,#0f172a);
}

/* Wrapper */

.hack-response-wrapper{
    max-width: 720px;
    width: 100%;
}

/* Card */

.hack-response-card{
    background: #0f172a;
    border-radius: 16px;
    padding: 50px 40px;
    text-align: center;
    border: 1px solid #1e293b;
    box-shadow: 0 20px 50px rgba(0,0,0,0.5);
}

/* Icon */

.hack-response-icon{
    font-size: 70px;
    color: #38bdf8;
    margin-bottom: 20px;
}

/* Title */

.hack-response-title{
    font-size: 32px;
    font-weight: 600;
    color: #f1f5f9;
    margin-bottom: 15px;
}

/* Text */

.hack-response-text{
    font-size: 17px;
    color: #cbd5f5;
    margin-bottom: 10px;
    line-height: 1.6;
}

/* Info */

.hack-response-info{
    font-size: 15px;
    color: #94a3b8;
    margin-bottom: 30px;
}

/* Buttons */

.hack-response-buttons{
    display: flex;
    justify-content: center;
    gap: 15px;
    flex-wrap: wrap;
}

/* Home Button */

.hack-home-btn{
    padding: 12px 26px;
    background: #2563eb;
    color: white;
    text-decoration: none;
    border-radius: 8px;
    font-weight: 500;
    transition: 0.3s;
}

.hack-home-btn:hover{
    background:#1d4ed8;
    transform: translateY(-2px);
}

/* Event Button */

.hack-event-btn{
    padding: 12px 26px;
    background: transparent;
    color: #38bdf8;
    border: 1px solid #38bdf8;
    text-decoration: none;
    border-radius: 8px;
    font-weight: 500;
    transition: 0.3s;
}

.hack-event-btn:hover{
    background:#38bdf8;
    color:#020617;
}

/* ============================
   Responsive
============================ */

@media (max-width:768px){

.hack-response-card{
    padding:40px 25px;
}

.hack-response-title{
    font-size:26px;
}

.hack-response-icon{
    font-size:60px;
}

.hack-response-buttons{
    flex-direction:column;
}

}

/*--------------------------- Summit Payment -----------------------------*/
/* ===============================
    Payment Page
=================================*/
.payment-section {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 80vh;
    background: #f4f6fb;
    padding: 60px 20px;
}
    
.payment-card {
    background: white;
    padding: 40px;
    border-radius: 16px;
    box-shadow: 0 15px 40px rgba(0,0,0,0.1);
    border: 1px solid #e2e8f0;
    max-width: 500px;
    width: 100%;
    text-align: center;
}

.payment-card h2 {
    font-size: 24px;
     margin-bottom: 5px;
    color: #111827;
}
   
.payment-sub {
    font-size: 16px;
    color: #4b5563;
    margin-bottom: 20px;
}

.payment-details {
    margin-bottom: 30px;
}

.row {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
    font-size: 15px;
}

.row.total {
    font-weight: 600;
    font-size: 18px;
    color: #1e293b;
}

 .pay-btn {
    background: #2563eb;
    color: white;
    padding: 12px 30px;
    font-size: 16px;
    font-weight: 500;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    transition: 0.3s;
}

.pay-btn:hover {
    background: #1d4ed8;
    transform: translateY(-2px);
} 
    
/* Responsive */
@media (max-width: 480px) {
    .payment-card {
        padding: 30px 20px;
    }
    .payment-card h2 {
        font-size: 20px;
    }
    .payment-sub {
        font-size: 14px;
    }
    .row {
        font-size: 14px;
    }
    .row.total {
        font-size: 16px;
    }
    .pay-btn {
        width: 100%;
    }
}


@media (max-width: 780px) {
    .payment-card {
        padding: 30px 20px;
    }
    .payment-card h2 {
        font-size: 22px;
    }
    .payment-sub {
        font-size: 14px;
    }
    .row {
        font-size: 14px;
    }
    .row.total {
        font-size: 16px;
    }
}


@media (max-width: 360px) {
    .payment-card {
        padding: 25px 15px;
    }
    .payment-card h2 {
        font-size: 18px;
    }
    .payment-sub {
        font-size: 13px;
    }
    .row {
        font-size: 13px;
    }
    .row.total {
        font-size: 15px;
    }
}

/*--------------------------- Hackathon Payment -----------------------------*/
/* ===============================
    Hackathon Payment Page
=================================*/

.payment-section {

    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 80vh;
    background: #f4f6fb;

}

.payment-card {

    background: white;
    padding: 40px;
    border-radius: 12px;
    width: 420px;
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.08);

}

.payment-card h2 {

    font-size: 24px;
    margin-bottom: 5px;

}

.payment-sub {

    color: #6b7280;
    margin-bottom: 25px;

}

.payment-details {

    margin-bottom: 30px;

}

.row {

    display: flex;
    justify-content: space-between;
    margin-bottom: 12px;
    font-size: 15px;

}

.row.total {

    font-size: 18px;
    font-weight: 600;

}

.pay-btn {

    width: 100%;
    padding: 14px;
    background: #16a34a;
    color: white;
    border: none;
    border-radius: 8px;
    font-size: 16px;
    cursor: pointer;

}

.pay-btn:hover {

    background: #15803d;

}

/* Responsive */
@media (max-width: 480px) {

    .payment-card {
        width: 100%;
        padding: 30px 20px;
    }

    .payment-card h2 {
        font-size: 20px;
    }

    .payment-sub {
        font-size: 14px;
    }

    .row {
        font-size: 14px;
    }

    .row.total {
        font-size: 16px;
    }

}

@media (max-width: 780px) {

    .payment-card {
        width: 100%;
        padding: 30px 20px;
    }

    .payment-card h2 {
        font-size: 22px;
    }

    .payment-sub {
        font-size: 14px;
    }

    .row {
        font-size: 14px;
    }

    .row.total {
        font-size: 16px;
    }

}
@media (max-width: 360px) {

    .payment-card {
        width: 100%;
        padding: 25px 15px;
    }

    .payment-card h2 {
        font-size: 18px;
    }

    .payment-sub {
        font-size: 13px;
    }

    .row {
        font-size: 13px;
    }

    .row.total {
        font-size: 15px;
    }

}



/*---------------------------  Payment Success -----------------------------*/
/* ===============================
    Payment Success Page
=================================*/
.payment-success-section {
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 80vh;
    background: linear-gradient(135deg,#f8fafc,#eef2ff);
    padding: 60px 20px;
}

.payment-success-card {
    background: white;
    padding: 40px;
    border-radius: 16px;
    box-shadow: 0 15px 40px rgba(0,0,0,0.1);
    border: 1px solid #e2e8f0;
    max-width: 500px;
    width: 100%;
    text-align: center;
}

.payment-success-sub {
    font-size: 16px;
    color: #4b5563;
    margin-bottom: 20px;
}

@media screen and (max-width: 768px) {
    .payment-success-card {
        padding: 30px 20px;
    }
    .payment-success-sub {
        font-size: 14px;
    }
    
}

@media screen and (max-width: 480px) {
    .payment-success-card {
        padding: 25px 15px;
    }
    .payment-success-sub {
        font-size: 13px;
    }
}
