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

/* Variáveis */
:root {
  --primary-bg: #0E0E0E;
  --secondary-bg: #1A1A1A;
  --accent-color: #4A90E2;
  --text-primary: #FFFFFF;
  --text-secondary: #B0B0B0;
  --gradient-primary: linear-gradient(135deg, #4A90E2 0%, #357ABD 100%);
  --shadow-primary: 0 10px 30px rgba(74, 144, 226, 0.3);
  --border-radius: 12px;
  --transition-fast: 0.3s ease;
  --transition-slow: 0.6s ease;
  --neon-color: #00FFEA;
  --neon-shadow: 0 0 20px var(--neon-color), 0 0 50px var(--neon-color);
  --gradient-text: linear-gradient(90deg, #00FFEA, #FF00FF);
  --radius: 12px;
  --shadow-soft: 0 4px 16px rgba(0,0,0,.08);
  --transition: .3s ease;
  --accent-1: #4A90E2;
  --accent-2: #1d1d1d;
  --sbw: 0px;
  --sbw-px: 0px;
}
@supports not (scrollbar-gutter: stable) {
  :root { --sbw: calc(100vw - 100%); }
}
#aboutme-mobile{ margin-top:-1px; }
.aboutme-m { 
  min-height: var(--hero-h, 68vh);
  background: var(--hero-img) center/cover no-repeat;
}
.full-bleed{
  position: relative;
  left: 50%;
  max-width: none;
  width: 100vw;           /* base */
  margin-left: -50vw;
  margin-right: -50vw;
}

@supports (width: 100dvw) {
  .full-bleed{
    width: 100dvw;        /* estável com toolbars dinâmicas */
    margin-left: -50dvw;
    margin-right: -50dvw;
  }
}
html.loading .main-content {
  opacity: 0;
  visibility: hidden;
}

/* Estilo base */
body {
  font-family: 'Inter', sans-serif;
  background: var(--primary-bg);
  color: var(--text-primary); 
  line-height: 1.6;
  display: block;
  min-height: 100vh;
}
/* ---- FORÇA SCROLL NO SITE ---- */
html, body {
  height: auto !important;
  overflow-y: auto;
  overflow-x: clip;
  scroll-behavior: smooth !important;
  /* scrollbar-gutter: stable both-edges; */
}
html.rc-locked { overflow-y: scroll; }

body.rc-fixed,
.rc-locked body {
  position: fixed;
  width: 100%;
  left: 0; right: 0;
}

/* Preloader */
.preloader {
  position: fixed;
  inset: 0;
  background: var(--primary-bg);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  transition: opacity var(--transition-slow), visibility var(--transition-slow);
}

.btn-outline-light:hover{
    background-color: #D8E4EE!important;
}
.part {
  display: inline-block;
  opacity: 0;
  transition: transform 1.2s ease, opacity 1.2s ease;
  transform: translateY(50px);
}

.bg-dark {
    --bs-bg-opacity: 1;
    background-color: rgb(61 61 61) !important;
}
.part.show {
  opacity: 1;
  transform: translateY(0);
}

.part.afastado.part-left {
  transform: translateX(-15px);
  transition: transform 1s ease;
}

.part.afastado.part-right {
  transform: translateX(15px);
  transition: transform 1s ease;
}

.preloader-text .icon {
  opacity: 0;
  font-size: 2.5rem;
  color: var(--accent-color);
  transform: scale(0);
  transition: opacity 0.5s ease, transform 0.5s ease;
}

.preloader-text .icon.show {
  opacity: 1;
  transform: scale(1);
}

.preloader-text .icon.rotating {
  animation: rotate-icon 2s linear forwards;
}

@keyframes rotate-icon {
  from { transform: scale(1) rotate(0deg); }
  to { transform: scale(1) rotate(720deg); }
}

/* Barra de progresso */
.loading-bar {
  width: 100%;
  height: 4px;
  background: var(--secondary-bg);
  border-radius: 2px;
  overflow: hidden;
  margin: 1.5rem 0;
}

.loading-progress {
  height: 100%;
  background: var(--gradient-primary);
  width: 0%;
  animation: loadingProgress 3s ease-in-out forwards;
}

@keyframes loadingProgress {
  0% { width: 0; }
  50% { width: 70%; }
  100% { width: 100%; }
}

.loading-text {
  font-size: 0.9rem;
  color: var(--text-secondary);
  opacity: 0;
  animation: fadeInUp 1s ease 1s forwards;
}
#home {
  background-color: #f4f4f4;
}

#skip-intro {
  position: relative;
  z-index: 20;
  padding: 0.5rem 1.2rem;
  font-size: 1rem;
  border-radius: 30px;
  transition: background-color 0.3s ease;
}

#skip-intro:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

/* Responsividade */
@media (max-width: 768px) {
  .preloader-text {
    font-size: 2.5rem;
    gap: 0.6rem;
  }

  .preloader-text .icon {
    font-size: 1.8rem;
  }
}

@media (max-width: 480px) {
  .preloader-text {
    font-size: 2rem;
    gap: 0.4rem;
  }

  .preloader-text .icon {
    font-size: 1.5rem;
  }
}
.transition-bg {
  position: fixed;
  top: 0;
  left: 0;
  height: 100vh;
  width: 100vw;
  background-color: #F0EEEB;
  z-index: 9998;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.6s ease-in-out;
  pointer-events: none;
  backface-visibility: hidden;
  will-change: transform;
}

.transition-bg.show {
  transform: scaleX(1);
}


/* Conteúdo principal com fundo fixo e transição */
.main-content {
  background-color: #F0EEEB;
  min-height: 100vh;
  position: relative;
  opacity: 0;
  transition: opacity 0.6s ease-in;
  z-index: 1;
}

.main-content.show {
  opacity: 1;
}
.transition-bg.hidden {
  display: none;
}

.header-row {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    font-family: "Playfair Display", sans-serif;
    font-weight: 900;
    z-index: 10;
    background-color: #F0EEEB;
    color: #000000;
    -webkit-transition: color 200ms 700ms linear;
    -o-transition: color 200ms 700ms linear;
    transition: color 200ms 700ms linear;
    vertical-align: baseline;
    
}



.nav__bar {
    position: absolute;
    top: 0;
    left: 0;
    height: 4rem;
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 1rem 2rem;
    background-color: #F0EEEB;
}

.is-expanded-menu #header.transparent-header.semi-transparent {
    --cnvs-header-bg: #F0EEEB;
}
.is-expanded-menu .style-3 .menu-container>.menu-item>.menu-link {
    --cnvs-primary-menu-padding-y: 0;
    margin: 0;
    color: #000000;
    font-size: 2.3rem;
    font: inherit;
    text-transform: lowercase;
}


#home h1 {
  font-family: 'Playfair Display', serif;
  font-weight: 900;
  margin: 0;
  line-height: 1; /* Evita espaçamento vertical excessivo */
  text-transform: uppercase; /* Garante que o texto está em maiúsculas */
}
#home h5 {
    font-family: sans-serif; /* Uma fonte mais simples para o subtítulo */
}

.blue{background-color: #D8E4EE;}


#heroVideo {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.video-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1;
  transition: background 0.5s ease;
}

.main-content.active .video-overlay {
  background: rgba(13, 43, 69, 0.7);
}
#blog h2 {
    font-family: 'Playfair Display', serif;
    font-weight: 900;
    margin: 0;
    line-height: 1;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    font-size: 183px;
}
#blog p{
    color: #353535;
    font-family: 'Lora', serif;
}
.scroll-container {
  width: 100%;
}

.title-col {
  flex: 0 0 30%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-left: 5%;
}


.blog-label {
  position: absolute;
  top: 5%;
  left: 5%;
  font-size: 1.2rem;
  font-weight: 800;
  text-transform: uppercase;
  color: #d8e4ee;
  opacity: 1 !important;
}

.scroll-section {
  display: flex;
  align-items: flex-start;
  margin-bottom: 4rem;
  height: 75vh;            /* ALTURA de exibição */
}



.posts-col {
  flex: 1;
  position: relative;
  height: 100%;           /* pega 75vh da secção */
  overflow: hidden;       /* esconde o que sair desse 75vh */
}

.posts-wrapper {
  position: absolute;
  /* em vez de 50%, usa 55% ou 60% */
  top: 55%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}


.post h4 {
  margin: 0 0 .5rem;
}
.post p {
  margin: 0;
  line-height: 1.4;
}


/* === Home Section Fade-in === */
#home h1#dynamic-h1 { opacity: 0; transform: translateY(20px); }
#home h1#dynamic-h1.visible { opacity: 1; transform: none; }


.pastel-text { 
  color: #6C757D;
  background: linear-gradient(90deg, #FFDDE2 0%, #E4F9F5 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}


.pastel-subtitle {
  color: #8A8A8A;
}

.pastel-logo {
  max-width: 200px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

/* ---------- animações de entrada ---------- */


.fade-in-up.visible {
  opacity: 1;
  transform: translateY(0);
}

/* botão bio — adiciona um subtil hover */
#bio-btn {
  border-color: #6C757D;
  color: #6C757D;
  transition: background-color 0.3s ease, color 0.3s ease;
}
#bio-btn:hover {
  background-color: #6C757D;
  color: #fff;
}


/* ===== Container isolado ===== */
.contact-code-section {
  text-align: center;
  padding: 2rem;
}

/* Intro */
.contact-code-intro {
  margin-bottom: 1.5rem;
  font-size: 1.5rem;
  font-weight: 500;
  background: linear-gradient(90deg, #aaa, #555);
  -webkit-background-clip: text;
  color: transparent;
}

/* Código completo */
.contact-code {
  display: inline-flex;
  background: #111;
  border-radius: 1rem;
  box-shadow: inset 0 1px rgba(255,255,255,0.2);
  user-select: none;
  overflow: hidden;
}
.contact-code:hover { cursor: grab; }

/* Cada célula e separador */
.cc-digit,
.cc-sep {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem 1rem;
  position: relative;
}
.cc-sep {
  padding: 2rem 0.5rem;
  color: #777;
  font-size: 2rem;
  pointer-events: none;
}

/* Espaço extra à esquerda/direita */
.cc-digit:first-of-type { padding-left: 3rem; }
.cc-digit:last-of-type  { padding-right: 3rem; }


/* Dígito: texto e transições */
.cc-digit span {
  display: inline-block;
  font-size: 2rem;
  color: #fff;
  text-shadow: 0 0 4px rgba(0,0,0,0.8);
  transform: scale(calc(var(--cc-active, 0) * 0.25 + 0.75));
  filter: blur(calc((1 - var(--cc-active, 0)) * 0.2rem));
  transition: transform 0.3s ease, filter 0.3s ease;
}

/* Destaque de fundo no active */
.cc-digit:is(:hover, :focus-visible)::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.1);
  z-index: -1;
  transition: background 0.3s ease;
}

/* Distribuição de --cc-active */
/* central */
.cc-digit:is(:hover, :focus-visible) { --cc-active: var(--cc-lerp-0); }
/* vizinhos à direita e à esquerda */
.cc-digit:is(:hover, :focus-visible) + .cc-digit,
.cc-digit + .cc-digit:is(:hover, :focus-visible) { --cc-active: var(--cc-lerp-1); }
.cc-digit:is(:hover, :focus-visible) + .cc-digit + .cc-digit,
.cc-digit + .cc-digit + .cc-digit:is(:hover, :focus-visible) { --cc-active: var(--cc-lerp-2); }
.cc-digit:is(:hover, :focus-visible) + .cc-digit + .cc-digit + .cc-digit,
.cc-digit + .cc-digit + .cc-digit + .cc-digit:is(:hover, :focus-visible) { --cc-active: var(--cc-lerp-3); }
.cc-digit:is(:hover, :focus-visible) + .cc-digit + .cc-digit + .cc-digit + .cc-digit,
.cc-digit + .cc-digit + .cc-digit + .cc-digit + .cc-digit:is(:hover, :focus-visible) { --cc-active: var(--cc-lerp-4); }
.cc-digit:is(:hover, :focus-visible) + .cc-digit + .cc-digit + .cc-digit + .cc-digit + .cc-digit,
.cc-digit + .cc-digit + .cc-digit + .cc-digit + .cc-digit + .cc-digit:is(:hover, :focus-visible) { --cc-active: var(--cc-lerp-5); }

/* Cursor durante o drag */
.contact-code:active { cursor: grabbing; }



/* ===== Monitor estilizado ===== */
.monitor {
  position: relative;
  width: 320px;
  background: #2d2d2d;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
  overflow: hidden;
  font-family: 'Source Code Pro', monospace;
  margin: 2rem 0;
}

