/* =================================================
 * ŚCIEŻKA: /wcm-ipricelist/assets/css/frontend.css
 * ZMIANA: Dodana pełna responsywność z szerokim użyciem clamp() dla typografii,
 * marginesów, paddingów i kluczowych wymiarów.
 * Media queries pozostają tylko dla zmian layoutu.
 * ================================================= */

@import url('https://fonts.googleapis.com/css2?family=Quicksand:wght@400;600;700;800&family=Poppins:wght@500;700;800&family=Source+Code+Pro:wght@400;600;700;800&display=swap');

:root {
  /* Paleta AiEnergy */
  --ae-navy: #0B1E39;
  --ae-navy-2: #0F2649;
  --ae-green: #9AD300;
  --ae-green-2: #486109;
  --ae-green-dark: #388E3C;
  --ae-white: #FFFFFF;

  /* Szarości i akcenty */
  --ae-gray-50: #F5F7FA;
  --ae-gray-200: #D9DEE7;
  --ae-gray-400: #94A3B8;
  --ae-gray-900: #0B1220;
  --ae-error-bg: rgba(239, 68, 68, .15);
  --ae-error-border: rgba(239, 68, 68, .45);
  --ae-error-text: #FEE2E2;
  --ae-success-bg: rgba(16, 185, 129, .15);
  --ae-success-border: rgba(16, 185, 129, .45);
  --ae-success-text: #D1FAE5;

  /* Kompatybilność + System */
  --green-primary: var(--ae-green);
  --green-dark: var(--ae-green-dark);
  --green-light: var(--ae-green-2);
  --white-background: var(--ae-white);
  --dark-grey-text: #E9EEF6;
  --medium-grey-text: #C9D4E3;
  --border-color-light: rgba(255, 255, 255, .16);
  --field-color: rgba(255, 255, 255, .08);
  --field-focus-color: rgba(255, 255, 255, .12);
  --placeholder-color: rgba(255, 255, 255, .55);

  /* Cienie */
  --shadow-color-light: rgba(11, 30, 57, 0.25);
  --shadow-color-medium: rgba(11, 30, 57, .4);
  --shadow-1: 0 8px 28px rgba(11, 30, 57, .35), 0 2px 10px rgba(11, 30, 57, .25);
  --shadow-2: 0 10px 36px rgba(11, 30, 57, .5), 0 3px 14px rgba(11, 30, 57, .32);
  --focus-ring: 0 0 0 3px rgba(154, 211, 0, .35);

  /* Promienie */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 20px;
  --radius-full: 50%;

  /* Odstępy */
  --space-1: 4px;
  --space-2: 8px;
  --space-2-5: 10px;
  --space-3: 12px;
  --space-3-5: 14px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-7: 28px;
  --space-8: 32px;
  --space-9: 36px;
  --space-12: 48px;
}

/* =================================================
  Globalne style i reset
================================================= */

body {
  font-family: Quicksand, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  color: var(--dark-grey-text);
  background:
    radial-gradient(900px 600px at 8% 0%, rgba(89, 178, 89, .10), transparent 60%),
    radial-gradient(1100px 700px at 92% 100%, rgba(118, 199, 118, .08), transparent 65%),
    linear-gradient(180deg, var(--ae-navy) 0%, var(--ae-navy-2) 100%);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}

/* =================================================
  Główny kontener formularza
================================================= */

.wcm-ipricelist-hidden-field {
  display: none !important;
}

.wcm-ipricelist-form {
  margin: clamp(24px, 5vw, 48px) auto;
  max-width: min(100%, 1200px);
  padding: clamp(var(--space-4), 3.2vw, var(--space-8));
  position: relative;
  overflow-x: hidden;
  color: var(--dark-grey-text);
  background: rgba(255, 255, 255, .06);
  border: 1px solid var(--border-color-light);
  border-radius: clamp(var(--radius-md), 2.4vw, var(--radius-xl));
  backdrop-filter: blur(6px);
}

/* =================================================
  Nagłówek i opis
================================================= */

