/* ==========================================================================
   SIQUEIRA & MIRANDA — Assessoria em Leilões de Imóveis
   Sistema de design: navy + dourado, serif/sans, arcos concêntricos
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,500;0,600;0,700;1,500&family=Manrope:wght@400;500;600;700;800&display=swap');

:root{
  /* cores */
  --navy-950:#08162B;
  --navy-900:#0B1B33;
  --navy-800:#0F2440;
  --navy-700:#1A3358;
  --navy-600:#274873;
  --gold-600:#A9813C;
  --gold-500:#C6A25C;
  --gold-300:#E3CFA0;
  --ivory-50:#F8F6F1;
  --ivory-100:#F1EDE3;
  --ink-900:#131722;
  --ink-700:#2B3140;
  --ink-500:#5B6472;
  --line:#E4DFD3;
  --line-dark:rgba(230,214,170,0.16);
  --white:#FFFFFF;

  /* tipografia */
  --font-display:'Playfair Display', Georgia, serif;
  --font-body:'Manrope', -apple-system, BlinkMacSystemFont, sans-serif;

  /* espaçamento */
  --gap-section: clamp(64px, 9vw, 128px);
  --gap-inner: clamp(24px, 4vw, 48px);
  --radius: 4px;
  --max-w: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink-900);
  background:var(--ivory-50);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3,h4{ font-family:var(--font-display); margin:0; font-weight:600; line-height:1.15; }
p{ margin:0; }
button{ font-family:inherit; cursor:pointer; }

@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

:focus-visible{ outline:2px solid var(--gold-500); outline-offset:3px; }

.wrap{
  max-width:var(--max-w);
  margin:0 auto;
  padding-left:clamp(20px,5vw,32px);
  padding-right:clamp(20px,5vw,32px);
}

.section{ padding:var(--gap-section) 0; position:relative; }
.section--dark{ background:var(--navy-900); color:var(--ivory-50); }
.section--gold-line::before{
  content:"";
  position:absolute; top:0; left:50%; transform:translateX(-50%);
  width:64px; height:2px; background:var(--gold-500);
}

.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body); font-weight:700; font-size:12.5px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--gold-600);
  margin-bottom:16px;
}
.section--dark .eyebrow{ color:var(--gold-300); }
.eyebrow::before{ content:""; width:24px; height:1px; background:currentColor; }

.section-head{ max-width:640px; margin-bottom:var(--gap-inner); }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head h2{ font-size:clamp(28px,4vw,42px); }
.section-head p{ margin-top:14px; color:var(--ink-500); font-size:17px; }
.section--dark .section-head p{ color:rgba(248,246,241,0.72); }

/* ---------- arco decorativo (elemento assinatura) ---------- */
.arc-field{ position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.arc-field svg{ position:absolute; }

/* ---------- header ---------- */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(8,22,43,0.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-dark);
}
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; height:78px; }
.brand{ display:flex; align-items:center; gap:10px; color:var(--ivory-50); }
.brand-mark{ width:34px; height:34px; flex:none; }
.brand-name{ font-family:var(--font-display); font-size:19px; letter-spacing:.02em; white-space:nowrap; }
.brand-name b{ color:var(--gold-500); font-weight:600; }
.brand-sub{ display:none; }

.nav-desktop{ display:none; }
.nav-desktop ul{ display:flex; gap:32px; }
.nav-desktop a{
  font-size:14.5px; font-weight:600; color:rgba(248,246,241,0.82);
  transition:color .2s;
}
.nav-desktop a:hover{ color:var(--gold-500); }

.header-cta{ display:none; }
.btn-wpp-small{
  display:inline-flex; align-items:center; gap:8px;
  background:var(--gold-500); color:var(--navy-950);
  font-weight:700; font-size:14px; padding:11px 20px;
  border-radius:3px; transition:background .2s, transform .2s;
}
.btn-wpp-small:hover{ background:var(--gold-300); transform:translateY(-1px); }

.nav-toggle{
  background:none; border:1px solid var(--line-dark); border-radius:3px;
  width:42px; height:42px; display:flex; align-items:center; justify-content:center;
  color:var(--ivory-50);
}
.nav-toggle svg{ width:20px; height:20px; }