/* Cabeça do monitor: botões estilo macOS */
.monitor-header {
  display: flex;
  gap: .5rem;
  padding: .75rem;
  background: #1f1f1f;
}
.dot {
  width: 12px; height: 12px;
  border-radius: 50%;
  display: inline-block;
}
.red    { background: #ff5f56; }
.yellow { background: #ffbd2e; }
.green  { background: #27c93f; }

/* Ecrã com typing animation */
.monitor-screen {
  background: #1e1e1e;
  padding: 1rem;
  height: 180px;
  overflow-x: auto;
  scrollbar-width: thin;
  scrollbar-color: #555 transparent;
}
.monitor-screen::-webkit-scrollbar {
  height: 6px;
}
.monitor-screen::-webkit-scrollbar-thumb {
  background: #555;
  border-radius: 3px;
}

.code-lines {
  margin: 0;
  color: #c5c8c6;
  font-size: .9rem;
  line-height: 1.4;
}
.code-lines code {
  display: inline-block;
  white-space: pre;
  overflow: hidden;
  border-right: 2px solid #c5c8c6;
  box-sizing: content-box;
  width: 0;
  animation: typing 3s steps(30,end) .5s forwards,
             blinkCaret .75s step-end infinite .5s;
}

/* Stand do monitor */
.monitor-stand {
  width: 16px;
  height: 40px;
  background: #3a3a3a;
  margin: 0 auto;
  border-radius: 4px;
}

/* Base do monitor */
.monitor-base {
  width: 120px;
  height: 12px;
  background: #3a3a3a;
  margin: .5rem auto 0;
  border-radius: 4px;
}


.fade-in-up {
  opacity: 0;
  animation: fadeInUp .8s ease-out forwards;
}

/* Ajuste responsivo: alinhar verticalmente */
@media (min-width: 768px) {
  .col-md-6.d-flex {
    display: flex;
    align-items: center;
  }
}
.is-expanded-menu .sticky-header #header-wrap {

    background-color: rgb(240 238 235)!important;
}
/* 
.pin-spacer {
  padding-bottom: 0 !important;
  margin-bottom: 4rem;
}
CSS: Estilos 3D avançados e responsivos */

/* Perspectiva e contexto 3D */
.stack-wrapper {
  perspective: 1400px;
  transform-style: preserve-3d;
  height: 180px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}

/* Container das camadas */
.stack-3d {
  position: relative;
  transform-style: preserve-3d;
  will-change: transform;
  backface-visibility: hidden;
}

/* Estilo base do texto */
.layer-text {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0;
  font-family: 'Playfair Display', serif;
  font-size: clamp(4rem, 10vw, 8rem);
  font-weight: 900;
  color: #1e2023;
  line-height: 1;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  /* pequena transição para suavizar hover/resizing */
  transition: transform 0.3s ease-out;
}

/* Camada frontal */
.front-layer {
  position: relative;
  z-index: 20;
}

/* Camadas de fundo com translateZ crescente */
.layer-text:nth-child(2) { transform: translateZ(-4px); opacity: 0.4; }
.layer-text:nth-child(3) { transform: translateZ(-8px); opacity: 0.3; }
.layer-text:nth-child(4) { transform: translateZ(-12px); opacity: 0.2; }
.layer-text:nth-child(5) { transform: translateZ(-16px); opacity: 0.15; }

/* Sombra subtil para profundidade */
.shadow-layer {
  color: #1e2023;
  text-shadow: 0 4px 6px rgba(0, 0, 0, 0.25);
}

/* Pequena vibração ao hover para interação */
.stack-wrapper:hover .front-layer {
  transform: translateZ(8px) rotateY(2deg) scale(1.02);
}
/* CSS: Indicador de scroll animado */

/* CSS Atualizado: Indicador de scroll “seta” muito maior */

/* Container do indicador, ajusta posição se necessário */
.scroll-indicator {
  position: absolute;
  right: 20%;
  bottom: 1rem;
  width: 3rem;      /* largura maior para o container */
  height: 4rem;     /* altura maior para o container */
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

/* Setão grande, usando borders para criar o triângulo */
.arrow {
  position: relative;
  width: 1.5rem;             /* largura da base da seta */
  height: 1.5rem;            /* altura da base da seta */
  border-left: 12px solid #1e2023;   /* grossura e cor da linha */
  border-bottom: 12px solid #1e2023; /* grossura e cor da linha */
  transform: rotate(-45deg);
  animation: bounce 1.5s ease-in-out infinite;
}

/* Animação “bounce” para a seta */
@keyframes bounce {
  0%, 20%, 50%, 80%, 100% {
    transform: translateY(0) rotate(-45deg);
  }
  40% {
    transform: translateY(12px) rotate(-45deg);
  }
  60% {
    transform: translateY(6px) rotate(-45deg);
  }
}

/* Container centralizado e máximo */
.blog-section {
  max-width: 1580px;
  margin: 0 auto 4rem;
  padding: 0 1rem;
}

/* Título com destaque */
.blog-section .section-title {
  position: relative;
  font-size: 2.5rem;
  margin-bottom: 2rem;
  color: #222;
}
.blog-section .section-title::after {
  content: '';
  position: absolute;
  left: 0; bottom: -6px;
  width: 60px; height: 4px;
  background: var(--accent-color);
  border-radius: 2px;
}


/* Container do swiper: garante overflow visível */
.blog-swiper {
  position: relative;
  overflow: visible;
  padding: 2rem 0;
}

/* Slides: largura fixa, mostra 3 por vez */
.blog-swiper .swiper-slide {
  width: 280px;           /* controla quantos cabem */
  margin-right: 20px;     /* espaço entre eles */
  background: none;       /* fundo vem do .post-card */
  box-shadow: none;
}

/* Card interno */
.post-card {
  background: #eaf2fb;
  border-radius: var(--border-radius);
  padding: 1.5rem;
  height: 100%;
  position: relative;
  overflow: hidden;
  box-shadow: 0 8px 24px rgba(0,0,0,0.1);
}

/* Sombra difusa por trás do card azul */
.post-card.blue::before {
  content: "";
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: var(--gradient-primary);
  filter: blur(60px) opacity(0.2);
  z-index: -1;
}

/* Setas maiores, fora do conteúdo */
.swiper-button-prev,
.swiper-button-next {
  width: 48px;
  height: 48px;
  background: rgba(0,0,0,0.6);
  border-radius: 50%;
  color: #fff;               /* seta branca no centro escuro */
  --swiper-navigation-size: 20px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
}
.swiper-button-prev:hover,
.swiper-button-next:hover {
  background: rgba(0,0,0,0.8);
}
.blog-swiper .swiper-button-prev {
  left: -2.5rem;
}
.blog-swiper .swiper-button-next {
  right: -2.5rem;
}
.blog-swiper .swiper-button-prev:hover,
.blog-swiper .swiper-button-next:hover {
  background: #357ABD;
  transform: translateY(-50%) scale(1.1);
}



/* 3) Forçar z‑index dos bullets acima dos slides */
.swiper-pagination {
  bottom: 16px;
  z-index: 10;
}

/* Responsivo: menos slides em mobile */
@media (max-width: 992px) {
  .blog-swiper .swiper-slide { width: 220px; }
}
@media (max-width: 768px) {
  .blog-swiper .swiper-slide { width: 180px; }
}

.post-card .read-more {
  cursor: pointer;
  position: relative;
  z-index: 10;
  text-decoration: none; /* ou força underline se quiser */
}

/* Opcional: dá um hover visual */
.post-card .read-more:hover {
  color: var(--accent-color);
  text-decoration: underline;
}

/* glow suave no post-card que estiver ativo */
.swiper-slide-active .post-card {
  box-shadow: 0 0 20px rgba(74,144,226,0.6);
  transition: box-shadow 0.4s ease;
}

/* remove o glow nos restantes para não acumular */
.swiper-slide .post-card {
  box-shadow: none;
}
@keyframes pulse-glow {
  0%   { box-shadow: 0 0 10px rgba(74,144,226,0.4); }
  50%  { box-shadow: 0 0 25px rgba(74,144,226,0.8); }
  100% { box-shadow: 0 0 10px rgba(74,144,226,0.4); }
}

.swiper-slide-active .post-card {
  animation: pulse-glow 2s ease-in-out infinite;
}

.top-anim {
    position: relative;
    width: 100%;
    height: 50vh;
    background: #122339;
    display: flex
;
    justify-content: center;
    align-items: center;
    overflow: hidden;
    perspective: 800px;
}

.end-phrase {
  position: absolute;
  bottom: 10%;
  left: 50%;
  transform: translateX(-50%) translateY(40px);
  opacity: 0;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 600;
  pointer-events: none;
  white-space: nowrap;
}
.logo-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  background-color: #4A90E2;  /* ou outra variável de cor que uses */
  border-radius: 50%;
  margin-right: 8px;          /* espaçamento antes do nome */
  vertical-align: middle;     /* alinha a bola ao centro do texto */
}


#gotoTop {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
  /* mantém o transform de “descida” inicial */
  transform: translateY(20px);
}

/* Quando adicionas a classe .show, o CSS torna-o visível */
#gotoTop.show {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}


/* --- Container GRID --- */
#aboutme{
  position: relative;          /* necessário para o ::before */
  /* altura robusta */
  min-height: 75vh;
  min-height: 75svh;
  min-height: 75lvh;
  min-height: 75dvh;

  /* estabilidade de pintura/composição (Edge/Win) */
  contain: paint;
  backface-visibility: hidden;
  transform: translateZ(0.001px);
  will-change: transform;
}

/* mover o background para um pseudo-elemento */
#aboutme::before{
  content: "";
  position: absolute; inset: 0;
  z-index: 0;
  background: var(--hero) center/cover no-repeat;
}

/* conteúdo acima do fundo */
#aboutme > .aboutme-container{
  position: relative;
  z-index: 1;
  min-height: inherit;          /* herda a altura do section */
  display: grid;
  align-content: center;
  grid-template-columns: 1fr 1fr;
  grid-template-areas:
    "social  img"
    "content img"
    "info    img";
  gap: 1.5rem 2rem;
  padding: 4rem 2rem;
}

/* altura mínima em ecrãs muito baixos */
@media (max-height: 700px){
  #aboutme{ min-height: 560px; }
}
/* Associações */
.aboutme-social  { grid-area: social; }
.aboutme-content { grid-area: content; }
.aboutme-info    { grid-area: info; }
.aboutme-img     { grid-area: img; }

/* Contactos (wrapper) */
.aboutme-info {
  display: flex;
  gap: 2rem;
  align-items: flex-start;
  
}



/* ---------------------------------------------------
   Bloco “Siga-me” personalizado
--------------------------------------------------- */
/* Estilo bloco “Siga-me” revisitado */
.aboutme-social {
  display: flex;
  align-items: center;
  gap: 1rem;
  font-size: 0.9rem;
  font-weight: 500;
  position: relative;
}

.aboutme-social .social-label {
  color: #fff;
  position: relative;
  padding-bottom: 0.25rem;
}

/* Sub-linha gradient abaixo do texto */
.aboutme-social .social-label::after {
  content: '';
  position: absolute;
  left: 0; 
  bottom: 0;    /* bem embaixo do texto */
  width: 40px;  /* comprimento da linha */
  height: 2px;
  background: linear-gradient(
    135deg,
    #1d4e8b 0%,
    #00ffea 50%,
    #1d4e8b 100%
  );
  border-radius: 1px;
  transition: width 0.3s ease;
}

/* Ao passar o mouse, extende a sublinha */
.aboutme-social .social-label:hover::after {
  width: 60px;
}

/* Lista de ícones */
.aboutme-social .social-list {
  display: flex;
  gap: 0.75rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.aboutme-social .social-item a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.4rem;
  height: 2.4rem;
  background: #222;
  color: #fff;
  border-radius: 50%;
  font-size: 1.2rem;
  transition:
    background 0.3s ease,
    transform 0.2s ease;
}

/* Hover com degradê idêntico ao botão */
.aboutme-social .social-item a:hover {
  background: linear-gradient(
    135deg,
    #1d4e8b 0%,
    #00ffea 50%,
    #1d4e8b 100%
  );
  transform: scale(1.1);
}


/* Imagem */
.aboutme-img img {
  width: 100%;
  max-width: 420px;
  border-radius: 0.5rem;
  object-fit: cover;
}

/* Conteúdo */
.aboutme-content h1 {
  font-size: 2.5rem;
  margin-bottom: 0.5rem;
  color: hsl(242, 8%, 95%);
}
.aboutme-content h3 {
  font-size: 1.5rem;
  font-weight: 400;
  margin-bottom: 1rem;
  color: #ccc;
}
.aboutme-content p {
  line-height: 1.5;
  margin-bottom: 1.5rem;
  max-width: 520px;
}



/* Responsivo */
@media (max-width: 768px) {
  #aboutme .aboutme-container {
    grid-template-columns: 1fr;
    grid-template-areas:
      "social"
      "img"
      "content"
      "info";
    text-align: center;
  }


  .aboutme-img img {
    max-width: 300px;
    margin: 0 auto;
  }
}



/* 1) Wrapper com anel neon + glow interno */
.profile-wrapper {
  --size: 300px;
  position: relative;
  width: var(--size);
  height: var(--size);
  border-radius: 50%;
  background:
    /* anel externo animado */
    conic-gradient(from 0deg, #4A90E2, #00FFEA, #4A90E2)
    padding-box,
    /* glow interno estático */
    radial-gradient(circle at center, rgba(74,144,226,0.3), transparent 60%)
    border-box;
  padding: 5px;
  animation: spin 6s linear infinite;
  box-shadow:
    0 0 30px rgba(74,144,226,0.6),
    inset 0 0 20px rgba(0,255,234,0.4);
  transition: transform .3s ease-out;
  will-change: transform;
  margin: auto; /* centra se usares grid ou flex */
}

/* 2) Imagem em si */
.profile-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  filter: grayscale(30%) contrast(1.1);
  transition: filter .4s ease, transform .4s ease;
}

/* 3) Hover sobre o wrapper */
.profile-wrapper:hover {
  transform: scale(1.05);
}

/* 4) Hover sobre a imagem — volta às cores e dá um zoom subtil */
.profile-wrapper:hover .profile-img {
  filter: grayscale(0) contrast(1);
  transform: scale(1.03);
}

/* 5) Keyframes de rotação do anel */
@keyframes spin {
  to { transform: rotate(360deg); }
}


.aboutme-content .btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border-radius: 0.3rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(
    135deg,
    #1d4e8b 0%,
    #00ffea 50%,
    #1d4e8b 100%
  );
  background-size: 200% 100%;
  background-position: 0 0;
  transition:
    background-position 0.4s ease,
    transform 0.2s ease;
}

.aboutme-content .btn:hover {
  background-position: 100% 0;
  transform: translateY(-3px);
}
/* Botões com degradê consistente */


.btn-gradient {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  border: none;
  border-radius: 0.3rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(135deg, #1d4e8b 0%, #00ffea 50%, #1d4e8b 100%);
  background-size: 200% 100%;
  background-position: 0 0;
  transition: background-position 0.4s, transform 0.2s;
  text-decoration: none;
}
.btn-gradient:hover {
  background-position: 100% 0;
  transform: translateY(-3px);
  background:  linear-gradient(34deg, #ffd45f 0%, #fffc00 50%, #ff5252 100%);
  color: #125859 !important;
}



/* Cada item */
.info-item {
  display: flex;
}

/* Ícone */
.info-item i {
  font-size: 1.6rem;
  color: #00ffea;             /* ciano-esverdeado */
  flex-shrink: 0;
}

/* Título (h4) */
.info-item h4 {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
  color: #00ffea;             /* mesmo tom do ícone */
}

/* Texto (span) */
.info-item span {
  display: block;
  margin-top: 0.15rem;
  font-size: 0.98rem;    /* valor corrigido */
  color: #ccc;           /* cinza leve para secundário */
}

/* Link dentro do span */
.info-item span a {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s;
}
.info-item span a:hover {
  color: #ffffff;             /* branco suave no hover */
}

.wave-divider {
  line-height: 0;
  transform: rotate(180deg); /* inverte, se quiser */
}
.wave-divider svg {
  display: block;
  width: 100%;
  height: 100px;
}


.portfolio-header {
  text-align: center;
  max-width: 600px;
  margin: 0 auto 3rem;
}

/* Substitui o bloco global por versões escopadas */
#portfolio-grid-section .section-title,
.portfolio-header .section-title {
  font-size: 2.5rem;
  margin-bottom: .5rem;
  color: #1d2230;
}

.section-subtitle {
  font-size: 1.1rem;
  color: #555;
  line-height: 1.5;
}

#portfolio-grid-section {
  padding: 5rem 0;
  background: #f4f4f4;
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px,1fr));
  gap: 1.5rem;
}


/* Imagem */
.card-thumb {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
}

.card-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

/* Corpo */
.card-body {
  padding: 1rem 1.2rem;
}

.card-title {
  font-size: 1.25rem;
  margin: 0 0 0.5rem;
  color: #1d1d1d;
}

.card-desc {
  font-size: 0.94rem;
  line-height: 1.4;
  margin-bottom: 0.75rem;
  color: #555;
}

/* Tecnologias */
.card-tech {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  list-style: none;
  padding: 0;
  margin: 0;
}

.card-tech li {
  font-size: 0.78rem;
  background: #e4e4e4;
  padding: 0.3rem 0.6rem;
  border-radius: 0.3rem;
}

/* === Portefólio — Estilos Específicos === */
#portfolio {
  width: 100vw;
  min-height: 100vh;
  background: #f4f4f4;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  padding: 0; /* caso existam paddings globais */
}

#portfolio-deck {
  position: relative;
  width: 85vw;
  max-width: 1000px;
  height: 88vh;
  max-height: 1050px;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 1200px;
}

