/* 
 * F1 CLASH CALCULATOR STYLES
 * Complete version with compact styling and coherent organization
 */

/*==============================================
 * MAIN CONTAINER & RESPONSIVE LAYOUT
 *==============================================*/
 .calculator-container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 20px;
  height: 100%;
  overflow-y: auto;
}

@media (max-width: 1200px) {
  .calculator-container {
    grid-template-columns: 1fr;
  }
}


/*==============================================
 * TRACK & TEAM ACTIONS LAYOUT
 *==============================================*/
/* Layout for track selection and team actions */
.calculator-container .track-and-actions {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 15px;
  width: 100%;
}

/* Make track selection more compact */
.calculator-container .track-selection {
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: 15px;
  width: 60%; /* Reduce to 60% of container width */
  margin-left: auto; /* Push to the right side */
}

/* Style track key stats to be more compact */
.calculator-container .track-key-stats {
  display: flex;
  justify-content: space-between;
  gap: 8px; /* Reduced from 10px */
  margin-top: 8px; /* Reduced from 10px */
}

.calculator-container .track-dominant-stat, 
.calculator-container .track-secondary-stat {
  flex: 1;
  padding: 8px; /* Reduced from 10px */
  border-radius: var(--border-radius-md);
  background-color: rgba(52, 152, 219, 0.1); /* Light blue background */
  text-align: center;
  border: 1px solid rgba(52, 152, 219, 0.3); /* Light blue border */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

/* Series badges in track display */
.calculator-container .track-series {
  margin-top: 8px; /* Reduced from 10px */
  display: flex;
  align-items: center;
  background-color: rgba(52, 152, 219, 0.05); /* Very light blue background */
  border-radius: var(--border-radius-md);
  padding: 5px 8px;
  border: 1px solid rgba(52, 152, 219, 0.2); /* Very light blue border */
}

/* Style team actions for the new layout */
.calculator-container .track-and-actions .team-actions {
  width: 35%; /* Take 35% of the available space */
  margin: 0;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  height: 100%;
  justify-content: center;
  padding: 15px;
}

/* Adjust team score display for vertical layout */
.calculator-container .track-and-actions .team-actions .score-display {
  margin-bottom: 10px;
  width: 100%;
  border: 2px solid #e74c3c; /* Add border matching the score color */
  border-radius: 8px;
  padding: 8px 12px;
  background-color: rgba(231, 76, 60, 0.05); /* Very subtle red background */
  box-shadow: 0 2px 5px rgba(231, 76, 60, 0.1);
}

/* Make the optimize button take full width */
.calculator-container .track-and-actions .team-actions .optimize-btn {
  width: 100%;
  justify-content: center;
}

/* Remove the team actions from its original location */
.calculator-container .boosts-grid .team-actions {
  display: none;
}


/*==============================================
 * LEFT PANEL - SETUP PANEL STYLES
 *==============================================*/
.calculator-container .setup-panel {
  background-color: var(--color-card);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-md);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  overflow: auto;
}

.calculator-container .setup-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 15px;
}

/*==============================================
 * SECTION DIVIDERS - Used across all sections
 *==============================================*/
.calculator-container .section-divider {
  display: flex;
  align-items: center;
  margin: 18px 0 12px; /* Compact: reduced from 30px 0 25px */
  width: 100%;
  max-width: 100%;
  position: relative;
}

.calculator-container .section-divider .divider-line {
  flex-grow: 1;
  height: 1px;
  background: rgba(231, 76, 60, 0.7); /* Red color with transparency */
}

.calculator-container .section-divider .divider-text {
  padding: 0 10px; /* Compact: reduced from 0 15px */
  font-size: 13px; /* Compact: reduced from 14px */
  font-weight: 700;
  color: #e74c3c; /* Red color */
  letter-spacing: 0.5px;
  text-transform: uppercase;
  position: relative;
  white-space: nowrap;
}

/* Remove unnecessary pseudo-elements and animations */
.calculator-container .section-divider .divider-text::before,
.calculator-container .section-divider .divider-text::after {
  display: none;
}

.calculator-container .section-divider .divider-text {
  animation: none;
}

/* Consistent styling for all divider types */
.calculator-container .section-divider.team-divider .divider-line,
.calculator-container .section-divider.stats-divider .divider-line,
.calculator-container .section-divider.series-divider .divider-line {
  background: rgba(231, 76, 60, 0.7);
}

