/* ===========================
   RUNAWAY STUDIO
   Premium Photography Website
=========================== */

#progress{

position:fixed;

top:0;

left:0;

height:4px;

width:0;

background:linear-gradient(90deg,#d4af37,#ffd700);

z-index:99999;

}

#topBtn{

position:fixed;

bottom:30px;

right:30px;

width:55px;

height:55px;

border:none;

border-radius:50%;

background:#d4af37;

color:#111;

font-size:24px;

cursor:pointer;

opacity:0;

visibility:hidden;

transition:.35s;

z-index:999;

}

#topBtn.show{

opacity:1;

visibility:visible;

}

.nav-menu a.active{

color:#d4af37;

}

/* =======================
PRELOADER
======================= */

#preloader{

position:fixed;

inset:0;

background:#05070d;

display:flex;

justify-content:center;

align-items:center;

z-index:999999;

transition:.7s;

}

.loader{

width:80px;

height:80px;

border-radius:50%;

border:6px solid rgba(255,255,255,.15);

border-top:6px solid #d4af37;

animation:spin 1s linear infinite;

}

@keyframes spin{

to{

transform:rotate(360deg);

}

}

/* =======================
LIGHTBOX
======================= */

#lightbox{

position:fixed;

inset:0;

background:rgba(0,0,0,.92);

display:flex;

justify-content:center;

align-items:center;

opacity:0;

visibility:hidden;

transition:.4s;

z-index:99999;

}

#lightbox.active{

opacity:1;

visibility:visible;

}

#lightbox img{

max-width:90%;

max-height:90%;

border-radius:15px;

}

#closeLightbox{

position:absolute;

top:30px;

right:40px;

font-size:55px;

color:white;

cursor:pointer;

}

/* =======================
WHATSAPP
======================= */

.whatsapp{

position:fixed;

right:30px;

bottom:30px;

width:65px;

height:65px;

border-radius:50%;

background:#25D366;

display:flex;

justify-content:center;

align-items:center;

font-size:32px;

color:white;

text-decoration:none;

box-shadow:0 10px 30px rgba(0,0,0,.3);

z-index:9999;

transition:.3s;

}

.whatsapp:hover{

transform:scale(1.12);

}

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

/* ===========================
        RESET
=========================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

html{
    scroll-behavior:smooth;
}

body{

    font-family:'Poppins',sans-serif;

    background:#05070d;

    color:#fff;

    overflow-x:hidden;

    line-height:1.7;

}

/* Scrollbar */

::-webkit-scrollbar{

    width:10px;

}

::-webkit-scrollbar-track{

    background:#05070d;

}

::-webkit-scrollbar-thumb{

    background:#d4af37;

    border-radius:20px;

}

::-webkit-scrollbar-thumb:hover{

    background:#f5d76e;

}

/* ===========================
        VARIABLES
=========================== */

:root{

--primary:#d4af37;

--secondary:#ffffff;

--dark:#05070d;

--card:#0d111c;

--glass:rgba(255,255,255,.06);

--border:rgba(255,255,255,.12);

--text:#ffffff;

--muted:#b8bcc7;

--gradient:linear-gradient(
135deg,
#d4af37,
#ffe27a
);

}

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

.container{

    width:90%;

    max-width:1300px;

    margin:auto;

}

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

.background-blur{

    position:fixed;

    width:500px;

    height:500px;

    border-radius:50%;

    filter:blur(140px);

    opacity:.18;

    z-index:-2;

}

.blur1{

    background:#d4af37;

    top:-200px;

    left:-120px;

    animation:float1 12s infinite ease-in-out;

}

.blur2{

    background:#0ea5e9;

    bottom:-250px;

    right:-150px;

    animation:float2 14s infinite ease-in-out;

}

@keyframes float1{

0%{

transform:translate(0,0);

}

50%{

transform:translate(100px,60px);

}

100%{

transform:translate(0,0);

}

}

@keyframes float2{

0%{

transform:translate(0,0);

}

50%{

transform:translate(-120px,-80px);

}

100%{

transform:translate(0,0);

}

}

/* ===========================
      PARTICLE CANVAS
=========================== */

#particles{

position:fixed;

top:0;

left:0;

width:100%;

height:100%;

z-index:-3;

}

/* ===========================
        NAVBAR 
=========================== */

