/* ============================================
   FINDING HOME - ABOUT & SERVICES PAGE STYLES
   ============================================ */

/* ========== ABOUT PAGE ========== */


/* ---------- HERO / BANNER (paste into css/about.css) ---------- */
.hero {
  position: relative;
  width: 100%;
  min-height: 62vh; /* desktop height */
  display: flex;
  align-items: center;
  overflow: hidden;
  background-color: #faf7f3; /* fallback */
}

.hero-background,
.hero-image-container {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
}

.hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover; /* ensures full cover, no distortion */
  object-position: center center;
  display: block;
  -o-object-fit: cover;
}

/* subtle dark overlay for contrast (keeps text readable) */
.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.35) 0%, rgba(0,0,0,0.45) 100%);
  z-index: 2;
  pointer-events: none;
}

/* content should be above the image */
.hero-content {
  position: relative;
  z-index: 3;
  width: 100%;
  padding: 76px 20px;
  box-sizing: border-box;
}

/* hero title responsive style */
.hero-title {
  color: #f8f4f4;
  font-family: "Playfair Display", serif;
  font-size: 56px;
  line-height: 1.02;
  max-width: 1200px;
  margin: 0 0 18px;
  letter-spacing: -0.02em;
}

/* accent text color if needed */
.title-accent { display:block; color:#faf4f4; }

/* hero buttons */
.hero-actions { display:flex; gap:18px; flex-wrap:wrap; align-items:center; }

/* CTA buttons should be readable on overlay */
.btn-primary { background: #d3aa2b; color:#080808; border-radius:6px; padding:16px 30px; text-decoration:none; display:inline-flex; align-items:center; justify-content:center; }
.btn-secondary { background: transparent; border:2px solid rgba(211,170,43,0.9); color:#d3aa2b; padding:16px 28px; border-radius:6px; text-decoration:none; }

/* mobile tweaks */
@media (max-width: 1024px) {
  .hero-title { font-size: 44px; padding-right: 20px; }
  .hero { min-height: 56vh; }
}

@media (max-width: 768px) {
  .hero { min-height: 44vh; }
  .hero-title { font-size: 28px; line-height:1.15; }
  .hero-content { padding: 36px 18px; }
  .hero-actions { flex-direction:column; align-items:stretch; }
  .btn-primary, .btn-secondary { width:100%; text-align:center; }
}


.brand-story-section {
    padding: var(--space-12) 0;
    background-color: var(--ivory);
}

.story-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-10);
    align-items: center;
}

.story-content .lead-text {
    font-size: var(--text-xl);
    line-height: 1.8;
    color: var(--grey-dark);
    margin-bottom: var(--space-6);
    font-weight: 500;
}

.story-content p {
    font-size: var(--text-lg);
    line-height: 1.8;
    margin-bottom: var(--space-5);
}

.story-highlights {
    margin-top: var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.highlight-item {
    display: flex;
    align-items: flex-start;
    gap: var(--space-4);
    padding: var(--space-5);
    background-color: var(--white);
    border-radius: var(--radius-md);
    border-left: 4px solid var(--gold);
    box-shadow: var(--shadow-sm);
    transition: all var(--duration-medium) var(--ease-standard);
}

.highlight-item:hover {
    box-shadow: var(--shadow-md);
    transform: translateX(5px);
}

.highlight-item i {
    font-size: var(--text-2xl);
    color: var(--gold);
    width: 40px;
    flex-shrink: 0;
}

.highlight-item strong {
    display: block;
    font-size: var(--text-lg);
    color: var(--black);
    margin-bottom: var(--space-1);
}

.highlight-item p {
    font-size: var(--text-base);
    color: var(--grey-medium);
    margin: 0;
}

.story-image {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
}

.story-image img {
    width: 100%;
    height: 500px;
    object-fit: cover;
}

.image-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, rgba(212, 175, 55, 0.1) 0%, transparent 100%);
}

/* Founder Section */
.founder-section {
    padding: var(--space-16) 0;
}

.founder-grid {
    display: grid;
    grid-template-columns: 1fr 1.5fr;
    gap: var(--space-10);
    align-items: center;
}

.founder-image {
    position: relative;
}

.founder-image img {
    width: 100%;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
}

