/* UZZA — premium + leve (no frameworks) */

/* ------------------ Reset (lightweight) ------------------ */
*,*::before,*::after{box-sizing:border-box}
html:focus-within{scroll-behavior:smooth}
body{margin:0;min-height:100vh;line-height:1.5}
img,svg{display:block;max-width:100%}
input,button,textarea,select{font:inherit}
a{color:inherit}
:root{
  --bg:#0B1020;
  --bg2:#0F172A;
  --text:#EAF0FF;
  --muted:#A9B4D0;
  --card:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.10);
  --shadow: 0 18px 60px rgba(0,0,0,.35);
  --radius:18px;

  --accent1:#2DD4BF; /* teal */
  --accent2:#6366F1; /* indigo */
  --accent3:#A855F7; /* purple */

  --container: 1120px;
}

/* Light theme */
html[data-theme="light"]{
  --topbar-bg: rgba(247,249,255,.92);
  --bg:#F7F8FF;
  --bg2:#FFFFFF;
  --text:#0B1020;
  --muted:#41506B;
  --card:rgba(11,16,32,.05);
  --border:rgba(11,16,32,.10);
  --shadow: 0 18px 50px rgba(11,16,32,.12);
}

body{
  background:
    radial-gradient(900px 420px at 10% 10%, rgba(99,102,241,.18), transparent 55%),
    radial-gradient(700px 380px at 85% 25%, rgba(168,85,247,.14), transparent 60%),
    radial-gradient(700px 420px at 25% 90%, rgba(45,212,191,.14), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial;
}

.skip-link{
  position:absolute;left:-999px;top:10px;
  background:var(--bg2);color:var(--text);
  padding:10px 14px;border-radius:12px;border:1px solid var(--border);
  z-index:1000
}
.skip-link:focus{left:12px}

.container{width:min(var(--container), calc(100% - 40px));margin-inline:auto}

/* ------------------ Topbar / Nav ------------------ */
.topbar{
  position:sticky; top:0; z-index:50;
  background: var(--topbar-bg);
  border-bottom:1px solid var(--border);
  backdrop-filter: blur(12px);
}
.topbar__inner{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 0;
}
.brand{display:flex;flex-direction:column;gap:2px;text-decoration:none}
.brand__mark{
  letter-spacing:.14em;
  font-weight:800;
  font-size:18px;
  line-height:1;
}
.brand__tag{
  font-size:12px;color:var(--muted);
  letter-spacing:.08em;
  text-transform:uppercase;
}

.nav{display:flex;align-items:center;gap:10px}
.nav__toggle{
  display:none;
  width:42px;height:42px;border-radius:14px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
}
.nav__toggleLines{
  display:block;width:18px;height:2px;background:currentColor;margin:0 auto;
  position:relative;border-radius:2px
}
.nav__toggleLines::before,.nav__toggleLines::after{
  content:"";position:absolute;left:0;right:0;height:2px;background:currentColor;border-radius:2px
}
.nav__toggleLines::before{top:-6px}
.nav__toggleLines::after{top:6px}

.nav__list{
  list-style:none;margin:0;padding:0;
  display:flex;align-items:center;gap:10px;
}
.nav__link{
  text-decoration:none;
  padding:10px 12px;border-radius:12px;
  color:var(--muted);
  border:1px solid transparent;
  transition: transform .15s ease, background .15s ease, border-color .15s ease, color .15s ease;
  font-size:14px;
}
.nav__link:hover{background:var(--card);border-color:var(--border);color:var(--text);transform:translateY(-1px)}
.nav__link.is-active{background:var(--card);border-color:var(--border);color:var(--text)}
.nav__link--cta{
  background:linear-gradient(90deg, rgba(45,212,191,.20), rgba(99,102,241,.20), rgba(168,85,247,.20));
  color:var(--text);
  border-color:color-mix(in oklab, var(--accent2) 35%, var(--border));
}
.theme{
  width:42px;height:42px;border-radius:14px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--text);
  display:grid;place-items:center;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease;
}
.theme:hover{transform:translateY(-1px);background:color-mix(in oklab, var(--card) 70%, transparent)}
.theme__icon{
  width:18px;height:18px;
  background: currentColor;
  mask: var(--icon-moon) center/contain no-repeat;
  -webkit-mask: var(--icon-moon) center/contain no-repeat;
}
html[data-theme="light"] .theme__icon{
  mask: var(--icon-sun) center/contain no-repeat;
  -webkit-mask: var(--icon-sun) center/contain no-repeat;
}