.deck-item {
  position: absolute;
  top: 0; left: 50%;
  width: 595px;
  min-width: 320px;
  max-width: 99vw;
  height: 842px;
  max-height: 86vh;
  transform: translateX(-50%) scale(0.8);
  opacity: 0;
  filter: grayscale(80%);
  pointer-events: none;
  transition: transform .6s cubic-bezier(.4,1.3,.6,1),
              opacity .5s cubic-bezier(.4,1.3,.6,1),
              z-index .3s;
}

.deck-item.active {
  transform: translateX(-50%) scale(1);
  opacity: 1;
  filter: none;
  z-index: 3;
  pointer-events: auto;
  background-color: #f0eeeb;
}

.deck-item.left,
.deck-item.right {
  opacity: 0.6;
  z-index: 2;
}

.deck-item.left  { transform: translateX(-130%) scale(0.85); }
.deck-item.right { transform: translateX(30%)  scale(0.85); }

.deck-item.far-left,
.deck-item.far-right {
  opacity: 0.2;
  z-index: 1;
  pointer-events: none;
}

.deck-item.far-left  { transform: translateX(-260%) scale(0.72); }
.deck-item.far-right { transform: translateX(160%) scale(0.72); }

.deck-item figure {
  width: 100%;
  aspect-ratio: 16/8;
  background: #e7e7e7;
  overflow: hidden;
  border-radius: 0 0 8px 8px;
  margin: 0;
}

.deck-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 0 0 8px 8px;
  display: block;
}

.deck-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 1.3rem 1.2rem 0.8rem;
}

.deck-content h3 {
  font-family: 'Playfair Display', serif;
  font-size: 1.45rem;
  margin: 0 0 0.6rem;
  text-align: center;
  color: #1a2130;
}

.deck-desc {
  font-family: 'Lora', serif;
  font-size: 0.98rem;
  line-height: 1.5;
  color: #353535;
  text-align: center;
  margin-bottom: 0.6rem;
}

.deck-tech {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.45rem;
  margin-bottom: 0.6rem;
}

.badge-tech {
  background: #e7eaf3;
  color: #305d9f;
  font-size: 0.89rem;
  font-family: 'Inter', sans-serif;
  padding: 0.26rem 0.8rem;
  border-radius: 7px;
  box-shadow: 0 1px 4px #dde3ee;
}

.deck-features {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  list-style: none;
  gap: 0.7rem;
  margin: 0 0 1rem;
  padding: 0;
}

.deck-features .feature-check {
  color: #009551;
  margin-right: 0.6em;
}

.deck-link {
  display: inline-block;
  margin: 1.2rem auto 0;
  padding: 0.38em 1.5em;
  font-family: 'Inter', sans-serif;
  font-weight: 600;
  font-size: 0.97rem;
  letter-spacing: 0.06em;
  border: 2px solid #3b2a54;
  background: #f4f4f4;
  color: #1d1547;
  border-radius: 8px;
  text-decoration: none;
  transition: background .2s, border .2s, color .2s;
}

.deck-link:hover {
  background: #3b2a54;
  color: #fff;
  border-color: #3b2a54;
}

/* Controle de volume */
.deck-volume-control {
  position: fixed;
  bottom: 2.8rem;
  left: 2.2rem;
  display: flex;
  align-items: center;
  background: rgba(34,38,56,0.92);
  padding: 0.48em 1.1em;
  gap: 0.7em;
  border-radius: 22px;
  box-shadow: 0 2px 24px rgba(34,38,56,0.45);
  font-family: 'Inter', sans-serif;
  font-size: 1.03rem;
  color: #8fd2fd;
  transition: opacity .28s;
}

.deck-volume-control.hide {
  opacity: 0;
  pointer-events: none;
}

.deck-volume-control input[type=range] {
  accent-color: #8fd2fd;
  width: 100px;
  cursor: pointer;
}

.deck-volume-control .icon-sound {
  width: 1.2em;
  height: 1.2em;
  opacity: 0.84;
}

.nav-tabs{
    border: none !important;
}

.nav-link {  
    color: #f0eeeb;
}

.nav-link:hover {  
    color: #00FFEA;
    border: none !important;
}




  #portfolio-grid h2 {
  font-family: 'Playfair Display', serif;
  font-weight: 700;
}

.project-card {
  background: #fff;
  border-radius: var(--radius);
  box-shadow: var(--shadow-soft);
  transition: transform var(--transition),
              box-shadow var(--transition);
  overflow: hidden;
  font-size: 14px;
    font-weight: 500!important;
}

.project-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 12px 30px rgba(0,0,0,0.25);
}

.project-card .card-img-top {
  height: 180px;
  object-fit: cover;
}

.project-card .card-title {
  color: var(--accent-2);
  font-weight: 600;
  position: relative;
  margin-bottom: .75rem;
}

.project-card .card-title::after {
  content: '';
  position: absolute;
  left: 0; bottom: -4px;
  width: 40px; height: 3px;
  background: var(--accent-1);
  transition: width var(--transition);
}

.project-card:hover .card-title::after {
  width: 100%;
}



.project-card .card-img{
    border: none !important;
}

.btn-outline-secondary:hover{
    color: #fff;
    background-color: #ff5252;
    border-color: #ff5252;

}

/* Espaçamento extra no topo */
#projectsTab { margin: 2rem; }

/* Esconde itens filtrados */
.project-item.hide {
  display: none !important;
}