.nav-mobile{
  display:none; flex-direction:column; gap:2px;
  background:var(--navy-950); border-bottom:1px solid var(--line-dark);
  padding:8px 0 20px;
}
.nav-mobile.open{ display:flex; }
.nav-mobile a{
  padding:14px clamp(20px,5vw,32px); font-weight:600; font-size:15px;
  color:rgba(248,246,241,0.88); border-top:1px solid var(--line-dark);
}
.nav-mobile .btn-wpp-small{ margin:14px clamp(20px,5vw,32px) 0; justify-content:center; }

@media(min-width:960px){
  .nav-desktop{ display:block; }
  .header-cta{ display:block; }
  .nav-toggle{ display:none; }
  .brand-sub{ display:block; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:rgba(248,246,241,0.55); margin-top:1px; }
}

/* ---------- hero ---------- */
.hero{
  position:relative;
  background:var(--navy-950);
  color:var(--ivory-50);
  padding:clamp(72px,12vw,140px) 0 clamp(56px,8vw,104px);
  overflow:hidden;
}
.hero .wrap{ position:relative; z-index:2; }
.hero-inner{ max-width:700px; }
.hero h1{
  font-size:clamp(34px,6vw,60px);
  color:var(--white);
}
.hero h1 em{ font-style:normal; color:var(--gold-500); }
.hero p.lead{
  margin-top:22px; font-size:clamp(16px,2vw,19px);
  color:rgba(248,246,241,0.78); max-width:560px;
}
.hero-ctas{ display:flex; flex-wrap:wrap; gap:14px; margin-top:36px; }
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:15px 28px; border-radius:3px; font-weight:700; font-size:15px;
  transition:transform .2s, background .2s, border-color .2s, color .2s;
  border:1px solid transparent; white-space:nowrap;
}
.btn-primary{ background:var(--gold-500); color:var(--navy-950); }
.btn-primary:hover{ background:var(--gold-300); transform:translateY(-2px); }
.btn-outline{ border-color:rgba(248,246,241,0.35); color:var(--ivory-50); }
.btn-outline:hover{ border-color:var(--gold-500); color:var(--gold-500); }
.btn svg{ width:18px; height:18px; }

.hero-trust{
  margin-top:44px; padding-top:22px; border-top:1px solid var(--line-dark);
  display:flex; flex-wrap:wrap; gap:10px 28px;
  font-size:13.5px; color:rgba(248,246,241,0.62); font-weight:600;
}
.hero-trust span{ display:flex; align-items:center; gap:8px; }
.hero-trust svg{ width:15px; height:15px; color:var(--gold-500); flex:none; }

/* ---------- cards genéricas ---------- */
.grid{ display:grid; gap:22px; }
.grid-2{ grid-template-columns:1fr; }
.grid-3{ grid-template-columns:1fr; }
.grid-4{ grid-template-columns:1fr; }
@media(min-width:700px){
  .grid-2{ grid-template-columns:1fr 1fr; }
  .grid-4{ grid-template-columns:1fr 1fr; }
}
@media(min-width:960px){
  .grid-3{ grid-template-columns:repeat(3,1fr); }
  .grid-4{ grid-template-columns:repeat(4,1fr); }
}

/* ---------- quem somos ---------- */
.about{ background:var(--ivory-50); }
.about-layout{ display:grid; gap:44px; align-items:start; }
@media(min-width:900px){ .about-layout{ grid-template-columns:0.85fr 1.15fr; gap:64px; } }
.about-figure{
  position:relative; background:var(--navy-900); border-radius:var(--radius);
  padding:40px 32px; color:var(--ivory-50); overflow:hidden; min-height:280px;
  display:flex; flex-direction:column; justify-content:flex-end;
}
.about-figure .stat{ position:relative; z-index:2; }
.about-figure .stat b{ display:block; font-family:var(--font-display); font-size:44px; color:var(--gold-500); }
.about-figure .stat span{ font-size:13px; color:rgba(248,246,241,0.7); text-transform:uppercase; letter-spacing:.08em; font-weight:700; }
.about-text p{ color:var(--ink-700); font-size:16.5px; margin-bottom:16px; }
.about-text p:last-child{ margin-bottom:0; }
.about-text strong{ color:var(--ink-900); }

/* ---------- missão / valores ---------- */
.mission{ background:var(--navy-900); color:var(--ivory-50); }
.mission-layout{ display:grid; gap:56px; }
@media(min-width:960px){ .mission-layout{ grid-template-columns:0.9fr 1.1fr; gap:72px; } }
.mission-statement p{ font-size:clamp(18px,2.4vw,22px); font-family:var(--font-display); font-style:italic; font-weight:500; line-height:1.5; color:var(--ivory-100); }
.mission-statement strong{ color:var(--gold-500); font-weight:600; font-style:normal; }

