/*=========================================================
PRCI EXCELLENCE AWARDS 2026
Premium Landing Page
Author: ChatGPT
=========================================================*/

/*==========================
GOOGLE FONTS
===========================*/

@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&family=Poppins:wght@300;400;500;600;700&display=swap');

/*==========================
ROOT VARIABLES
===========================*/

:root{

    --primary:#2D1B69;
    --secondary:#472B8C;

    --gold:#D8A13A;
    --gold-light:#F0C766;

    --orange:#E57A00;

    --dark:#0E0E1A;

    --white:#ffffff;

    --light:#F8F9FC;

    --text:#555;

    --shadow:
    0 15px 40px rgba(0,0,0,.10);

    --transition:.35s;

}

/*==========================
GLOBAL
===========================*/

*{

margin:0;

padding:0;

box-sizing:border-box;

}

html{

scroll-behavior:smooth;

}

body{

font-family:'Poppins',sans-serif;

background:#fff;

color:var(--text);

overflow-x:hidden;

line-height:1.7;

}

img{

max-width:100%;

display:block;

}

a{

text-decoration:none;

}

ul{

padding-left:0;

}

.section{

padding:100px 0;

position:relative;

}

.bg-light{

background:#F8F9FD!important;

}

/*==========================
TYPOGRAPHY
===========================*/

h1,h2,h3,h4,h5,h6{

font-family:'Montserrat',sans-serif;

font-weight:800;

color:var(--primary);

}

.section-title{

font-size:48px;

margin-bottom:25px;

text-align:center;

position:relative;

}

.section-title:after{

content:"";

width:90px;

height:5px;

border-radius:30px;

display:block;

margin:18px auto;

background:

linear-gradient(90deg,

var(--gold),

var(--gold-light));

}

.section p{

font-size:18px;

max-width:900px;

margin:auto;

}

/*==========================
NAVBAR
===========================*/

.navbar{

background:

rgba(20,12,55,.55);

backdrop-filter:blur(16px);

padding:18px 0;

transition:.4s;

z-index:999;

}

.navbar.scrolled{

background:#1B103C;

padding:10px 0;

box-shadow:

0 10px 25px rgba(0,0,0,.18);

}

.navbar-brand{

font-weight:800;

font-size:24px;

letter-spacing:.5px;

color:#fff!important;

}

.nav-link{

color:#fff!important;

margin-left:22px;

font-weight:500;

position:relative;

transition:.3s;

}

.nav-link:after{

content:"";

position:absolute;

bottom:-5px;

left:0;

width:0;

height:2px;

background:var(--gold);

transition:.35s;

}

.nav-link:hover{

color:var(--gold)!important;

}

.nav-link:hover:after{

width:100%;

}

/*==========================
BUTTONS
===========================*/

.btn-warning{

background:

linear-gradient(135deg,

var(--gold),

var(--gold-light));

border:none;

color:#241400;

font-weight:700;

padding:15px 34px;

border-radius:60px;

transition:.35s;

position:relative;

overflow:hidden;

}

.btn-warning:hover{

transform:translateY(-4px);

box-shadow:

0 15px 35px rgba(216,161,58,.35);

}

.btn-warning:before{

content:"";

position:absolute;

left:-100%;

top:0;

width:50%;

height:100%;

background:

rgba(255,255,255,.45);

transform:skewX(-25deg);

}

.btn-warning:hover:before{

left:160%;

transition:.8s;

}

.btn-outline-light{

padding:15px 34px;

border-radius:60px;

}

/*==========================
HERO SECTION
===========================*/

.hero{

position:relative;

display:flex;

align-items:center;

min-height:100vh;

background:

linear-gradient(

rgba(33,18,73,.90),

rgba(20,10,50,.95)),

url("images/hero-bg.jpg");

background-size:cover;

background-position:center;

overflow:hidden;

}

/*==========================
GLOW EFFECT
===========================*/

.hero:before{

content:"";

position:absolute;

width:700px;

height:700px;

border-radius:50%;

right:-200px;

top:-180px;

background:

radial-gradient(circle,

rgba(216,161,58,.25),

transparent 70%);

animation:pulse1 8s infinite;

}

.hero:after{

content:"";

position:absolute;

width:600px;

height:600px;

left:-180px;

bottom:-180px;

border-radius:50%;

background:

radial-gradient(circle,

rgba(130,70,255,.18),

transparent 70%);

animation:pulse2 10s infinite;

}

@keyframes pulse1{

0%{

transform:scale(.9);

}

50%{

transform:scale(1.1);

}

100%{

transform:scale(.9);

}

}

