/*
Theme Name: Éder Mendes - Consultor Imobiliário
Theme URI: https://edermendes.pt
Author: Éder Mendes
Author URI: https://edermendes.pt
Description: Tema premium para consultor imobiliário de luxo em Lisboa. Century 21 Nações.
Version: 1.0.1
License: Private
License URI: #
Text Domain: eder-mendes
Tags: real-estate, luxury, premium, portuguese
*/

/* === DESIGN SYSTEM === */
:root {
  --ink:     #0A0A0A;
  --navy:    #0B1929;
  --navy2:   #0F2236;
  --gold:    #C9A96E;
  --copper:  #B8845A;
  --cream:   #F7F3EE;
  --mist:    #F0EDE8;
  --white:   #FFFFFF;
  --grey:    #8A8A8A;
  --light:   #E8E4DF;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body:    'Outfit', system-ui, sans-serif;

  --radius:  4px;
  --shadow:  0 8px 40px rgba(0,0,0,0.12);
  --shadow-lg: 0 20px 60px rgba(0,0,0,0.18);

  --nav-h: 80px;
  --section-pad: clamp(60px, 8vw, 120px);
}

/* === RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  font-family: var(--font-body);
  color: var(--ink);
  background: var(--white);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
ul { list-style: none; }

/* === TYPOGRAPHY === */
h1,h2,h3,h4,h5 {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.2;
}
.display { font-size: clamp(2.8rem,5vw,5rem); font-weight: 300; letter-spacing:-0.02em; }
.headline { font-size: clamp(2rem,3.5vw,3.2rem); font-weight: 500; }
.subhead  { font-size: clamp(1.3rem,2vw,1.8rem); font-weight: 300; }
.label    { font-family:var(--font-body); font-size:.75rem; letter-spacing:.15em; text-transform:uppercase; font-weight:500; }
.gold     { color: var(--gold); }
.cream-bg { background: var(--cream); }
.navy-bg  { background: var(--navy); color: var(--white); }

/* === LAYOUT === */
.container { max-width: 1240px; margin: 0 auto; padding: 0 clamp(20px,4vw,60px); }
.section-pad { padding: var(--section-pad) 0; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,4vw,60px); }
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,3vw,40px); }
.flex   { display:flex; align-items:center; }
.flex-between { display:flex; align-items:center; justify-content:space-between; }

/* === CURSOR === */
.cursor-dot  { width:6px; height:6px; background:var(--gold); border-radius:50%; position:fixed; pointer-events:none; z-index:9999; transform:translate(-50%,-50%); transition:transform .15s; }
.cursor-ring { width:32px; height:32px; border:1px solid var(--gold); border-radius:50%; position:fixed; pointer-events:none; z-index:9998; transform:translate(-50%,-50%); transition:transform .25s, width .25s, height .25s, opacity .25s; opacity:.7; }

/* === NAVBAR === */
.site-nav {
  position: fixed; top:0; left:0; right:0; z-index:1000;
  height: var(--nav-h);
  padding: 0 clamp(20px,4vw,60px);
  display: flex; align-items:center; justify-content:space-between;
  /* Always dark — never transparent on white pages */
  background: rgba(11,25,41,0.97);
  backdrop-filter: blur(20px);
  box-shadow: 0 1px 0 rgba(201,169,110,0.2);
  transition: background .4s, backdrop-filter .4s, box-shadow .4s;
}
.site-nav.scrolled {
  background: rgba(11,25,41,0.97);
  backdrop-filter: blur(20px);
  box-shadow: 0 1px 0 rgba(201,169,110,0.2);
}
.nav-logo { display:flex; align-items:center; gap:14px; text-decoration:none; }
.nav-logo-mark {
  width:44px; height:44px; border-radius:50%;
  background: linear-gradient(135deg, var(--gold), var(--copper));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:1.1rem; color:var(--white); font-weight:600;
}
.nav-logo-text { font-family:var(--font-display); font-size:1.1rem; color:var(--white); letter-spacing:.05em; }
.nav-links { display:flex; align-items:center; gap:clamp(20px,3vw,40px); }
.nav-links a { color:rgba(255,255,255,.85); font-size:.9rem; letter-spacing:.04em; transition:color .2s; }
.nav-links a:hover { color:var(--gold); }
.nav-cta {
  padding: 10px 22px; border:1px solid var(--gold); color:var(--gold);
  font-size:.85rem; letter-spacing:.08em; text-transform:uppercase;
  transition: background .2s, color .2s;
}
.nav-cta:hover { background:var(--gold); color:var(--navy); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; padding:8px; }
.nav-hamburger span { display:block; width:24px; height:1.5px; background:var(--white); transition:.3s; }