.calculator-container .section-divider.team-divider .divider-text,
.calculator-container .section-divider.stats-divider .divider-text,
.calculator-container .section-divider.series-divider .divider-text {
  color: #e74c3c;
}

/*==============================================
 * TRACK SELECTION SECTION
 *==============================================*/
.calculator-container .track-selection {
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: 15px;
}

.calculator-container .track-dropdown select {
  width: 100%;
  padding: 8px 12px;
  border-radius: var(--border-radius-md);
  border: 1px solid var(--color-border);
  background-color: var(--input-bg);
  color: var(--color-text);
  margin-bottom: 10px;
}

.calculator-container .track-details {
  margin-top: 10px;
}

/* Track Key Stats */
.calculator-container .track-key-stats {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 10px;
}

.calculator-container .track-dominant-stat, 
.calculator-container .track-secondary-stat {
  flex: 1;
  padding: 10px;
  border-radius: var(--border-radius-md);
  background-color: var(--color-card-alt);
  text-align: center;
}

.calculator-container .track-dominant-stat {
  border-left: 3px solid var(--color-primary);
}

.calculator-container .track-secondary-stat {
  border-left: 3px solid var(--color-secondary);
}

.calculator-container .stat-label {
  display: block;
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-bottom: 4px;
}

.calculator-container .stat-name {
  font-weight: bold;
  font-size: 16px;
  color: var(--color-text);
}

/* Series Badges for Tracks */
.calculator-container .track-series {
  margin-top: 10px;
  display: flex;
  align-items: center;
}

.calculator-container .series-label {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-right: 8px;
}

.calculator-container .series-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.calculator-container .series-badge {
  background-color: var(--color-primary);
  color: white;
  border-radius: 50%;
  width: 20px;
  height: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: bold;
}

/*==============================================
 * SHARED CARD AND SLOT STYLES
 *==============================================*/
/* Mini Card Common Styles */
.calculator-container .mini-card {
  background-color: var(--color-card-alt);
  border-radius: var(--border-radius-md);
  padding: 10px;
  margin-top: 10px;
}

.calculator-container .mini-card-header {
  display: flex;
  justify-content: space-between;
  margin-bottom: 8px;
}

.calculator-container .mini-card-name {
  font-weight: bold;
  font-size: 14px;
}

.calculator-container .mini-card-rarity {
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 10px;
}

/* Series and Level info for cards */
.calculator-container .mini-card-series {
  margin-bottom: 8px;
}

.calculator-container .mini-card-series-level {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.calculator-container .mini-level-text {
  font-size: 11px;
  color: var(--color-text-secondary);
}

.calculator-container .mini-series-label {
  font-size: 11px;
  color: var(--color-text-secondary);
  background-color: var(--color-card-alt);
  padding: 2px 6px;
  border-radius: 10px;
}

/* Rarity classes for cards */
.calculator-container .rarity-common {
  background-color: var(--rarity-common-bg);
  color: var(--rarity-common-text);
  border-color: var(--rarity-common-border);
}

.calculator-container .rarity-rare {
  background-color: var(--rarity-rare-bg);
  color: var(--rarity-rare-text);
  border-color: var(--rarity-rare-border);
}

.calculator-container .rarity-epic {
  background-color: var(--rarity-epic-bg);
  color: var(--rarity-epic-text);
  border-color: var(--rarity-epic-border);
}

.calculator-container .rarity-legendary {
  background-color: var(--rarity-legendary-bg);
  color: var(--rarity-legendary-text);
  border-color: var(--rarity-legendary-border);
}

/* Stats display in cards */
.calculator-container .mini-card-stats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
  gap: 8px;
  overflow: hidden;
}

