/*
Theme Name: SE3D Theme
Theme URI: https://www.se3d.com.br
Author: SE3D
Description: Tema personalizado SE3D — Impressão 3D Profissional em Aracaju
Version: 2.0
Text Domain: se3d-theme
*/

/* ============================================================
   VARIÁVEIS E RESET
============================================================ */
:root {
  --bg:         #F8F7FC;
  --fg:         #1D1B28;
  --card:       #FFFFFF;
  --primary:    #D85C32;
  --primary-fg: #FFFFFF;
  --secondary:  #4CC5D4;
  --muted:      #F2F0FA;
  --muted-fg:   #7A7590;
  --border:     #E4E1F0;
  --grad-start: #D85C32;
  --grad-mid:   #C94B7A;
  --grad-end:   #4CC5D4;
  --radius:     0.625rem;
  --radius-lg:  1rem;
  --radius-xl:  1.5rem;
  --shadow:     0 4px 16px rgba(0,0,0,.07);
  --shadow-lg:  0 12px 32px rgba(0,0,0,.12);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{background:var(--bg);color:var(--fg);font-family:'Inter','Segoe UI',system-ui,sans-serif;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;font-family:inherit}

/* ============================================================
   UTILITÁRIOS
============================================================ */
.gradient-text{
  background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gradient-bg{background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end))}
.glass{background:rgba(255,255,255,.72);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.container{max-width:1200px;margin:0 auto;padding:0 1.5rem}
@media(min-width:1024px){.container{padding:0 2rem}}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(216,92,50,.3);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(216,92,50,.5)}

/* ============================================================
   ANIMAÇÕES (controladas via JS + Customizer)
============================================================ */
.anim-el{opacity:0;transition:opacity .6s ease,transform .6s ease}
.anim-el.fade-up{transform:translateY(32px)}
.anim-el.fade-left{transform:translateX(-32px)}
.anim-el.fade-right{transform:translateX(32px)}
.anim-el.zoom{transform:scale(.92)}
.anim-el.visible{opacity:1;transform:none}
.anim-el.d1{transition-delay:.1s}.anim-el.d2{transition-delay:.2s}
.anim-el.d3{transition-delay:.3s}.anim-el.d4{transition-delay:.4s}
.anim-el.d5{transition-delay:.5s}
@keyframes spin{to{transform:rotate(360deg)}}
.spin{animation:spin .8s linear infinite}
@keyframes pulse-dot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4);opacity:.7}}
@keyframes float{0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-20px) translateX(10px)}}
@keyframes bounce-y{0%,100%{transform:translateY(0)}50%{transform:translateY(10px)}}

/* ============================================================
   HEADER
============================================================ */
#site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    transition: background .4s, box-shadow .4s;
    background: rgba(255,255,255,.95); /* Fundo mais sólido */
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 72px;
    padding: 0.5rem 0; /* Pequeno espaçamento interno */
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    border-bottom: 1px solid rgba(228,225,240,0.8);
}

/* Se quiser que o menu não fique tão no topo, adicione um padding-top no body MAIOR */
body {
    padding-top: 90px !important;
}
.site-logo img{height:38px;width:auto;transition:transform .2s}
.site-logo:hover img{transform:scale(1.05)}
.main-nav{display:flex;align-items:center;gap:.25rem}
.main-nav a{padding:.45rem .9rem;font-size:.875rem;font-weight:500;color:rgba(29,27,40,.75);border-radius:999px;transition:color .2s,background .2s}
.main-nav a:hover,.main-nav a.active{color:var(--fg);background:rgba(29,27,40,.06)}
.btn-cta{display:inline-flex;align-items:center;gap:.4rem;margin-left:.75rem;padding:.55rem 1.35rem;font-size:.875rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));border-radius:999px;border:none;box-shadow:0 4px 14px rgba(216,92,50,.3);transition:transform .2s,box-shadow .2s}
.btn-cta:hover{transform:scale(1.05);box-shadow:0 6px 20px rgba(216,92,50,.45);color:#fff}
/* Mobile toggle */
.btn-cta, .btn-primary, .cf-submit-btn {
    background: linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end)) !important;
}
.menu-toggle{display:none;background:none;border:none;padding:.5rem;border-radius:.5rem}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--fg);margin:5px 0;transition:transform .3s,opacity .3s}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;flex-direction:column;padding:1.25rem 1.5rem 1.5rem;gap:.4rem;border-top:1px solid rgba(228,225,240,.5)}
.mobile-nav.open{display:flex}
.mobile-nav a{padding:.7rem 1rem;font-size:1rem;font-weight:500;color:rgba(29,27,40,.8);border-radius:.5rem;transition:background .2s}
.mobile-nav a:hover{background:rgba(29,27,40,.05)}
.mobile-nav .btn-cta{margin:0.5rem 0 0;justify-content:center}
@media(max-width:767px){.main-nav{display:none}.menu-toggle{display:block}}

