/* ===========================================================
   FORMS.CSS — formularze globalne
   =========================================================== */

/* ===========================================================
   1. PROFILE / USER – wiersze, sekcje
   =========================================================== */

/* Pola w formularzu profilu */
.profile-form .field {
  margin-bottom: 20px;
}

/* ROW-1 / ROW-2 / ROW-3 — siatki formularza */
.row-1,
.row-2,
.row-3,
.row-4 {
  display: grid;
  gap: 20px;
}

/* Jedno pole na całą szerokość */
.row-1 {
  grid-template-columns: 1fr;
  margin-bottom: 24px;
}

/* Dwa pola obok siebie */
.row-2 {
  grid-template-columns: 1fr 1fr;
}

/* Trzy pola w jednym wierszu (np. kategorie) */
.row-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 24px;
}

.row-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 24px;
}

/* Tablet: row-3 = 2 kolumny */
@media (max-width: 1024px) {
  .row-3,
  .row-4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Mobile — jedno pod drugim + 5px marginesu globalnie */
@media (max-width: 768px) {
  .row-2,
  .row-3,
  .row-4 {
    grid-template-columns: 1fr;
    gap: 10px;
    padding-left: 2px;
    padding-right: 2px;
  }
}

.row-2.no-gap {
  margin-bottom: 0;
}

/* Mniejsze odstępy wewnątrz kart/sekcji */
.profile-card .field,
.user-section-content .field {
  margin-bottom: 16px;
}

.profile-card {
  text-align: center;
}

/* user-section-content – bez wewnętrznych paddingów */
.user-section-content {
  padding: 0 !important;
  border: none !important;
  box-shadow: none !important;
  background: transparent !important;
}

.user-section {
  margin-bottom: 40px;
}

/* Tablet */
@media (max-width: 1024px) {
  .user-section-content {
    max-width: 96% !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* Mobile – po 5px z każdej strony */
@media (max-width: 768px) {
  .user-section-content {
    max-width: calc(100% - 10px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
}

/* ===========================================================
   2. LOGIN / REGISTER — box, odstępy, responsywność
   =========================================================== */

/* Główny box formularza (login + register) */
.ui-box.form-box {
  max-width: 520px;
  margin: 40px auto;
  padding: 30px 28px;
  background: var(--card-bg);
  border: 1px solid var(--border-color);
  border-radius: 14px;
  box-shadow: var(--shadow);
  box-sizing: border-box;
  text-align: left;
}

.ui-box.form-box h2 {
  margin-top: 0;
  margin-bottom: 20px;
  text-align: center;
}

/* Tablet */
@media (max-width: 992px) {
  .ui-box.form-box {
    margin: 30px auto;
    padding: 28px 24px;
  }
}

/* Mobile – po 5px z każdej strony */
@media (max-width: 768px) {
  .ui-box.form-box {
    max-width: calc(100% - 10px);
    margin: 20px auto 40px;
    padding: 22px 18px;
    border-radius: 12px;
  }
}

/* Form-group — wspólny dla wszystkich formularzy */
.form-group {
  margin-bottom: 22px;
  text-align: left;
  position: relative;
}

/* Pierwsza grupa na mobile – trochę „oddechu” od góry */
@media (max-width: 768px) {
  .ui-box.form-box .form-group:first-of-type {
    margin-top: 12px;
  }
}

/* Footer pod formularzem (Masz już konto? / Nie masz konta?) */
.form-footer {
  margin-top: 18px;
  text-align: center;
  font-size: 0.95rem;
}

.form-status-card {
  max-width: 440px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.form-status-card p {
  margin-left: auto;
  margin-right: auto;
}

/* Przyciski w login / register – na środku */
.ui-box.form-box form .btn-primary {
  display: block;
  margin: 0 auto;
}

/* ===========================================================
   3. GLOBALNE INPUTY / LABELKI
   =========================================================== */

/* Globalny wygląd inputów – nadpisuje ewentualne stare style */
/* Globalny wygląd TYLKO dla pól tekstowych */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="url"],
input[type="search"],
input[type="tel"],
textarea,
select {
  width: 100% !important;
  padding: 12px 14px !important;
  border-radius: 10px !important;
  border: 1px solid var(--border-color) !important;
  background: var(--input-bg) !important;
  color: var(--text-color) !important;
  font-size: 1rem !important;
  box-sizing: border-box !important;
  transition:
    background .25s,
    border-color .25s,
    color .25s !important;
}

input:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--accent-color) !important;
  box-shadow: var(--focus-ring) !important;
}

/* Globalny styl labeli formularzy */
.form-label,
.field > label,
.form-row > label,
.form-label-strong,
.ui-box.form-box label {
  font-size: 1.15rem !important;
  font-weight: 700 !important;
  color: var(--text-color);
  margin-bottom: 8px;
  display: block;
  line-height: 1.3;
}

/* Dodatkowa klasa, której używamy w PHP */
.form-label-strong {
  text-align: left;
}

/* Przyciski w wierszach formularzy (np. stare .form-row) */
.form-row button {
  display: block;
  margin: 0 auto;
}

/* ===========================================================
   4. BŁĘDY / HINTY / PODPOWIEDZI
   =========================================================== */

.error-message,
.form-error {
  font-size: 0.95rem !important;
  font-weight: 700 !important;
  color: #c62828 !important;
  margin-top: 6px;
}

.form-hint,
.form-url-preview,
.username-hint,
.help-popup {
  font-size: 0.95rem !important;
  line-height: 1.5;
  margin-top: 6px;
  color: var(--text-muted);
}

/* hint pod username – centrowany */
.username-hint {
  margin-top: 6px;
  text-align: center;
}

/* wyróżnienie „OK” przy username */
.username-hint .ok {
  color: #2e7d32;
  font-size: 1rem;
  font-weight: 700;
}

.username-hint .err {
  color: #c62828;
  font-weight: 700;
}

/* invalid border */
.is-invalid {
  border-color: var(--danger-color) !important;
}

/* ===========================================================
   5. TOOLTIP „i” (help-icon) dla username
   =========================================================== */

.help-icon {
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:18px;
  height:18px;
  border-radius:50%;
  border:1px solid var(--border-color);
  font-size:0.8rem;
  cursor:pointer;
  background:var(--card-bg);
  color: var(--text-muted);
  margin-left:6px;
}

.help-icon:hover {
  background: color-mix(in oklab, var(--accent-color) 8%, var(--card-bg));
  color: var(--accent-color);
}

/* dymek */
.help-popup {
  display:none;
  position:absolute;
  top: 100%;
  left: 0;
  margin-top:4px;
  background:var(--card-bg);
  border:1px solid var(--border-color);
  border-radius:8px;
  padding:10px 12px;
  max-width:260px;
  z-index:2000;
}

/* hover/focus pokazuje dymek */
.help-icon:hover + .help-popup,
.help-icon:focus + .help-popup {
  display:block;
}

/* ===========================================================
   6. INPUT Z IKONĄ STATUSU (✔ przy poprawnym username)
   =========================================================== */

.input-with-status {
  position: relative;
  display: flex;
  align-items: center;
}

.input-with-status input {
  padding-right: 34px;
}

.username-status {
  position:absolute;
  right:10px;
  font-size:1.15rem;
  pointer-events:none;
  color:#2e7d32;
  opacity: 0;
  transition: opacity .2s ease;
}

.username-status.ok {
  opacity: 1;
}

.username-status.err {
  opacity: 1;
  color: #c62828;
}
/* ===========================================================
   7. LOGIN-BOX (legacy) — jeśli gdzieś jeszcze używasz
   =========================================================== */

.section-medium.login-box {
  text-align: left;
}

.section-medium.login-box.section-narrow {
  max-width: 460px;
  margin: 20px auto 60px;
  padding: 32px 24px 40px;
  border-radius: 20px;
  box-sizing: border-box;
}

@media (max-width: 1024px) {
  .section-medium.login-box.section-narrow {
    max-width: calc(100% - 10px);
    border-radius: 16px;
  }
}

@media (max-width: 768px) {
  .section-medium.login-box.section-narrow {
    max-width: calc(100% - 10px);
    margin: 12px auto 55px;
    border-radius: 12px;
    padding: 22px 18px;
  }
}

/* ==========================================
   GLOBALNE CHECKBOX / RADIO
========================================== */

input[type="checkbox"],
input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;

  width: 22px;
  height: 22px;

  border: 2px solid var(--border-color);
  background: var(--input-bg);

  display: inline-grid;
  place-content: center;

  cursor: pointer;
  box-sizing: border-box;

  transition:
    background .18s ease,
    border-color .18s ease,
    box-shadow .18s ease;
}

/* ===== CHECKBOX ===== */

input[type="checkbox"] {
  border-radius: 6px;
}

input[type="checkbox"]::before {
  content: "";
  width: 12px;
  height: 12px;

  transform: scale(0);
  transition: transform .15s ease;

  box-shadow: inset 1em 1em white;

  clip-path: polygon(
    14% 44%,
    0 65%,
    50% 100%,
    100% 16%,
    80% 0%,
    43% 62%
  );
}

input[type="checkbox"]:checked {
  background: var(--accent-color);
  border-color: var(--accent-color);
}

input[type="checkbox"]:checked::before {
  transform: scale(1);
}


/* ===== RADIO ===== */

input[type="radio"] {
  appearance: none;
  -webkit-appearance: none;

  width: 25px;
  height: 25px;
  aspect-ratio: 1 / 1;

  border-radius: 50%;
  border: 2px solid var(--border-color);
  background: var(--input-bg);

  display: inline-flex;
  align-items: center;
  justify-content: center;

  cursor: pointer;
  box-sizing: border-box;

  vertical-align: middle;
  line-height: 1;
  padding: 0;
}

input[type="radio"]::before {
  content: "";
  width: 9px;
  height: 9px;

  border-radius: 50%;
  background: white;

  transform: scale(0);
  transition: transform .15s ease;
}

input[type="radio"]:checked {
  background: var(--accent-color);
  border-color: var(--accent-color);
}

input[type="radio"]:checked::before {
  transform: scale(1);
}


/* ===== FOCUS (estetyczny, bez niebieskiego) ===== */

input[type="checkbox"]:focus,
input[type="radio"]:focus {
  outline: none !important;
  box-shadow: 0 0 0 3px
    color-mix(in oklab, var(--accent-color) 35%, transparent);
}

/* ===========================================================
   9. ROW-3 – pola bez labela (np. dodatkowe selecty)
   =========================================================== */

.field-no-label label {
  visibility: hidden;
  height: 0;
  margin: 0;
  padding: 0;
}

.row-3 .field-no-label {
  padding-top: 26px;
}

/* ===========================================================
   10. DROPZONE — wspólna dla portfolio i ogłoszeń
   =========================================================== */

.dropzone {
  border: 2px dashed var(--accent-color);
  border-radius: 12px;
  padding: 50px 20px;
  text-align: center;
  background: var(--card-bg);
  transition: background .25s ease, border-color .25s ease;
}

.dropzone p {
  margin: 6px 0;
}

/* Opis / notka pod przyciskiem – wspólny styl */
.dropzone .note,
.dropzone .dropzone-hint {
  font-size: 0.9rem;
  opacity: 0.8;
}

/* Stan "drag over" */
.dropzone.dragover,
.dropzone.is-dragover {
  background: color-mix(in oklab, var(--accent-color) 15%, #fff);
  border-color: var(--accent-color);
}

#ad-preview:empty {
  display: none;
}

/* ===========================================================
   11. CENA / PLN / NEGOCJACJE
   =========================================================== */

.field-inline-price .price-inline-wrap {
  display: flex;
  align-items: center;
  gap: 14px;
}

/* Cena + PLN w 1 kolumnie */
.price-flex {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

/* input Cena */
.price-input {
  width: 120px;
}

/* PLN — mała ramka */
.price-unit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  padding: 0 16px;
  border-radius: 8px;
  border: 1px solid var(--border-color);
  background: var(--card-bg);
  color: var(--text-color);
  font-size: 0.95rem;
}

/* Do negocjacji — równo z checkboxem */
.price-check {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* =========================================================
   FORMS — FINAL
========================================================= */

/* ===== FIELD ===== */
.field {
  display: flex;
  flex-direction: column;
  margin-bottom: 16px;
}

.field > label {
  font-weight: 600;
  margin-bottom: 6px;
  color: var(--text-color);
}

/* ===== INPUTY (bez checkbox/radio) ===== */
.field input:not([type="checkbox"]):not([type="radio"]),
.field select,
.field textarea {
  padding: 12px 14px;
  border-radius: 10px;
  border: 1px solid var(--border-color);
  background: var(--input-bg);
  transition: border-color .2s ease, box-shadow .2s ease;
}

.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--accent-color);
  box-shadow: var(--focus-ring);
  outline: none;
}

/* ===== BŁĄD WYGRYWA Z FOCUSEM ===== */
.field.field-error input,
.field.field-error select,
.field.field-error textarea,
.field.field-error input:focus,
.field.field-error select:focus,
.field.field-error textarea:focus {
  border-color: var(--danger-color) !important;
  box-shadow: none !important;
}

/* ===== LABEL + OPIS BŁĘDU ===== */

.field-error-msg {
  margin-top: 6px;
  font-size: .9rem;
  line-height: 1.4;
  color: var(--danger-color);
}

html[data-theme="dark"] .field-error-msg,
:root[data-theme="dark"] .field-error-msg {
  color: #fecaca;
}

/* =========================================================
   CENA
========================================================= */
.price-flex {
  display: inline-flex;
  align-items: center;
  gap: 10px;
}

.price-unit {
  height: 42px;
  padding: 0 16px;
  border-radius: 8px;
  border: 1px solid var(--border-color);
  background: var(--card-bg);
}

.field.field-error .price-unit {
  border-color: var(--danger-color);
  color: var(--danger-color);
}

/* ================================
   DROPZONE — PRIORYTETY STANÓW
================================ */

/* ERROR – najwyższy priorytet */
.field.field-error .dropzone {
  border-color: var(--danger-color);
  background: color-mix(in oklab, var(--danger-color) 6%, var(--card-bg));
}

/* DRAGOVER – tylko gdy NIE MA błędu */
.field:not(.field-error) .dropzone.dragover,
.field:not(.field-error) .dropzone.is-dragover {
  border-color: var(--accent-color);
  background: color-mix(in oklab, var(--accent-color) 12%, var(--card-bg));
}

/* VALID – tylko gdy NIE MA błędu */
.field:not(.field-error) .dropzone.is-valid {
  border-color: var(--accent-color);
  background: color-mix(in oklab, var(--accent-color) 6%, var(--card-bg));
}

/* ================================
   DROPZONE — DRAG FEEDBACK (ZAWSZE)
================================ */

/* dragover – delikatna poświata, NIE zmienia koloru walidacji */
.dropzone.dragover,
.dropzone.is-dragover {
  outline: 3px solid color-mix(in oklab, var(--accent-color) 45%, transparent);
  outline-offset: -3px;
}

/* jeżeli jest ERROR – dragover tylko jako poświata */
.field.field-error .dropzone.dragover,
.field.field-error .dropzone.is-dragover {
  outline-color: color-mix(in oklab, var(--danger-color) 45%, transparent);
}


/* ── Dark mode: ikony date/time w inputach ── */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="month"]::-webkit-calendar-picker-indicator {
  opacity: 0.6;
  cursor: pointer;
}

