/* Force parent containers to allow widget expansion */
.widget_text .cr-program-matcher,
.textwidget .cr-program-matcher,
.widget .cr-program-matcher,
[class*="widget"] .cr-program-matcher {
  overflow: visible !important;
  max-height: none !important;
  height: auto !important;
}

/* CSS Variables for consistent theming - Scoped to widget */
.cr-program-matcher {
  /* Colors */
  --color-primary: #0044ab;
  --color-danger: #dc2626;
  --color-success: #008000;

  /* Text Colors */
  --color-text-primary: #1f2937;
  --color-text-secondary: #6c757d;
  --color-text-white: #ffffff;

  /* Background Colors */
  --color-bg-primary: #ffffff;
  --color-bg-tag: #e7f0f5;
  --color-bg-tag-text: #0c4a6f;

  /* Border Colors */
  --color-border: #b3b3b3;
  --color-border-hover: #2563eb;
  --color-divider: #e5e7eb;

  /* Shadows */
  --shadow-lg: 0 4px 20px rgba(0, 0, 0, 0.1);

  /* Spacing */
  --spacing-sm: 8px;
  --spacing-md: 12px;
  --spacing-lg: 16px;
  --spacing-xl: 20px;
  --spacing-2xl: 24px;

  /* Border Radius */
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 24px;

  /* Typography */
  --font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen,
    Ubuntu, Cantarell, sans-serif;
  --font-size-sm: 14px;
  --font-size-md: 20px;
  --font-size-lg: 26px;
  --font-size-xl: 32px;

  /* Font Weights */
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;

  /* Transitions */
  --transition-normal: 0.2s ease;

  /* Layout */
  --container-max-width: 100%;
  --logo-height: 24px;
  --logo-max-width: 120px;

  /* Reset and base styles - scoped to widget only */
  font-family: var(--font-family);
  color: var(--color-text-primary);
  line-height: 1.5;
  box-sizing: border-box;

  /* Container styles */
  background: rgb(248, 249, 250);
  border-radius: var(--radius-lg);
  border: 1px solid #d3d3d3;
  box-shadow: var(--shadow-lg);
  max-width: 100%;
  width: 100%;
  overflow: visible;
  margin: 0;

  /* Layout isolation to prevent affecting WordPress sidebar */
  position: relative;
  display: block;
  clear: both;
  /* Remove containment to allow free expansion */
  /* contain: layout; - REMOVED to allow expansion */
  /* isolation: isolate; - REMOVED to prevent stacking issues */
  /* Prevent parent overflow from clipping widget */
  min-height: 0;
  /* Ensure widget can expand */
  height: auto;
  /* Prevent layout breaks */
  will-change: auto;
  /* Ensure widget doesn't get clipped by parent */
  overflow: visible !important;
  /* Force parent containers to allow overflow */
  max-height: none !important;
}

/* Reset only elements within the widget */
.cr-program-matcher *,
.cr-program-matcher *::before,
.cr-program-matcher *::after {
  box-sizing: border-box;
}

/* Logo Styles */
.cr-program-matcher .logo {
  display: flex;
  align-items: center;
}

.cr-program-matcher .college-recon-logo {
  height: var(--logo-height);
  width: auto;
  max-width: var(--logo-max-width);
}

/* Divider - High specificity to override WordPress theme styles */
.cr-program-matcher .divider,
.cr-program-matcher hr.divider,
.cr-program-matcher hr {
  border: none !important;
  border-top: none !important;
  border-bottom: none !important;
  border-left: none !important;
  border-right: none !important;
  height: 1px !important;
  background: var(--color-divider) !important;
  background-color: var(--color-divider) !important;
  margin: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding: 0 !important;
  width: 100% !important;
  box-sizing: border-box !important;
  display: block !important;
  /* Reset common WordPress/Bootstrap hr styles */
  opacity: 1 !important;
  color: var(--color-divider) !important;
  clear: both !important;
  float: none !important;
  position: relative !important;
}

/* Form Content */
.cr-program-matcher .form-content {
  padding: var(--spacing-lg) var(--spacing-lg);
  /* Ensure form can expand */
  overflow: visible !important;
  min-height: 0;
}

/* Wider padding for wide containers */
.cr-program-matcher.cr-wide-container .form-content {
  padding: 0 var(--spacing-2xl) 0 var(--spacing-2xl);
}

.cr-program-matcher .form-content .title {
  text-align: center;
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  margin: 6px !important;
  color: var(--color-text-primary);
}

/* Smaller title for narrow containers */
.cr-program-matcher.cr-narrow-container .form-content .title {
  font-size: 18px;
}

.cr-program-matcher .form-content .subtitle {
  text-align: center;
  margin: 10px !important;
  color: var(--color-text-primary);
  font-size: var(--font-size-sm);
}
 .cr-program-matcher .section{
  margin-top: 20px !important;
 }