.calculator-container .mini-stat {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.calculator-container .mini-stat-label {
  font-size: 11px;
  color: var(--color-text-secondary);
}

.calculator-container .mini-stat-value {
  font-weight: bold;
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/*==============================================
 * SELECTION GRIDS & SLOTS
 *==============================================*/
/* Common grid layouts */
.calculator-container .drivers-grid, 
.calculator-container .parts-grid, 
.calculator-container .boosts-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 15px;
}

/* Common slot styles */
.calculator-container .driver-slot, 
.calculator-container .part-slot, 
.calculator-container .boost-slot {
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: 15px;
  position: relative;
  transition: border-color 0.2s;
}

/* Track match highlighting for slots */
.calculator-container .track-match {
  border: 2px solid var(--color-success);
  position: relative;
}

.calculator-container .track-match::after {
  content: "✓";
  position: absolute;
  top: 5px;
  right: 5px;
  background-color: var(--color-success);
  color: white;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: bold;
}

/* Dropdowns in slots */
.calculator-container .driver-dropdown select, 
.calculator-container .part-dropdown select,
.calculator-container .boost-dropdown select {
  width: 100%;
  padding: 8px 12px;
  border-radius: var(--border-radius-md);
  border: 1px solid var(--color-border);
  background-color: var(--input-bg);
  color: var(--color-text);
  margin-bottom: 10px;
  font-size: 0.85rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/*==============================================
 * BOOST SPECIFIC STYLES
 *==============================================*/
.calculator-container .boost-mini-card {
  background-color: var(--color-card-alt);
  border-top: 3px solid var(--color-primary);
}

.calculator-container .boost-effect-display {
  width: 100%;
}

.calculator-container .boost-effect {
  display: flex;
  align-items: center;
  gap: 4px;
}

.calculator-container .boost-value {
  font-weight: bold;
  color: var(--color-primary);
}

.calculator-container .boost-stat {
  font-size: 12px;
}

.calculator-container .boost-duration {
  margin-top: 5px;
  font-size: 11px;
  color: var(--color-text-secondary);
  background-color: rgba(var(--color-primary-rgb, 255, 30, 0), 0.1);
  padding: 2px 6px;
  border-radius: 10px;
  display: inline-block;
}

/*==============================================
 * TEAM ACTIONS (OPTIMIZE BUTTON & SCORE)
 *==============================================*/
.calculator-container .boosts-grid .team-actions {
  grid-column: 1 / -1; /* Span all columns */
}

.calculator-container .team-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 20px; /* Compact: reduced from 25px */
  padding: 12px; /* Compact: reduced from 15px */
  background: linear-gradient(to right, rgba(231, 76, 60, 0.05), rgba(255, 255, 255, 0.7), rgba(231, 76, 60, 0.05));
  border-radius: 10px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05);
  width: 100%;
  box-sizing: border-box;
  margin-left: 0;
  margin-right: 0;
}