.values-list{ display:grid; gap:1px; background:var(--line-dark); border:1px solid var(--line-dark); border-radius:var(--radius); overflow:hidden; }
.value-item{ background:var(--navy-900); padding:22px 24px; display:flex; gap:16px; align-items:flex-start; }
.value-icon{
  flex:none; width:40px; height:40px; border-radius:50%;
  background:rgba(198,162,92,0.12); display:flex; align-items:center; justify-content:center;
}
.value-icon svg{ width:19px; height:19px; color:var(--gold-500); }
.value-item h4{ font-family:var(--font-body); font-size:15.5px; font-weight:700; color:var(--white); margin-bottom:4px; }
.value-item p{ font-size:14.5px; color:rgba(248,246,241,0.68); }

/* ---------- como funciona ---------- */
.process{ background:var(--ivory-50); }
.process-list{ counter-reset:step; display:grid; gap:0; border-top:1px solid var(--line); }
.process-item{
  counter-increment:step; border-bottom:1px solid var(--line);
  padding:30px 0; display:grid; gap:6px 28px; align-items:start;
}
@media(min-width:760px){ .process-item{ grid-template-columns:90px 1fr; padding:38px 0; } }
.process-num{
  font-family:var(--font-display); font-size:15px; font-weight:600; color:var(--gold-600);
}
.process-num::before{ content:"0" counter(step); font-size:34px; display:block; line-height:1; margin-bottom:4px; color:var(--navy-800); }
.process-item h3{ font-size:20px; margin-bottom:8px; color:var(--ink-900); }
.process-item p{ color:var(--ink-500); font-size:15.5px; max-width:620px; }

/* ---------- vantagens / comparativo ---------- */
.compare{ background:var(--navy-900); color:var(--ivory-50); }
.compare-table{ display:grid; grid-template-columns:1fr; gap:2px; background:var(--line-dark); border:1px solid var(--line-dark); border-radius:var(--radius); overflow:hidden; }
@media(min-width:760px){ .compare-table{ grid-template-columns:1.1fr 1fr 1fr; } }
.compare-cell{ background:var(--navy-900); padding:18px 22px; font-size:14.5px; }
.compare-head{ background:var(--navy-800); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:.06em; }
.compare-head.gold{ color:var(--navy-950); background:var(--gold-500); }
.compare-row-label{ color:rgba(248,246,241,0.55); font-weight:700; font-size:13px; text-transform:uppercase; letter-spacing:.04em; }
.compare-cell.win{ background:rgba(198,162,92,0.08); color:var(--ivory-50); font-weight:600; }
.compare-cell.lose{ color:rgba(248,246,241,0.6); }
.compare-note{ margin-top:18px; font-size:12.5px; color:rgba(248,246,241,0.5); }

/* ---------- área de atuação ---------- */
.area{ background:var(--ivory-50); }
.area-layout{ display:grid; gap:36px; }
@media(min-width:900px){ .area-layout{ grid-template-columns:1fr 1fr; gap:48px; align-items:stretch; } }
.area-map{ border-radius:var(--radius); overflow:hidden; border:1px solid var(--line); min-height:320px; filter:grayscale(0.25) contrast(1.05); }
.area-map iframe{ width:100%; height:100%; min-height:320px; border:0; display:block; }
.area-info{ display:flex; flex-direction:column; justify-content:center; }
.area-info h3{ font-size:24px; margin-bottom:14px; }
.area-info p{ color:var(--ink-500); font-size:16px; margin-bottom:24px; }
.area-facts{ display:grid; gap:16px; }
.area-fact{ display:flex; gap:14px; align-items:flex-start; padding:16px; background:var(--white); border:1px solid var(--line); border-radius:var(--radius); }
.area-fact svg{ width:20px; height:20px; color:var(--gold-600); flex:none; margin-top:2px; }
.area-fact b{ display:block; font-size:14.5px; color:var(--ink-900); margin-bottom:2px; }
.area-fact span{ font-size:14px; color:var(--ink-500); }

/* ---------- depoimentos ---------- */
.testimonials{ background:var(--navy-900); color:var(--ivory-50); }
.t-card{
  background:var(--navy-800); border:1px dashed rgba(230,214,170,0.28);
  border-radius:var(--radius); padding:28px; display:flex; flex-direction:column; gap:16px; min-height:200px;
}
.t-card .t-quote{ font-family:var(--font-display); font-style:italic; font-size:16px; color:rgba(248,246,241,0.4); }
.t-card .t-placeholder{
  display:flex; align-items:center; gap:10px; font-size:13px; font-weight:700;
  text-transform:uppercase; letter-spacing:.05em; color:var(--gold-300); margin-top:auto;
}
.t-card .t-placeholder svg{ width:16px; height:16px; }

