/* ============================================================
   Dra. Luciana Pinho — Advocacia Previdenciária
   Shared stylesheet (index, conteúdo, artigos)
   ============================================================ */
:root{
  --navy:#16324e;
  --navy-deep:#122a42;
  --navy-soft:#1d3d5c;
  --coral:#e2855f;
  --coral-dark:#d2734c;
  --coral-soft:#f5d9cb;
  --cream:#f6f1ea;
  --cream-deep:#efe8dd;
  --ink:#1c3553;
  --body:#56616e;
  --muted:#8a929c;
  --line:#e7e1d6;
  --line-cream:#e1d9cc;
  --white:#ffffff;
  --serif:'Spectral',Georgia,serif;
  --sans:'Source Sans 3',system-ui,sans-serif;
  --maxw:1200px;
  --shadow-card:0 1px 3px rgba(28,53,83,.05), 0 8px 24px rgba(28,53,83,.05);
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;scroll-padding-top:84px;}
body{
  font-family:var(--sans);
  color:var(--body);
  background:var(--white);
  line-height:1.6;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--serif);color:var(--ink);font-weight:600;line-height:1.18;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,3vw,44px);}
.accent{color:var(--coral);}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--sans);font-weight:600;font-size:15px;
  padding:14px 24px;border-radius:10px;cursor:pointer;border:1.5px solid transparent;
  transition:background .18s,border-color .18s,color .18s,transform .18s;
  white-space:nowrap;
}
.btn svg{width:18px;height:18px;}
.btn-coral{background:var(--coral);color:#fff;}
.btn-coral:hover{background:var(--coral-dark);}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.35);}
.btn-ghost-light:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6);}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--coral);color:var(--coral);}