:root[data-theme="dark"] input[type="date"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="time"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="datetime-local"]::-webkit-calendar-picker-indicator,
:root[data-theme="dark"] input[type="month"]::-webkit-calendar-picker-indicator {
  filter: invert(1) brightness(0.85) !important;
  opacity: 0.9 !important;
  cursor: pointer;
}

.password-field {
  position: relative;
  display: flex;
  align-items: center;
}

.password-field input {
  width: 100%;
  padding-right: 48px;
}

.password-field__toggle {
  position: absolute;
  right: 10px;
  top: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  padding: 0;
  border: 1px solid transparent;
  border-radius: 999px;
  background: transparent;
  color: var(--text-muted);
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, opacity 0.2s ease;
  transform: translateY(-50%);
}

.password-field__toggle:hover,
.password-field__toggle:focus-visible {
  background: var(--hover-bg-soft);
  border-color: var(--border-color);
  opacity: 1;
}

.password-field__toggle:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--accent-color) 45%, transparent);
  outline-offset: 2px;
}

.password-field__icon {
  display: block;
  width: 18px;
  height: 18px;
  object-fit: contain;
  filter: brightness(0) saturate(100%) invert(38%) sepia(10%) saturate(560%) hue-rotate(176deg) brightness(92%) contrast(88%);
  opacity: 0.9;
}

