/* Keys From Kristina — calming cool family-home theme
   Edward 2026-05-09: Winter Springs FL, family suburban (NOT beach, NOT resort, NOT corporate)
   Palette: dusty blue + sage green + cream + soft taupe + warm sun accent
*/
:root {
  --kr-blue: #5b7fa3;       /* dusty blue — primary cool */
  --kr-blue-deep: #2d4566;  /* deeper dusty blue for headings */
  --kr-blue-darkest: #243751;
  --kr-sage: #6cb5b3;       /* sage green */
  --kr-sage-deep: #56908f;
  --kr-cream: #f6f1e9;      /* warm cream */
  --kr-cream-light: #f6f1ea;
  --kr-taupe: #a89684;      /* soft taupe accent */
  --kr-taupe-deep: #867869;
  --kr-sun: #ddd8d1;        /* warm sun accent (sparingly) */
  --kr-charcoal: #1f2937;   /* text */
  --kr-charcoal-soft: #787e87;
  --kr-white: #ffffff;
  --kr-shadow: 0 4px 24px rgba(74, 90, 100, 0.08);
  --kr-shadow-lg: 0 12px 48px rgba(74, 90, 100, 0.14);
  --kr-radius: 12px;
  --kr-radius-lg: 24px;
  --kr-font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", "Helvetica Neue", sans-serif;
  --kr-font-heading: "Cormorant Garamond", Georgia, "Times New Roman", serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--kr-font-body);
  color: var(--kr-charcoal);
  background: var(--kr-cream-light);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: var(--kr-font-heading); font-weight: 500; letter-spacing: -0.02em; color: var(--kr-charcoal); margin: 0 0 0.5em; }
h1 { font-size: 3.5rem; line-height: 1.1; }
h2 { font-size: 2.5rem; line-height: 1.15; }
h3 { font-size: 1.75rem; line-height: 1.2; }
h4 { font-size: 1.25rem; line-height: 1.25; }
p { margin: 0 0 1em; }
a { color: var(--kr-blue-deep); text-decoration: none; transition: color 0.2s; }
a:hover { color: var(--kr-blue-darkest); }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }

/* === NAV === */
.kr-nav {
  background: var(--kr-cream-light);
  border-bottom: 1px solid rgba(168, 192, 168, 0.2);
  padding: 18px 0;
  position: sticky; top: 0; z-index: 100;
}
.kr-nav-inner { display: flex; align-items: center; justify-content: space-between; }
.kr-logo { font-family: var(--kr-font-heading); font-size: 1.6rem; font-weight: 500; color: var(--kr-charcoal); letter-spacing: -0.01em; }
.kr-logo-from { color: var(--kr-sage-deep); font-style: italic; }
.kr-nav-links { display: flex; gap: 32px; list-style: none; padding: 0; margin: 0; }
.kr-nav-links a { color: var(--kr-charcoal-soft); font-size: 0.95rem; font-weight: 500; }
.kr-nav-cta { background: var(--kr-blue-deep); color: white !important; padding: 10px 22px; border-radius: 999px; font-size: 0.9rem; }
.kr-nav-cta:hover { background: var(--kr-blue-darkest); color: white; }