.wcm-ipricelist-fields h2 {
  text-align: center;
  color: var(--ae-white);
  margin: clamp(var(--space-3), 3vh, var(--space-5)) 0;
  font-size: clamp(1.4rem, 3.2vw, 2rem);
  text-transform: none;
  font-weight: 800;
  letter-spacing: -.02em;
  font-family: Poppins, Quicksand, sans-serif;
  position: relative;
  line-height: 1.2;
}

.wcm-ipricelist-fields h2:after {
  content: '';
  display: block;
  width: clamp(40px, 6vw, 64px);
  height: var(--space-1);
  background: linear-gradient(90deg, var(--ae-green) 0%, var(--ae-green-2) 100%);
  margin: clamp(var(--space-3), 2.5vh, var(--space-4)) auto 0;
  border-radius: 2px;
}

.wcm-ipricelist-fields .wcm-ipricelist-description {
  text-align: center;
  color: var(--medium-grey-text);
  margin: clamp(var(--space-2), 1.8vh, var(--space-2-5)) auto clamp(var(--space-6), 4vh, var(--space-8));
  line-height: 1.6;
  font-size: clamp(.85rem, 1.6vw, .95rem);
  font-family: Quicksand, sans-serif;
  max-width: 820px;
}

/* =================================================
  Pola formularza (wspólne)
================================================= */

.wcm-ipricelist-field-vlook2d,
.wcm-ipricelist-field {
  font-family: Poppins, Quicksand, sans-serif;
  display: flex;
  flex-direction: column;
  margin-bottom: clamp(var(--space-2), 1.6vh, var(--space-3)) !important;
}

.wcm-ipricelist-field label {
  font-weight: 600;
  margin-bottom: clamp(var(--space-2), 1.4vh, var(--space-2-5)) !important;
  color: var(--ae-white);
  font-size: clamp(.86rem, 1.6vw, .95rem);
  font-family: Poppins, Quicksand, sans-serif;
  display: block;
}

/* --- SKONSOLIDOWANE STYLE PÓL --- */
.wcm-ipricelist-field input[type="text"],
.wcm-ipricelist-field input[type="number"],
.wcm-ipricelist-field input[type="email"],
.wcm-ipricelist-field input[type="tel"],
.wcm-ipricelist-field select,
.wcm-ipricelist-field textarea {
  width: 100%;
  font-family: Quicksand, sans-serif;
  padding: clamp(var(--space-2-5), 1.4vh, var(--space-3-5)) clamp(var(--space-3), 1.8vw, var(--space-4));
  margin-bottom: clamp(var(--space-2), 1.4vh, var(--space-2-5)) !important;
  border: 1px solid var(--border-color-light);
  border-radius: var(--radius-md);
  font-size: clamp(.92rem, 1.8vw, 1rem) !important;
  min-height: clamp(44px, 6vh, 52px);
  font-weight: 500;
  box-sizing: border-box;
  transition: border-color .2s, box-shadow .2s, background .2s, transform .06s;
  background: var(--field-color);
  color: var(--ae-white);
  appearance: none;
  box-shadow: inset 0 2px 4px var(--shadow-color-light);
  white-space: pre-wrap;
  overflow-wrap: break-word;
  word-break: break-word;
}

.wcm-ipricelist-field input::placeholder,
.wcm-ipricelist-field textarea::placeholder {
  color: var(--ae-white);
}

.wcm-ipricelist-field input:hover,
.wcm-ipricelist-field select:hover,
.wcm-ipricelist-field textarea:hover {
  border-color: rgba(25, 57, 71, .28);
}

.wcm-ipricelist-field input:focus-visible,
.wcm-ipricelist-field select:focus-visible,
.wcm-ipricelist-field textarea:focus-visible {
  border-color: var(--ae-green);
  box-shadow: var(--focus-ring), inset 0 2px 4px var(--shadow-color-light);
  outline: none;
  background: var(--field-focus-color) !important;
  transform: translateY(-1px);
  color: var(--ae-white) !important;
}

.wcm-ipricelist-field select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23C9D4E3' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 1rem auto;
}

/* Czytelność opcji w selectach */
.wcm-ipricelist-field select option,
.wcm-ipricelist-summary-field select option {
  color: var(--ae-gray-200) !important;
  background: var(--ae-navy-2) !important;
}

