:root {
    --bg-color: #000220;
    --text-color: #e2e8f0;
    --tayo-green: #10B981;
    --tayo-blue: #0003AE;
    --dark-card: #050720;
    --font-main: 'Inter', sans-serif;
}

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

html {
    scroll-behavior: auto; /* O Lenis cuida disso */
}

body {
    background-color: var(--bg-color);
    color: var(--text-color);
    font-family: var(--font-main);
    overflow-x: hidden;
    line-height: 1.6;
    position: relative;
}

/* --- FUNDO ESTRELADO ANIMADO --- */
.stars-container {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: -1;
    background: radial-gradient(ellipse at bottom, #0d1d31 0%, #000220 100%);
    overflow: hidden;
}

#stars, #stars2, #stars3 {
    position: absolute;
    top: 50%;
    left: 50%;
    border-radius: 50%;
    animation: animStar linear infinite;
}

#stars { width: 1px; height: 1px; background: transparent; animation-duration: 150s; box-shadow: -38vw -6vh #fff, 26vw -32vh #fff, -10vw 39vh #fff, 49vw 34vh #fff, -47vw -31vh #fff, 28vw -15vh #fff, 8vw 10vh #fff, -24vw 41vh #fff, 33vw -48vh #fff, -30vw 22vh #fff, 15vw 4vh #fff, -42vw -18vh #fff, 40vw 27vh #fff, -12vw -44vh #fff, 6vw 30vh #fff, -36vw 16vh #fff, 22vw -8vh #fff, -4vw 47vh #fff, 45vw -25vh #fff, -28vw 3vh #fff, 18vw -39vh #fff, -45vw 36vh #fff, 38vw 12vh #fff, -15vw -22vh #fff, 3vw 44vh #fff, -33vw -9vh #fff, 30vw 25vh #fff, -8vw -48vh #fff, 42vw 5vh #fff, -22vw 19vh #fff, 12vw -34vh #fff, -40vw 42vh #fff, 36vw -14vh #fff, -6vw 28vh #fff, 24vw -42vh #fff, -49vw 8vh #fff, 47vw -28vh #fff, -18vw 45vh #fff, 10vw -5vh #fff, -34vw 33vh #fff, 44vw 17vh #fff, -2vw -26vh #fff, 20vw 38vh #fff, -44vw -36vh #fff, 32vw 2vh #fff, -26vw -11vh #fff, 4vw 21vh #fff, -38vw 48vh #fff, 27vw -24vh #fff, -13vw 31vh #fff, 41vw -4vh #fff, -46vw 14vh #fff, 17vw -45vh #fff, -21vw 7vh #fff, 35vw 40vh #fff, -41vw -21vh #fff, 14vw 26vh #fff, -9vw -38vh #fff, 48vw 9vh #fff, -31vw 43vh #fff, 25vw -17vh #fff, -4vw 4vh #fff, 31vw 35vh #fff, -27vw -47vh #fff, 7vw 18vh #fff, -43vw 29vh #fff, 39vw -12vh #fff, -16vw -33vh #fff, 21vw 46vh #fff, -35vw -2vh #fff, 46vw 23vh #fff, -11vw 37vh #fff, 29vw -30vh #fff, -48vw 11vh #fff, 13vw -19vh #fff, -23vw 49vh #fff, 37vw 3vh #fff, -5vw -42vh #fff, 43vw 20vh #fff, -29vw -15vh #fff, 19vw 32vh #fff, -39vw -35vh #fff, 23vw 8vh #fff, -14vw 41vh #fff, 49vw -46vh #fff, -42vw 25vh #fff, 9vw -10vh #fff, -32vw 38vh #fff, 34vw -27vh #fff, -7vw 15vh #fff, 26vw 48vh #fff, -47vw -5vh #fff, 41vw 34vh #fff, -20vw -23vh #fff, 16vw 9vh #fff, -37vw 44vh #fff, 28vw -40vh #fff, -4vw 27vh #fff, 45vw 13vh #fff, -44vw -28vh #fff, 22vw 36vh #fff, -10vw -13vh #fff, 15vw 33vh #fff, -25vw -41vh #fff, 50vw 19vh #fff, -36vw 7vh #fff; }

