:root {
    --zombie-green: #4CAF50;
    --beetlejuice-purple: #673AB7;
    --ftb-red: #D32F2F;
    --dark-background: #1a1a1a;
    --dark-text: #333;
}

body { font-family: 'Helvetica Neue', Helvetica, Arial, sans-serif; margin: 0; padding: 0; color: var(--dark-text); line-height: 1.6; background-color: #fff; }
.container { width: 90%; max-width: 1100px; margin: 0 auto; padding: 0 20px; }

/* HERO SECTION */
.hero { background-color: var(--dark-background); padding: 60px 0; text-align: center; border-bottom: 5px solid var(--zombie-green); }
.hero img.main-zombie { width: 90%; max-width: 550px; height: auto; margin-bottom: 20px; filter: drop-shadow(0px 10px 15px rgba(0,0,0,0.5)); }
.hero h1 { font-size: 3.5rem; margin-bottom: 10px; color: #fff; }
.hero h1 span { color: var(--zombie-green); }
.hero p.subtitle { font-size: 1.6rem; color: #ccc; max-width: 800px; margin: 0 auto 40px auto; }

/* SEARCH BAR */
.search-container { background: #fff; padding: 10px; border-radius: 50px; box-shadow: 0 10px 25px rgba(0,0,0,0.1); display: flex; max-width: 600px; margin: 0 auto; border: 2px solid #eee; }
.search-container input { flex-grow: 1; border: none; padding: 15px 25px; font-size: 1.2rem; border-radius: 50px 0 0 50px; outline: none; }
.search-container button { background-color: var(--zombie-green); color: white; border: none; padding: 15px 30px; font-size: 1.2rem; font-weight: bold; border-radius: 50px; cursor: pointer; }
#results-area { margin-top: 30px; font-weight: bold; font-size: 1.2rem; min-height: 50px; }

/* FAQ SECTION */
.faq { padding: 80px 0; background-color: #fcfcfc; }
.faq h2 { text-align: center; font-size: 2.8rem; margin-bottom: 50px; color: #111; }
.faq-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.faq-item { background: #fff; padding: 30px; border-radius: 12px; border: 1px solid #eee; box-shadow: 0 4px 6px rgba(0,0,0,0.02); transition: transform 0.2s; }
.faq-item:hover { transform: translateY(-5px); border-color: var(--zombie-green); }
.faq-item h3 { color: var(--beetlejuice-purple); margin-top: 0; font-size: 1.4rem; }
.faq-item p { color: #555; margin-bottom: 0; font-size: 1.05rem; }

/* FOOTER */
.footer { background-color: var(--dark-background); color: #fff; padding: 80px 0; text-align: center; border-top: 5px solid var(--zombie-green); }
.footer img.ghost-zombie { width: 90%; max-width: 450px; height: auto; margin-bottom: 20px; }
.footer h3 { color: var(--zombie-green); font-size: 2.5rem; }
.footer p.case-study { color: #bbb; max-width: 700px; margin: 0 auto 30px auto; font-size: 1.4rem; }

/* MODALS */
.footer-nav { margin-top: 40px; display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; }
.footer-nav a { color: #888; text-decoration: none; font-size: 0.95rem; cursor: pointer; font-weight: 500; }
.footer-nav a:hover { color: var(--zombie-green); }

.modal { display: none; position: fixed; z-index: 1000; left: 0; top: 0; width: 100%; height: 100%; background-color: rgba(0,0,0,0.85); overflow-y: auto; }
.modal-content { background-color: #fff; margin: 5% auto; padding: 40px; border-radius: 15px; width: 85%; max-width: 800px; color: #333; text-align: left; position: relative; }
.close { position: absolute; right: 20px; top: 10px; font-size: 32px; font-weight: bold; cursor: pointer; color: #aaa; }

@media (max-width: 850px) {
    .faq-grid { grid-template-columns: 1fr; }
    .hero h1 { font-size: 2.5rem; }
    .search-container { flex-direction: column; border-radius: 20px; }
    .search-container input { border-radius: 20px; text-align: center; }
    .search-container button { border-radius: 20px; width: 100%; }
}