/* ===========================
   styles.css — Versão aprimorada
   Coloque este arquivo como styles.css (arquivo 2/3)
   =========================== */

/* Variáveis de tema */
:root{
  --bg: #071018;
  --panel: #0b1216;
  --neon: #8af7bf;
  --neon-strong: #00ff87;
  --muted: #9aa6b2;
  --glass: rgba(255,255,255,0.03);
  --accent-glow: 0 12px 40px rgba(138,247,191,0.08);
  --radius: 14px;
  --shadow-strong: 0 18px 60px rgba(0,0,0,0.6);
  --max-width: 1180px;
  --ease: 0.25s;
}

/* Reset básico */
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background:
    radial-gradient(1200px 600px at 10% 10%, rgba(138,247,191,0.02), transparent 8%),
    linear-gradient(180deg, rgba(8,12,18,1) 0%, rgba(6,7,10,1) 100%);
  color:#e6eef3;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
  padding-bottom:80px;
  position:relative;
  line-height:1.45;
  font-size:15px;
}


/* Skip link */
.skip-link:focus{
  position:static; left:auto; top:auto; width:auto; height:auto;
  padding:8px 12px; background:#021109; color:var(--neon); border-radius:8px; z-index:60;
}

/* Canvas overlay helper (keeps canvas behind) */
#bgCanvas{ position:fixed; inset:0; z-index:0; pointer-events:none; }

/* Container central */
.container{ max-width: var(--max-width); margin:0 auto; padding:36px 6%; position:relative; z-index:2; }

/* ---------- TOPBAR ---------- */
.topbar{
  position:sticky; top:0; z-index:40;
  display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:12px 6%;
  backdrop-filter: blur(8px);
  background: linear-gradient(90deg, rgba(0,0,0,0.28), rgba(0,0,0,0.18));
  border-bottom: 1px solid rgba(255,255,255,0.02);
}
.brand{ display:flex; align-items:center; gap:12px; }
.logo{ width:44px; height:44px; border-radius:8px; overflow:hidden; background:transparent; }
.logo-img{ width:100%; height:100%; object-fit:cover; display:block; }
.brand-title{ font-size:15px; font-weight:700; }
.brand-sub{ font-size:12px; color:var(--muted); margin-top:2px; }

