/* ============================================================
   REALESTATE — bespoke layout (агентство недвижимости)
   Tone: премиум-консультация. Bronze + ivory + graphite.
   Hero search · listings grid · mortgage calc · neighborhood
   ============================================================ */

body[data-niche="realestate"] {
  --bronze:       #B79268;
  --bronze-deep:  #8E6E47;
  --bronze-soft:  #EFE0CB;
  --ivory:        #F4F1EC;
  --paper:        #FFFFFF;
  --oat:          #EAE4DA;
  --char:         #1A1814;
  --char-2:       #3A3530;
  --slate:        #6B6357;
  --hairline:     #DDD3BF;
  --stone:        #1F1D17;

  --surface-page:   var(--ivory);
  --surface-card:   var(--paper);
  --surface-soft:   var(--oat);
  --text-primary:   var(--char);
  --text-secondary: var(--slate);
  --border-soft:    var(--hairline);
  --accent:         var(--bronze);
  --accent-dark:    var(--bronze-deep);

  background: var(--ivory); color: var(--char); font-family: var(--font-sans);
}

body[data-niche="realestate"] h1, body[data-niche="realestate"] h2, body[data-niche="realestate"] h3 {
  font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 500;
  letter-spacing: -0.012em; color: var(--char); line-height: 1.08;
}

/* TOPBAR */
.re-topbar { position: sticky; top: 0; z-index: 30; background: rgba(244,241,236,.92); backdrop-filter: saturate(160%) blur(14px); border-bottom: 1px solid var(--hairline); padding: 16px 0; }
.re-topbar-inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.re-brand { display: inline-flex; align-items: baseline; gap: 8px; font-family: 'Cormorant Garamond', serif; font-size: 24px; font-weight: 500; }
.re-brand small { font-size: 10px; letter-spacing: .24em; text-transform: uppercase; color: var(--bronze); font-family: var(--font-sans); font-weight: 700; padding: 2px 6px; border: 1px solid var(--bronze); }
.re-nav { display: flex; gap: 28px; }
.re-nav a { color: var(--char-2); font-size: 14px; font-weight: 500; }
.re-nav a:hover { color: var(--bronze); }
.re-cta { display: inline-flex; padding: 11px 22px; background: var(--bronze); color: var(--paper); font-size: 13px; font-weight: 700; letter-spacing: .04em; transition: background .25s; }
.re-cta:hover { background: var(--bronze-deep); }
.re-cta.gh { background: transparent; color: var(--bronze-deep); border: 1px solid var(--bronze-deep); }
@media (max-width: 760px) { .re-nav { display: none; } }

/* HERO with search */
.re-hero {
  position: relative; padding: clamp(64px, 8vw, 110px) 0 clamp(48px, 6vw, 80px);
  background:
    radial-gradient(50% 50% at 80% 0%, color-mix(in srgb, var(--bronze) 12%, transparent), transparent 60%),
    var(--ivory);
}
.re-hero h1 { font-size: clamp(44px, 6vw, 84px); line-height: 1.04; margin: 0 0 18px; max-width: 18ch; }
.re-hero h1 i { color: var(--bronze-deep); }
.re-hero-lead { color: var(--char-2); font-size: clamp(16px, 1.4vw, 19px); line-height: 1.6; max-width: 60ch; margin: 0 0 36px; }