/* ---------- Brand ---------- */
.brand{display:flex;align-items:center;gap:13px;color:#fff;}
.brand .mark{width:34px;height:34px;color:var(--coral);flex:none;}
.brand .mark svg{width:100%;height:100%;}
.brand-name{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.05;color:#fff;letter-spacing:.04em;text-transform:uppercase;}
.brand-name span{display:block;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.62);font-family:var(--sans);font-weight:500;margin-top:4px;}

/* ---------- Header ---------- */
header{
  position:sticky;top:0;z-index:50;background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.07);
}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;}
.nav-links{display:flex;align-items:center;gap:30px;}
.nav-links a{color:rgba(255,255,255,.82);font-size:15px;font-weight:500;padding:6px 0;position:relative;transition:color .18s;}
.nav-links a:hover{color:#fff;}
.nav-links a.active{color:var(--coral);}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--coral);border-radius:2px;}
.nav-right{display:flex;align-items:center;gap:18px;}
.menu-toggle{display:none;background:none;border:none;color:#fff;cursor:pointer;padding:6px;}
.menu-toggle svg{width:26px;height:26px;}

/* ---------- Hero ---------- */
.hero{background:var(--navy);color:#fff;position:relative;overflow:hidden;}
.hero-grid{position:relative;display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:0;min-height:560px;align-items:center;}
.hero-text{max-width:600px;padding:96px 56px 96px 0;position:relative;z-index:2;}
.hero-tag{display:inline-block;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);margin-bottom:22px;}
.hero h1{color:#fff;font-size:clamp(32px,3.6vw,48px);font-weight:600;letter-spacing:-.01em;line-height:1.14;}
.hero p.lead{font-size:17px;color:rgba(255,255,255,.8);max-width:500px;line-height:1.7;margin-top:24px;}
.hero-badges{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap;}
.hero-badges .badge{display:flex;align-items:center;gap:11px;padding:13px 18px;border:1px solid rgba(255,255,255,.16);border-radius:10px;background:rgba(255,255,255,.04);}
.hero-badges .badge svg{width:22px;height:22px;color:var(--coral);flex:none;}
.hero-badges .badge b{display:block;color:#fff;font-size:15px;font-weight:600;font-family:var(--sans);}
.hero-badges .badge small{display:block;color:rgba(255,255,255,.6);font-size:12.5px;}
.hero-photo{position:absolute;top:0;right:0;bottom:0;width:54%;}
.hero-photo img{
  width:100%;height:100%;object-fit:cover;object-position:center top;
  -webkit-mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.35) 18%, #000 46%);
  mask-image:linear-gradient(to right, transparent 0%, rgba(0,0,0,.35) 18%, #000 46%);
}

/* ---------- Section primitives ---------- */
section{position:relative;}
.section-cream{background:var(--cream);}
.section-navy{background:var(--navy);color:#fff;}
.pad{padding:80px 0;}
.center{text-align:center;}
.sec-title{font-size:clamp(28px,3.2vw,38px);text-align:center;letter-spacing:.02em;text-transform:uppercase;}
.title-rule{width:56px;height:3px;background:var(--coral);border-radius:3px;margin:16px auto 0;}
.sec-intro{max-width:560px;margin:18px auto 0;text-align:center;color:var(--body);font-size:15.5px;}

/* ---------- Áreas de atuação ---------- */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px;}
.area-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:32px 26px;
  text-align:center;box-shadow:0 1px 2px rgba(28,53,83,.04);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.area-card:hover{transform:translateY(-4px);box-shadow:0 14px 32px rgba(28,53,83,.1);border-color:var(--coral);}
.area-card .ic{width:42px;height:42px;color:var(--coral);margin:0 auto 18px;}
.area-card h3{font-size:16px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em;}
.area-card p{font-size:14.5px;color:var(--body);}

/* ---------- Sobre ---------- */
.sobre-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;margin-top:50px;align-items:start;}
.sobre-photo{width:100%;border-radius:18px;overflow:hidden;margin-bottom:26px;box-shadow:var(--shadow-card);}
.sobre-photo img{width:100%;height:auto;display:block;}
.sobre-text p{font-size:15.5px;color:var(--body);margin-bottom:16px;}
.sobre-list{background:var(--cream);border:1px solid var(--line-cream);border-radius:18px;padding:34px 30px;}
.sobre-list .row{display:flex;align-items:flex-start;gap:15px;padding:15px 0;border-bottom:1px solid var(--line-cream);}
.sobre-list .row:last-child{border-bottom:none;}
.sobre-list .row .ic{width:26px;height:26px;color:var(--coral);flex:none;margin-top:1px;}
.sobre-list .row span{font-size:15px;color:var(--ink);font-weight:500;line-height:1.45;}

/* ---------- Atendimento (steps) ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:50px;align-items:start;}
.step{position:relative;padding:0 28px;text-align:center;}
.step .num{width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;font-size:19px;margin:0 auto 18px;}
.step h4{font-size:16px;margin-bottom:10px;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;}
.step p{font-size:14.5px;color:var(--body);line-height:1.6;}
.step .arrow{position:absolute;top:12px;right:-11px;color:var(--coral);width:24px;height:24px;}
.step:last-child .arrow{display:none;}

/* ---------- Conteúdo (cards) ---------- */
.content-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:50px;}
.content-card{
  background:#fff;border:1px solid var(--line);border-radius:18px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 1px 2px rgba(28,53,83,.04);
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.content-card:hover{transform:translateY(-4px);box-shadow:0 14px 34px rgba(28,53,83,.1);border-color:var(--coral);}
.content-card .cover{aspect-ratio:16/10;overflow:hidden;background:var(--cream);}
.content-card .cover img{width:100%;height:100%;object-fit:cover;}
.content-card .body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1;}
.content-card h3{font-size:19px;line-height:1.3;margin-bottom:10px;}
.content-card p{font-size:14.5px;color:var(--body);line-height:1.55;flex:1;}
.content-card .read{font-size:13.5px;color:var(--coral);font-weight:600;display:inline-flex;align-items:center;gap:6px;margin-top:18px;}
.content-card .read svg{width:15px;height:15px;transition:transform .18s;}
.content-card:hover .read svg{transform:translateX(3px);}

/* ---------- Contato ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:52px;align-items:start;}
.contact-left h2{color:#fff;font-size:clamp(26px,3vw,34px);margin-bottom:10px;display:flex;align-items:center;gap:12px;}
.contact-left h2 svg{width:30px;height:30px;color:var(--coral);}
.contact-left .lead{font-size:15.5px;color:rgba(255,255,255,.8);margin-bottom:28px;max-width:380px;}
.contact-list{list-style:none;display:flex;flex-direction:column;gap:18px;}
.contact-list li{display:flex;align-items:flex-start;gap:14px;color:rgba(255,255,255,.85);font-size:15px;line-height:1.5;}
.contact-list li svg{width:20px;height:20px;color:var(--coral);flex:none;margin-top:3px;}
.contact-list li a{color:rgba(255,255,255,.85);}
.contact-list li a:hover{color:#fff;}
.form{background:#fff;border-radius:18px;padding:32px;box-shadow:0 18px 44px rgba(0,0,0,.18);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{margin-bottom:16px;}
.field input,.field textarea,.field select{
  width:100%;font-family:var(--sans);font-size:15px;color:var(--ink);
  padding:13px 15px;border:1px solid var(--line);border-radius:10px;background:#fdfcfa;
  transition:border-color .18s,box-shadow .18s;
}
.field textarea{resize:vertical;min-height:118px;}
.field select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238a929c' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");background-repeat:no-repeat;background-position:right 15px center;padding-right:40px;cursor:pointer;}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-soft);}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);}
.form-foot{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-top:6px;flex-wrap:wrap;}
.consent{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--body);max-width:300px;line-height:1.4;}
.consent input{width:17px;height:17px;margin-top:2px;accent-color:var(--coral);flex:none;}
.consent a{color:var(--coral);font-weight:600;}
.form .btn-coral{padding:14px 30px;}
.lgpd{display:flex;gap:10px;align-items:flex-start;margin-top:16px;}
.lgpd svg{width:18px;height:18px;color:var(--muted);flex:none;margin-top:2px;}
.lgpd p{font-size:12.5px;color:var(--muted);margin:0;}

/* ---------- Footer ---------- */
footer{background:var(--navy-deep);color:rgba(255,255,255,.72);}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1.3fr;gap:40px;padding:56px 0 40px;align-items:start;}
.foot-brand .brand{margin-bottom:16px;}
.foot-brand p{font-size:14px;color:rgba(255,255,255,.62);max-width:300px;line-height:1.6;}
.foot h5{color:#fff;font-family:var(--sans);font-size:15px;font-weight:600;margin-bottom:18px;}
.foot ul{list-style:none;display:flex;flex-direction:column;gap:11px;}
.foot ul a{font-size:14px;color:rgba(255,255,255,.72);transition:color .18s;}
.foot ul a:hover{color:var(--coral);}
.foot-contact li{display:flex;align-items:flex-start;gap:11px;font-size:14px;color:rgba(255,255,255,.72);margin-bottom:11px;}
.foot-contact li svg{width:17px;height:17px;color:var(--coral);flex:none;margin-top:3px;}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.foot-bottom .l{font-size:13px;color:rgba(255,255,255,.55);}
.foot-bottom .r{font-size:13px;color:rgba(255,255,255,.55);display:flex;gap:14px;align-items:center;}
.foot-bottom .r .dot{opacity:.4;}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease;}
.reveal.in{opacity:1;transform:none;}