/* ---------- FAQ ---------- */
.faq{ background:var(--ivory-50); }
.faq-list{ border-top:1px solid var(--line); max-width:820px; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{
  width:100%; background:none; border:0; text-align:left;
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  padding:22px 4px; font-family:var(--font-display); font-size:18px; color:var(--ink-900);
}
.faq-q .plus{
  flex:none; width:26px; height:26px; border-radius:50%; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; position:relative; transition:transform .25s, border-color .25s;
}
.faq-q .plus::before, .faq-q .plus::after{ content:""; position:absolute; background:var(--navy-800); transition:transform .25s; }
.faq-q .plus::before{ width:11px; height:1.5px; }
.faq-q .plus::after{ width:1.5px; height:11px; }
.faq-item.open .faq-q .plus{ border-color:var(--gold-500); transform:rotate(45deg); }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .3s ease; }
.faq-a p{ padding:0 30px 22px 4px; color:var(--ink-500); font-size:15.5px; max-width:680px; }

/* ---------- blog preview ---------- */
.blog-preview{ background:var(--ivory-50); }
.post-card{
  background:var(--white); border:1px solid var(--line); border-radius:var(--radius);
  overflow:hidden; display:flex; flex-direction:column; transition:transform .2s, box-shadow .2s;
}
.post-card:hover{ transform:translateY(-3px); box-shadow:0 14px 30px rgba(11,27,51,0.08); }
.post-card-body{ padding:24px; display:flex; flex-direction:column; gap:10px; flex:1; }
.post-tag{ font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--gold-600); }
.post-card h3{ font-size:19px; line-height:1.3; }
.post-card p{ color:var(--ink-500); font-size:14.5px; flex:1; }
.post-meta{ font-size:12.5px; color:var(--ink-500); font-weight:600; margin-top:6px; }
.post-link{ display:inline-flex; align-items:center; gap:6px; font-weight:700; font-size:14px; color:var(--navy-800); margin-top:4px; }
.post-link svg{ width:14px; height:14px; transition:transform .2s; }
.post-card:hover .post-link svg{ transform:translateX(3px); }
.post-card.soon{ opacity:.55; }
.post-card.soon .post-card-body{ pointer-events:none; }

.section-cta-row{ display:flex; justify-content:center; margin-top:40px; }

/* ---------- contato ---------- */
.contact{ background:var(--navy-950); color:var(--ivory-50); position:relative; overflow:hidden; }
.contact-layout{ display:grid; gap:48px; position:relative; z-index:2; }
@media(min-width:960px){ .contact-layout{ grid-template-columns:0.85fr 1.15fr; gap:72px; } }
.contact-info p{ color:rgba(248,246,241,0.72); font-size:16px; margin-bottom:28px; }
.contact-channels{ display:grid; gap:14px; }
.contact-channel{
  display:flex; align-items:center; gap:14px; padding:16px 18px;
  background:var(--navy-800); border:1px solid var(--line-dark); border-radius:var(--radius);
  transition:border-color .2s;
}
.contact-channel:hover{ border-color:var(--gold-500); }
.contact-channel svg{ width:20px; height:20px; color:var(--gold-500); flex:none; }
.contact-channel b{ display:block; font-size:13px; text-transform:uppercase; letter-spacing:.05em; color:rgba(248,246,241,0.55); }
.contact-channel span{ font-size:15.5px; font-weight:600; }

.form-card{ background:var(--ivory-50); border-radius:var(--radius); padding:clamp(24px,4vw,40px); color:var(--ink-900); }
.form-card h3{ font-size:22px; margin-bottom:6px; }
.form-card > p{ color:var(--ink-500); font-size:14.5px; margin-bottom:24px; }
.field{ margin-bottom:18px; }
.field label{ display:block; font-size:13px; font-weight:700; margin-bottom:7px; color:var(--ink-700); }
.field input, .field textarea, .field select{
  width:100%; padding:13px 14px; border:1px solid var(--line); border-radius:3px;
  font-family:inherit; font-size:15px; background:var(--white); color:var(--ink-900);
  transition:border-color .2s;
}
.field input:focus, .field textarea:focus, .field select:focus{ border-color:var(--gold-600); outline:none; }
.field textarea{ resize:vertical; min-height:100px; }
.form-row{ display:grid; gap:18px; }
@media(min-width:560px){ .form-row{ grid-template-columns:1fr 1fr; } }
.form-note{ font-size:12.5px; color:var(--ink-500); margin-top:14px; }
.btn-block{ width:100%; }