/* ============================================================
   HERO
============================================================ */
#hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center right}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,var(--bg) 0%,rgba(248,247,252,.88) 55%,rgba(248,247,252,.5) 100%),linear-gradient(to top,var(--bg) 0%,transparent 40%)}
/* Fallback sem imagem */
.hero-bg-gradient{position:absolute;inset:0;z-index:0;background:linear-gradient(135deg,rgba(216,92,50,.1) 0%,rgba(201,75,122,.06) 40%,rgba(76,197,212,.1) 100%)}
.hero-bg-gradient::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(216,92,50,.12) 1px,transparent 0);background-size:48px 48px}
/* Partículas */
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.particle{position:absolute;width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));opacity:.35;animation:float linear infinite}
.hero-content{position:relative;z-index:2;padding:7rem 0 3rem;max-width:720px}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.45rem 1rem;background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid rgba(228,225,240,.6);border-radius:999px;font-size:.8rem;font-weight:500;color:var(--muted-fg);margin-bottom:1.75rem}
.hero-badge .dot{width:7px;height:7px;border-radius:50%;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));animation:pulse-dot 2s infinite}
.hero-logo{margin-bottom:1.25rem}.hero-logo img{height:56px;width:auto}
.hero-title{font-size:clamp(2.4rem,6vw,4.5rem);font-weight:900;line-height:1.06;letter-spacing:-.03em;margin-bottom:1.25rem}
.hero-subtitle{font-size:clamp(.95rem,1.8vw,1.1rem);color:var(--muted-fg);max-width:480px;line-height:1.75;margin-bottom:2.5rem}
.hero-actions{display:flex;flex-wrap:wrap;gap:.875rem;margin-bottom:3.5rem}
.btn-primary{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.875rem;font-size:.975rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));border-radius:999px;border:none;box-shadow:0 6px 20px rgba(216,92,50,.3);transition:transform .2s,box-shadow .2s}
.btn-primary:hover{transform:scale(1.05);box-shadow:0 10px 28px rgba(216,92,50,.42);color:#fff}
.btn-secondary{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.875rem;font-size:.975rem;font-weight:600;color:var(--fg);background:rgba(29,27,40,.05);border:1px solid rgba(228,225,240,.7);border-radius:999px;transition:background .2s,transform .2s}
.btn-secondary:hover{background:rgba(29,27,40,.1);transform:scale(1.04)}
/* Stats */
.hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.875rem;max-width:580px}
@media(min-width:640px){.hero-stats{grid-template-columns:repeat(4,1fr)}}
.stat-card{padding:.875rem .75rem;background:rgba(255,255,255,.68);backdrop-filter:blur(12px);border:1px solid rgba(228,225,240,.4);border-radius:var(--radius-lg);text-align:center}
.stat-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:.625rem;background:rgba(216,92,50,.1);margin:0 auto .5rem}
.stat-icon svg{width:16px;height:16px;color:var(--primary)}
.stat-value{font-size:1.5rem;font-weight:900;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{font-size:.7rem;color:var(--muted-fg);margin-top:.15rem;line-height:1.3}
/* Scroll indicator */
.scroll-ind {
    position: absolute;
    bottom: 1rem;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.6rem;  /* Aumente esse valor para mais espaço */
    z-index: 35;
    
}

.scroll-ind span {
    font-size: 0.65rem;
    color: var(--muted-fg);
    text-transform: uppercase;
    letter-spacing: 0.1em;
}

.scroll-ind svg {
    width: 18px;
    height: 18px;
    color: var(--muted-fg);
    animation: bounce-y 1.6s ease-in-out infinite;
    margin-top: -15px;
}
/* ============================================================
   SEÇÃO GENÉRICA
============================================================ */
.section{padding:5rem 0}
.section-alt{background:rgba(242,240,250,.35)}
.section-tag{display:inline-block;padding:.35rem .9rem;font-size:.78rem;font-weight:600;color:var(--primary);background:rgba(255,255,255,.7);backdrop-filter:blur(8px);border:1px solid rgba(228,225,240,.6);border-radius:999px;margin-bottom:1rem}
.section-title{font-size:clamp(1.8rem,4.5vw,3rem);font-weight:900;line-height:1.1;letter-spacing:-.025em;margin-bottom:.875rem}
.section-desc{font-size:1rem;color:var(--muted-fg);max-width:580px;line-height:1.75}
.section-header{text-align:center;margin-bottom:3.5rem}
.section-header .section-desc{margin:0 auto}

/* ============================================================
   SERVIÇOS
============================================================ */
#servicos{position:relative;overflow:hidden}
#servicos::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(216,92,50,.1) 1px,transparent 0);background-size:40px 40px;opacity:.45;pointer-events:none}

/* Card destaque */
.srv-featured{margin-bottom:3rem;border-radius:var(--radius-xl);overflow:hidden;border:1px solid rgba(228,225,240,.5)}
.srv-featured-inner{position:relative;height:380px;display:flex;align-items:center}
@media(min-width:768px){.srv-featured-inner{height:440px}}
.srv-featured-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.srv-featured-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(248,247,252,.95) 0%,rgba(248,247,252,.65) 55%,transparent 100%)}
.srv-featured-content{position:relative;z-index:2;padding:2rem 2.5rem;max-width:500px}
.srv-badge{display:inline-block;padding:.35rem .875rem;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));color:#fff;font-size:.76rem;font-weight:700;border-radius:999px;margin-bottom:.875rem}
.srv-featured-content h3{font-size:clamp(1.4rem,2.5vw,1.9rem);font-weight:800;margin-bottom:.75rem;color:var(--fg)}
.srv-featured-content p{color:var(--muted-fg);font-size:.95rem;line-height:1.75;margin-bottom:1.25rem}

/* Grid serviços - versão em GRADE (blocos lado a lado) */
.srv-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
}