.wcm-ipricelist-field textarea {
  resize: vertical;
  min-height: clamp(110px, 18vh, 160px);
  margin-bottom: clamp(var(--space-3), 1.8vh, var(--space-3-5)) !important;
}

.wcm-ipricelist-field-vlook2d {
  margin-top: clamp(var(--space-2-5), 1.6vh, var(--space-3)) !important;
}

/* Wyświetlacze wartości */
.wcm-ipricelist-display-field,
.wcm-ipricelist-vlook1d-value,
.wcm-ipricelist-vlook2d-value,
.wcm-ipricelist-calculation-value {
  padding: clamp(var(--space-2-5), 1.4vh, var(--space-3)) clamp(var(--space-3), 1.8vw, var(--space-4));
  border: 1px solid var(--border-color-light);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .06);
  color: var(--ae-white);
  font-size: clamp(.9rem, 1.8vw, 1rem) !important;
  font-weight: 600;
  font-family: Quicksand, sans-serif;
  min-height: clamp(44px, 6vh, 52px);
  display: flex;
  align-items: center;
  box-sizing: border-box;
  width: 100%;
  cursor: default;
  box-shadow: inset 0 2px 4px var(--shadow-color-light);
}

/* =================================================
  Przyciski
================================================= */

.wcm-ipricelist-send-quote-button,
.wcm-ipricelist-recalculate-button {
  display: block;
  width: 100%;
  max-width: 420px;
  padding: clamp(var(--space-3), 2vh, var(--space-3-5)) clamp(var(--space-4), 3vw, var(--space-5));
  background: linear-gradient(135deg, var(--ae-green) 0%, var(--ae-green-2) 100%);
  color: var(--ae-white);
  border: none;
  border-radius: clamp(var(--radius-md), 2vw, var(--radius-lg));
  font-size: clamp(1rem, 2.2vw, 1.05rem);
  font-weight: 800;
  cursor: pointer;
  transition: transform .06s ease, box-shadow .2s ease, filter .2s ease;
  text-transform: uppercase;
  letter-spacing: .06em;
  box-shadow: 0 10px 24px rgba(89, 178, 89, .35);
  margin: clamp(var(--space-4), 4vh, var(--space-7)) auto;
  position: relative;
  overflow: hidden;
  z-index: 1;
}

.wcm-ipricelist-send-quote-button:hover,
.wcm-ipricelist-recalculate-button:hover {
  filter: brightness(1.03);
  box-shadow: 0 14px 32px rgba(89, 178, 89, .45);
  transform: translateY(-1px);
}

.wcm-ipricelist-send-quote-button:focus-visible,
.wcm-ipricelist-recalculate-button:focus-visible {
  outline: none;
  box-shadow: var(--focus-ring);
}

/* =================================================
  Komunikaty (success / error)
================================================= */

#wcm-ipricelist-frontend-messages {
  margin-top: clamp(var(--space-4), 3vh, var(--space-6));
  padding: clamp(var(--space-3), 1.8vh, var(--space-3-5)) clamp(14px, 2.4vw, 18px);
  border-radius: var(--radius-md);
  display: none;
  text-align: center;
  font-size: clamp(.9rem, 1.8vw, 1rem);
  font-weight: 700;
  line-height: 1.5;
  box-shadow: 0 4px 16px var(--shadow-color-medium);
}

#wcm-ipricelist-frontend-messages.success {
  background-color: var(--ae-success-bg);
  border: 1px solid var(--ae-success-border);
  color: var(--ae-success-text);
}

#wcm-ipricelist-frontend-messages.error {
  background-color: var(--ae-error-bg);
  border: 1px solid var(--ae-error-border);
  color: var(--ae-error-text);
}

/* =================================================
  Grupy pól
================================================= */

.wcm-ipricelist-group {
  border-radius: clamp(var(--radius-md), 2vw, var(--radius-lg));
  padding: clamp(var(--space-3-5), 2vh, var(--space-5));
  margin: clamp(16px, 2.8vw, 24px) 0;
  background: rgba(255, 255, 255, .05);
  box-shadow: var(--shadow-1);
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border-color-light);
}