/* ---------- footer ---------- */
.site-footer{ background:var(--navy-950); color:rgba(248,246,241,0.6); padding:56px 0 28px; border-top:1px solid var(--line-dark); }
.footer-top{ display:grid; gap:36px; padding-bottom:36px; border-bottom:1px solid var(--line-dark); }
@media(min-width:760px){ .footer-top{ grid-template-columns:1.3fr 1fr 1fr; } }
.footer-brand .brand-name{ color:var(--ivory-50); }
.footer-brand p{ margin-top:14px; font-size:14px; max-width:320px; line-height:1.7; }
.footer-col h5{ font-size:13px; text-transform:uppercase; letter-spacing:.08em; color:var(--gold-300); font-weight:700; margin-bottom:16px; }
.footer-col ul{ display:grid; gap:11px; }
.footer-col a{ font-size:14.5px; transition:color .2s; }
.footer-col a:hover{ color:var(--gold-500); }
.footer-bottom{ padding-top:24px; display:flex; flex-wrap:wrap; gap:12px; justify-content:space-between; font-size:12.5px; }

/* ---------- botão flutuante whatsapp ---------- */
.wpp-float{
  position:fixed; right:20px; bottom:20px; z-index:60;
  width:56px; height:56px; border-radius:50%; background:#25D366;
  display:flex; align-items:center; justify-content:center; box-shadow:0 8px 24px rgba(0,0,0,0.25);
  transition:transform .2s;
}
.wpp-float:hover{ transform:scale(1.06); }
.wpp-float svg{ width:28px; height:28px; color:#fff; }

/* ---------- artigo do blog ---------- */
.article-hero{ padding-top:clamp(48px,7vw,72px); padding-bottom:40px; }
.article-hero .hero-inner{ max-width:760px; }
.article-meta-row{ display:flex; flex-wrap:wrap; gap:10px 22px; margin-top:26px; font-size:13.5px; color:rgba(248,246,241,0.6); font-weight:600; }
.article-meta-row span{ display:flex; align-items:center; gap:7px; }
.article-meta-row svg{ width:15px; height:15px; color:var(--gold-500); }

.article-body{ background:var(--ivory-50); padding:var(--gap-section) 0; }
.article-content{ max-width:720px; margin:0 auto; }
.article-content > p{ font-size:17px; color:var(--ink-700); margin-bottom:22px; }
.article-content h2{ font-size:26px; margin-top:44px; margin-bottom:16px; color:var(--ink-900); }
.article-content h3{ font-size:20px; margin-top:32px; margin-bottom:12px; color:var(--ink-900); }
.article-content ul{ margin-bottom:22px; display:grid; gap:10px; }
.article-content ul li{ position:relative; padding-left:26px; color:var(--ink-700); font-size:16.5px; }
.article-content ul li::before{ content:""; position:absolute; left:0; top:9px; width:8px; height:8px; border-radius:50%; background:var(--gold-500); }
.article-content ol{ margin:0 0 22px; padding-left:22px; display:grid; gap:10px; }
.article-content ol li{ color:var(--ink-700); font-size:16.5px; padding-left:6px; }
.article-content strong{ color:var(--ink-900); }
.article-content blockquote{
  border-left:3px solid var(--gold-500); margin:28px 0; padding:4px 0 4px 22px;
  font-family:var(--font-display); font-style:italic; font-size:19px; color:var(--ink-900);
}
.article-cta{
  margin-top:48px; padding:32px; background:var(--navy-900); color:var(--ivory-50);
  border-radius:var(--radius); text-align:center;
}
.article-cta h3{ font-size:22px; margin-bottom:10px; }
.article-cta p{ color:rgba(248,246,241,0.72); font-size:15px; margin-bottom:22px; max-width:480px; margin-left:auto; margin-right:auto; }
.article-back{ display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:14px; color:var(--navy-800); margin-bottom:28px; }
.article-back svg{ width:16px; height:16px; }

/* ---------- utilitários ---------- */
.text-center{ text-align:center; }
.mt-0{ margin-top:0; }
