/*
Theme Name: Morena Perícia
Version: 4.0
Author: Morena Informática
*/

:root{
    --bg-dark:#071a2b;
    --bg-dark-2:#0b243a;
    --bg-deep:#081826;
    --text:#ffffff;
    --text-soft:rgba(255,255,255,.84);
    --title:#071a2b;
    --body:#334155;
    --blue:#1E88E5;
    --blue-2:#0b3c75;
    --green:#25D366;
    --border:rgba(255,255,255,.10);
    --light:#f4f6f8;
    --light-2:#f8fafc;
    --card:#ffffff;
    --radius:22px;
    --shadow:0 22px 52px rgba(6,22,38,.18);
    --shadow-soft:0 12px 32px rgba(8,24,38,.08);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
    margin:0;
    font-family:'Segoe UI', Arial, Helvetica, sans-serif;
    background:var(--bg-dark);
    color:var(--text);
}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none}
button,input,textarea{font:inherit}

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

/* Header */
.topbar{
    position:fixed;
    inset:0 0 auto 0;
    z-index:9999;
    padding:16px 0;
    background:rgba(7,26,43,.86);
    backdrop-filter:blur(12px);
    border-bottom:1px solid rgba(255,255,255,.06);
}
.topo{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:24px;
}
.logo-topo{
    display:flex;
    align-items:center;
}
.logo-topo img{
    height:60px;
    width:auto;
    display:block;
    transition:transform .25s ease, filter .25s ease;
}
.logo-topo:hover img{
    transform:translateY(-2px);
    filter:drop-shadow(0 0 8px rgba(30,136,229,.35));
}
.menu-toggle{
    display:none;
    color:#fff;
    font-size:30px;
    line-height:1;
    cursor:pointer;
    user-select:none;
}
.menu{
    display:flex;
    align-items:center;
    gap:30px;
}
.menu a{
    color:#fff;
    font-size:15px;
    opacity:.94;
    position:relative;
}
.menu a::after{
    content:'';
    position:absolute;
    left:0;
    bottom:-8px;
    width:0;
    height:2px;
    background:var(--blue);
    transition:width .25s ease;
}
.menu a:hover::after,
.menu a.active::after{width:100%}