/* === HERO === */
.hero {
  height: 100vh; min-height:600px;
  position: relative; display:grid; grid-template-columns: 1fr 1fr;
  background: linear-gradient(135deg, #0B1929 0%, #162840 40%, #0D2035 70%, #0B1929 100%);
  overflow: hidden;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse 80% 60% at 70% 40%, rgba(201,169,110,.08) 0%, transparent 60%),
              radial-gradient(ellipse 40% 40% at 20% 80%, rgba(201,169,110,.05) 0%, transparent 50%);
}
.hero-shapes { position:absolute; inset:0; overflow:hidden; pointer-events:none; }
.hero-shape {
  position:absolute; border-radius:50%;
  border:1px solid rgba(201,169,110,.1);
}
.hero-shape-1 { width:600px; height:600px; right:-150px; top:-100px; }
.hero-shape-2 { width:400px; height:400px; right:50px; top:50px; border-color:rgba(201,169,110,.06); }
.hero-shape-3 { width:200px; height:200px; left:10%; bottom:20%; border-color:rgba(201,169,110,.08); }
.hero-content {
  position:relative; z-index:2;
  max-width:760px; padding: 0 clamp(20px,4vw,60px);
  margin-top: 60px;
}
.hero-eyebrow { color:var(--gold); font-size:.8rem; letter-spacing:.2em; text-transform:uppercase; margin-bottom:20px; opacity:0; animation:fadeUp .8s .3s forwards; }
.hero h1 { color:var(--white); margin-bottom:16px; opacity:0; animation:fadeUp .8s .5s forwards; }
.hero-divider { width:60px; height:1px; background:var(--gold); margin:24px 0; opacity:0; animation:fadeUp .8s .7s forwards; }
.hero-sub { color:rgba(255,255,255,.7); font-size:1.05rem; max-width:500px; margin-bottom:40px; opacity:0; animation:fadeUp .8s .9s forwards; }
.hero-actions { display:flex; gap:16px; flex-wrap:wrap; opacity:0; animation:fadeUp .8s 1.1s forwards; }
.btn-primary {
  padding:14px 32px; background:var(--gold); color:var(--navy);
  font-size:.9rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase;
  transition: transform .2s, box-shadow .2s;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 30px rgba(201,169,110,.35); }
.btn-outline {
  padding:14px 32px; border:1px solid rgba(255,255,255,.4); color:var(--white);
  font-size:.9rem; letter-spacing:.05em; text-transform:uppercase;
  transition: border-color .2s, background .2s;
}
.btn-outline:hover { border-color:var(--gold); background:rgba(201,169,110,.08); }
.hero-scroll {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,.5); font-size:.75rem; letter-spacing:.1em;
  animation:bounce 2s infinite;
}
.hero-scroll svg { opacity:.5; }

/* === STATS BAR === */
.stats-bar {
  background: var(--navy2);
  border-top:1px solid rgba(201,169,110,.15);
  border-bottom:1px solid rgba(201,169,110,.15);
  padding: 40px 0;
}
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.stat-item { text-align:center; padding:20px; }
.stat-number {
  font-family:var(--font-display); font-size:clamp(2rem,3vw,2.8rem);
  color:var(--gold); font-weight:600; display:block; line-height:1;
}
.stat-label { color:rgba(255,255,255,.6); font-size:.85rem; margin-top:8px; letter-spacing:.05em; }

/* === SERVICES === (design, background e padding definidos em v2.css — não sobrescrever) */

/* === PROPERTIES === (layout only — cores e design vêm do v2.css) */
.properties { padding: var(--section-pad) 0; }
/* NÃO definir background/border aqui — v2.css tem o design escuro correto */

/* === ABOUT === (layout e design definidos em v2.css — não sobrescrever) */

/* === TESTIMONIALS === (layout e design definidos em v2.css — não sobrescrever) */
.testi-slider { position:relative; overflow:hidden; }
.testi-track { display:flex; transition:transform .5s cubic-bezier(.25,.1,.25,1); }
.testi-slide { flex:0 0 100%; padding:0 20px; }
.testi-card {
  max-width:760px; margin:0 auto; text-align:center;
  padding:clamp(30px,4vw,60px);
}
.testi-stars { display:flex; justify-content:center; gap:4px; margin-bottom:24px; }
.testi-star { color:var(--gold); font-size:1rem; }
.testi-quote-icon { font-family:var(--font-display); font-size:5rem; color:var(--gold); line-height:.8; opacity:.3; margin-bottom:8px; }
.testi-text { font-family:var(--font-display); font-size:clamp(1.1rem,2vw,1.4rem); color:var(--white); font-style:italic; line-height:1.7; margin-bottom:32px; }
.testi-author { color:var(--gold); font-size:.9rem; font-weight:600; letter-spacing:.05em; }
.testi-role   { color:rgba(255,255,255,.5); font-size:.8rem; margin-top:4px; }
.testi-dots   { display:flex; justify-content:center; gap:8px; margin-top:40px; }
.testi-dot    { width:6px; height:6px; border-radius:50%; background:rgba(255,255,255,.2); cursor:pointer; transition:.2s; }
.testi-dot.active { background:var(--gold); }