#stars2 { width: 2px; height: 2px; background: transparent; animation-duration: 200s; opacity: 0.8; box-shadow: -45vw 12vh #fff, 38vw -25vh #fff, -22vw 41vh #fff, 15vw 8vh #fff, -33vw -48vh #fff, 42vw 34vh #fff, -8vw -15vh #fff, 27vw 22vh #fff, -49vw 39vh #fff, 19vw -32vh #fff, -14vw 5vh #fff, 31vw 47vh #fff, -38vw -21vh #fff, 47vw 18vh #fff, -4vw -44vh #fff, 24vw 29vh #fff, -28vw 14vh #fff, 36vw -38vh #fff, -19vw 43vh #fff, 9vw -9vh #fff, -41vw 30vh #fff, 22vw -17vh #fff, -6vw 45vh #fff, 44vw 2vh #fff, -31vw -29vh #fff, 12vw 37vh #fff, -47vw 25vh #fff, 29vw -42vh #fff, -2vw 10vh #fff, 33vw 21vh #fff, -35vw -13vh #fff, 17vw 48vh #fff, -24vw -36vh #fff, 49vw 14vh #fff, -11vw 27vh #fff, 26vw -23vh #fff, -43vw 6vh #fff, 39vw 32vh #fff, -16vw -46vh #fff, 7vw 19vh #fff, -37vw 35vh #fff, 41vw -4vh #fff, -21vw -27vh #fff, 14vw 42vh #fff, -30vw 9vh #fff, 46vw -34vh #fff, -9vw 24vh #fff, 34vw 7vh #fff, -45vw -19vh #fff, 21vw 40vh #fff, -3vw -31vh #fff, 25vw 16vh #fff, -39vw 49vh #fff, 48vw -11vh #fff, -13vw 31vh #fff, 37vw -49vh #fff, -26vw 3vh #fff, 11vw 38vh #fff, -42vw -25vh #fff, 28vw 11vh #fff; }

#stars3 { width: 3px; height: 3px; background: transparent; animation-duration: 250s; opacity: 0.6; box-shadow: -42vw -14vh #fff, 35vw 28vh #fff, -19vw 46vh #fff, 47vw -39vh #fff, -28vw 9vh #fff, 12vw -23vh #fff, -37vw 33vh #fff, 41vw 17vh #fff, -8vw -44vh #fff, 24vw 39vh #fff, -45vw -6vh #fff, 29vw 7vh #fff, -14vw -31vh #fff, 33vw 48vh #fff, -31vw 22vh #fff, 17vw -18vh #fff, -23vw 41vh #fff, 44vw -27vh #fff, -5vw 14vh #fff, 26vw 35vh #fff, -39vw -21vh #fff, 49vw 3vh #fff, -11vw -48vh #fff, 21vw 26vh #fff, -34vw 11vh #fff, 38vw -36vh #fff, -16vw 43vh #fff, 8vw -9vh #fff, -47vw 30vh #fff, 31vw -42vh #fff, 10vw 10vh #fff, -20vw -20vh #fff; }

@keyframes animStar {
    from { transform: translateY(0px) translateX(0px) rotate(0deg); }
    to { transform: translateY(-2000px) translateX(-1000px) rotate(360deg); }
}

/* --- SCROLLBAR CUSTOM --- */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: var(--bg-color); }
::-webkit-scrollbar-thumb { background: var(--tayo-blue); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--tayo-green); }

