/* ============================================================================
   coshoppingcenters.com — Site Styles
   ============================================================================ */

/* Layout */
.site-wrapper { display: flex; flex-direction: column; min-height: 100vh; }
.site-content { flex: 1; }
.page-container { max-width: var(--max-content-width); margin: 0 auto; padding: 0 var(--space-md); }
.section { padding: var(--space-xl) 0; }

/* ---- Header ---- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--brand-primary);
  height: 64px; display: flex; align-items: center;
  box-shadow: var(--shadow-md);
}
.header-inner {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
}
.logo {
  color: var(--nm-white); font-size: var(--text-lg); font-weight: 700;
  text-decoration: none; display: flex; align-items: center; gap: 6px;
}
.logo img { height: 36px; }
.logo span { color: var(--brand-accent); }
.site-nav { display: flex; align-items: center; gap: 24px; }
.site-nav a {
  color: rgba(255,255,255,0.82); font-size: var(--text-sm);
  text-decoration: none; transition: color 0.15s;
}
.site-nav a:hover, .site-nav a.active { color: #fff; text-decoration: none; }
.nav-cta {
  background: var(--brand-teal); color: #fff !important;
  padding: 8px 18px; border-radius: var(--radius-pill);
  font-weight: 600; transition: background 0.15s;
}
.nav-cta:hover { background: var(--brand-teal-hover) !important; }
.hamburger {
  display: none; background: none; border: none; color: #fff;
  font-size: 22px; cursor: pointer; padding: 4px 8px;
}

/* ---- Hero ---- */
.home-hero {
  background: linear-gradient(135deg, var(--brand-primary) 0%, #003060 100%);
  color: #fff; padding: var(--space-hero) 0; text-align: center;
}
.home-hero h1 { color: #fff; font-size: var(--text-hero); margin-bottom: var(--space-sm); }
.home-hero .hero-sub {
  color: rgba(255,255,255,0.82); font-size: var(--text-lg);
  max-width: 560px; margin: 0 auto var(--space-lg);
}
.hero-cta-group { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ---- Buttons ---- */
.btn-primary {
  background: var(--brand-teal); color: #fff;
  padding: 14px 28px; border-radius: var(--radius-pill);
  font-size: var(--text-md); font-weight: 600;
  border: none; cursor: pointer; text-decoration: none;
  display: inline-block; transition: background 0.15s;
}
.btn-primary:hover { background: var(--brand-teal-hover); text-decoration: none; }
.btn-secondary {
  background: transparent; color: #fff;
  padding: 14px 28px; border-radius: var(--radius-pill);
  font-size: var(--text-md); font-weight: 600;
  border: 2px solid rgba(255,255,255,0.5); cursor: pointer;
  text-decoration: none; display: inline-block; transition: border-color 0.15s;
}
.btn-secondary:hover { border-color: #fff; text-decoration: none; }
.btn-outline {
  background: transparent; border: 2px solid var(--brand-teal); color: var(--brand-teal);
  padding: 10px 20px; border-radius: var(--radius-pill);
  font-size: var(--text-sm); font-weight: 600; cursor: pointer;
  transition: background 0.15s, color 0.15s; text-decoration: none; display: inline-block;
}
.btn-outline:hover { background: var(--brand-teal); color: #fff; text-decoration: none; }
.btn-outline:disabled, .btn-outline[disabled] {
  border-color: var(--nm-divider); color: var(--nm-gray-mid); cursor: not-allowed;
}
.btn-apply {
  background: var(--brand-teal); color: #fff;
  padding: 10px 24px; border-radius: var(--radius-pill);
  font-size: var(--text-sm); font-weight: 600; border: none; cursor: pointer;
  text-decoration: none; display: inline-flex; align-items: center; gap: 6px;
  transition: background 0.15s;
}
.btn-apply:hover { background: var(--brand-teal-hover); text-decoration: none; }
.btn-apply-large {
  background: var(--brand-teal); color: #fff;
  padding: 16px 36px; border-radius: var(--radius-pill);
  font-size: var(--text-lg); font-weight: 700; border: none; cursor: pointer;
  text-decoration: none; display: inline-block; transition: background 0.15s;
}
.btn-apply-large:hover { background: var(--brand-teal-hover); text-decoration: none; }
.back-btn {
  display: inline-flex; align-items: center; gap: 6px;
  color: var(--brand-teal); font-size: var(--text-sm); font-weight: 600;
  cursor: pointer; border: none; background: none; padding: 0;
  margin-bottom: var(--space-md);
}
.back-btn:hover { text-decoration: underline; }

/* ---- Stats bar ---- */
.stats-bar { background: var(--nm-cream); padding: var(--space-lg) 0; }
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-md); text-align: center; }
.stat-number { font-size: var(--text-2xl); font-weight: 700; color: var(--brand-primary); display: block; }
.stat-label  { font-size: var(--text-sm); color: var(--nm-gray-mid); }

/* ---- Property grid ---- */
.properties-section { padding: var(--space-2xl) 0; }
.properties-section > .page-container > h2 { text-align: center; margin-bottom: var(--space-xl); }
.filter-pills { display: flex; gap: 10px; justify-content: center; margin-bottom: var(--space-lg); flex-wrap: wrap; }
.filter-pill {
  padding: 6px 18px; border-radius: var(--radius-pill); border: 1px solid var(--nm-divider);
  background: #fff; color: var(--nm-gray-dark); font-size: var(--text-sm); cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.filter-pill.active {
  background: var(--brand-primary); color: #fff; border-color: var(--brand-primary);
}
.property-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: var(--space-lg);
}
.property-card {
  background: #fff; border-radius: var(--radius-lg); box-shadow: var(--shadow-md);
  overflow: hidden; cursor: pointer; transition: transform 0.15s, box-shadow 0.15s;
  text-decoration: none; display: block; color: inherit;
}
.property-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); text-decoration: none; }
.property-card-img { width: 100%; height: 220px; object-fit: cover; display: block; }
.property-card-placeholder {
  width: 100%; height: 220px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-teal) 100%);
  color: #fff; font-size: var(--text-2xl); font-weight: 700; letter-spacing: 2px;
}
.property-card-body { padding: var(--space-md); }
.property-card-name { font-size: var(--text-lg); font-weight: 700; color: var(--brand-primary); margin-bottom: 4px; }
.property-card-city { font-size: var(--text-sm); color: var(--nm-gray-mid); margin-bottom: var(--space-sm); }
.card-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: var(--space-sm); }
.tag {
  background: var(--nm-gray-light); color: var(--nm-gray-dark);
  padding: 4px 10px; border-radius: var(--radius-pill); font-size: var(--text-xs);
}
.tag.available { background: rgba(58,173,165,0.12); color: var(--brand-teal); }
.property-card-footer {
  border-top: 1px solid var(--nm-divider); padding-top: var(--space-sm); margin-top: var(--space-sm);
  display: flex; justify-content: space-between; align-items: center;
}
.avail-badge { font-size: var(--text-sm); color: var(--nm-gray-mid); }
.card-link { font-size: var(--text-sm); color: var(--brand-teal); font-weight: 600; }

