/* =========================================
   PAGE: HOME (#page-home)
   ========================================= */
#page-home {
  --hp-brand: #1c3a27;        /* Dark Green */
  --hp-accent: #c45a40;       /* Terracotta/Orange */
  --hp-gold: #b99056;         /* Gold accent */
  --hp-bg-main: #f8f5ec;      /* Off-white */
  --hp-bg-sec: #ebe4d6;       /* Secondary Background */
  --hp-text-dark: #2c2c2c;
  --hp-text-eyebrow: #be5737;
  --hp-text-muted: #6b7280;
  --hp-text-desc: color-mix(in oklab, #f7f1e5 70%, transparent);
  --hp-border: #ddd7c9;
  --hp-border-light: rgba(255, 255, 255, 0.1);

  --spacing: .25rem;
  
  --font-bold: 'TikTokSans-Bold', sans-serif;
  --font-reg: 'TikTokSans-Regular', sans-serif;

  font-family: var(--font-reg);
  color: var(--hp-text-dark);
  background-color: var(--hp-bg-main);
  line-height: 1.6;
}

.w-4 {
    width: calc(var(--spacing) * 4);
}
.h-4 {
    height: calc(var(--spacing) * 4);
}
img, svg, video, canvas, audio, iframe, embed, object {
    vertical-align: middle;
    display: block;
}

/* --- UTILITIES & TYPOGRAPHY --- */
#page-home .hp-container { max-width: 1240px; margin: 0 auto; padding: 0 24px; }
#page-home .hp-section { padding: 6rem 0; position: relative;}
#page-home .bg-secondary { background-color: var(--hp-bg-sec); }
#page-home .bg-primary { background-color: var(--hp-brand); }
#page-home .bg-main { background-color: var(--hp-bg-main); }
#page-home .text-light, #page-home .text-ivory { color: #fff; }
#page-home .text-ivory-70 { color: rgba(255,255,255,0.7); }
#page-home .text-gold { color: var(--hp-gold); }
#page-home .rounded { border-radius: 4px; }
#page-home .shadow-xl { box-shadow: 0 20px 40px rgba(0,0,0,0.1); }
#page-home .mt-4 { margin-top: 1rem; } #page-home .mt-6 { margin-top: 1.5rem; }
#page-home .mt-8 { margin-top: 2rem; } #page-home .mt-12 { margin-top: 3rem; }
#page-home .mt-16 { margin-top: 4rem; } #page-home .mb-4 { margin-bottom: 1rem; }
#page-home .mb-6 { margin-bottom: 1.5rem; }

#page-home .hp-eyebrow { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--hp-text-eyebrow); margin-bottom: 1rem; }
#page-home .hp-title-xl { font-family: var(--font-bold); font-size: clamp(2.5rem, 5vw, 4.5rem); color: var(--hp-brand); line-height: 1.2; margin-bottom: 2rem; }
#page-home .hp-title-lg { font-family: var(--font-bold); font-size: clamp(2rem, 4vw, 3rem); color: var(--hp-brand); line-height: 1.3; }
#page-home section.hp-services .hp-title-lg, #page-home section.hp-method .hp-title-lg, #page-home section.hp-method .hp-title-md, #page-home section.hp-method .hp-text-sm, #page-home section.hp-cta .hp-title-lg, #page-home section.hp-cta .hp-text-lg { color: #f7f1e5; }
#page-home section.hp-services .hp-title-md { font-family: var(--font-bold); font-size: 1.5rem; color: var(--hp-text-desc); margin-bottom: 1rem; }
#page-home .hp-title-sm { font-family: var(--font-bold); font-size: 1.25rem; color: var(--hp-brand); margin-bottom: 0.75rem; }
#page-home .hp-lede { font-size: 1.125rem; color: var(--hp-text-muted); margin-top: 1.5rem; max-width: 700px; }
#page-home section.hp-services .hp-lede { font-size: 1.125rem; color: var(--hp-text-desc); margin-top: 1.5rem; max-width: 700px; }
#page-home .hp-text-sm { font-size: 0.875rem; color: var(--hp-text-muted); line-height: 1.7; }
#page-home section.hp-services .hp-text-sm { font-size: 0.875rem; color: var(--hp-text-desc); line-height: 1.7; }
#page-home .hp-list-dots li { color: var(--hp-text-desc); }
#page-home .hp-max-3xl { max-width: 900px; }

/* --- GRID SYSTEM --- */
#page-home .hp-grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; }
#page-home .hp-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; }
#page-home section.hp-services .hp-grid-3 { gap: calc(var(--spacing) * 8); }
#page-home .hp-grid-12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 3rem; align-items: center; }
#page-home .hp-col-5 { grid-column: span 5; }
#page-home .hp-col-7 { grid-column: span 7; }
#page-home .hp-border-grid { background: var(--hp-border); border: 1px solid var(--hp-border); }

