/* New Construction Lead Gen Theme
   Purpose: make key funnel pages (inventory + county pages + newbuild) feel like one premium product.
*/

:root{
  --nc-bg: #0B1224;
  --nc-surface: #0F172A;
  --nc-surface-2: #111C33;
  --nc-border: rgba(255,255,255,.10);
  --nc-text: #E2E8F0;
  --nc-muted: rgba(226,232,240,.78);
  --nc-blue: #3B82F6;
  --nc-red: #CC2032;
  --nc-green: #10B981;
  --nc-shadow: 0 18px 40px rgba(2,6,23,.25);
}

.nc-hero{
  background: radial-gradient(900px 300px at 20% 10%, rgba(59,130,246,.22), transparent 60%),
              radial-gradient(800px 260px at 90% 20%, rgba(16,185,129,.18), transparent 60%),
              linear-gradient(180deg, #0B1224 0%, #0F172A 100%);
  color: var(--nc-text);
  padding: 3.25rem 0 2.25rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.nc-hero__wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.25rem;
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 1.25rem;
  align-items: center;
}

@media (max-width: 980px){
  .nc-hero__wrap{grid-template-columns: 1fr; padding-bottom: .25rem}
}

.nc-kicker{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
  padding:.4rem .75rem;
  border-radius:999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.86);
  font-weight: 800;
  font-size: .82rem;
  letter-spacing: .01em;
}

.nc-title{
  margin:.9rem 0 .5rem;
  font-size: clamp(2rem, 3.8vw, 3.1rem);
  line-height: 1.08;
  letter-spacing: -0.02em;
  font-weight: 900;
  color: #fff;
}

.nc-subtitle{
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--nc-muted);
  max-width: 58ch;
}

.nc-chips{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top: 1.25rem;
}

.nc-chip{
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  padding:.5rem .75rem;
  border-radius: 999px;
  text-decoration:none;
  font-weight: 900;
  color: rgba(255,255,255,.90);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  transition: transform .15s ease, background .15s ease;
}
.nc-chip:hover{transform: translateY(-1px); background: rgba(255,255,255,.12)}

.nc-hero__card{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  box-shadow: var(--nc-shadow);
  padding: 1rem;
}
.nc-hero__card h3{
  margin: 0 0 .35rem;
  color: #fff;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
}
.nc-hero__card p{
  margin: 0 0 .75rem;
  color: var(--nc-muted);
  font-size: .95rem;
  line-height: 1.5;
}
.nc-cta-row{
  display:grid;
  grid-template-columns: 1fr;
  gap: .65rem;
}
.nc-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  width: 100%;
  padding: .75rem .95rem;
  border-radius: 14px;
  text-decoration:none;
  font-weight: 900;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.08);
  color: #fff;
}
.nc-btn:hover{filter: brightness(1.03)}
.nc-btn--primary{background: var(--nc-red); border-color: transparent}
.nc-btn--secondary{background: rgba(59,130,246,.20); border-color: rgba(59,130,246,.25)}
.nc-btn--tertiary{background: rgba(16,185,129,.18); border-color: rgba(16,185,129,.25)}

.nc-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 1.5rem 1.25rem 2.5rem;
}

.nc-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.nc-card{
  grid-column: span 12;
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 16px;
  box-shadow: 0 1px 2px rgba(2,6,23,.05);
  padding: 16px;
}

.nc-card--soft{
  background: #F8FAFC;
}