.founder-badge {
    position: absolute;
    bottom: var(--space-6);
    left: var(--space-6);
    background-color: var(--gold);
    color: var(--black);
    padding: var(--space-3) var(--space-6);
    border-radius: var(--radius-md);
    font-weight: 700;
    font-size: var(--text-base);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.founder-content h2 {
    color: var(--gold);
    font-size: var(--text-5xl);
    margin-bottom: var(--space-2);
}

.founder-title {
    font-size: var(--text-2xl);
    color: var(--white);
    font-weight: 400;
    margin-bottom: var(--space-6);
}

.founder-bio {
    font-size: var(--text-lg);
    line-height: 1.8;
    color: var(--grey-light);
    margin-bottom: var(--space-5);
}

.founder-content p {
    font-size: var(--text-lg);
    line-height: 1.8;
    color: var(--grey-light);
    font-style: italic;
    margin-bottom: var(--space-8);
    border-left: 4px solid var(--gold);
    padding-left: var(--space-5);
}

.founder-contact {
    display: flex;
    gap: var(--space-4);
    flex-wrap: wrap;
}

/* Values Section */
.values-section {
    padding: var(--space-16) 0;
    background-color: var(--ivory);
}

.values-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
}

.value-card {
    background-color: var(--white);
    padding: var(--space-8);
    border-radius: var(--radius-lg);
    text-align: center;
    box-shadow: var(--shadow-md);
    transition: all var(--duration-medium) var(--ease-standard);
    border-top: 4px solid var(--gold);
}

.value-card:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-8px);
}

.value-icon {
    font-size: var(--text-6xl);
    color: var(--gold);
    margin-bottom: var(--space-4);
}

.value-card h3 {
    font-size: var(--text-2xl);
    margin-bottom: var(--space-4);
    color: var(--black);
}

.value-card p {
    font-size: var(--text-base);
    line-height: 1.8;
    color: var(--grey-medium);
}

/* Why Choose Section */
.why-choose-section {
    padding: var(--space-16) 0;
}

.why-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: var(--space-10);
    align-items: start;
}

.why-list {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    margin-top: var(--space-6);
}

.why-item {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
}

.why-item i {
    font-size: var(--text-2xl);
    color: var(--gold);
    margin-top: var(--space-1);
    flex-shrink: 0;
}

.why-item strong {
    display: block;
    font-size: var(--text-lg);
    color: var(--black);
    margin-bottom: var(--space-1);
}

.why-item p {
    font-size: var(--text-base);
    color: var(--grey-medium);
    margin: 0;
}

.why-stats {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
}

.stat-card {
    background: linear-gradient(135deg, var(--gold) 0%, var(--gold-2) 100%);
    padding: var(--space-8);
    border-radius: var(--radius-lg);
    text-align: center;
    box-shadow: var(--shadow-lg);
    transition: all var(--duration-medium) var(--ease-standard);
}

.stat-card:hover {
    transform: scale(1.05);
    box-shadow: var(--shadow-gold);
}

.stat-card .stat-number {
    font-family: var(--font-serif);
    font-size: var(--text-6xl);
    font-weight: 700;
    color: var(--black);
    margin-bottom: var(--space-2);
}

.stat-card .stat-label {
    font-size: var(--text-base);
    color: var(--black);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    font-weight: 600;
}

/* ========== SERVICES PAGE ========== */

.services-intro-section {
    padding: var(--space-12) 0;
    background-color: var(--ivory);
    text-align: center;
}

.intro-content {
    max-width: 900px;
    margin: 0 auto;
}

.main-services-section {
    padding: var(--space-16) 0;
}

.service-block {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: var(--space-8);
    align-items: start;
    margin-bottom: var(--space-16);
    padding-bottom: var(--space-16);
    border-bottom: 2px solid var(--grey-light);
}

.service-block:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.service-icon-large {
    font-size: var(--text-8xl);
    color: var(--gold);
    width: 150px;
    text-align: center;
    flex-shrink: 0;
}

.service-content h2 {
    font-size: var(--text-4xl);
    margin-bottom: var(--space-3);
    color: var(--black);
}

.service-tagline {
    font-size: var(--text-xl);
    color: var(--gold);
    margin-bottom: var(--space-6);
    font-weight: 500;
}

.service-features {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-5);
    margin-top: var(--space-6);
}

.feature-item {
    display: flex;
    gap: var(--space-3);
    align-items: flex-start;
}

.feature-item i {
    color: var(--gold);
    font-size: var(--text-lg);
    margin-top: var(--space-1);
    flex-shrink: 0;
}

.feature-item strong {
    display: block;
    font-size: var(--text-lg);
    color: var(--black);
    margin-bottom: var(--space-1);
}

.feature-item p {
    font-size: var(--text-base);
    color: var(--grey-medium);
    margin: 0;
}

/* Concierge Section */
.concierge-section {
    padding: var(--space-16) 0;
}

.concierge-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}

.concierge-card {
    background-color: var(--white);
    padding: var(--space-8);
    border-radius: var(--radius-lg);
    text-align: center;
    transition: all var(--duration-medium) var(--ease-standard);
    border: 2px solid var(--gold-light);
}