.navbar{
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 9999;

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

    padding: 18px 40px;

    background: rgba(8,10,18,.65);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);

    border-bottom: 1px solid rgba(255,255,255,.08);

    transition: .3s ease;
}

/* LOGO */
.logo{
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 2px;
    color: #fff;
}

/* MENU */
.nav-menu{
    display: flex;
    gap: 30px;
    align-items: center;
}

.nav-menu a{
    text-decoration: none;
    color: #fff;
    font-size: .95rem;
    font-weight: 500;
    position: relative;
    transition: .3s;
}

/* underline hover */
.nav-menu a::after{
    content: "";
    position: absolute;
    left: 0;
    bottom: -6px;
    width: 0%;
    height: 2px;
    background: var(--primary);
    transition: .3s;
}

.nav-menu a:hover{
    color: var(--primary);
}

.nav-menu a:hover::after{
    width: 100%;
}

/* ACTIVE LINK */
.nav-menu a.active{
    color: var(--primary);
}

.nav-menu a.active::after{
    width: 100%;
}

/* MOBILE MENU (optional) */
#menu-btn{
    display: none;
    font-size: 1.6rem;
    cursor: pointer;
    color: #fff;
}

/* RESPONSIVE */
@media(max-width: 768px){
    .nav-menu{
        display: none;
    }

    #menu-btn{
        display: block;
    }
}

body{
    padding-top: 80px;
}


/* ===========================
        HERO FINAL FIX
=========================== */

.hero{
    position: relative;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    overflow: hidden;
}

/* VIDEO BACKGROUND */
.hero-video{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -2;
}

/* OVERLAY */
.overlay{
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.65);
    z-index: -1;
}

/* CONTENT */
.hero-content{
    max-width: 900px;
    padding: 20px;
    z-index: 2;
}

/* TOP TEXT */
.hero-content p:first-child{
    color: var(--primary);
    letter-spacing: 4px;
    font-size: 1rem;
    text-transform: uppercase;
    margin-bottom: 20px;
}

/* TITLE */
.hero h1{
    font-size: 5rem;
    line-height: 1.1;
    font-family: 'Playfair Display', serif;
    margin-bottom: 20px;
    color: #fff;
}

/* GRADIENT TEXT */
.hero h1 span{
    background: var(--gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
}

/* SUB TEXT */
.hero-desc{
    font-size: 1.1rem;
    max-width: 700px;
    margin: 25px auto;
    color: var(--muted);
}

/* BUTTON WRAPPER */
.hero-btn{
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 45px;
    flex-wrap: wrap;
}

/* BUTTON PRIMARY */
.btn-primary{
    padding: 15px 38px;
    background: var(--gradient);
    border-radius: 50px;
    color: #111;
    font-weight: 700;
    text-decoration: none;
    transition: .3s;
}

.btn-primary:hover{
    transform: translateY(-5px);
}

/* BUTTON OUTLINE */
.btn-outline{
    padding: 15px 38px;
    border-radius: 50px;
    border: 2px solid rgba(255,255,255,.2);
    color: #fff;
    text-decoration: none;
    transition: .3s;
}

.btn-outline:hover{
    background: #fff;
    color: #111;
}

/* SOCIAL ICONS */
.socials{
    display: flex;
    justify-content: center;
    gap: 20px;
    margin-top: 50px;
}

.socials a{
    width: 50px;
    height: 50px;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    background: rgba(255,255,255,.05);
    color: #fff;
    font-size: 1.2rem;
    transition: .3s;
}

.socials a:hover{
    background: var(--primary);
    color: #111;
    transform: translateY(-5px);
}

/* SCROLL DOWN */
.scroll-down{
    position: absolute;
    bottom: 25px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 2rem;
    color: #fff;
    animation: bounce 2s infinite;
}

/* ANIMATION */
@keyframes bounce{
    0%,100%{ transform: translate(-50%,0); }
    50%{ transform: translate(-50%,12px); }
}

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

@media(max-width: 991px){
    .hero h1{
        font-size: 3.5rem;
    }
}

@media(max-width: 768px){
    .hero h1{
        font-size: 2.5rem;
    }

    .hero-desc{
        font-size: .95rem;
    }

    .socials{
        gap: 15px;
    }
}
/* ===========================
      RESPONSIVE HERO
=========================== */

@media(max-width:991px){

.hero h1{

font-size:3.5rem;

}

.nav-menu{

display:none;

}

#menu-btn{

display:block;

}

}

