/* ========================================================================
   RAVI AGRAWAL – GLOBAL STYLESHEET
   Design System: Futuristic Governance + Financial Intelligence
   ======================================================================== */

/* ---------- RESET ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
    /* Palette */
    --navy:#0a0e1a;
    --navy-light:#0f1526;
    --charcoal:#1a1f2e;
    --surface:#141824;
    --surface-light:#1e2438;
    --gold:#c9a84c;
    --gold-light:#d4b85c;
    --teal:#2ec4b6;
    --teal-dark:#1a9e92;
    --silver:#8892a4;
    --text:#e2e6ee;
    --text-dim:#7a8499;
    --text-muted:#525d73;
    --white:#ffffff;
    --border:rgba(201,168,76,.1);
    --border-hover:rgba(201,168,76,.25);

    /* Typography */
    --font-body:'Inter',system-ui,sans-serif;
    --font-heading:'Outfit',system-ui,sans-serif;

    /* Spacing */
    --section-pad:100px 0;
    --container-w:1200px;
}

html{scroll-behavior:smooth;font-size:16px}
body{
    font-family:var(--font-body);
    background:var(--navy);
    color:var(--text);
    line-height:1.7;
    -webkit-font-smoothing:antialiased;
    overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{text-decoration:none;color:inherit;transition:color .3s}
ul,ol{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:600;line-height:1.2;color:var(--white)}

/* ---------- UTILITY ---------- */
.container{width:90%;max-width:var(--container-w);margin:0 auto}
.section{padding:var(--section-pad)}
.section-label{
    display:inline-block;font-size:.65rem;font-weight:600;
    letter-spacing:3px;text-transform:uppercase;
    color:var(--gold);margin-bottom:12px;
}
.section-title{font-size:2.4rem;font-weight:700;letter-spacing:-.5px;margin-bottom:16px}
.section-subtitle{font-size:1.05rem;color:var(--silver);max-width:600px;line-height:1.6;margin-bottom:40px}

/* ---------- NAVIGATION ---------- */
.navbar{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    background:rgba(10,14,26,.82);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border);
    transition:background .3s;
}
.nav-inner{
    display:flex;align-items:center;justify-content:space-between;
    padding:0 5%;height:68px;max-width:1400px;margin:0 auto;
}
.nav-brand{
    font-family:var(--font-heading);font-weight:700;font-size:1.15rem;
    color:var(--white);letter-spacing:-.3px;
    display:flex;align-items:center;gap:10px;
}
.nav-brand .brand-dot{
    width:8px;height:8px;border-radius:50%;
    background:linear-gradient(135deg,var(--gold),var(--teal));
    flex-shrink:0;
}
.nav-links{display:flex;align-items:center;gap:28px}
.nav-links a{
    font-size:.78rem;font-weight:500;letter-spacing:.5px;
    text-transform:uppercase;color:var(--silver);
    position:relative;transition:color .3s;
}
.nav-links a::after{
    content:'';position:absolute;bottom:-4px;left:0;
    width:0;height:2px;
    background:linear-gradient(90deg,var(--gold),var(--teal));
    transition:width .3s;
}
.nav-links a:hover,
.nav-links a.active{color:var(--white)}
.nav-links a:hover::after,
.nav-links a.active::after{width:100%}