/* Nav */
nav.desktop-nav{ display:flex; gap:20px; align-items:center; }
nav.desktop-nav a{ color:var(--muted); font-weight:600; text-decoration:none; padding:6px 8px; border-radius:8px; transition:all var(--ease); }
nav.desktop-nav a:hover{ color:var(--neon); transform:translateY(-2px); }
nav.desktop-nav a.cta{
  background: linear-gradient(90deg, var(--neon), #00c86b);
  color:#021109; padding:8px 14px; border-radius:10px; font-weight:800; box-shadow:var(--accent-glow);
}

/* Burger (mobile) */
.burger{ display:none; cursor:pointer; padding:8px; border-radius:8px; background:transparent; border:0; }
.burger span{ display:block; width:22px; height:3px; background:#071018; margin:4px; border-radius:3px; box-shadow:0 1px 0 rgba(255,255,255,0.02); }

/* Mobile menu */
.mobile-menu{
  display:none; position:absolute; right:6%; top:72px;
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
  border-radius:12px; padding:10px; box-shadow:0 12px 40px rgba(2,6,10,0.6);
}
.mobile-menu a{ display:block; padding:10px 14px; color:var(--muted); text-decoration:none; border-radius:8px; }
.mobile-menu a:hover{ background: rgba(255,255,255,0.02); color:var(--neon); }

/* ---------- HERO ---------- */
.hero{ display:grid; grid-template-columns: 1fr 520px; gap:28px; align-items:center; margin-top:18px; }
.hero-card{
  background: linear-gradient(180deg, rgba(255,255,255,0.015), transparent);
  border-radius: var(--radius); padding:34px; box-shadow: var(--shadow-strong);
  border:1px solid rgba(255,255,255,0.02); position:relative; overflow:hidden;
}
.eyebrow{
  display:inline-block; background: rgba(138,247,191,0.06); color:var(--neon); padding:6px 10px;
  border-radius:999px; font-weight:800; font-size:13px; margin-bottom:12px; box-shadow:0 6px 20px rgba(0,255,135,0.04);
}
.hero-title{ font-family:"Space Grotesk", sans-serif; font-size:38px; line-height:1.05; margin-bottom:12px; color:#f2fff8; }
.hero-title .hl{ color:var(--neon); text-shadow: 0 8px 36px rgba(0,255,135,0.06); }
.hero-lead{ color:var(--muted); margin-bottom:18px; font-size:15px; }

/* CTAs */
.hero-ctas{ display:flex; gap:12px; align-items:center; margin-top:14px; }
.btn{
  display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:12px;
  font-weight:800; text-decoration:none; cursor:pointer; border:0; transition: transform var(--ease), box-shadow var(--ease);
  background: linear-gradient(90deg, var(--neon), #00c86b); color:#021109; box-shadow:var(--accent-glow);
}
.btn.ghost{ background:transparent; color:var(--neon); border:1px solid rgba(138,247,191,0.12); backdrop-filter: blur(4px); }
.btn:hover{ transform:translateY(-3px); box-shadow: 0 18px 48px rgba(0,0,0,0.55); }

/* Features chips */
.features{ display:flex; gap:12px; margin-top:18px; flex-wrap:wrap; }
.feature{ background:rgba(255,255,255,0.02); padding:10px 12px; border-radius:10px; font-size:13px; color:var(--muted); border:1px solid rgba(255,255,255,0.02); }

/* small note */
.small-note{ font-size:13px; color:var(--muted); margin-top:18px; }

/* ---------- HERO VISUAL (direita) ---------- */
.hero-visual{
  display:flex; align-items:center; justify-content:center; height:360px; padding:12px; border-radius:12px; position:relative; overflow:visible;
}
.dev-img{
  display:block; width:100%; max-width:520px; height:calc(360px - 24px); object-fit:cover; object-position:30% 35%;
  border-radius:14px; box-shadow: var(--shadow-strong), 0 6px 28px rgba(0,255,135,0.06); transition: transform .35s ease;
}
.hero-visual:hover .dev-img{ transform: translateY(-4px) scale(1.01); }

/* Mini card (sobre a imagem) */
.mini-card{
  position:absolute; left:36%; bottom:-50px; transform:translateX(-50%); background:var(--glass);
  padding:6px 12px; border-radius:10px; border:1px solid rgba(255,255,255,0.03); backdrop-filter: blur(6px);
  display:flex; gap:10px; align-items:center; box-shadow:0 8px 30px rgba(0,0,0,0.6); color:var(--muted); font-weight:700; font-size:13px;
}

/* ---------- Sections & Cards ---------- */
.section{ margin-top:40px; }
.section-title{ font-size:20px; margin-bottom:8px; font-weight:800; letter-spacing:-0.01em; position:relative; }
.section-title::after{ content:''; display:block; width:64px; height:4px; background: linear-gradient(90deg, var(--neon), transparent); border-radius:2px; margin-top:10px; opacity:.95; }

/* Cards grid */
.cards{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap:22px; margin-top:18px;
}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  border:1px solid rgba(255,255,255,0.03); border-radius:var(--radius); padding:20px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.35); transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.card:hover{ transform: translateY(-6px); border-color: rgba(138,247,191,0.25); box-shadow: 0 18px 48px rgba(0,0,0,0.6); }
.service-head{ display:flex; align-items:center; gap:12px; margin-bottom:6px; }
.service-icon{
  width:56px; height:56px; border-radius:12px; display:grid; place-items:center;
  background: radial-gradient(120% 120% at 30% 30%, rgba(138,247,191,0.55), rgba(138,247,191,0.05));
  border:1px solid rgba(138,247,191,0.45); font-size:26px; box-shadow: inset 0 0 40px rgba(138,247,191,0.12);
}
.service-card h4{ margin:0 0 6px; font-weight:700; font-size:1.05rem; }
.service-card p{ font-size:.95rem; color:var(--muted); }

/* Portfolio grid */
.portfolio-grid{ margin-top:24px; display:grid; gap:18px; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.project-card{
  position:relative; overflow:hidden; border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(255,255,255,0.01), rgba(255,255,255,0.008));
  border:1px solid rgba(255,255,255,0.02); box-shadow: 0 10px 30px rgba(0,0,0,0.35);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease; text-decoration:none; color:inherit;
}
.project-card:hover{ transform: translateY(-6px); border-color: rgba(138,247,191,0.25); box-shadow: 0 18px 48px rgba(0,0,0,0.6); }
.project-card{ cursor:pointer; }
.project-thumb{ aspect-ratio: 16/9; display:flex; align-items:center; justify-content:center; color:#aaf5cf; font-weight:700; background: radial-gradient(120% 120% at 20% 10%, rgba(138,247,191,0.12), rgba(7,16,24,0.75) 80%); }
/* Badge "Saiba mais" global (aparece em todas as larguras) */
.project-thumb{ position: relative; }
.project-thumb::after{
  content: "Saiba mais";
  position: absolute;
  top: 8px; right: 8px;
  font-size: 11px; font-weight: 700;
  padding: 4px 8px; border-radius: 999px;
  background: rgba(138,247,191,0.12);
  border: 1px solid rgba(138,247,191,0.28);
  color: #c8ffe3;
  pointer-events: none;
  z-index: 2;
}

/* Tags */
.tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.tag{ font-size:12px; padding:6px 10px; border-radius:999px; background: rgba(138,247,191,0.06); border:1px solid rgba(138,247,191,0.12); color:#c8ffe3; }

/* Contact */
.contact .contact-form{
  margin-top:18px; background: var(--glass); border:1px solid rgba(255,255,255,0.03);
  border-radius: var(--radius); padding:16px; display:grid; gap:12px; grid-template-columns:1fr;
  box-shadow: 0 10px 30px rgba(0,0,0,0.35); backdrop-filter: blur(10px) saturate(120%);
}
.contact .contact-form input, .contact .contact-form textarea{
  background: rgba(0,0,0,0.35); border:1px solid rgba(255,255,255,0.06); border-radius:12px; padding:12px 14px; color:#e9fff5; outline:none;
  transition: border-color .18s ease, box-shadow .18s ease;
}
.contact .contact-form input::placeholder, .contact .contact-form textarea::placeholder{ color: rgba(234,247,240,0.45); }
.contact .contact-form input:focus, .contact .contact-form textarea:focus{ border-color: rgba(138,247,191,0.45); box-shadow: 0 0 0 4px rgba(138,247,191,0.12); }

/* Footer aprimorado */
.footer{
  border-top:1px solid rgba(255,255,255,0.06);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), rgba(0,0,0,0.18));
  padding:28px 6% 20px;
  margin-top:40px;
}
.footer-grid{
  display:grid; gap:20px; grid-template-columns: 1.1fr 1fr 1fr;
  margin-top:18px;
}
.footer-col .footer-title{
  font-size:13px; color:#b8ffe1; letter-spacing:.08em; text-transform:uppercase; margin-bottom:10px;
}
.brand-mini{ display:flex; align-items:center; gap:12px; margin-bottom:10px; }
.footer-about{ margin-top:4px; }
.footer-links{ list-style:none; display:grid; gap:8px; }
.footer a{ color:var(--muted); text-decoration:none; transition: color .2s ease, transform .2s ease; }
.footer a:hover{ color:var(--neon); transform: translateY(-1px); }
.socials{ display:flex; gap:10px; margin-top:10px; flex-wrap:wrap; }
.social-link{
  padding:6px 10px; border-radius:999px;
  background: rgba(138,247,191,0.06);
  border:1px solid rgba(138,247,191,0.18);
  color:#c8ffe3;
}
.footer-bottom{
  margin-top:16px; padding-top:12px;
  border-top:1px solid rgba(255,255,255,0.06);
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  color:var(--muted); font-size:13px;
}

/* Toast */
.toast{
  position:fixed; right:16px; bottom:16px; background: rgba(20,30,26,0.92);
  border:1px solid rgba(138,247,191,0.2); color:#dfffee; padding:12px 14px; border-radius:12px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.4); z-index:60; opacity:0; transform: translateY(12px); pointer-events:none; transition: opacity .3s ease, transform .3s ease;
}
.toast.show{ opacity:1; transform: translateY(0); pointer-events:auto; }

/* Reveal on scroll */
.reveal{ opacity:0; transform: translateY(16px); transition: opacity .7s ease, transform .7s ease; }
.reveal.in{ opacity:1; transform: translateY(0); }

/* Responsividade */
@media (max-width:1100px){
  .hero{ grid-template-columns: 1fr 420px; }
  .hero-visual{ height:320px; }
  .hero-visual .dev-img{ max-width:420px; }
}
@media (max-width:980px){
  .hero{ grid-template-columns:1fr; gap:18px; }
  .hero-visual{ order:-1; height:260px; display:flex; justify-content:center; }
  .hero-visual .dev-img{ width:320px; height:220px;object-position: center 22%;}
  nav.desktop-nav{ display:none; }
  .burger{ display:block; }
  .mobile-menu{ display:none; }
  .service-card{ width:100%; }

  /* centraliza o mini-card abaixo da foto */
  .mini-card{
    left: 50%;
    transform: translateX(-50%);
    bottom: -32px;
  }
}
@media (max-width:768px){
  .topbar{ padding:10px 5%; }
  .container{ padding:28px 5%; }
  .hero{
    grid-template-columns:1fr; /* garante uma coluna */
    gap:18px;
  }
  .hero-card{ padding:24px; }
  .hero-title{ font-size:32px; line-height:1.08; }
  .hero-lead{ font-size:14px; }

  .features{ justify-content:center; }

  .hero-visual{
    height:auto; padding:0; margin-top:4px;
  }
  /* Foto menor e centralizada (sobrepõe CSS inline com !important) */
  .hero-visual .dev-img{
    width: min(88vw, 360px) !important;
    height: auto !important;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    object-position: 35% 22% !important; /* desce um pouco o enquadramento */
  }
  /* Mini-card centralizado sob a foto */
  .mini-card{
    left:50%;
    bottom:-32px;
    transform: translateX(-50%);
    padding:6px 12px;
  }

  /* Portfólio: 2 colunas confortáveis */
  .portfolio-grid{
    grid-template-columns: repeat(2, 1fr);
    gap:16px;
  }

  /* Modal: respira melhor em telas menores */
  .modal-card{ width: min(90vw, 560px); }

  .footer{ padding:24px 5% 18px; }
  .footer-grid{ grid-template-columns: 1fr 1fr; gap:16px; }
}

/* ====== 600px ====== */
@media (max-width:600px){
  .brand-title{ font-size:14px; }
  .brand-sub{ font-size:11px; }

  .hero-card{ padding:20px; }
  .hero-title{ font-size:30px; }
  .hero-lead{ font-size:14px; }

  .hero-ctas{ gap:10px; }
  .btn{ padding:12px 14px; }

  .hero-visual .dev-img{
    width: min(90vw, 320px) !important;
    aspect-ratio: 4 / 3;
    object-position: 30% 24% !important; /* desce mais no 600px */
  }
  .mini-card{ bottom:-26px; }

  /* Portfólio: 1 coluna para foco no conteúdo */
  .portfolio-grid{ grid-template-columns: 1fr; }

  /* Cards e formulário com mais respiro */
  .cards{ grid-template-columns: 1fr; }
  .contact .contact-form{ padding:14px; gap:10px; }

  .footer-grid{ grid-template-columns: 1fr; }
  .footer-col{ text-align:center; }
  .brand-mini{ justify-content:center; }
  .footer-links{ justify-items:center; } /* grid já usado nas ULs */
  .socials{ justify-content:center; }
  .footer-bottom{
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
    gap:6px;
  }
}

/* ====== 400px ====== */
@media (max-width:400px){
  .container{ padding:24px 5%; }
  .hero-title{ font-size:26px; }
  .hero-lead{ font-size:13px; }

  .hero-ctas{
    flex-direction:column;
    align-items:stretch;
  }
  .hero-ctas .btn{
    width:100%;
    justify-content:center;
  }

  .hero-visual .dev-img{
    width: 86vw !important;
    aspect-ratio: 4 / 3;
    object-position: 30% 20% !important; /* foco mais alto para não cortar a cabeça */
  }
  .mini-card{
    bottom:-22px;
    font-size:12px;
    padding:5px 10px;
  }

  /* Grid centralizado e cards menores */
  .portfolio-grid{ grid-template-columns: 1fr; justify-items: center; }

  .project-card{
    width: 92vw !important;
    max-width: 320px;
    height: auto !important;
    margin: 0 auto !important;
  }

  .project-body{ padding: 12px 12px 14px; }
  .tags{ flex-wrap: wrap; gap: 8px; }
  .tag{ white-space: normal; }

  /* Badge "Saiba mais" na thumb para indicar clique */
  .project-thumb{ position: relative; } /* garante posicionamento do pseudo-elemento */
  .project-thumb::after{
    content: "Saiba mais";
    position: absolute;
    top: 8px; right: 8px;
    font-size: 11px; font-weight: 700;
    padding: 4px 8px; border-radius: 999px;
    background: rgba(138,247,191,0.12);
    border: 1px solid rgba(138,247,191,0.28);
    color: #c8ffe3;
    pointer-events: none;
  }

  /* Força topo-direito no mobile e remove qualquer bottom anterior */
  .project-thumb::after{
    top: 8px !important;
    right: 8px !important;
    bottom: auto !important;
  }

  /* Modal: pilha única e mais compacto */
  .modal-content{ grid-template-columns: 1fr; }
  .modal-body{ padding:12px; }
  .modal-header{ padding:12px; }
  .modal-close{ padding:6px 10px; }

  .footer{ padding:22px 5% 16px; }
  .footer-grid{ gap:14px; }
  .footer-links{ gap:6px; }
  .social-link{ padding:6px 9px; }
  .footer-bottom{ font-size:12px; }
  .footer .logo{ width:40px; height:40px; } /* deixa compacto */
  .brand-mini{ gap:10px; }

  /* Cards do portfólio: largura fluída e altura automática (evita cortar tags) */
  .project-card{
    width: 100% !important;
    height: auto !important;
    margin: 0 !important;
  }

  /* Opcional: um pouco menos de padding no corpo para caber melhor */
  .project-body{ padding: 12px 12px 14px; }

  /* Garantir quebra de linha das tags em telas muito estreitas */
  .tags{ flex-wrap: wrap; gap: 8px; }
  .tag{ white-space: normal; }
}

/* Modal (Portfólio) */
.modal{
  position: fixed; inset: 0; z-index: 60;
  background: rgba(0,0,0,.55);
  display: none; align-items: center; justify-content: center;
  padding: 24px;
}
.modal.open{ display:flex; }
.modal-card{
  position:relative;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.02));
  border:1px solid rgba(255,255,255,0.06);
  border-radius: var(--radius);
  box-shadow: var(--shadow-strong);
  backdrop-filter: blur(12px) saturate(140%);
  width: min(92vw, 720px);
  color:#e6eef3;
  overflow:hidden;
  transform: translateY(8px) scale(.98);
  opacity: .96;
  transition: transform .24s ease, opacity .24s ease;
}
.modal.open .modal-card{ transform: translateY(0) scale(1); opacity:1; }
/* brilho sutil na borda */
.modal-card::before{
  content:""; position:absolute; inset:0; pointer-events:none;
  border-radius:inherit;
  background: conic-gradient(from 180deg at 50% 50%, rgba(138,247,191,0.12), transparent 25%, rgba(138,247,191,0.08) 50%, transparent 75%, rgba(138,247,191,0.12));
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  padding:1px;
  opacity:.6;
}

/* Header do modal */
.modal-header{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding: 14px 16px; border-bottom: 1px solid rgba(255,255,255,.06);
}
.modal-title{
  font-weight:800; letter-spacing:-.01em; font-size:1.1rem;
  display:flex; align-items:center; gap:10px;
}
.modal-chip{
  display:inline-flex; align-items:center; gap:8px;
  font-size:12px; font-weight:700; color:#bfffe3;
  background: rgba(138,247,191,0.08);
  border:1px solid rgba(138,247,191,0.25);
  padding:6px 10px; border-radius:999px;
}
.modal-close{
  background: transparent; border: 1px solid rgba(255,255,255,.12);
  color:#dfffee; border-radius:10px; padding:6px 10px; cursor:pointer;
}
.modal-close:hover{ border-color: rgba(138,247,191,.35); }

/* Conteúdo do modal */
.modal-body{ padding: 14px 16px 16px; }
.modal-content{
  display:grid; gap:16px; grid-template-columns: 1fr 220px;
}
@media (max-width:720px){
  .modal-content{ grid-template-columns: 1fr; }
}
.modal-desc {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.modal-desc .intro{
  color:#eaf7f0;
  font-weight:700;
  letter-spacing:-.01em;
  line-height:1.55;
}
.modal-desc .points{
  margin:4px 0 0;
  padding:0;
  list-style:none;
  display:grid;
  gap:8px;
}
.modal-desc .points li{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color:var(--muted);
  line-height:1.55;
  background: rgba(255,255,255,0.02);
  border:1px solid rgba(255,255,255,0.06);
  padding:8px 10px;
  border-radius:10px;
}
.modal-desc .points li::before{
  content:"✔";
  color:var(--neon);
  font-weight:800;
  line-height:1;
  margin-top:2px;
}

/* Mobile: mantém leitura confortável */
@media (max-width:600px){
  .modal-desc .intro{ font-size:1rem; }
  .modal-desc .points li{ font-size:.95rem; }
}

/* Fundo fixo sem zoom (imagem inteira visível) */
body{
  /* desativa a imagem aplicada direto no body para evitar conflito */
  background-image: none !important;
}

/* Aplica a imagem fixa via pseudo-elemento (funciona no mobile também) */
body::before{
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  /* imagem + gradiente de fallback para preencher as laterais/topo/rodapé */
  background:
    url('imagens/fundo.jpeg') center top / contain no-repeat,
    linear-gradient(180deg, rgba(8,12,18,1) 0%, rgba(6,7,10,1) 100%);
  /* força composição em GPU e evita “tremida” ao scroll */
  will-change: transform;
  transform: translateZ(0);
}

/* Dica: se quiser preencher toda a tela mesmo cortando (mais zoom), troque contain por cover. */