@media(max-width:768px){

.hero h1{

font-size:2.7rem;

}

.hero-desc{

font-size:.95rem;

}

.logo span{

display:none;

}

}

/* ===================================
        SECTION GLOBAL
=================================== */

section{
    padding:120px 0;
    position:relative;
}

.section-title{
    text-align:center;
    margin-bottom:70px;
}

.section-title p{

    color:var(--primary);

    letter-spacing:4px;

    text-transform:uppercase;

    font-size:.9rem;

    margin-bottom:12px;

}

.section-title h2{

    font-family:'Playfair Display',serif;

    font-size:3rem;

    margin-bottom:15px;

}

.section-title::after{

    content:"";

    display:block;

    width:90px;

    height:4px;

    margin:25px auto;

    border-radius:20px;

    background:var(--gradient);

}

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

#about{

    background:#070b14;

}

#about .container{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:70px;

    align-items:center;

}

.about-image{

    position:relative;

}

.about-image img{

    width:100%;

    border-radius:25px;

    display:block;

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

    transition:.5s;

}

.about-image:hover img{

    transform:scale(1.03);

}

.about-image::before{

    content:"";

    position:absolute;

    inset:-15px;

    border:2px solid rgba(212,175,55,.25);

    border-radius:30px;

    z-index:-1;

}

.about-content h2{

    font-family:'Playfair Display',serif;

    font-size:3rem;

    line-height:1.2;

    margin:20px 0;

}

.about-content p{

    color:var(--muted);

    margin-bottom:35px;

    font-size:1rem;

}

.about-grid{

    display:grid;

    grid-template-columns:repeat(3,1fr);

    gap:20px;

}

.about-grid div{

    background:rgba(255,255,255,.04);

    border:1px solid rgba(255,255,255,.08);

    backdrop-filter:blur(10px);

    border-radius:18px;

    padding:30px;

    text-align:center;

    transition:.35s;

}

.about-grid div:hover{

    transform:translateY(-8px);

    border-color:rgba(212,175,55,.5);

}

.about-grid h3{

    color:var(--primary);

    font-size:2rem;

}

.about-grid p{

    margin:10px 0 0;

}

/* ===================================
            SERVICES
=================================== */

#services{

    background:#05070d;

}

.services-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(280px,1fr));

    gap:35px;

}

.service-card{

    position:relative;

    overflow:hidden;

    background:rgba(255,255,255,.04);

    backdrop-filter:blur(14px);

    border:1px solid rgba(255,255,255,.08);

    border-radius:25px;

    padding:45px 35px;

    transition:.45s;

    cursor:pointer;

}

.service-card::before{

    content:"";

    position:absolute;

    width:220px;

    height:220px;

    background:rgba(212,175,55,.12);

    border-radius:50%;

    top:-120px;

    right:-120px;

    transition:.5s;

}

.service-card:hover::before{

    transform:scale(2);

}

.service-card:hover{

    transform:translateY(-12px);

    border-color:rgba(212,175,55,.45);

    box-shadow:0 25px 50px rgba(0,0,0,.35);

}

.service-card i{

    font-size:2.8rem;

    color:var(--primary);

    margin-bottom:25px;

    transition:.35s;

}

.service-card:hover i{

    transform:rotate(10deg) scale(1.15);

}

.service-card h3{

    font-size:1.5rem;

    margin-bottom:18px;

}

.service-card p{

    color:var(--muted);

    line-height:1.8;

}

/* ===================================
            CTA STRIP
=================================== */

.cta{

    margin-top:80px;

    border-radius:30px;

    background:linear-gradient(
        135deg,
        rgba(212,175,55,.12),
        rgba(255,255,255,.03)
    );

    border:1px solid rgba(255,255,255,.08);

    padding:70px;

    text-align:center;

}

.cta h2{

    font-family:'Playfair Display',serif;

    font-size:3rem;

    margin-bottom:20px;

}

.cta p{

    color:var(--muted);

    max-width:650px;

    margin:auto auto 40px;

}

.cta .btn-primary{

    display:inline-block;

}

/* ===================================
            HOVER EFFECT
=================================== */

img{

    transition:.5s;

}

img:hover{

    filter:brightness(1.05);

}

button,
a{

    transition:.35s;

}

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

@media(max-width:991px){

#about .container{

grid-template-columns:1fr;

}

.about-content{

text-align:center;

}

.about-grid{

grid-template-columns:1fr;

}