/* === HERO === */
.kr-hero {
  position: relative;
  padding: 120px 0 100px;
  background: linear-gradient(135deg, var(--kr-cream) 0%, var(--kr-blue) 60%, var(--kr-sage) 100%);
  overflow: hidden;
}
.kr-hero::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 30% 20%, rgba(255,255,255,0.4), transparent 50%);
  pointer-events: none;
}
.kr-hero-inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items: center; }
.kr-hero-eyebrow { color: var(--kr-charcoal-soft); font-size: 0.95rem; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 600; margin-bottom: 16px; }
.kr-hero h1 { font-size: 4rem; line-height: 1.05; color: var(--kr-charcoal); margin: 0 0 24px; }
.kr-hero h1 em { font-style: italic; color: var(--kr-sage-deep); font-weight: 500; }
.kr-hero-lead { font-size: 1.2rem; color: var(--kr-charcoal-soft); margin: 0 0 32px; max-width: 480px; }
.kr-hero-cta-row { display: flex; gap: 16px; align-items: center; }
.kr-btn { display: inline-block; padding: 14px 32px; border-radius: 999px; font-weight: 600; font-size: 1rem; transition: all 0.2s; cursor: pointer; border: none; }
.kr-btn-primary { background: var(--kr-blue-deep); color: white; }
.kr-btn-primary:hover { background: var(--kr-blue-darkest); color: white; transform: translateY(-1px); }
.kr-btn-ghost { background: transparent; color: var(--kr-charcoal); border: 1.5px solid var(--kr-taupe); }
.kr-btn-ghost:hover { border-color: var(--kr-charcoal); color: var(--kr-charcoal); }
.kr-hero-image {
  aspect-ratio: 4/5;
  border-radius: var(--kr-radius-lg);
  background: linear-gradient(160deg, var(--kr-sage) 0%, var(--kr-blue) 100%);
  box-shadow: var(--kr-shadow-lg);
  position: relative;
  overflow: hidden;
}
.kr-hero-image::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 70% 30%, rgba(245,240,232,0.3), transparent 50%); }
.kr-hero-img-caption { position: absolute; bottom: 24px; left: 24px; right: 24px; color: white; font-style: italic; font-family: var(--kr-font-heading); font-size: 1.1rem; z-index: 1; text-shadow: 0 2px 12px rgba(0,0,0,0.3); }

/* === SECTIONS === */
.kr-section { padding: 100px 0; }
.kr-section-header { text-align: center; max-width: 720px; margin: 0 auto 60px; }
.kr-section-eyebrow { color: var(--kr-sage-deep); font-size: 0.9rem; letter-spacing: 0.15em; text-transform: uppercase; font-weight: 600; margin-bottom: 12px; }
.kr-section-header h2 { margin-bottom: 12px; }
.kr-section-header p { font-size: 1.1rem; color: var(--kr-charcoal-soft); }

/* === VALUE GRID === */
.kr-value-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.kr-value-card {
  background: white;
  border-radius: var(--kr-radius-lg);
  padding: 40px 32px;
  box-shadow: var(--kr-shadow);
  border: 1px solid rgba(168, 192, 168, 0.15);
  transition: transform 0.3s, box-shadow 0.3s;
}
.kr-value-card:hover { transform: translateY(-4px); box-shadow: var(--kr-shadow-lg); }
.kr-value-icon {
  width: 56px; height: 56px;
  border-radius: 18px;
  background: linear-gradient(135deg, var(--kr-blue) 0%, var(--kr-sage) 100%);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 24px;
  font-size: 1.6rem;
}
.kr-value-card h3 { font-size: 1.4rem; margin-bottom: 12px; }
.kr-value-card p { color: var(--kr-charcoal-soft); margin: 0; font-size: 0.98rem; }

/* === COMMUNITIES === */
.kr-communities {
  background: var(--kr-cream);
  padding: 100px 0;
}
.kr-community-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.kr-community-card {
  aspect-ratio: 3/4;
  border-radius: var(--kr-radius);
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: transform 0.3s;
}
.kr-community-card:hover { transform: translateY(-4px); }
.kr-community-card.winter-springs { background: url('../img/kristina-iter3-hero_winter_springs_neighborhood_jugg_s90402_00001_.png') center/cover, var(--kr-sage); }
.kr-community-card.oviedo       { background: url('../img/kristina-iter3-hero_garden_walkway_jugg_s90801_00001_.png') center/cover, var(--kr-blue); }
.kr-community-card.casselberry  { background: url('../img/kristina-iter3-hero_lakeside_home_jugg_s90501_00001_.png') center/cover, var(--kr-cream); }
.kr-community-card.lake-mary    { background: url('../img/kristina-iter3-hero_evening_calm_home_jugg_s90701_00001_.png') center/cover, var(--kr-blue-deep); }
.kr-community-card::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgba(46, 53, 64, 0.5), transparent 60%); }
.kr-community-name { position: absolute; bottom: 24px; left: 24px; right: 24px; color: white; z-index: 1; }
.kr-community-name h3 { color: white; margin-bottom: 4px; font-size: 1.5rem; }
.kr-community-name span { font-size: 0.85rem; opacity: 0.9; letter-spacing: 0.05em; text-transform: uppercase; }