/* ------------------ Hero ------------------ */
.hero{padding:54px 0 26px}
.hero__grid{display:grid;grid-template-columns: 1.2fr .9fr;align-items:center;gap:30px}
.pill{
  display:inline-flex;gap:10px;align-items:center;
  padding:8px 12px;border:1px solid var(--border);
  background:var(--card);
  border-radius:999px;
  color:var(--muted);
  font-size:13px;
  margin:0 0 14px;
}
h1{
  margin:0 0 12px;
  font-size: clamp(34px, 4vw, 54px);
  line-height:1.05;
  letter-spacing:-.02em;
}
.lead{margin:0 0 18px;color:var(--muted);font-size: clamp(16px, 1.2vw, 18px)}
.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 22px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:14px;
  border:1px solid var(--border);
  text-decoration:none;
  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
  user-select:none;
}
.btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(0,0,0,.18)}
.btn--primary{
  color:var(--text);
  border-color: color-mix(in oklab, var(--accent2) 40%, var(--border));
  background: linear-gradient(90deg, color-mix(in oklab, var(--accent1) 45%, transparent), color-mix(in oklab, var(--accent2) 45%, transparent), color-mix(in oklab, var(--accent3) 45%, transparent));
}
.btn--ghost{background:var(--card);color:var(--text)}
.btn--full{width:100%}
.btn__spinner{
  width:16px;height:16px;border-radius:999px;
  border:2px solid color-mix(in oklab, var(--text) 45%, transparent);
  border-top-color: var(--text);
  display:none;
  animation: spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.trust{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:12px;
}
.trust__item{
  padding:14px;border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
}
.trust__kpi{display:block;font-weight:800;font-size:22px;letter-spacing:-.02em}
.trust__label{display:block;color:var(--muted);font-size:12px;margin-top:2px}

.hero__visual{position:relative;min-height:340px}
.glass{
  position:relative;
  border-radius:24px;border:1px solid var(--border);
  background: color-mix(in oklab, var(--card) 70%, transparent);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.glass__top{
  display:flex;gap:8px;align-items:center;
  padding:12px 14px;border-bottom:1px solid var(--border);
  background: color-mix(in oklab, var(--bg2) 55%, transparent);
}
.dot{width:10px;height:10px;border-radius:999px;background:var(--muted);opacity:.8}
.dot--r{background:#F87171}
.dot--y{background:#FBBF24}
.dot--g{background:#34D399}
.glass__body{padding:16px 16px 18px}
.code__line{
  height:10px;border-radius:999px;margin:10px 0;
  background: linear-gradient(90deg, color-mix(in oklab, var(--accent2) 40%, var(--card)), color-mix(in oklab, var(--accent3) 40%, var(--card)));
  opacity:.9
}
.code__gap{height:10px}
.w90{width:90%}.w85{width:85%}.w80{width:80%}.w70{width:70%}.w60{width:60%}.w50{width:50%}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.chip{
  font-size:12px;color:var(--muted);
  padding:8px 10px;border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--card) 70%, transparent);
}

.orb{
  position:absolute;filter:blur(0px);
  width:180px;height:180px;border-radius:999px;
  background: radial-gradient(circle at 30% 30%, rgba(45,212,191,.42), transparent 58%),
              radial-gradient(circle at 60% 60%, rgba(99,102,241,.42), transparent 60%),
              radial-gradient(circle at 50% 50%, rgba(168,85,247,.35), transparent 62%);
  opacity:.9;
  pointer-events:none;
}
.orb--a{right:-34px;top:-34px}
.orb--b{left:-42px;bottom:-40px;opacity:.7}
.orb--c{right:30px;bottom:-58px;opacity:.55;width:220px;height:220px}

/* ------------------ Sections ------------------ */
.section{padding:56px 0}
.section--alt{
  background: linear-gradient(180deg, transparent, color-mix(in oklab, var(--bg2) 42%, transparent), transparent);
}
.section__head{max-width:780px;margin-bottom:22px}
.section__head h2{
  margin:0 0 8px;font-size:30px;letter-spacing:-.02em
}
.section__head p{margin:0;color:var(--muted)}

.grid{display:grid;gap:14px}
.grid--3{grid-template-columns: repeat(3, minmax(0, 1fr))}
.grid--2{grid-template-columns: repeat(2, minmax(0, 1fr))}

.card{
  padding:18px;border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
  box-shadow: 0 10px 30px rgba(0,0,0,.10);
}
.card h3{margin:0 0 8px;font-size:17px}
.card p{margin:0;color:var(--muted)}

.note{
  margin-top:14px;
  padding:14px 16px;border-radius:16px;
  border:1px dashed var(--border);
  color:var(--muted);
  background: color-mix(in oklab, var(--card) 60%, transparent);
}

/* Steps */
.steps{
  list-style:none;margin:0;padding:0;
  display:grid;gap:12px;
}
.step{
  display:flex;gap:12px;align-items:flex-start;
  padding:16px;border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
}
.step__n{
  width:34px;height:34px;border-radius:12px;
  display:grid;place-items:center;
  background: linear-gradient(90deg, rgba(45,212,191,.26), rgba(99,102,241,.22), rgba(168,85,247,.20));
  border:1px solid color-mix(in oklab, var(--accent2) 30%, var(--border));
  font-weight:800;
}
.step h3{margin:0 0 4px;font-size:16px}
.step p{margin:0;color:var(--muted)}

/* Portfolio */
.proj{
  display:grid;grid-template-columns: 220px 1fr;gap:14px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
  overflow:hidden;
}
.proj__thumb{
  position:relative;
  overflow:hidden;
  padding:14px;
  min-height:160px;
  border-right:1px solid var(--border);
  background-color: var(--bg2);
}
.thumbBadge{
  position:absolute;
  left:14px;
  top:14px;
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  border:1px solid var(--border);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(10px);
}
.thumbTitle{
  position:absolute;
  left:14px;
  bottom:14px;
  right:14px;
  font-weight:800;
  letter-spacing:.2px;
  font-size:16px;
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}
.proj__body{padding:16px}
.proj__body h3{margin:0 0 6px}
.proj__body p{margin:0 0 10px;color:var(--muted)}
.proj__tags{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 10px}
.tag{
  font-size:12px;color:var(--muted);
  padding:6px 10px;border-radius:999px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--card) 70%, transparent);
}
.link{display:inline-flex;align-items:center;gap:8px;text-decoration:none;color:var(--text)}
.link:hover{text-decoration:underline}

.proj--soon .proj__thumb{opacity:.9}
.soon{
  display:inline-flex;margin-top:6px;
  color:var(--muted);font-size:12px
}

.ctaCard{
  padding:20px;border-radius:var(--radius);
  border:1px solid color-mix(in oklab, var(--accent2) 30%, var(--border));
  background:
    radial-gradient(260px 180px at 10% 20%, rgba(45,212,191,.20), transparent 60%),
    radial-gradient(260px 180px at 90% 10%, rgba(168,85,247,.16), transparent 55%),
    color-mix(in oklab, var(--bg2) 60%, transparent);
  display:flex;flex-direction:column;gap:10px;justify-content:center;
}
.ctaCard h3{margin:0}
.ctaCard p{margin:0;color:var(--muted)}

/* Split */
.split{display:grid;grid-template-columns: 1.2fr .8fr;gap:14px}
.split__card{padding:20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--card)}
.split__card--accent{
  border-color: color-mix(in oklab, var(--accent2) 35%, var(--border));
  background:
    radial-gradient(260px 180px at 20% 30%, rgba(99,102,241,.20), transparent 60%),
    radial-gradient(260px 180px at 80% 20%, rgba(45,212,191,.18), transparent 60%),
    color-mix(in oklab, var(--card) 70%, transparent);
}
.list{margin:12px 0 0;padding-left:18px;color:var(--muted)}
.list li{margin:8px 0}

