/* --- NEO-BRUTALISM THEME V2 (REFINED) --- */

/* 1. FONT IMPORT */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;0,9..40,800;1,9..40,400&display=swap');

/* 2. CSS VARIABLES (REFINED) */
:root {
  --background: oklch(0.99 0 0);
  --foreground: oklch(0.15 0 0); /* Softer than pure black */
  --border-color: oklch(0.2 0 0);
  --border-color-soft: oklch(0.9 0 0); /* Lighter grey for tables */
  --radius: 0px;
  --shadow-sm: 3px 3px 0px 0px var(--border-color); /* Slightly smaller shadow */
  
  --primary: oklch(0.6489 0.2370 26.9728);   /* Orange */
  --primary-foreground: oklch(1.0000 0 0);
  --secondary: oklch(0.85 0.18 115); /* Softer Green */
  --secondary-foreground: oklch(0.1 0 0);
  --destructive: oklch(0.73 0.2 20);
  --destructive-foreground: oklch(1.0000 0 0);

  --muted: oklch(0.96 0 0); /* Lighter grey background */
  --muted-foreground: oklch(0.45 0 0);

  --chart-1: var(--primary);
  --chart-2: oklch(0.9680 0.2110 109.7692);

  --font-sans: 'DM Sans', sans-serif;
}

/* 3. BASE STYLES */
body {
  font-family: var(--font-sans);
  background-color: var(--background);
  color: var(--foreground);
}

h1, h2, h3, h4, h5, h6 {
  font-weight: 700;
  color: var(--foreground);
}

/* 4. COMPONENT STYLES */

/* Buttons */
.btn {
  border-radius: var(--radius);
  border: 2px solid var(--border-color);
  box-shadow: var(--shadow-sm);
  font-weight: 700;
  transition: all 0.1s ease-in-out;
}
.btn:hover {
  transform: translate(-2px, -2px);
  box-shadow: 5px 5px 0px 0px var(--border-color);
}
.btn:active {
  transform: translate(1px, 1px) !important;
  box-shadow: 2px 2px 0px 0px var(--border-color) !important;
}

.btn-neo-primary { background-color: var(--primary); color: var(--primary-foreground); }
.btn-neo-primary:hover { background-color: var(--primary); color: var(--primary-foreground); }
.btn-neo-secondary { background-color: var(--background); color: var(--foreground); }
.btn-neo-secondary:hover { background-color: var(--background); color: var(--foreground); }
.btn-neo-danger { background-color: var(--destructive); color: var(--destructive-foreground); }
.btn-neo-danger:hover { background-color: var(--destructive); color: var(--destructive-foreground); }

/* Cards */
.card-neo {
  background-color: var(--background);
  border: 2px solid var(--border-color);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
}
.card-neo-interactive:hover {
  transform: translate(-4px, -4px);
  box-shadow: 7px 7px 0px 0px var(--border-color);
}
.card-neo .card-header {
  border-bottom: 2px solid var(--border-color);
  border-radius: 0;
  padding: 1rem 1.5rem; /* ADDED PADDING */
}
.card-neo .card-body {
  padding: 1.5rem; /* ADDED PADDING */
}

/* Forms */
.form-control-neo, .form-select-neo {
  border: 2px solid var(--border-color);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  padding: .75rem 1rem;
}
.form-control-neo:focus, .form-select-neo:focus {
  border-color: var(--primary);
  box-shadow: var(--shadow-sm), 0 0 0 2px var(--primary);
  outline: 0;
}

/* REFINED Table Style */
.table-refined {
  border-spacing: 0;
  width: 100%;
}
.table-refined th {
  background-color: var(--muted);
  border-bottom: 2px solid var(--border-color-soft);
  font-weight: 600;
  color: var(--muted-foreground);
  text-transform: uppercase;
  font-size: 0.8rem;
  letter-spacing: 0.05em;
}
.table-refined td, .table-refined th {
  padding: 1rem 1.5rem; /* ADDED PADDING */
  text-align: left;
  border-bottom: 1px solid var(--border-color-soft);
}
.table-refined tbody tr:hover {
  background-color: var(--muted);
}