/* Dark mode fix specifically for the team actions */
.dark-mode .calculator-container .team-actions {
  background: linear-gradient(to right, rgba(231, 76, 60, 0.05), rgba(40, 44, 52, 0.7), rgba(231, 76, 60, 0.05));
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

/* Dark mode fix for the score display */
.dark-mode .calculator-container .track-and-actions .team-actions .score-display {
  background-color: rgba(231, 76, 60, 0.1);
  border-color: rgba(231, 76, 60, 0.4);
}

.calculator-container .team-actions .team-score {
  display: flex;
  align-items: center;
}

.calculator-container .team-actions .score-display {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.calculator-container .team-actions .score-label {
  font-size: 13px; /* Compact: reduced from 14px */
  font-weight: bold;
  color: #7f8c8d;
}

.calculator-container .team-actions .score-value {
  font-size: 20px; /* Compact: reduced from 24px */
  font-weight: bold;
  color: #e74c3c;
}

.calculator-container .team-actions .optimize-btn {
  background: linear-gradient(135deg, #e74c3c, #c0392b);
  color: white;
  font-weight: bold;
  padding: 8px 12px; /* Compact: reduced from 10px 15px */
  border-radius: 8px;
  border: none;
  box-shadow: 0 2px 4px rgba(0,0,0,0.2);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px; /* Compact: added for smaller text */
}

.calculator-container .team-actions .optimize-btn:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 4px 8px rgba(0,0,0,0.3);
}

.calculator-container .team-actions .optimize-btn:disabled {
  background: linear-gradient(135deg, #95a5a6, #7f8c8d);
  cursor: not-allowed;
  opacity: 0.7;
}

.calculator-container .team-actions .optimize-btn i {
  font-size: 16px; /* Compact: reduced from 18px */
}

/*==============================================
 * RIGHT PANEL - STATS SUMMARY & COMPATIBILITY
 *==============================================*/
.calculator-container .stats-summary-panel {
  background-color: var(--color-card);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-md);
  padding: 15px; /* Compact: reduced from 20px */
  display: flex;
  flex-direction: column;
  gap: 15px; /* Compact: reduced from 20px */
  overflow: auto;
}

/* Stats grid layout */
.calculator-container .stats-grid {
  display: flex;
  flex-direction: column;
  gap: 10px; /* Compact: reduced from 15px */
}

/* Stat category headers with icons */
.calculator-container .stats-summary-panel .stat-category h4 {
  display: flex;
  align-items: center;
  margin-bottom: 5px; /* Compact: reduced from 8px */
  font-size: 14px; /* Compact: reduced from default */
}

.calculator-container .stats-summary-panel .stat-category h4::before {
  content: "";
  display: inline-block;
  width: 16px; /* Compact: reduced from 20px */
  height: 16px; /* Compact: reduced from 20px */
  margin-right: 6px; /* Compact: reduced from 8px */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

/* Specific stat category icons */
.calculator-container .stats-summary-panel .stat-category:nth-child(1) h4::before {
  background-image: url('../images/icons/speed.png');
}

.calculator-container .stats-summary-panel .stat-category:nth-child(2) h4::before {
  background-image: url('../images/icons/powerunit.png');
}

.calculator-container .stats-summary-panel .stat-category:nth-child(3) h4::before {
  background-image: url('../images/icons/cornering.png');
}

.calculator-container .stats-summary-panel .stat-category:nth-child(4) h4::before {
  background-image: url('../images/icons/racestart.png');
}

.calculator-container .stats-summary-panel .stat-category:nth-child(5) h4::before {
  background-image: url('../images/icons/pitstop.png');
}

.calculator-container .stats-summary-panel .stat-category:nth-child(6) h4::before {
  background-image: url('../images/icons/drs.png');
}

/* Stat meter bars */
.calculator-container .stat-meter {
  height: 16px; /* Compact: reduced from 20px */
  background-color: var(--color-card-alt);
  border-radius: 10px;
  display: flex;
  align-items: center;
  position: relative;
}

.calculator-container .stat-bar {
  height: 16px; /* Compact: reduced from 20px */
  border-radius: 10px;
  min-width: 5px;
  transition: width 0.3s ease-out;
}

/* Gradient colors for stat bars based on value */
.calculator-container .stat-bar.very-low {
  background: linear-gradient(90deg, #FF0000, #FF3300);  /* Red */
}

.calculator-container .stat-bar.low {
  background: linear-gradient(90deg, #FF6600, #FF9900);  /* Orange */
}

.calculator-container .stat-bar.medium {
  background: linear-gradient(90deg, #FFCC00, #FFFF00);  /* Yellow */
}

.calculator-container .stat-bar.high {
  background: linear-gradient(90deg, #CCFF00, #99FF00);  /* Light Green */
}

.calculator-container .stat-bar.very-high {
  background: linear-gradient(90deg, #66FF00, #00FF00);  /* Green */
}

/* Stat value text */
.calculator-container .stat-value {
  position: absolute;
  right: 8px; /* Compact: reduced from 10px */
  color: white;
  font-weight: bold;
  text-shadow: 0 0 2px rgba(0, 0, 0, 0.5);
  font-size: 12px; /* Compact: reduced from default */
}

/* Better visibility for yellow medium bar */
.calculator-container .stat-bar.medium .stat-value {
  color: #333;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.7);
}

/*==============================================
 * TRACK COMPATIBILITY SECTION
 *==============================================*/
.calculator-container .track-compatibility-section {
  margin-bottom: 12px; /* Compact: reduced from 20px */
}

.calculator-container .compatibility-meter {
  height: 16px; /* Compact: reduced from 20px */
  background-color: #f1f1f1;
  border-radius: 10px;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,0.1);
  margin: 8px 0; /* Compact: reduced from 10px */
}

.calculator-container .compatibility-bar {
  height: 100%;
  border-radius: 10px;
  background: linear-gradient(90deg, 
    #FF4136 0%, 
    #FF851B 25%, 
    #FFDC00 50%, 
    #2ECC40 75%,
    #01FF70 100%
  );
  transition: width 0.5s ease-out;
}

.calculator-container .compatibility-value {
  position: absolute;
  right: 8px; /* Compact: reduced from 10px */
  color: #333;
  font-weight: bold;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.5);
  z-index: 2;
  font-size: 12px; /* Compact: reduced */
}

.calculator-container .compatibility-description {
  text-align: center;
  font-size: 12px; /* Compact: reduced from 14px */
  font-style: italic;
  color: #555;
  margin-top: 5px; /* Compact: reduced from 8px */
}

.calculator-container .compatibility-description p {
  margin: 0;
  line-height: 1.3;
}

/*==============================================
 * SERIES OPTIMIZATION SECTION
 *==============================================*/
/* Redesigned Series Notes with Integrated Buttons */
.calculator-container .series-info {
  margin-bottom: 15px;
  width: 100%; /* Full width for the container */
}

.calculator-container .series-note {
  padding: 12px 15px;
  margin-bottom: 10px;
  border-radius: 8px;
  background: rgba(52, 152, 219, 0.08); /* Lighter blue background */
  border: 1px solid rgba(52, 152, 219, 0.2); /* Light blue border */
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.calculator-container .series-note-content {
  flex: 1;
}

.calculator-container .track-series-badge {
  font-weight: bold;
  color: #3498db;
  margin-right: 8px;
  display: inline-block;
  font-size: 12px;
  background-color: rgba(52, 152, 219, 0.15); /* Slight background */
  padding: 2px 6px;
  border-radius: 4px;
}

.calculator-container .series-focus {
  color: #5f6368; /* Darker, more readable text */
  font-style: italic;
  font-size: 12px;
  line-height: 1.3;
}

.calculator-container .series-optimize-btn {
  background: linear-gradient(135deg, #3498db, #2980b9);
  color: white;
  font-weight: bold;
  padding: 8px 12px;
  border-radius: 6px;
  border: none;
  box-shadow: 0 2px 3px rgba(0,0,0,0.1);
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  min-width: 120px;
  justify-content: center;
  margin-left: 15px;
  white-space: nowrap;
}

.calculator-container .series-optimize-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 5px rgba(0,0,0,0.15);
}

.calculator-container .series-optimize-btn:active {
  transform: translateY(0);
  box-shadow: 0 2px 3px rgba(0,0,0,0.1);
}

/* Hide the old series buttons grid */
.calculator-container .series-buttons-grid {
  display: none;
}

/*==============================================
 * SETUP MANAGEMENT SECTION
 *==============================================*/
/* Setup Management always at the bottom */
.calculator-container .stats-summary-panel {
  position: relative; /* To establish a positioning context */
  display: flex;
  flex-direction: column;
  min-height: 100%; /* Full height of parent */
}

/* Push divider and setup management to the bottom */
.calculator-container .setup-management-section {
  margin-top: auto; /* This pushes the section to the bottom */
  width: 100%;
  padding-top: 15px;
}

/* Style for setup management container */
.calculator-container .setup-management {
  margin-top: 0;
  position: relative;
  width: 100%;
  padding-bottom: 15px; /* Space from content to the bottom red line */
}

/* Setup buttons styling - changed to row layout */
.calculator-container .setup-buttons {
  display: flex; /* Changed to flex for row layout */
  justify-content: space-between;
  gap: 10px;
  margin-top: 8px;
}

.calculator-container .setup-management-divider {
  display: flex;
  align-items: center;
  margin: 18px 0 12px;
  width: 100%;
  max-width: 100%;
  position: relative;
}

.calculator-container .setup-management-divider .divider-line {
  flex-grow: 1;
  height: 1px;
  background: rgba(231, 76, 60, 0.7);
}

.calculator-container .setup-management-divider .divider-text {
  padding: 0 10px;
  font-size: 13px;
  font-weight: 700;
  color: #e74c3c;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  position: relative;
  white-space: nowrap;
}

/* Setup action buttons - now each takes equal width */
.calculator-container .save-btn, 
.calculator-container .load-btn, 
.calculator-container .share-btn {
  flex: 1; /* Make buttons take equal width */
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 6px 10px; /* Compact: reduced from 8px 12px */
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  background-color: var(--color-card-alt);
  color: var(--color-text);
  cursor: pointer;
  transition: background-color 0.2s;
  font-size: 13px; /* Compact: reduced */
}

.calculator-container .save-btn:hover, 
.calculator-container .load-btn:hover, 
.calculator-container .share-btn:hover {
  background-color: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
}

/* Setup save dialog */
.calculator-container .setup-save-dialog {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background-color: var(--color-card);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-lg);
  padding: 12px; /* Compact: reduced from 15px */
  z-index: 10;
  margin-top: 8px; /* Compact: reduced from 10px */
}

.calculator-container .setup-save-dialog input {
  width: 100%;
  padding: 6px 10px; /* Compact: reduced from 8px 12px */
  border-radius: var(--border-radius-md);
  border: 1px solid var(--color-border);
  background-color: var(--input-bg);
  color: var(--color-text);
  margin-bottom: 8px; /* Compact: reduced from 10px */
  font-size: 13px; /* Compact: reduced */
}

.calculator-container .dialog-buttons {
  display: flex;
  justify-content: flex-end;
  gap: 8px; /* Compact: reduced from 10px */
}

.calculator-container .confirm-btn, 
.calculator-container .cancel-btn {
  padding: 5px 10px; /* Compact: reduced from 6px 12px */
  border-radius: var(--border-radius-md);
  cursor: pointer;
  font-size: 13px; /* Compact: reduced */
}

.calculator-container .confirm-btn {
  background-color: var(--color-primary);
  color: white;
  border: none;
}

.calculator-container .cancel-btn {
  background-color: transparent;
  border: 1px solid var(--color-border);
  color: var(--color-text);
}


/*==============================================
 * IMPORT/EXPORT DIALOGS & BUTTONS
 *==============================================*/
/* Modal Dialog Styles */
.calculator-container .modal-dialog {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.calculator-container .modal-content {
  background-color: var(--color-card);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-lg);
  width: 90%;
  max-width: 600px;
  max-height: 90vh;
  overflow-y: auto;
}

.calculator-container .modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 15px 20px;
  border-bottom: 1px solid var(--color-border);
}

.calculator-container .modal-header h3 {
  margin: 0;
  font-size: 18px;
  color: var(--color-text);
}

.calculator-container .close-btn {
  background: none;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--color-text-secondary);
}

.calculator-container .modal-body {
  padding: 20px;
}

.calculator-container .modal-footer {
  padding: 15px 20px;
  border-top: 1px solid var(--color-border);
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

/* Export/Import Option Styles */
.calculator-container .export-options, 
.calculator-container .import-options {
  margin: 15px 0;
}

.calculator-container .export-option, 
.calculator-container .import-option {
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  background-color: rgba(52, 152, 219, 0.05);
}

.calculator-container .option-description {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-top: 5px;
  font-style: italic;
}

/* Textarea for Import */
.calculator-container .modal-body textarea {
  width: 100%;
  min-height: 200px;
  padding: 10px;
  border-radius: var(--border-radius-md);
  border: 1px solid var(--color-border);
  background-color: var(--input-bg);
  color: var(--color-text);
  resize: vertical;
  margin: 10px 0;
  font-family: monospace;
  font-size: 13px;
}

/* Export/Import Button Styles */
.calculator-container .export-btn,
.calculator-container .import-btn {
  flex: 1; /* Make buttons take equal width */
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 6px 10px;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  background-color: var(--color-card-alt);
  color: var(--color-text);
  cursor: pointer;
  transition: background-color 0.2s;
  font-size: 13px;
}

.calculator-container .export-btn:hover,
.calculator-container .import-btn:hover {
  background-color: var(--color-primary);
  color: white;
  border-color: var(--color-primary);
}

/* Media query to make better display on small screens */
@media (max-width: 768px) {
  .calculator-container .setup-buttons {
    flex-wrap: wrap;
  }
  
  .calculator-container .save-btn, 
  .calculator-container .load-btn, 
  .calculator-container .share-btn,
  .calculator-container .export-btn,
  .calculator-container .import-btn {
    flex-basis: 48%; /* 2 columns on smaller screens */
  }
}

@media (max-width: 576px) {
  .calculator-container .save-btn, 
  .calculator-container .load-btn, 
  .calculator-container .share-btn,
  .calculator-container .export-btn,
  .calculator-container .import-btn {
    flex-basis: 100%; /* 1 column on very small screens */
  }
}


/*==============================================
 * RESPONSIVE ADJUSTMENTS
 *==============================================*/
@media (max-width: 768px) {
  .calculator-container .drivers-grid, 
  .calculator-container .parts-grid, 
  .calculator-container .boosts-grid {
    grid-template-columns: 1fr;
  }
  
  .calculator-container .preset-buttons, 
  .calculator-container .setup-buttons {
    grid-template-columns: 1fr 1fr;
  }
  
  .calculator-container .series-buttons-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

@media (max-width: 576px) {
  .calculator-container .series-buttons-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}