/* About */
.about{display:grid;grid-template-columns: 1.1fr .9fr;gap:14px}
.about__card{padding:20px;border-radius:var(--radius);border:1px solid var(--border);background:var(--card)}
.about__card--stats{display:grid;gap:10px}
.miniStat{
  padding:14px;border-radius:16px;border:1px solid var(--border);
  background: color-mix(in oklab, var(--card) 65%, transparent);
  display:grid;grid-template-columns: 28px 1fr;column-gap:10px;row-gap:1px;
}
.miniStat__n{grid-row:span 3;display:grid;place-items:center}
.miniStat__t{font-weight:800}
.miniStat__d{color:var(--muted);font-size:13px}

/* FAQ */
.faq{display:grid;gap:10px}
.faq__item{
  border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
  padding:14px 16px;
}
.faq__item summary{cursor:pointer;font-weight:700}
.faq__item p{margin:10px 0 0;color:var(--muted)}

/* Contact */
.contact{display:grid;grid-template-columns: .9fr 1.1fr;gap:14px}
.contact__card{
  padding:20px;border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
}
.contact__actions{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}
.small{color:var(--muted);font-size:13px}
.badge{
  display:inline-flex;padding:3px 8px;border-radius:999px;border:1px solid var(--border);
  background: color-mix(in oklab, var(--card) 70%, transparent);
}