.section-title h2{

font-size:2.5rem;

}

.cta{

padding:50px 30px;

}

}

@media(max-width:768px){

.section-title h2{

font-size:2rem;

}

.about-content h2{

font-size:2.2rem;

}

.service-card{

padding:35px 25px;

}

.cta h2{

font-size:2rem;

}

}

/* ===================================
        PORTFOLIO
=================================== */

#portfolio{
    background:#070b14;
}

.portfolio-filter{
    display:flex;
    justify-content:center;
    flex-wrap:wrap;
    gap:15px;
    margin-bottom:60px;
}

.portfolio-filter button{

    background:transparent;

    color:#fff;

    border:1px solid rgba(255,255,255,.1);

    padding:12px 28px;

    border-radius:50px;

    cursor:pointer;

    transition:.35s;

}

.portfolio-filter button:hover,
.portfolio-filter .active{

    background:var(--gradient);

    color:#111;

    border:none;

}

.portfolio-grid{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(320px,1fr));

    gap:28px;

}

.portfolio-item{

    position:relative;

    overflow:hidden;

    border-radius:25px;

    cursor:pointer;

}

.portfolio-item img{

    width:100%;

    height:420px;

    object-fit:cover;

    transition:.7s;

}

.portfolio-item:hover img{

    transform:scale(1.12);

}

.portfolio-overlay{

    position:absolute;

    inset:0;

    background:linear-gradient(
    transparent,
    rgba(0,0,0,.85));

    display:flex;

    flex-direction:column;

    justify-content:flex-end;

    padding:35px;

    opacity:0;

    transition:.4s;

}

.portfolio-item:hover .portfolio-overlay{

    opacity:1;

}

.portfolio-overlay h3{

    color:var(--primary);

    font-size:1.7rem;

}

.portfolio-overlay p{

    color:#ddd;

}

/* ===================================
        TESTIMONIAL
=================================== */

#testimonial{

    background:#05070d;

}

.testimonial-wrapper{

    display:grid;

    grid-template-columns:repeat(auto-fit,minmax(350px,1fr));

    gap:35px;

}

.testimonial-card{

    background:rgba(255,255,255,.04);

    border:1px solid rgba(255,255,255,.08);

    border-radius:25px;

    padding:40px;

    backdrop-filter:blur(18px);

    transition:.4s;

}

.testimonial-card:hover{

    transform:translateY(-10px);

    border-color:rgba(212,175,55,.5);

}

.testimonial-card i{

    font-size:3rem;

    color:var(--primary);

    margin-bottom:20px;

}

.testimonial-card p{

    color:var(--muted);

    margin-bottom:25px;

}

.testimonial-card h3{

    color:#fff;

}

.testimonial-card span{

    color:var(--primary);

}

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

#contact{
    background: #070b14;
    padding: 120px 8%;
}

/* GRID LAYOUT */
.contact-grid{
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 60px;
    align-items: start;
}

/* INFO SIDE */
.contact-info h3{
    font-size: 2rem;
    margin-bottom: 25px;
    color: #fff;
}

.contact-info p{
    margin-bottom: 18px;
    color: var(--muted);
    line-height: 1.6;
}

.contact-info i{
    color: var(--primary);
    margin-right: 10px;
}

/* FORM */
.contact-form{
    display: flex;
    flex-direction: column;
    gap: 20px;
}

/* INPUT & TEXTAREA */
.contact-form input,
.contact-form textarea{
    width: 100%;
    padding: 16px 18px;

    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 14px;

    color: #fff;
    outline: none;

    transition: .3s ease;
    font-size: 0.95rem;
}

/* TEXTAREA SIZE */
.contact-form textarea{
    min-height: 160px;
    resize: none;
}

/* FOCUS EFFECT */
.contact-form input:focus,
.contact-form textarea:focus{
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(212,175,55,.1);
}

/* BUTTON */
.contact-form button{
    border: none;
    cursor: pointer;
}

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

@media(max-width: 991px){
    .contact-grid{
        grid-template-columns: 1fr;
        gap: 40px;
    }

    #contact{
        padding: 100px 5%;
    }
}

/* ===================================
        FOOTER
=================================== */

footer{

    background:#040506;

    padding:70px 0 40px;

    text-align:center;

}

footer h2{

    font-family:'Playfair Display',serif;

    color:var(--primary);

    margin-bottom:15px;

}

footer p{

    color:#aaa;

}