/* Para tablets */
@media (max-width: 900px) {
    .srv-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* Para celular */
@media (max-width: 600px) {
    .srv-grid {
        grid-template-columns: 1fr;
    }
}

/* Card individual */
.srv-card {
    position: relative;
    padding: 1.75rem;
    border-radius: var(--radius-xl);
    background: rgba(255,255,255,.7);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(228,225,240,.5);
    transition: transform .3s, box-shadow .3s;
}

.srv-card:hover {
    transform: translateY(-7px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(216,92,50,.2);
}

.srv-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,rgba(216,92,50,.04),rgba(76,197,212,.03));
    opacity: 0;
    transition: opacity .3s;
    border-radius: inherit;
    pointer-events: none;
}

.srv-card:hover::before {
    opacity: 1;
}

.srv-num {
    position: absolute;
    top: 1rem;
    right: 1.25rem;
    font-size: 3.5rem;
    font-weight: 900;
    color: rgba(29,27,40,.04);
    line-height: 1;
    transition: color .3s;
}

.srv-card:hover .srv-num {
    color: rgba(216,92,50,.07);
}

.srv-icon {
    width: 48px;
    height: 48px;
    border-radius: .875rem;
    background: linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 1.1rem;
    box-shadow: 0 4px 12px rgba(216,92,50,.22);
}

.srv-icon svg {
    width: 20px;
    height: 20px;
    color: #fff;
}

.srv-card h3 {
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 0.625rem;
    color: var(--fg);
    transition: color .2s;
}

.srv-card p {
    font-size: 0.85rem;
    color: var(--muted-fg);
    line-height: 1.65;
    margin-bottom: 0.75rem;
}

.srv-arrow {
    display: flex;
    align-items: center;
    gap: .35rem;
    margin-top: 1rem;
    font-size: .82rem;
    font-weight: 600;
    color: var(--primary);
    opacity: 0;
    transform: translateX(-6px);
    transition: opacity .2s, transform .2s;
}

.srv-card:hover .srv-arrow {
    opacity: 1;
    transform: translateX(0);
}

.srv-arrow a {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    text-decoration: none;
    color: var(--primary);
}

.srv-arrow svg {
    width: 13px;
    height: 13px;
}

.srv-card img {
    width: 100%;
    height: 120px;
    object-fit: cover;
    border-radius: 0.75rem;
    margin-bottom: 1rem;
}

/* ============================================================
   PORTFÓLIO
============================================================ */
#portfolio{background:rgba(242,240,250,.35)}
.pf-filters{display:flex;flex-wrap:wrap;justify-content:center;gap:.625rem;margin-bottom:2.5rem}
.filter-btn{padding:.5rem 1.35rem;font-size:.84rem;font-weight:600;border:1px solid rgba(228,225,240,.7);border-radius:999px;background:rgba(255,255,255,.7);backdrop-filter:blur(8px);color:var(--fg);cursor:pointer;transition:all .22s}
.filter-btn:hover,.filter-btn.active{background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));color:#fff;border-color:transparent;box-shadow:0 4px 14px rgba(216,92,50,.28)}
.filter-btn:hover, .filter-btn.active {
    background: linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end));
}
.pf-grid{display:grid;gap:1rem;grid-template-columns:1fr;margin-bottom:4rem}
@media(min-width:600px){.pf-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.pf-grid{grid-template-columns:repeat(3,1fr)}}
.pf-item{border-radius:var(--radius-xl);overflow:hidden;background:rgba(255,255,255,.7);border:1px solid rgba(228,225,240,.5);transition:transform .3s,box-shadow .3s,border-color .3s;display:block}
.pf-item:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:rgba(216,92,50,.2)}
.pf-item[style*="display:none"]{display:none!important}
.pf-img{position:relative;aspect-ratio:4/3;overflow:hidden}
.pf-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.pf-item:hover .pf-img img{transform:scale(1.08)}
.pf-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));display:flex;align-items:center;justify-content:center;font-size:3.5rem;font-weight:900;color:rgba(255,255,255,.2)}
.pf-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,18,30,.82) 0%,rgba(20,18,30,.15) 55%,transparent 100%);opacity:.65;transition:opacity .3s}
.pf-item:hover .pf-overlay{opacity:.9}
.pf-info{position:absolute;bottom:0;left:0;right:0;padding:1.1rem}
.pf-cat{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--secondary);margin-bottom:.3rem}
.pf-info h3{font-size:.975rem;font-weight:700;color:#fff;margin-bottom:.2rem}
.pf-info p{font-size:.78rem;color:rgba(255,255,255,.7);opacity:0;transform:translateY(6px);transition:opacity .25s,transform .25s}
.pf-item:hover .pf-info p{opacity:1;transform:translateY(0)}
.pf-arrow{position:absolute;top:.875rem;right:.875rem;width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(0);transition:opacity .2s,transform .2s}
.pf-item:hover .pf-arrow{opacity:1;transform:scale(1)}
.pf-arrow svg{width:15px;height:15px;color:#fff}
/* Depoimentos */
.dep-title{text-align:center;font-size:clamp(1.4rem,3vw,2rem);font-weight:800;margin-bottom:2.5rem}
.dep-grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:768px){.dep-grid{grid-template-columns:1fr 1fr}}
.dep-card{position:relative;padding:1.75rem;background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid rgba(228,225,240,.5);border-radius:var(--radius-xl)}
.dep-quote-icon{position:absolute;top:1rem;right:1.25rem;width:42px;height:42px;color:rgba(216,92,50,.1)}
.dep-card blockquote{font-size:.95rem;line-height:1.75;color:var(--fg);margin-bottom:1.25rem;font-style:italic}
.dep-author{display:flex;align-items:center;gap:.875rem}
.dep-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;flex-shrink:0}
.dep-name{font-weight:700;font-size:.9rem}
.dep-role{font-size:.78rem;color:var(--muted-fg)}