body.dark-mode .password-field__icon,
body.dark-theme .password-field__icon,
body.theme-dark .password-field__icon,
html[data-theme="dark"] .password-field__icon,
:root[data-theme="dark"] .password-field__icon {
  filter: none !important;
  opacity: 0.92;
  mix-blend-mode: normal !important;
}

.password-tools {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  margin: -4px 0 18px;
}

.password-tools__generate {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 9px;
  border: 1px solid var(--border-color);
  border-radius: 999px;
  background: var(--card-bg);
  color: var(--text-color);
  font: inherit;
  font-size: 0.8rem;
  font-weight: 600;
  line-height: 1.15;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.password-tools__generate:hover,
.password-tools__generate:focus-visible {
  background: var(--hover-bg-soft);
  border-color: var(--accent-color);
  color: var(--accent-color);
}

.password-tools__generate:focus-visible {
  outline: 2px solid color-mix(in oklab, var(--accent-color) 45%, transparent);
  outline-offset: 2px;
}

/* ── Hero small — baner na stronach login / register / verify ── */
.hero-small {
  position: relative;
  height: 180px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.hero-small::after {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  pointer-events: none;
}

.hero-small .hero-content {
  position: relative;
  z-index: 1;
  text-align: center;
  color: #fff;
  padding: 0 20px;
}

.hero-small .hero-content h1 {
  margin: 0 0 6px;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
}

.hero-small .hero-content p {
  margin: 0;
  font-size: 0.95rem;
  opacity: 0.85;
}

@media (max-width: 600px) {
  .hero-small {
    height: 130px;
  }

  .hero-small .hero-content h1 {
    font-size: 1.35rem;
  }
}