/* Buttons */
.btn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    padding:16px 26px;
    border-radius:12px;
    font-weight:700;
    transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
    border:1px solid transparent;
}
.btn:hover{
    transform:translateY(-1px);
}
.btn-primary{
    background:linear-gradient(135deg, #1877d5 0%, #1e88e5 100%);
    color:#fff;
    box-shadow:0 12px 28px rgba(30,136,229,.28);
}
.btn-whatsapp{
    background:linear-gradient(135deg, #1fae56 0%, #25D366 100%);
    color:#fff;
    box-shadow:0 12px 28px rgba(37,211,102,.24);
}
.btn-outline-light{
    background:rgba(255,255,255,.06);
    color:#fff;
    border-color:rgba(255,255,255,.16);
}
.btn-outline-light:hover{
    background:rgba(255,255,255,.10);
}

/* Hero */
.hero{
    position:relative;
    min-height:100vh;
    background:url('./assets/img/hero.jpg') center right no-repeat;
    background-size:cover;
    display:flex;
    align-items:center;
    overflow:hidden;
}
.hero-overlay{
    position:absolute;
    inset:0;
    background:linear-gradient(90deg, rgba(7,26,43,.97) 0%, rgba(7,26,43,.90) 28%, rgba(7,26,43,.72) 52%, rgba(7,26,43,.12) 100%);
}
.hero-content{
    position:relative;
    z-index:2;
    width:100%;
    padding:130px 0 70px;
}
.hero-left{max-width:760px}
.badge,
.mini-tag{
    display:inline-flex;
    align-items:center;
    padding:9px 16px;
    border-radius:999px;
    font-size:12px;
    font-weight:700;
    letter-spacing:.12em;
}
.badge{
    background:rgba(255,255,255,.08);
    color:#cfe3ff;
    border:1px solid rgba(255,255,255,.08);
    margin-bottom:24px;
}
.hero h1{
    margin:0 0 22px;
    font-size:clamp(58px, 6vw, 84px);
    line-height:.95;
    letter-spacing:-.04em;
    max-width:700px;
}
.hero p{
    margin:0 0 34px;
    font-size:clamp(18px, 1.6vw, 21px);
    line-height:1.65;
    color:var(--text-soft);
    max-width:620px;
}
.buttons{
    display:flex;
    flex-wrap:wrap;
    gap:16px;
    margin-bottom:34px;
}
.hero-cards{
    display:grid;
    grid-template-columns:repeat(2, minmax(260px, 1fr));
    gap:18px;
    max-width:760px;
}
.card{
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
    backdrop-filter:blur(12px);
    border-radius:20px;
    padding:22px;
    min-height:155px;
    box-shadow:0 10px 24px rgba(0,0,0,.12);
}
.card h3{
    margin:0 0 12px;
    font-size:20px;
}
.card p{
    margin:0;
    font-size:15px;
    line-height:1.65;
    color:rgba(255,255,255,.84);
}

/* Sections */
.secao{padding:100px 0}
.secao-servicos,.secao-diferenciais{background:var(--light)}
.secao-situacoes,.secao-contato{background:var(--light-2)}
.secao-topo{
    max-width:860px;
    margin-bottom:34px;
}
.mini-tag{
    background:#e6eef8;
    color:#0b3c75;
    margin-bottom:16px;
}
.mini-tag-dark{
    background:rgba(255,255,255,.08);
    color:#dbeafe;
}
.secao h2{
    margin:0 0 16px;
    font-size:clamp(32px,4vw,48px);
    line-height:1.12;
    color:var(--title);
}
.secao-topo p,
.secao p{
    color:var(--body);
    line-height:1.65;
    font-size:18px;
}

.grid-servicos,
.grid-situacoes,
.grid-diferenciais{
    display:grid;
    gap:40px;
    align-items:center;
}
.grid-servicos{grid-template-columns:1.05fr .95fr}
.grid-situacoes,
.grid-diferenciais{grid-template-columns:.95fr 1.05fr}
.servicos-texto,
.situacoes-cards,
.diferenciais-cards{
    display:grid;
    gap:20px;
}
.servico-item,
.situacao-item,
.diferencial-item{
    background:var(--card);
    border-radius:18px;
    padding:24px;
    box-shadow:var(--shadow-soft);
}
.servico-item h3,
.diferencial-item h3{
    margin:0 0 10px;
    color:var(--title);
    font-size:26px;
}
.situacao-item h3{
    margin:0 0 10px;
    color:var(--title);
    font-size:24px;
}
.servico-item p,
.situacao-item p,
.diferencial-item p{
    margin:0;
    font-size:17px;
    color:var(--body);
}
.servicos-midia img,
.situacoes-midia img,
.diferenciais-midia img{
    width:100%;
    height:100%;
    min-height:320px;
    object-fit:cover;
    border-radius:22px;
    box-shadow:var(--shadow);
}

.fluxo-pericia{
    display:flex;
    align-items:center;
    justify-content:center;
    gap:18px;
    margin-top:44px;
    flex-wrap:wrap;
}
.fluxo-item{
    background:linear-gradient(180deg, #071a2b 0%, #0b243a 100%);
    color:#fff;
    border-radius:18px;
    padding:24px 22px;
    width:250px;
    min-height:170px;
    box-shadow:0 10px 28px rgba(7,26,43,.18);
}
.fluxo-item span{
    display:inline-flex;
    width:38px;
    height:38px;
    border-radius:50%;
    align-items:center;
    justify-content:center;
    background:var(--blue);
    font-weight:700;
    margin-bottom:14px;
}
.fluxo-item h4{
    margin:0 0 10px;
    font-size:22px;
}
.fluxo-item p{
    margin:0;
    font-size:16px;
    line-height:1.55;
    color:rgba(255,255,255,.88);
}
.fluxo-seta{
    font-size:34px;
    line-height:1;
    color:#0b3c75;
    font-weight:700;
}

/* Contact */
.contato-box{
    background:linear-gradient(145deg, #071a2b 0%, #0b243a 100%);
    color:#fff;
    border-radius:28px;
    padding:38px;
    box-shadow:0 18px 40px rgba(7,26,43,.16);
    display:grid;
    grid-template-columns:minmax(0,1.18fr) minmax(290px,.82fr);
    gap:32px;
    align-items:start;
}
.contato-info{max-width:780px}
.contato-box h3{
    margin:0 0 12px;
    font-size:clamp(34px, 4vw, 52px);
    line-height:1.05;
}
.contato-texto-intro{
    margin:0 0 24px !important;
    font-size:18px !important;
    color:rgba(255,255,255,.88) !important;
    line-height:1.75 !important;
}
.contato-local{
    display:inline-flex;
    align-items:center;
    gap:10px;
    margin:6px 0 18px;
    padding:10px 16px;
    border-radius:999px;
    background:rgba(255,255,255,.08);
    color:#dbeafe;
    font-size:14px;
    font-weight:700;
    line-height:1.3;
}
.contato-local-icone{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:24px;
    height:24px;
    border-radius:50%;
    background:rgba(255,255,255,.12);
    font-size:13px;
}
.contato-actions{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    align-items:stretch;
    gap:18px;
}
.contato-cta-card,
.contato-sigilo-box{
    width:100%;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.08);
    border-radius:20px;
    padding:20px;
}
.contato-cta-kicker{
    display:inline-block;
    margin-bottom:10px;
    color:#b9d7ff;
    font-size:12px;
    font-weight:700;
    letter-spacing:.10em;
}
.contato-cta-card h4{
    margin:0 0 10px;
    font-size:28px;
    color:#fff;
}
.contato-cta-card p,
.contato-sigilo-box p{
    margin:0;
    color:rgba(255,255,255,.78);
    font-size:15px;
    line-height:1.7;
}
.contato-sigilo-box strong{
    display:block;
    margin-bottom:8px;
    font-size:16px;
    color:#fff;
}
.contato-arte-ms{
    display:flex;
    justify-content:center;
    width:100%;
    padding:12px;
    border-radius:20px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.06);
}
.contato-arte-ms img{
    max-width:320px;
    width:100%;
    object-fit:contain;
}

.contato-form{margin-top:10px}
.form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
}
.form-grid-bottom{margin-top:2px}
.form-group{
    display:flex;
    flex-direction:column;
    gap:8px;
    margin-bottom:16px;
}
.form-group-full{margin-bottom:16px}
.form-group-demandas{align-self:start}
.contato-form label{
    font-size:14px;
    font-weight:700;
    color:#dbeafe;
}
.contato-form input,
.contato-form textarea{
    width:100%;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.06);
    color:#fff;
    border-radius:14px;
    padding:14px 16px;
    font-size:15px;
    outline:none;
    transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.contato-form textarea{
    resize:vertical;
    min-height:150px;
}
.contato-form input:focus,
.contato-form textarea:focus{
    border-color:rgba(30,136,229,.88);
    box-shadow:0 0 0 3px rgba(30,136,229,.18);
    background:rgba(255,255,255,.08);
}
.contato-form input::placeholder,
.contato-form textarea::placeholder{color:rgba(255,255,255,.55)}

.demandas-grid{
    display:grid;
    grid-template-columns:repeat(2, minmax(0,1fr));
    gap:14px;
}
.demanda-item{
    display:flex;
    align-items:flex-start;
    gap:12px;
    padding:16px 18px;
    border-radius:16px;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.12);
    color:#fff;
    min-height:72px;
    cursor:pointer;
    transition:border-color .25s ease, background .25s ease, transform .25s ease;
}
.demanda-item:hover{
    border-color:rgba(30,136,229,.6);
    background:rgba(255,255,255,.08);
    transform:translateY(-1px);
}
.demanda-item input{
    width:18px;
    height:18px;
    margin-top:2px;
    flex:0 0 18px;
    accent-color:#1E88E5;
}
.demanda-item span{
    display:block;
    color:#fff;
    font-size:15px;
    line-height:1.45;
}