/* === TESTIMONIALS === */
.kr-testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.kr-testimonial {
  background: var(--kr-cream-light);
  border-radius: var(--kr-radius);
  padding: 32px;
  border: 1px solid rgba(168, 192, 168, 0.2);
}
.kr-testimonial-quote { font-family: var(--kr-font-heading); font-size: 1.15rem; line-height: 1.5; color: var(--kr-charcoal); margin-bottom: 24px; font-style: italic; }
.kr-testimonial-author { display: flex; align-items: center; gap: 12px; }
.kr-testimonial-avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(135deg, var(--kr-blue) 0%, var(--kr-sage) 100%); }
.kr-testimonial-name { font-weight: 600; font-size: 0.95rem; }
.kr-testimonial-where { font-size: 0.85rem; color: var(--kr-charcoal-soft); }

/* === CTA SECTION === */
.kr-cta {
  background: linear-gradient(135deg, var(--kr-blue-deep) 0%, var(--kr-sage-deep) 100%);
  padding: 100px 0;
  color: white;
  text-align: center;
}
.kr-cta h2 { color: white; font-size: 3rem; }
.kr-cta p { color: rgba(255,255,255,0.9); font-size: 1.2rem; max-width: 540px; margin: 0 auto 32px; }
.kr-cta .kr-btn-primary { background: white; color: var(--kr-charcoal); }
.kr-cta .kr-btn-primary:hover { background: var(--kr-cream); color: var(--kr-charcoal); }

/* === FOOTER === */
.kr-footer { background: var(--kr-charcoal); color: rgba(255,255,255,0.85); padding: 60px 0 32px; }
.kr-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 48px; margin-bottom: 48px; }
.kr-footer h4 { color: white; font-family: var(--kr-font-body); font-size: 0.85rem; letter-spacing: 0.1em; text-transform: uppercase; margin-bottom: 16px; }
.kr-footer ul { list-style: none; padding: 0; margin: 0; }
.kr-footer ul li { margin-bottom: 8px; }
.kr-footer a { color: rgba(255,255,255,0.85); font-size: 0.95rem; }
.kr-footer a:hover { color: var(--kr-cream); }
.kr-footer-bottom { padding-top: 32px; border-top: 1px solid rgba(255,255,255,0.1); display: flex; justify-content: space-between; font-size: 0.85rem; color: rgba(255,255,255,0.6); }

/* === LISTING CARDS (for featured page) === */
.kr-listing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.kr-listing-card { background: white; border-radius: var(--kr-radius); overflow: hidden; box-shadow: var(--kr-shadow); transition: transform 0.3s; }
.kr-listing-card:hover { transform: translateY(-4px); box-shadow: var(--kr-shadow-lg); }
.kr-listing-image { aspect-ratio: 4/3; background: linear-gradient(160deg, var(--kr-sage) 0%, var(--kr-blue) 100%); position: relative; }
.kr-listing-status { position: absolute; top: 16px; left: 16px; background: white; color: var(--kr-charcoal); padding: 6px 14px; border-radius: 999px; font-size: 0.8rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; }
.kr-listing-body { padding: 24px; }
.kr-listing-price { font-family: var(--kr-font-heading); font-size: 1.6rem; color: var(--kr-charcoal); margin-bottom: 4px; }
.kr-listing-address { color: var(--kr-charcoal-soft); font-size: 0.95rem; margin-bottom: 16px; }
.kr-listing-stats { display: flex; gap: 16px; padding-top: 16px; border-top: 1px solid rgba(168,192,168,0.2); font-size: 0.9rem; color: var(--kr-charcoal-soft); }

/* === RESPONSIVE === */
@media (max-width: 900px) {
  h1 { font-size: 2.4rem; }
  h2 { font-size: 1.9rem; }
  .kr-hero { padding: 80px 0; }
  .kr-hero h1 { font-size: 2.6rem; }
  .kr-hero-inner { grid-template-columns: 1fr; gap: 40px; }
  .kr-section { padding: 60px 0; }
  .kr-value-grid, .kr-testimonial-grid, .kr-listing-grid, .kr-community-grid { grid-template-columns: 1fr; }
  .kr-footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .kr-nav-links { display: none; }
}