/* Modals */
.modal-content-neo {
  border: 2px solid var(--border-color);
  border-radius: var(--radius);
  box-shadow: 6px 6px 0px 0px var(--border-color);
}
.modal-content-neo .modal-header, .modal-content-neo .modal-footer {
  border-color: var(--border-color);
  padding: 1.5rem;
}

/* Badges */
.badge-neo {
  border: 2px solid var(--border-color);
  color: var(--foreground);
  background-color: var(--muted);
  font-size: 0.9em;
  padding: 0.4em 0.7em;
  font-weight: 700;
  border-radius: var(--radius);
}
.badge-neo.bg-success {
    background-color: var(--secondary);
    color: var(--secondary-foreground);
    border-color: var(--secondary-foreground);
}

/* Flash Messages */
.alert-neo {
    border: 2px solid var(--border-color);
    border-radius: var(--radius);
    box-shadow: var(--shadow-sm);
    font-weight: 700;
    padding: 1rem 1.5rem;
}
.alert-neo.alert-success { background-color: var(--secondary); color: var(--secondary-foreground); border-color: var(--secondary-foreground); }
.alert-neo.alert-danger { background-color: var(--destructive); color: var(--destructive-foreground); border-color: var(--border-color); }
.alert-neo.alert-warning { background-color: var(--primary); color: var(--primary-foreground); border-color: var(--border-color); }

/* --- CORRECTED FIX FOR HOMEPAGE FAQ --- */

.accordion .accordion-item {
  border: 2px solid var(--border-color);
  box-shadow: var(--shadow-sm);
  margin-bottom: 1rem;
  background-color: var(--background); /* Ensure background is correct */
  border-radius: var(--radius); /* Ensure no rounded corners */
}

.accordion .accordion-button {
  font-weight: 700;
  color: var(--foreground); /* Black font, as requested */
  text-decoration: none;
  background-color: transparent;
  width: 100%;
  text-align: left;
  border: none;
  /* This adds the necessary padding */
  padding: 1.25rem 1.5rem; 
}

.accordion .accordion-button:focus {
  box-shadow: none; /* Remove blue glow on click */
}

/* When the accordion is open, the button color remains black */
.accordion .accordion-button:not(.collapsed) {
  color: var(--foreground); 
  background-color: transparent;
  box-shadow: none;
}

/* Remove Bootstrap's default ugly arrow icon */
.accordion .accordion-button::after {
  display: none;
}

.accordion .accordion-body {
  /* Add padding to the answer text */
  padding: 0 1.5rem 1.5rem 1.5rem; 
  color: var(--muted-foreground);
}
/* --- START: ADDITIVE STYLES FOR NEW HOMEPAGE HERO --- */

/* This styles the "Clarity." text with your primary orange color */
.hero-highlight {
    color: var(--primary);
}

/* This styles the header dots inside the mockup */
.mockup-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    border: 1px solid rgba(0,0,0,0.2);
}

/* This adds the subtle fade-in animation */
.hero-text-animation, .hero-mockup-animation {
    animation: fadeInUp 0.8s ease-out forwards;
}

.hero-mockup-animation {
    animation-delay: 0.2s;
    opacity: 0; /* Starts hidden */
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}
/* --- END: ADDITIVE STYLES FOR NEW HOMEPAGE HERO --- */

/* --- START: DROPDOWN & OVERLAP FIXES --- */

/* This targets the dropdown menu itself */
.dropdown-menu.card-neo {
    /* Ensures the dropdown appears ON TOP of all other content */
    z-index: 1050; 
}

/* 
This targets the individual items INSIDE the dropdown.
It fixes the hover color and the text readability.
*/
.dropdown-menu.card-neo .dropdown-item:hover,
.dropdown-menu.card-neo .dropdown-item:focus {
    background-color: var(--primary);       /* USE OUR ORANGE */
    color: var(--primary-foreground);       /* USE OUR BLACK TEXT */
}

/* --- END: DROPDOWN & OVERLAP FIXES --- */