/* ============================================================
   BLOG
============================================================ */
#blog{position:relative;overflow:hidden}
#blog::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent,rgba(76,197,212,.04),transparent);pointer-events:none}
.blog-header{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:3rem}
@media(min-width:768px){.blog-header{flex-direction:row;align-items:flex-end;justify-content:space-between}}
.blog-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--primary);white-space:nowrap;transition:gap .2s}
.blog-link:hover{gap:.65rem;color:var(--primary)}
.blog-link svg{width:15px;height:15px;transition:transform .2s}
.blog-link:hover svg{transform:translateX(4px)}
a, .blog-link, .ct-social:hover, .ft-social:hover {
    color: var(--primary);
}
.blog-grid{display:grid;gap:1.75rem;grid-template-columns:1fr;margin-bottom:3rem}
@media(min-width:600px){.blog-grid{grid-template-columns:1fr 1fr}}
@media(min-width:960px){.blog-grid{grid-template-columns:repeat(3,1fr)}}
.blog-card{background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid rgba(228,225,240,.5);border-radius:var(--radius-xl);overflow:hidden;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-lg);border-color:rgba(216,92,50,.18)}
.blog-card-img{position:relative;height:170px;overflow:hidden;background:linear-gradient(135deg,rgba(216,92,50,.12),rgba(201,75,122,.08),rgba(76,197,212,.12));display:flex;align-items:center;justify-content:center}
.blog-card-img img{width:100%;height:100%;object-fit:cover}
.blog-card-img-ph{font-size:3rem;font-weight:900;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.25}
.blog-card-cat{position:absolute;top:.875rem;left:.875rem;padding:.28rem .7rem;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));color:#fff;font-size:.7rem;font-weight:700;border-radius:999px}
.blog-card-body{padding:1.35rem;flex:1;display:flex;flex-direction:column}
.blog-meta{display:flex;gap:.875rem;font-size:.73rem;color:var(--muted-fg);margin-bottom:.625rem}
.blog-meta span{display:flex;align-items:center;gap:.28rem}
.blog-meta svg{width:12px;height:12px}
.blog-card h3{font-size:.95rem;font-weight:700;line-height:1.4;margin-bottom:.625rem;color:var(--fg);transition:color .2s;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.blog-card:hover h3{color:var(--primary)}
.blog-card p{font-size:.83rem;color:var(--muted-fg);line-height:1.65;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;flex:1}
.blog-read-more{display:flex;align-items:center;gap:.35rem;margin-top:.875rem;font-size:.82rem;font-weight:600;color:var(--primary);transition:gap .2s}
.blog-card:hover .blog-read-more{gap:.55rem}
.blog-read-more svg{width:14px;height:14px;transition:transform .2s}
.blog-card:hover .blog-read-more svg{transform:translateX(4px)}
.blog-cta-box{display:flex;flex-direction:column;align-items:center;gap:1.1rem;padding:1.75rem;background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid rgba(228,225,240,.5);border-radius:var(--radius-xl);text-align:center}
@media(min-width:640px){.blog-cta-box{flex-direction:row;text-align:left}}
.blog-cta-box p{color:var(--muted-fg);flex:1;font-size:.95rem}

/* ============================================================
   FORMULÁRIO DE CONTATO (nativo)
============================================================ */
#contato{position:relative;overflow:hidden}
#contato::before{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent,rgba(216,92,50,.04),transparent);pointer-events:none}
.contact-grid{display:grid;gap:3.5rem;grid-template-columns:1fr}
@media(min-width:1024px){.contact-grid{grid-template-columns:1fr 1fr;align-items:start}}
/* Campos do formulário nativo */
.cf-field{margin-bottom:1.1rem}
.cf-field label{display:block;font-size:.875rem;font-weight:600;margin-bottom:.45rem;color:var(--fg)}
.cf-field input,.cf-field textarea,.cf-field select{
  width:100%;padding:.9rem 1.15rem;
  border-radius:var(--radius-lg);
  background:rgba(255,255,255,.7);backdrop-filter:blur(8px);
  border:1.5px solid var(--border);
  font-size:.95rem;color:var(--fg);font-family:inherit;
  transition:border-color .25s,box-shadow .25s;outline:none}
.cf-field input:focus,.cf-field textarea:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(216,92,50,.12)}
.cf-field input::placeholder,.cf-field textarea::placeholder{color:var(--muted-fg)}
.cf-field textarea{resize:none;min-height:128px}
.cf-field input:focus, .cf-field textarea:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(216,92,50,.12); /* Essa sombra precisa ser ajustada via JS */
}
.cf-row{display:grid;gap:1rem;grid-template-columns:1fr 1fr}
@media(max-width:600px){.cf-row{grid-template-columns:1fr}}
.cf-submit-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1rem 1.5rem;font-size:1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));border:none;border-radius:999px;box-shadow:0 6px 20px rgba(216,92,50,.3);transition:transform .2s,box-shadow .2s;cursor:pointer}
.cf-submit-btn:hover{transform:scale(1.02);box-shadow:0 10px 28px rgba(216,92,50,.42)}
.cf-submit-btn:disabled{opacity:.7;cursor:wait;transform:none}
.cf-submit-btn svg{width:18px;height:18px}
.cf-feedback{display:none;padding:.875rem 1.1rem;border-radius:var(--radius);font-size:.9rem;font-weight:500;margin-top:.875rem}
.cf-feedback.success{background:rgba(53,184,176,.1);color:#1e8a84;border:1px solid rgba(53,184,176,.3)}
.cf-feedback.error{background:rgba(216,92,50,.08);color:var(--primary);border:1px solid rgba(216,92,50,.25)}
/* Info contato */
.ct-items{display:flex;flex-direction:column;gap:.875rem;margin-bottom:2rem}
.ct-item{display:flex;align-items:center;gap:1.1rem;padding:1.1rem;background:rgba(255,255,255,.7);backdrop-filter:blur(12px);border:1px solid rgba(228,225,240,.5);border-radius:var(--radius-lg);text-decoration:none;color:inherit;transition:transform .22s,border-color .22s}
.ct-item:hover{transform:translateX(7px);border-color:rgba(216,92,50,.22)}
.ct-item-icon{width:48px;height:48px;border-radius:.875rem;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 3px 10px rgba(216,92,50,.2)}
.ct-item-icon svg{width:20px;height:20px;color:#fff}
.ct-item-lbl{font-size:.75rem;color:var(--muted-fg)}
.ct-item-val{font-size:.95rem;font-weight:700;color:var(--fg)}
.ct-social-lbl{font-size:.75rem;font-weight:600;color:var(--muted-fg);margin-bottom:.875rem}
.ct-socials{display:flex;gap:.625rem;margin-bottom:1.75rem}
.ct-social{width:42px;height:42px;border-radius:.625rem;background:rgba(255,255,255,.7);border:1px solid rgba(228,225,240,.5);display:flex;align-items:center;justify-content:center;color:var(--muted-fg);transition:color .2s,border-color .2s,transform .2s}
.ct-social:hover{color:var(--primary);border-color:rgba(216,92,50,.3);transform:translateY(-4px)}
.ct-social svg{width:17px;height:17px}
.ct-map{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-xl);overflow:hidden;border:1px solid rgba(228,225,240,.5);height:160px;background:linear-gradient(135deg,rgba(216,92,50,.07),rgba(76,197,212,.07));text-decoration:none;color:inherit;transition:transform .25s}
.ct-map:hover{transform:scale(1.02)}
.ct-map-inner{text-align:center}
.ct-map-inner svg{width:28px;height:28px;color:var(--primary);margin:0 auto .625rem}
.ct-map-inner span{display:block;font-size:.8rem;color:var(--muted-fg)}
.ct-map-inner strong{display:block;font-size:.9rem;font-weight:700;color:var(--fg)}
.ct-map-inner em{display:block;font-size:.72rem;color:var(--primary);font-style:normal;margin-top:.4rem}
/* Forminator override */
.forminator-custom-form input[type=text],.forminator-custom-form input[type=email],.forminator-custom-form input[type=tel],.forminator-custom-form textarea{width:100%!important;padding:.9rem 1.15rem!important;border-radius:var(--radius-lg)!important;background:rgba(255,255,255,.7)!important;border:1.5px solid var(--border)!important;font-size:.95rem;color:var(--fg);font-family:inherit;transition:border-color .25s,box-shadow .25s;outline:none!important}
.forminator-custom-form input:focus,.forminator-custom-form textarea:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px rgba(216,92,50,.12)!important}
.forminator-custom-form .forminator-button-submit{width:100%!important;padding:1rem 1.5rem!important;background:linear-gradient(135deg,var(--grad-start),var(--grad-mid),var(--grad-end))!important;color:#fff!important;border:none!important;border-radius:999px!important;font-size:1rem;font-weight:700!important;cursor:pointer;box-shadow:0 6px 20px rgba(216,92,50,.3)!important;transition:transform .2s,box-shadow .2s;font-family:inherit!important}
.forminator-custom-form .forminator-button-submit:hover{transform:scale(1.02)!important;box-shadow:0 10px 28px rgba(216,92,50,.42)!important}

/* ============================================================
   RODAPÉ
============================================================ */

#site-footer {
    position: relative;
    padding: 4.5rem 0 2rem;
    border-top: 1px solid rgba(228,225,240,.6);
    overflow: hidden;
}
#site-footer::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle at 1px 1px, rgba(216,92,50,.07) 1px, transparent 0);
    background-size: 40px 40px;
    opacity: .4;
    pointer-events: none;
}
.ft-inner {
    position: relative;
    z-index: 1;
}
.ft-grid {
    display: grid;
    gap: 2.5rem;
    margin-bottom: 3.5rem;
    grid-template-columns: 1fr;
}
@media (min-width: 600px) {
    .ft-grid {
        grid-template-columns: 1fr 1fr;
    }
}
@media (min-width: 960px) {
    .ft-grid {
        grid-template-columns: 2fr 1fr 1fr;
    }
}
.ft-brand img {
    height: 44px;
    width: auto;
    margin-bottom: 1.1rem;
}
.ft-brand p {
    font-size: .88rem;
    color: var(--muted-fg);
    line-height: 1.7;
    margin-bottom: .6rem;
    max-width: 340px;
}
.ft-brand small {
    font-size: .78rem;
    color: var(--muted-fg);
    display: block;
    margin-bottom: 1.1rem;
}
.ft-socials {
    display: flex;
    gap: .75rem;
}
.ft-social {
    width: 38px;
    height: 38px;
    border-radius: .625rem;
    background: rgba(255,255,255,.7);
    border: 1px solid rgba(228,225,240,.6);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--muted-fg);
    transition: color .2s, border-color .2s, transform .2s;
    text-decoration: none;
}
.ft-social:hover {
    color: var(--primary);
    border-color: rgba(216,92,50,.3);
    transform: translateY(-2px);
}
.ft-social svg {
    width: 18px;
    height: 18px;
}
.ft-col h4 {
    font-size: .9rem;
    font-weight: 700;
    margin-bottom: 1.1rem;
    color: var(--fg);
}
.ft-col ul {
    display: flex;
    flex-direction: column;
    gap: .625rem;
}
.ft-col ul li {
    list-style: none;
}
.ft-col ul a {
    font-size: .85rem;
    color: var(--muted-fg);
    transition: color .2s;
    text-decoration: none;
}
.ft-col ul a:hover {
    color: var(--primary);
}
.ft-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .875rem;
    padding-top: 2rem;
    border-top: 1px solid rgba(228,225,240,.6);
}
@media (min-width: 640px) {
    .ft-bottom {
        flex-direction: row;
        justify-content: space-between;
    }
}
.ft-bottom p {
    font-size: .8rem;
    color: var(--muted-fg);
}
.scroll-top {
    width: 46px;
    height: 46px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end));
    border: none;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 14px rgba(216,92,50,.28);
    transition: transform .2s, box-shadow .2s;
}
.scroll-top:hover {
    transform: scale(1.1) translateY(-4px);
    box-shadow: 0 8px 22px rgba(216,92,50,.42);
}
.scroll-top svg {
    width: 18px;
    height: 18px;
    color: #fff;
}