.nc-kpis{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
@media (max-width: 860px){
  .nc-kpis{grid-template-columns: 1fr}
}

.nc-kpi{
  background: #fff;
  border: 1px solid rgba(15,23,42,.08);
  border-radius: 16px;
  padding: 14px 14px;
}
.nc-kpi__label{color: #475569; font-weight: 800; font-size: .82rem; text-transform: uppercase; letter-spacing: .08em}
.nc-kpi__value{margin-top: .35rem; font-size: 1.55rem; font-weight: 950; color: #0F172A}
.nc-kpi__hint{margin-top: .25rem; color: #64748b; font-weight: 700; font-size: .9rem}

.nc-filters{
  display:flex;
  flex-wrap:wrap;
  gap:.65rem;
  align-items:center;
}
.nc-filters select,
.nc-filters input{
  padding: .65rem .75rem;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.14);
  background: #fff;
  font: inherit;
}
.nc-filters label{display:inline-flex;align-items:center;gap:.5rem;font-weight:800;color:#0F172A}

.nc-section-title{
  margin: 0 0 .35rem;
  font-size: 1.35rem;
  font-weight: 950;
  letter-spacing: -0.01em;
  color: #0F172A;
}
.nc-section-sub{
  margin: 0;
  color: #475569;
  font-weight: 650;
  line-height: 1.55;
}

.nc-inline-cta{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-top: 1rem;
}
.nc-inline-cta a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  padding:.65rem .85rem;
  border-radius: 999px;
  text-decoration:none;
  font-weight: 900;
  border: 1px solid rgba(15,23,42,.12);
  background: #fff;
  color:#0F172A;
}
.nc-inline-cta a[href^="sms:"]{background: var(--nc-red); color:#fff; border-color: transparent}
.nc-inline-cta a.nc-link{background: rgba(59,130,246,.10); border-color: rgba(59,130,246,.22)}

/* Inventory + listing components */
.nc-kpis--4{
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 980px){
  .nc-kpis--4{grid-template-columns: 1fr}
}

.nc-section-actions{
  display:flex;
  flex-wrap:wrap;
  gap:.6rem;
  margin-top: 1rem;
}
.nc-action-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.45rem;
  padding:.7rem .95rem;
  border-radius:14px;
  border:1px solid rgba(15,23,42,.14);
  background:#fff;
  color:#0F172A;
  font-weight:900;
  cursor:pointer;
}
.nc-action-btn--primary{background:var(--nc-red);border-color:transparent;color:#fff}
.nc-action-btn--blue{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.22)}
.nc-action-btn--soft{background:#F8FAFC}

.nc-loading{
  display:flex;
  align-items:center;
  gap:.75rem;
  padding: 1.25rem .75rem;
  color: #475569;
  font-weight: 800;
}
.nc-loading__spinner{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 2px solid rgba(15,23,42,.18);
  border-top-color: rgba(15,23,42,.55);
  animation: ncspin 1s linear infinite;
}
@keyframes ncspin{to{transform:rotate(360deg)}}
@media (prefers-reduced-motion: reduce){
  .nc-loading__spinner{animation:none}
}

.nc-listing-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
@media (max-width: 1024px){
  .nc-listing-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
}
@media (max-width: 720px){
  .nc-listing-grid{grid-template-columns: 1fr}
}

.nc-listing-card{
  background:#fff;
  border:1px solid rgba(15,23,42,.10);
  border-radius: 16px;
  overflow:hidden;
  box-shadow: 0 1px 2px rgba(2,6,23,.05);
  transition: transform .14s ease, box-shadow .14s ease;
  position: relative;
}
.nc-listing-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(2,6,23,.12);
}
@media (prefers-reduced-motion: reduce){
  .nc-listing-card{transition:none}
  .nc-listing-card:hover{transform:none}
}

.nc-listing-media{
  height: 148px;
  background: linear-gradient(135deg, rgba(59,130,246,.18), rgba(16,185,129,.14));
  position: relative;
}
.nc-listing-placeholder{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 950;
  color: rgba(15,23,42,.72);
  letter-spacing: .02em;
}

.hot-badge{
  position:absolute;
  top: 10px;
  right: 10px;
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  background: rgba(204,32,50,.98);
  color:#fff;
  border-radius:999px;
  padding:.38rem .6rem;
  font-weight: 950;
  font-size: .78rem;
  box-shadow: 0 10px 20px rgba(2,6,23,.20);
}

.nc-listing-body{padding: 12px}
.nc-listing-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:.75rem;
}
.builder-name{
  color:#64748b;
  font-weight: 950;
  font-size: .78rem;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.property-price{
  font-weight: 950;
  color:#0F172A;
  font-size: 1.08rem;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.nc-price-drop{
  margin-right: .4rem;
  color: rgba(204,32,50,.95);
  text-decoration: line-through;
  font-weight: 950;
  font-size: .9rem;
}
.property-address{
  margin-top: .45rem;
  font-weight: 950;
  color:#0F172A;
}
.property-location{
  margin-top: .2rem;
  color:#64748b;
  font-weight: 700;
  font-size: .92rem;
}

.nc-specs{
  display:flex;
  flex-wrap:wrap;
  gap:.5rem;
  margin-top: .65rem;
}
.nc-spec{
  display:inline-flex;
  align-items:center;
  gap:.35rem;
  padding:.32rem .55rem;
  border-radius:999px;
  background: rgba(15,23,42,.04);
  border: 1px solid rgba(15,23,42,.08);
  color:#0F172A;
  font-weight: 850;
  font-size: .86rem;
}
.nc-spec__icon{opacity:.85}

.incentives{
  margin-top: .7rem;
  padding: .65rem .7rem;
  border-radius: 14px;
  border: 1px solid rgba(15,23,42,.10);
  background: rgba(59,130,246,.06);
}
.incentives h4{
  margin:0 0 .35rem;
  color:#0F172A;
  font-size: .9rem;
  font-weight: 950;
}
.incentive-item{
  color:#0F172A;
  font-weight: 750;
  font-size: .9rem;
  line-height: 1.35;
}

.property-status{
  margin-top: .65rem;
  color:#475569;
  font-weight: 700;
  font-size: .9rem;
  line-height: 1.35;
}
.property-status strong{color:#0F172A}

.nc-card-actions{
  display:flex;
  gap:.5rem;
  margin-top: .75rem;
}
.nc-mini-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex: 1 1 0;
  padding: .55rem .7rem;
  border-radius: 12px;
  border: 1px solid rgba(15,23,42,.14);
  background:#fff;
  color:#0F172A;
  font-weight: 950;
  cursor:pointer;
}
.nc-mini-btn--primary{background:rgba(59,130,246,.12);border-color:rgba(59,130,246,.22)}

.nc-empty{
  padding: 1.25rem .75rem;
  color:#475569;
}
.nc-empty h3{
  margin:0;
  color:#0F172A;
  font-weight: 950;
}
.nc-empty p{margin:.35rem 0 0}
