/* ====== Claudia Lima — Mediação Imobiliária ====== */
:root{
  --navy:#162947;
  --navy-700:#1d3458;
  --navy-900:#0f1d35;
  --gold:#8f824a;
  --gold-soft:#a99a5e;
  --cream:#f6f3ec;
  --cream-2:#efeadf;
  --paper:#ffffff;
  --ink:#1f2733;
  --ink-soft:#586173;
  --line:#e4ddcf;
  --shadow:0 10px 30px rgba(22,41,71,.10);
  --shadow-lg:0 24px 60px rgba(22,41,71,.18);
  --serif:"Cinzel",Georgia,serif;
  --sans:"Mulish",system-ui,-apple-system,sans-serif;
  --r:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream);
  font-size:18px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.15;margin:0;letter-spacing:.01em}
.wrap{width:min(1180px,92vw);margin-inline:auto}
.eyebrow{font-family:var(--sans);font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:13px;color:var(--gold)}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 26px;border-radius:999px;font-weight:800;font-size:17px;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
  min-height:52px;white-space:nowrap;
}
.btn:active{transform:translateY(1px)}
.btn-gold{background:var(--gold);color:#fff;box-shadow:0 8px 22px rgba(143,130,74,.35)}
.btn-gold:hover{background:var(--gold-soft)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-700)}
.btn-wa{background:#25D366;color:#fff;box-shadow:0 8px 22px rgba(37,211,102,.35)}
.btn-wa:hover{filter:brightness(1.05)}
.btn-ghost{background:transparent;border:1.5px solid rgba(255,255,255,.45);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-outline{background:#fff;border:1.5px solid var(--line);color:var(--navy)}
.btn-outline:hover{border-color:var(--gold)}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:40;background:var(--navy);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.hd-inner{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:14px}
.brand .mark{width:46px;height:46px;flex:none}
.brand .name{font-family:var(--serif);color:var(--cream);line-height:.95}
.brand .name b{display:block;font-size:20px;font-weight:600;letter-spacing:.1em;color:var(--gold)}
.brand .name span{display:block;font-family:var(--sans);font-size:9.5px;letter-spacing:.34em;color:rgba(246,243,236,.7);font-weight:700;margin-top:3px}
.hd-nav{display:flex;align-items:center;gap:28px}
.hd-nav a{color:rgba(246,243,236,.82);font-weight:700;font-size:16px}
.hd-nav a:hover{color:var(--gold)}
.hd-cta{display:flex;align-items:center;gap:10px}
.hd-phone{display:inline-flex;align-items:center;gap:9px;color:var(--cream);font-weight:800;font-size:17px}
.hd-phone svg{color:var(--gold)}
@media(max-width:880px){
  .hd-nav{display:none}
  .hd-phone span{display:none}
  .hd-cta .btn-gold{display:none}
}
@media(max-width:420px){
  .brand .name span{display:none}
  .brand .mark{width:40px;height:40px}
}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.hero-inner{position:relative;z-index:2;padding:72px 0 64px;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center}
.hero h1{font-size:clamp(33px,4.6vw,52px);color:var(--cream);line-height:1.22;letter-spacing:.02em}
.hero h1 em{font-style:normal;color:var(--cream)}
.hero p.lead{font-size:19px;color:rgba(246,243,236,.8);max-width:34ch;margin:24px 0 32px;line-height:1.6}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}
.hero-photo{position:relative;border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/5}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;left:18px;bottom:18px;background:rgba(15,29,53,.82);backdrop-filter:blur(6px);border:1px solid rgba(143,130,74,.5);padding:12px 18px;border-radius:14px}
.hero-badge b{display:block;font-family:var(--serif);font-size:24px;color:var(--gold)}
.hero-badge span{font-size:13px;color:rgba(246,243,236,.8);font-weight:700;letter-spacing:.04em}
.hero-stats{display:flex;gap:34px;margin-top:36px;padding-top:26px;border-top:1px solid rgba(255,255,255,.12)}
.hero-stats .st b{font-family:var(--serif);font-size:34px;color:var(--gold);display:block;line-height:1}
.hero-stats .st span{font-size:14px;color:rgba(246,243,236,.7);font-weight:700}
@media(max-width:880px){
  .hero-inner{grid-template-columns:1fr;padding:40px 0 36px;gap:32px}
  .hero-photo{aspect-ratio:16/12;max-height:340px}
  .hero p.lead{font-size:18px;max-width:none}
  .hero-stats{gap:24px}
}

/* ---------- filters ---------- */
.listings{padding:54px 0 30px;background:var(--cream)}
.sec-head{text-align:center;max-width:640px;margin:0 auto 30px}
.sec-head h2{font-size:clamp(32px,4.5vw,46px);color:var(--navy)}
.sec-head p{color:var(--ink-soft);margin:12px 0 0;font-size:18px}
.filters{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  box-shadow:var(--shadow);padding:18px;display:grid;
  grid-template-columns:repeat(4,1fr) auto;gap:14px;align-items:end;margin-bottom:28px;
}
.field{display:flex;flex-direction:column;gap:7px;min-width:0}
.field label{font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.field select,.field input{
  appearance:none;width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;
  background:#fff;font-family:inherit;font-size:16px;font-weight:600;color:var(--ink);min-height:50px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238f824a' stroke-width='3'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;
}
.field input{background-image:none;padding-right:14px}
.field select:focus,.field input:focus{outline:none;border-color:var(--gold)}
.filters .clearbtn{padding:13px 18px;border-radius:12px;border:1.5px solid var(--line);background:#fff;font-weight:800;color:var(--navy);min-height:50px;white-space:nowrap}
.filters .clearbtn:hover{border-color:var(--gold);color:var(--gold)}
.result-count{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.result-count .n{font-weight:800;color:var(--navy);font-size:17px}
.result-count .n b{color:var(--gold)}
@media(max-width:880px){
  .filters{grid-template-columns:1fr 1fr;padding:14px}
  .filters .clearbtn{grid-column:1/-1}
}

/* ---------- property cards ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:980px){.grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){.grid{grid-template-columns:1fr}}
.card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);overflow:hidden;
  box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .25s ease;display:flex;flex-direction:column;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card-media{position:relative;aspect-ratio:4/3;overflow:hidden;cursor:pointer;background:var(--cream-2)}
.card-media img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.card:hover .card-media img{transform:scale(1.05)}
.tag{position:absolute;top:14px;left:14px;background:var(--gold);color:#fff;font-weight:800;font-size:13px;letter-spacing:.05em;padding:7px 13px;border-radius:999px;text-transform:uppercase}
.tag.sold{background:var(--navy)}
.photo-count{position:absolute;bottom:12px;right:12px;background:rgba(15,29,53,.78);color:#fff;font-weight:700;font-size:13px;padding:6px 11px;border-radius:999px;display:flex;align-items:center;gap:6px}
.card-body{padding:20px 20px 22px;display:flex;flex-direction:column;gap:14px;flex:1}
.card-price{font-family:var(--serif);font-size:30px;font-weight:600;color:var(--navy);line-height:1}
.card-title{font-weight:800;font-size:18px;color:var(--ink);margin:0}
.card-loc{display:flex;align-items:center;gap:7px;color:var(--ink-soft);font-size:15px;font-weight:600}
.card-loc svg{color:var(--gold);flex:none}
.specs{display:flex;gap:16px;padding-top:14px;border-top:1px solid var(--line);margin-top:auto;color:var(--ink-soft);font-weight:700;font-size:14.5px}
.specs .sp{display:flex;align-items:center;gap:7px}
.specs svg{color:var(--gold)}
.card-cta{display:flex;gap:10px;padding-top:4px}
.card-cta .btn{flex:1;padding:12px 16px;font-size:15px;min-height:48px}

/* ---------- about ---------- */
.about{background:var(--navy);color:#fff;padding:70px 0}
.about-inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:center}
.about-photo{border-radius:24px;overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:1/1}
.about-photo img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.about h2{font-size:clamp(30px,4vw,44px);color:var(--cream);margin-bottom:8px}
.about .role{color:var(--gold);font-weight:800;letter-spacing:.04em;margin-bottom:18px;font-size:16px}
.about p{color:rgba(246,243,236,.82);font-size:18px;margin:0 0 16px;max-width:54ch}
.about .ami{display:inline-flex;gap:10px;align-items:center;margin-top:8px;color:rgba(246,243,236,.7);font-weight:700;font-size:15px;border:1px solid rgba(143,130,74,.5);padding:9px 16px;border-radius:999px}
@media(max-width:880px){.about-inner{grid-template-columns:1fr;gap:30px}.about{padding:50px 0}}

/* ---------- contact ---------- */
.contact{padding:70px 0 90px;background:var(--cream)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact h2{font-size:clamp(30px,4vw,44px);color:var(--navy)}
.contact .sub{color:var(--ink-soft);font-size:18px;margin:12px 0 26px}
.contact-list{display:flex;flex-direction:column;gap:14px}
.cl-item{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px 18px;box-shadow:var(--shadow)}
.cl-item .ic{width:46px;height:46px;border-radius:12px;background:var(--cream-2);display:grid;place-items:center;color:var(--gold);flex:none}
.cl-item .tx b{display:block;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:800}
.cl-item .tx span{font-size:18px;font-weight:800;color:var(--navy)}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.form .field{margin-bottom:16px}
.form textarea{width:100%;padding:13px 14px;border:1.5px solid var(--line);border-radius:12px;font-family:inherit;font-size:16px;font-weight:600;min-height:110px;resize:vertical}
.form textarea:focus{outline:none;border-color:var(--gold)}
.form .btn{width:100%}
.form .ok{background:#eaf7ee;border:1px solid #bfe6cb;color:#1f7a3d;padding:14px;border-radius:12px;font-weight:700;text-align:center}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;gap:28px}.contact{padding:50px 0 110px}}

/* ---------- footer ---------- */
.site-footer{background:var(--navy-900);color:rgba(246,243,236,.7);padding:34px 0;text-align:center;font-size:15px}
.site-footer .brand{justify-content:center;margin-bottom:14px}
.site-footer a:hover{color:var(--gold)}

/* ---------- mobile sticky bar ---------- */
.mobile-bar{position:fixed;bottom:0;left:0;right:0;z-index:50;display:none;gap:10px;padding:10px 14px calc(10px + env(safe-area-inset-bottom));background:rgba(255,255,255,.96);backdrop-filter:blur(8px);border-top:1px solid var(--line);box-shadow:0 -8px 24px rgba(22,41,71,.1)}
.mobile-bar .btn{flex:1;min-height:48px;padding:12px 16px;font-size:15px;gap:8px;box-shadow:none}
@media(max-width:880px){.mobile-bar{display:flex}body{padding-bottom:calc(72px + env(safe-area-inset-bottom))}}

/* ---------- modal gallery ---------- */
.modal-back{position:fixed;inset:0;z-index:80;background:rgba(10,18,33,.78);backdrop-filter:blur(4px);display:grid;place-items:center;padding:18px;animation:fade .2s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--paper);border-radius:22px;overflow:hidden;width:min(960px,100%);max-height:92vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.modal-gallery{position:relative;background:#0f1d35;aspect-ratio:16/10;flex:none}
.modal-gallery img{width:100%;height:100%;object-fit:cover}
.mg-nav{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.9);display:grid;place-items:center;color:var(--navy);box-shadow:var(--shadow)}
.mg-nav:hover{background:#fff}
.mg-nav.prev{left:14px}.mg-nav.next{right:14px}
.mg-dots{position:absolute;bottom:14px;left:0;right:0;display:flex;justify-content:center;gap:8px}
.mg-dots i{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.5);cursor:pointer}
.mg-dots i.on{background:var(--gold);width:22px;border-radius:999px}
.modal-close{position:absolute;top:14px;right:14px;width:44px;height:44px;border-radius:50%;background:rgba(15,29,53,.7);color:#fff;display:grid;place-items:center;z-index:3}
.modal-body{padding:24px 26px 26px;overflow:auto}
.modal-body .price{font-family:var(--serif);font-size:36px;color:var(--navy);font-weight:600;line-height:1}
.modal-body h3{font-size:24px;margin:8px 0 6px;color:var(--ink)}
.modal-specs{display:flex;flex-wrap:wrap;gap:18px;margin:18px 0;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.modal-specs .sp{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--ink-soft)}
.modal-specs svg{color:var(--gold)}
.modal-desc{color:var(--ink-soft);font-size:17px;margin:0 0 20px}
.modal-feats{display:flex;flex-wrap:wrap;gap:9px;margin-bottom:22px}
.modal-feats span{background:var(--cream);border:1px solid var(--line);color:var(--navy);font-weight:700;font-size:14px;padding:7px 13px;border-radius:999px}
.modal-cta{display:flex;gap:12px;flex-wrap:wrap}
.modal-cta .btn{flex:1;min-width:160px}
@media(max-width:620px){.modal-gallery{aspect-ratio:4/3}.modal-body .price{font-size:30px}}

/* ====== Animations ====== */
@media(prefers-reduced-motion:no-preference){

  /* scroll reveal */
  [data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.22,.61,.36,1),transform .7s cubic-bezier(.22,.61,.36,1)}
  [data-reveal].is-in{opacity:1;transform:none}

  /* hero entrance on load */
  .hero h1,.hero .eyebrow,.hero p.lead,.hero-actions{opacity:0;animation:heroUp .8s cubic-bezier(.22,.61,.36,1) forwards}
  .hero .eyebrow{animation-delay:.05s}
  .hero h1{animation-delay:.15s}
  .hero p.lead{animation-delay:.28s}
  .hero-actions{animation-delay:.4s}
  .hero-photo{opacity:0;animation:heroReveal 1s cubic-bezier(.22,.61,.36,1) .25s forwards}
  @keyframes heroUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}
  @keyframes heroReveal{from{opacity:0;transform:scale(1.04)}to{opacity:1;transform:none}}

  /* link underline grow */
  .hd-nav a{position:relative}
  .hd-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:2px;background:var(--gold);transition:right .28s ease}
  .hd-nav a:hover::after{right:0}

  /* button lift */
  .btn{transition:transform .18s cubic-bezier(.22,.61,.36,1),box-shadow .25s ease,background .2s ease,filter .2s ease}
  .btn:hover{transform:translateY(-2px)}
  .btn:active{transform:translateY(0)}

  /* contact item slide */
  .cl-item{transition:transform .2s ease,box-shadow .25s ease,border-color .2s ease}
  a.cl-item:hover{transform:translateX(4px);border-color:var(--gold);box-shadow:var(--shadow-lg)}

  /* tag pulse on availability */
  .tag:not(.sold){animation:tagPulse 2.6s ease-in-out infinite}
  @keyframes tagPulse{0%,100%{box-shadow:0 0 0 0 rgba(143,130,74,.45)}50%{box-shadow:0 0 0 7px rgba(143,130,74,0)}}

  /* modal entrance */
  .modal{animation:modalUp .35s cubic-bezier(.22,.61,.36,1)}
  @keyframes modalUp{from{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:none}}

  /* spinner for busy form button */
  .btn .spin{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
  @keyframes spin{to{transform:rotate(360deg)}}
}