/* ============================================================
   HEADER
============================================================ */
#site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    transition: background .4s, box-shadow .4s;
    background: rgba(255,255,255,.95);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 72px;
    padding: 0.5rem 0;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05);
    border-bottom: 1px solid rgba(228,225,240,0.8);
}

body {
    padding-top: 90px !important;
}

.site-logo img{height:38px;width:auto;transition:transform .2s}
.site-logo:hover img{transform:scale(1.05)}

/* ---- Header CTA botão ---- */
.btn-cta, #header-cta-btn {
    background: var(--header-cta-bg, linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end)));
    color: var(--header-cta-fg, #fff);
}

/* ---- Logo texto (quando logo está oculto) ---- */
.site-logo-txt {
    font-weight: 800;
    font-size: 1.1rem;
    color: var(--fg);
    text-decoration: none;
}

.main-nav {
    display: flex;
    align-items: center;
    gap: .25rem;
}

.main-nav a {
    padding: .45rem .9rem;
    font-size: .875rem;
    font-weight: 500;
    color: rgba(29,27,40,.75);
    border-radius: 999px;
    transition: color .2s, background .2s;
}

.main-nav a.active,
.main-nav a:hover {
    color: var(--nav-active-fg, var(--fg));
    background: var(--nav-active-bg, rgba(29,27,40,.06));
}