.captcha-box{
    display:grid;
    grid-template-columns:140px 1fr;
    gap:12px;
    align-items:center;
}
.captcha-pergunta,
.form-note{
    min-height:54px;
    display:flex;
    align-items:center;
    padding:14px 16px;
    border-radius:14px;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.06);
    color:#fff;
}
.captcha-pergunta{
    justify-content:center;
    font-size:18px;
    font-weight:800;
    letter-spacing:.02em;
}
.form-note{
    color:#dbeafe;
    line-height:1.55;
    font-size:14px;
}
#telefone{letter-spacing:.02em}

.form-check{
    display:flex;
    align-items:flex-start;
    gap:10px;
    margin:10px 0 18px;
    color:#dbeafe;
    font-size:14px;
    line-height:1.55;
}
.form-check input{
    width:18px;
    height:18px;
    margin-top:2px;
    accent-color:#1e88e5;
}
.form-actions{
    display:flex;
    align-items:center;
    gap:14px;
    flex-wrap:wrap;
}
.form-alert{
    margin:0 0 18px;
    padding:14px 16px;
    border-radius:14px;
    font-size:14px;
    line-height:1.55;
    border:1px solid transparent;
}
.form-alert-success{
    background:rgba(37,211,102,.12);
    color:#b8ffd1;
    border-color:rgba(37,211,102,.28);
}
.form-alert-error{
    background:rgba(255,90,90,.12);
    color:#ffd1d1;
    border-color:rgba(255,90,90,.28);
}

