:root{
--bg:#ffffff;
--text:#111111;
--accent:#0A84FF;
--card:#f4f4f4;
}

body.dark{
--bg:#0e0e0e;
--text:#f2f2f2;
--accent:#4da3ff;
--card:#1a1a1a;
}

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

html{
scroll-behavior:smooth;
}

body{
font-family:'Inter',sans-serif;
background:var(--bg);
color:var(--text);
line-height:1.6;
transition:0.3s ease;
}

/* NAV */

nav{
position:fixed;
width:100%;
top:0;
display:flex;
justify-content:space-between;
align-items:center;
padding:10px 10%;
background:rgba(255,255,255,0.7);
backdrop-filter:blur(8px);
z-index:1000;
}
body.dark nav{
background:rgba(0,0,0,0.6);
}

nav h2{
font-family:'Playfair Display',serif;
}

nav ul{
display:flex;
gap:20px;
list-style:none;
}

nav a{
text-decoration:none;
color:var(--text);
font-weight:500;
}

.theme-toggle{
cursor:pointer;
border:none;
background:var(--accent);
color:white;
padding:8px 14px;
border-radius:20px;
}

/* HERO */

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

.hero video{
position:absolute;
top:0;
left:0;
width:100%;
height:100%;
object-fit:cover;
z-index:-1;
}

.hero-overlay{
background:rgba(0,0,0,0.45);
position:absolute;
width:100%;
height:100%;
z-index:-1;
}

.hero h1{
font-family:'Playfair Display',serif;
font-size:60px;
margin-bottom:20px;
}

.hero p{
font-size:18px;
margin-bottom:30px;
}

.cta{
padding:14px 30px;
background:var(--accent);
border:none;
color:white;
border-radius:30px;
font-size:16px;
cursor:pointer;
}

/* SECTIONS */

section{
padding:100px 10%;
max-width:1300px;
margin:auto;
}

.section-title{
font-family:'Playfair Display',serif;
font-size:20px;
margin-bottom:40px;
text-align:center;
}

/* ABOUT */

.about{
display:grid;
grid-template-columns:1fr 1fr;
gap:50px;
}

.about p{
font-size:18px;
}

/* GALLERY */

.gallery{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
gap:20px;
}

.gallery img{
width:100%;
height:260px;
object-fit:cover;
border-radius:8px;
transition:0.4s;
}

.gallery img:hover{
transform:scale(1.05);
}

/* TESTIMONIALS */

.testimonials{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
gap:30px;
}

.testimonial{
background:var(--card);
padding:30px;text-align:center;
border-radius:8px;
}

.testimonial p{
font-style:italic;
}

/* CONTACT */

form{
max-width:600px;
text-align:center;margin:auto;
display:flex;
flex-direction:column;
gap:15px;
}

input, textarea{
padding:14px;
border:1px solid #ccc;
border-radius:6px;
font-family:'Inter';
}

button.submit{
background:var(--accent);
border:none;
color:white;
padding:14px;
border-radius:6px;
cursor:pointer;
}

/* FOOTER */

footer{
padding:40px 10%;
text-align:center;
background:var(--card);
}

footer a{
margin:0 10px;
color:var(--text);
text-decoration:none;
}

/* ANIMATIONS */

.fade{
opacity:0;
transform:translateY(30px);
transition:1s;
}

.fade.visible{
opacity:1;
transform:translateY(0);
}

/* MOBILE */

@media(max-width:800px){

.hero h1{
font-size:42px;
}

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

nav ul{
display:none;
}

}