/* --- UTILITÁRIOS --- */
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.section { padding: 100px 0; }
.blue-text { color: #60a5fa; }
.green-text { color: var(--tayo-green); }

/* --- NAVBAR --- */
.navbar { position: fixed; top: 0; width: 100%; z-index: 1000; background: rgba(0, 2, 32, 0.8); backdrop-filter: blur(15px); border-bottom: 1px solid rgba(255,255,255,0.05); padding: 15px 0; }
.nav-content { display: flex; justify-content: space-between; align-items: center; }
.nav-buttons { display: flex; align-items: center; gap: 12px; }
.logo img { height: 50px; width: auto; }

.btn-nav, .btn-follow { padding: 10px 20px; border-radius: 50px; text-decoration: none; font-weight: 700; font-size: 14px; display: flex; align-items: center; gap: 8px; transition: 0.3s; }
.btn-follow { background: rgba(255, 255, 255, 0.05); color: white; border: 1px solid rgba(255, 255, 255, 0.1); }
.btn-follow:hover { background: #E1306C; border-color: #E1306C; }
.btn-nav { background: var(--tayo-green); color: black; }
.btn-nav:hover { box-shadow: 0 0 20px rgba(16, 185, 129, 0.4); transform: scale(1.05); }

/* --- HERO --- */
.hero { min-height: 100vh; display: flex; align-items: center; justify-content: center; text-align: center; padding-top: 80px; }
.badge { background: rgba(16, 185, 129, 0.1); border: 1px solid rgba(16, 185, 129, 0.2); padding: 8px 16px; border-radius: 50px; font-size: 11px; font-weight: 700; letter-spacing: 1px; margin-bottom: 24px; display: inline-flex; align-items: center; gap: 8px; color: var(--tayo-green); }
.pulse { width: 8px; height: 8px; background: var(--tayo-green); border-radius: 50%; animation: pulse-animation 2s infinite; }
@keyframes pulse-animation { 0% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0.7); } 70% { box-shadow: 0 0 0 10px rgba(16, 185, 129, 0); } 100% { box-shadow: 0 0 0 0 rgba(16, 185, 129, 0); } }