/* --- BUTTONS & LINKS --- */
#page-home .hp-btn-group { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2.5rem; }
#page-home .hp-btn { padding: 14px 28px; border-radius: 50px; text-decoration: none; font-family: var(--font-bold); font-size: 0.9rem; transition: all 0.3s ease; display: inline-flex; align-items: center; gap: 8px; cursor: pointer; }
#page-home .hp-btn-primary { background: var(--hp-brand); color: #fff; }
#page-home .hp-btn-primary:hover { background: #be5737; }
#page-home .hp-btn-ghost { background: transparent; color: var(--hp-brand); border: 1px solid var(--hp-border); }
#page-home .hp-btn-ghost:hover { background: var(--hp-border); }
#page-home .hp-btn-ghost-link { border-radius: 0; color: var(--hp-brand); font-family: var(--font-bold); text-decoration: none; border-bottom: 1px solid var(--hp-brand); padding-bottom: 2px; transition: gap .3s; }
#page-home .hp-btn-ghost-link:hover { color: var(--hp-accent); border-color: var(--hp-accent); gap: 1rem; }
#page-home .hp-btn-accent { background: var(--hp-accent); color: #fff; border-radius: 50px; }
#page-home .hp-btn-accent:hover { background: var(--hp-gold); }
#page-home .hp-btn-outline-light { border: 1px solid rgba(255,255,255,0.3); color: #fff; border-radius: 50px; }
#page-home .hp-btn-outline-light:hover { border-color: #fff; }
#page-home .hp-link-underline { color: var(--hp-accent); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 1px; text-decoration: none; border-bottom: 1px solid var(--hp-accent); padding-bottom: 2px; border-radius: 0; }
#page-home .hp-link-underline:hover { color: var(--hp-gold); border-color: var(--hp-gold); gap: 1rem; }

/* --- HERO SECTION --- */
#page-home .hp-hero { padding-top: 8rem; }
#page-home .hp-hero-grid { display: grid; grid-template-columns: 7fr 5fr; gap: 4rem; margin-bottom: 5rem; }
#page-home .hp-quote-small { font-style: italic; font-size: 0.875rem; color: var(--hp-text-muted); border-left: 2px solid var(--hp-accent); padding-left: 1rem; margin-top: 3rem; }
#page-home .hp-img-wrapper { position: relative; overflow: hidden; border-radius: 4px; }
#page-home .aspect-4-5 { aspect-ratio: 4/5; }
#page-home .hp-img-cover { width: 100%; height: 100%; object-fit: cover; }
#page-home .hp-gradient-overlay { position: absolute; inset: 0; background: linear-gradient(to top right, rgba(29,70,52,0.3), transparent); }
#page-home .hp-hero-visual { position: relative; }
#page-home .hp-philosophy-card { position: absolute; bottom: -24px; left: -48px; background: var(--hp-bg-main); padding: 24px; border: 1px solid var(--hp-border); max-width: 300px; z-index: 2; }
#page-home .hp-tag { font-size: 0.75rem; color: var(--hp-accent); text-transform: uppercase; letter-spacing: 2px; margin-bottom: 8px; }
#page-home .hp-philosophy-text { font-family: var(--font-bold); font-size: 1.125rem; color: var(--hp-brand); }
#page-home .hp-stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); background: var(--hp-border); gap: 1px; /*border: 1px solid var(--hp-border);*/ }
#page-home .hp-stat-card { background: var(--hp-bg-main); padding: 32px 24px; }
#page-home .hp-stat-num { font-family: var(--font-bold); color: var(--hp-accent); font-size: 1.25rem; margin-bottom: 12px; }

/* --- CARDS & LISTS --- */
#page-home .hp-card-hover { background: var(--hp-bg-sec); padding: 40px; transition: background 0.3s; }
#page-home .hp-card-hover:hover { background: var(--hp-bg-main); }
#page-home .hp-card-top { display: flex; align-items: center; gap: 1rem; margin-bottom: 1.5rem; }
#page-home .hp-card-num { font-family: var(--font-bold); color: var(--hp-accent); font-size: 2rem; }
#page-home .hp-line { height: 1px; flex: 1; background: var(--hp-border); transition: background 0.3s; }
#page-home .hp-card-hover:hover .hp-line { background: var(--hp-accent); }
#page-home .hp-card-solid { background: var(--hp-bg-main); padding: 40px; transition: background 0.3s; }
#page-home .hp-card-solid:hover { background: var(--hp-bg-sec); }
#page-home .hp-glass-card { background: rgba(255,255,255,0.05); backdrop-filter: blur(10px); border: 1px solid var(--hp-border-light); padding: 40px; transition: background 0.3s; }
#page-home .hp-glass-card:hover { background: rgba(255,255,255,0.1); }
#page-home .hp-card-top-flex { display: flex; justify-content: space-between; align-items: center; margin-bottom: 1.5rem; }
#page-home .hp-card-num-gold { font-family: var(--font-bold); font-size: 2rem; color: var(--hp-gold); }
#page-home .hp-list-dots { list-style: none; padding: 0; margin: 0 0 2rem 0; font-size: 0.85rem; }
#page-home .hp-list-dots li { margin-bottom: 6px; }
#page-home .hp-tag-accent { color: var(--hp-accent); font-size: 0.75rem; font-weight: bold; }