/* Input Groups - High specificity to override WordPress themes */
.cr-program-matcher .input-group,
.cr-program-matcher div.input-group {
  margin-bottom: var(--spacing-lg) !important;
  margin-top: 0 !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  display: block !important;
  width: 100% !important;
  position: relative !important;
  padding: 0 !important;
  border: none !important;
  background: none !important;
  box-shadow: none !important;
  transition: all var(--transition-normal);
  /* Reset common WordPress/Bootstrap input-group styles */
  flex-direction: initial !important;
  align-items: initial !important;
  justify-content: initial !important;
  flex-wrap: initial !important;
  /* Ensure input group can expand */
  overflow: visible !important;
  min-height: 0 !important;
  max-height: none !important;
}

/* More spacing for wide containers */
.cr-program-matcher.cr-wide-container .input-group {
  margin-bottom: var(--spacing-2xl) !important;
}

.cr-program-matcher .input-group label,
.cr-program-matcher div.input-group label {
  display: block !important;
  font-size: var(--font-size-sm) !important;
  font-weight: var(--font-weight-bold) !important;
  color: var(--color-text-primary) !important;
  margin-bottom: var(--spacing-sm) !important;
  font-family: var(--font-family) !important;
  line-height: 1.5 !important;
}

/* Education Goals */
.cr-program-matcher .education-goals {
  display: grid;
  /* Default to 2 columns for narrow containers (like sidebars) */
  grid-template-columns: 1fr 1fr;
  gap: var(--spacing-sm);
  /* Remove containment to allow free expansion */
  /* contain: layout; - REMOVED */
  min-height: 0;
  /* Ensure grid stays within bounds */
  width: 100%;
  box-sizing: border-box;
  /* Smooth expansion */
  transition: none; /* Remove transition that might cause issues */
  /* Prevent layout breaks */
  will-change: auto;
  /* Ensure grid can expand */
  overflow: visible !important;
}

/* Use 3 columns only when widget container is wide enough */
.cr-program-matcher.cr-wide-container .education-goals {
  grid-template-columns: 1fr 1fr 1fr;
}

/* Ensure narrow container always uses 2 columns */
.cr-program-matcher.cr-narrow-container .education-goals {
  grid-template-columns: 1fr 1fr !important;
}

.cr-program-matcher .loading {
  grid-column: 1 / -1;
  text-align: center;
  padding: var(--spacing-xl);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.cr-program-matcher .goal-btn {
  padding: var(--spacing-md) var(--spacing-sm);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-primary);
  color: var(--color-text-primary);
  font-size: 12px;
  font-weight: var(--font-weight-medium);
  cursor: pointer;
  transition: all var(--transition-normal);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
}

/* Larger buttons for wide containers */
.cr-program-matcher.cr-wide-container .goal-btn {
  padding: var(--spacing-md) var(--spacing-lg);
  font-size: var(--font-size-sm);
}

.cr-program-matcher .goal-btn:hover {
  box-shadow: 0 6px 10px rgba(0, 0, 0, 0.15);
  transform: translateY(-1px);
}

.cr-program-matcher .goal-btn.selected {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: var(--color-text-white);
  position: relative;
}

.cr-program-matcher .goal-btn.selected::before {
  content: "✓";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  background: var(--color-text-white);
  border-radius: 50%;
  margin-right: var(--spacing-sm);
  font-size: 12px;
  font-weight: var(--font-weight-bold);
  color: var(--color-primary);
  flex-shrink: 0;
}

/* Location Input */
.cr-program-matcher .location-input {
  position: relative;
  background: var(--color-text-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--spacing-md) var(--spacing-md);
  min-height: 48px;
  display: flex;
  align-items: center;
  cursor: text;
  transition: border-color var(--transition-normal);
}

/* More padding for wide containers */
.cr-program-matcher.cr-wide-container .location-input {
  padding: var(--spacing-md) var(--spacing-lg);
}

.cr-program-matcher .location-input:hover {
  border-color: var(--color-border-hover);
}

.cr-program-matcher .location-input:focus-within {
  border-color: var(--color-border-hover);
  outline: none;
}

.cr-program-matcher .input-content {
  display: flex;
  flex: 1;
  align-items: center;
  position: relative;
}

.cr-program-matcher .tags-container {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  flex: 1;
}

.cr-program-matcher .tag {
  background: var(--color-bg-tag);
  color: var(--color-bg-tag-text);
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-xl);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  display: flex;
  align-items: center;
  gap: var(--spacing-sm);
}

.cr-program-matcher .remove-tag {
  cursor: pointer;
  font-weight: var(--font-weight-bold);
  font-size: var(--font-size-sm);
  line-height: 1;
}

.cr-program-matcher .remove-tag:hover {
  color: var(--color-danger);
}

