
/* =========================================================
   MAKASSED REGISTRATION – MODERN RESPONSIVE STYLES
   Scope: the /registration/ page only (via .registration-page)
   Requires: Forminator Design = "None"
   Version: 1.0.8
   ========================================================= */

/* ------------------------------
   0) DESIGN TOKENS (THEME)
   ------------------------------ */
:root {
  /* Brand */
  --brand-600: #146c43;
  --brand-700: #0f5132;
  --brand-500: #198754;

  /* Surface */
  --surface-0: #ffffff;
  --surface-25: #fcfdfc;
  --surface-50: #f6faf8;
  --surface-100: #eef6f1;

  /* Text */
  --text-900: #0b1220;
  --text-700: #344054;
  --text-500: #667085;

  /* Borders & State */
  --border: #d0d5dd;
  --border-strong: #98a2b3;
  --focus: 25, 135, 84; /* rgb tuple */
  --success-50: #ecfdf3;
  --success-600: #12b76a;
  --error-50: #fef3f2;
  --error-600: #d92d20;

  /* Shadows */
  --shadow-sm: 0 6px 18px rgba(0,0,0,.06);
  --shadow-md: 0 16px 40px rgba(0,0,0,.08);

  /* Radii */
  --radius-8: 8px;
  --radius-10: 10px;
  --radius-12: 12px;
  --radius-14: 14px;

  /* Sizing */
  --control-h: 44px;
  --btn-h: 48px;

  /* Typography (fluid) */
  --fs-12: clamp(11px, 0.75rem, 12px);
  --fs-13: clamp(12px, 0.8rem, 13px);
  --fs-14: clamp(13px, 0.9rem, 14px);
  --fs-16: clamp(15px, 1rem, 16px);
  --fs-18: clamp(16px, 1.1rem, 18px);

  /* Spacing (fluid) */
  --space-8: clamp(6px, 0.5vw, 8px);
  --space-12: clamp(8px, 1vw, 12px);
  --space-16: clamp(12px, 1.5vw, 16px);
  --space-20: clamp(14px, 2vw, 20px);
  --space-24: clamp(16px, 2.5vw, 24px);
  --space-32: clamp(20px, 3vw, 32px);
  --space-40: clamp(26px, 4vw, 40px);
  --space-48: clamp(32px, 5vw, 48px);
}