/* Desativa destaque se configurado */
.no-nav-highlight .main-nav a.active,
.no-nav-highlight .main-nav a:hover {
    background: transparent;
    color: var(--fg);
}

/* ---- Menu item com classe menu-cta ---- */
.main-nav .nav-menu-cta {
    background: var(--header-cta-bg, linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end)));
    color: var(--header-cta-fg, #fff) !important;
    padding: .55rem 1.35rem !important;
    border-radius: 999px;
    box-shadow: 0 4px 14px rgba(216,92,50,.28);
}

.main-nav .nav-menu-cta:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 20px rgba(216,92,50,.4);
}

.btn-cta {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    margin-left: .75rem;
    padding: .55rem 1.35rem;
    font-size: .875rem;
    font-weight: 600;
    color: #fff;
    background: linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end));
    border-radius: 999px;
    border: none;
    box-shadow: 0 4px 14px rgba(216,92,50,.3);
    transition: transform .2s, box-shadow .2s;
}

.btn-cta:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 20px rgba(216,92,50,.45);
    color: #fff;
}

.btn-cta, .btn-primary, .cf-submit-btn {
    background: linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end)) !important;
}

/* ---- Botão de busca no header ---- */
.header-search-btn,
.hdr-search-icon {
    background: none;
    border: none;
    cursor: pointer;
    padding: .4rem;
    border-radius: .5rem;
    color: var(--muted-fg);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: color .2s, background .2s;
}

.header-search-btn:hover,
.hdr-search-icon:hover {
    color: var(--primary);
    background: rgba(29,27,40,.05);
}

.header-search-btn svg,
.hdr-search-icon svg {
    width: 20px;
    height: 20px;
}

/* ---- Overlay de busca ---- */
.search-overlay,
.hdr-search-overlay {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(255,255,255,.98);
    backdrop-filter: blur(20px);
    border-top: 1px solid var(--border);
    box-shadow: 0 8px 32px rgba(0,0,0,.1);
    z-index: 99;
}

.search-overlay.open,
.hdr-search-overlay.open {
    display: block;
}

.search-overlay-inner,
.hdr-search-overlay .container {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.1rem 1.5rem;
}