/* Hamburger */
.nav-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ---------- HERO ---------- */
.hero{
    position:relative;min-height:100vh;
    display:flex;align-items:center;
    padding-top:68px;overflow:hidden;
}
.hero-bg{
    position:absolute;inset:0;z-index:0;
}
.hero-bg img{
    width:100%;height:100%;object-fit:cover;
    filter:brightness(.35);
}
.hero-overlay{
    position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(10,14,26,.3) 0%,rgba(10,14,26,.85) 70%,var(--navy) 100%);
}
.hero-grid{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(201,168,76,.03) 1px,transparent 1px),
        linear-gradient(90deg,rgba(201,168,76,.03) 1px,transparent 1px);
    background-size:80px 80px;
}
.hero-content{position:relative;z-index:2;width:90%;max-width:var(--container-w);margin:0 auto}
.hero-label{
    font-size:.6rem;font-weight:600;letter-spacing:4px;text-transform:uppercase;
    color:var(--gold);margin-bottom:16px;
    display:flex;align-items:center;gap:12px;
}
.hero-label .line{width:40px;height:1px;background:var(--gold)}
.hero h1{
    font-size:3.8rem;font-weight:800;letter-spacing:-1.5px;
    line-height:1.05;margin-bottom:20px;
    max-width:700px;
}
.hero h1 .highlight{
    background:linear-gradient(135deg,var(--gold),var(--teal));
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
}
.hero-desc{
    font-size:1.1rem;color:var(--silver);line-height:1.7;
    max-width:540px;margin-bottom:36px;
}
.hero-stats{display:flex;gap:40px;flex-wrap:wrap}
.hero-stat{
    border-left:2px solid rgba(201,168,76,.3);
    padding-left:20px;
}
.hero-stat .num{
    font-family:var(--font-heading);font-size:2rem;font-weight:700;
    color:var(--white);line-height:1.1;
}
.hero-stat .num span{color:var(--gold);font-size:1.2rem}
.hero-stat .label{font-size:.72rem;color:var(--text-dim);letter-spacing:1px;text-transform:uppercase;margin-top:4px}

/* ---------- CARDS ---------- */
.card{
    background:rgba(20,24,36,.6);
    backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
    border:1px solid var(--border);
    border-radius:16px;
    padding:36px;
    transition:border-color .3s,transform .3s,box-shadow .3s;
}
.card:hover{
    border-color:var(--border-hover);
    transform:translateY(-4px);
    box-shadow:0 20px 60px rgba(0,0,0,.3);
}
.card-icon{
    width:48px;height:48px;border-radius:12px;
    background:linear-gradient(135deg,rgba(201,168,76,.12),rgba(46,196,182,.12));
    display:flex;align-items:center;justify-content:center;
    margin-bottom:20px;color:var(--gold);
}
.card h3{font-size:1.15rem;margin-bottom:10px;font-weight:600}
.card p{font-size:.9rem;color:var(--silver);line-height:1.65}

.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.cards-grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}

/* ---------- TIMELINE ---------- */
.timeline{position:relative;padding-left:32px}
.timeline::before{
    content:'';position:absolute;left:0;top:0;bottom:0;
    width:2px;background:linear-gradient(180deg,var(--gold),var(--teal),transparent);
}
.timeline-item{
    position:relative;margin-bottom:48px;
    padding-left:28px;
}
.timeline-item::before{
    content:'';position:absolute;left:-37px;top:6px;
    width:12px;height:12px;border-radius:50%;
    background:var(--navy);
    border:2px solid var(--gold);
}
.timeline-item .year{
    font-family:var(--font-heading);font-size:.75rem;font-weight:600;
    color:var(--teal);letter-spacing:2px;margin-bottom:6px;
}
.timeline-item h3{font-size:1.1rem;margin-bottom:8px}
.timeline-item p{font-size:.9rem;color:var(--silver);line-height:1.65}

/* ---------- IMAGE SECTION ---------- */
.img-section{
    display:grid;grid-template-columns:1fr 1fr;gap:48px;
    align-items:center;
}
.img-section.reverse{direction:rtl}
.img-section.reverse > *{direction:ltr}
.img-frame{
    position:relative;border-radius:16px;overflow:hidden;
    border:1px solid var(--border);
    aspect-ratio:4/3;
}
.img-frame img{
    width:100%;height:100%;object-fit:cover;
    object-position:center top;
    transition:transform .6s;
}
.img-frame:hover img{transform:scale(1.03)}
.img-frame .img-overlay{
    position:absolute;inset:0;
    background:linear-gradient(180deg,transparent 60%,rgba(10,14,26,.6));
    pointer-events:none;
}

