/* style.css */
@import url('https://fonts.googleapis.com/css2?family=Nunito:wght@300;400;600;700&family=Poppins:wght@400;500;700;800&display=swap');

:root {
  --primary-color: #4F46E5; /* Indigo 600 */
  --secondary-color: #312E81; /* Indigo 900 */
  --accent-color: #14B8A6; /* Teal 500 */
  --light-color: #F8FAFC; /* Slate 50 */
  --dark-color: #0F172A; /* Slate 900 */
  --text-color: #334155; /* Slate 700 */
  --background-color: #FFFFFF;
  --font-heading: 'Poppins', sans-serif;
  --font-text: 'Nunito', sans-serif;
}

body {
  font-family: var(--font-text);
  color: var(--text-color);
  background-color: var(--background-color);
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  margin: 0;
  -webkit-font-smoothing: antialiased;
}

main {
  flex: 1;
}

h1, h2, h3, h4, h5, h6, .font-heading {
  font-family: var(--font-heading);
  color: var(--dark-color);
}

.text-primary { color: var(--primary-color); }
.bg-primary { background-color: var(--primary-color); }
.bg-secondary { background-color: var(--secondary-color); }
.text-accent { color: var(--accent-color); }
.bg-accent { background-color: var(--accent-color); }
.bg-light { background-color: var(--light-color); }
.text-dark { color: var(--dark-color); }
.bg-dark { background-color: var(--dark-color); }

.btn-primary {
  background-color: var(--primary-color);
  color: #ffffff;
  padding: 1rem 2.5rem;
  border-radius: 9999px; /* Pill shape */
  font-weight: 600;
  font-family: var(--font-heading);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: inline-block;
  text-align: center;
  box-shadow: 0 4px 14px 0 rgba(79, 70, 229, 0.39);
  border: 2px solid transparent;
}

.btn-primary:hover {
  background-color: transparent;
  color: var(--primary-color);
  border-color: var(--primary-color);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(79, 70, 229, 0.23);
}

.btn-accent {
  background-color: var(--accent-color);
  color: #ffffff;
  padding: 1rem 2.5rem;
  border-radius: 9999px;
  font-weight: 700;
  font-family: var(--font-heading);
  transition: all 0.3s ease;
  display: inline-block;
  text-align: center;
  box-shadow: 0 4px 14px 0 rgba(20, 184, 166, 0.39);
}

.btn-accent:hover {
  background-color: #0D9488;
  transform: translateY(-2px);
  color: #ffffff;
}

/* Cookie Banner (JS Version) */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgba(15, 23, 42, 0.95);
  backdrop-filter: blur(10px);
  color: #ffffff;
  padding: 1.5rem;
  text-align: center;
  z-index: 9999;
  box-shadow: 0 -10px 40px rgba(0,0,0,0.2);
  border-top: 1px solid rgba(255,255,255,0.1);
}

.cookie-btn {
  cursor: pointer;
  padding: 0.75rem 2rem;
  margin: 0.5rem;
  background-color: var(--accent-color);
  color: #ffffff;
  border-radius: 8px;
  border: none;
  display: inline-block;
  font-weight: 700;
  font-family: var(--font-heading);
  transition: all 0.2s ease;
}

.cookie-btn:hover {
  background-color: #0D9488;
  transform: scale(1.02);
}

.cookie-btn-alt {
  background-color: transparent;
  border: 2px solid #64748B;
  color: #F1F5F9;
}

.cookie-btn-alt:hover {
  background-color: #334155;
  border-color: #94A3B8;
  color: #ffffff;
}

/* Mobile Menu */
#mobile-menu {
  display: none;
  transform-origin: top;
  animation: slideDown 0.3s ease-out forwards;
}
#mobile-menu.active {
  display: block;
}

@keyframes slideDown {
  0% { opacity: 0; transform: scaleY(0.9); }
  100% { opacity: 1; transform: scaleY(1); }
}

.hero-overlay {
  background: linear-gradient(90deg, rgba(15, 23, 42, 0.85) 0%, rgba(49, 46, 129, 0.6) 100%);
}