.re-search {
  background: var(--paper); border: 1px solid var(--hairline); border-radius: 6px;
  padding: 10px; display: grid; grid-template-columns: repeat(4, 1fr) auto; gap: 8px; align-items: stretch;
  box-shadow: 0 24px 48px -20px rgba(26,24,20,.12);
}
.re-search-tabs { display: flex; gap: 0; grid-column: 1 / -1; padding: 0 6px; border-bottom: 1px solid var(--hairline); margin-bottom: 6px; }
.re-search-tabs button { background: transparent; border: 0; padding: 12px 20px; font: inherit; font-weight: 600; font-size: 13px; letter-spacing: .04em; color: var(--slate); cursor: pointer; position: relative; text-transform: uppercase; }
.re-search-tabs button.active { color: var(--char); }
.re-search-tabs button.active::after { content: ''; position: absolute; left: 20px; right: 20px; bottom: -1px; height: 2px; background: var(--bronze); }
.re-search-field { display: flex; flex-direction: column; padding: 10px 14px; }
.re-search-field label { font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--slate); font-weight: 700; margin-bottom: 4px; }
.re-search-field select, .re-search-field input { border: 0; background: transparent; font: inherit; font-size: 15px; padding: 0; color: var(--char); outline: none; }
.re-search-go { background: var(--char); color: var(--paper); border: 0; font: inherit; font-size: 13px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 0 28px; cursor: pointer; transition: background .25s; }
.re-search-go:hover { background: var(--bronze-deep); }
@media (max-width: 900px) { .re-search { grid-template-columns: 1fr 1fr; } .re-search-go { grid-column: 1 / -1; padding: 16px; } }

.re-hero-stats { margin-top: 36px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; padding-top: 24px; border-top: 1px solid var(--hairline); }
.re-hero-stat { padding-right: 24px; border-right: 1px solid var(--hairline); }
.re-hero-stat:last-child { border-right: 0; padding-right: 0; }
.re-hero-stat strong { display: block; font-family: 'Cormorant Garamond', serif; font-size: clamp(28px, 3.4vw, 42px); color: var(--bronze-deep); margin-bottom: 4px; line-height: 1; }
.re-hero-stat small { color: var(--slate); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; }
@media (max-width: 760px) { .re-hero-stats { grid-template-columns: 1fr 1fr; gap: 24px; } .re-hero-stat:nth-child(2n) { border-right: 0; padding-right: 0; } }

/* SECTIONS */
.re-sec { padding: clamp(72px, 9vw, 110px) 0; }
.re-eyebrow { color: var(--bronze-deep); font-size: 11px; letter-spacing: .26em; text-transform: uppercase; font-weight: 700; margin-bottom: 14px; display: inline-block; }
.re-h2 { font-size: clamp(34px, 4.4vw, 56px); line-height: 1.08; margin: 0 0 14px; letter-spacing: -0.012em; }
.re-h2 i { color: var(--bronze-deep); }
.re-lead { color: var(--char-2); font-size: clamp(15px, 1.2vw, 17px); line-height: 1.65; max-width: 60ch; }

