* { margin: 0; padding: 0; box-sizing: border-box; }
body { background: #f2f2f2; font-family: 'Oswald', sans-serif; color: #111; overflow-x: hidden; }

.container { display: flex; padding: 60px 80px; gap: 80px; }
.sidebar { width: 280px; }

.logo { display: inline-block; text-decoration: none; color: inherit; cursor: pointer; }
.logo h1 { font-size: 54px; line-height: 48px; letter-spacing: 4px; }
.logo span { font-size: 13px; letter-spacing: 3px; opacity: 0.6; }
.logo:hover { opacity: 0.8; }

.language-switcher { display: flex; justify-content: flex-end; align-items: center; margin: 10px 0; gap: 8px; }
.language-switcher img { width: 24px; height: 24px; cursor: pointer; transition: transform 0.2s; }
.language-switcher img:hover { transform: scale(1.2); }
@media (max-width: 768px) {
 .language-switcher { justify-content: flex-start; padding-left: 0px; }
}

.section-title { margin-top: 60px; font-size: 12px; letter-spacing: 3px; opacity: 0.5; }
.menu { list-style: none; margin-top: 20px; }
.menu li { margin-bottom: 16px; }
.menu a { text-decoration: none; color: #111; font-size: 20px; letter-spacing: 2px; transition: 0.3s ease; position: relative; }
.menu a:hover { opacity: 0.6; }
.menu a::after { content: ""; position: absolute; left: 0; bottom: -4px; width: 0%; height: 2px; background: #111; transition: 0.3s; }
.menu a:hover::after { width: 100%; }

/* PORTFOLIO */
.portfolio { flex: 1; display: grid; grid-template-columns: repeat(3, 1fr); gap: 35px; }
.project { position: relative; aspect-ratio: 1/1; overflow: hidden; text-decoration: none; color: inherit; }
.project img { width: 100%; height: 100%; object-fit: cover; transition: 0.4s ease; }
.project:hover img { transform: scale(1.08); }

/* OVERLAY */
.overlay { position: absolute; inset: 0; background: rgba(0,0,0,0.65); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 18px; letter-spacing: 3px; opacity: 0; transition: 0.4s ease; }
.project:hover .overlay { opacity: 1; }

/* PÁGINA INTERNA AJUSTADA */
.project-page { flex: 1; max-width: 1350px; }
.project-title { font-size: clamp(28px, 5vw, 50px); word-wrap: break-word;  overflow-wrap: break-word; } /* tamanho flexível entre 28px e 52px */
.project-description { font-size: 19px; line-height: 1.8; margin-bottom: 35px; max-width: auto; color: #333; }

/* GALERIA */
.project-gallery { display: flex; flex-direction: column; gap: 40px; }
.project-gallery img { width: 100%; height: auto; display: block; }

/* GRID 2 COLUNAS */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }

/* BACK LINK */
.back-link { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; color: #777; font-size: 15px; margin-top: 50px; transition: 0.3s; }
.back-link:hover { color: #000; }

/* RESPONSIVO */
@media (max-width: 1024px) {
 .container { flex-direction: column; padding: 40px 30px; }
 .sidebar { width: 100%; display: flex; flex-direction: column; align-items: flex-start; }
 .portfolio { grid-template-columns: repeat(2, 1fr); gap: 20px; margin-top: 0px; }
 .logo h1 { font-size: 42px; line-height: 40px; }
 .logo span { font-size: 12px; }
}

@media (max-width: 600px) {
 .portfolio { grid-template-columns: 1fr; gap: 15px; }
 .logo h1 {font-size: 32px; line-height: 36px; }
 .logo span { font-size: 11px; }
 .menu a { font-size: 18px; }
}

/* === PÁGINA QUEM SOU === */
.topo-quem-sou { display: flex; align-items: center; gap: 40px; margin-bottom: 50px; }
.foto-perfil { flex-shrink: 0; width: 220px; height: 220px; overflow: hidden; border-radius: 50%; border: 4px solid #111; }
.foto-perfil img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.4s ease; }
.foto-perfil img:hover { transform: scale(1.05); }
.info-quem-sou { flex: 1; }
.quem-sou { flex: 1; max-width: 1100px; padding-top: 30px; }
.quem-sou h1 { font-size: clamp(32px, 5vw, 52px); margin-bottom: 10px; word-wrap: break-word; }
.quem-sou .subtitle { font-size: 16px; font-weight: 400; color: #777; margin-bottom: 40px; }
.quem-sou .contato { display: flex; flex-wrap: wrap; gap: 20px; margin-bottom: 50px; }
.quem-sou .contato p { margin: 0; font-size: 15px; }
.quem-sou .contato a { color: #111; text-decoration: underline; }
.quem-sou .secao { margin-bottom: 50px; }
.quem-sou h2 { font-size: clamp(24px, 4vw, 32px); color: #111; border-bottom: 2px solid #eaeaea; padding-bottom: 10px; margin-bottom: 20px; }
.quem-sou h3 { font-size: 18px; margin-top: 20px; margin-bottom: 10px; }
.quem-sou ul { list-style: disc; margin-left: 20px; margin-bottom: 20px; color: #333; }
.quem-sou ul li { margin-bottom: 8px; }
.quem-sou .skills { display: flex; flex-wrap: wrap; gap: 10px; }
.quem-sou .skills span { background-color: #111; color: #fff; padding: 6px 12px; border-radius: 20px; font-size: 0.85rem; }

@media (max-width: 1024px) {
 .quem-sou .contato { flex-direction: column; }
}

@media (max-width: 600px) {
 .quem-sou h1 { font-size: 32px; }
 .quem-sou h2 { font-size: 22px; }
 .quem-sou h3 { font-size: 16px; }
 .quem-sou .skills span { font-size: 0.8rem; }
}

@media(max-width: 768px) {
 .topo-quem-sou { flex-direction: column; align-items: center; text-align: center; }
 .foto-perfil { width: 180px; height: 180px; }
 .info-quem-sou { width: 100%; }
}

/* FOOTER */
.site-footer { margin-top: 80px; padding: 40px 30px; background: #111; color: #fff; }
.footer-content { max-width: 1350px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 15px; }
.site-footer p { font-size: 14px; letter-spacing: 1px; opacity: 0.85; }
.site-footer a { color: #fff; text-decoration: underline; transition: 0.3s; }
.site-footer a:hover { opacity: 0.7; }

@media (max-width: 768px) {
 .footer-content { flex-direction: column; text-align: center; }
}