/**
 * moj.golf - Kalkulator HCP Page Styles v25
 * Design System zgodny z docs/styleguide.md
 * Wymaga: global-25.css, components-25.css, header-nav-25.css, footer-25.css
 */

/* =============================================================================
   0. PAGE SETUP
   ============================================================================= */

/* Hero section, header i nav overrides są w header-nav-25.css */

/* =============================================================================
   1. CALCULATOR SECTION
   ============================================================================= */

.calculator-section {
  padding: var(--spacing-6) 0;
  margin-bottom: var(--spacing-10);
}

.calculator-wrapper {
  max-width: 1000px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .calculator-wrapper {
    padding: 0 var(--spacing-4);
  }
}

@media (min-width: 1024px) {
  .calculator-wrapper {
    padding: 0 var(--spacing-6);
  }
}

/* =============================================================================
   2. FORM ELEMENTS
   ============================================================================= */

/*
 * Podstawowe style formularzy (form-input-compact, form-label-compact, etc.)
 * są w components-25.css jako wspólne komponenty.
 * Tutaj tylko specyficzny layout dla kalkulatora.
 */

.calculator-form-compact {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
}

@media (min-width: 768px) {
  .calculator-section {
    background-color: var(--color-dark-primary);
  }

  .calculator-form-compact {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: var(--spacing-4);
    row-gap: 15px;
    align-items: end;
    background-color: var(--color-white);
    padding: var(--spacing-6);
    border-radius: 12px;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-gray-200);
  }
}

@media (min-width: 1024px) {
  .calculator-form-compact {
    grid-template-columns: repeat(3, 1fr);
    padding: var(--spacing-8);
  }
}

.form-group {
  width: 100%;
  margin-bottom: 0;
}

/* Column spans */
@media (min-width: 768px) {
  .form-col-2 {
    grid-column: span 2;
  }

  .form-col-3 {
    grid-column: span 2;
  }
}

@media (min-width: 1024px) {
  .form-col-2 {
    grid-column: span 2;
  }

  .form-col-3 {
    grid-column: span 3;
  }
}

/* Wyrównanie elementów w kolumnach do lewej */
@media (min-width: 768px) {
  .form-group {
    justify-self: start;
    width: 100%;
  }

  .form-group-button {
    justify-self: start;
    width: auto;
  }

  /* Tablet - 90% szerokości dla zawartości kolumn (oprócz pola golfowego) */
  .form-group:not(:has(#golfCourse)) .form-input-compact,
  .form-group:not(:has(#golfCourse)) .form-select-compact,
  .form-group:not(:has(#golfCourse)) .radio-group-compact {
    max-width: 90%;
  }

  /* Radio groups - wypełniają 90% kolumny */
  .form-group .radio-group-compact {
    width: 90%;
    display: flex;
    gap: var(--spacing-2);
  }

  .form-group .radio-group-compact .radio-label-compact {
    flex: 1;
    justify-content: center;
  }
}

@media (min-width: 1024px) {
  /* Desktop - resetuj do 100% i zastosuj selektywne ograniczenia */
  .form-group .form-select-compact {
    max-width: 100%;
  }

  .form-group .radio-group-compact {
    max-width: 100%;
  }

  .form-group .form-input-compact {
    max-width: 100%;
  }

  /* Kolor tee, Aktualny HCP, % HCP - 80% szerokości */
  .form-group:has(#teeColor) .form-select-compact,
  .form-group:has(#currentHCP) .form-input-compact,
  .form-group:has(#hcpAllowance) .form-select-compact {
    max-width: 80%;
  }
}

/* Submit Button */
.btn-large {
  padding: var(--spacing-3) var(--spacing-6);
  font-size: var(--font-size-body);
  width: 100%;
}

@media (min-width: 768px) {
  .btn-large {
    padding: var(--spacing-4) var(--spacing-8);
    width: auto;
  }
}

/* Disclaimer */
.calculator-disclaimer {
  text-align: center;
  font-size: var(--font-size-body-sm);
  font-style: italic;
  color: var(--color-gray-600);
  margin-top: var(--spacing-6);
  padding-top: var(--spacing-4);
  border-top: 1px solid var(--color-gray-200);
}

@media (max-width: 767px) {
  .calculator-disclaimer {
    margin-top: var(--spacing-4);
  }
}

.btn-primary {
  background-color: var(--color-dark-primary);
  color: var(--color-white);
  border: none;
  border-radius: 8px;
  font-weight: var(--font-weight-semibold);
  font-family: var(--font-family-primary);
  cursor: pointer;
  transition: all var(--duration-normal) var(--ease-out);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-2);
}

.btn-primary:hover {
  background-color: var(--color-green-fairway);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn-primary svg {
  width: 20px;
  height: 20px;
}

/* =============================================================================
   3. RESULT SECTION - wyniki w kalkulatorze
   ============================================================================= */

.result-section {
  padding-top: var(--spacing-6);
  margin-top: var(--spacing-4);
  border-top: 2px solid var(--color-gray-200);
}

.result-course-info {
  margin-bottom: var(--spacing-4);
  padding-bottom: var(--spacing-3);
  border-bottom: 1px solid var(--color-gray-200);
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: var(--spacing-1);
  font-size: var(--font-size-body);
  color: var(--color-gray-700);
}

.result-info-label {
  font-weight: var(--font-weight-semibold);
  color: var(--color-gray-700);
}

.result-course-name {
  font-weight: var(--font-weight-semibold);
  color: var(--color-gray-900);
}

.result-course-details {
  color: var(--color-gray-600);
}

/* Result Grid */
.result-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--spacing-3);
}

@media (min-width: 768px) {
  .result-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--spacing-4);
  }
}

@media (min-width: 1024px) {
  .result-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.result-item {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-1);
  padding: var(--spacing-3);
  background-color: var(--color-gray-50);
  border-radius: 8px;
}

.result-label {
  font-size: var(--font-size-body-sm);
  color: var(--color-gray-600);
  font-weight: var(--font-weight-semibold);
}

.result-value {
  font-size: var(--font-size-h5);
  color: var(--color-gray-900);
  font-weight: var(--font-weight-bold);
}

.result-highlight {
  background: linear-gradient(135deg, rgba(85, 139, 47, 0.15) 0%, rgba(85, 139, 47, 0.05) 100%);
  border: 2px solid var(--color-green-fairway);
}

.result-highlight .result-value {
  color: var(--color-green-green);
  font-size: var(--font-size-h4);
}

/* =============================================================================
   4. HCP EXPLANATION SECTION - używa wspólnych klas z components-25.css
   ============================================================================= */

/* Explanation section używa wspólnych klas:
   - .content-wrapper (container)
   - .content-section (sekcje)
   - .highlight-box (zielone boxy)
   - .highlight-box-blue (niebieskie boxy)
   - .code-box (formuły i przykłady)
*/