.wcm-ipricelist-group-title,
h3.wcm-ipricelist-group-title {
  color: var(--ae-white);
  text-align: left;
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  padding-bottom: clamp(var(--space-2), 1.4vh, var(--space-2-5));
  font-family: Poppins, Quicksand, sans-serif;
  font-weight: 700;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

/* Checkboksy */
.wcm-ipricelist-checkbox-group-container {
  width: 100%;
  flex-direction: column;
}

.wcm-ipricelist-field-checkbox {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.wcm-ipricelist-checkbox-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: clamp(var(--space-2), 1.6vw, var(--space-3)) !important;
  cursor: pointer !important;
  margin: 0 !important;
  width: auto !important;
  line-height: 1 !important;
  font-size: clamp(.85rem, 1.6vw, .95rem) !important;
  color: var(--dark-grey-text);
}

.wcm-ipricelist-checkbox-input {
  width:  22px !important; 
  height: 22px !important;
  flex-shrink: 0 !important;
  border: 1px solid var(--border-color-light) !important;
  border-radius: var(--radius-sm) !important;
  appearance: none;
  background: rgba(255, 255, 255, .06) ;
  transition: all .2s ease !important;
  position: relative !important;
  cursor: pointer !important;
  box-shadow: inset 0 1px 3px var(--shadow-color-light) !important;
}

.wcm-ipricelist-checkbox-input:checked {
  background: var(--ae-green) !important;
  border-color: var(--ae-green) !important;
  box-shadow: var(--focus-ring) !important;
}

.wcm-ipricelist-checkbox-input:checked::before {
  content: '✓' !important;
  position: absolute !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  color: var(--ae-white) !important;
  font-size: .95em !important;
  font-weight: 900 !important;
}

.wcm-ipricelist-checkbox-input:focus-visible {
  outline: none !important;
  box-shadow: var(--focus-ring) !important;
  color: var(--ae-white) !important;
}

/* Pola zależne */
.wcm-ipricelist-dependent-fields-wrapper {
  display: flex !important;
  flex-direction: column !important;
  box-sizing: border-box !important;
  visibility: visible !important;
  opacity: 1 !important;
  width: 100%;
  padding-left: clamp(var(--space-2), 2.5vw, var(--space-5));
  transition: opacity .3s ease, max-height .3s ease;
  overflow: hidden;
}

.wcm-ipricelist-dependent-fields-wrapper.wcm-ipricelist-hidden-field {
  visibility: hidden !important;
  opacity: 0 !important;
  max-height: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin: 0 !important;
}

.wcm-ipricelist-dependent-fields-wrapper .wcm-ipricelist-field {
  margin: 0 !important;
  padding-top: clamp(var(--space-2), 1.4vh, var(--space-2-5)) !important;
  font-size: .95em !important;
}

.wcm-ipricelist-dependent-fields-wrapper label {
  font-weight: 600 !important;
  color: var(--medium-grey-text) !important;
}

/* =================================================
  Responsywność (layout + drobne korekty)
================================================= */

@media (max-width: 1024px) {
  .wcm-ipricelist-form {
    margin: clamp(20px, 5vh, 30px) auto;
    padding: clamp(var(--space-4), 3vw, var(--space-6));
    border-radius: clamp(var(--radius-md), 2.4vw, var(--radius-lg));
  }

  .wcm-ipricelist-fields h2 {
    font-size: clamp(1.25rem, 3vw, 1.75rem);
  }

  .wcm-ipricelist-summary-field .summary-row {
    padding: clamp(var(--space-3), 2vh, var(--space-4)) clamp(var(--space-5), 5vw, var(--space-7));
  }

  .wcm-ipricelist-email-quote-section {
    padding: clamp(var(--space-4), 3vh, var(--space-6));
    margin: clamp(var(--space-6), 5vh, var(--space-9)) auto;
  }
}

@media (max-width: 768px) {
  .wcm-ipricelist-form {
    margin: clamp(var(--space-4), 4vh, var(--space-5)) clamp(var(--space-3), 4vw, var(--space-3-5));
    padding: clamp(var(--space-4), 3vh, var(--space-5));
    border-radius: clamp(var(--radius-md), 2vw, var(--radius-lg));
  }

  .wcm-ipricelist-fields h2 {
    margin: clamp(var(--space-2), 2vh, var(--space-3)) 0;
  }

  .wcm-ipricelist-fields .wcm-ipricelist-description {
    font-size: clamp(.86rem, 2.2vw, .95rem);
    margin: clamp(var(--space-2), 2vh, var(--space-3)) clamp(var(--space-2), 4vw, var(--space-3)) clamp(var(--space-4), 4vh, var(--space-6));
  }

  .wcm-ipricelist-field input[type="text"],
  .wcm-ipricelist-field input[type="number"],
  .wcm-ipricelist-field input[type="email"],
  .wcm-ipricelist-field select,
  .wcm-ipricelist-field textarea,
  .wcm-ipricelist-display-field,
  .wcm-ipricelist-vlook1d-value,
  .wcm-ipricelist-vlook2d-value,
  .wcm-ipricelist-calculation-value {
    font-size: clamp(.95rem, 2.4vw, 1rem) !important;
    color: var(--ae-white) !important;
  }

  .wcm-ipricelist-summary-field {
    border-radius: clamp(var(--radius-md), 2vw, var(--radius-lg));
    padding: clamp(var(--space-2-5), 2vh, var(--space-3-5)) 0;
    box-shadow: 0 -5px 20px var(--shadow-color-medium);
  }

  .wcm-ipricelist-summary-field .summary-row {
    flex-direction: column;
    align-items: center;
    padding: clamp(var(--space-2-5), 2vh, var(--space-3-5)) clamp(14px, 4vw, 18px);
    gap: clamp(var(--space-2-5), 2vh, var(--space-3-5));
  }

  .wcm-ipricelist-summary-field .summary-left,
  .wcm-ipricelist-summary-field .summary-right {
    width: 100%;
    align-items: center;
    text-align: center;
  }

  .wcm-ipricelist-summary-field .summary-vat-rate {
    flex-direction: column;
    gap: clamp(var(--space-2), 2vh, var(--space-2-5));
    width: 100%;
    margin-bottom: clamp(var(--space-1), 1.5vh, var(--space-2)) !important;
    font-family: Quicksand, sans-serif;
  }

  .wcm-ipricelist-summary-field select {
    text-align: center;
  }

  .wcm-ipricelist-email-quote-section {
    margin: clamp(var(--space-5), 4vh, var(--space-8)) 0;
    padding: clamp(20px, 3vh, 24px);
    border-radius: clamp(var(--radius-md), 2vw, var(--radius-lg));
  }

  .wcm-ipricelist-email-quote-section h3 {
    font-size: clamp(1.05rem, 2.4vw, 1.2rem);
  }

  .wcm-ipricelist-send-quote-button,
  .wcm-ipricelist-recalculate-button {
    padding: clamp(var(--space-2-5), 1.8vh, var(--space-3)) clamp(var(--space-3), 3vw, var(--space-4));
    font-size: clamp(.9rem, 2.4vw, .95rem);
    border-radius: clamp(var(--radius-md), 2vw, var(--radius-lg));
    margin: clamp(14px, 3vh, 18px) auto;
  }

  .wcm-ipricelist-group {
    padding: clamp(var(--space-3), 2.4vh, var(--space-3-5));
  }

  .wcm-ipricelist-dependent-fields-wrapper {
    padding-left: clamp(var(--space-2), 3vw, var(--space-2-5));
  }
}

@media (max-width: 480px) {
  .wcm-ipricelist-form {
    margin: clamp(var(--space-3), 3vh, var(--space-3-5)) clamp(var(--space-2-5), 4vw, var(--space-3));
    padding: clamp(var(--space-3-5), 3vh, var(--space-4));
  }

  .wcm-ipricelist-fields h2 {
    font-size: clamp(1.05rem, 3.4vw, 1.2rem);
  }

  #wcm-ipricelist-frontend-messages {
    padding: clamp(var(--space-2-5), 2vh, var(--space-3));
    font-size: clamp(.86rem, 2.5vw, .95rem);
  }
}