.form{
  padding:20px;border-radius:var(--radius);
  border:1px solid var(--border);
  background:var(--card);
}
.form label{display:grid;gap:6px;font-weight:700;font-size:13px}
.form input,.form textarea,.form select{
  padding:12px 12px;border-radius:14px;
  border:1px solid var(--border);
  background: color-mix(in oklab, var(--bg2) 70%, transparent);
  color:var(--text);
  outline:none;
}
html[data-theme="light"] .form input,
html[data-theme="light"] .form textarea,
html[data-theme="light"] .form select{
  background: color-mix(in oklab, var(--bg2) 90%, transparent);
}
.form input:focus,.form textarea:focus,.form select:focus{
  border-color: color-mix(in oklab, var(--accent2) 45%, var(--border));
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--accent2) 18%, transparent);
}
.form__row{display:grid;grid-template-columns: 1fr 1fr;gap:12px;margin-bottom:12px}
.form__status{margin:12px 0 0;color:var(--muted)}
.honeypot{display:none !important}

/* Footer */
.footer{padding:26px 0;border-top:1px solid var(--border);background:color-mix(in oklab, var(--bg2) 50%, transparent)}
.footer__inner{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;flex-wrap:wrap}
.footer__links{display:flex;gap:12px;flex-wrap:wrap}
.footer__links a{text-decoration:none;color:var(--muted)}
.footer__links a:hover{color:var(--text);text-decoration:underline}
.brand--footer .brand__mark{font-size:16px}

