@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;600;700;800&display=swap');

:root{
  --bg:#ffffff;
  --surface:#f8fbff;
  --surface-2:#eef4fc;
  --border:rgba(0,45,125,.10);
  --text:#050505;
  --muted:#4c6680;
  --accent-1:#0E6EE8;
  --accent-2:#4AA3FF;
  --accent:linear-gradient(90deg,#0E6EE8,#4AA3FF);
  --accent-solid:#0E6EE8;
  --accent-contrast:#ffffff;
  --shadow:0 10px 26px rgba(0,45,125,.08);
  --glass:rgba(0,45,125,.04);
  --glass-strong:rgba(0,45,125,.08);
  --brand-logo:86px;
  --radius:14px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Nunito", system-ui, sans-serif;
  background-color: var(--bg);
  background-image: linear-gradient(180deg,
    var(--bg)100vh,
    var(--surface) 0%,
    var(--surface-2) 0%,
    #ebeffa 100%);
  color:#19191a;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

img{max-width:100%;display:block}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.page-wrapper{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}

.site-header{
  position:sticky;top:0;z-index:40;
  background:rgba(255,255,255,.7);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}

.nav{
  min-height:calc(var(--brand-logo) + 16px);
  display:flex;align-items:center;justify-content:space-between;padding:14px 0;
}

.brand{text-decoration:none;color:var(--text);display:flex;align-items:center;gap:12px;font-size:1.4rem;font-weight:800}
.brand img.logo{
  height:var(--brand-logo);
  width:auto;
  border-radius:12px;
}

.nav-links{
  display:flex;gap:18px;list-style:none;
}

.nav-links a{
  color:var(#d8e4fc);
  text-decoration:none;
  font-weight:600;
  padding:10px 12px;
  border-radius:10px;
  transition:.15s;
}

.nav-links a:not(.btn):hover,
.nav-links a:not(.btn):focus {
  color:var(#c9dafb);
  background:rgba(14,110,232,.08);
}


.nav-toggle{display:none;color:var(--text);border:1px solid var(--border);padding:8px 10px;border-radius:10px;background:transparent}

.btn{
  padding:12px 22px;
  border-radius:12px;
  font-weight:700;
  cursor:pointer;
  transition:.22s ease;
  display:inline-block;
  text-align:center;
  border:1px solid transparent;
  text-decoration:none;
}

.btn-primary{
  background:#E9F3FF;
  color:#0E6EE8;
  border:1px solid #B8D4FA;
  box-shadow:var(--shadow);
}

.btn-primary:hover{
  background:#D9E9FF;
  transform:translateY(-3px);
}

.btn-outline{
  background:transparent;
  border:1px solid #B8D4FA;
  color:var(--accent-1);
}

.btn-outline:hover{
  background:#E9F3FF;
  transform:translateY(-2px);
}

.hero{
  padding:72px 0 44px;
  background:#f6f9ff;
}

.hero h1{
  font-size:clamp(2rem,3.6vw,3.6rem);
  font-weight:800;
  margin-bottom:12px;
  letter-spacing:-0.6px;
}

.hero p{
  font-size:1.1rem;
  color:var(--muted);
  margin-bottom:20px;
}

.hero .actions{display:flex;gap:14px;flex-wrap:wrap}

.section{padding:64px 0}
.section-header h2{
  font-size:2rem;font-weight:800;margin-bottom:6px;color:var(--text)
}
.section-header p{color:var(--muted)}

.cards{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.card{
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:22px;
  box-shadow:var(--shadow);
  transition:.14s ease;
}

.card:hover{transform:translateY(-6px);box-shadow:0 18px 44px rgba(0,45,125,.12)}
.card h3{font-weight:700;margin-bottom:6px}
.card p{color:var(--muted)}


/* --- SEÇÃO DE SERVIÇOS --- */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 28px;
  margin-top: 30px;
}

.card {
  background: #24465c;
  border: 1px solid #e3e8f0;
  border-radius: 18px;
  padding: 34px 28px;
  box-shadow: 0 4px 18px rgba(0, 0, 0, 0.04);
  transition: all 0.25s ease;
  text-align: left;
}

.card:hover {
  transform: translateY(-6px);
  box-shadow: 0 10px 32px rgba(0, 0, 0, 0.08);
}

.card h3 {
  font-size: 1.25rem;
  color: #d8e4fc;
  margin-bottom: 10px;
  font-weight: 700;
}

.card p {
  font-size: 0.98rem;
  color: #f3f3f3;
  margin-bottom: 18px;
  line-height: 1.6;
}

.contact-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.btn.btn-outline {
  font-weight: 600;
  padding: 10px 18px;
  font-size: 0.9rem;
  border-radius: 10px;
  border: 1px solid #c9dafb;
  color: #585a5c;
  background: #f3fafc;
  transition: all 0.22s ease;
}

.btn.btn-outline:hover {
  background: #e9f2ff;
  color: #0949a0;
  transform: translateY(-2px);
}

.btn.btn-primary {
  background: #0e6ee8;
  color: #fff;
  border: none;
  font-weight: 700;
  border-radius: 12px;
  padding: 14px 28px;
  box-shadow: 0 8px 22px rgba(14, 110, 232, 0.25);
  transition: all 0.25s ease;
}

.btn.btn-primary:hover {
  background: #095cd0;
  transform: translateY(-3px);
}


@media (max-width: 768px) {
  .card {
    padding: 26px 20px;
  }
}


.work-grid{margin-top:22px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.work-card{
  border:1px solid var(--border);
  border-radius:12px;
  background:#ffffff;
  box-shadow:var(--shadow);
  transition:.14s ease;
}
.work-card:hover{transform:translateY(-8px)}

.work-thumb{aspect-ratio:16/10;background:#dfe9ff}
.work-meta{
  padding:12px 14px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.work-title{margin:0;font-size:1rem;font-weight:700}
.tag{
  font-size:.75rem;
  padding:6px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  color:var(--accent-1);
  background:#E9F3FF;
}

footer{
  background:#092152;
  color:#dfe9ff;
  border-top:1px solid var(--border);
  padding:32px 0;
  
}

.footer-grid{
  display:flex;justify-content:space-between;
  flex-wrap:wrap;gap:20px
}

.footer-links{
  display:flex;flex-direction:column;gap:6px;min-width:220px;
}

.footer-links a{
  text-decoration:none;color:var(--muted);font-weight:600;
}

.footer-links a:hover{
  color:var(--accent-1);
}

.social a{
  color:var(--accent-1);
  margin-left:10px;
}

.cookie-banner{
  position:fixed;left:0;right:0;bottom:0;
  display:flex;align-items:center;
  justify-content:center;
  background:#EAF2FF;
  padding:14px 16px;
  border-top:1px solid var(--border);
  gap:14px;
}

.cookie-banner a{
  color:var(--accent-1)!important
}

.cookie-actions button{
  background:#0E6EE8;
  color:#fff;
  border-radius:8px;
  padding:10px 16px;
  border:0;
}

.whatsapp-fab{
  position:fixed;bottom:18px;right:18px;
  width:56px;height:56px;border-radius:50%;
  display:grid;place-items:center;
  background:#0E6EE8;
  color:#fff;
  box-shadow:0 10px 32px rgba(0,45,125,.28);
  text-decoration:none;
  transition:.15s;
}
.whatsapp-fab:hover{
  transform:translateY(-3px);
}

@media(max-width:920px){
  .cards,.work-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:640px){
  .nav-toggle{display:block}
  .nav-links{
    position:absolute;top:64px;right:20px;
    background:#f8fbff;
    flex-direction:column;
    padding:10px;
    border:1px solid var(--border);
    border-radius:12px;
    box-shadow:var(--shadow);
    display:none;
  }
  .nav-links.open{display:flex}
  .cards,.work-grid{grid-template-columns:1fr}
  :root{--brand-logo:56px}
}

/* formulario*/ 
.form-contato{
  margin-top:34px;
  display:grid;
  gap:18px;
  background:var(--surface);
  padding:32px;
  border-radius:var(--radius);
  border:1px solid var(--border);
  box-shadow:var(--shadow);
}

.form-contato label{
  font-weight:600;
  font-size:.95rem;
  color:var(--text);
}

.form-contato input,
.form-contato select,
.form-contato textarea{
  width:100%;
  padding:14px 16px;
  font-size:1rem;
  border-radius:12px;
  border:1px solid var(--border);
  background:#ffffff;
  transition:border-color .15s, box-shadow .15s;
  font-family:"Poppins",system-ui,sans-serif;
}

.form-contato input:focus,
.form-contato select:focus,
.form-contato textarea:focus{
  border-color:var(--accent-1);
  box-shadow:0 0 0 3px rgba(14,110,232,.15);
  outline:0;
}

.form-contato fieldset{
  border:1px solid var(--border);
  border-radius:12px;
  padding:18px;
  display:flex;
  align-items:flex-start;
  gap:10px;
}

.form-contato fieldset legend{
  font-weight:700;
  margin-left:6px;
  font-size:.9rem;
}

.form-contato fieldset label{
  font-weight:500;
  line-height:1.4;
  font-size:.9rem;
}

.form-contato button[type=submit]{
  background:var(--accent);
  color:var(--accent-contrast);
  padding:16px 26px;
  font-size:1rem;
  font-weight:700;
  border-radius:14px;
  border:0;
  box-shadow:var(--shadow);
  cursor:pointer;
  transition:.22s ease;
  margin-top:10px;
}

.form-contato button:hover{
  transform:translateY(-3px);
  opacity:.95;
}

@media(max-width:520px){
  .form-contato{
    padding:22px;
  }
}
