/* ===== BASE ===== */

body{
margin:0;
font-family:'Playfair Display',serif;
background-color:#F1ECE6;
color:#3A342F;
}

img{
max-width:100%;
height:auto;
display:block;
}

/* ===== HEADER ===== */

header{
text-align:center;
padding:60px 20px 30px 20px;
}

.logo img{
width:400px;
margin:auto;
filter:grayscale(100%) brightness(0);
transition: transform 0.35s ease, opacity 0.35s ease;
cursor:pointer;
}

.logo img:hover{
transform:scale(1.04);
opacity:0.85;
}

/* ===== NAV ===== */

nav{
margin-top:35px;
}

nav a{
margin:0 20px;
text-decoration:none;
color:#3A342F;
font-weight:300;
letter-spacing:2px;
font-size:13px;
position:relative;
font-family:'Montserrat',sans-serif;
}

nav a:after{
content:"";
position:absolute;
width:0;
height:1px;
background:#D8CDC3;
left:50%;
transform:translateX(-50%);
bottom:-6px;
transition:width .3s ease;
}

nav a:hover:after{
width:100%;
}

nav a.active{
font-weight:500;
}

nav a.active:after{
width:100%;
}

/* ===== HERO ===== */

.hero{
background-image:linear-gradient(
rgba(255,255,255,0.65),
rgba(255,255,255,0.65)
),
url("studio2.jpg");

background-size:cover;
background-position:center;

padding:120px 20px;
margin-top:70px;

text-align:center;

box-shadow:0 20px 60px rgba(0,0,0,0.04);
}

.hero h1{
font-family:'Cormorant Garamond',serif;
font-size:48px;
font-style:italic;
letter-spacing:1px;
margin-bottom:25px;
}

/* ===== BUTTON ===== */

.button{
display:inline-block;
margin-top:40px;
background-color:#E7DED6;
color:#3A342F;
padding:15px 36px;
text-decoration:none;
border-radius:50px;
font-size:12px;
letter-spacing:2px;
border:1px solid #E7DED6;
transition:all .35s ease;
}

.button:hover{
background-color:transparent;
border:1px solid #3A342F;
transform:scale(1.02);
box-shadow:0 12px 30px rgba(0,0,0,0.08);
}

/* ===== TEXT ===== */

section{
padding:40px 20px 80px 20px;
text-align:center;
}

section p{
max-width:680px;
margin:24px auto;
line-height:1.9;
font-size:17px;
}

/* ===== CLASS TYPES ===== */

.class-types{
list-style:none;
padding:0;
margin:25px auto;
max-width:350px;
text-align:center;
}

.class-types li{
margin:8px 0;
}

/* ===== CLASSES PAGE ===== */

.classes{
width:85%;
margin:10px auto;
}

.class-list{
max-width:600px;
margin:60px auto;
}

.class-item{
display:block;
padding:22px 24px;
text-decoration:none;
color:#3A342F;
transition:all .3s ease;
border-radius:12px;
}

.class-item:hover{
background:#F1ECE6;
transform:translateY(-2px);
box-shadow:0 8px 20px rgba(0,0,0,0.04);
}

.class-item h3{
font-family:'Cormorant Garamond',serif;
font-size:28px;
margin:0;
}

.class-item p{
font-size:13px;
letter-spacing:2px;
opacity:.7;
}

/* ===== ABOUT / PT ===== */

.about{
width:85%;
max-width:1100px;
margin:80px auto;
}

.about-container{
display:flex;
align-items:flex-start;
justify-content:space-between;
gap:80px;
margin-top:80px;
}

.about-text{
flex:1;
max-width:620px;
text-align:left;
}

.about-image{
flex:0 0 360px;
display:flex;
justify-content:center;
}

.about-image img{
width:100%;
height:auto;
border-radius:30px;
}

/* ===== CONTACT ===== */

.contact{
width:85%;
margin:80px auto;
}

.contact-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
}

.contact a{
color:#3A342F;
text-decoration:none;
font-weight:400;
transition:font-weight .2s ease;
}

.contact a:hover{
font-weight:500;
}

/* ===== CONTACT FORM ===== */

.contact-form input,
.contact-form textarea{
width:100%;
padding:14px 16px;
border:1px solid #DED6CF;
border-radius:10px;
background:#F7F3EE;
font-family:'Playfair Display',serif;
font-size:14px;
margin-bottom:15px;
outline:none;
transition:all .25s ease;
}

.contact-form input:focus,
.contact-form textarea:focus{
border-color:#CFC3B8;
background:#FFFFFF;
}

.contact-form textarea{
min-height:120px;
resize:vertical;
}

/* ===== FOOTER ===== */

.footer{
width:85%;
margin:80px auto 40px auto;
padding-top:40px;
border-top:1px solid #DED6CF;
text-align:center;
}

.footer p{
font-size:12px;
letter-spacing:2px;
margin-bottom:20px;
}

.footer-icons{
display:flex;
justify-content:center;
gap:20px;
}

.footer-icons img{
width:24px;
opacity:.8;
transition:.3s;
}

.footer-icons img:hover{
opacity:1;
transform:scale(1.1);
}

/* ===== HAMBURGER ===== */

.hamburger{
display:none;
font-size:28px;
cursor:pointer;
color:#3A342F;
user-select:none;
}

/* ===== MOBILE ===== */

@media (max-width:768px){

.logo img{
width:230px;
}

.hamburger{
display:block;
text-align:center;
}

/* MENU */

nav{
display:none;
flex-direction:column;
align-items:center;
gap:18px;

background:#F1ECE6;
padding:25px 0;
margin-top:25px;

border-radius:20px;
box-shadow:0 15px 40px rgba(0,0,0,0.05);
}

nav.show{
display:flex;
animation:menuFade .35s ease;
}

nav a{
font-size:14px;
letter-spacing:3px;
}

/* HERO */

.hero{
padding:80px 20px;
margin-top:40px;
}

.hero h1{
font-size:34px;
}

/* ABOUT */

.about-container{
flex-direction:column;
align-items:center;
gap:40px;
}

.about-text{
text-align:center;
max-width:600px;
}

.about-image{
flex:none;
width:100%;
}

.about-image img{
width:80%;
max-width:360px;
margin:auto;
}

/* CONTACT */

.contact-grid{
grid-template-columns:1fr;
gap:40px;
}

/* CLASSES */

.class-item{
padding:18px;
}

}

/* ===== MENU ANIMATION ===== */

@keyframes menuFade{

from{
opacity:0;
transform:translateY(-10px);
}

to{
opacity:1;
transform:translateY(0);
}

}