*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --blue:   #1a73e8;
  --blue-d: #1557b0;
  --text:   #1f2937;
  --muted:  #6b7280;
  --bg:     #f8fafc;
  --white:  #ffffff;
  --border: #e5e7eb;
  --radius: 12px;
}

body { font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
       color: var(--text); background: var(--bg); line-height: 1.6; }

.container { max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* Header */
.header { background: var(--white); border-bottom: 1px solid var(--border);
          position: sticky; top: 0; z-index: 100; }
.header .container { display:flex; align-items:center; gap:24px; height:64px; }
.logo { display:flex; align-items:center; gap:10px; font-weight:700; font-size:1.1rem; text-decoration:none; color:var(--text); }
.nav { display:flex; gap:20px; margin-left:auto; }
.nav a { text-decoration:none; color:var(--muted); font-size:.9rem; transition:color .2s; }
.nav a:hover { color:var(--blue); }

/* Buttons */
.btn { padding:10px 20px; border-radius:8px; border:none; cursor:pointer; font-size:.9rem; font-weight:600; transition:.2s; }
.btn-primary  { background:var(--blue); color:#fff; }
.btn-primary:hover  { background:var(--blue-d); }
.btn-outline  { background:transparent; color:var(--blue); border:1.5px solid var(--blue); }
.btn-outline:hover  { background:var(--blue); color:#fff; }

/* Hero */
.hero { background:linear-gradient(135deg,#1a73e8 0%,#0d47a1 100%); color:#fff; padding:72px 0 60px; }
.hero h1 { font-size:clamp(1.8rem,4vw,2.8rem); line-height:1.25; margin-bottom:16px; }
.hero-sub { font-size:1.1rem; opacity:.88; margin-bottom:36px; max-width:540px; }
.search-bar { display:flex; gap:10px; flex-wrap:wrap; background:rgba(255,255,255,.15); backdrop-filter:blur(8px); padding:12px; border-radius:12px; max-width:640px; }
.search-bar select, .search-bar input { flex:1; min-width:140px; padding:10px 14px; border:none; border-radius:8px; font-size:.95rem; }
.search-bar button { flex-shrink:0; }

/* Stats */
.stats { background:var(--white); border-bottom:1px solid var(--border); }
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:0; }
.stat { text-align:center; padding:28px 16px; border-right:1px solid var(--border); }
.stat:last-child { border-right:none; }
.stat-num   { display:block; font-size:1.8rem; font-weight:700; color:var(--blue); }
.stat-label { display:block; font-size:.85rem; color:var(--muted); margin-top:4px; }

/* Services */
.services { padding:64px 0; }
.services h2, .objects h2, .contacts h2 { font-size:1.75rem; margin-bottom:32px; }
.cards { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.card { background:var(--white); border:1px solid var(--border); border-radius:var(--radius);
        padding:28px 24px; transition:box-shadow .2s; }
.card:hover { box-shadow:0 8px 30px rgba(0,0,0,.08); }
.card-icon { font-size:2rem; margin-bottom:14px; }
.card h3 { font-size:1.1rem; margin-bottom:8px; }
.card p  { color:var(--muted); font-size:.9rem; }

/* Listings */
.objects { padding:64px 0; background:var(--white); }
.listings { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.listing { border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.listing-img { height:160px; position:relative; }
.badge { position:absolute; top:12px; left:12px; background:var(--blue); color:#fff;
         font-size:.75rem; font-weight:600; padding:3px 10px; border-radius:20px; }
.badge-rent { background:#2e7d32; }
.badge-sec  { background:#e65100; }
.listing-info { padding:16px; }
.listing-info h4 { font-size:1rem; margin-bottom:4px; }
.listing-addr { font-size:.82rem; color:var(--muted); margin-bottom:8px; }
.listing-price { font-size:1.1rem; font-weight:700; color:var(--blue); }

/* Contacts */
.contacts { padding:64px 0; }
.contacts-grid { display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:start; }
.contacts p { margin-bottom:10px; font-size:.95rem; }
.contact-form { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); padding:28px; }
.contact-form h3 { margin-bottom:20px; }
.contact-form input, .contact-form textarea {
  display:block; width:100%; padding:10px 14px; margin-bottom:14px;
  border:1px solid var(--border); border-radius:8px; font-size:.9rem; font-family:inherit; }
.contact-form textarea { height:90px; resize:vertical; }

/* Footer */
.footer { background:var(--text); color:rgba(255,255,255,.6); padding:24px 0; font-size:.82rem; text-align:center; }

/* Modal */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5);
                 backdrop-filter:blur(3px); z-index:999; align-items:center; justify-content:center; }
.modal { background:var(--white); border-radius:var(--radius); padding:36px 32px;
         width:100%; max-width:400px; position:relative; }
.modal-close { position:absolute; top:14px; right:18px; background:none; border:none;
               font-size:1.5rem; cursor:pointer; color:var(--muted); }
.modal h3 { font-size:1.3rem; margin-bottom:6px; }
.modal-sub { color:var(--muted); font-size:.88rem; margin-bottom:22px; }
.modal label { display:block; font-size:.85rem; font-weight:600; margin-bottom:5px; }
.modal input { display:block; width:100%; padding:10px 14px; margin-bottom:16px;
               border:1px solid var(--border); border-radius:8px; font-size:.9rem; }
.modal-remember { display:flex; justify-content:space-between; align-items:center;
                  font-size:.85rem; margin-bottom:20px; }
.modal-remember a { color:var(--blue); text-decoration:none; }

@media(max-width:768px){
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .cards, .listings, .contacts-grid { grid-template-columns:1fr; }
  .nav { display:none; }
}