:root{
  --kb2-grad: linear-gradient(45deg, rgb(212 219 231) 0%, #1678a1 100%);
  --kb2-white:#fff;
  --kb2-black:#0f172a;
  --kb2-muted:#64748b;
  --kb2-shadow:0 14px 36px rgba(0,0,0,.28);
  --kb2-radius:16px;
}


.kb2-news {
  position: relative;
  overflow: hidden;
  background-color: #0b0e18;
  box-shadow: 
      
    0 40px 60px -30px rgba(0,0,0,0.6);   /* fundo */

}

.kb2-news__bg {
  position: absolute;
  inset: -10vh 0 -10vh 0;       /* “folga” para o vídeo não revelar bordas */
 
  z-index: 0;
}


.kb2-news__video{
   width: 100%;
  height: 120%;
  object-fit: cover;
  object-position: 85% center;  /* o teu enquadramento */
  display: block;
  pointer-events: none;
}



.kb2-news__bg img{width:100%;height:100%;object-fit:cover;}
.kb2-news__bg::after{
  content:"";
  position:absolute; inset:0;
  background: var(--kb2-grad, linear-gradient(45deg, rgba(209,0,42,.65) 0%, #0E5DC4 100%));
  opacity:.92;
  pointer-events:none;
}
.kb2-news__inner{position:relative;z-index:1;max-width:1320px;margin:0 auto;padding:clamp(48px,5vw,76px) clamp(16px,4vw,28px) 110px}

.kb2-news__title{font:900 clamp(34px,5vw,64px) "Playfair Display",serif;letter-spacing:.2px;line-height:1;margin:0 0 18px}

.kb2-filters{display:flex;flex-wrap:wrap;gap:10px 12px;margin-bottom:24px}
.kb2-chip {
  appearance: none;
  border: 1px solid rgba(255,255,255,.15);
  background: rgba(61,61,61,.9);
  color: #e8f1ff;
  padding: .55rem .9rem;
  border-radius: 999px;
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .02em;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  min-height: 38px;
  line-height: 1;
  cursor: pointer;
  transition: transform .12s ease, border-color .2s ease, background .2s ease, color .2s ease, box-shadow .2s ease;
}

.kb2-chip:hover {
  transform: translateY(-2px);
  border-color: rgba(0,255,234,.45);
  background: rgba(0,255,234,.18);
  color: #fff;
}

.kb2-chip.is-active {
  border-color: transparent;
  background: linear-gradient(135deg, #1d4e8b 0%, #00ffea 50%, #1d4e8b 100%);
  color: #0b1b1b;
  box-shadow: 0 10px 28px rgba(0,255,234,.18);
}

.kb2-chip:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(0,255,234,.35);
  transform: translateY(0);
}

.kb2-chip:disabled {
  opacity: .5;
  cursor: not-allowed;
  transform: none !important;
}

.kb2-chip .kb2-chip-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #00ffea;
  box-shadow: 0 0 10px rgba(0,255,234,.6);
  flex: 0 0 8px;
}

@media (prefers-reduced-motion: reduce) {
  #kb2-news .kb2-news__bg { transform: none !important; }
  #kb2-news .kb2-news__video { height: 100%; }
}

.kb2-swiper{position:relative;overflow:visible;padding:8px 70px 76px}
.kb2-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:50px;height:50px;border:none;border-radius:999px;background:#fff;color:#111;box-shadow:var(--kb2-shadow);display:grid;place-items:center;cursor:pointer}
.kb2-arrow svg{width:22px;height:22px}
.kb2-arrow--prev{left:10px}
.kb2-arrow--next{right:10px}

.kb2-pagination{position:absolute;left:50%;transform:translateX(-50%);bottom:26px}
.kb2-pagination .swiper-pagination-bullet{width:86px;max-width:24vw;height:10px;border-radius:999px;background:#fff;opacity:.28;margin:0 6px;transition:width .35s ease,opacity .25s ease}
.kb2-pagination .swiper-pagination-bullet-active{opacity:1;width:140px}

.kb2-card{height:100%;width:auto;max-width:640px;border-radius:var(--kb2-radius);position:relative;padding:22px 22px 18px;transition:transform .35s ease}
.kb2-card::before{content:"";position:absolute;inset:0;border-radius:inherit;background:#fff;transform:scaleY(0);transform-origin:bottom;transition:transform .45s ease;z-index:0;box-shadow:var(--kb2-shadow)}
.kb2-card__content{position:relative;z-index:1;color:#e9f1ff}
.kb2-card__date{display:inline-grid;gap:4px;padding-bottom:12px;margin-bottom:14px;border-bottom:2px solid currentColor;opacity:.95}
.kb2-card__day{font-weight:900;font-size:28px;line-height:1}
.kb2-card__month{font-size:14px;letter-spacing:.04em;text-transform:uppercase}
.kb2-card__title{font:800 clamp(18px,2.2vw,26px) "Inter",system-ui;line-height:1.2;margin:8px 0 10px}
.kb2-card__excerpt{color:#cfe3f1;line-height:1.55;font-size:15px;max-width:60ch}
.kb2-card__media{margin-top:18px;border-radius:18px;overflow:hidden;box-shadow:var(--kb2-shadow)}
.kb2-card__media img{display:block;width:100%;height:232px;object-fit:cover;transition:transform .35s ease}
.kb2-card:hover::before{transform:scaleY(1)}
.kb2-card:hover .kb2-card__title,
.kb2-card:hover .kb2-card__date,
.kb2-card:hover .kb2-card__excerpt{color:var(--kb2-black)}
.kb2-card:hover .kb2-card__media img{transform:scale(1.035)}

.kb2-swiper .swiper-slide{width:calc((100% - 2*24px - 140px) / 3);max-width:560px;margin-right:24px}
.kb2-swiper .swiper-slide:last-child{margin-right:0}
.kb2-swiper .swiper-slide{opacity:.85;transform:scale(.985);transition:transform .26s ease,opacity .26s ease}
.kb2-swiper .swiper-slide.swiper-slide-active {
  opacity: 1;
  transform: scale(1);
  background-color: #ffffff33; /* branco com transparência */
  border-radius: var(--kb2-radius);
}

@media (max-width:1199px){
  .kb2-swiper .swiper-slide{width:calc((100% - 24px - 140px) / 2)}
}
@media (max-width:767px){
  .kb2-swiper{padding:6px 56px 76px}
  .kb2-swiper .swiper-slide{width:calc(100% - 140px)}
  .kb2-card__media img{height:200px}
}

@media (prefers-reduced-motion:reduce){
  .kb2-card,.kb2-card::before,.kb2-swiper .swiper-slide,.kb2-pagination .swiper-pagination-bullet{transition:none}
}

/* Versão “dark” — mantém como já tens */
.pf-nav-wrap{ display:flex; justify-content:center; margin-bottom:1.25rem; }
.pf-chips{ display:flex; flex-wrap:wrap; gap:.6rem .75rem; list-style:none; margin:0; padding:0; }
.pf-chip{ appearance:none; border:1px solid rgba(255,255,255,.15); background:rgba(255,255,255,.05); color:#e8f1ff; padding:.55rem .9rem; border-radius:999px; font-weight:700; font-size:.95rem; letter-spacing:.02em; display:inline-flex; align-items:center; gap:.55rem; transition:transform .12s ease, border-color .2s ease, background .2s ease, color .2s ease; outline:none; }
.pf-chip .pf-chip-dot{ width:8px; height:8px; border-radius:50%; background:#00ffea; opacity:.85; box-shadow:0 0 10px rgba(0,255,234,.6); }
.pf-chip .pf-chip-count{ font-size:.85rem; font-weight:800; opacity:.75; padding:.1rem .45rem; background:rgba(255,255,255,.08); border-radius:999px; }
.pf-chip:hover{ transform:translateY(-2px); border-color:rgba(0,255,234,.45); background:rgba(0,255,234,.12); color:#eafffb; }
.pf-chip.active{ border-color:transparent; color:#0a1717; background:linear-gradient(135deg,#1d4e8b 0%, #00ffea 50%, #1d4e8b 100%); box-shadow:0 10px 28px rgba(0,255,234,.18); }

/* Versão “clara” — ESCOPA COM .pf-light */
.pf-light .pf-chips{
  display:flex; gap:.35rem; padding:.4rem; border-radius:999px;
  background:rgba(255,255,255,.65);
  box-shadow:0 8px 24px rgba(31,46,80,.08), inset 0 1px rgba(255,255,255,.8);
  backdrop-filter:blur(6px);
}
.pf-light .pf-chip{
  appearance:none; border:1px solid rgba(18,32,56,.09); background:rgba(18,32,56,.03); color:#1f2e50;
  padding:.65rem 1rem; border-radius:999px; font:700 .95rem/1 "Inter",system-ui; letter-spacing:.01em;
  display:inline-flex; align-items:center; gap:.55rem; transition:transform .12s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease; outline:0;
}
.pf-light .pf-chip .pf-chip-dot{ background:#00e6de; box-shadow:0 0 8px rgba(0,230,222,.55); }
.pf-light .pf-chip .pf-chip-count{ font-size:.8rem; font-weight:800; padding:.1rem .5rem; border-radius:999px; background:#e9eef5; color:#43506a; }
.pf-light .pf-chip:hover{ transform:translateY(-2px); border-color:rgba(0,190,200,.35); background:rgba(0,190,200,.10); box-shadow:0 8px 22px rgba(0,190,200,.15); color:#163042; }
.pf-light .pf-chip.active{
  border-color:#f5f7f7; color:#082a2a;
  background:linear-gradient(135deg,#b9faff 0%, #57d6e6 50%, #2fb4d7 100%);
  box-shadow:0 10px 26px rgba(47,180,215,.30), inset 0 1px 0 rgba(255,255,255,.65);
}
.pf-light .pf-chip.active .pf-chip-count{ background:rgba(255,255,255,.85); color:#0f2a33; }
.pf-light .pf-chip:focus-visible{ box-shadow:0 0 0 3px rgba(47,180,215,.35), 0 8px 22px rgba(47,180,215,.18); transform:none; }


  /* ==================== SUBTÍTULO ==================== */
  .pf-subtitle{
    color: #686868 !important;
  }

  /* ==================== CARTÕES ==================== */
  .pf-card{
    background: #f0eeeb;
    border-radius: 16px;
    border: 1px solid transparent;
    overflow: hidden;
    display:flex; flex-direction:column;
    box-shadow: 0 8px 24px rgba(0,0,0,.35);
    transition: transform .2s ease, box-shadow .25s ease, border-color .25s ease;
  }
  .pf-card:hover{
    transform: translateY(-6px);
    border-color: rgba(0,255,234,.22);
    box-shadow: 0 16px 40px rgba(0,0,0,.45), 0 0 0 1px rgba(0,255,234,.08) inset;
  }

  /* Thumb 16:9 */
  /* THUMB SEM ARTEFACTOS */
  /* THUMB COM ARREDONDAMENTO SÓ NO TOPO */
.pf-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  border-top-left-radius: 14px;   /* só canto superior esquerdo */
  border-top-right-radius: 14px;  /* só canto superior direito */
  overflow: hidden;
  background: #0b0e18;
  isolation: isolate;
}

.pf-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: 0;
  transform: translateZ(0) scale(1.04);
  transition: transform .6s ease;
  backface-visibility: hidden;
}

.pf-card:hover .pf-thumb img {
  transform: translateZ(0) scale(1.08);
}

.pf-thumb, .pf-thumb * {
  outline: 0 !important;
  box-shadow: none;
}



  /* Overlay de ações */
  .pf-thumb-overlay{
    position:absolute; inset:0; display:flex; align-items:flex-end; justify-content:center;
    background: linear-gradient(180deg, rgba(0,0,0,0) 35%, rgba(0,0,0,.55) 100%);
    opacity: 0; transform: translateY(6px);
    transition: opacity .25s ease, transform .25s ease;
    padding: .9rem;
  }
  .pf-card:hover .pf-thumb-overlay{ opacity:1; transform: translateY(0); }

  .pf-action{
    display:inline-block; text-decoration:none; font-weight:800; letter-spacing:.02em;
    padding:.55rem .95rem; border-radius: 10px;
    color:#0a1717; background: linear-gradient(135deg, #1d4e8b 0%, #00ffea 50%, #1d4e8b 100%);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 6px 18px rgba(0,255,234,.25);
    transition: transform .1s ease, box-shadow .2s ease;
  }
  .pf-action:hover{ transform: translateY(-2px); box-shadow: 0 10px 26px rgba(0,255,234,.35); }

  /* Corpo */
  .pf-body{ padding: 1rem 1rem 1.15rem; display:flex; flex-direction:column; gap:.4rem; }
  .pf-type{
    display:inline-flex; align-self:flex-start; font-size:.78rem; font-weight:800; letter-spacing:.06em;
    padding:.25rem .55rem; border-radius: 999px; color:#9eeff1; background: rgba(0,255,234,.12);
    border:1px solid rgba(0,255,234,.3);
  }
  .pf-title{
    margin: .2rem 0 0; color:#4a4a4a; position:relative;
  }
  .pf-title::after{
    content:''; position:absolute; left:0; bottom:-6px; width:48px; height:3px;
    background: linear-gradient(90deg,#00ffea,#1d4e8b); border-radius:2px; opacity:.85;
    transition: width .25s ease;
  }
  .pf-card:hover .pf-title::after{ width: 82px; }
  .pf-desc{ 
      color:#4a4a4a;
      font-size: 13px;
  }

  /* ==================== RESPONSIVO ==================== */
  @media (max-width: 576px){
    .pf-chip .pf-chip-count{ display:none; } /* opcional: esconder a contagem no mobile */
  }

  /* header do card: categoria à esquerda, botão à direita */
.pf-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:.75rem;
  margin-bottom:.25rem;
}

/* impedir o botão de esticar */
.pf-header .btn-mask{
  flex:0 0 auto;
  align-self:auto;
  display:inline-flex;
}

/* botão “mask” pequeno com contraste para o fundo #3d3d3d */
/* Base do botão pequeno */
.btn-mask.btn-small{
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 36px;
  padding: 0 16px;
  border-radius: 8px 0;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, #2a2f38 0%, #3b424d 50%, #2a2f38 100%);
  color:#fff;
  text-decoration: none;
  font-weight: 800;
  letter-spacing:.02em;
  box-shadow: 0 4px 8px rgba(0,0,0,.35);
  transition: transform .15s ease, box-shadow .25s ease, filter .25s ease;
  overflow: hidden;
}

/* texto sempre branco por cima */
.btn-mask__label{
  position: relative;
  z-index: 1;
  color:#fff !important;
}

/* brilho suave ao passar o rato */
.btn-mask.btn-small::after{
  content:'';
  position:absolute; inset:0;
  background: radial-gradient(120% 120% at 10% 0%, rgba(255,255,255,.10) 0%, transparent 60%);
  opacity:.0; transition: opacity .3s ease;
  transition: opacity .3s ease;
}
.btn-mask.btn-small:hover{
  transform: translateY(-2px);
  filter: none;
  box-shadow: 0 10px 26px rgba(0,0,0,.45);
}
.btn-mask.btn-small:hover::after{ opacity:.6; }

/* foco acessível */
.btn-mask.btn-small:focus-visible{
  outline:0;
  box-shadow: 0 0 0 3px rgba(255,255,255,.25), 0 10px 26px rgba(0,0,0,.45);
}

/* versão “neutra” (se precisares num fundo mais claro) */
.btn-mask.btn-small.is-ghost{
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.35);
  box-shadow: none;
}
.btn-mask.btn-small.is-ghost:hover{
  background: rgba(255,255,255,.18);
}


.glow-on-hover {
    width: 220px;
    height: 50px;
    border: none;
    outline: none;
    color: #fff;
    background: #111;
    cursor: pointer;
    position: relative;
    z-index: 0;
    border-radius: 10px;
    padding: 5px 8px;
}

.glow-on-hover:before {
    content: '';
    background: linear-gradient(45deg, #ff0000, #ff7300, #fffb00, #48ff00, #00ffd5, #002bff, #7a00ff, #ff00c8, #ff0000);
    position: absolute;
    top: -2px;
    left:-2px;
    background-size: 400%;
    z-index: -1;
    filter: blur(5px);
    width: calc(100% + 4px);
    height: calc(100% + 4px);
    animation: glowing 20s linear infinite;
    opacity: 0;
    transition: opacity .3s ease-in-out;
    border-radius: 10px;
}

.glow-on-hover:active {
    color: #000
}

.glow-on-hover:active:after {
    background: transparent;
}

.glow-on-hover:hover:before {
    opacity: 1;
}

.glow-on-hover:after {
    z-index: -1;
    content: '';
    position: absolute;
    width: 100%;
    height: 100%;
    background: #111;
    left: 0;
    top: 0;
    border-radius: 10px;
}

@keyframes glowing {
    0% { background-position: 0 0; }
    50% { background-position: 400% 0; }
    100% { background-position: 0 0; }
}


/* ─────────────────────────────────────────────
   CONTACT FINAL — hot-fix do retângulo + form
   ──────────────────────────────────────────── */

/* ===================== CONTACT FINAL — CSS ÚNICO ===================== */
#contact-final{
  position: relative;
  isolation: isolate;
  background: #0b0e18; /* fallback escuro */
  color: #eaf6ff;
  overflow: hidden;
   /* Sombras internas no topo e fundo */
  box-shadow: 
      0 -40px 60px -30px rgba(0,0,0,0.6),  /* topo */
    0 40px 60px -30px rgba(0,0,0,0.6);   /* fundo */
}

/* ---- Fundo animado (usa background-image inline no HTML) ---- */
#contact-final .cf-bg-mover{
  position: absolute;
  inset: -10%;
  z-index: 0;
  pointer-events: none;
  background-repeat: no-repeat;
  background-size: 110% auto;      /* ligeiro zoom para evitar bordas em movimento */
  background-position: 50% 50%;
  animation: cf-bg-pan 40s ease-in-out infinite alternate;
}
@keyframes cf-bg-pan{
  0%   { background-position: 36% 54%; }
  50%  { background-position: 54% 46%; }
  100% { background-position: 50% 50%; }
}

/* ---- Halo (suave, sem mix-blend) ---- */
#contact-final .effect-layer{
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  --mx: 50%; --my: 50%;
  background:
    radial-gradient(900px 620px at var(--mx) var(--my),
      rgba(255,255,255,0.28) 0%,
      rgba(255,255,255,0.18) 16%,
      rgba(255,255,255,0.10) 30%,
      rgba(255,255,255,0.00) 55%),
    radial-gradient(1200px 780px at calc(var(--mx) + 4%) calc(var(--my) + 1%),
      rgba(0,129,250,0.22) 0%,
      rgba(0,255,234,0.16) 28%,
      rgba(0,129,250,0.10) 48%,
      rgba(0,0,0,0) 72%);
}

/* ---- Conteúdo por cima do halo/fundo ---- */
#contact-final .contact-final__inner{
  position: relative;
  z-index: 2;
  max-width: 1200px;
  margin: 0 auto;
  padding: clamp(32px,4vw,64px) clamp(16px,3vw,28px);
}

/* ---- Grid em colunas (form | imagem) ---- */
#contact-final .contact-final__grid{
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  align-items: center;
  gap: clamp(24px,3vw,48px);
}
#contact-final .contact-final__form{ 
    min-width: 0;
    background: linear-gradient(
    to bottom,
    rgba(0, 0, 0, 0.5) 0%,   /* mais escuro no topo */
    rgba(0, 0, 0, 0.1) 100%  /* mais claro na base */
  );
  padding: 0.15em 1.45em;               /* espaço compacto */
  border-radius: 6px;

}
#contact-final .contact-final__visual{ justify-self: center; }

/* ---- Form styles ---- */
#contact-final .contact-final__title{
  font-family: "Playfair Display", serif;
  font-weight: 900;
  font-size: clamp(28px,3.2vw,44px);
  margin: 0 0 .5rem;
  color: #eaf6ff;
}
#contact-final .contact-final__lead {
  display: inline-block;               /* só envolve o texto */
  color: #b2b287;
  margin: 0 0 1.25rem;
 
  line-height: 1.4;
}

#contact-final .cf-form{ display: grid; gap: 1rem; }
#contact-final .cf-row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}
#contact-final .cf-field{ display: grid; gap: .4rem; }
#contact-final .cf-field label{
  font-weight: 700;
  font-size: .95rem;
  color: #9ddff6;
  letter-spacing: .02em;
}
#contact-final .cf-field input,
#contact-final .cf-field textarea{
  appearance: none;
  width: 100%;
  padding: .9rem 1rem;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: #eaf6ff;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
#contact-final .cf-field textarea{ min-height: 180px; resize: vertical; }
#contact-final .cf-field input::placeholder,
#contact-final .cf-field textarea::placeholder{ color: #9fb1c6; }
#contact-final .cf-field input:focus,
#contact-final .cf-field textarea:focus{
  border-color: rgba(0,255,234,.45);
  box-shadow: 0 0 0 3px rgba(0,255,234,.22);
  background: rgba(255,255,255,.08);
}
#contact-final .btn-gradient{ margin-top: .25rem; font-size: .98rem; }

/* ---- Astronauta (tilt) sem sombras/placas ---- */
#contact-final .tilt-card{
  max-width: 420px;
  width: 100%;
  border-radius: 24px;
  transform-style: preserve-3d;
  overflow: visible;
  background: transparent !important;
  box-shadow: none !important;
}
#contact-final .tilt-img{
  display: block;
  width: 100%;
  height: auto;
  border-radius: 24px;
  backface-visibility: hidden;
  transform: translateZ(40px);
  box-shadow: none !important;
}
/* limpar “placas”/glare do VanillaTilt se existir */
#contact-final .contact-final__visual::before,
#contact-final .contact-final__visual::after,
#contact-final .tilt-card::before,
#contact-final .tilt-card::after{ content: none !important; }
#contact-final .tilt-card .js-tilt-glare{
  overflow: visible !important;
  border-radius: inherit !important;
  background: transparent !important;
  box-shadow: none !important;
}
#contact-final .tilt-card .js-tilt-glare-inner{
  background-image: linear-gradient(0deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 100%) !important;
  opacity: 0 !important;
}

/* ---- Responsivo ---- */
@media (max-width: 992px){
  #contact-final .contact-final__grid{ grid-template-columns: 1fr; }
  #contact-final .contact-final__visual{
    order: -1;
    margin-bottom: 16px;
  }
  #contact-final .cf-row{ grid-template-columns: 1fr; }
}

/* ---- Acessibilidade: reduzir movimento ---- */

/* =========== PORTFÓLIO – NAV CHIPS (harmonizado p/ fundo claro) =========== */

/* wrapper central e respiro */
.pf-nav-wrap{
  display:flex; justify-content:center;
  margin: 1rem 0 2rem;
}

/* a UL vira uma “barra” suave tipo glass */
.pf-chips{
  display:flex; gap:.35rem; padding:.4rem;
  border-radius: 999px;
  background: rgba(255,255,255,.65);
  box-shadow: 0 8px 24px rgba(31,46,80,.08), inset 0 1px rgba(255,255,255,.8);
  backdrop-filter: blur(6px);
}

/* cada chip – tipografia/espaçamento consistentes */
.pf-chip{
  appearance:none;
  border: 1px solid rgba(18,32,56,.09);
  background: rgba(18,32,56,.03);
  color:#1f2e50;
  padding: .65rem 1rem;
  border-radius: 999px;
  font: 700 .95rem/1 "Inter",system-ui;
  letter-spacing:.01em;
  display:inline-flex; align-items:center; gap:.55rem;
  transition: transform .12s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease, color .2s ease;
  outline:0;
}

/* pontinho indicador */
.pf-chip .pf-chip-dot{
  width:8px; height:8px; border-radius:50%;
  background: #00e6de; box-shadow: 0 0 8px rgba(0,230,222,.55);
  flex:0 0 8px;
}

/* contador pequeno, discreto */
.pf-chip .pf-chip-count{
  font-size:.8rem; font-weight:800;
  padding:.1rem .5rem;
  border-radius:999px;
  background: #e9eef5; color:#43506a;
}

/* hover com leve “lift” */
.pf-chip:hover{
  transform: translateY(-2px);
  border-color: rgba(0,190,200,.35);
  background: rgba(0,190,200,.10);
  box-shadow: 0 8px 22px rgba(0,190,200,.15);
  color:#163042;
}