.footer-social{

    display:flex;

    justify-content:center;

    gap:18px;

    margin:30px 0;

}

.footer-social a{

    width:48px;

    height:48px;

    display:flex;

    justify-content:center;

    align-items:center;

    border-radius:50%;

    background:rgba(255,255,255,.05);

    color:#fff;

    transition:.35s;

}

.footer-social a:hover{

    background:var(--primary);

    color:#111;

    transform:translateY(-5px);

}

.copyright{

    margin-top:25px;

    font-size:.9rem;

    color:#777;

}

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

@media(max-width:991px){

.contact-grid{

grid-template-columns:1fr;

}

.portfolio-grid{

grid-template-columns:1fr;

}

.testimonial-wrapper{

grid-template-columns:1fr;

}

}

@media(max-width:768px){

.portfolio-item img{

height:300px;

}

.portfolio-overlay{

padding:25px;

}

.section-title h2{

font-size:2rem;

}

}

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

.gallery-hero{

padding-top:180px;
padding-bottom:120px;

text-align:center;

background:
linear-gradient(
rgba(0,0,0,.65),
rgba(0,0,0,.75)
),
url("gallery-bg.jpg");

background-size:cover;
background-position:center;
background-attachment:fixed;

}

.gallery-hero h1{

font-size:4rem;
margin-bottom:20px;

}

.gallery-hero p{

max-width:700px;

margin:auto;

font-size:1.1rem;

opacity:.8;

}

/*==================================
        FILTER
==================================*/

.portfolio-section{

padding:100px 8%;

}

.portfolio-filter{

display:flex;

justify-content:center;

flex-wrap:wrap;

gap:15px;

margin-bottom:70px;

}

.portfolio-filter button{

background:rgba(255,255,255,.06);

border:none;

padding:14px 32px;

border-radius:50px;

color:white;

cursor:pointer;

font-size:.95rem;

transition:.4s;

}

.portfolio-filter button:hover,

.portfolio-filter .active{

background:var(--primary);

color:#000;

}

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

.portfolio-grid{

column-count:3;

column-gap:25px;

}

.portfolio-item{

position:relative;

overflow:hidden;

margin-bottom:25px;

border-radius:22px;

break-inside:avoid;

cursor:pointer;

}

.portfolio-item img{

width:100%;

display:block;

transition:.7s;

border-radius:22px;

}

.portfolio-item:hover img{

transform:scale(1.08);

filter:brightness(.55);

}

/*==================================
        OVERLAY
==================================*/

.portfolio-overlay{

position:absolute;

left:0;

right:0;

bottom:0;

padding:30px;

background:linear-gradient(

transparent,

rgba(0,0,0,.95)

);

opacity:0;

transition:.45s;

}

.portfolio-item:hover .portfolio-overlay{

opacity:1;

}

.portfolio-overlay h3{

font-size:1.6rem;

margin-bottom:8px;

}

.portfolio-overlay p{

opacity:.75;

}

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

.gallery-bottom{

text-align:center;

margin-top:80px;

}

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

@media(max-width:992px){

.portfolio-grid{

column-count:2;

}

.gallery-hero h1{

font-size:3rem;

}

}

@media(max-width:650px){

.portfolio-grid{

column-count:1;

}

.gallery-hero{

padding-top:140px;

}

.gallery-hero h1{

font-size:2.3rem;

}

.portfolio-filter{

gap:10px;

}

.portfolio-filter button{

padding:10px 20px;

font-size:.8rem;

}

}

/*========================
PRICING
========================*/

.pricing {
    padding: 150px 8%;
}

.pricing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 35px;
    margin-top: 60px;
}

.price-card {
    position: relative;
    background: rgba(255,255,255,.05);
    padding: 45px;
    border-radius: 25px;
    backdrop-filter: blur(20px);
    text-align: center;
    transition: .4s;
    border: 1px solid rgba(255,255,255,.08);
}

.price-card:hover {
    transform: translateY(-12px);
}

.price-card h2 {
    font-size: 2.8rem;
    margin: 25px 0;
    color: var(--primary);
}

.price-card ul {
    list-style: none;
    margin: 35px 0;
    padding: 0;
}

.price-card li {
    margin: 15px 0;
}

.price-card li i {
    color: var(--primary);
    margin-right: 10px;
}

/* FIX: popular jangan override hover transform */
.popular {
    border: 2px solid var(--primary);
    transform: scale(1.05);
}