/* WhatsApp button */
.wa{
  position:fixed; right:18px; bottom:18px; z-index:60;
  width:56px; height:56px; border-radius:18px;
  background: linear-gradient(180deg, #25D366, #1FAF57);
  border:1px solid rgba(255,255,255,.18);
  display:grid; place-items:center;
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  text-decoration:none;
}
.wa:hover{ transform: translateY(-1px); }
.wa:active{ transform: translateY(1px); }

.wa:hover{transform:translateY(-1px)}
.wa__icon{
  width:24px; height:24px;
  background:#ffffff;
  mask: var(--icon-wa) center/contain no-repeat;
  -webkit-mask: var(--icon-wa) center/contain no-repeat;
}
.wa__tip{
  position:absolute;right:64px;bottom:8px;
  background:var(--bg2);color:var(--text);
  border:1px solid var(--border);
  padding:8px 10px;border-radius:14px;
  font-size:13px;white-space:nowrap;
  opacity:0;transform:translateX(6px);
  transition: opacity .15s ease, transform .15s ease;
  pointer-events:none;
}
.wa:hover .wa__tip{opacity:1;transform:translateX(0)}

/* Reveal */
.reveal{opacity:0;transform:translateY(12px);transition: opacity .6s ease, transform .6s ease}
.reveal.is-in{opacity:1;transform:none}

/* ------------------ Responsive ------------------ */
@media (max-width: 980px){
  .hero__grid{grid-template-columns: 1fr;gap:18px}
  .hero__visual{min-height:280px}
  .grid--3{grid-template-columns: 1fr 1fr}
  .split{grid-template-columns:1fr}
  .about{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .proj{grid-template-columns: 1fr}
  .proj__thumb{border-right:none;border-bottom:1px solid var(--border)}
}

@media (max-width: 760px){
  .nav__toggle{display:inline-grid;place-items:center}
  .nav__list{
    position:fixed;left:20px;right:20px;top:72px;
    background:var(--bg2);
    border:1px solid var(--border);
    border-radius:18px;
    padding:12px;
    display:none;
    box-shadow: var(--shadow);
    flex-direction:column;align-items:stretch;
  }
  .nav__list.is-open{display:flex}
  .nav__link{justify-content:center}
  .grid--3{grid-template-columns: 1fr}
  .grid--2{grid-template-columns: 1fr}
  .form__row{grid-template-columns: 1fr}
  .trust{grid-template-columns: 1fr}
}

/* ------------------ Icon masks (inline svg via CSS variables) ------------------ */
:root{
  --icon-moon: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M21 14.5A8.5 8.5 0 0 1 9.5 3a7.5 7.5 0 1 0 11.5 11.5Z'/%3E%3C/svg%3E");
  --icon-sun: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 18a6 6 0 1 0 0-12 6 6 0 0 0 0 12Zm0-16h1v3h-1V2Zm0 19h1v3h-1v-3ZM2 12h3v1H2v-1Zm19 0h3v1h-3v-1ZM4.2 4.2l2.1 2.1-.7.7-2.1-2.1.7-.7Zm14.1 14.1 2.1 2.1-.7.7-2.1-2.1.7-.7ZM19.8 4.2l.7.7-2.1 2.1-.7-.7 2.1-2.1ZM5.2 18.3l.7.7-2.1 2.1-.7-.7 2.1-2.1Z'/%3E%3C/svg%3E");
  --icon-wa: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%2024%2024%27%3E%3Cpath%20d%3D%27M20.52%203.48A11.93%2011.93%200%200%200%2012%200C5.37%200%20.01%205.37%200%2012c0%202.11.55%204.17%201.59%206L0%2024l6.2-1.63A11.92%2011.92%200%200%200%2012%2024c6.63%200%2012-5.37%2012-12%200-3.2-1.25-6.2-3.48-8.52zM12%2021.82c-1.88%200-3.72-.5-5.33-1.44l-.38-.22-3.68.97.98-3.59-.25-.37A9.86%209.86%200%200%201%202.18%2012C2.18%206.57%206.57%202.18%2012%202.18c2.63%200%205.11%201.02%206.97%202.88A9.8%209.8%200%200%201%2021.82%2012c0%205.43-4.39%209.82-9.82%209.82zm5.6-7.36c-.3-.15-1.77-.87-2.04-.97-.27-.1-.47-.15-.67.15-.2.3-.77.97-.94%201.17-.17.2-.35.22-.65.07-.3-.15-1.26-.46-2.4-1.48-.89-.79-1.49-1.77-1.66-2.07-.17-.3-.02-.46.13-.61.13-.13.3-.35.45-.52.15-.17.2-.3.3-.5.1-.2.05-.37-.02-.52-.07-.15-.67-1.61-.92-2.2-.24-.58-.48-.5-.67-.5h-.57c-.2%200-.52.07-.79.37-.27.3-1.04%201.02-1.04%202.49%200%201.47%201.07%202.89%201.22%203.09.15.2%202.11%203.22%205.11%204.51.71.31%201.27.49%201.71.63.72.23%201.37.2%201.88.12.57-.08%201.77-.72%202.02-1.42.25-.7.25-1.3.17-1.42-.08-.12-.27-.2-.57-.35z%27/%3E%3C/svg%3E");
}


/* ================== Chamativo / Premium Motion Pack ================== */

/* Use the screenshot thumbs in portfolio */
.proj__thumb{
  /* background em camadas (compatível) */
  background-color: var(--bg2);
  background-image:
    linear-gradient(180deg, rgba(0,0,0,.25), rgba(0,0,0,.70)),
    var(--thumb, none);
  background-position: center, center;
  background-size: cover, cover;
  background-repeat: no-repeat, no-repeat;
}
.proj__thumb::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(420px 260px at 30% 25%, rgba(99,102,241,.14), transparent 62%),
    radial-gradient(420px 260px at 70% 30%, rgba(168,85,247,.10), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.38));
  opacity:.35;
  z-index: 1;
  pointer-events:none;
}
.thumbBadge,.thumbTitle{
  position:absolute;
  left:14px;
  bottom:14px;
  right:14px;
  font-weight:800;
  letter-spacing:.2px;
  font-size:16px;
  line-height:1.15;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* Sticky header shrink */
.topbar.is-scrolled{box-shadow: 0 10px 40px rgba(0,0,0,.18);}
.topbar.is-scrolled .topbar__inner{padding:10px 0}

/* Cursor glow */
.cursorGlow{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  background: radial-gradient(260px 260px at var(--cx, 50%) var(--cy, 40%), rgba(99,102,241,.22), transparent 60%),
              radial-gradient(220px 220px at calc(var(--cx, 50%) + 10%) calc(var(--cy, 40%) + 10%), rgba(168,85,247,.16), transparent 60%),
              radial-gradient(220px 220px at calc(var(--cx, 50%) - 10%) calc(var(--cy, 40%) + 18%), rgba(45,212,191,.14), transparent 60%);
  mix-blend-mode: screen;
  opacity:.9;
}
html[data-theme="light"] .cursorGlow{mix-blend-mode: multiply;opacity:.55;}
@media (prefers-reduced-motion: reduce){.cursorGlow{display:none}}

/* Stagger reveal */
.stagger.is-in > *{animation: popIn .65s ease both;}
@keyframes popIn{from{opacity:0;transform: translateY(14px) scale(.985)}to{opacity:1;transform:none}}

/* Chamativo: gradient shift + floating orbs + hover lift */
@media (prefers-reduced-motion: no-preference){
  .btn--primary{background-size:200% 200%;animation: gradientShift 6s ease infinite;}
  @keyframes gradientShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
  .orb{animation: floaty 7.5s ease-in-out infinite;}
  .orb--b{animation-duration: 9.5s;}
  .orb--c{animation-duration: 11s;}
  @keyframes floaty{0%,100%{transform: translate3d(0,0,0) scale(1)}50%{transform: translate3d(0,-10px,0) scale(1.03)}}
  .card:hover,.proj:hover,.split__card:hover,.about__card:hover,.faq__item:hover{
    transform: translateY(-3px);
    transition: transform .18s ease, box-shadow .18s ease;
    box-shadow: 0 20px 60px rgba(0,0,0,.22);
  }
}

/* Portfolio actions */
.proj__actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.linkBtn{border:none;background:none;padding:0;color:var(--text);cursor:pointer}
.linkBtn:hover{text-decoration:underline}

/* Modal */
.modal{position:fixed;inset:0;z-index:80;display:none}
.modal.is-open{display:block}
.modal__backdrop{position:absolute;inset:0;background: rgba(0,0,0,.65);backdrop-filter: blur(8px)}
.modal__panel{
  position:relative;
  width:min(980px, calc(100% - 30px));
  margin: 60px auto;
  border-radius: 22px;
  border:1px solid var(--border);
  background: var(--bg2);
  box-shadow: var(--shadow);
  overflow:hidden;
  transform: translateY(10px);
}
.modal.is-open .modal__panel{animation: modalIn .22s ease both}
@keyframes modalIn{to{transform:none}}
.modal__close{
  position:absolute;top:10px;right:10px;
  width:42px;height:42px;border-radius:14px;
  border:1px solid var(--border);
  background:var(--card);color:var(--text);
  cursor:pointer;z-index:2;
}
.modal__media{padding:14px;background: linear-gradient(180deg, rgba(45,212,191,.10), rgba(99,102,241,.10), rgba(168,85,247,.10));}
.modal__media img{width:100%;height:auto;border-radius:16px;border:1px solid var(--border);}
.modal__body{padding:16px 18px 18px}
.modal__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:12px}