.cr-program-matcher .input-placeholder {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  pointer-events: none;
}

.cr-program-matcher .dropdown-icon {
  color: var(--color-text-secondary);
  font-size: 12px;
  margin-left: var(--spacing-sm);
  flex-shrink: 0;
}

/* Enhanced Dropdown Styles */
.cr-program-matcher .location-dropdown {
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.15);
  border: 1px solid #d1d5db;
  border-top: none;
}

.cr-program-matcher .location-dropdown input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.cr-program-matcher .dropdown-option:hover {
  background-color: #f3f4f6;
}

.cr-program-matcher .dropdown-option.selected {
  background-color: var(--color-primary);
  color: white;
}

.cr-program-matcher .checkbox svg {
  pointer-events: none;
}

/* Dropdown Styles */
.cr-program-matcher .location-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: white;
  border: 1px solid #d1d5db;
  border-top: none;
  border-radius: 0 0 8px 8px;
  max-height: 250px;
  overflow-y: auto;
  z-index: 1000;
  display: none;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

/* Search Container */
.cr-program-matcher .search-container {
  padding: 12px 16px;
  border-bottom: 1px solid #e5e7eb;
  position: sticky;
  top: 0;
  background: white;
  z-index: 1;
}

/* Search Input */
.cr-program-matcher .search-input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid #d1d5db;
  border-radius: 6px;
  font-size: 14px;
  outline: none;
}

.cr-program-matcher .search-input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1);
}

.cr-program-matcher .dropdown-option {
  padding: 12px 16px;
  cursor: pointer;
  font-size: var(--font-size-sm);
  color: #1f2937;
  display: flex;
  align-items: center;
  gap: 12px;
  transition: background-color 0.15s ease;
}

.cr-program-matcher .dropdown-option:hover {
  background-color: #f3f4f6;
}

.cr-program-matcher .dropdown-option.selected {
  background-color: var(--color-bg-tag);
  color: var(--color-bg-tag-text);
}

.cr-program-matcher .dropdown-option.disabled {
  cursor: not-allowed;
  color: #9ca3af;
  opacity: 0.5;
}

/* Checkbox Styles */
.cr-program-matcher .checkbox {
  width: 20px;
  height: 20px;
  border: 2px solid #d1d5db;
  border-radius: 3px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  flex-shrink: 0;
}

.cr-program-matcher .checkbox.checked {
  border-color: var(--color-primary);
  background: var(--color-primary);
}

/* Error Message */
.cr-program-matcher .error-message {
  position: absolute;
  top: -30px;
  left: 0;
  background: #dc2626;
  color: white;
  padding: 4px 8px;
  border-radius: var(--radius-md);
  font-size: 12px;
  z-index: 1001;
  animation: cr-program-matcher-fadeInOut 2s ease-in-out;
}

@keyframes cr-program-matcher-fadeInOut {
  0%,
  100% {
    opacity: 0;
  }
  20%,
  80% {
    opacity: 1;
  }
}

/* Footer */
.cr-program-matcher .footer {
  padding: var(--spacing-lg);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--spacing-md);
}

/* Wider padding for wide containers */
.cr-program-matcher.cr-wide-container .footer {
  padding: var(--spacing-xl) var(--spacing-2xl);
  flex-wrap: nowrap;
}

.cr-program-matcher .powered-by {
  /* display: flex; */
  align-items: center;
  gap: var(--spacing-sm);
  font-size: 12px;
  color: var(--color-text-secondary);
}

.cr-program-matcher .get-started-btn {
  background: var(--color-success);
  color: var(--color-text-white);
  border: none;
  border-radius: var(--radius-xl);
  padding: var(--spacing-md) var(--spacing-lg);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  cursor: pointer;
  transition: background-color var(--transition-normal);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Larger button for wide containers */
.cr-program-matcher.cr-wide-container .get-started-btn {
  padding: var(--spacing-md) var(--spacing-2xl);
}

.cr-program-matcher .get-started-btn:hover {
  transform: translateY(1px);
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
}

.cr-program-matcher .get-started-btn.disabled {
  /* background: #9ca3af; */
  cursor: not-allowed;
  opacity: 0.6;
}

.cr-program-matcher .get-started-btn.disabled:hover {
  transform: none;
  box-shadow: none;
}

/* Container queries for modern browsers (fallback if JavaScript doesn't work) */
@supports (container-type: inline-size) {
  .cr-program-matcher {
    container-type: inline-size;
  }

  @container (min-width: 500px) {
    .cr-program-matcher .education-goals {
      grid-template-columns: 1fr 1fr 1fr;
    }

    .cr-program-matcher .form-content {
      padding: 0 var(--spacing-2xl) 0 var(--spacing-2xl);
    }

    .cr-program-matcher .footer {
      padding: var(--spacing-xl) var(--spacing-2xl);
    }
  }
}