/* ---- Property page ---- */
.property-hero { position: relative; height: 360px; overflow: hidden; }
.property-hero img { width: 100%; height: 100%; object-fit: cover; display: block; }
.property-hero-placeholder {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--brand-primary) 0%, var(--brand-teal) 100%);
  color: #fff; font-size: var(--text-hero); font-weight: 700;
}
.property-hero-overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(0,0,0,0.65));
  padding: var(--space-lg) var(--space-md);
}
.property-hero-overlay h1 { color: #fff; margin: 0; }
.property-hero-overlay .property-city { color: rgba(255,255,255,0.78); font-size: var(--text-md); }
.property-info-bar { background: var(--nm-gray-light); border-bottom: 1px solid var(--nm-divider); padding: var(--space-md) 0; }
.property-info-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: var(--space-md); }
.info-item label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.08em; color: var(--nm-gray-mid); display: block; margin-bottom: 4px; }
.info-item span  { font-size: var(--text-lg); font-weight: 700; color: var(--brand-primary); }

/* ---- Unit accordion ---- */
.units-section { padding: var(--space-xl) 0; }
.units-section h2 { margin-bottom: var(--space-lg); }
.unit-accordion { display: flex; flex-direction: column; gap: var(--space-sm); }
.unit-row { border: 1px solid var(--nm-divider); border-radius: var(--radius-md); overflow: hidden; background: #fff; }
.unit-row-header {
  display: flex; align-items: center; padding: var(--space-md); cursor: pointer;
  gap: var(--space-md); transition: background 0.1s;
}
.unit-row-header:hover { background: var(--nm-gray-light); }
.unit-name { font-weight: 700; color: var(--brand-primary); font-size: var(--text-md); flex: 1; }
.unit-sf   { font-size: var(--text-sm); color: var(--nm-gray-mid); min-width: 100px; }
.unit-rent { font-size: var(--text-sm); font-weight: 600; color: var(--brand-primary); min-width: 130px; }
.unit-status-badge {
  padding: 4px 10px; border-radius: var(--radius-pill); font-size: var(--text-xs); font-weight: 600;
}
.unit-status-badge.available    { background: rgba(58,173,165,0.12); color: var(--brand-teal); }
.unit-status-badge.coming-soon  { background: var(--nm-cream); color: var(--nm-gold); }
.unit-status-badge.leased       { background: var(--nm-gray-light); color: var(--nm-gray-mid); }
.chevron { transition: transform 0.2s; color: var(--nm-gray-mid); font-size: 18px; line-height: 1; }
.chevron.open { transform: rotate(180deg); }
.unit-row-body { display: none; padding: 0 var(--space-md) var(--space-md); border-top: 1px solid var(--nm-divider); }
.unit-row-body.open { display: block; }
.unit-body-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-lg); margin: var(--space-md) 0; }
.unit-body-grid p { font-size: var(--text-sm); color: var(--nm-gray-dark); margin: 0; }
.unit-body-grid .detail-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.06em; color: var(--nm-gray-mid); display: block; margin-bottom: 2px; }
.unit-actions { display: flex; gap: var(--space-sm); flex-wrap: wrap; padding-top: var(--space-sm); }