/* ---------- GALLERY GRID ---------- */
.gallery-grid{
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
    gap:20px;
}
.gallery-item{
    position:relative;border-radius:12px;overflow:hidden;
    border:1px solid var(--border);
    aspect-ratio:4/3;
    cursor:pointer;
}
.gallery-item img{
    width:100%;height:100%;object-fit:cover;
    object-position:center top;
    transition:transform .6s,filter .6s;
}
.gallery-item:hover img{transform:scale(1.05);filter:brightness(1.1)}
.gallery-item .gallery-overlay{
    position:absolute;inset:0;
    background:linear-gradient(180deg,transparent 50%,rgba(10,14,26,.7));
    opacity:0;transition:opacity .3s;
    display:flex;align-items:flex-end;padding:20px;
}
.gallery-item:hover .gallery-overlay{opacity:1}
.gallery-item .gallery-caption{
    font-size:.8rem;color:var(--text);font-weight:500;
}

/* ---------- QUOTE / HIGHLIGHT BOX ---------- */
.highlight-box{
    background:linear-gradient(135deg,rgba(201,168,76,.06),rgba(46,196,182,.04));
    border:1px solid var(--border);
    border-left:3px solid var(--gold);
    border-radius:12px;
    padding:32px 36px;
    margin:40px 0;
}
.highlight-box p{
    font-size:1.05rem;font-style:italic;color:var(--text);line-height:1.7;
}
.highlight-box .attribution{
    font-size:.8rem;color:var(--gold);font-style:normal;margin-top:12px;font-weight:600;
}

/* ---------- CONTACT FORM AREA ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.contact-info-card{
    background:rgba(20,24,36,.6);
    backdrop-filter:blur(12px);
    border:1px solid var(--border);
    border-radius:16px;
    padding:40px;
}
.contact-row{
    display:flex;align-items:center;gap:16px;
    margin-bottom:24px;
}
.contact-row:last-child{margin-bottom:0}
.contact-row .icon-circle{
    width:44px;height:44px;border-radius:50%;flex-shrink:0;
    background:rgba(201,168,76,.08);
    display:flex;align-items:center;justify-content:center;
    color:var(--gold);
}
.contact-row .info h4{font-size:.9rem;margin-bottom:2px}
.contact-row .info a,
.contact-row .info p{font-size:.88rem;color:var(--silver);transition:color .3s}
.contact-row .info a:hover{color:var(--gold)}

/* ---------- CONTACT FORM ---------- */
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{
    font-size:.75rem;font-weight:600;letter-spacing:1px;
    text-transform:uppercase;color:var(--silver);
}
.form-group input,
.form-group textarea{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(201,168,76,.12);
    border-radius:10px;
    padding:14px 16px;
    font-family:var(--font-body);font-size:.9rem;
    color:var(--text);
    transition:border-color .3s,box-shadow .3s;
    outline:none;resize:vertical;
}
.form-group input::placeholder,
.form-group textarea::placeholder{color:var(--text-muted);font-size:.85rem}
.form-group input:focus,
.form-group textarea:focus{
    border-color:rgba(201,168,76,.4);
    box-shadow:0 0 0 3px rgba(201,168,76,.08);
}
.form-submit{
    display:inline-flex;align-items:center;justify-content:center;gap:10px;
    background:linear-gradient(135deg,var(--gold),#d4b85c);
    border:none;border-radius:12px;
    padding:16px 32px;
    font-family:var(--font-body);font-size:.85rem;font-weight:600;
    color:var(--navy);cursor:pointer;
    letter-spacing:.5px;
    transition:transform .2s,box-shadow .3s;
}
.form-submit:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 24px rgba(201,168,76,.25);
}
.form-submit:active{transform:translateY(0)}
.form-success{
    font-size:.85rem;color:var(--teal);
    margin-top:8px;
    opacity:0;transform:translateY(-4px);
    transition:opacity .3s,transform .3s;
}
.form-success.visible{opacity:1;transform:translateY(0)}

/* ---------- FOOTER ---------- */
.site-footer{
    background:var(--surface);
    border-top:1px solid var(--border);
    padding:48px 0 28px;
}
.footer-inner{
    display:flex;align-items:flex-start;justify-content:space-between;
    gap:40px;flex-wrap:wrap;
    width:90%;max-width:var(--container-w);margin:0 auto;
}
.footer-brand h3{
    font-family:var(--font-heading);font-size:1.1rem;font-weight:700;
    margin-bottom:6px;color:var(--white);
}
.footer-brand p{font-size:.8rem;color:var(--text-dim);line-height:1.6}