/* --- METHOD LIST --- */
#page-home .hp-method-list { list-style: none; padding: 0; margin: 0; }
#page-home .hp-method-list li { display: grid; grid-template-columns: 60px 1fr; gap: 24px; padding: 18px 0; border-bottom: 1px solid var(--hp-border-light); }
#page-home .hp-method-num { font-family: var(--font-bold); font-size: 2rem; color: var(--hp-gold); }

/* --- OTHER SECTIONS --- */
#page-home .hp-quote-box { position: absolute; top: -24px; right: -24px; background: var(--hp-accent); color: #fff; padding: 24px; max-width: 220px; z-index: 2; }
#page-home .hp-icon-quote { font-size: 3rem; line-height: 0.5; font-family: serif; display: block; margin-bottom: 10px; }
#page-home .hp-quote-text { font-style: italic; font-size: 1.125rem; }
#page-home .hp-bg-image-overlay { position: absolute; inset: 0; }
#page-home .hp-overlay-dark { position: absolute; inset: 0; background: rgba(250, 249, 246, 0.85); }
#page-home .hp-stat-box { background: var(--hp-bg-main); padding: 40px; }
#page-home .hp-stat-huge { font-family: var(--font-bold); font-size: 3.5rem; color: var(--hp-accent); margin-bottom: 1rem; }
#page-home .hp-tags-wrap { display: flex; flex-wrap: wrap; gap: 8px; }
#page-home .hp-pill-tag { font-size: 0.75rem; padding: 8px 16px; border: 1px solid var(--hp-border); border-radius: 50px; background: var(--hp-bg-main); color: var(--hp-text-muted); }
#page-home .hp-img-hover-scale { position: relative; overflow: hidden; }
#page-home section.hp-gallery .hp-img-hover-scale { margin: 0 10px; }
#page-home .hp-img-hover-scale img { transition: transform 0.7s ease; }
#page-home .hp-img-hover-scale:hover img { transform: scale(1.05); }
#page-home .hp-floating-tag { position: absolute; bottom: 16px; left: 16px; background: rgba(29,70,52,0.7); backdrop-filter: blur(4px); color: #fff; padding: 6px 12px; font-size: 0.75rem; text-transform: uppercase; border-radius: 50px; letter-spacing: 1px; }

/* --- CTA FOOTER --- */
#page-home .hp-cta-box { padding: 4rem 3rem; text-align: left; }
#page-home .hp-cta-glow { position: absolute; inset: 0; background: radial-gradient(circle at 80% 20%, rgba(196,90,64,0.15) 0, transparent 50%), radial-gradient(circle at 20% 80%, rgba(212,175,55,0.15) 0, transparent 50%); pointer-events: none; }

/* --- ANIMATIONS --- */
#page-home .hp-fade-up { opacity: 0; transform: translateY(40px); transition: opacity 0.8s ease-out, transform 0.8s ease-out; }
#page-home .hp-fade-up.is-visible { opacity: 1; transform: translateY(0);}
#page-home .style-delay-1 { transition-delay: 0.2s; }
#page-home .style-delay-2 { transition-delay: 0.4s; }

/* --- RESPONSIVE --- */
@media (max-width: 1024px) {
  #page-home .hp-grid-12, #page-home .hp-hero-grid { display: flex; flex-direction: column; gap: 3rem; }
  #page-home .hp-philosophy-card { left: 0; bottom: 0; }
  #page-home .order-mobile-2 { order: 2; }
  #page-home .order-mobile-1 { order: 1; }
  #page-home .hp-quote-box { right: 0; }
}
@media (max-width: 768px) {
  #page-home .hp-grid-2, #page-home .hp-grid-3, #page-home .hp-stats-grid { grid-template-columns: 1fr; }
  #page-home .hp-section { padding: 4rem 0; }
  #page-home .hp-cta-box { padding: 3rem 1.5rem; }
}