/* ---- Unit detail page ---- */
.unit-detail-page { padding: var(--space-xl) 0; }
.unit-detail-header { margin-bottom: var(--space-lg); }
.unit-detail-title-row { display: flex; align-items: center; gap: var(--space-sm); flex-wrap: wrap; margin-bottom: var(--space-sm); }
.unit-stats-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--space-md);
  background: var(--nm-gray-light); padding: var(--space-lg); border-radius: var(--radius-lg);
  margin-bottom: var(--space-xl);
}
.unit-photo-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-sm); margin-bottom: var(--space-xl); }
.photo-placeholder {
  height: 240px; background: linear-gradient(135deg, #e8e8e8 0%, #d0d0d0 100%);
  border-radius: var(--radius-md); display: flex; align-items: center; justify-content: center;
  color: var(--nm-gray-mid); font-size: var(--text-sm);
}
.photo-placeholder.main { grid-column: span 2; height: 360px; }
.unit-description { margin-bottom: var(--space-xl); }
.unit-description h3 { margin-bottom: var(--space-sm); }
.unit-floorplan-section { margin-bottom: var(--space-xl); padding: var(--space-lg); background: var(--nm-gray-light); border-radius: var(--radius-lg); display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); }
.unit-floorplan-section p { margin: 0; font-size: var(--text-sm); color: var(--nm-gray-mid); }
.apply-cta-box {
  background: linear-gradient(135deg, var(--brand-primary) 0%, #003060 100%);
  color: #fff; padding: var(--space-xl); border-radius: var(--radius-lg); text-align: center;
}
.apply-cta-box h2 { color: #fff; margin-bottom: var(--space-sm); }
.apply-cta-box p  { color: rgba(255,255,255,0.82); margin-bottom: var(--space-lg); }

/* ---- Contact page ---- */
.contact-page { max-width: 680px; margin: 0 auto; padding: var(--space-2xl) var(--space-md); }
.contact-page h1 { margin-bottom: var(--space-sm); }
.contact-page .sub { color: var(--nm-gray-mid); font-size: var(--text-md); margin-bottom: var(--space-xl); }
.contact-form { display: flex; flex-direction: column; gap: var(--space-md); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-md); }
.form-group { display: flex; flex-direction: column; }
.form-group label { font-size: var(--text-sm); font-weight: 600; color: var(--nm-gray-dark); margin-bottom: 6px; }
.form-group input,
.form-group textarea,
.form-group select {
  width: 100%; border: 1px solid var(--nm-divider); border-radius: var(--radius-md);
  padding: 12px var(--space-sm); font-size: var(--text-base); outline: none;
  font-family: var(--font-body); transition: border-color 0.15s, box-shadow 0.15s;
  background: #fff;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
  border-color: var(--brand-teal);
  box-shadow: 0 0 0 3px rgba(58,173,165,0.15);
}
.form-group textarea { min-height: 120px; resize: vertical; }
.contact-success { background: rgba(46,125,50,0.08); border: 1px solid #2E7D32; border-radius: var(--radius-md); padding: var(--space-lg); text-align: center; color: #2E7D32; }
.contact-aside { background: var(--nm-gray-light); border-radius: var(--radius-lg); padding: var(--space-lg); margin-top: var(--space-xl); }
.contact-aside h3 { margin-bottom: var(--space-sm); }
.contact-aside p  { font-size: var(--text-sm); color: var(--nm-gray-dark); margin-bottom: 8px; }
.contact-aside a  { color: var(--brand-teal); }
.contact-note { font-size: var(--text-sm); color: var(--nm-gray-mid); margin-top: var(--space-sm); }

/* ---- Breadcrumb ---- */
.breadcrumb { font-size: var(--text-sm); color: var(--nm-gray-mid); padding: var(--space-sm) 0; }
.breadcrumb a { color: var(--brand-teal); }
.breadcrumb .sep { margin: 0 8px; color: var(--nm-divider); }

/* ---- Footer ---- */
.site-footer { background: var(--brand-primary); color: rgba(255,255,255,0.7); padding: var(--space-xl) 0; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: var(--space-xl); }
.footer-brand-name { color: #fff; font-size: var(--text-lg); font-weight: 700; margin-bottom: var(--space-sm); }
.footer-brand-name span { color: var(--brand-accent); }
.footer-tagline { font-size: var(--text-sm); color: rgba(255,255,255,0.6); margin: 0; }
.footer-col h4 { color: #fff; font-size: var(--text-sm); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: var(--space-sm); }
.footer-col a { display: block; color: rgba(255,255,255,0.6); font-size: var(--text-sm); margin-bottom: 8px; }
.footer-col a:hover { color: #fff; text-decoration: none; }
.footer-col p { font-size: var(--text-sm); color: rgba(255,255,255,0.6); margin-bottom: 8px; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.1); margin-top: var(--space-xl); padding-top: var(--space-md); font-size: var(--text-xs); color: rgba(255,255,255,0.4); text-align: center; }

/* ---- Misc ---- */
.empty-state { text-align: center; padding: var(--space-2xl); color: var(--nm-gray-mid); }
.empty-state h2 { color: var(--nm-gray-mid); }

/* ---- Mobile (768px) ---- */
@media (max-width: 768px) {
  .home-hero h1 { font-size: var(--text-2xl); }
  .home-hero .hero-sub { font-size: var(--text-base); }
  .hero-cta-group { flex-direction: column; align-items: center; }
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .property-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: var(--space-lg); }
  .unit-body-grid { grid-template-columns: 1fr; }
  .unit-photo-gallery { grid-template-columns: 1fr; }
  .photo-placeholder.main { grid-column: span 1; height: 240px; }
  .form-row { grid-template-columns: 1fr; }
  .unit-floorplan-section { flex-direction: column; align-items: flex-start; }
  .unit-row-header { flex-wrap: wrap; gap: 8px; }
  .unit-sf, .unit-rent { min-width: auto; }
  .hamburger { display: block; }
  .site-nav {
    display: none; position: absolute; top: 64px; left: 0; right: 0;
    background: var(--brand-primary); flex-direction: column; padding: var(--space-md);
    gap: var(--space-sm); box-shadow: var(--shadow-lg);
  }
  .site-nav.open { display: flex; }
  .site-nav a { padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.1); }
  .nav-cta { border: none; text-align: center; }
  .property-hero { height: 240px; }
  .property-hero-placeholder { font-size: var(--text-2xl); }
  .contact-page { padding: var(--space-xl) var(--space-sm); }
}