/* LISTINGS */
.re-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
.re-card {
  background: var(--paper); border: 1px solid var(--hairline); display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s, border-color .25s;
}
.re-card:hover { transform: translateY(-4px); box-shadow: 0 24px 48px -16px rgba(26,24,20,.14); border-color: var(--bronze); }
.re-card-photo { aspect-ratio: 4/3; position: relative; background-size: cover; background-position: center; background-color: var(--oat); }
.re-card-photo .tag { position: absolute; top: 14px; left: 14px; background: var(--paper); color: var(--bronze-deep); padding: 4px 10px; font-size: 11px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.re-card-photo .heart { position: absolute; top: 14px; right: 14px; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.92); border: 0; cursor: pointer; color: var(--bronze); }
.re-card-body { padding: 22px 24px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.re-card-price { font-family: 'Cormorant Garamond', serif; font-size: 30px; line-height: 1; color: var(--char); }
.re-card-price small { font-style: italic; color: var(--slate); font-size: 14px; margin-left: 8px; font-family: var(--font-sans); }
.re-card-title { font-size: 18px; font-weight: 600; line-height: 1.3; margin: 0; color: var(--char); }
.re-card-meta { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding: 14px 0; border-top: 1px dotted var(--hairline); border-bottom: 1px dotted var(--hairline); }
.re-card-meta div { display: flex; flex-direction: column; gap: 2px; }
.re-card-meta div b { color: var(--char); font-weight: 700; font-size: 14px; }
.re-card-meta div span { color: var(--slate); font-size: 11px; letter-spacing: .04em; }
.re-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.re-card-addr { color: var(--slate); font-size: 13px; flex: 1; }
.re-card-arr { color: var(--bronze-deep); font-weight: 700; font-size: 13px; letter-spacing: .04em; transition: gap .25s; display: inline-flex; align-items: center; gap: 6px; }
.re-card-arr:hover { gap: 12px; }
@media (max-width: 1000px) { .re-list { grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px)  { .re-list { grid-template-columns: 1fr; } }

/* MORTGAGE CALC */
.re-mort { background: var(--char); color: var(--ivory); padding: clamp(60px, 8vw, 100px) 0; }
.re-mort h2 { color: var(--ivory); }
.re-mort .re-eyebrow { color: var(--bronze); }
.re-mort-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center; margin-top: 36px; }
.re-mort-form { background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1); padding: 32px; }
.re-mort-row { margin-bottom: 22px; }
.re-mort-row:last-child { margin-bottom: 0; }
.re-mort-row label { display: flex; justify-content: space-between; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: rgba(244,241,236,.66); margin-bottom: 10px; font-weight: 600; }
.re-mort-row label b { color: var(--bronze); font-weight: 700; }
.re-mort-row input[type=range] {
  -webkit-appearance: none; appearance: none; width: 100%; background: transparent; cursor: pointer;
}
.re-mort-row input[type=range]::-webkit-slider-runnable-track { height: 4px; background: rgba(255,255,255,.14); border-radius: 2px; }
.re-mort-row input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; appearance: none; width: 18px; height: 18px; border-radius: 50%; background: var(--bronze); margin-top: -7px; cursor: grab; box-shadow: 0 4px 8px rgba(0,0,0,.4); }
.re-mort-row input[type=range]::-moz-range-track { height: 4px; background: rgba(255,255,255,.14); border-radius: 2px; }
.re-mort-row input[type=range]::-moz-range-thumb { width: 18px; height: 18px; border-radius: 50%; background: var(--bronze); border: 0; cursor: grab; }
.re-mort-row .span { display: flex; justify-content: space-between; color: rgba(244,241,236,.5); font-size: 11px; letter-spacing: .04em; margin-top: 6px; }

.re-mort-result { padding: 36px; background: linear-gradient(135deg, var(--bronze), var(--bronze-deep)); color: var(--char); display: flex; flex-direction: column; gap: 18px; }
.re-mort-result-label { font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: rgba(26,24,20,.66); font-weight: 700; }
.re-mort-result-value { font-family: 'Cormorant Garamond', serif; font-size: clamp(40px, 5vw, 64px); line-height: 1; }
.re-mort-result-value small { font-style: italic; font-size: 16px; font-family: var(--font-sans); color: rgba(26,24,20,.7); margin-left: 6px; }
.re-mort-breakdown { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding-top: 18px; border-top: 1px solid rgba(26,24,20,.18); }
.re-mort-breakdown div b { display: block; font-family: 'Cormorant Garamond', serif; font-size: 22px; line-height: 1; margin-bottom: 4px; }
.re-mort-breakdown div span { color: rgba(26,24,20,.66); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; }
.re-mort-cta { background: var(--char); color: var(--ivory); border: 0; padding: 16px; font: inherit; font-weight: 700; font-size: 13px; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; }
.re-mort-cta:hover { background: var(--stone); }
@media (max-width: 900px) { .re-mort-grid { grid-template-columns: 1fr; } }

/* NEIGHBORHOODS */
.re-hoods { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 36px; }
.re-hood {
  position: relative; aspect-ratio: 4/5; overflow: hidden;
  background-size: cover; background-position: center; background-color: var(--oat);
  display: flex; align-items: end; padding: 22px;
  transition: transform .3s;
}
.re-hood:hover { transform: scale(1.02); }
.re-hood::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(26,24,20,.78) 100%); }
.re-hood-info { position: relative; z-index: 1; color: var(--paper); }
.re-hood-info h4 { color: var(--paper); margin: 0 0 4px; font-size: 22px; }
.re-hood-info span { color: var(--bronze-soft); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; font-weight: 600; }
.re-hood-info b { display: block; color: var(--paper); font-size: 13px; margin-top: 6px; }
@media (max-width: 1000px) { .re-hoods { grid-template-columns: 1fr 1fr; } }