@keyframes pulse2{

0%{

transform:scale(1);

}

50%{

transform:scale(.85);

}

100%{

transform:scale(1);

}

}

/*==========================
FLOATING PARTICLES
===========================*/

.particle{

position:absolute;

background:rgba(255,220,120,.8);

border-radius:50%;

animation:floatParticle linear infinite;

}

.particle:nth-child(1){

width:6px;

height:6px;

left:8%;

animation-duration:14s;

}

.particle:nth-child(2){

width:8px;

height:8px;

left:30%;

animation-duration:18s;

}

.particle:nth-child(3){

width:5px;

height:5px;

left:60%;

animation-duration:15s;

}

.particle:nth-child(4){

width:7px;

height:7px;

left:82%;

animation-duration:20s;

}

@keyframes floatParticle{

0%{

transform:translateY(110vh);

opacity:0;

}

15%{

opacity:1;

}

100%{

transform:translateY(-100px);

opacity:0;

}

}

/*==========================
HERO CONTENT
===========================*/

.hero h5{

color:var(--gold);

font-weight:600;

letter-spacing:4px;

margin-bottom:20px;

}

.hero h1{

font-size:72px;

font-weight:900;

line-height:1.15;

color:#fff;

margin-bottom:25px;

}

.hero h1 span{

color:var(--gold);

}

.hero p{

font-size:20px;

color:#f2f2f2;

max-width:650px;

margin-bottom:20px;

}

.hero-logo{

max-width:430px;

filter:

drop-shadow(

0 30px 50px rgba(0,0,0,.45));

animation:logoFloat 5s ease-in-out infinite;

}

@keyframes logoFloat{

0%{

transform:translateY(0);

}

50%{

transform:translateY(-12px);

}

100%{

transform:translateY(0);

}

}

/*==========================
GLASS CARD
===========================*/

.glass{

background:

rgba(255,255,255,.08);

border:

1px solid rgba(255,255,255,.15);

backdrop-filter:blur(20px);

padding:30px;

border-radius:24px;

}

/*==========================
COUNTDOWN
===========================*/

.countdown{

background:

linear-gradient(

90deg,

var(--primary),

var(--secondary));

padding:60px 0;

color:#fff;

}

.countdown h2{

font-size:58px;

font-weight:800;

color:var(--gold);

margin-bottom:8px;

}

.countdown span{

letter-spacing:3px;

font-size:13px;

text-transform:uppercase;

}

/*==========================
UTILITY CLASSES
===========================*/

.text-gold{

color:var(--gold);

}

.shadow-premium{

box-shadow:var(--shadow);

}

.rounded-premium{

border-radius:20px;

}

/*=========================================================
PART 2
ABOUT • AWARDS • CATEGORIES • WHY PARTICIPATE
=========================================================*/

/*==========================
ABOUT SECTIONS
===========================*/

#about,
#awards{

    position:relative;

    overflow:hidden;

}

#about::before{

    content:"";

    position:absolute;

    width:350px;
    height:350px;

    top:-120px;
    right:-120px;

    border-radius:50%;

    background:radial-gradient(circle,
        rgba(216,161,58,.10),
        transparent 70%);

}

#awards::after{

    content:"";

    position:absolute;

    width:280px;
    height:280px;

    left:-80px;
    bottom:-80px;

    border-radius:50%;

    background:radial-gradient(circle,
        rgba(71,43,140,.08),
        transparent 70%);

}

#about p,
#awards p{

    text-align:justify;

    font-size:17px;

    line-height:1.9;

    color:#555;

}

#awards img{

    border-radius:20px;

    box-shadow:
    0 20px 45px rgba(0,0,0,.15);

    transition:.4s;

}

#awards img:hover{

    transform:scale(1.03);

}

/*==========================
CATEGORY SECTION
===========================*/

#categories{

    background:#fff;

    position:relative;

}

#categories::before{

content:"";

position:absolute;

top:0;

left:0;

width:100%;

height:100%;

background:

linear-gradient(
135deg,
rgba(216,161,58,.03),
transparent);

pointer-events:none;

}

/*==========================
CATEGORY CARD
===========================*/

.category-card{

position:relative;

overflow:hidden;

background:#fff;

border-radius:22px;

padding:40px 30px;

height:100%;

transition:.35s;

box-shadow:

0 18px 45px rgba(0,0,0,.08);

border-top:5px solid transparent;

}

.category-card:hover{

transform:translateY(-12px);

border-color:var(--gold);

box-shadow:

0 30px 60px rgba(45,27,105,.16);

}

.category-card::before{

content:"";

position:absolute;

left:-120%;

top:0;

width:100%;

height:100%;

background:

linear-gradient(
120deg,
transparent,
rgba(255,255,255,.5),
transparent);

transition:.8s;

}