.search-form {
    display: flex;
    align-items: center;
    gap: .5rem;
    flex: 1;
}

.search-field,
.hdr-search-input {
    flex: 1;
    padding: .75rem 1rem;
    border: 1.5px solid var(--border);
    border-radius: 999px;
    font-size: 1rem;
    color: var(--fg);
    background: var(--bg);
    font-family: inherit;
    outline: none;
    transition: border-color .25s, box-shadow .25s;
}

.search-field:focus,
.hdr-search-input:focus {
    border-color: var(--primary);
    box-shadow: 0 0 0 3px rgba(216,92,50,.12);
}

.search-submit,
.hdr-search-submit {
    background: linear-gradient(135deg, var(--grad-start), var(--grad-end));
    border: none;
    border-radius: 999px;
    padding: .7rem 1.25rem;
    color: #fff;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: .35rem;
    font-size: .875rem;
    font-weight: 600;
    font-family: inherit;
    transition: transform .2s, box-shadow .2s;
}

.search-submit:hover,
.hdr-search-submit:hover {
    transform: scale(1.04);
    box-shadow: 0 4px 12px rgba(216,92,50,.3);
}

.search-submit svg,
.hdr-search-submit svg {
    width: 16px;
    height: 16px;
}

.search-close,
#search-close {
    background: none;
    border: none;
    cursor: pointer;
    padding: .4rem;
    border-radius: .5rem;
    color: var(--muted-fg);
    transition: color .2s;
    display: inline-flex;
    align-items: center;
}

.search-close:hover,
#search-close:hover {
    color: var(--primary);
}

.search-close svg,
#search-close svg {
    width: 22px;
    height: 22px;
}

/* ---- Controles mobile ---- */
.mobile-controls {
    display: none;
    align-items: center;
    gap: .5rem;
}

.menu-toggle {
    display: none;
    background: none;
    border: none;
    padding: .5rem;
    border-radius: .5rem;
}

.menu-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: var(--fg);
    margin: 5px 0;
    transition: transform .3s, opacity .3s;
}

.menu-toggle.open span:nth-child(1) {
    transform: translateY(7px) rotate(45deg);
}

.menu-toggle.open span:nth-child(2) {
    opacity: 0;
}

.menu-toggle.open span:nth-child(3) {
    transform: translateY(-7px) rotate(-45deg);
}

.mobile-nav {
    display: none;
    flex-direction: column;
    padding: 1.25rem 1.5rem 1.5rem;
    gap: .4rem;
    border-top: 1px solid rgba(228,225,240,.5);
}

.mobile-nav.open {
    display: flex;
}

.mobile-nav a {
    padding: .7rem 1rem;
    font-size: 1rem;
    font-weight: 500;
    color: rgba(29,27,40,.8);
    border-radius: .5rem;
    transition: background .2s;
}

.mobile-nav a:hover {
    background: rgba(29,27,40,.05);
}

.mobile-nav .btn-cta {
    margin: 0.5rem 0 0;
    justify-content: center;
}

@media (max-width: 991px) {
    .main-nav .hdr-search-icon {
        display: none;
    }
    .mobile-controls .hdr-search-icon {
        display: inline-flex;
    }
}