/* === CONTACT === */
.contact-cta { padding: var(--section-pad) 0; background: linear-gradient(135deg, var(--navy), #0F2236); position:relative; overflow:hidden; }
.contact-cta::before {
  content:''; position:absolute; top:-50%; right:-10%; width:500px; height:500px;
  border-radius:50%; border:1px solid rgba(201,169,110,.06);
}
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,80px); align-items:start; }
.contact-info .label { color:var(--gold); margin-bottom:16px; display:block; }
.contact-info h2 { color:var(--white); margin-bottom:16px; }
.contact-info p  { color:rgba(255,255,255,.7); line-height:1.8; margin-bottom:32px; }
.contact-details { display:flex; flex-direction:column; gap:16px; }
.contact-detail { display:flex; align-items:center; gap:14px; color:rgba(255,255,255,.8); font-size:.9rem; }
.contact-detail-icon { width:40px; height:40px; border:1px solid rgba(201,169,110,.3); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; color:var(--gold); }
.contact-form { background:rgba(255,255,255,.05); border:1px solid rgba(201,169,110,.15); padding:clamp(24px,4vw,40px); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-group { margin-bottom:16px; }
.form-group label { display:block; color:rgba(255,255,255,.6); font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; margin-bottom:8px; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%; background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  color:var(--white); padding:12px 16px; font-family:var(--font-body); font-size:.95rem;
  transition:border-color .2s; outline:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus { border-color:var(--gold); }
.form-group select option { background:var(--navy); }
.form-group textarea { resize:vertical; min-height:120px; }
.btn-submit {
  width:100%; padding:16px; background:var(--gold); color:var(--navy);
  font-size:.9rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  transition:background .2s, transform .2s;
}
.btn-submit:hover { background:#d4b07a; transform:translateY(-1px); }

/* === FOOTER === */
.site-footer { background:var(--ink); padding:60px 0 30px; border-top:1px solid rgba(201,169,110,.1); }
.footer-grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; margin-bottom:50px; }
.footer-brand .nav-logo { margin-bottom:16px; }
.footer-brand p { color:rgba(255,255,255,.5); font-size:.85rem; line-height:1.7; }
.footer-col h4 { color:var(--white); font-family:var(--font-display); font-size:1rem; margin-bottom:16px; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { color:rgba(255,255,255,.5); font-size:.85rem; transition:color .2s; }
.footer-col ul li a:hover { color:var(--gold); }
.footer-bottom { padding-top:24px; border-top:1px solid rgba(255,255,255,.06); display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:16px; }
.footer-legal { color:rgba(255,255,255,.3); font-size:.75rem; }
.footer-socials { display:flex; gap:16px; }
.footer-social { width:36px; height:36px; border:1px solid rgba(255,255,255,.12); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.5); transition:.2s; }
.footer-social:hover { border-color:var(--gold); color:var(--gold); }

/* === SCROLL ANIMATIONS === */
.fade-up, .fade-left, .fade-right, .fade-in {
  opacity:0; transition: opacity .7s ease, transform .7s ease;
}
.fade-up    { transform:translateY(30px); }
.fade-left  { transform:translateX(-30px); }
.fade-right { transform:translateX(30px); }
.fade-up.in, .fade-left.in, .fade-right.in, .fade-in.in { opacity:1; transform:none; }

/* === ANIMATIONS === */
@keyframes fadeUp  { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:none; } }
@keyframes bounce  { 0%,100%{ transform:translateX(-50%) translateY(0); } 50%{ transform:translateX(-50%) translateY(8px); } }

/* === MOBILE === */
@media (max-width:1024px) {
  .svc-grid  { grid-template-columns:1fr; gap:0; }
  .prop-grid { grid-template-columns:1fr 1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .stats-grid  { grid-template-columns:repeat(2,1fr); }
}
@media (max-width:768px) {
  .nav-links, .nav-cta { display:none; }
  .nav-hamburger { display:flex; }
  .nav-links.open {
    display:flex; flex-direction:column; position:fixed; top:var(--nav-h); left:0; right:0;
    background:var(--navy); padding:20px; gap:16px; border-top:1px solid rgba(201,169,110,.15);
  }
  .grid-2, .about-grid, .contact-grid { grid-template-columns:1fr; }
  .prop-grid { grid-template-columns:1fr; }
  .form-row  { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .stats-grid  { grid-template-columns:1fr 1fr; }
  .about-portrait { display:none; }
}