.footer-contact p,
.footer-contact a{font-size:.8rem;color:var(--silver);display:block;margin-bottom:4px;transition:color .3s}
.footer-contact a:hover{color:var(--gold)}

.footer-social{display:flex;gap:12px}
.footer-social a{
    width:36px;height:36px;border-radius:50%;
    border:1px solid rgba(201,168,76,.15);
    display:flex;align-items:center;justify-content:center;
    color:var(--silver);transition:all .3s;
}
.footer-social a:hover{
    border-color:var(--gold);color:var(--gold);
    transform:translateY(-2px);
}
.footer-social a svg{width:16px;height:16px}

.footer-bottom{
    width:90%;max-width:var(--container-w);margin:28px auto 0;
    padding-top:20px;
    border-top:1px solid rgba(255,255,255,.04);
    display:flex;align-items:center;justify-content:space-between;
    flex-wrap:wrap;gap:12px;
}
.footer-bottom p{font-size:.72rem;color:var(--text-muted)}
.footer-bottom a{color:var(--gold);transition:color .3s}
.footer-bottom a:hover{color:var(--gold-light)}

/* ---------- PAGE HEADER (INNER PAGES) ---------- */
.page-header{
    position:relative;padding:160px 0 80px;
    overflow:hidden;
    background:linear-gradient(180deg,var(--surface) 0%,var(--navy) 100%);
}
.page-header .header-grid{
    position:absolute;inset:0;
    background-image:
        linear-gradient(rgba(201,168,76,.025) 1px,transparent 1px),
        linear-gradient(90deg,rgba(201,168,76,.025) 1px,transparent 1px);
    background-size:80px 80px;
}
.page-header .header-glow{
    position:absolute;top:-100px;right:-100px;
    width:500px;height:500px;border-radius:50%;
    background:radial-gradient(circle,rgba(201,168,76,.06),transparent 70%);
}
.page-header .container{position:relative;z-index:1}
.page-header h1{font-size:2.8rem;font-weight:700;letter-spacing:-.5px;margin-bottom:16px}
.page-header p{font-size:1.05rem;color:var(--silver);max-width:600px;line-height:1.7}

/* ---------- FADE-IN ANIMATION ---------- */
.fade-in{
    opacity:0;transform:translateY(30px);
    transition:opacity .7s ease,transform .7s ease;
}
.fade-in.visible{opacity:1;transform:translateY(0)}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1024px){
    .cards-grid{grid-template-columns:repeat(2,1fr)}
    .img-section{grid-template-columns:1fr;gap:32px}
    .contact-grid{grid-template-columns:1fr}
    .hero h1{font-size:2.8rem}
    .section-title{font-size:2rem}
    .page-header h1{font-size:2.2rem}
}

@media(max-width:768px){
    :root{--section-pad:60px 0}
    .nav-links{
        position:fixed;top:68px;left:0;right:0;
        background:rgba(10,14,26,.96);
        backdrop-filter:blur(20px);
        flex-direction:column;gap:0;
        max-height:0;overflow:hidden;
        transition:max-height .4s ease;
        border-bottom:1px solid var(--border);
    }
    .nav-links.open{max-height:500px}
    .nav-links a{
        display:block;padding:14px 5%;
        border-bottom:1px solid rgba(255,255,255,.03);
        width:100%;
    }
    .nav-toggle{display:flex}
    .hero h1{font-size:2.2rem}
    .hero-stats{gap:24px}
    .cards-grid{grid-template-columns:1fr}
    .cards-grid-2{grid-template-columns:1fr}
    .gallery-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
    .footer-inner{flex-direction:column;gap:24px}
    .footer-bottom{flex-direction:column;align-items:flex-start}
}

@media(max-width:480px){
    .hero h1{font-size:1.7rem}
    .section-title{font-size:1.6rem}
    .page-header{padding:130px 0 60px}
    .page-header h1{font-size:1.8rem}
    .card{padding:28px 24px}
    .hero-stat .num{font-size:1.5rem}
}