/* Footer */
.site-footer{
    background:var(--bg-dark);
    color:rgba(255,255,255,.72);
    padding:28px 0;
    text-align:center;
    border-top:1px solid rgba(255,255,255,.06);
}

/* Responsive */
@media (max-width: 1100px){
    .hero{background-position:68% center}
    .hero-left{max-width:680px}
    .hero-cards{
        grid-template-columns:repeat(2, minmax(220px, 1fr));
        max-width:640px;
    }
}

@media (max-width: 900px){
    .container{width:min(100% - 28px, 100%)}
    .menu-toggle{display:block}
    .menu{
        position:absolute;
        top:76px;
        left:0;
        right:0;
        background:#071a2b;
        border-top:1px solid rgba(255,255,255,.06);
        display:none;
        flex-direction:column;
        align-items:center;
        gap:0;
        padding:10px 0 16px;
    }
    .menu.active{display:flex}
    .menu a{
        width:100%;
        text-align:center;
        padding:14px 18px;
    }
    .menu a::after{display:none}

    .hero{
        min-height:auto;
        background-position:70% center;
    }
    .hero-overlay{
        background:linear-gradient(180deg, rgba(7,26,43,.96) 0%, rgba(7,26,43,.80) 46%, rgba(7,26,43,.54) 100%);
    }
    .hero-content{padding:120px 0 60px}
    .hero-left{max-width:100%}
    .buttons{
        flex-direction:column;
        align-items:stretch;
    }
    .btn{width:100%}
    .hero-cards{grid-template-columns:1fr}

    .secao{padding:80px 0}
    .secao-topo{margin-bottom:28px}
    .secao-topo p,
    .secao p{font-size:16px}

    .grid-servicos,
    .grid-situacoes,
    .grid-diferenciais,
    .contato-box,
    .form-grid{
        grid-template-columns:1fr;
        gap:24px;
    }

    .servicos-midia img,
    .situacoes-midia img,
    .diferenciais-midia img{
        min-height:230px;
        border-radius:18px;
    }

    .servico-item,
    .situacao-item,
    .diferencial-item{
        padding:20px;
        border-radius:16px;
    }
    .servico-item h3,
    .situacao-item h3,
    .diferencial-item h3{font-size:22px}

    .fluxo-pericia{
        flex-direction:column;
        gap:14px;
        margin-top:30px;
    }
    .fluxo-seta{
        transform:rotate(90deg);
        font-size:28px;
    }
    .fluxo-item{
        width:100%;
        min-height:auto;
    }

    .contato-box{
        padding:28px 22px;
        border-radius:24px;
    }
    .contato-local{
        width:100%;
        justify-content:flex-start;
        border-radius:16px;
        padding:12px 14px;
    }
    .contato-actions{gap:16px}
    .contato-arte-ms img{max-width:230px}
    .demandas-grid{grid-template-columns:1fr}
    .captcha-box{grid-template-columns:1fr}
    .form-actions{
        flex-direction:column;
        align-items:stretch;
    }
    .form-actions .btn{
        width:100%;
        justify-content:center;
    }
}

@media (max-width: 560px){
    .hero h1{
        font-size:42px;
        line-height:1.02;
        max-width:100%;
    }
    .logo-topo img{height:52px}
    .contato-box h3{font-size:34px}
}


/* SEO local */
.secao-seo-local{
    background:#ffffff;
    padding-top:88px;
    padding-bottom:88px;
}
.seo-local-box{
    max-width:980px;
    background:linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
    border:1px solid rgba(11,60,117,.08);
    border-radius:24px;
    padding:38px 34px;
    box-shadow:0 18px 38px rgba(8,24,38,.07);
}
.seo-local-box h2{
    margin:0 0 18px;
    color:var(--title);
    font-size:clamp(30px, 4vw, 44px);
    line-height:1.14;
}
.seo-local-box p{
    margin:0 0 14px;
    color:var(--body);
    font-size:18px;
    line-height:1.78;
}
.seo-local-box p:last-child{
    margin-bottom:0;
}
@media (max-width: 768px){
    .secao-seo-local{
        padding-top:72px;
        padding-bottom:72px;
    }
    .seo-local-box{
        padding:28px 22px;
        border-radius:20px;
    }
    .seo-local-box p{
        font-size:16px;
        line-height:1.72;
    }
}