/* ============================================================
   Article / Conteúdo pages
   ============================================================ */
.page-hero{background:var(--navy);color:#fff;padding:64px 0 56px;}
.page-hero .crumb{font-size:13.5px;color:rgba(255,255,255,.6);margin-bottom:16px;display:flex;align-items:center;gap:7px;flex-wrap:wrap;}
.page-hero .crumb a{color:var(--coral);font-weight:600;}
.page-hero .crumb svg{width:13px;height:13px;}
.page-hero h1{color:#fff;font-size:clamp(30px,4vw,46px);max-width:820px;line-height:1.16;}
.page-hero p{font-size:17px;color:rgba(255,255,255,.78);max-width:680px;margin-top:18px;line-height:1.6;}
.page-hero .meta{display:flex;gap:18px;margin-top:24px;flex-wrap:wrap;font-size:13.5px;color:rgba(255,255,255,.65);}
.page-hero .meta span{display:flex;align-items:center;gap:7px;}
.page-hero .meta svg{width:15px;height:15px;color:var(--coral);}

.article-wrap{max-width:780px;margin:0 auto;padding:64px clamp(20px,3vw,44px) 80px;}
.article-cover{width:100%;border-radius:18px;overflow:hidden;margin-bottom:40px;box-shadow:var(--shadow-card);}
.article-cover img{width:100%;height:auto;}
.prose h2{font-size:26px;margin:42px 0 16px;}
.prose h3{font-size:20px;margin:32px 0 12px;color:var(--ink);}
.prose p{font-size:16.5px;color:var(--body);margin-bottom:18px;line-height:1.75;}
.prose ul,.prose ol{margin:0 0 20px 22px;color:var(--body);font-size:16.5px;line-height:1.75;}
.prose li{margin-bottom:9px;}
.prose strong{color:var(--ink);}
.prose .lead-p{font-size:18.5px;color:var(--ink);line-height:1.7;margin-bottom:26px;}
.callout{background:var(--cream);border-left:4px solid var(--coral);border-radius:0 12px 12px 0;padding:22px 26px;margin:30px 0;}
.callout p{margin:0;font-size:15.5px;color:var(--ink);}
.callout strong{color:var(--coral-dark);}
.article-cta{background:var(--cream);border:1px solid var(--line-cream);border-radius:18px;padding:34px;text-align:center;margin-top:50px;}
.article-cta h3{font-size:22px;margin-bottom:10px;}
.article-cta p{font-size:15px;color:var(--body);max-width:440px;margin:0 auto 22px;}
.article-disclaimer{font-size:13px;color:var(--muted);margin-top:36px;padding-top:22px;border-top:1px solid var(--line);line-height:1.6;}

/* related */
.related{border-top:1px solid var(--line);}

/* ---------- Mobile ---------- */
@media(max-width:980px){
  .hero-grid{display:flex;flex-direction:column;gap:0;min-height:0;}
  .hero-text{order:1;max-width:none;padding:44px 0 56px;}
  .hero-photo{position:static;order:-1;width:auto;height:320px;}
  .hero-photo img{
    object-position:center 20%;
    -webkit-mask-image:linear-gradient(to bottom, #000 60%, transparent 100%);
    mask-image:linear-gradient(to bottom, #000 60%, transparent 100%);
  }
  .areas-grid{grid-template-columns:repeat(2,1fr);}
  .sobre-grid{grid-template-columns:1fr;gap:34px;}
  .steps{grid-template-columns:1fr;gap:32px;}
  .step .arrow{display:none;}
  .content-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;gap:36px;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:680px){
  .wrap{padding:0 20px;}
  .nav-links,.nav-right .btn{display:none;}
  .menu-toggle{display:block;}
  .nav-links.open{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;background:var(--navy-soft);padding:18px 24px;gap:6px;border-bottom:1px solid rgba(255,255,255,.1);}
  .nav-links.open a{padding:11px 0;border-bottom:1px solid rgba(255,255,255,.08);width:100%;}
  .areas-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr;gap:30px;}
  .pad{padding:56px 0;}
}

/* ============================================================
   ATMOSFERA — profundidade de cor (marinho · royal · petróleo · salmão)
   Camada de gradiente/brilho sobre a estrutura existente.
   ============================================================ */
:root{ --royal:#1a4686; --petrol:#15555d; --salmon:#f08d68; }
body{ background:#fbf7f1; }

/* Hero das páginas internas: marinho→royal + brilho salmão + petróleo */
.page-hero{
  background:
    radial-gradient(110% 130% at 88% 0%, rgba(240,141,104,.22), transparent 55%),
    radial-gradient(90% 130% at 0% 100%, rgba(21,85,93,.42), transparent 60%),
    linear-gradient(152deg,#1c4a8c 0%, #16324e 48%, #0f2740 100%);
}
.page-hero .meta svg{color:var(--salmon);}

/* Accent e filetes em degradê salmão→coral */
.accent{
  background:linear-gradient(96deg,#f59a73,#d2734c);
  -webkit-background-clip:text;background-clip:text;
  -webkit-text-fill-color:transparent;color:transparent;
}
.title-rule,.contact-left .rule{background:linear-gradient(90deg,#f59a73,#d2734c);}

/* Botões coral com volume */
.btn-coral{background:linear-gradient(135deg,#f3956d,#d2734c);box-shadow:0 6px 16px rgba(210,115,76,.30);}
.btn-coral:hover{background:linear-gradient(135deg,#ee8a5f,#c2653d);}

/* Seções creme com gradiente quente */
.section-cream{
  background:
    radial-gradient(72% 60% at 100% 0%, rgba(240,141,104,.11), transparent 60%),
    linear-gradient(180deg,#f8f3ec 0%, #f1e8dc 100%);
}

/* Cards de conteúdo com sombra quente e ícones salmão */
.content-card{box-shadow:0 1px 2px rgba(28,53,83,.05), 0 16px 34px -22px rgba(210,115,76,.45);}
.area-card .ic,.content-card .read{color:var(--salmon);}

/* Artigo: realces quentes */
.callout{background:linear-gradient(180deg,#f8f1e9,#f3e9dd);border-left-color:var(--salmon);}
.article-cta{
  background:
    radial-gradient(80% 120% at 100% 0%, rgba(240,141,104,.12), transparent 60%),
    linear-gradient(180deg,#f8f3ec,#f1e8dc);
}
.article-cover{box-shadow:0 16px 36px -22px rgba(28,53,83,.5);}

/* Header: mesmo padrão do rodapé, invertido na vertical (brilho salmão na base) */
header{
  background:
    radial-gradient(64% 150% at 92% 100%, rgba(240,141,104,.20), transparent 56%),
    radial-gradient(72% 150% at 0% 0%, rgba(21,85,93,.5), transparent 60%),
    linear-gradient(200deg,#0f2740 0%, #1b4787 100%);
  border-bottom:1px solid rgba(255,255,255,.10);
  box-shadow:0 1px 0 rgba(240,141,104,.25), 0 10px 30px -18px rgba(8,20,36,.7);
}
header::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;
  background:linear-gradient(90deg,transparent, rgba(240,141,104,.6) 35%, rgba(240,141,104,.6) 65%, transparent);
}

/* Rodapé: royal + petróleo + brilho salmão */
footer{
  background:
    radial-gradient(60% 120% at 92% 0%, rgba(240,141,104,.18), transparent 55%),
    radial-gradient(72% 120% at 0% 100%, rgba(21,85,93,.5), transparent 60%),
    linear-gradient(160deg,#1b4787 0%, #0f2740 100%);
}

/* Textura de grão sutil */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ============================================================
   Capas em gradiente (artigos sem foto) — ícone sobre atmosfera
   ============================================================ */
.cover.grad,.article-cover.grad{
  display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;
  background:
    radial-gradient(82% 120% at 86% 8%, rgba(240,141,104,.32), transparent 55%),
    radial-gradient(90% 120% at 0% 100%, rgba(21,85,93,.55), transparent 60%),
    linear-gradient(150deg,#1c4a8c 0%, #0f2740 100%);
}
.cover.grad svg{width:62px;height:62px;color:#fff;opacity:.95;stroke-width:1.4;}
.article-cover.grad{min-height:230px;border:none;}
.article-cover.grad svg{width:84px;height:84px;color:#fff;opacity:.95;stroke-width:1.3;}
/* filete salmão na base da capa */
.cover.grad::after,.article-cover.grad::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:3px;
  background:linear-gradient(90deg,transparent,#f08d68 40%,#f08d68 60%,transparent);
}