/* ================== Scroll Progress Bar ================== */
.scrollProgress{
  position: fixed !important;
  top: env(safe-area-inset-top, 0px);
  left: 0; right: 0;
  height: 4px;
  z-index: 9999;
  pointer-events: none;
  background: transparent;
}
.scrollProgress__bar{
  height: 100%;
  width: 100%;
  transform-origin: left center;
  transform: scaleX(0);
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(99,102,241,1), rgba(168,85,247,1), rgba(34,211,238,1));
  box-shadow: 0 0 18px rgba(168,85,247,.55), 0 0 10px rgba(34,211,238,.45);
  opacity: .92;
}
:root[data-theme="light"] .scrollProgress__bar{
  opacity: .85;
  box-shadow: 0 0 14px rgba(99,102,241,.35), 0 0 10px rgba(168,85,247,.28);
}
/* ================== Tilt (3D) ================== */
.tilt{
  position: relative;
  transform-style: preserve-3d;
  will-change: transform;
}
.tilt::after{
  content:"";
  position:absolute;inset:-1px;
  border-radius: inherit;
  pointer-events:none;
  opacity:0;
  transition: opacity .18s ease;
  background: radial-gradient(520px 220px at var(--tx, 50%) var(--ty, 20%), rgba(255,255,255,.18), transparent 60%);
}
.tilt.is-tilting::after{opacity:1}