@media (max-width: 767px) {
    .main-nav {
        display: none;
    }
    .menu-toggle {
        display: block;
    }
    .mobile-controls {
        display: flex;
    }
}
/* ============================================================
   PÁGINAS INTERNAS
============================================================ */
.page-hero{padding:9rem 0 3.5rem;background:linear-gradient(135deg,rgba(216,92,50,.05),rgba(76,197,212,.05))}
.page-hero h1{font-size:clamp(1.8rem,4.5vw,3rem);font-weight:800;margin-bottom:.875rem}
.page-content{padding:3.5rem 0;max-width:780px;margin:0 auto}
.page-content h2{font-size:1.6rem;font-weight:700;margin:2rem 0 .875rem}
.page-content p{color:var(--muted-fg);line-height:1.85;margin-bottom:1rem}
.page-content a{color:var(--primary);text-decoration:underline}
.post-header{padding:8rem 0 2.5rem}
.post-cat{display:inline-block;padding:.3rem .875rem;background:linear-gradient(135deg,var(--grad-start),var(--grad-end));color:#fff;font-size:.73rem;font-weight:700;border-radius:999px;margin-bottom:1.1rem}
.post-header h1{font-size:clamp(1.7rem,3.5vw,2.8rem);font-weight:800;margin-bottom:.875rem;line-height:1.2}
.post-meta-bar{display:flex;flex-wrap:wrap;gap:1.25rem;color:var(--muted-fg);font-size:.82rem}
.post-meta-bar svg{width:14px;height:14px;vertical-align:middle;margin-right:.25rem}
.post-content{padding:2.5rem 0;max-width:740px;margin:0 auto}
.post-content img{border-radius:var(--radius-lg);margin:1.75rem 0}
.post-content h2{font-size:1.5rem;font-weight:700;margin:2rem 0 .875rem}
.post-content p{color:var(--fg);line-height:1.85;margin-bottom:1.1rem}
.post-content a{color:var(--primary);text-decoration:underline}
.archive-section{padding:4.5rem 0}

/* ============================================================
   AVISO ADMIN
============================================================ */
.se3d-admin-notice{color:var(--primary);font-weight:600;padding:1rem 1.25rem;background:rgba(216,92,50,.07);border:1px solid rgba(216,92,50,.2);border-radius:var(--radius);margin:.875rem 0}
.se3d-admin-notice a{color:var(--primary);text-decoration:underline}

/* ============================================================
   RESPONSIVO
============================================================ */
@media(max-width:767px){
  .hero-content{padding-top:5.5rem}
  .hero-title{font-size:2.2rem}
  .section{padding:3.5rem 0}
  .srv-featured-content{padding:1.35rem 1.5rem}
  .srv-featured-inner{height:320px}
  .hero-actions .btn-primary,.hero-actions .btn-secondary{padding:.75rem 1.35rem;font-size:.9rem}
}
/* ============================================================
   PORTFÓLIO: duplo título (nome + fallback)
============================================================ */
.pf-info h3 + .pf-info-sub {
    font-size: .78rem;
    color: rgba(255,255,255,.6);
    font-style: italic;
    margin-top: .1rem;
}
/* Estado inicial dos itens do portfólio */
.pf-item {
    transition: opacity 0.4s ease, transform 0.4s ease, box-shadow 0.3s ease;
    opacity: 1;
    transform: scale(1);
}

.pf-item.hidden-item {
    display: none !important;
}

/* Animações suaves para os botões */
.filter-btn {
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.filter-btn:active {
    transform: scale(0.96);
}

/* Efeito de entrada suave para novos itens */
.pf-item.show-animation {
    animation: fadeInScale 0.4s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

/* Animação de entrada suave */
@keyframes fadeInScale {
    0% {
        opacity: 0;
        transform: scale(0.95);
    }
    100% {
        opacity: 1;
        transform: scale(1);
    }
}

.pf-item {
    transition: box-shadow 0.3s ease, transform 0.3s ease;
    animation: fadeInScale 0.4s ease forwards;
}
/* ============================================================
   DROPDOWN MENU (Desktop)
============================================================ */
.main-nav li {
    position: relative;
    list-style: none;
}

.main-nav .sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: rgba(255,255,255,.98);
    backdrop-filter: blur(20px);
    border-radius: var(--radius-lg);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-lg);
    padding: 0.5rem 0;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.2s ease;
    z-index: 100;
}

.main-nav li:hover > .sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.main-nav .sub-menu li {
    display: block;
}

.main-nav .sub-menu a {
    display: block;
    padding: 0.5rem 1.25rem;
    font-size: 0.85rem;
    white-space: nowrap;
}

.main-nav .sub-menu a:hover {
    background: rgba(29,27,40,.05);
}

.dropdown-arrow {
    font-size: 0.7rem;
    margin-left: 0.3rem;
    display: inline-block;
}

/* Mobile submenu */
.mobile-menu-item {
    position: relative;
}

.mobile-sub-menu {
    padding-left: 1.5rem;
    margin-top: 0.25rem;
    display: none;
}

.mobile-sub-menu.open {
    display: block;
}

.mobile-sub-menu a {
    font-size: 0.9rem;
    padding: 0.5rem 1rem;
    opacity: 0.8;
}

.mobile-dropdown-toggle {
    float: right;
    font-size: 1.2rem;
    font-weight: bold;
    cursor: pointer;
}
/* Destaque especial para o item Softwares no menu */
.main-nav .nav-menu-cta {
    background: linear-gradient(135deg, var(--grad-start), var(--grad-mid), var(--grad-end)) !important;
    color: #fff !important;
    padding: 0.55rem 1.35rem !important;
    border-radius: 999px;
    box-shadow: 0 4px 14px rgba(216,92,50, 0.3);
    transition: transform 0.2s, box-shadow 0.2s;
}

.main-nav .nav-menu-cta:hover {
    transform: scale(1.05);
    box-shadow: 0 6px 20px rgba(216,92,50, 0.45);
}

/* Se quiser que o item tenha animação de pulso */
.main-nav .nav-menu-cta {
    animation: pulse-glow 2s infinite;
}

@keyframes pulse-glow {
    0%, 100% {
        box-shadow: 0 4px 14px rgba(216,92,50, 0.3);
    }
    50% {
        box-shadow: 0 4px 20px rgba(216,92,50, 0.6);
    }
}

/* Fallback para posts sem imagem destacada */
.blog-card-img {
    position: relative;
    height: 180px;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(216,92,50,.12), rgba(76,197,212,.12));
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s ease;
}

.blog-card:hover .blog-card-img img {
    transform: scale(1.08);
}

.blog-card-img-placeholder {
    font-size: 3rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--grad-start), var(--grad-end));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    opacity: 0.3;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

/* Quando a imagem falha, mostrar o placeholder */
.blog-card-img.no-thumb .blog-card-img-placeholder {
    display: flex !important;
}

.blog-card-img.no-thumb img {
    display: none !important;
}
/* ============================================================
   CAPTCHA - CAMPO DE DIGITAÇÃO
============================================================ */
#cf-captcha {
    width: 120px !important;
    min-width: 120px !important;
    max-width: 120px !important;
    text-align: center !important;
    font-size: 1.1rem !important;
    display: inline-block !important;
}

.captcha-field input {
    width: auto !important;
    display: inline-block !important;
}

.captcha-field label {
    display: block !important;
    margin-bottom: 0.5rem !important;
}
#site-header {
    position: relative !important;
    display: block !important;
    background: #fff !important;
    margin-bottom: 20px !important;
    z-index: 9999 !important;
}

body {
    padding-top: 0 !important;
}