/* estado ativo – pill com gradiente suave */
.pf-chip.active{
  border-color: #f5f7f7;
  color:#082a2a;
  background: linear-gradient(135deg,#b9faff 0%, #57d6e6 50%, #2fb4d7 100%);
  box-shadow:
    0 10px 26px rgba(47,180,215,.30),
    inset 0 1px 0 rgba(255,255,255,.65);
}

/* contador dentro do ativo fica claro (contraste) */
.pf-chip.active .pf-chip-count{
  background: rgba(255,255,255,.85);
  color:#0f2a33;
}

/* acessibilidade */
.pf-chip:focus-visible{
  box-shadow: 0 0 0 3px rgba(47,180,215,.35), 0 8px 22px rgba(47,180,215,.18);
  transform: translateY(0);
}

/* mobile – menos “puff” horizontal */
@media (max-width: 576px){
  .pf-chips{ gap:.25rem; padding:.3rem; }
  .pf-chip{ padding:.55rem .85rem; font-size:.92rem; }
  .pf-chip .pf-chip-count{ display:none; }
}


.about-corporate {
  background: #f8f9fa; /* fundo claro */
  color: #333;
  padding: clamp(40px, 5vw, 80px) 20px;
}

.about-corporate .section-title {
  font-family: "Playfair Display", serif;
  font-weight: 900;
  font-size: clamp(26px, 3vw, 40px);
  text-align: center;
  margin-bottom: 0.5em;
  color: #1d4e8b;
}

.about-corporate .section-lead {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 2em auto;
  font-size: 1.1rem;
  color: #555;
}

.about-corporate .about-content {
  max-width: 900px;
  margin: 0 auto;
  font-size: 1rem;
  line-height: 1.6;
}

.about-corporate ul {
  list-style: none;
  padding: 0;
  margin-top: 1.5em;
}

.about-corporate ul li {
  position: relative;
  padding-left: 28px;
  margin-bottom: 0.75em;
}

.about-corporate ul li::before {
  content: "✔";
  position: absolute;
  left: 0;
  top: 0;
  color: #1d4e8b;
  font-weight: bold;
}

.bg-dark-2{
    background-color: #122339;
    font-family: "Montserrat", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
}
.bg-dark-2 svg { width:100%; height:100vh; }

#aboutme .aboutme-content{ max-width: 760px; }

:root{
  --rc-size: 56px;
  --rc-accent: #00d46a;
  --rc-overlay-bg: #000;
  --cx: 50%;
  --cy: 50%;
}

/* ===== Widget ===== */
#rc-clock-widget{ z-index: 10040; }
#rc-clock-btn{
  min-height: var(--rc-size);
  border-radius: 99px 0 0 99px;
  backdrop-filter: blur(10px);
  box-shadow: 1px 6px 84px rgba(0,0,0,.42);
  transition: box-shadow .2s ease, transform .2s ease;
  position: relative; overflow: hidden; will-change: transform, box-shadow;
}
.rc-dot{ width:8px; height:8px; background:var(--rc-accent); border-radius:50%; box-shadow:0 0 12px rgba(0,212,106,.95); }
.rc-time{ font-variant-numeric: tabular-nums; letter-spacing:.02em; }
.rc-sep{ user-select:none; }

/* CTA glow rings */
#rc-clock-btn.rc-cta{ box-shadow: 0 0 0 6px rgba(0,212,106,.45), 0 30px 76px rgba(0,0,0,.55); }
#rc-clock-btn.rc-cta::before,
#rc-clock-btn.rc-cta::after{
  content:""; position:absolute; inset:-32%; border-radius:999px; pointer-events:none;
  background: radial-gradient(circle at 50% 50%, rgba(0,212,106,.45) 0%, transparent 42%);
  transform: scale(.52); opacity:0; mix-blend-mode: screen; animation: rc-ring-cta 1.1s ease-out infinite;
}
#rc-clock-btn.rc-cta::after{
  animation-delay:.28s;
  background: radial-gradient(circle at 50% 50%, rgba(0,212,106,.28) 0%, transparent 40%);
}
@keyframes rc-ring-cta{ 0%{transform:scale(.5);opacity:0} 22%{opacity:.5} 100%{transform:scale(1.2);opacity:0} }

/* Tremor do botão (versão herói) — ÚNICA definição */
@keyframes rc-shake-hero{
  0%,100%{ transform: translate3d(0,0,0) rotate(0) scale(1); }
  12% { transform: translateX(-11px) rotate(-1.8deg) scale(1.04); }
  24% { transform: translateX( 11px) rotate( 1.8deg) scale(1.04); }
  36% { transform: translate(-9px, 1px) rotate(-1.4deg) }
  48% { transform: translate( 9px,-1px) rotate( 1.4deg) }
  60% { transform: translate(-7px, 0) rotate(-1.1deg) }
  72% { transform: translate( 7px, 0) rotate( 1.1deg) }
  84% { transform: translate(-4px, 0) rotate(0) }
}
#rc-clock-btn.rc-shake-hero{ animation: rc-shake-hero .2s ease-in-out infinite; }

/* ===== CINEMATIC LENS DIRT ===== */
.rc-lens{
  position: fixed; inset:0; pointer-events:none; z-index: 99920;
  opacity: 0; animation: rc-lens-in .38s ease forwards;
}
@keyframes rc-lens-in{ to{ opacity: 1; } }

/* Vinheta + grão + scanlines discretas */
.rc-lens::before{
  content:""; position:absolute; inset:0; opacity:.23; mix-blend-mode: overlay;
  background:
    repeating-linear-gradient(to bottom, rgba(255,255,255,.038), rgba(255,255,255,.038) 1px, transparent 2px, transparent 4px),
    radial-gradient(ellipse at 50% 50%, rgba(0,0,0,.0) 38%, rgba(0,0,0,.42) 90%);
  animation: rc-grain 1.15s steps(2,end) infinite;
}
@keyframes rc-grain{ 50%{ filter: brightness(1.07) contrast(1.03); } }

/* Anamorphic streak */
.rc-lens::after{
  content:""; position:absolute; left:-20%; right:-20%; top:-12%; bottom:-12%;
  opacity:0; mix-blend-mode: screen; filter: blur(12px) saturate(1.15);
  background: linear-gradient(90deg, transparent 10%, rgba(255,255,255,.15) 50%, transparent 90%);
  transform: rotate(4deg) translateY(-12%) scaleX(1.6);
  animation: rc-streak 1.15s cubic-bezier(.16,.84,.43,.99) .1s forwards;
}
@keyframes rc-streak{
  0%{opacity:0;transform:rotate(4deg) translateY(-18%) scaleX(1.3)}
  40%{opacity:.7}
  100%{opacity:0;transform:rotate(4deg) translateY(10%) scaleX(2.1)}
}

/* Bokeh */
.rc-lens .blob{
  position:absolute; pointer-events:none;
  width: var(--s,200px); height: var(--s,200px);
  left: calc(var(--x,50%) - var(--s,200px)/2); top: calc(var(--y,50%) - var(--s,200px)/2);
  background:
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.55) 0%, rgba(255,255,255,.18) 35%, rgba(255,255,255,0) 60%),
    radial-gradient(circle at 60% 40%, rgba(0,212,106,.25), transparent 55%);
  filter: blur(2px) saturate(1.15);
  mix-blend-mode: screen; border-radius: 50%;
  transform: scale(.7); opacity:0;
  animation: rc-bokeh var(--d,1400ms) cubic-bezier(.16,.84,.43,.99) forwards;
}
@keyframes rc-bokeh{
  0%{ opacity:0; transform: scale(.7) translateY(-4px); }
  35%{ opacity:.95; }
  70%{ opacity:.9; transform: scale(1.06) translateY(0); }
  100%{ opacity:0; transform: scale(1.22) translateY(5px); }
}

/* Shockwave circular */
.rc-lens .shock{
  position:absolute; pointer-events:none;
  width: 22vmax; height: 22vmax;
  left: calc(var(--sx) - 11vmax); top: calc(var(--sy) - 11vmax);
  border: 2px solid rgba(255,255,255,.28);
  border-radius: 50%; filter: blur(.6px);
  transform: scale(.12); opacity: .92;
  animation: rc-shock 900ms cubic-bezier(.16,.84,.43,.99) forwards;
  box-shadow: 0 0 40px rgba(255,255,255,.2), inset 0 0 40px rgba(255,255,255,.12);
}
@keyframes rc-shock{ 100%{ transform: scale(4.8); opacity:0; } }

.rc-wow{
  position: fixed; inset: 0; z-index: 10060; pointer-events: none;
}
.rc-wow .wow-ring{
  position: absolute;
  left: var(--cx); top: var(--cy);
  width: 2px; height: 2px;
  border: 2px solid rgba(255,255,255,.55);
  border-radius: 50%;
  transform: translate(-50%,-50%) scale(1);
  opacity: .85;
  animation: rc-wow-ring 1.1s cubic-bezier(.16,.84,.43,.99) forwards;
}



@keyframes rc-wow-ring{
  60% { transform: translate(-50%,-50%) scale(110); opacity:.85; }
  100%{ transform: translate(-50%,-50%) scale(160); opacity:0; }
}



/* === Fallback só para elementos que ANIMAM A SI MESMOS === */
[data-anim]:not([data-anim-scope="find"]):not([data-anim-scope="children"]) {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .6s ease, transform .6s ease;
  will-change: opacity, transform;
}
[data-anim].is-visible:not([data-anim-scope="find"]):not([data-anim-scope="children"]) {
  opacity: 1;
  transform: none;
}

/* === NÃO esconder containers que são apenas “scope” === */
[data-anim][data-anim-scope="find"],
[data-anim][data-anim-scope="children"] {
  opacity: 1;           /* container sempre visível */
  transform: none;
}

/* Acessibilidade: reduzir movimento */
@media (prefers-reduced-motion: reduce) {
  [data-anim]:not([data-anim-scope="find"]):not([data-anim-scope="children"]) {
    transition: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

/* === Escopo children: anima só os filhos === */
[data-anim][data-anim-scope="children"]:not(.is-visible) > * {
  opacity: 0;
  transform: translateY(24px);
}
[data-anim][data-anim-scope="children"].is-visible > * {
  opacity: 1;
  transform: none;
  transition: transform .7s cubic-bezier(.22,.61,.36,1), opacity .7s cubic-bezier(.22,.61,.36,1);
}

/* === Escopo find: anima os elementos encontrados === */
[data-anim][data-anim-scope="find"]:not(.is-visible) .anim-item,
[data-anim][data-anim-scope="find"]:not(.is-visible) [data-anim-item]{
  opacity: 0;
  transform: translateY(24px);
}
[data-anim][data-anim-scope="find"].is-visible .anim-item,
[data-anim][data-anim-scope="find"].is-visible [data-anim-item]{
  opacity: 1;
  transform: none;
  transition: transform .7s cubic-bezier(.22,.61,.36,1), opacity .7s cubic-bezier(.22,.61,.36,1);
}



@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: none; }
}
@keyframes typing {
  from { width: 0; }
  to   { width: 100%; }
}
@keyframes blinkCaret {
  50% { border-color: transparent; }
}

/* ===========================
   RC CONTACT OVERLAY — FINAL
   =========================== */

/* Contêiner base */
.rc-overlay{
  position: fixed;
  inset: 0;
  z-index: 10050;            /* acima do site e do widget */
  pointer-events: none;       /* os filhos é que recebem clique */
}
.rc-overlay.d-none{ display: none !important; }

/* Estado de preparação (antes de abrir) */
.rc-overlay.rc-prep .rc-overlay-backdrop{
  opacity: 0;
  /* se o browser suportar clip-path, começamos “colado” ao botão (—cx/—cy) */
  clip-path: circle(0% at var(--cx, 50%) var(--cy, 50%));
}

/* Backdrop */
.rc-overlay-backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.85);
  opacity: 0;
  transition: opacity .55s ease;
  pointer-events: auto;       /* recebe os cliques para fechar */
}

/* Conteúdo */
.rc-overlay-content{
  position: relative;
  z-index: 1;
  height: 100dvh;             /* ocupa viewport */
  display: grid;
  place-items: center;
  opacity: 0;
  transform: translateY(10px) scale(.985);
  transition: opacity .5s ease, transform .5s ease;
  pointer-events: none;        /* evita clicar antes de abrir */
}

/* Abrir */
.rc-overlay.rc-open { pointer-events: auto; }
.rc-overlay.rc-open .rc-overlay-backdrop{
  opacity: 1;
}
.rc-overlay.rc-open .rc-overlay-content{
  opacity: 1;
  transform: none;
  pointer-events: auto;
  animation: rc-overlay-in .65s cubic-bezier(.16,.84,.43,.99) both;
}

/* Efeito “bolha” (se suportado) */
@supports (clip-path: circle(50% at 50% 50%)) {
  .rc-overlay-backdrop{
    clip-path: circle(0% at var(--cx, 50%) var(--cy, 50%));
    transition:
      opacity .55s ease,
      clip-path 1s cubic-bezier(.16,.84,.43,.99);
  }
  .rc-overlay.rc-open .rc-overlay-backdrop{
    /* grande o suficiente para cobrir o viewport todo a partir de —cx/—cy */
    clip-path: circle(180% at var(--cx, 50%) var(--cy, 50%));
  }
}

/* Animação de entrada do cartão/conteúdo (subtil) */
@keyframes rc-overlay-in{
  0%   { transform: translateY(-14px) scale(1.04); filter: blur(2px) saturate(1.15); opacity:.45; }
  55%  { transform: translateY(3px)  scale(.995);  filter: blur(.2px) saturate(1.02); opacity:1;   }
  100% { transform: none; filter:none; opacity:1; }
}

/* Cartão interno (opcional — podes ajustar o look) */
.rc-overlay-card{
  width: min(760px, 92vw);
  color: #fff;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    rgba(17,17,17,.55);
  backdrop-filter: blur(10px);
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  box-shadow:
    0 18px 60px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.08);
}

/* Botão fechar fica posicionado pelo teu HTML (Bootstrap) */
#rc-overlay-close { pointer-events: auto; }

/* Acessibilidade: reduzir movimento */
@media (prefers-reduced-motion: reduce){
  .rc-overlay-backdrop,
  .rc-overlay-content{
    transition: none !important;
    animation: none !important;
  }
  @supports (clip-path: circle(50% at 50% 50%)){
    .rc-overlay-backdrop{ clip-path: none !important; }
  }
}

/* Pequeno “shake” no WhatsApp quando abre (opcional) */
@keyframes rc-wa-shake {
  0%,100%{ transform:none }
  25%{ transform:translateX(-4px) }
  50%{ transform:translateX(4px) }
  75%{ transform:translateX(-2px) }
}
#rc-wa-btn.rc-wa-shake{ animation: rc-wa-shake .6s ease; }


/* ===== Overlay CTA — polimento visual ===== */
.rc-pill{
  display:inline-block;
  font: 700 .85rem/1 "Inter", system-ui;
  letter-spacing:.02em;
  padding:.4rem .7rem;
  border-radius:999px;
  color:#0b1b1b;
  background:linear-gradient(135deg,#1d4e8b 0%, #00ffea 60%, #1d4e8b 100%);
  box-shadow:0 8px 24px rgba(0,255,234,.18);
}

.rc-headline{
  font-family:"Playfair Display", serif;
  font-weight:900;
  font-size: clamp(28px, 3.2vw, 34px);
  line-height:1.25;
  margin: .35rem 0 .25rem;
  background: linear-gradient(90deg,#eaf6ff 0%, #9ddff6 60%, #eaf6ff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 1px 0 rgba(255,255,255,.08);
}

.rc-subtitle{
  color:#cfe3f1;
  font-size:1.05rem;
  margin: 0 0 1rem;
}

.rc-benefits{
  list-style:none;
  margin:0 0 1.25rem;
  padding:0;
  display:grid;
  gap:.55rem;
}
.rc-benefits li {
  color:#e9f1ff;
  display:flex;
  align-items:flex-start;
  gap:.6rem;
  padding:10px;
  border-bottom:1px solid #dadada; /* aplica apenas linha inferior */
}

/* apenas o primeiro item tem a linha de cima */
.rc-benefits li:first-child {
  border-top:1px solid #dadada;
}
.rc-benefits i{
  color:#00ffea;
  margin-top:.15rem;
}

/* CTA group */
.rc-cta-group{
  display:flex; flex-wrap:wrap; gap:.8rem;
  align-items:center; justify-content:center;
  margin: .5rem 0 1rem;
}
/* ghost button a condizer com o tema */
.btn-ghost{
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  color:#eaf6ff;
  border-radius:10px;
  transition: transform .15s ease, box-shadow .25s ease, background .25s ease;
}
.btn-ghost:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.14);
  box-shadow:0 10px 26px rgba(0,0,0,.35);
}

