:root {
  --bg: #ffffff;
  --fg: #0f1220;
  --muted: #697085;
  --border: #e4e7ef;
  --card: #ffffff;
  --accent: #7c3aed;
  --space: 18px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg: #0b0c12;
    --fg: #e9e9f2;
    --muted: #a6abc0;
    --border: #23263a;
    --card: #141522;
  }
}

html[data-theme="light"] {
  --bg: #ffffff;
  --fg: #0f1220;
  --muted: #697085;
  --border: #e4e7ef;
  --card: #ffffff;
}

html[data-theme="dark"] {
  --bg: #0b0c12;
  --fg: #e9e9f2;
  --muted: #a6abc0;
  --border: #23263a;
  --card: #141522;
}

html, body { height: 100%; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, sans-serif;
  line-height: 1.5;
}

a { 
  color: inherit; 
}
img { 
  max-width: 100%; 
  height: auto; 
}

.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 280px;
  border-right: 1px solid var(--border);
  background: var(--card);
}

.sidebar_info {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.presentation {
  height: 140px;
  display: flex;
  justify-content: space-evenly;
  flex-direction: column;
  line-height: 1.2;
}

.presentation > div > p {
  margin: 0;
  font-size: 13px;
}

.content {
  margin-left: 280px;
  padding: 36px;
}

/* Seções */
.block {
  padding-block: 28px;
  border-bottom: 1px dashed var(--border);
  scroll-margin-top: 16px; /* Compensa cabeçalho fixo ao navegar por âncoras (se houver)*/
}

/* ========= Componentes ========= */
.cris {
  width: 64px; height: 64px;
  border-radius: 50%;
  display: grid; 
  border: 1px solid var(--border);
  background-image: url(imagens/foto-cris.png);
  background-size: cover;
}

.name {
  background: linear-gradient(to right, var(--accent), #b794ff, var(--fg));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  font-size: 20px;
  font-weight: 800;
}

.snav { display: flex; flex-direction: column; gap: 10px; }
.snav a {
  text-decoration: none;
  opacity: .9;
  padding: 6px 8px;
  border-radius: 8px;
}
.snav a:hover { opacity: 1; background: color-mix(in oklab, var(--accent) 12%, transparent); transition: .8s;}

.btn {
  
  padding: .6rem .9rem;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--fg);
  cursor: pointer;
  transition: transform .05s ease, background-color .15s ease, border-color .15s ease;
  text-decoration: none;
}

.btn:hover { background: color-mix(in oklab, var(--accent) 10%, transparent); transition: .8s; } 
.btn:active { transform: translateY(1px); }

.btn a {
  text-decoration: none;
}

.tags {
  list-style: none; padding: 0; margin: 0;
  display: flex; gap: 8px; flex-wrap: wrap;
}
.tags li {
  padding: .35rem .6rem;
  border: 1px solid var(--border);
  border-radius: 999px;
  font-size: .95rem;
}

.tags li:hover { background: color-mix(in oklab, var(--accent) 10%, transparent); transition: .8s; cursor: default;}

/* Cards responsivos sem rolagem lateral */
.cards {
  display: grid;
  gap: 16px;
  /* o min() garante que o mínimo nunca passe de 100% do container */
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 360px), 1fr));
}

/* Permite o conteúdo encolher dentro do grid (evita “vazar” largura) */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
  font-size: 14px;
  min-width: 0; 
  overflow-wrap: anywhere; /* quebra palavras grandes se precisar */
}

.card ul li {
  padding: 0;
  margin: 10px; 
}

.card h3 { margin-top: 0; }

/* ========= Rede sociais ========= */
.social-media a {
  width: 48px; height: 48px; /* garante hitbox igual */
  display: inline-block;
  border-radius: 12px;
  border: 1px solid var(--border);
  background-color: var(--card);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  background-size: 70%;
  background-repeat: no-repeat;
  background-position: center;
}

.social-media a:hover,
.social-media a:focus-visible {
  transform: translateY(-3px);
  border-color: color-mix(in oklab, var(--accent) 30%, var(--border));
  box-shadow: 0 8px 22px color-mix(in oklab, var(--accent) 16%, transparent);
  outline: none;
}

.mail { background-image: url('./imagens/icon-mail.png'); }
.whatsapp { background-image: url('./imagens/icon-whatsapp.png'); }
.linkedin { background-image: url('./imagens/icon-linkedin.png'); }
.instagram { background-image: url('./imagens/icon-instagram.png'); }

html[data-theme="dark"] .mail {
  background-image: url('./imagens/icon-mail.png');
}
html[data-theme="light"] .mail {
  background-image: url('./imagens/icon-mail-dark.png');
}

html[data-theme="dark"] .whatsapp {
  background-image: url('./imagens/icon-whatsapp.png');
}
html[data-theme="light"] .whatsapp {
  background-image: url('./imagens/icon-whatsapp-dark.png');
}

html[data-theme="dark"] .linkedin {
  background-image: url('./imagens/icon-linkedin.png');
} 

html[data-theme="light"] .linkedin {
  background-image: url('./imagens/icon-linkedin-dark.png');
} 

html[data-theme="dark"] .instagram {
  background-image: url('./imagens/icon-instagram.png');
} 

html[data-theme="light"] .instagram {
  background-image: url('./imagens/icon-instagram-dark.png');
} 


/* ========= Responsividade ========= */
@media (max-width: 900px) {
  .sidebar { position: static; width: auto; }
  .content { margin-left: 0; padding: 24px; }
}