/* AGENTS */
.re-agents { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 40px; }
.re-agent { background: var(--paper); border: 1px solid var(--hairline); padding: 24px; }
.re-agent-photo { aspect-ratio: 1/1; border-radius: 50%; background-size: cover; background-position: center; background-color: var(--oat); margin: 0 auto 18px; max-width: 140px; }
.re-agent h3 { font-size: 18px; text-align: center; margin: 0 0 4px; }
.re-agent p { text-align: center; color: var(--bronze-deep); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; font-weight: 700; margin: 0 0 14px; }
.re-agent-meta { display: flex; justify-content: center; gap: 18px; padding-top: 14px; border-top: 1px solid var(--hairline); font-size: 12px; color: var(--slate); }
.re-agent-meta b { color: var(--char); font-weight: 700; }
@media (max-width: 1000px) { .re-agents { grid-template-columns: 1fr 1fr; } }

/* STAGES */
.re-stages { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-top: 36px; counter-reset: re-step; }
.re-stage { background: var(--paper); border: 1px solid var(--hairline); padding: 22px; position: relative; }
.re-stage::before { counter-increment: re-step; content: counter(re-step, decimal-leading-zero); display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 28px; color: var(--bronze); margin-bottom: 10px; line-height: 1; }
.re-stage h4 { font-size: 16px; margin: 0 0 6px; }
.re-stage p { font-size: 13px; color: var(--slate); line-height: 1.5; margin: 0; }
@media (max-width: 1000px) { .re-stages { grid-template-columns: 1fr 1fr; } }

/* FAQ */
.re-faq { max-width: 760px; margin: 36px auto 0; }
.re-faq details { border-top: 1px solid var(--hairline); padding: 22px 0; }
.re-faq details:last-child { border-bottom: 1px solid var(--hairline); }
.re-faq summary { list-style: none; cursor: pointer; display: flex; justify-content: space-between; gap: 24px; font-family: 'Cormorant Garamond', serif; font-size: 22px; font-weight: 500; }
.re-faq summary::-webkit-details-marker { display: none; }
.re-faq summary::after { content: '+'; color: var(--bronze-deep); font-size: 26px; transition: transform .25s; }
.re-faq details[open] summary::after { transform: rotate(45deg); }
.re-faq details > div { padding-top: 12px; color: var(--char-2); line-height: 1.7; font-size: 15px; }

/* FOOTER */
.re-foot { background: var(--stone); color: var(--ivory); padding: 64px 0 28px; }
.re-foot-top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 36px; }
.re-foot-brand b { font-family: 'Cormorant Garamond', serif; font-size: 28px; color: var(--paper); display: block; }
.re-foot-brand p { color: rgba(244,241,236,.62); margin: 12px 0 0; max-width: 36ch; line-height: 1.6; }
.re-foot h5 { color: var(--bronze); font-size: 11px; letter-spacing: .26em; text-transform: uppercase; margin: 0 0 14px; font-weight: 700; }
.re-foot a { color: rgba(244,241,236,.78); display: block; padding: 4px 0; font-size: 14px; }
.re-foot a:hover { color: var(--bronze); }
.re-foot-bot { padding-top: 20px; border-top: 1px solid rgba(255,255,255,.08); display: flex; justify-content: space-between; flex-wrap: wrap; color: rgba(244,241,236,.4); font-size: 12px; gap: 14px; }
@media (max-width: 800px) { .re-foot-top { grid-template-columns: 1fr; } }

body[data-niche="realestate"] .reveal { opacity: 0; transform: translateY(14px); transition: opacity 600ms var(--ease-smooth), transform 600ms var(--ease-smooth); }
body[data-niche="realestate"] .reveal.in { opacity: 1; transform: none; }