/* Badges de confiança */
.rc-badges{
  display:flex; flex-wrap:wrap; gap:.5rem .6rem;
  justify-content:center;
  margin-top:.2rem;
}
.rc-badge{
  display:inline-flex; align-items:center; gap:.4rem;
  font: 700 .82rem/1 "Inter", system-ui;
  padding:.45rem .6rem;
  color:#9ddff6;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
}
.rc-badge i{ opacity:.9; }

/* ajuste do cartão para “glass” elegante */
.rc-overlay-card{
  backdrop-filter: blur(12px);
  background:
    linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03)),
    rgba(17,17,17,.55) !important;
  border:1px solid rgba(255,255,255,.14);
  box-shadow: 0 18px 60px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
  border-radius: 16px;
}

/* Mobile: empilha botões com conforto */
@media (max-width: 480px){
  .rc-cta-group{ flex-direction:column; }
  .rc-badges{ gap:.4rem; }
}
/* ===== Camera shake (aplicado nos filhos do body) ===== */
@keyframes rc-cam-body {
  0%,100% { transform: translate3d(0,0,0) rotate(0); }
  10%     { transform: translate3d(-8px,-2px,0) rotate(-0.35deg); }
  20%     { transform: translate3d( 7px, 1px,0) rotate( 0.30deg); }
  30%     { transform: translate3d(-6px, 3px,0) rotate(-0.28deg); }
  40%     { transform: translate3d( 5px,-2px,0) rotate( 0.22deg); }
  50%     { transform: translate3d(-4px, 0px,0) rotate(-0.20deg); }
  60%     { transform: translate3d( 3px, 2px,0) rotate( 0.18deg); }
  70%     { transform: translate3d(-2px,-1px,0) rotate(-0.12deg); }
  80%     { transform: translate3d( 2px, 1px,0) rotate( 0.10deg); }
  90%     { transform: translate3d(-1px, 0px,0) rotate( 0.00deg); }
}

/* 1) Tremer também se a classe cair no <body> (fallback do JS) */
#rc-cam-wrap.rc-cam,
body.rc-cam {
  animation: rc-cam-body 0.35s linear infinite;
  transform-origin: 50% 50%;
  will-change: transform;
}

/* 2) Se o utilizador tiver "reduzir movimento", desliga os DOIS (layout e botão),
      a não ser que forces com <html class="rc-force-shake"> para testes */
@media (prefers-reduced-motion: reduce) {
  html:not(.rc-force-shake) #rc-cam-wrap.rc-cam,
  html:not(.rc-force-shake) body.rc-cam,
  html:not(.rc-force-shake) #rc-clock-btn.rc-shake-hero {
    animation: none !important;
  }
}

/* Torna o card o “containing block” do X */
.rc-overlay-card { position: relative; }

/* Botão X dentro do card, grande e com alto contraste */
.rc-card-close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  width: 44px;
  height: 44px;
  border-radius: 9999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.12);
  color: #fff;
  cursor: pointer;
  backdrop-filter: blur(6px);
  box-shadow: 0 6px 18px rgba(0,0,0,.25);
  transition: transform .12s ease, background-color .12s ease, box-shadow .12s ease, border-color .12s ease;
}

.rc-card-close i { font-size: 1.25rem; line-height: 1; }

.rc-card-close:hover { 
  background: rgba(255,255,255,.2);
  transform: scale(1.05);
  box-shadow: 0 10px 22px rgba(0,0,0,.28);
  border-color: rgba(255,255,255,.55);
}

.rc-card-close:active { transform: scale(.98); }

.rc-card-close:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 3px rgba(255,255,255,.4), 0 8px 24px rgba(0,0,0,.35);
}
  /* ====== ESTILO LOCAL (move para custom.css se preferires) ====== */

  /* Fundo branco global da secção */
  #kb2-article { background:#fff!important; position:relative; overflow:hidden; }

  /* Container com largura confortável */
  #kb2-article .kb-wrap { margin:0 auto; padding:0px 20px 72px; }
  
  #kb2-article ul, ol{padding-left: 26px;}

  /* Breadcrumb compacto em linha (deixa de “partir” linhas) */
  .kb-breadcrumb { font-size:14px; color:#6b7280; margin-bottom:18px; white-space:nowrap; overflow:auto; }
  .kb-breadcrumb a { color:#6b7280; text-decoration:none; }
  .kb-breadcrumb a:hover { text-decoration:underline; }

  /* Cabeçalho do artigo em grid: título à esquerda, meta + excerpt à direita */
  .kb-head { display:block; grid-template-columns: minmax(300px, 1fr) minmax(280px, 420px); gap:36px; align-items:start; }

  /* Título com clamp (evita ficar “gigante” em ecrãs largos) */
  .kb-title {
    font-family: "Playfair Display", serif;
    line-height: .95;
    margin:0 0 10px;
    letter-spacing:-.8px;
    font-weight:700;
    font-size: clamp(32px, 6vw, 64px); /* ← ajusta aqui se quiseres maior/menor */
    color:#0f172a;
  }

  /* Meta + chips */
  .kb-meta { display:flex; align-items:center; gap:14px; flex-wrap:wrap; color:#6b7280; font-size:14px; }
  .kb-chip { background:#f1f5f9; border-radius:999px; padding:6px 12px; font-weight:600; display:inline-flex; align-items:center; gap:8px; }
  .kb-chip-dot { width:8px; height:8px; background:#10b981; border-radius:50%; display:inline-block; }

  /* Excerpt ao lado do título para leitura rápida */
  .kb-excerpt { margin-top:8px; color:#6b7280; font-size:18px; line-height:1.6; }

  /* Imagem de capa full width abaixo do header */
  .kb-cover { margin:28px 0 36px; }
  .kb-cover img { width:100%; height:auto; border-radius:14px; display:block; }

  /* Corpo do artigo */
  .kb-body { font-size:18px; line-height:1.8; color:#111827; }
  .kb-body h2, .kb-body h3 { color:#0f172a; margin-top:1.6em; font-weight:700; }
  .kb-body p { margin:1em 0; }
  .kb-body img { max-width:100%; height:auto; border-radius:10px; }

  /* CTA final */
  .kb-cta { margin-top:36px; display:flex; gap:14px; flex-wrap:wrap; }

  /* Canto animado sem fundo (apenas traço) – discreto e fora do fluxo */
  .corner-anim { position:absolute; right:-60px; bottom:-60px; width:300px; height:300px; pointer-events:none; opacity:.65; }
  .corner-anim path {
    fill:none; stroke:url(#cornerStroke); stroke-width:2.5; stroke-linecap:round; stroke-linejoin:round;
    stroke-dasharray:900; stroke-dashoffset:900;
    animation:drawCorner 1.8s ease-out .3s forwards, floatCorner 7s ease-in-out 2.2s infinite;
    filter:drop-shadow(0 2px 6px rgba(0,0,0,.08));
  }
  @keyframes drawCorner { to { stroke-dashoffset:0; } }
  @keyframes floatCorner {
    0%{ transform:translate(0,0); opacity:.65; }
    50%{ transform:translate(-4px,-3px); opacity:.85; }
    100%{ transform:translate(0,0); opacity:.65; }
  }

  /* Responsivo: empilha tudo cedo para evitar “saltos” e textos a colidir */
  @media (max-width: 920px) {
    .kb-head { grid-template-columns: 1fr; gap:18px; }
    .kb-excerpt { font-size:16px; }
    .corner-anim { display:none; } /* remove o adorno em ecrãs pequenos */
  }
  
  .kb-close-home{
      position: fixed;
      top: calc(22px + env(safe-area-inset-top, 0px));
      right: calc(22px + env(safe-area-inset-right, 0px));
      z-index: 1100; /* acima do conteúdo */
      width: 56px; height: 56px; border-radius: 999px;
      display: inline-flex; align-items: center; justify-content: center;
      background: rgba(255,255,255,.92);
      color: #111; border: 1px solid rgba(0,0,0,.08);
      box-shadow: 0 6px 24px rgba(0,0,0,.16), inset 0 1px 0 rgba(255,255,255,.8);
      backdrop-filter: blur(6px);
      text-decoration: none;
      transition: transform .18s ease, box-shadow .18s ease, opacity .18s ease;
    }
    .kb-close-home i{ font-size: 26px; line-height: 1; }
    .kb-close-home:hover{ transform: translateY(-1px) scale(1.03); box-shadow: 0 10px 30px rgba(0,0,0,.18); color: #ff0000; }
    .kb-close-home:active{ transform: translateY(0) scale(.98); }
    .kb-close-home:focus-visible{
      outline: 0;
      box-shadow: 0 0 0 4px rgba(0,128,255,.35), 0 6px 24px rgba(0,0,0,.18);
    }
    @media (max-width: 576px){
      .kb-close-home{ width: 48px; height: 48px; }
      .kb-close-home i{ font-size: 22px; }
    }

.rc-shake-hero {
  animation-iteration-count: 1; 
}
.modal-backdrop { z-index: 1070; }
.modal          { z-index: 1080; }
/* se tiveres overlays próprios muito altos, baixa-os */
.effect-layer, .cf-bg-mover { z-index: 1030; }

.modal-body {color: #222!important;}

/* ---------- Vars locais ---------- */
:root{
  --kb-tri-h: clamp(56px, 7vw, 96px);  /* altura do triângulo */
  --kb-block-bg: #F0EEEB;              /* cinza do bloco */
}

/* não cortar o ::before */
#kb2-article .kb-wrap{ overflow: visible; }

/* ---------- Header cinza ---------- */
#kb2-article .kb-head.kb-head--tri{
  position: relative;
  isolation: isolate;
  background: var(--kb-block-bg);
  color: inherit;                      /* usa as cores padrão do tema */
  border-radius: 14px 14px 0 0;

  /* 40 nos lados e em cima, 20 em baixo */
  padding-inline: clamp(20px, 3vw, 40px);
  padding-top:   clamp(20px, 3vw, 40px);
  padding-bottom: 20px;
}

/* manter o conteúdo acima do triângulo */
#kb2-article .kb-head.kb-head--tri > *{
  position: relative;
  z-index: 1;
}

/* ---------- Triângulo ---------- */
#kb2-article .kb-head.kb-head--tri::before{
  content: "";
  position: absolute;
  left: 0; right: 0;
  height: var(--kb-tri-h);
  /* sobe 2px para eliminar a “linha branca” */
  bottom: calc(-1 * var(--kb-tri-h) + 2px);
  background: var(--kb-block-bg);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
  pointer-events: none;
}

/* empurra o artigo para baixo do triângulo
   (compensa os 2px que subimos) */
#kb2-article .kb-body{
  margin-top: calc((var(--kb-tri-h) - 2px) + 1.25rem);
}

/* (opcional) cores “escuras” para texto/chips dentro do header */
#kb2-article .kb-head--tri .kb-title{ color:#0f172a; }
#kb2-article .kb-head--tri .kb-meta,
#kb2-article .kb-head--tri .kb-excerpt{ color:#334155; }
#kb2-article .kb-head--tri .kb-chip{
  background:#ececec; color:#0f172a; border:1px solid rgba(0,0,0,.06);
}
#kb2-article .kb-head--tri .kb-chip-dot{ background:#10b981; box-shadow:none; }


/*MOBILE */

/* ---------- Toggle Grade/Leitura ---------- */
.pf-view-toggle{ display:flex; gap:.4rem; margin-left:auto; }
.pf-view-btn{
  appearance:none; border:1px solid rgba(0,0,0,.1); background:#fff;
  padding:.55rem .9rem; border-radius:999px; font:700 .95rem/1 "Inter",system-ui;
  letter-spacing:.01em; cursor:pointer; transition:.2s box-shadow,.2s transform,.2s background;
}
.pf-view-btn.is-active{ background:linear-gradient(135deg,#b9faff 0%,#57d6e6 50%,#2fb4d7 100%); border-color:transparent; }
.pf-view-btn:hover{ transform:translateY(-1px); box-shadow:0 8px 18px rgba(47,180,215,.2); }

/* ---------- Select de filtro para mobile ---------- */
.pf-select{ display:none; margin-left:auto; padding:.6rem .8rem; border-radius:10px; border:1px solid rgba(0,0,0,.12); background:#fff; font-weight:600; }
@media (max-width:576px){
  .pf-nav-wrap .pf-chips{ display:none; }
  .pf-select{ display:block; }
}

/* ===================================================
   MODO LEITURA (escopado ao #portfolio)
   =================================================== */
#portfolio.pf-view-read .row.g-4{ display:block; }
#portfolio.pf-view-read .project-item{
  width:100% !important; max-width:100% !important; padding-left:0 !important; padding-right:0 !important;
  margin-bottom:12px;
}
#portfolio.pf-view-read .pf-card{
  background:#fff; border:1px solid #e8e8e8; border-radius:12px;
  box-shadow:none; transform:none !important;
}
#portfolio.pf-view-read .pf-header{
  display:flex; align-items:center; justify-content:space-between; gap:.75rem;
  cursor:pointer; position:relative; padding-right:8px;
}
#portfolio.pf-view-read .pf-title{ margin:.1rem 0; font-size:1.08rem; color:#1b1f2b; }
#portfolio.pf-view-read .pf-desc{ display:none; font-size:.98rem; color:#2c2c2c; }
#portfolio.pf-view-read .pf-thumb{ display:none; }            /* colapsado por defeito */
#portfolio.pf-view-read .pf-body{ padding:12px 14px; }

/* seta de estado */
#portfolio.pf-view-read .pf-header::after{
  content:""; flex:0 0 auto; width:10px; height:10px;
  border-right:2px solid #666; border-bottom:2px solid #666;
  transform:rotate(-45deg); transition:transform .2s ease;
}
#portfolio.pf-view-read .pf-card[aria-expanded="true"] .pf-header::after{ transform:rotate(45deg); }

/* expandido */
#portfolio.pf-view-read .pf-card[aria-expanded="true"] .pf-thumb{ display:block; margin:.35rem 0 .25rem; }
#portfolio.pf-view-read .pf-card[aria-expanded="true"] .pf-desc{ display:block; }

/* botões dentro do cartão em modo leitura */
#portfolio.pf-view-read .btn-mask.btn-small{ height:32px; padding:0 12px; border-radius:8px; }

/* acessibilidade/focus */
#portfolio.pf-view-read .pf-header:focus-visible{
  outline:0; box-shadow:0 0 0 3px rgba(47,180,215,.35); border-radius:8px;
}

/* reduz animações se o utilizador pediu menos movimento */
@media (prefers-reduced-motion:reduce){
  #portfolio.pf-view-read .pf-header::after{ transition:none; }
}

/* utilidade: esconder visualmente texto (para o label do select) */
.visually-hidden{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

:root{
  --rc-burger-size: 48px;
  --rc-burger-z: 10070;
  --rc-mnav-z: 10090;
  --rc-mnav-width: min(86vw, 360px);

  /* cores/realces */
  --rc-surface: rgba(15,16,22,.82);         /* vidro escuro */
  --rc-outline: rgba(255,255,255,.14);      /* contorno */
  --rc-ink: rgba(255,255,255,.92);          /* ícone/texto */
  --rc-accent-1: #22d1ee;                   /* ciano */
  --rc-accent-2: #27ef9f;                   /* verde */
}

/* ---------- Burger (glass + alto contraste) ---------- */
.rc-burger{
  position: fixed;
  top: calc(16px + env(safe-area-inset-top, 0px));
  right: calc(16px + env(safe-area-inset-right, 0px));
  z-index: var(--rc-burger-z);
  width: var(--rc-burger-size);
  height: var(--rc-burger-size);
  border-radius: 16px;
  border: 1px solid var(--rc-outline);
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)),
    var(--rc-surface);
  -webkit-backdrop-filter: blur(12px) saturate(1.1);
          backdrop-filter: blur(12px) saturate(1.1);
  color: var(--rc-ink);
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow:
    0 10px 30px rgba(0,0,0,.35),          /* sombra externa */
    inset 0 1px rgba(255,255,255,.10);    /* brilho interno */
  transition: transform .15s ease, box-shadow .25s ease, background .25s ease, border-color .25s ease;
}
.rc-burger:hover{ transform: translateY(-1px); box-shadow: 0 16px 40px rgba(0,0,0,.45); }
.rc-burger:focus-visible{ outline: 0; box-shadow: 0 0 0 3px rgba(34,209,238,.35), 0 16px 40px rgba(0,0,0,.45); }

/* Ícone (3 linhas do SVG) */
.rc-burger__icon{
  width: 22px; height: 22px;
  stroke: currentColor; stroke-width: 2.4; fill: none;
  vector-effect: non-scaling-stroke;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,.35)); /* contraste extra */
}
.rc-burger__icon path{
  stroke-linecap: round; stroke-linejoin: round;
  transform-origin: 12px 12px;
  transition: transform .28s cubic-bezier(.2,.9,.2,1), opacity .2s ease;
}

/* Estado aberto: gradiente + X harmonioso */
#rc-burger[aria-expanded="true"]{
  background: linear-gradient(135deg, var(--rc-accent-1), var(--rc-accent-2));
  border-color: transparent;
  color: #0b1b1b;             /* ícone escuro sobre gradiente claro */
}
#rc-burger[aria-expanded="true"] .rc-burger__icon path:nth-child(1){ transform: translateY(5px)  rotate(45deg); }
#rc-burger[aria-expanded="true"] .rc-burger__icon path:nth-child(2){ transform: scaleX(0); opacity: 0; }
#rc-burger[aria-expanded="true"] .rc-burger__icon path:nth-child(3){ transform: translateY(-5px) rotate(-45deg); }