.category-card:hover::before{

left:130%;

}

.category-card i{

font-size:54px;

display:block;

margin-bottom:25px;

background:

linear-gradient(
135deg,
var(--gold),
var(--gold-light));

-webkit-background-clip:text;

-webkit-text-fill-color:transparent;

}

.category-card h4{

font-size:26px;

margin-bottom:20px;

color:var(--primary);

}

.category-card ul{

margin:0;

padding:0;

list-style:none;

}

.category-card ul li{

padding:10px 0;

font-size:15px;

border-bottom:1px solid #eee;

position:relative;

padding-left:28px;

}

.category-card ul li:last-child{

border:none;

}

.category-card ul li::before{

content:"✓";

position:absolute;

left:0;

color:var(--gold);

font-weight:700;

}

/*==========================
WHY PARTICIPATE
===========================*/

.feature-box{

background:#fff;

padding:40px 30px;

border-radius:22px;

height:100%;

transition:.35s;

text-align:center;

box-shadow:

0 18px 45px rgba(0,0,0,.08);

position:relative;

overflow:hidden;

}

.feature-box::before{

content:"";

position:absolute;

width:120px;

height:120px;

border-radius:50%;

top:-50px;

right:-50px;

background:

rgba(216,161,58,.08);

transition:.4s;

}

.feature-box:hover{

transform:translateY(-12px);

background:

linear-gradient(
135deg,
var(--primary),
var(--secondary));

}

.feature-box:hover::before{

transform:scale(2);

opacity:.15;

}

.feature-box i{

font-size:58px;

margin-bottom:22px;

color:var(--gold);

transition:.35s;

}

.feature-box:hover i{

transform:scale(1.15);

}

.feature-box h4{

margin-bottom:18px;

font-size:24px;

transition:.35s;

}

.feature-box p{

font-size:15px;

margin:0;

transition:.35s;

}

.feature-box:hover h4,
.feature-box:hover p{

color:#fff;

}

/*==========================
SECTION ANIMATIONS
===========================*/

.category-card,
.feature-box{

animation:fadeUp .8s ease;

}

@keyframes fadeUp{

0%{

opacity:0;

transform:translateY(30px);

}

100%{

opacity:1;

transform:translateY(0);

}

}

/*==========================
DIVIDER
===========================*/

.section-divider{

width:120px;

height:5px;

margin:25px auto;

border-radius:50px;

background:

linear-gradient(
90deg,
var(--gold),
var(--gold-light));

}

/*==========================
RESPONSIVE
===========================*/

@media(max-width:992px){

.category-card{

margin-bottom:25px;

}

#about p,
#awards p{

text-align:left;

}

}

@media(max-width:768px){

.category-card{

padding:30px 25px;

}

.category-card h4{

font-size:22px;

}

.feature-box{

padding:30px 25px;

}

.feature-box h4{

font-size:20px;

}

.feature-box i{

font-size:46px;

}

}

/*=========================================================
PART 3
REGISTRATION • CONTACT • FOOTER • ANIMATIONS • RESPONSIVE
=========================================================*/

/*==========================
REGISTRATION SECTION
===========================*/

#register{
    position:relative;
    background:
        linear-gradient(135deg,#faf8ff,#f5f0ff);
    overflow:hidden;
}

#register::before{
    content:"";
    position:absolute;
    width:450px;
    height:450px;
    border-radius:50%;
    background:radial-gradient(circle,
        rgba(216,161,58,.12),
        transparent 70%);
    top:-180px;
    right:-180px;
}

#register::after{
    content:"";
    position:absolute;
    width:350px;
    height:350px;
    border-radius:50%;
    background:radial-gradient(circle,
        rgba(71,43,140,.10),
        transparent 70%);
    bottom:-120px;
    left:-120px;
}

.register-box{

    position:relative;

    background:rgba(255,255,255,.92);

    backdrop-filter:blur(20px);

    border-radius:28px;

    padding:60px;

    box-shadow:
        0 30px 80px rgba(45,27,105,.12);

    border:1px solid rgba(255,255,255,.6);

}

.register-box h2{
    color:var(--primary);
}

.form-label{
    font-weight:600;
    color:var(--primary);
    margin-bottom:8px;
}

.form-control{

    height:58px;

    border-radius:14px;

    border:1px solid #ddd;

    padding-left:18px;

    font-size:15px;

    transition:all .3s;

    background:#fff;

}

.form-control:focus{

    border-color:var(--gold);

    box-shadow:
        0 0 0 .25rem rgba(216,161,58,.18);

}

