/* =====================================================================
   Desiclean — Frontend
   Tipografia: Poppins  |  Verde #65bc7b  |  Azul #0d7fc6  |  Escuro #212934
   ===================================================================== */
:root{
    --cor-primaria:#65bc7b;
    --cor-secundaria:#0d7fc6;
    --header-bg:#212934;
    --header-texto:#ffffff;
    --footer-bg:#212934;
    --footer-texto:#cfd3da;
    --escuro:#212934;
    --texto:#4a4e57;
    --texto-claro:#747474;
    --cinza-fundo:#f6f6f6;
    --borda:#e5e4e3;
    --radius:10px;
    --shadow:0 10px 30px rgba(33,41,52,.08);
    --shadow-hover:0 18px 45px rgba(33,41,52,.16);
    --container:1180px;
    --transition:.25s ease;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    font-family:'Poppins',Arial,Helvetica,sans-serif;
    color:var(--texto);
    font-size:16px;
    line-height:1.7;
    background:#fff;
    -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{color:var(--escuro);font-weight:600;line-height:1.2}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 20px}

/* ----- Botões ----- */
.btn{
    display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
    font-weight:600;font-size:.95rem;padding:.85rem 1.8rem;border-radius:50px;
    cursor:pointer;border:2px solid transparent;transition:var(--transition);
    text-align:center;
}
.btn-lg{padding:1rem 2.3rem;font-size:1rem}
.btn-block{width:100%}
.btn-primary{background:var(--cor-primaria);color:#fff;border-color:var(--cor-primaria)}
.btn-primary:hover{background:#0a87d4;border-color:#0a87d4;transform:translateY(-2px);box-shadow:0 10px 22px rgb(18 101 192 / 34%)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.7)}
.btn-outline:hover{background:#fff;color:var(--escuro);border-color:#fff}

/* ----- Header ----- */
.site-header{
    position:sticky;top:0;z-index:1000;
    background:var(--header-bg);color:var(--header-texto);
    box-shadow:0 2px 14px rgba(0,0,0,.12);
}
/* Logótipo ao centro, itens do menu de cada lado (configurável no backoffice) */
.header-inner{display:flex;align-items:center;justify-content:center;gap:var(--logo-gap,40px);
    min-height:var(--header-altura,92px);position:relative}
.brand{display:inline-flex;flex-shrink:0}
.brand-logo{max-height:var(--logo-altura,56px);width:auto;display:block}
.nav-list{display:flex;align-items:center;gap:var(--item-gap,6px);list-style:none}
.nav-list-esq{flex:1;justify-content:flex-end}
.nav-list-dir{flex:1;justify-content:flex-start}
.nav-list a{
    color:var(--header-texto);font-weight:500;padding:.45rem .9rem;border-radius:6px;
    transition:var(--transition);opacity:.96;font-size:.95rem;white-space:nowrap;
}
.nav-list a:hover{color:#fff;background:rgba(255,255,255,.14);opacity:1}
.nav-list a.nav-cta{background:var(--cor-primaria);color:#fff;padding:.5rem 1.4rem;border-radius:50px}
.nav-list a.nav-cta:hover{background:#54a869;color:#fff}
.main-nav-mobile{display:none}
.nav-toggle{display:none;position:absolute;left:0;top:50%;transform:translateY(-50%);
    background:none;border:0;color:var(--header-texto);font-size:1.85rem;cursor:pointer;line-height:1}

/* ----- Caixas de destaque (3 serviços antes do Sobre) ----- */
.section-destaques{padding:80px 0 40px}
.destaques-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.box-destaque{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:36px 28px;
    text-align:center;transition:var(--transition);border-top:3px solid transparent}
.box-destaque:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover);border-top-color:var(--cor-primaria)}
.box-destaque .bd-icon{width:72px;height:72px;margin:0 auto 18px;border-radius:50%;
    background:rgba(101,188,123,.12);color:var(--cor-primaria);display:grid;place-items:center;font-size:1.9rem}
.box-destaque h3{font-size:1.2rem;margin-bottom:.6rem}
.box-destaque p{color:var(--texto-claro);font-size:.93rem;margin-bottom:1.1rem}
.box-destaque .bd-link{color:var(--cor-secundaria);font-weight:600;font-size:.9rem;display:inline-flex;align-items:center;gap:.35rem;transition:var(--transition)}
.box-destaque .bd-link:hover{gap:.65rem}

/* ----- Hero ----- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:1}
.hero-overlay{position:absolute;inset:0;z-index:2;
    background:linear-gradient(105deg,rgba(33,41,52,.86) 0%,rgba(33,41,52,.55) 55%,rgba(13,127,198,.35) 100%)}
.hero-grid{position:relative;z-index:3;display:grid;grid-template-columns:1.25fr .9fr;gap:50px;
    align-items:center;padding:46px 20px;width:100%;max-width:var(--container);margin:0 auto}
.hero-content{max-width:660px}
.hero-title{font-size:clamp(2.1rem,5vw,3.6rem);color:#fff;font-weight:700;margin-bottom:1.2rem}
.hero-subtitle{font-size:1.2rem;color:rgba(255,255,255,.92);margin-bottom:2rem;font-weight:300;max-width:620px}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* Card de formulário rápido no hero */
.hero-form-card{background:#fff;border-radius:14px;padding:30px 26px;box-shadow:0 24px 60px rgba(0,0,0,.28);color:var(--texto)}
.hero-form-card h3{font-size:1.4rem;margin-bottom:.3rem}
.hero-form-card>p{color:var(--texto-claro);font-size:.92rem;margin-bottom:1.2rem}
.hero-quickform{display:flex;flex-direction:column;gap:.75rem}
.hero-quickform input{width:100%;padding:.85rem .95rem;border:1px solid var(--borda);border-radius:8px;
    font-family:inherit;font-size:.95rem;color:var(--texto);transition:var(--transition)}
.hero-quickform input:focus{outline:none;border-color:var(--cor-primaria);box-shadow:0 0 0 3px rgba(101,188,123,.15)}
.hero-form-note{color:var(--texto-claro);font-size:.78rem;text-align:center}
.hero-form-note a{color:var(--cor-secundaria);text-decoration:underline}

/* ----- Secções genéricas ----- */
.section{padding:90px 0}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.eyebrow{display:inline-block;color:var(--cor-primaria);font-weight:600;text-transform:uppercase;
    letter-spacing:2px;font-size:.82rem;margin-bottom:.6rem}
.section-title{font-size:clamp(1.8rem,3.5vw,2.6rem);margin-bottom:1rem}
.section-lead{color:var(--texto-claro);font-size:1.08rem}

/* ----- Cards de serviços ----- */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:30px}
.card-servico{
    background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
    transition:var(--transition);display:flex;flex-direction:column;
}
.card-servico:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.card-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--cinza-fundo)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:.4s ease}
.card-servico:hover .card-media img{transform:scale(1.07)}
.card-icon{
    position:absolute;left:20px;bottom:-26px;width:56px;height:56px;border-radius:50%;
    background:var(--cor-primaria);color:#fff;display:grid;place-items:center;font-size:1.5rem;
    box-shadow:0 8px 18px rgba(101,188,123,.4);
}
.card-body{padding:38px 24px 28px}
.card-body h3{font-size:1.22rem;margin-bottom:.7rem}
.card-body p{color:var(--texto-claro);font-size:.95rem}

/* ----- Sobre ----- */
.section-sobre{background:var(--cinza-fundo)}
.sobre-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.sobre-media img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%}
.sobre-text p{color:var(--texto-claro);margin-bottom:1.4rem}
.check-list{list-style:none;margin-bottom:1.8rem}
.check-list li{display:flex;align-items:center;gap:.7rem;padding:.4rem 0;color:var(--escuro);font-weight:500}
.check-list i{color:var(--cor-primaria);font-size:1.2rem}

/* ----- FAQ ----- */
.faq-list{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:14px}
.faq-item{background:#fff;border:1px solid var(--borda);border-radius:var(--radius);overflow:hidden}
.faq-item summary{
    list-style:none;cursor:pointer;padding:20px 24px;font-weight:600;color:var(--escuro);
    display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary i{color:var(--cor-primaria);transition:var(--transition);flex-shrink:0}
.faq-item[open] summary i{transform:rotate(45deg)}
.faq-answer{padding:0 24px 22px;color:var(--texto-claro)}

/* ----- Contactos ----- */
.section-contactos{background:var(--escuro);color:#fff}
.section-contactos .section-title,.section-contactos h2{color:#fff}
.contactos-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:56px;align-items:start}
.contactos-info p{color:rgba(255,255,255,.8);margin-bottom:1.6rem}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:1rem}
.contact-list li{display:flex;align-items:center;gap:.9rem;color:rgba(255,255,255,.92)}
.contact-list i{color:var(--cor-primaria);font-size:1.2rem}
.contactos-form-wrap{background:#fff;border-radius:14px;padding:34px;box-shadow:var(--shadow)}
.form-contacto label{display:block;font-size:.88rem;font-weight:500;color:var(--escuro);margin-bottom:1rem}
.form-contacto label span{color:#e23}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-contacto input,.form-contacto textarea{
    width:100%;margin-top:.4rem;padding:.8rem .95rem;border:1px solid var(--borda);
    border-radius:8px;font-family:inherit;font-size:.95rem;color:var(--texto);transition:var(--transition);
}
.form-contacto input:focus,.form-contacto textarea:focus{
    outline:none;border-color:var(--cor-primaria);box-shadow:0 0 0 3px rgba(101,188,123,.15)
}
.consent{font-weight:400!important;color:var(--texto-claro)!important;font-size:.85rem!important;
    display:flex!important;align-items:flex-start;gap:.5rem}
.consent input{width:auto!important;margin-top:.2rem!important}
.consent a{color:var(--cor-secundaria);text-decoration:underline}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.alert{padding:.9rem 1.1rem;border-radius:8px;margin-bottom:1rem;font-size:.92rem}
.alert-sucesso{background:#e6f6ec;color:#1c7a3e;border:1px solid #bfe6cd}
.alert-erro{background:#fdeaea;color:#b3261e;border:1px solid #f3c4c2}

/* ----- Páginas legais ----- */
.page-hero{background:var(--escuro);color:#fff;padding:70px 0 50px}
.page-hero h1{color:#fff;font-size:2.4rem;margin-bottom:.6rem}
.breadcrumb{color:rgba(255,255,255,.7);font-size:.9rem}
.breadcrumb a{color:var(--cor-primaria)}
.legal-content{max-width:850px}
.legal-content h2{margin:2rem 0 .8rem;font-size:1.4rem}
.legal-content p{margin-bottom:1rem;color:var(--texto-claro)}
.legal-updated{margin-top:2rem;color:#999;font-size:.85rem}

/* ----- 404 ----- */
.section-404{text-align:center;padding:120px 0}
.section-404 h1{font-size:6rem;color:var(--cor-primaria);line-height:1}
.section-404 h2{margin:.5rem 0 1rem}
.section-404 p{color:var(--texto-claro);margin-bottom:1.6rem}

/* ----- Footer ----- */
.site-footer{background:var(--footer-bg);color:var(--footer-texto)}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding:64px 20px 44px}
.footer-logo{max-height:48px;margin-bottom:1rem}
.footer-tag{color:rgba(255,255,255,.65);margin-bottom:1.2rem}
.footer-social{display:flex;gap:.7rem}
.footer-social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.08);
    display:grid;place-items:center;color:#fff;transition:var(--transition)}
.footer-social a:hover{background:var(--cor-primaria)}
.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:1.1rem}
.footer-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-list a,.footer-list li{color:var(--footer-texto);transition:var(--transition);font-size:.94rem}
.footer-list a:hover{color:var(--cor-primaria)}
.footer-livro a{display:inline-flex;align-items:center;gap:.5rem;color:var(--footer-texto)}
.footer-livro a:hover{color:var(--cor-primaria)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;text-align:center;
    font-size:.86rem;color:rgba(255,255,255,.55)}

/* ----- Back to top ----- */
.back-to-top{position:fixed;right:24px;bottom:24px;width:46px;height:46px;border-radius:50%;
    background:var(--cor-primaria);color:#fff;display:grid;place-items:center;opacity:0;
    pointer-events:none;transition:var(--transition);z-index:900;box-shadow:0 8px 20px rgba(101,188,123,.4)}
.back-to-top.show{opacity:1;pointer-events:auto}
.back-to-top:hover{background:#54a869;transform:translateY(-3px)}

/* ----- Responsivo ----- */
@media (max-width:900px){
    .sobre-grid,.contactos-grid{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr 1fr}
    .destaques-grid{grid-template-columns:1fr}
    .hero-grid{grid-template-columns:1fr;gap:32px}
    .hero-form-card{max-width:480px}
}
@media (max-width:768px){
    .header-inner{justify-content:center;gap:0;min-height:68px}
    .nav-list-esq,.nav-list-dir{display:none}
    .nav-toggle{display:block}
    .brand{margin:0 auto}
    .main-nav-mobile{
        display:block;position:absolute;top:68px;left:0;right:0;background:var(--header-bg);
        max-height:0;overflow:hidden;transition:max-height .3s ease;box-shadow:0 12px 20px rgba(0,0,0,.2);z-index:1001;
    }
    .main-nav-mobile.open{max-height:520px}
    .nav-list-mobile{flex-direction:column;align-items:stretch;gap:0;padding:10px 0}
    .nav-list-mobile li{width:100%}
    .nav-list-mobile a{display:block;padding:.9rem 20px;border-radius:0;text-align:center}
    .nav-list-mobile a.nav-cta{margin:.5rem 20px;text-align:center}
    .section{padding:64px 0}
    .section-destaques{padding:54px 0 20px}
    .form-row{grid-template-columns:1fr}
    .footer-grid{grid-template-columns:1fr;gap:30px}
    .hero{min-height:78vh}
}