/* Esconde em desktop */
@media (min-width: 992px){
  .rc-burger{ display: none; }
}

/* Respeita “reduzir movimento” */
@media (prefers-reduced-motion: reduce){
  .rc-burger__icon path{ transition: none !important; }
}


/* -------- Off-canvas nav -------- */
.rc-mnav{ position: fixed; inset: 0; z-index: var(--rc-mnav-z); pointer-events: none; }
.rc-mnav.is-open{ pointer-events: auto; }

.rc-mnav-backdrop{
  position: absolute; inset: 0; background: rgba(0,0,0,.72);
  opacity: 0; transition: opacity .28s ease;
}
.rc-mnav.is-open .rc-mnav-backdrop{ opacity: 1; }

.rc-mnav-panel{
  position: absolute; top: 0; right: 0; height: 100%; width: var(--rc-mnav-width);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02)), rgba(17,17,17,.85);
  backdrop-filter: blur(10px);
  border-left: 1px solid rgba(255,255,255,.12);
  box-shadow: -20px 0 50px rgba(0,0,0,.45);
  transform: translateX(100%);
  transition: transform .32s cubic-bezier(.2,.9,.2,1);
}
.rc-mnav.is-open .rc-mnav-panel{ transform: translateX(0); }

/* Close */
.rc-mnav-close{
  position: absolute; top: 12px; right: 12px;
  width: 44px; height: 44px; border-radius: 999px;
  border: 1px solid rgba(255,255,255,.2);
  background: rgba(255,255,255,.1); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  transition: transform .12s ease, background .2s ease;
}
.rc-mnav-close:hover{ transform: scale(1.05); background: rgba(255,255,255,.18); }
.rc-mnav-close:focus-visible{ outline: 0; box-shadow: 0 0 0 3px rgba(0,255,234,.35); }

/* Lista */
.rc-mnav-list{
  list-style: none; margin: 0; padding: 84px 18px 18px;
  display: grid; gap: 6px;
}
.rc-mnav-link{
  display: block;
  padding: 14px 14px;
  font: 700 1.05rem/1.2 "Inter",system-ui;
  letter-spacing: .01em;
  color: #eaf6ff; text-decoration: none; border-radius: 10px;
  border: 1px solid transparent;
  transition: transform .12s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.rc-mnav-link:hover{ transform: translateX(-2px); background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.16); }
.rc-mnav-link.is-active{
  color: #0b1b1b;
  background: linear-gradient(135deg, #1d4e8b 0%, #00ffea 60%, #1d4e8b 100%);
  border-color: transparent;
}

/* Quando o menu está aberto, bloqueia scroll (reusa a tua classe) */
html.rc-locked{ overflow-y: hidden; }

/* Respeita “reduzir movimento” */
@media (prefers-reduced-motion: reduce){
  .rc-mnav-backdrop, .rc-mnav-panel, .rc-burger__bar{ transition: none !important; }
}


/* =========================================================
   ABOUTME — ajustes só para mobile (não mexe em desktop)
   ========================================================= */
@media (max-width: 992px){
  
    .full-bleed{
    left: 50%;
    width: calc(100vw - var(--sbw-px, 0px));
    margin-left: calc(-50vw + var(--sbw-px, 0px)/2);
    margin-right: calc(-50vw + var(--sbw-px, 0px)/2);
  }
  /* hero mais alto no telefone e centrado */
  #aboutme{
    min-height: 90dvh;
    background-position: center;
  }

  /* 1 coluna: social → conteúdo → contactos */
 

  /* corrige o inline do H1 (nowrap/overflow/font-size) só no mobile */
  #about-title{
    white-space: normal !important;
    overflow: visible !important;
    font-size: clamp(28px, 8vw, 42px) !important;
    line-height: 1.05;
    letter-spacing: -.02em;
    text-wrap: balance;
    margin: .1rem 0 .4rem;
  }

  /* cartão “glass” para legibilidade do texto sobre a foto */
  .aboutme-content{
    grid-area: content;
    
    max-width: 680px;
    margin-inline: auto;
  }
  .aboutme-content h3{
    font-size: clamp(14px, 3.8vw, 18px);
    color: #cfe9ff;
    margin: .2rem 0 .6rem;
  }
  .aboutme-content p{
    font-size: clamp(13.5px, 3.6vw, 16px);
    line-height: 1.55;
    color: #eaf6ff;
    margin: 0 0 .9rem;
  }
  .aboutme-content .btn-gradient{
    width: 100%;
    justify-content: center;
    padding: .9rem 1rem;
    border-radius: 12px;
  }

  /* social compacto, centrado */
  .aboutme-social{ grid-area: social; display:flex; justify-content:center; }
  .aboutme-social .social-list{ gap: .6rem; }
  .aboutme-social .social-item a{
    width: 36px; height: 36px;
    background: rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.12);
  }

  /* contactos em cartões empilhados, fáceis de tocar */
  .aboutme-info{
    grid-area: info;
    flex-direction: column;
    align-items: stretch;
    gap: .75rem;
    margin-top: .25rem;
  }
  .aboutme-info .info-link{
    display: flex; align-items: center; gap: .75rem;
    padding: .75rem .9rem;
    border-radius: 12px;
    background: rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.12);
  }
  .aboutme-info .info-text h4{ font-size: 1rem; }
  .aboutme-info .info-text span{ font-size: .96rem; color: #e8e8e8; }
}

@media (max-width: 991.98px){
  .aboutme-content p{
    font-size: 1rem;          /* ~16px confortável */
    line-height: 1.55;
    margin-bottom: 1rem;
    text-wrap: balance;        /* quebras mais bonitas */
    max-width: 60ch;           /* evita linhas longas */
    margin-inline: auto;       /* centra se tiver text-align:center */
  }
  .aboutme-content .btn-gradient{
    width: 100%;
    justify-content: center;
    border-radius: 12px;
  }
}
/* Mobile/Tablet: mantém lado a lado sempre que couberem */
@media (max-width: 991.98px){
  #aboutme .aboutme-info,
  #aboutme.aboutme-hero .aboutme-info{
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: .75rem 1rem;
    align-items: stretch;
  }

  /* cartão clicável ocupa a largura toda da célula */
  #aboutme .aboutme-info .info-link{
    display: flex;
    align-items: center;
    gap: .65rem;
    width: 100%;
    padding: .8rem .95rem;
    border-radius: 12px;
    background: rgba(0,0,0,.35);
    border: 1px solid rgba(255,255,255,.12);
    text-decoration: none;
  }

  #aboutme .aboutme-info i{ flex: 0 0 auto; font-size: 1.35rem; }
  #aboutme .aboutme-info .info-text{ line-height: 1.2; }
}

@media (max-width: 991.98px){
  .pf-hidden-mobile{ display:none !important; }
  #rc-clock-widget{ display:none !important; }
}
/* Esconde cards extra em mobile */
@media (max-width: 991.98px){
  .pf-hidden-mobile{ display:none !important; }
}

/* Botão flutuante (esquerda) */
#pf-fab{
  position: fixed;
  right: -0.75rem;                 /* encostado à esquerda */
  bottom: 50%;                 /* junto ao polegar */
  z-index: 1035;                /* acima do conteúdo */
  transform: translateX(-140%); /* fora do ecrã por defeito */
  opacity: 0;
  transition: transform .28s cubic-bezier(.2,.9,.2,1), opacity .2s ease;
  pointer-events: none;       
  border-radius: 16px 0 0 16px;
}
#pf-fab.pf-fab--visible{
  transform: translateX(0);
  opacity: 1;
  pointer-events: auto;
}

/* desktop nunca mostra */
@media (min-width: 992px){
  #pf-fab{ display:none !important; }
}
/* =========================
   ABOUT-CORPORATE — POLIMENTO
   ========================= */
#about-corporate{ background:#f8f9fa; color:#333; }
#about-corporate .container { max-width:1200px; margin:0 auto; padding:0 20px; }
#about-corporate .ac-title{
  font-family:"Playfair Display",serif; font-weight:900;
  letter-spacing:-.02em; color:#1d2230;
  font-size:clamp(28px,3.6vw,44px); margin:0 0 .35rem;
}
#about-corporate .ac-lead{
  color:#666; max-width:52ch; margin:0 0 1.25rem;
}

/* Layout 2 colunas equilibrado (desktop) */
#about-corporate .ac-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,440px);
  gap:clamp(24px,4vw,56px);
  align-items:start;
}

/* Lista com check harmonizado */
#about-corporate .ac-list{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; }
#about-corporate .ac-list li{ display:flex; align-items:flex-start; gap:.55rem; }
#about-corporate .ac-list i{ color:#1bbd8a; margin-top:.2rem; } /* verde consistente */
#about-corporate .ac-more{ margin-top:.4rem; }

/* Cards de serviço (direita) */
#about-corporate .ac-cards{
  display:grid; grid-template-columns:repeat(2, minmax(0,1fr)); gap:12px;
}
#about-corporate .ac-card{
  background:#fff; border:1px solid rgba(0,0,0,.06);
  border-radius:12px; padding:18px 16px; text-align:center;
  box-shadow:0 8px 22px rgba(0,0,0,.06);
}
#about-corporate .ac-card i{ display:block; font-size:1.25rem; margin-bottom:.35rem; color:#1d4e8b; }
#about-corporate .ac-card strong{ font-weight:700; color:#1b1f2b; }

/* Stack/tech chips */
#about-corporate .ac-stack{
  display:flex; gap:.5rem; overflow-x:auto; padding-bottom:.25rem;
  -webkit-overflow-scrolling:touch; scroll-snap-type:x proximity;
}
#about-corporate .ac-stack .badge{
  background:#f0f3f7; color:#415069; border:1px solid rgba(0,0,0,.06);
  scroll-snap-align:start;
}

/* CTA alinhada e mais suave */
#about-corporate .ac-cta .btn{ border-radius:12px; padding:.8rem 1.25rem; }

/* Responsivo */
@media (max-width: 991.98px){
  #about-corporate .ac-grid{ grid-template-columns:1fr; }
  #about-corporate .ac-cta{ text-align:center; }
}
@media (max-width: 575.98px){
  #about-corporate .ac-cards{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}


/* CTA attention */
.cta-lead {
  position: relative;

  will-change: transform, box-shadow;
  animation: cta-pulse 2.2s ease-in-out infinite;
  border-radius: 999px; /* pílula */
}

/* brilho que “varre” o botão */
.cta-lead::after {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,.35) 50%, transparent 100%);
  transform: translateX(-120%);
  animation: cta-shine 4.5s ease-in-out infinite;
  border-radius: inherit;
  pointer-events: none;
  mix-blend-mode: screen;
}

/* badge/linha de confiança */
.cta-trust { opacity: .8; font-size: .9rem; }

/* nudge discreto a cada ~12s (aplicado via JS) */
.cta-lead.cta-nudge {
  animation: cta-nudge .6s ease, cta-pulse 2.2s ease-in-out infinite 0.6s;
}

@keyframes cta-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(37,211,102,.28), 0 10px 20px rgba(0,0,0,.12); }
  50% { box-shadow: 0 0 0 10px rgba(37,211,102,0), 0 12px 26px rgba(0,0,0,.16); }
}
@keyframes cta-shine { 
  0%, 80% { transform: translateX(-120%); } 
  100% { transform: translateX(120%); } 
}
@keyframes cta-nudge {
  0% { transform: translateY(0) scale(1); }
  35% { transform: translateY(-2px) scale(1.02); }
  70% { transform: translateY(1px) scale(0.998); }
  100% { transform: translateY(0) scale(1); }
}

/* respeita utilizadores com motion reduzido */
@media (prefers-reduced-motion: reduce) {
  .cta-lead, .cta-lead::after { animation: none !important; }
}



/* sombra única e consistente */
.btn-gradient {
  position: relative;
  border: 0;
  border-radius: 9px 9px 9px 0 ;
  box-shadow: 0 10px 24px rgba(0,0,0,.28);
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease;

  overflow: hidden;                  /* garante que nada “sangra” para fora */
}

/* hover/press elegantes (opcional) */
.btn-gradient:hover { 
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,.32);
}
.btn-gradient:active {
  transform: translateY(0);
  box-shadow: 0 8px 18px rgba(0,0,0,.25);
}