/* Dark mode */
@media (prefers-color-scheme: dark) {
  :root {
    --surface-0: #0f1418;
    --surface-25: #0e1317;
    --surface-50: #12181d;
    --surface-100: #172025;

    --text-900: #e6edf3;
    --text-700: #cbd5e1;
    --text-500: #94a3b8;

    --border: #2b3640;
    --border-strong: #3a4752;

    --shadow-sm: 0 6px 18px rgba(0,0,0,.45);
    --shadow-md: 0 16px 40px rgba(0,0,0,.55);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}

/* =========================================================
   HEADER CLEANUP ON /registration/
   - Hide theme hero/banner and extra title blocks
   - Remove unnecessary top spacing
   ========================================================= */
.registration-page .page-header,
.registration-page .page-title,
.registration-page .page-header-area,
.registration-page .breadcrumb-area,
.registration-page .entry-header,
.registration-page .hero,
.registration-page .header-banner,
.registration-page .site-content .wp-block-cover:first-of-type,
.registration-page .elementor-section[class*="hero"],
.registration-page .elementor-section[data-element_type="section"].has-banner {
  display: none !important;
}

/* Remove residual spacing above content */
.registration-page .site-content,
.registration-page .content-area {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

/* =========================================================
   FORM AREA (band + card)
   ========================================================= */

/* Full-bleed band behind the form area */
.registration-page .forminator-ui {
  display: block;
  width: 100%;
  background: var(--surface-50);
  padding: var(--space-40) var(--space-48);
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

@media (max-width: 768px) {
  .registration-page .forminator-ui {
    padding: var(--space-24) var(--space-16);
  }
}

/* Form container (mobile/tablet = card; desktop = full width) */
.registration-page .forminator-ui .forminator-custom-form {
  background: var(--surface-0);
  border: 1px solid var(--border);
  border-radius: var(--radius-14);
  box-shadow: var(--shadow-md);
  padding: var(--space-32);
  max-width: 1100px;         /* card feel on mobile/tablet */
  margin: 0 auto;
}

@media (max-width: 768px) {
  .registration-page .forminator-ui .forminator-custom-form {
    padding: var(--space-24);
    border-radius: var(--radius-12);
  }
}

/* ✅ Desktop full-width override */
@media (min-width: 1024px) {
  .registration-page .forminator-ui .forminator-custom-form {
    max-width: 100% !important;
    width: 100% !important;
    margin: 0 !important;
    border-radius: 0 !important;                /* optional: edge-to-edge */
    padding: var(--space-40) var(--space-48) !important; /* breathing room */
    border-left: none !important;
    border-right: none !important;
    box-shadow: none !important;                /* flat, full-bleed feel */
  }
  /* If you prefer a faint divider line under the header: */
  .registration-page .forminator-ui .forminator-custom-form {
    border-top: 1px solid var(--border) !important;
    border-bottom: 1px solid var(--border) !important;
  }
}

/* =========================================================
   LAYOUT (grid)
   ========================================================= */
.registration-page .forminator-row {
  width: 100%;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: var(--space-16) !important;
}

.registration-page .forminator-col { width: 100%; }

/* Helper: data attributes convert rows to 2 or 3 columns */
@media (min-width: 640px) {
  .registration-page .forminator-row[data-columns="auto"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
@media (min-width: 1024px) {
  .registration-page .forminator-row[data-columns="auto-lg"] {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
}

/* Example: name group 2 cols (only if markup has #name-1) */
@media (min-width: 992px) {
  .registration-page .forminator-field#name-1 .forminator-row {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 22px 26px !important;
  }
}

/* =========================================================
   HEADERS & TEXT
   ========================================================= */
.registration-page .form-section-title {
  background: var(--surface-100);
  padding: var(--space-12) var(--space-16);
  border-radius: var(--radius-8);
  font-size: var(--fs-16);
  font-weight: 700;
  color: var(--brand-700);
  margin: 0 0 var(--space-20);
}

.registration-page .forminator-field-html > .forminator-field > label {
  display: none !important;
}

.registration-page label.forminator-label {
  font-size: var(--fs-13);
  font-weight: 600;
  color: var(--text-700);
  margin-bottom: var(--space-8);
}

.registration-page .forminator-description,
.registration-page .forminator-input + .forminator-field-helper {
  font-size: var(--fs-12);
  color: var(--text-500);
}

/* =========================================================
   INPUTS & TEXTAREAS
   ========================================================= */
.registration-page input,
.registration-page select,
.registration-page textarea {
  width: 100%;
  height: var(--control-h);
  padding: 0 var(--space-12);
  font-size: var(--fs-14);
  color: var(--text-900);
  background: var(--surface-0);
  border-radius: var(--radius-8);
  border: 1px solid var(--border);
  transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.registration-page textarea {
  min-height: 120px;
  padding: var(--space-12);
  line-height: 1.5;
}

.registration-page .forminator-input-with-icon input { padding-left: 38px; }

.registration-page input:focus,
.registration-page select:focus,
.registration-page textarea:focus {
  border-color: rgb(var(--focus));
  box-shadow: 0 0 0 3px rgba(var(--focus), .18);
  outline: none;
}

/* Valid / Error states */
.registration-page .forminator-error {
  border-color: var(--error-600) !important;
  background: var(--error-50) !important;
}
.registration-page .forminator-error + .forminator-error-message {
  color: var(--error-600) !important;
  font-size: var(--fs-12) !important;
}
.registration-page .forminator-success {
  border-color: var(--success-600) !important;
  background: var(--success-50) !important;
}

/* =========================================================
   SELECT2 POLISH
   ========================================================= */
.registration-page .select2-container { width: 100% !important; }
.registration-page .select2-container--default .select2-selection {
  height: var(--control-h) !important;
  border-radius: var(--radius-8) !important;
  border: 1px solid var(--border) !important;
  background: var(--surface-0) !important;
}
.registration-page .select2-container--default .select2-selection__rendered {
  line-height: var(--control-h) !important;
  padding-left: var(--space-12) !important;
  color: var(--text-900) !important;
}
.registration-page .select2-container--default .select2-selection__arrow {
  height: var(--control-h) !important;
}
.registration-page .select2-dropdown {
  border-color: var(--border) !important;
  border-radius: var(--radius-8) !important;
  box-shadow: var(--shadow-sm) !important;
}

/* =========================================================
   RADIO & CHECKBOX (defaults)
   ========================================================= */
.registration-page .forminator-radio,
.registration-page .forminator-checkbox { margin-right: var(--space-20); }

.registration-page .forminator-radio input:focus + label,
.registration-page .forminator-checkbox input:focus + label {
  outline: 3px solid rgba(var(--focus), .18);
  outline-offset: 2px;
  border-radius: var(--radius-8);
  padding: 2px 4px;
}

/* =========================================================
   GENDER – PILL TOGGLE (scoped via .is-gender)
   JS adds .is-gender to the correct radio field wrapper.
   ========================================================= */
.registration-page .forminator-field.forminator-field-radio.is-gender {
  --pill-bg: var(--surface-0);
  --pill-border: var(--border);
  --pill-text: var(--text-700);
  --pill-text-active: #fff;
  --pill-active: var(--brand-600);
}

/* Layout: label | pills */
.registration-page .forminator-field.forminator-field-radio.is-gender > .forminator-field {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 640px) {
  .registration-page .forminator-field.forminator-field-radio.is-gender > .forminator-field {
    grid-template-columns: 220px auto;
    align-items: center;
  }
}

/* Field label */
.registration-page .forminator-field.forminator-field-radio.is-gender label.forminator-label {
  margin: 0;
  font-weight: 600;
  color: var(--text-700);
}

/* Pills container */
.registration-page .forminator-field.forminator-field-radio.is-gender .forminator-field--group {
  display: inline-flex;
  gap: 10px;
  flex-wrap: wrap;
}

/* Hide native radio but keep accessible */
.registration-page .forminator-field.forminator-field-radio.is-gender input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

/* Pill */
.registration-page .forminator-field.forminator-field-radio.is-gender .forminator-radio {
  position: relative;
  margin: 0;
}
.registration-page .forminator-field.forminator-field-radio.is-gender .forminator-radio label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 110px;
  height: 40px;
  padding: 0 14px;
  border-radius: 999px;
  border: 1px solid var(--pill-border);
  background: var(--pill-bg);
  color: var(--pill-text);
  font-size: var(--fs-14);
  cursor: pointer;
  transition: background .2s ease, color .2s ease, border-color .2s ease, box-shadow .2s ease;
}

/* Hover */
.registration-page .forminator-field.forminator-field-radio.is-gender .forminator-radio label:hover {
  border-color: var(--brand-500);
}

/* Checked */
.registration-page .forminator-field.forminator-field-radio.is-gender input[type="radio"]:checked + label {
  background: var(--pill-active);
  border-color: var(--pill-active);
  color: var(--pill-text-active);
  box-shadow: 0 6px 14px rgba(20,108,67,.18);
}

/* Focus */
.registration-page .forminator-field.forminator-field-radio.is-gender input[type="radio"]:focus + label {
  outline: 3px solid rgba(var(--focus), .22);
  outline-offset: 2px;
}

/* Dark mode fine-tune */
@media (prefers-color-scheme: dark) {
  .registration-page .forminator-field.forminator-field-radio.is-gender {
    --pill-bg: #11161a;
    --pill-border: #2b3640;
    --pill-text: #e6edf3;
  }
}

/* =========================================================
   BUTTONS
   ========================================================= */
.registration-page .forminator-button-submit {
  width: 100%;
  height: var(--btn-h);
  background: linear-gradient(180deg, var(--brand-600), var(--brand-700));
  color: #fff;
  font-size: var(--fs-16);
  font-weight: 700;
  border-radius: var(--radius-10);
  border: none;
  margin-top: var(--space-24);
  box-shadow: 0 6px 20px rgba(20, 108, 67, .25);
  transition: transform .08s ease, box-shadow .2s ease;
  will-change: transform;
}
.registration-page .forminator-button-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 28px rgba(20, 108, 67, .28);
}
.registration-page .forminator-button-submit:active {
  transform: translateY(0);
}

/* =========================================================
   MOBILE UX
   ========================================================= */
@media (max-width: 480px) {
  .registration-page input,
  .registration-page select { height: 48px; }
  .registration-page .select2-container--default .select2-selection { height: 48px !important; }
  .registration-page .select2-container--default .select2-selection__rendered { line-height: 48px !important; }
}

/* General field spacing */
.registration-page .forminator-field { margin-bottom: 16px; }
