/*
Theme Name: Velloso Advocacia
Theme URI: https://testeia.letsite.com.br
Author: LETS Marketing
Author URI: https://letsmarketing.com.br
Description: Tema institucional para escritorio de advocacia. Banners, equipe e areas de atuacao editaveis pelo painel, com paginas individuais por servico e por socio(a) para SEO.
Version: 1.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: velloso
*/

/* ===== Reset & Tokens ===== */
:root{
  --cream:#f2ebe3;
  --cream-light:#fdf6f0;
  --dark:#3a2c27;
  --navy:#262838;
  --earth:#976a4e;
  --earth-dark:#7a5239;
  --orange:#cf8a57;
  --orange-light:#e3ab78;
  --text:#2b211d;
  --gutter:64px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'Inter',Arial,sans-serif;color:var(--text);background:var(--cream);line-height:1.55;}
h1,h2,h3,.display{font-family:'Fraunces',serif;font-weight:500;letter-spacing:-0.01em;}
a{text-decoration:none;color:inherit;}
img{display:block;max-width:100%;height:auto;}
ul{list-style:none;}
button,.btn{cursor:pointer;font-family:'Inter',sans-serif;}
.wrap{max-width:1200px;margin:0 auto;padding:0 var(--gutter);}
.label{display:flex;align-items:center;gap:8px;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--earth);font-weight:600;}
.label::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--orange);flex:none;}
.tag{position:relative;display:inline-flex;align-items:center;gap:8px;background:var(--cream-light);color:var(--earth);font-size:13px;padding:14px 22px 14px 26px;border-radius:0 10px 0 0;}
.tag::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--orange);position:absolute;left:10px;}
.btn{display:inline-flex;align-items:center;gap:10px;background:var(--orange);color:#fff;font-weight:600;font-size:14px;padding:13px 24px;border-radius:4px;border:none;}
.btn:hover{background:var(--earth-dark);}
.crumbs{font-size:12.5px;color:#8a7a6f;display:flex;gap:8px;flex-wrap:wrap;}
.admin-note{margin-top:16px;font-size:11.5px;color:var(--earth-dark);background:#fff3e9;border:1px dashed var(--orange);border-radius:4px;padding:9px 13px;display:inline-block;}

/* ===== Header ===== */
.site-header{position:sticky;top:0;z-index:50;background:rgba(253,246,240,.92);backdrop-filter:blur(6px);}
.site-header .wrap{display:flex;align-items:center;justify-content:space-between;height:88px;}
.site-logo{font-family:'Fraunces',serif;font-size:23px;font-weight:600;letter-spacing:.02em;color:var(--earth-dark);display:flex;align-items:center;}
.site-logo img,.site-logo .custom-logo-link img,.custom-logo-link img,img.custom-logo{max-height:44px;width:auto;display:block;}
.main-nav ul{display:flex;gap:6px;}
.main-nav a{font-size:14px;padding:10px 17px;border-radius:24px;color:var(--text);display:block;}
.main-nav .current-menu-item>a,.main-nav a.active{background:var(--dark);color:#fff;}
.nav-toggle{display:none;background:none;border:none;font-size:22px;color:var(--earth-dark);}

/* ===== Hero (home) ===== */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden;min-height:600px;display:flex;flex-direction:column;background-size:cover;background-position:center;}
.hero-bg{position:absolute;inset:0;opacity:.55;background-image:radial-gradient(circle at 1px 1px, rgba(207,138,87,.4) 1px, transparent 1.6px);background-size:9px 9px;}
.hero-overlay{position:absolute;inset:0;background:rgba(38,40,56,.55);}
.hero-content{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:center;padding:80px 0 0;}
.hero-content .wrap{width:100%;}
.hero h1{font-size:clamp(38px,5vw,66px);line-height:1.08;max-width:760px;color:var(--orange-light);}
.hero p{margin-top:24px;max-width:500px;font-size:16px;color:#dfd6cc;}
.hero .btn{margin-top:32px;}
.hero-tag-row{position:relative;z-index:2;}

/* ===== Services list (home + hub) ===== */
.services{background:var(--dark);color:#fff;}
.services .intro{padding:0 0 50px;}
.services .intro .wrap{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);align-items:end;padding-top:54px;}
.services .intro p{font-size:18px;color:#e9e1d8;}
.services .row{display:grid;grid-template-columns:60px 1fr;gap:24px;align-items:center;padding:32px 0;border-top:1px solid rgba(255,255,255,.12);}
.services .row:last-child{border-bottom:1px solid rgba(255,255,255,.12);}
.services .row .num{font-family:'Fraunces',serif;font-size:24px;color:var(--orange);}
.services .row .name{font-family:'Fraunces',serif;font-size:23px;text-align:right;}
.services .row a.name{display:block;}

/* ===== About / split panel ===== */
.about{display:grid;grid-template-columns:1.05fr .95fr;min-height:560px;}
.about .photo{height:100%;}
.about .photo img{width:100%;height:100%;object-fit:cover;}
.about .panel{background:var(--cream-light);display:flex;flex-direction:column;justify-content:center;padding:70px var(--gutter);}
.about .panel h2{font-size:33px;color:var(--earth-dark);line-height:1.18;margin:16px 0 20px;}
.about .panel p{font-size:15px;color:#5b4f48;margin-bottom:28px;}

/* ===== Value / stats ===== */
.value{background:var(--cream);padding:84px 0;border-bottom:1px solid rgba(0,0,0,.08);}
.value .wrap{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);align-items:start;}
.value h2{font-size:50px;color:var(--earth);opacity:.6;}
.value p{font-size:15px;color:#5b4f48;padding-top:16px;}
.stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--cream-light);}
.stats div{padding:44px var(--gutter) 44px 36px;border-left:1px solid rgba(0,0,0,.1);}
.stats div:first-child{border-left:none;}
.stats .n{font-family:'Fraunces',serif;font-size:38px;color:var(--earth-dark);margin-bottom:8px;}
.stats .l{font-size:13px;color:#6b5d54;}

/* ===== Team grid (home + hub) ===== */
.team{padding:96px 0;background:var(--cream);}
.team .head{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);align-items:end;margin-bottom:46px;}
.team h2{font-size:34px;color:var(--earth-dark);}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;}
.member{position:relative;display:block;}
.member .photo{aspect-ratio:3/4;border-radius:2px;overflow:hidden;margin-bottom:14px;position:relative;background:var(--cream-light);}
.member .photo img{width:100%;height:100%;object-fit:cover;}
.member .arrow{position:absolute;top:10px;right:10px;width:30px;height:30px;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:2px;}
.member .name{font-family:'Fraunces',serif;font-size:18px;color:var(--earth-dark);}
.member .role{font-size:13px;color:#6b5d54;margin-top:3px;}

/* ===== Blog grid ===== */
.blog{padding:88px 0;background:var(--cream-light);}
.blog .head{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);align-items:end;margin-bottom:44px;}
.blog h2{font-size:34px;color:var(--earth-dark);}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.post-card .photo{aspect-ratio:4/3;border-radius:2px;overflow:hidden;margin-bottom:16px;background:var(--cream);}
.post-card .photo img{width:100%;height:100%;object-fit:cover;}
.post-card .cat{font-size:11.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--orange);font-weight:600;margin-bottom:8px;}
.post-card h3{font-size:18px;line-height:1.32;}

/* ===== Contact ===== */
.contact{display:grid;grid-template-columns:1fr 1fr;background:var(--cream-light);}
.contact .left{padding:88px var(--gutter);}
.contact .left h2{font-size:36px;color:var(--earth-dark);max-width:420px;line-height:1.2;margin:16px 0 28px;}
.contact form{display:flex;flex-direction:column;gap:13px;max-width:420px;}
.contact input,.contact textarea{border:1px solid rgba(0,0,0,.15);background:#fff;padding:13px 14px;font-family:'Inter';font-size:14px;border-radius:3px;width:100%;}
.contact textarea{min-height:88px;resize:vertical;}
.contact .right{position:relative;background:var(--dark);overflow:hidden;}
.form-msg{font-size:13.5px;padding:10px 14px;border-radius:4px;margin-bottom:8px;}
.form-msg.success{background:#e7f3e0;color:#3c6b2c;}
.form-msg.error{background:#fbe6e0;color:#9b3a22;}

/* ===== Footer ===== */
.site-footer{position:relative;background:var(--navy);color:#fff;min-height:460px;display:flex;flex-direction:column;}
.site-footer .bg{position:absolute;inset:0;opacity:.4;}
.site-footer .bg img{width:100%;height:100%;object-fit:cover;}
.site-footer .wrap{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:64px 0 34px;}
.site-footer .tagline{font-size:clamp(34px,5.6vw,58px);color:var(--orange-light);max-width:560px;}
.site-footer .bottom{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;}
.logo-foot{font-family:'Fraunces',serif;font-size:28px;color:#fff;}
.footer-links{display:flex;gap:24px;font-size:14px;color:#dfd6cc;flex-wrap:wrap;}
.copy{font-size:11.5px;color:#b1a59b;margin-top:6px;}

/* ===== Simple footer (non-home pages, fallback) ===== */
.footer-simple{background:var(--dark);color:#cbb9a8;padding:40px 0;font-size:12.5px;}
.footer-simple .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}

/* ===== Generic page hero (Sobre, etc.) ===== */
.page-hero{background:var(--cream-light);padding:64px 0 50px;}
.page-hero h1{font-size:clamp(32px,4.5vw,50px);color:var(--earth-dark);margin-top:14px;}
.page-content{padding:70px 0;}
.page-content .wrap{max-width:760px;}
.page-content .wrap img{border-radius:2px;margin-bottom:30px;}
.page-content p{font-size:16px;color:#3f332c;margin-bottom:18px;}
.page-content h2{font-size:26px;color:var(--earth-dark);margin:34px 0 14px;}

/* ===== Service detail (single area_atuacao) ===== */
.intro-block{background:var(--dark);color:#fff;padding:64px 0 70px;}
.intro-block .grid2{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);align-items:start;}
.intro-block h2{font-size:30px;line-height:1.2;}
.intro-block p{font-size:15.5px;color:#e2d7cc;padding-top:6px;}
.service-block{background:var(--dark);color:#fff;border-top:1px solid rgba(255,255,255,.12);}
.service-block .grid2{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--gutter);padding:54px 0;align-items:start;}
.service-block h3{font-size:26px;line-height:1.22;color:var(--orange-light);}
.service-block ul{display:flex;flex-direction:column;gap:14px;}
.service-block li{position:relative;padding-left:20px;font-size:15px;color:#ece3d9;}
.service-block li::before{content:'';position:absolute;left:0;top:7px;width:7px;height:7px;background:var(--orange);}
.why{background:var(--cream-light);padding:90px 0;}
.why .grid2{display:grid;grid-template-columns:1fr 1fr;gap:var(--gutter);}
.why h2{font-size:32px;color:var(--earth-dark);}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px 28px;}
.why-item .n{font-family:'Fraunces',serif;color:var(--orange);font-size:14px;margin-bottom:8px;display:block;}
.why-item h4{font-size:16px;margin-bottom:6px;}
.why-item p{font-size:13.5px;color:#5b4f48;}
.cross{background:var(--cream);padding:80px 0;border-top:1px solid rgba(0,0,0,.08);}
.cross .head{display:flex;justify-content:space-between;align-items:end;margin-bottom:34px;flex-wrap:wrap;gap:10px;}
.cross h2{font-size:26px;color:var(--earth-dark);}
.cross-list a{display:flex;justify-content:space-between;align-items:center;padding:22px 0;border-top:1px solid rgba(0,0,0,.1);font-family:'Fraunces',serif;font-size:19px;color:var(--earth-dark);}
.cross-list a:last-child{border-bottom:1px solid rgba(0,0,0,.1);}
.cross-list span{font-size:13px;color:var(--orange);font-family:'Inter';}
.contact-cta{background:var(--navy);color:#fff;padding:90px 0;text-align:center;}
.contact-cta h2{font-size:34px;color:var(--orange-light);max-width:560px;margin:0 auto 26px;}

/* ===== Team profile (single equipe) ===== */
.profile-hero{background:var(--cream-light);padding:54px 0 0;}
.profile-hero .grid2{display:grid;grid-template-columns:.8fr 1.2fr;gap:var(--gutter);align-items:end;}
.profile-hero .photo{aspect-ratio:3/4;border-radius:2px;overflow:hidden;background:var(--cream);}
.profile-hero .photo img{width:100%;height:100%;object-fit:cover;}
.profile-hero .info{padding-bottom:50px;}
.profile-hero h1{font-size:clamp(32px,4.5vw,52px);color:var(--earth-dark);margin:14px 0 10px;}
.profile-hero .role{font-size:16px;color:var(--orange);font-weight:600;margin-bottom:18px;}
.profile-hero .creds{font-size:13.5px;color:#6b5d54;display:flex;flex-wrap:wrap;gap:6px 0;}
.profile-hero .creds span:not(:last-child)::after{content:'·';margin:0 10px;color:var(--orange);}
.bio-block{background:var(--dark);color:#fff;padding:64px 0;}
.bio-block .grid2{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--gutter);align-items:start;}
.bio-block h2{font-size:26px;color:var(--orange-light);}
.bio-block p{font-size:15px;color:#e2d7cc;margin-bottom:16px;}
.cv-block{background:var(--cream);padding:60px 0;border-bottom:1px solid rgba(0,0,0,.08);}
.cv-block .grid2{display:grid;grid-template-columns:.85fr 1.15fr;gap:var(--gutter);}
.cv-block h3{font-size:22px;color:var(--earth-dark);}
.cv-block ul{display:flex;flex-direction:column;gap:14px;}
.cv-block li{position:relative;padding-left:20px;font-size:15px;color:#3f332c;}
.cv-block li::before{content:'';position:absolute;left:0;top:7px;width:7px;height:7px;background:var(--orange);}
.cv-block li .yr{color:var(--orange);font-weight:600;margin-right:8px;}
.quote-block{background:var(--cream-light);padding:80px 0;text-align:center;}
.quote-block blockquote{font-family:'Fraunces',serif;font-style:italic;font-size:26px;line-height:1.4;color:var(--earth-dark);max-width:760px;margin:0 auto 18px;}
.quote-block cite{font-size:13px;color:#6b5d54;font-style:normal;}
.team-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.team-mini .photo{aspect-ratio:3/4;overflow:hidden;margin-bottom:12px;background:var(--cream-light);}
.team-mini .photo img{width:100%;height:100%;object-fit:cover;}
.team-mini .name{font-family:'Fraunces',serif;font-size:17px;color:var(--earth-dark);}
.team-mini .role{font-size:12.5px;color:#6b5d54;}

/* ===== Blog archive/single ===== */
.blog-archive{padding:70px 0 90px;}
.blog-archive .grid-posts{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:40px;}
.pagination-nav{display:flex;gap:10px;margin-top:50px;justify-content:center;}
.pagination-nav a,.pagination-nav span{padding:9px 16px;border:1px solid rgba(0,0,0,.15);border-radius:4px;font-size:13.5px;}
.single-post-content{padding:60px 0 90px;}
.single-post-content .wrap{max-width:760px;}
.single-post-content .feat-img{margin-bottom:30px;border-radius:2px;overflow:hidden;}
.single-post-content .meta{font-size:13px;color:var(--orange);font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;}
.single-post-content h1{font-size:clamp(28px,4vw,42px);color:var(--earth-dark);margin-bottom:24px;}
.single-post-content .entry-content p{font-size:16px;color:#3f332c;margin-bottom:18px;}
.single-post-content .entry-content h2{font-size:24px;color:var(--earth-dark);margin:30px 0 12px;}
.single-post-content .entry-content ul{padding-left:20px;list-style:disc;margin-bottom:18px;}

/* ===== Responsive ===== */
@media (max-width:900px){
  .about,.contact,.profile-hero .grid2,.bio-block .grid2,.cv-block .grid2{grid-template-columns:1fr;}
  .stats,.team-grid,.blog-grid,.why-grid,.team-mini,.blog-archive .grid-posts{grid-template-columns:repeat(2,1fr);}
  .services .intro .wrap,.team .head,.blog .head,.value .wrap,.intro-block .grid2,.service-block .grid2,.why .grid2{grid-template-columns:1fr;}
  .main-nav{display:none;}
  .nav-toggle{display:block;}
}


/* ===== Animacoes (entrada suave ao rolar + dinamismo) ===== */
@keyframes velloso-hero-zoom{
	from{background-size:112%;}
	to{background-size:100%;}
}
.hero{animation:velloso-hero-zoom 9s ease-out forwards;}

.site-footer .bg{overflow:hidden;}
@keyframes velloso-footer-zoom{
	from{transform:scale(1.12);}
	to{transform:scale(1);}
}
.site-footer .bg img{animation:velloso-footer-zoom 16s ease-out forwards;}

.about .photo{overflow:hidden;}
.about .photo img{transition:transform .6s ease;}
.about .photo:hover img{transform:scale(1.05);}

.post-card .photo img{transition:transform .5s ease;}
.post-card .photo:hover img{transform:scale(1.06);}
.post-card{transition:transform .3s ease;}
.post-card:hover{transform:translateY(-6px);}

.member .photo img{transition:transform .5s ease;}
.member .photo:hover img{transform:scale(1.05);}

.btn{transition:background .25s ease, transform .25s ease;}
.btn:hover{transform:translateY(-2px);}

[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .7s ease, transform .7s ease;}
[data-reveal].is-visible{opacity:1;transform:translateY(0);}