/* animação “nudge” breve depois de 8s (se usares a classe .cta-nudge) */
.cta-nudge { animation: cta-nudge .8s ease; }
@keyframes cta-nudge { 
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-3px); }
}
.availability-note{
  display:flex; align-items:center; gap:.5rem;
  font-size:.98rem; line-height:1.4;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.15);
  color:#e9f0ff; padding:.6rem .9rem; border-radius:12px;
  backdrop-filter: blur(4px);
  box-shadow: 0 0 0 rgba(0,200,255,.0);
  animation: collabPulse 2.6s ease-in-out infinite;
}
.availability-note i{font-size:1rem; opacity:.9;}
.availability-note .sep{opacity:.5; margin:0 .25rem;}
@keyframes collabPulse{
  0%,100%{ box-shadow: 0 0 0 rgba(0,200,255,0); }
  50%    { box-shadow: 0 0 24px rgba(0,200,255,.15); }
}
/* === ABOUTME — FIX DE TIPOGRAFIA + CONTRASTE (SÓ APLICA AQUI) === */
#aboutme{ position:relative; background-position: right center !important; }
#aboutme::before{
  content:""; position:absolute; inset:0; z-index:0;
  /* overlay para legibilidade do texto sobre a foto */
  background: linear-gradient(90deg,
    rgba(13,16,23,.90) 0%,
    rgba(13,16,23,.70) 38%,
    rgba(13,16,23,.28) 60%,
    rgba(13,16,23,0)   78%);
}
#aboutme .aboutme-container{ position:relative; z-index:1; }

/* mata leaks de estilos globais (uppercase, gradientes, etc.) */
#aboutme h1, #aboutme h2, #aboutme h3{ text-transform:none !important; background:none !important; }

/* Título estável (sem nowrap/overflow) */
#aboutme #about-title{
  font-size: clamp(34px, 4.2vw, 64px);
  line-height: 1.05;
  letter-spacing: -.02em;
  max-width: clamp(22ch, 50vw, 36ch); /* em vez de 16ch */
  white-space: normal;
  overflow: visible;
  text-wrap: balance;
}


/* Subtítulo + copy */
#aboutme .aboutme-content h3{
  font-size: clamp(15px, 1.4vw, 20px);
  color:#cfe9ff;
  margin:.2rem 0 .8rem;
}
#aboutme .aboutme-content p{ color:#fff; }

/* Disponibilidade (mantém o teu look) */
#aboutme .availability-note{
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.15);
  color:#e9f0ff; border-radius:12px;
}

/* Social/Info continuam como tens — sem mudanças visuais */

/* Ajuste de posicionamento da foto em ecrãs largos */
@media (min-width:1200px){
  #aboutme{ background-position: 72% center !important; }
}

/* Mobile: garante legibilidade/escala */
@media (max-width: 991.98px){
  #aboutme{ min-height: 90dvh; }
  #aboutme #about-title{ font-size: clamp(28px, 7vw, 42px); max-width: 20ch; }
}
.avail-hero{
  display:flex; align-items:center; gap:.6rem;
  color:#eaf6ff; font-weight:600;
  font-size: clamp(.98rem, 2vw, 1.15rem);
  margin:.35rem 0 1rem; text-wrap: balance;
}
.avail-hero i{ color:#00ffea; opacity:.9; }

.avail-hero .hl{
  position:relative; font-weight:800; color:#fff;
}
.avail-hero .hl::after{
  content:""; position:absolute; inset:auto -.2em .08em -.2em;
  height:.55em; z-index:-1; border-radius:.35em;
  background: linear-gradient(135deg,#1d4e8b, #00ffea 60%, #1d4e8b);
  opacity:.28; /* ↑ aumenta p/ mais “pop” (ex.: .4) */
}

/* opcional: versão mais discreta no mobile */
@media (max-width:576px){
  .avail-hero{ font-size:1rem; }
  .avail-hero .hl::after{ opacity:.22; }
}
.avail-hero{
  display:flex; align-items:center; gap:.6rem;
  color:#eaf6ff; font-weight:600;
  font-size: clamp(.98rem, 2vw, 1.15rem);
  margin:.35rem 0 1rem; text-wrap: balance;
}
.avail-hero i{ color:#00ffea; opacity:.9; }

/* highlight multi-linha */
.hl{
  --ink: rgba(0,255,234,.28); /* força do “marcador” */
  background: linear-gradient(to top, var(--ink) .58em, transparent 0);
  color: inherit;
  padding: 0 .12em;            /* respiro lateral */
  border-radius: .25em;
  -webkit-box-decoration-break: clone;
          box-decoration-break: clone; /* <<< faz o efeito em cada linha */
  hyphens: none;
}
.nowrap{ white-space: nowrap; }            /* evita partir termos chave */

/* opcional: mais discreto no mobile */
@media (max-width:576px){
  .hl{ --ink: rgba(0,255,234,.22); }
}
/* --- Social + email pill (não sobrepõe o H1) --- */
.aboutme-social{
  display:flex; align-items:center; flex-wrap:wrap;
  gap:.6rem .8rem; margin-bottom:.5rem;
}
.aboutme-social .social-list{ display:flex; gap:.6rem; margin:0; padding:0; list-style:none; }

/* email fora dos ícones redondos */
.email-pill{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.45rem .75rem;
  border-radius:999px;
  background: rgba(0,0,0,.45);
  border:1px solid rgba(255,255,255,.18);
  color:#fff; text-decoration:none; font-weight:700;
  line-height:1; backdrop-filter: blur(6px);
  max-width: 100%; /* nunca “vaza” para cima do H1 */
}
.email-pill i{ font-size:1rem; opacity:.9; }
.email-pill span{
  display:inline-block; max-width: 52vw;
  overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.email-pill:hover{ transform: translateY(-1px); transition:.2s; }

/* mobile: cabe sempre */
@media (max-width: 768px){
  .aboutme-social{ justify-content:center; }
  .email-pill span{ max-width: 66vw; }
}

/* lede com 2 linhas fortes (desktop) */
.about-lede strong{ font-weight:900; }

/* (segurança) se alguém voltar a pôr o email dentro do .social-item, não o arredonda */
.social-item a[href^="mailto"]{ width:auto; height:auto; border-radius:12px; padding:.4rem .6rem; }
/* Pulse visível: lift + leve scale + halo + shimmer do gradiente */
.btn-gradient.cta-pulse {
  animation: rcBtnPulse 2.8s ease-in-out infinite;
}

/* Animação do ícone do WhatsApp (ligeiro pop) */
.btn-gradient.cta-pulse i {
  animation: rcIconPop 2.8s ease-in-out infinite;
  animation-delay: .1s; /* desfase subtil face ao botão */
}

/* Pausa quando o utilizador interage */
.btn-gradient.cta-pulse:hover,
.btn-gradient.cta-pulse:focus,
.btn-gradient.cta-pulse:hover i,
.btn-gradient.cta-pulse:focus i {
  animation-play-state: paused;
}

/* Respeita “reduzir movimento” */
@media (prefers-reduced-motion: reduce) {
  .btn-gradient.cta-pulse,
  .btn-gradient.cta-pulse i { animation: none !important; }
}

@keyframes rcBtnPulse {
  0% {
    transform: translateY(0) scale(1);
    box-shadow:
      0 10px 24px rgba(0,0,0,.28),
      0 0 0 0 rgba(0,255,234,0);
    filter: none;
    /* precisares disto: .btn-gradient já tem background-size:200% 100% */
    background-position: 0% 0%;
  }
  40% {
    transform: translateY(-2px) scale(1.04);              /* mais notório */
    box-shadow:
      0 16px 36px rgba(0,0,0,.36),                        /* sombra mais funda */
      0 0 0 14px rgba(0,255,234,.22);                     /* halo visível */
    filter: brightness(1.06) saturate(1.04);              /* realça o gradiente */
    background-position: 22% 0%;                          /* shimmer suave */
  }
  100% {
    transform: translateY(0) scale(1);
    box-shadow:
      0 10px 24px rgba(0,0,0,.28),
      0 0 0 0 rgba(0,255,234,0);
    filter: none;
    background-position: 0% 0%;
  }
}

@keyframes rcIconPop {
  0%, 100% { transform: none; }
  40%      { transform: translateY(-1px) scale(1.12); }    /* pequeno “pop” */
}
#wa-cta { animation: rcBtnPulse 2.8s ease-in-out infinite; }
/* --- Pulse contínuo (não usa transform para não conflitar) --- */
.cta-pulse {
  animation: rc-pulse 1.8s ease-in-out infinite;
  will-change: box-shadow;
}
@keyframes rc-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(37,211,102,.55); }
  50%      { box-shadow: 0 0 0 12px rgba(37,211,102,0); }
}

/* --- Nudge curto (somado ao pulse) --- */
.cta-pulse.cta-nudge {
  animation: rc-nudge 600ms cubic-bezier(.2,.9,.2,1) 1,
             rc-pulse 1.8s ease-in-out 600ms infinite; /* volta ao pulse após o nudge */
}
@keyframes rc-nudge {
  0%,100% { transform: translateY(0); }
  30%     { transform: translateY(-2px); }
  60%     { transform: translateY(0); }
  80%     { transform: translateY(-1px); }
}

/* Respeita reduzir movimento do SO */
@media (prefers-reduced-motion: reduce) {
  .cta-pulse, .cta-pulse.cta-nudge { animation: none !important; }
}
/* PULSE para o #wa-cta */


/* Keyframes */
@keyframes waPulseRing {
  0%   { transform: scale(.9);  opacity: .85; }
  70%  { transform: scale(1.4); opacity: 0;   }
  100% { transform: scale(1.45);opacity: 0;   }
}
@keyframes waPulseShadow {
  0%,100% { box-shadow: 0 0 0 0 rgba(37,211,102,.45); }
  50%     { box-shadow: 0 0 0 14px rgba(37,211,102,0); }
}

#wa-cta-m{max-width: 250px;}
/* Acessibilidade: respeitar “reduzir movimento” */
@media (prefers-reduced-motion: reduce) {
  #wa-cta.cta-pulse,
  #wa-cta.cta-pulse::before,
  #wa-cta.cta-pulse::after {
    animation: none !important;
  }
}
#parcerias .parc-eyebrow { font-size: .9rem; text-transform: uppercase; letter-spacing: .04em; }
#parcerias .parc-chip { font-weight: 600; }
#parcerias .partner-logo {
  opacity: .85; filter: grayscale(100%); transition: filter .2s ease, opacity .2s ease, transform .2s ease;
}
#parcerias .partner-logo:hover { filter: none; opacity: 1; transform: translateY(-2px); }

#parcerias .benefit-card i { font-size: 1.15rem; opacity: .85; }
#parcerias .testimonial { background: #fff; border-radius: .75rem; }
#parcerias .case-card .display-6 { font-size: clamp(1.6rem, 3vw, 2.4rem); }

/* ============================
   ABOUT — MOBILE (<= 992px)
   Só o essencial para funcionar
   ============================ */
@media (max-width: 991.98px) {

  /* Secção + overlay p/ legibilidade */
  #aboutme{
    position: relative;
    min-height: 90dvh;
    background: #0d1017 center/cover no-repeat; /* ajusta no HTML se usares imagem */
    color: #fff;
    overflow: hidden;
  }
  #aboutme::before{
    content: "";
    position: absolute; inset: 0; z-index: 0;
    background: linear-gradient(90deg,
      rgba(13,16,23,.92) 0%,
      rgba(13,16,23,.75) 38%,
      rgba(13,16,23,.28) 60%,
      rgba(13,16,23,0)   80%);
  }

  /* Grid 1 coluna: social → conteúdo → contactos */
  #aboutme .aboutme-container{
    position: relative; z-index: 1;
    display: grid;
    grid-template-columns: 1fr;
    grid-template-areas:
      "social"
      "content"
      "info";
    gap: 1rem;
    padding: clamp(24px,4vw,40px) 16px 32px;
    align-items: start;
    text-align: center;
  }

  /* Título estável (sem nowrap/overflow) */
  #about-title{
    font-weight: 900;
    font-size: clamp(28px, 7vw, 42px);
    line-height: 1.05;
    letter-spacing: -.02em;
    margin: .1rem 0 .4rem;
    white-space: normal;
    overflow: visible;
    text-wrap: balance;
  }

  /* Conteúdo (subtítulo + texto + CTA) */
  .aboutme-content{ grid-area: content; max-width: 680px; margin-inline: auto; }
  .aboutme-content h3{
    font-weight: 600;
    font-size: clamp(14px, 3.8vw, 18px);
    color: #cfe9ff;
    margin: .2rem 0 .6rem;
  }
  .aboutme-content p{
    font-size: clamp(13.5px, 3.6vw, 16px);
    line-height: 1.55;
    color: #fff;
    margin: 0 0 .9rem;
  }
  .aboutme-content .btn-gradient{
    display: inline-flex;
    justify-content: center;
    align-items: center;
    gap: .5rem;
    width: 100%;
    padding: .9rem 1rem;
    border: 0;
    border-radius: 12px;
    font-weight: 700;
    color: #0b1b1b;
    text-decoration: none;
    background: linear-gradient(135deg,#1d4e8b 0%, #00ffea 50%, #1d4e8b 100%);
  }

  /* Barra de disponibilidade (opcional) */
  .avail-hero{
    display: flex; justify-content: center; align-items: center; gap: .6rem;
    font-weight: 600; font-size: clamp(.98rem, 2vw, 1.15rem);
    color: #eaf6ff; margin: .35rem 0 1rem;
  }
  .hl{
    --ink: rgba(0,255,234,.22);
    background: linear-gradient(to top, var(--ink) .58em, transparent 0);
    padding: 0 .12em; border-radius: .25em;
    -webkit-box-decoration-break: clone; box-decoration-break: clone;
  }

  /* Social + email pill */
  .aboutme-social{ grid-area: social; display: flex; justify-content: center; align-items: center; gap: .6rem .8rem; flex-wrap: wrap; }
  .aboutme-social .social-list{ display: flex; gap: .6rem; list-style: none; margin: 0; padding: 0; }
  .aboutme-social .social-item a{
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; border-radius: 50%;
    background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.12);
    color: #fff; text-decoration: none;
  }
  .email-pill{
    display: inline-flex; align-items: center; gap: .45rem;
    padding: .45rem .75rem; border-radius: 999px;
    background: rgba(0,0,0,.45); border: 1px solid rgba(255,255,255,.18);
    color: #fff; font-weight: 700; text-decoration: none; line-height: 1;
    max-width: 100%;
  }
  .email-pill span{ max-width: 66vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

  /* Contactos em cartões “tap-friendly” */
  .aboutme-info{
    grid-area: info;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: .75rem 1rem; align-items: stretch;
  }
  .aboutme-info .info-link{
    display: flex; align-items: center; gap: .65rem;
    width: 100%; padding: .8rem .95rem;
    border-radius: 12px;
    background: rgba(0,0,0,.35); border: 1px solid rgba(255,255,255,.12);
    color: #e8e8e8; text-decoration: none;
  }
  .aboutme-info i{ flex: 0 0 auto; font-size: 1.35rem; color: #00ffea; }
  .aboutme-info .info-text h4{ margin: 0; font-size: 1rem; color: #00ffea; }
  .aboutme-info .info-text span{ display: block; margin-top: .15rem; font-size: .96rem; color: #e8e8e8; }

  /* Se existir bloco de imagem no HTML, esconde no mobile */
  .aboutme-img{ display: none !important; }
}