/*=========================
SERVICES
=========================*/

.services-hero {
    padding: 180px 20px 100px;
    text-align: center;
}

.services-hero h1 {
    font-size: 4rem;
    margin-bottom: 20px;
}

.services-hero p {
    max-width: 700px;
    margin: auto;
    opacity: .8;
}

.services {
    padding: 100px 8%;
}

.service-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
    gap: 35px;
}

.service-card {
    padding: 45px;
    text-align: center;
    border-radius: 25px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(20px);
    transition: .4s;
}

.service-card:hover {
    transform: translateY(-10px);
    border-color: var(--primary);
}

.service-card i {
    font-size: 3rem;
    color: var(--primary);
    margin-bottom: 25px;
}

.service-card h3 {
    margin-bottom: 18px;
}

.service-card p {
    margin-bottom: 30px;
    opacity: .75;
}

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

.cta {
    padding: 120px 20px;
    text-align: center;
}

.cta h2 {
    font-size: 3rem;
    margin-bottom: 20px;
}

.cta p {
    margin-bottom: 35px;
    opacity: .8;
}

/* =========================
ABOUT PAGE
========================= */

.about-hero{
    padding:180px 8% 80px;
    text-align:center;
}

.about-hero h1{
    font-size:4rem;
    font-family:'Playfair Display',serif;
}

.about-hero p{
    max-width:700px;
    margin:20px auto 0;
    color:var(--muted);
}

/* MAIN */
.about-page{
    padding:80px 8% 120px;
}

.about-wrapper{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
}

.about-image img{
    width:100%;
    border-radius:25px;
    box-shadow:0 25px 60px rgba(0,0,0,.5);
}

/* CONTENT */
.about-content h2{
    font-size:2.5rem;
    margin-bottom:20px;
    font-family:'Playfair Display',serif;
}

.about-content p{
    color:var(--muted);
    margin-bottom:20px;
    line-height:1.8;
}

/* STATS */
.about-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
    margin-top:30px;
}

.about-grid div{
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.08);
    padding:25px;
    border-radius:18px;
    text-align:center;
}

.about-grid h3{
    color:var(--primary);
    font-size:2rem;
}

/* VISION MISSION */
.vision-mission{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:30px;
    margin-top:80px;
}

.vm-card{
    background:rgba(255,255,255,.05);
    border:1px solid rgba(255,255,255,.08);
    padding:40px;
    border-radius:25px;
    backdrop-filter:blur(20px);
}

.vm-card h3{
    color:var(--primary);
    margin-bottom:15px;
}

.vm-card p{
    color:var(--muted);
    line-height:1.8;
}

/* RESPONSIVE */
@media(max-width:991px){
    .about-wrapper{
        grid-template-columns:1fr;
    }

    .vision-mission{
        grid-template-columns:1fr;
    }

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

    .about-hero h1{
        font-size:2.8rem;
    }
}

/* ================= GALLERY PRO ================= */

.portfolio-section{
    padding:120px 8%;
}

.portfolio-filter{
    display:flex;
    justify-content:center;
    gap:12px;
    flex-wrap:wrap;
    margin-bottom:50px;
}

.portfolio-filter button{
    padding:10px 22px;
    border-radius:30px;
    border:none;
    background:rgba(255,255,255,.06);
    color:#fff;
    cursor:pointer;
    transition:.3s;
}

.portfolio-filter button.active,
.portfolio-filter button:hover{
    background:var(--primary);
    color:#111;
}

/* MASONRY STYLE */
.portfolio-grid{
    column-count:3;
    column-gap:20px;
}

.portfolio-item{
    break-inside:avoid;
    margin-bottom:20px;
    position:relative;
    border-radius:20px;
    overflow:hidden;
    cursor:pointer;
}

.portfolio-item img{
    width:100%;
    display:block;
    transition:.5s;
    border-radius:20px;
}

.portfolio-item:hover img{
    transform:scale(1.08);
    filter:brightness(.6);
}

/* OVERLAY */
.portfolio-overlay{
    position:absolute;
    bottom:0;
    left:0;
    right:0;
    padding:20px;
    background:linear-gradient(transparent, rgba(0,0,0,.9));
    opacity:0;
    transition:.3s;
}

.portfolio-item:hover .portfolio-overlay{
    opacity:1;
}

.portfolio-overlay h3{
    color:var(--primary);
    font-size:1.3rem;
}
