@import url('https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.0.0/css/all.min.css');

:root {
  /* Blue & Teal Palette for Trust/Health */
  --primary-color: #3498DB;
  --secondary-color: #2980B9;
  --accent-color: #1ABC9C;
  --light-color: #ECF0F1;
  --dark-color: #2C3E50;
  --gradient-primary: linear-gradient(135deg, #AED6F1 0%, #3498DB 100%);
  --hover-color: #2874A6;
  --background-color: #F0F4F8; /* Light Grey-Blue */
  --text-color: #34495E;
  --border-color: rgba(52, 152, 219, 0.2);
  --divider-color: rgba(41, 128, 185, 0.1);
  --shadow-color: rgba(44, 62, 80, 0.1);
  --highlight-color: #E67E22; /* Complementary Orange */
  --main-font: 'Montserrat', sans-serif;
  --alt-font: 'Open Sans', serif;
}

/* Base Styles */
html { scroll-behavior: smooth; }
body { font-family: var(--alt-font); background-color: var(--background-color); color: var(--text-color); margin: 0; padding: 0; }
h1, h2, h3, h4, h5, h6 { font-family: var(--main-font); color: var(--dark-color); }

/* Neumorphism Utilities */
.neumorphic {
    background: var(--background-color);
    box-shadow: 9px 9px 16px rgb(163,177,198,0.6), -9px -9px 16px rgba(255,255,255, 0.5);
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.2);
}
.neumorphic-inset {
    background: var(--background-color);
    box-shadow: inset 6px 6px 10px 0 rgb(163,177,198, 0.7), inset -6px -6px 10px 0 rgba(255,255,255, 0.8);
    border-radius: 8px;
}

/* Custom CSS required per prompt */
.hero-bg {
    background: linear-gradient(rgba(44, 62, 80, 0.7), rgba(44, 62, 80, 0.7)), url('./img/bg.jpg') no-repeat center center/cover;
    height: 70vh; /* Random between 60-80 */
}
.cta-bg {
    background: linear-gradient(rgba(0, 0, 0, 0.6), rgba(0, 0, 0, 0.6)), url('./img/bg.jpg') no-repeat center center/cover;
    background-attachment: fixed;
}
.feature-icon {
    font-size: 2rem;
    color: var(--primary-color);
    margin-bottom: 1rem;
}
.section-padding { padding-top: 10vh; padding-bottom: 10vh; }

/* Mobile Menu Logic (CSS Only) */
#menu-toggle { display: none; }
.mobile-menu { display: none; }
@media (max-width: 768px) {
    .nav-links { display: none; }
    .hamburger { display: block; cursor: pointer; font-size: 1.5rem; color: #fff; }
    #menu-toggle:checked ~ .mobile-menu { display: flex; flex-direction: column; background: var(--dark-color); position: absolute; top: 60px; left: 0; width: 100%; padding: 1rem; z-index: 50; }
    .mobile-menu a { color: #fff; padding: 10px; text-decoration: none; border-bottom: 1px solid rgba(255,255,255,0.1); }
}

/* FAQ Accordion (CSS Only) */
details summary { cursor: pointer; outline: none; list-style: none; padding: 15px; font-weight: bold; background: rgba(255,255,255,0.5); border-radius: 5px; margin-bottom: 5px;}
details[open] summary ~ * { animation: sweep .5s ease-in-out; }
@keyframes sweep { 0% {opacity: 0; margin-top: -10px} 100% {opacity: 1; margin-top: 0px} }