h1 { font-size: clamp(2.5rem, 6vw, 4.5rem); line-height: 1.1; font-weight: 800; margin-bottom: 24px; letter-spacing: -2px; color: white; }
.highlight { color: var(--tayo-green); }
.subtitle { font-size: 1.1rem; color: #94a3b8; max-width: 800px; margin: 0 auto 40px; }

.btn-primary { background: var(--tayo-green); color: black; padding: 18px 36px; border-radius: 50px; text-decoration: none; font-weight: 800; display: inline-flex; align-items: center; gap: 10px; transition: 0.3s; position: relative; }
.btn-primary:hover { transform: translateY(-3px); box-shadow: 0 10px 30px rgba(16, 185, 129, 0.3); }
.btn-outline { padding: 18px 36px; border-radius: 50px; border: 1px solid rgba(255,255,255,0.2); color: white; text-decoration: none; font-weight: 600; transition: 0.3s; }
.btn-outline:hover { background: rgba(255,255,255,0.05); border-color: white; }

/* --- MARQUEE --- */
.marquee-container { background: var(--tayo-blue); padding: 15px 0; transform: rotate(-1deg); overflow: hidden; white-space: nowrap; margin: 60px 0; }
.marquee-content { display: inline-block; animation: marquee 30s linear infinite; font-size: 1rem; font-weight: 900; color: white; }
.marquee-content span { margin-right: 50px; }
@keyframes marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* --- CABEÇALHO DE SEÇÃO PREMIUM (Atualizado) --- */
.section-header { text-align: left; margin-bottom: 80px; max-width: 900px; }
.section-header .label {
    color: var(--tayo-green); font-size: 0.9rem; letter-spacing: 3px; font-weight: 800;
    margin-bottom: 16px; display: inline-block; padding: 6px 16px;
    border: 1px solid rgba(16, 185, 129, 0.2); border-radius: 50px;
    background: rgba(16, 185, 129, 0.05); backdrop-filter: blur(5px);
}
.section-header h2 {
    font-size: clamp(3.5rem, 8vw, 6rem); line-height: 1; font-weight: 800;
    letter-spacing: -0.04em; margin-bottom: 24px; color: white;
}
.section-header h2 .blue-text {
    background: linear-gradient(to right, #60a5fa, #3b82f6, #a855f7);
    -webkit-background-clip: text; -webkit-text-fill-color: transparent;
    display: inline-block;
}
.section-header p { font-size: 1.25rem; color: #94a3b8; max-width: 600px; font-weight: 400; line-height: 1.6; }

/* --- TECH STACK PREMIUM (Layout Estilo Referência) --- */
.tech-wrapper {
    display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center;
    background: radial-gradient(circle at top left, rgba(0, 3, 174, 0.15), transparent 60%);
    border-radius: 32px; padding: 60px; border: 1px solid rgba(255,255,255,0.05);
    position: relative; overflow: hidden;
}
.tech-text h2 { font-size: 2.5rem; margin-bottom: 24px; line-height: 1.2; }
.tech-text p { color: #94a3b8; margin-bottom: 20px; font-size: 1.05rem; max-width: 400px; }
.tech-decoration { display: flex; align-items: center; gap: 12px; margin-top: 30px; padding-top: 20px; border-top: 1px solid rgba(255,255,255,0.1); }
.glow-point { width: 10px; height: 10px; background-color: var(--tayo-green); border-radius: 50%; box-shadow: 0 0 10px var(--tayo-green); }
.tech-decoration span { font-weight: 700; color: white; font-size: 0.9rem; letter-spacing: 0.5px; }

.tech-glass-card {
    background: rgba(0, 0, 0, 0.3); border: 1px solid rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(12px); padding: 30px; border-radius: 24px;
    box-shadow: 0 20px 50px rgba(0, 0, 0, 0.3); position: relative;
}
.tech-glass-card::after {
    content: ''; position: absolute; inset: 0; border-radius: 24px; padding: 1px;
    background: linear-gradient(180deg, rgba(255,255,255,0.1), transparent); 
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude; pointer-events: none;
}
.skills-grid-compact { display: grid; grid-template-columns: 1fr 1fr; gap: 15px; }

/* Ícones das Skills */
.skill-item {
    background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.05);
    padding: 15px; border-radius: 12px; display: flex; align-items: center; gap: 15px;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1); cursor: default;
}
.skill-item:hover { background: rgba(16, 185, 129, 0.1); border-color: var(--tayo-green); transform: translateX(5px); }
.skill-icon { width: 24px; height: 24px; color: #64748b; transition: 0.3s; }
.skill-item:hover .skill-icon { color: var(--tayo-green); transform: scale(1.1); }
.skill-item span { font-weight: 600; font-size: 0.9rem; color: #e2e8f0; }

/* --- PROJETOS ATUALIZADOS --- */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; }
.gap-large { gap: 60px; }
.offset-top { margin-top: 80px; }
.project-card { position: relative; }
.project-image { position: relative; border-radius: 24px; overflow: hidden; border: 1px solid rgba(255,255,255,0.1); aspect-ratio: 16/10; margin-bottom: 20px; }
.project-image img { width: 100%; height: 100%; object-fit: cover; transition: 0.5s; }
.project-card:hover img { transform: scale(1.05); }

.overlay { position: absolute; inset: 0; background: rgba(0, 3, 174, 0.3); opacity: 0; transition: opacity 0.5s; }
.project-card:hover .overlay { opacity: 1; }

.project-btn {
    position: absolute; bottom: 24px; right: 24px; background: var(--tayo-green); color: black;
    width: 50px; height: 50px; border-radius: 50%; display: flex; align-items: center; justify-content: center;
    transform: translateY(20px); opacity: 0; transition: all 0.3s; box-shadow: 0 10px 20px rgba(0,0,0,0.3);
}
.project-card:hover .project-btn { transform: translateY(0); opacity: 1; }
.blue-btn { background: var(--tayo-blue); color: white; }

.tech-tags { display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.tag { font-size: 10px; font-weight: 700; padding: 4px 10px; border-radius: 4px; background: rgba(0, 3, 174, 0.2); color: #60a5fa; border: 1px solid rgba(96, 165, 250, 0.2); }

.project-info h3 { font-size: 1.5rem; margin-bottom: 8px; color: white; }
.project-info p { color: #94a3b8; font-size: 0.95rem; }

/* --- SEÇÃO SOBRE MIM (Imagem) --- */
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; margin-top: 40px; }
.image-wrapper {
    position: relative; border-radius: 32px; overflow: hidden;
    border: 1px solid rgba(255,255,255,0.1); background: #0A0C28;
    max-width: 480px; margin: 0 auto; aspect-ratio: 3/4;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.4);
}
.image-wrapper img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.5s ease; }
.image-wrapper:hover img { transform: scale(1.03); }
.about-text h2 { font-size: clamp(2rem, 4vw, 3rem); line-height: 1.2; margin-bottom: 25px; }
.about-text p { margin-bottom: 18px; color: #94a3b8; font-size: 1.05rem; }
.signature { margin-top: 30px; display: flex; align-items: center; gap: 15px; }
.signature .line { width: 40px; height: 2px; background: var(--tayo-green); }
.signature span { font-weight: 700; text-transform: uppercase; font-size: 0.85rem; letter-spacing: 1px; color: var(--tayo-green); }

/* --- SERVICES (Cards com Glassmorphism) --- */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.service-card, .card-step {
    padding: 32px; border-radius: 24px; background: rgba(255,255,255,0.02);
    border: 1px solid rgba(255,255,255,0.05); transition: all 0.3s;
}
.service-card:hover { transform: translateY(-5px); background: rgba(255,255,255,0.05); }
.service-card i { width: 40px; height: 40px; margin-bottom: 20px; }
.blue-icon { color: var(--tayo-blue); }
.green-icon { color: var(--tayo-green); }
.purple-icon { color: #a855f7; }
.service-card h3 { font-size: 1.5rem; margin-bottom: 12px; color: white; }
.service-card p { color: #64748b; }

.blue-border { border-color: rgba(0, 3, 174, 0.2); }
.green-border { border-color: rgba(16, 185, 129, 0.2); }
.purple-border { border-color: rgba(168, 85, 247, 0.2); }

/* --- FOOTER --- */
footer { padding: 100px 0 50px; text-align: center; position: relative; }
.footer-glow { position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); width: 80%; height: 200px; background: radial-gradient(circle, rgba(0, 3, 174, 0.2) 0%, transparent 70%); filter: blur(50px); pointer-events: none; }
.social-links { display: flex; justify-content: center; gap: 15px; margin: 40px 0; }
.social-links a { width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; border-radius: 50%; background: rgba(255,255,255,0.05); color: white; transition: 0.3s; border: 1px solid rgba(255,255,255,0.1); }
.social-links a:hover { background: var(--tayo-green); color: black; transform: translateY(-5px); border-color: var(--tayo-green); }
.copyright { color: #475569; font-size: 0.8rem; }

/* --- RESPONSIVIDADE FINAL --- */
@media (max-width: 900px) {
    .tech-wrapper { grid-template-columns: 1fr; padding: 30px; gap: 40px; }
    .tech-text { text-align: center; }
    .tech-text p { margin: 0 auto 20px; }
    .tech-decoration { justify-content: center; }
    .skills-grid-compact { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
    .hero { padding-top: 120px; }
    h1 { font-size: 2.5rem; }
    .navbar .logo img { height: 40px; }
    .nav-buttons { display: none; }
    .grid-2, .grid-3, .about-grid { grid-template-columns: 1fr; }
    .offset-top { margin-top: 0; }
    .section-header h2 { font-size: 3rem; } /* Ajuste pro título gigante no mobile */
}