/* Footer link (sem sublinhar) */
.footerLink{color:inherit;text-decoration:none}
.footerLink:hover{opacity:.92;text-decoration:none}

/* Prevent horizontal drift on mobile */
html, body { overflow-x: hidden; }
.hero { overflow: hidden; }

/* Portfolio thumbs via <picture> (compatível) */
.proj__thumb{ position: relative; overflow: hidden; }
.proj__thumbPic{ position:absolute; inset:0; display:block; }
.proj__thumbImg{ width:100%; height:100%; object-fit:cover; display:block; }

.topbar__right, .topbar__actions{ margin-left: auto; display:flex; align-items:center; gap: 8px; }
  .themeToggle{ order: 1; }
  .navToggle{ order: 2; }
  .themeToggle, .navToggle{ flex: 0 0 auto; }
}

/* Camadas: imagem (0) -> glow (1) -> textos (2) */
.proj__thumbPic{ z-index:0; }
.thumbBadge, .thumbTitle{ position:relative; z-index:2; }

/* Header actions (mobile e desktop) */
.topbar__actions{ display:flex; align-items:center; gap:10px; }

@media (max-width: 720px){
  .topbar__inner{ align-items:flex-start; }
  .topbar__actions{ margin-left:auto; }
  .theme, .nav__toggle{ width:44px; height:44px; border-radius:16px; }
}


/* Footer credit link */
.jf-link{color:inherit;text-decoration:none;font-weight:700}
.jf-link:hover{opacity:.9;text-decoration:none}

.about__card p{margin:10px 0 0;color:var(--muted)}
.about__card p.muted{margin-top:10px}
.about__card h3{display:block}

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

/* Footer link (JFMorais) sem sublinhado */
.footerLink,
.footerLink:visited,
.footerLink:hover,
.footerLink:active{
  text-decoration: none !important;
  color: inherit;
}
.footerLink:hover{ opacity: .92; }