textarea.form-control{

    height:140px;

    padding-top:15px;

}

.register-box .btn{

    min-width:260px;

    height:58px;

    font-size:17px;

    letter-spacing:.5px;

}

/*==========================
CONTACT
===========================*/

#contact{

    background:#fff;

}

.contact-card{

    background:#fff;

    border-radius:22px;

    padding:40px 30px;

    text-align:center;

    transition:.35s;

    height:100%;

    box-shadow:
        0 15px 45px rgba(0,0,0,.08);

}

.contact-card:hover{

    transform:translateY(-10px);

    box-shadow:
        0 25px 55px rgba(45,27,105,.15);

}

.contact-card i{

    font-size:52px;

    color:var(--gold);

    margin-bottom:20px;

}

.contact-card h4{

    margin-bottom:15px;

    color:var(--primary);

}

.contact-card p{

    margin:0;

    color:#666;

}

/*==========================
FOOTER
===========================*/

footer{

    background:
        linear-gradient(135deg,#140827,#2D1B69);

    color:#ddd;

    padding:70px 0 35px;

}

footer h4{

    color:#fff;

    font-size:28px;

    margin-bottom:15px;

}

footer p{

    margin-bottom:8px;

    color:#d7d7d7;

}

footer a{

    color:var(--gold);

    transition:.3s;

}

footer a:hover{

    color:#fff;

}

footer .social-icons{

    margin-top:20px;

}

footer .social-icons a{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    width:44px;

    height:44px;

    border-radius:50%;

    background:rgba(255,255,255,.08);

    margin-right:10px;

    font-size:18px;

}

footer .social-icons a:hover{

    background:var(--gold);

    color:var(--primary);

}

/*==========================
TOP BUTTON
===========================*/

#topButton{

    transition:all .35s;

}

#topButton:hover{

    transform:translateY(-5px);

    box-shadow:
        0 18px 40px rgba(216,161,58,.35);

}

/*==========================
RIPPLE EFFECT
===========================*/

.btn-warning{

    position:relative;

    overflow:hidden;

}

.ripple{

    position:absolute;

    width:10px;

    height:10px;

    border-radius:50%;

    background:rgba(255,255,255,.55);

    transform:translate(-50%,-50%);

    animation:ripple .6s linear;

    pointer-events:none;

}

@keyframes ripple{

    from{

        width:0;
        height:0;
        opacity:.8;

    }

    to{

        width:420px;
        height:420px;
        opacity:0;

    }

}

/*==========================
SCROLLBAR
===========================*/

::-webkit-scrollbar{

    width:10px;

}

::-webkit-scrollbar-track{

    background:#efefef;

}

::-webkit-scrollbar-thumb{

    border-radius:30px;

    background:
        linear-gradient(
            var(--gold),
            var(--gold-light)
        );

}

/*==========================
GENERAL ANIMATIONS
===========================*/

.fade-in{

    animation:fadeIn .8s ease;

}

@keyframes fadeIn{

    from{

        opacity:0;

    }

    to{

        opacity:1;

    }

}

.float{

    animation:floating 4s ease-in-out infinite;

}

@keyframes floating{

    0%{

        transform:translateY(0);

    }

    50%{

        transform:translateY(-10px);

    }

    100%{

        transform:translateY(0);

    }

}

/*==========================
RESPONSIVE
===========================*/

@media(max-width:1200px){

    .hero h1{

        font-size:60px;

    }

}

@media(max-width:992px){

    .section{

        padding:80px 0;

    }

    .hero{

        text-align:center;

        padding:140px 0 80px;

    }

    .hero h1{

        font-size:48px;

    }

    .hero p{

        margin-left:auto;
        margin-right:auto;

    }

    .hero-logo{

        margin-top:50px;

        max-width:320px;

    }

    .register-box{

        padding:40px;

    }

    footer{

        text-align:center;

    }

}

@media(max-width:768px){

    .section{

        padding:70px 0;

    }

    .section-title{

        font-size:34px;

    }

    .hero h1{

        font-size:38px;

    }

    .hero p{

        font-size:16px;

    }

    .countdown h2{

        font-size:38px;

    }

    .register-box{

        padding:30px;

    }

    .btn-warning,
    .btn-outline-light{

        width:100%;

        margin-bottom:15px;

    }

    .contact-card{

        margin-bottom:25px;

    }

}

@media(max-width:576px){

    .navbar-brand{

        font-size:18px;

    }

    .hero h1{

        font-size:32px;

    }

    .hero-logo{

        max-width:250px;

    }

    .register-box{

        padding:25px;

    }

    .form-control{

        height:54px;

    }

}