.concierge-card:hover {
    background-color: var(--gold-light);
    border-color: var(--gold);
    transform: translateY(-5px);
}

.concierge-card i {
    font-size: var(--text-5xl);
    color: var(--gold);
    margin-bottom: var(--space-4);
}

.concierge-card h3 {
    font-size: var(--text-xl);
    color: var(--white);
    margin-bottom: var(--space-3);
}

.concierge-card p {
    font-size: var(--text-base);
    color: var(--grey-light);
    margin: 0;
}

/* ========== RESPONSIVE ========== */

@media (max-width: 1024px) {

    .story-grid,
    .founder-grid,
    .why-grid {
        grid-template-columns: 1fr;
    }

    .values-grid {
        grid-template-columns: 1fr;
    }

    .service-block {
        grid-template-columns: 1fr;
        gap: var(--space-5);
    }

    .service-icon-large {
        width: 100%;
        font-size: var(--text-7xl);
    }

    .service-features {
        grid-template-columns: 1fr;
    }

    .concierge-grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 768px) {
    .story-image img {
        height: 300px;
    }

    .why-stats {
        grid-template-columns: 1fr;
    }

    .founder-contact {
        flex-direction: column;
    }

    .founder-contact .btn {
        width: 100%;
    }

    .concierge-grid {
        grid-template-columns: 1fr;
    }
}


/* ---------- Collapsible FAQ styles (paste into css/about.css) ---------- */
.faq-section { padding:48px 16px; background: #fffaf6; }
.section-title { font-family: "Playfair Display", serif; font-size:36px; margin-bottom:18px; }

.faq-list { display:block; max-width:1100px; margin:0 auto; gap:12px; }

.faq-item { border-bottom:1px solid #eee; padding:12px 0; }
.faq-question {
  width:100%;
  background:transparent;
  border:0;
  text-align:left;
  font-weight:600;
  padding:12px 6px;
  font-size:18px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  cursor:pointer;
}
.faq-toggle-icon { font-size:20px; transform:rotate(0deg); transition:transform .2s ease; color:#222; }
.faq-answer { max-height:0; overflow:hidden; transition:max-height .28s ease, padding .2s ease; padding:0 6px; }
.faq-answer p { margin:10px 0 18px; color:#333; line-height:1.6; }

/* when open — JS toggles .open class on the button */
.faq-question.open .faq-toggle-icon { transform:rotate(45deg); }

/* For accessibility focus state */
.faq-question:focus { outline: 2px dashed #d3aa2b; outline-offset:6px; }

/* mobile */
@media (max-width: 768px) {
  .section-title { font-size:28px; }
  .faq-question { font-size:16px; }
  .faq-answer p { font-size:15px; }
}


.story-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
align-items:center;
}

.story-image img{
width:100%;
border-radius:8px;
}

.highlight-grid{
display:grid;
grid-template-columns:repeat(4,1fr);
gap:20px;
margin-top:40px;
}

.highlight-item{
display:flex;
align-items:center;
gap:12px;
padding:22px;
background:#f5f5f5;
border-radius:12px;
border-left:4px solid #caa76a;
min-height:90px;
}

.highlight-item strong,
.highlight-item a{
color:#caa76a;
text-decoration:none;
line-height:1.4;
word-break:break-word;
}

.highlight-item i{
color:#caa76a;
font-size:18px;
flex-shrink:0;
}

.highlight-gold{
    color:#caa76a;
}

.highlight-description{
    margin-top:30px;
    line-height:1.7;
    color:#555;
}

@media(max-width:768px){

.story-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:40px;
    align-items:center;
}

.story-image img{
    width:100%;
    max-width:100%;
    height:auto;
    border-radius:8px;
    display:block;
}
} 

@media (max-width:768px){

.highlight-grid{
grid-template-columns:1fr;
gap:16px;
}

.highlight-item{
padding:18px 20px;
font-size:15px;
min-height:auto;
}

}


.highlight-item{
transition:all .3s ease;
}

.highlight-item:hover{
transform:translateY(-3px);
box-shadow:0 8px 25px rgba(0,0,0,0.08);
}

.story-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:50px;
align-items:center;
}

.story-content{
max-width:100%;
}

.story-image img{
width:100%;
height:auto;
max-height:500px;
object-fit:cover;
border-radius:10px;
display:block;
}

@media (max-width:768px){

.story-grid{
grid-template-columns:1fr;
gap:25px;
}

.story-image img{
max-height:350px;
}

}

.story-image{
order:2;
}

.story-content{
order:1;
}