/*
Theme Name: EcoEquitable
Author: Helen + Hélène
Description: Custom CSS styles
Version: 1.0
*/

/* ================================
   COLOR VARIABLES
   ================================ */

:root {
  /* Primary Colors */
  --purple: #752A8B;
  --purple-10: rgba(117, 42, 139, 0.1);
  --purple-50: rgba(117, 42, 139, 0.5);
  --black: #000000;
  --black-10: rgba(0, 0, 0, 0.1);
  --white: #ffffff;
  
  /* Secondary Colors */
  --dark-purple: #45225C;
  --light-purple: #D9BCEC;
  --warm-gray: #D5C9C4;
  --olive-green: #618832;
  --olive-green-10: rgba(97, 136, 50, 0.1);
  --red: #FF6347;

  /* Text */
  --text-color: #000000;
  --heading-color: #000000;

  /* Backgrounds */
  --background-1: rgba(213, 201, 196, 0.1);
  --background-1-hover: rgba(213, 201, 196, 0.2);
  --background-2: #ffffff;

  /* Borders */
  --border-color-10: rgba(0, 0, 0, 0.2);

  /* Links */
  --link-color: #752A8B;
  --link-hover: #000000;
  
  /* Fixes */ 
  --gf-color-in-ctrl-primary: #752A8B !important;
  
  /* Spacing */
  --spacing-1: 0.0625rem;
  --spacing-2: 0.125rem;
  --spacing-3: 0.1875rem;
  --spacing-4: 0.25rem;
  --spacing-8: 0.5rem;
  --spacing-12: 0.75rem;
  --spacing-16: 1rem;
  --spacing-20: 1.25rem;
  --spacing-24: 1.5rem;
  --spacing-28: 1.75rem;
  --spacing-32: 2rem;
  --spacing-36: 2.25rem;
  --spacing-40: 2.5rem;
  --spacing-48: 3rem;
  --spacing-56: 3.5rem;
  --spacing-64: 4rem;
  --spacing-80: 5rem;
  --spacing-96: 6rem;
  --spacing-112: 7rem;
  --spacing-128: 8rem;
}

.custom-logo, .page-register .custom-logo {
  width: 150px;
  height: auto;
  margin: 0 0 2rem 0;
}

.page-register .custom-logo {
  margin: 0 !important;
}

/* ================================
   TYPOGRAPHY
   ================================ */

html, body {
  font-family: 'Arimo', sans-serif;
}

a { color: var(--purple); }
a:active { color: var(--purple); !important}
a:visted { color: var(--purple); !important}
a:hover { color: var(--black); !important}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Raleway', sans-serif;
  color: var(--heading-color);
  font-style: normal;
  line-height: normal;
}

h1 {
  font-size: 42px;
  font-weight: 400;
  margin: 0 0 0.5rem 0;
}

h2 {
  font-size: 32px;
  font-weight: 600;
  margin: 1.5rem 0;
}

.boxit h2:first-of-type {
  margin-top: 0 !important;
}

h3 {
  font-size: 24px;
  font-weight: 600;
}

h4 {
  font-size: 20px;
  font-weight: 700;
}

h5 {
  font-size: 16px;
  font-weight: 700;
}

dd {
  margin: 0 0 1.5rem 0;
}

.boxit > dl:last-child, .project-fields > .project-field:last-child > dd {
  margin-bottom: 0;
}

.text-muted {
  color: #999999 !important;
  font-style: italic;
}

/* ================================
   HEADER IMAGE
   ================================ */

.featured-img {
  width: 100%;
  height: 100px;
  border-radius: var(--spacing-8);
  overflow: hidden;
  margin: 0;
}

.featured-img__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.page-login .featured-img, .page-register .featured-img {
  height: 50px;
  margin: 0;
}

/* ================================
   CONTAINERS
   ================================ */
 
.heading {
  margin: 3rem 0;
}

.portal-main {
  height: 100%;
  width: 100%;
  padding: 6rem 0;  
  margin: auto; 
}

.boxit, .form-container {
  background-color: var(--background-1);
  padding: 3rem;
  border: none;
  border-radius: var(--spacing-8);
  width: 100%;
}

.boxit { margin: 2rem 0; }
.form-container { margin: 2rem 0; }

.boxit p:last-of-type {
  margin-bottom: 0;
}

.page-submit-project .gform-body {
  background-color: var(--background-1) !important;
  padding: 3rem !important;
  margin: 3rem 0 2rem 0 !important;
  border: none !important;
  border-radius: var(--spacing-8) !important;
  width: 100% !important;
}

/* ================================
 PROJECTS
 ================================ */
 
.project-section h2 {
  border-bottom: 1px solid var(--border-color-10);
  padding: 0 0 2rem 0;
  margin: 0 0 2rem 0;
}

.project-section h2 i {
  color: var(--purple);
}

.project-section .btn i {
  color: var(--white);
}

.project-header-image {
  position: relative;
  width: 100%;
  height: 400px;
  border-radius: var(--spacing-8);
  overflow: hidden;
  margin-bottom: 2rem;
}

.project-header-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.project-header-image__btn {
  position: absolute;
  bottom: 1rem;
  right: 1rem;
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  padding: 0.4rem 0.9rem;
  border-radius: var(--spacing-8);
  font-size: 0.875rem;
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  backdrop-filter: blur(4px);
}

.project-header-image__btn:hover {
  background: rgba(0, 0, 0, 0.7);
  color: #fff;
}

.project-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 1rem;
}

.project-gallery-item img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  border-radius: var(--spacing-8);
  display: block;
  transition: opacity 0.15s ease;
}

.project-gallery-item:hover img {
  opacity: 0.8;
}

.interested-sewists {
  list-style: none;
  padding: 0;
  margin: 0;
}

.interested-sewists li {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--warm-gray);
}

.interested-sewists li:last-child {
  border-bottom: none;
}

.project-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.project-list__item {
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--warm-gray);
}

.project-list__item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.project-list__link {
  font-weight: 600;
  text-decoration: none;
}

.project-list__link:hover {
  text-decoration: underline;
}

.project-list__meta {
  font-size: 0.875rem;
  color: #999;
  margin-top: 0.25rem;
}

.project-card {
  display: flex;
  flex-direction: column;
  background-color: var(--background-1);
  border-radius: var(--spacing-8);
  overflow: hidden;
  height: 100%;
}

.project-card__link {
  display: flex;
  flex-direction: column;
  flex: 1;
  text-decoration: none;
  color: var(--text-color);
  transition: background-color 0.2s ease;
}

.project-card__link:hover {
  background-color: var(--background-1-hover);
  color: var(--text-color);
}

.project-card__link:active {
  color: var(--text-color);
}

.project-card__link:visited {
  color: var(--text-color);
}

.project-card__link h3 {
  color: var(--black);
}

.project-card__thumbnail {
  position: relative;
}

.project-card__thumbnail img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  display: block;
}

.project-card__thumbnail-badge {
  position: absolute;
  top: 0.75rem;
  left: 0.75rem;
}

.project-card__thumbnail--placeholder {
  width: 100%;
  height: 180px;
  background-color: var(--warm-gray);
  display: flex;
  align-items: center;
  justify-content: center;
}

.project-card__thumbnail--placeholder i {
  color: var(--white);
  font-size: 2rem;
}

.project-card__body {
  padding: 1.5rem 1.5rem 1rem;
  flex: 1;
}

.project-card__body .badge {
  margin: 0 0 0.5rem 0;
}

.project-card__body h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 0.5rem 0;
}

.project-card__excerpt {
  font-size: 0.875rem;
  color: #666;
  margin: 0;
}

.project-card__footer {
  padding: 1rem 1.5rem 1.5rem;
}

.project-card__detail {
  font-size: 0.875rem;
  margin-bottom: 0.25rem;
}

/* ================================
 SEWIST CARDS
 ================================ */

.sewist-card {
  display: flex;
  flex-direction: column;
  background-color: var(--background-1);
  border-radius: var(--spacing-8);
  overflow: hidden;
  height: 100%;
  text-decoration: none;
  color: var(--text-color);
  transition: background-color 0.2s ease;
}

.sewist-card:hover {
  background-color: var(--background-1-hover);
  color: var(--text-color);
}

.sewist-card__thumbnail {
  position: relative;
  width: 100%;
  height: 180px;
  overflow: hidden;
}

.sewist-card__thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.sewist-card__thumbnail--placeholder {
  background-color: var(--warm-gray);
  display: flex;
  align-items: center;
  justify-content: center;
}

.sewist-card__thumbnail--placeholder i {
  color: var(--white);
  font-size: 2rem;
}

.sewist-card__body {
  padding: 1.5rem 1.5rem 1rem;
  flex: 1;
}

.sewist-card__body h3 {
  font-size: 1.1rem;
  font-weight: 600;
  margin: 0 0 0.5rem 0;
  color: var(--black);
}

.sewist-card__excerpt {
  font-size: 0.875rem;
  color: #666;
  margin: 0 0 0.75rem 0;
}

.sewist-card__skills {
  margin-top: 0.75rem;
}

.profile-skill-tag--more {
  background-color: var(--background-2);
  color: var(--text-color-muted);
}

.sewist-card__footer {
  padding: 0.75rem 1.5rem 1.25rem;
  border-top: 1px solid var(--border-color);
}

.sewist-card__availability {
  font-size: 0.875rem;
  color: #555;
}

.sewist-card__availability i {
  margin-right: 0.25rem;
}

/* ================================
 ACF PRO
 ================================ */

.acf-fields>.acf-field {
  padding: 2rem 0 !important;
}

/* ================================
 CALL TO ACTIONS
 ================================ */
 
.calltoaction {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: var(--background-1);
  padding: var(--spacing-24);
  border-radius: var(--spacing-8);
  height: 100%;
  font-size: 0.75rem;
}

.calltoaction__content {
  flex: 1;
}

.calltoaction__arrow {
  font-size: 1rem !important;
  color: var(--purple) !important;
  width: auto !important;
  height: auto !important;
  margin: 0 0 0 var(--spacing-16) !important;
  flex-shrink: 0;
}

.calltoaction h3 {
  color: var(--purple);
  font-weight: 500;
}

.calltoaction i,
.calltoaction svg {
  display: block;
  color: var(--purple-50);
  font-size: 2rem;
  width: 2rem;
  height: 2rem;
  margin: 0 0 var(--spacing-8) 0;
  padding: 0;
}

i.calltoaction__arrow {
  color: var(--purple);
}

.calltoaction:hover {
  background-color: var(--background-1-hover);
  transition: background-color 0.2s ease;
}

/* ================================
   SIDEBAR NAVIGATION
   ================================ */

.sidebar {
  background-color: var(--background-1);
  padding: 2rem;
  border-radius: var(--spacing-8);
  height: 100%;
}

.sidebar-logo {
  width: 150px;
  margin: 0;
}
   
.sidebar ul {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
}

.sidebar ul li {
  margin-bottom: var(--spacing-4);
}

.sidebar ul li a {
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-8) var(--spacing-12);
  border-radius: var(--spacing-8);
  color: var(--text-color);
  text-decoration: none;
  font-size: 15px;
  transition: background-color 0.2s ease;
}

.sidebar ul li a:hover {
  background-color: var(--purple-10);
  color: var(--purple);
}

.sidebar ul li.current-menu-item a {
  background-color: var(--purple-10);
  color: var(--purple);
}

.sidebar ul li a i {
  width: 20px;
  text-align: center;
  color: var(--purple);
}

/* Bottom nav logout link */
.sidebar-bottom ul li:last-child a, .sidebar-bottom ul li:last-child i  {
  color: red;
}

.sidebar-bottom ul li:last-child a:hover {
  background: rgba(255, 0, 0, 0.1);
}

/* ================================
   BADGES
   ================================ */

.badge {
  font-family: 'Arimo', sans-serif;
  font-size: 0.75rem;
  font-weight: 500;
  padding: 0.45em 0.85em;
  border-radius: 100px;
}
   
.badge.sewist {
  background-color: var(--olive-green-10);
  color: var(--olive-green);
}

.badge.client {
  background-color: var(--black-10);
  color: var(--black);
}

.badge.bg-success {
  background-color: var(--olive-green) !important;
}

.badge.bg-primary {
  background-color: var(--purple) !important;
}

.badge.bg-danger {
  background-color: var(--red) !important;
}

/* ================================
   BUTTONS
   ================================ */

.btn {
  border-radius: 0.5rem !important;
  border: 2px !important;
  padding: 0.4rem 0.9rem !important;
  font-size: 1rem !important;
}

.btn-primary {
  border: 2px solid var(--purple);
  background: var(--purple);
  color: var(--white) !important;
  transition: background-color 0.5s ease, border-color 0.5s ease;
}

.btn-success,
button, input[type="button"],
input[type="reset"],
input[type="submit"] {
  border: 2px solid var(--olive-green);
  background: var(--olive-green);
  color: var(--white) !important;
  transition: background-color 0.5s ease, border-color 0.5s ease;
}

.btn-danger {
  border: 2px solid var(--red);
  background: var(--red);
  color: var(--white) !important;
  transition: background-color 0.5s ease, border-color 0.5s ease;
}

.btn-primary:hover, 
.btn-success:hover, 
.btn-danger:hover,
button:hover, 
input[type="button"]:hover, 
input[type="reset"]:hover, 
input[type="submit"]:hover {
  border: 2px solid var(--black);
  background: var(--black);
}

.btn-link {
  background: none !important;
  border: none !important;
  color: var(--purple) !important;
  transition: color 0.2s ease;
  font-size: 0.85em;
  padding: 0;
}

.btn-link:hover {
  color: var(--black) !important;
  background: none !important;
  border: none !important;
}

.btn-link-danger {
  color: #dc3545 !important;
}

.btn-link-danger:hover {
  color: var(--black) !important;
}

.btn-link-muted {
  color: var(--warm-gray) !important;
  cursor: default;
  font-size: 0.85em;
}
 
.page-login .gform_button, .page-register .gform_button {
  width: 100% !important;
}
 
.calltoaction {
  text-decoration: none;
  color: var(--text-color, #000);
}

/* ================================
   FORMS
   ================================ */

input,
select,
textarea {
  border: 1px solid #ccc !important;
  background: #fff;
  color: #000;
}

.gf_page_steps {
  margin: 3rem 0 !important;
}

/* Hide default GF login form title */
.gform_wrapper .gform_heading {
  display: none;
}

/* Replace (Required) text with asterisk */
.gfield_required_text {
  display: none;
}
.gfield_required:not(.gfield_required_text)::after {
  content: ' *';
  color: var(-);
}

/* Remove GF default box-shadow on inputs */
.gform_wrapper input[type="text"],
.gform_wrapper input[type="password"],
.gform_wrapper input[type="email"],
.gform_wrapper input[type="tel"],
.gform_wrapper input[type="number"],
.gform_wrapper input[type="url"],
.gform_wrapper input[type="date"],
.gform_wrapper textarea,
.gform_wrapper select {
  box-shadow: none !important;
  width: 100%;
}

/* Purple focus highlight */
.gform_wrapper input[type="text"]:focus,
.gform_wrapper input[type="password"]:focus,
.gform_wrapper input[type="email"]:focus,
.gform_wrapper input[type="tel"]:focus,
.gform_wrapper input[type="number"]:focus,
.gform_wrapper input[type="url"]:focus,
.gform_wrapper input[type="date"]:focus,
.gform_wrapper textarea:focus,
.gform_wrapper select:focus {
  outline-color: var(--purple) !important;
  border-color: var(--purple) !important;
  box-shadow: 0 0 0 3px var(--purple-10) !important;
}

/* Input labels */
.gform_wrapper .gfield_label {
  font-size: 1em !important;
  font-weight: 600 !important;
}

.gform_wrapper .gsection_description {
  margin: 0 0 1rem 0;
}

/* Checkboxes and radios */
.gform_wrapper .gfield-choice-input,
.gform_wrapper input[type="checkbox"],
.gform_wrapper input[type="radio"],
.gform_wrapper .ginput_container_consent input[type="checkbox"] {
  accent-color: var(--purple) !important;
  cursor: pointer;
}

.gform_wrapper input[type="radio"]:focus,
.gform_wrapper input[type="checkbox"]:focus {
  outline-color: var(--purple) !important;
  box-shadow: 0 0 0 3px var(--purple-10) !important;
}

/* Submit button */
.gform_wrapper .gform_button,
.gform_wrapper input[type="submit"].gform_button {
  border-radius: var(--spacing-8) !important;
  border: 2px solid var(--purple) !important;
  background: var(--purple) !important;
  color: var(--white) !important;
  font-family: 'Arimo', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  margin: 2rem 0 0 0 !important;
  padding: 0.75rem 1rem !important;
  transition: background 0.5s ease, border-color 0.5s ease !important;
}

.gform_wrapper .gform_button:hover,
.gform_wrapper input[type="submit"].gform_button:hover {
  border: 2px solid var(--black) !important;
  background: var(--black) !important;
  color: var(--white) !important;
}

/* Next button (multi-page forms) */
.gform_wrapper .gform_next_button,
.gform_wrapper input[type="button"].gform_next_button {
  border-radius: var(--spacing-8) !important;
  border: 2px solid var(--purple) !important;
  background: var(--purple) !important;
  color: var(--white) !important;
  font-family: 'Arimo', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  margin: 0 !important;
  padding: 0.75rem 1rem !important;
  transition: background 0.5s ease, border-color 0.5s ease !important;
}

.gform_wrapper .gform_next_button:hover,
.gform_wrapper input[type="button"].gform_next_button:hover {
  border-color: var(--black) !important;
  background: var(--black) !important;
  color: var(--white) !important;
}

/* Page steps — stepper layout */
.gform_wrapper .gf_steps {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  list-style: none;
  padding: 0;
  margin: 0 0 2rem 0;
}

.gform_wrapper .gf_step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  flex: 1;
}

/* Connector line between steps */
.gform_wrapper .gf_step:not(.gf_step_last)::after {
  content: '';
  position: absolute;
  top: 20px;
  left: calc(50% + 22px);
  width: calc(100% - 20px);
  height: 1px;
  background-color: var(--warm-gray);
}

/* Connector line filled for completed steps */
.gform_wrapper .gf_step_completed:not(.gf_step_last)::after {
  background-color: var(--olive-green);
}

/* Step circle */
.gform_wrapper .gf_step_number {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  position: relative !important;
  z-index: 1 !important;
  background-color: var(--warm-gray) !important;
  border: none !important;
  color: var(--white) !important;
}

.gform_wrapper .gf_step_active .gf_step_number {
  background-color: var(--purple) !important;
  border-color: var(--purple) !important;
  color: var(--white) !important;
}

.gform_wrapper .gf_step_completed .gf_step_number {
  background-color: var(--white) !important;
}

.gform-theme--framework .gf_step_completed .gf_step_number::after {
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  font-size: 1rem;
  position: relative;
  z-index: 1;
  background-color: var(--olive-green) !important;
  border: none !important;
  color: var(--white) !important;
}

/* Step label */
.gform_wrapper .gf_step_label {
  margin-top: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500 !important;
  text-transform: capitalize !important;
  color: var(--warm-gray) !important;
}

.gform_wrapper .gf_step_active .gf_step_label {
  color: var(--purple) !important;
}

.gform_wrapper .gf_step_completed .gf_step_label {
  color: var(--olive-green) !important;
}

/* Multi-page navigation layout */
.gform_wrapper .gform_page_footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: relative;
}

/* Hide ajax spinner */
.gform_wrapper .gf_ajax_spinner,
.gform_wrapper .gform_ajax_spinner,
.gform_wrapper [id^="gform_ajax_spinner"] {
  display: none !important;
}

.gform_wrapper #gform_page_2_1 .gform_page_footer {
  justify-content: end !important;
}

/* Previous button (multi-page forms) */
.gform_wrapper .gform_previous_button,
.gform_wrapper input[type="button"].gform_previous_button {
  border-radius: var(--spacing-8) !important;
  border: 2px solid var(--purple) !important;
  background: transparent !important;
  color: var(--purple) !important;
  font-family: 'Arimo', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  margin: 0 !important;
  padding: 0.75rem 1rem !important;
  transition: background 0.5s ease, color 0.5s ease, border-color 0.5s ease !important;
}

.gform_wrapper .gform_previous_button:hover,
.gform_wrapper input[type="button"].gform_previous_button:hover {
  border-color: var(--black) !important;
  color: var(--black) !important;
}

/* File upload drop area */
.gform_wrapper .gform_drop_area {
  border: 2px dashed var(--border-color-10);
  border-radius: var(--spacing-8);
}

.gform_wrapper .gform_drop_area svg,
.gform_wrapper .gform_drop_area .gform_drop_instructions svg {
  color: var(--purple) !important;
  fill: var(--purple) !important;
}

.gform_wrapper .add_list_item, .gform_wrapper .delete_list_item {
  background-color: var(--purple) !important;
}

.gform_wrapper .gform_button_select_files {
  border-radius: var(--spacing-8) !important;
  border: 2px solid var(--purple) !important;
  background: var(--purple) !important;
  color: var(--white) !important;
  font-family: 'Arimo', sans-serif !important;
  font-size: 1rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  padding: 0.75rem 1rem !important;
  transition: background 0.5s ease, border-color 0.5s ease !important;
}

.gform_wrapper .gform_button_select_files:hover {
  border-color: var(--black) !important;
  background: var(--black) !important;
  color: var(--white) !important;
}

.gform-theme--framework .gfield:where(.gfield--type-fileupload,.gfield--input-type-fileupload,.gfield--type-post_image) .gform_drop_area::before {
    color: var(--purple) !important;
}

/* Forgot Password / Register links */
.gf_login_links,
.gf_login_links a {
  font-size: 0.875rem;
  text-align: center;
  margin-top: 2rem;
}

.gf_login_links br {
  display: block;
  margin-bottom: 1rem;
}

.gform_wrapper .validation_message {
  color: red;
  margin: 0 0 1rem 0;  
}

.gform_wrapper .validation_message a {
  display: none;
}

.gform_wrapper .gform-page-footer {
  margin: 4rem 0 0 0 !important;
  align-items: flex-end;
}

/* Hide register link for sewist accounts */
.account-sewist .gf_login_links a[title="Register"] {
  display: none;
}

.gfield_fileupload_progressbar_progress {
  background-color: var(--olive-green) !important;
}

.gform-theme--framework .gfield:where(.gfield--type-fileupload,.gfield--input-type-fileupload,.gfield--type-post_image) .ginput_preview .gfield_fileupload_progress::after {
  color: var(--olive-green) !important;
}

.form-wrap {
  margin-top: var(--spacing-96);
  margin-bottom: var(--spacing-96);
}

.form-logo {
  width: 150px;
}

.form-legal {
  font-size: 0.75rem;
  text-align: center;
}

.gform_wrapper form.is-submitting {
  position: relative;
  opacity: 0.75;
}

.gform_wrapper form.is-submitting input,
.gform_wrapper form.is-submitting select,
.gform_wrapper form.is-submitting textarea,
.gform_wrapper form.is-submitting button {
  pointer-events: none;
}

.gform_wrapper form.is-submitting input[type="submit"],
.gform_wrapper form.is-submitting button[type="submit"] {
  cursor: wait;
}

.form-uploading-message {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid var(--border-color-10);
  border-radius: 0.5rem;
  font-weight: 600;
  background: var(--background-1);
}

.form-spinner {
  width: 1.25rem;
  height: 1.25rem;
  border: 3px solid var(--border-color-10);
  border-top-color: var(--purple);
  border-radius: 50%;
  animation: form-spin 0.8s linear infinite;
  flex: 0 0 auto;
}

.btn-spinner {
  display: inline-block;
  width: 1rem;
  height: 1rem;
  border: 2px solid rgba(255, 255, 255, 0.4);
  border-top-color: var(--white);
  border-radius: 50%;
  animation: form-spin 0.8s linear infinite;
  vertical-align: middle;
  margin-right: 0.25rem;
}

@keyframes form-spin {
  to {
    transform: rotate(360deg);
  }
}

.gf_login_form .gfield {
  margin-bottom: var(--spacing-16);
}

.gf_login_form .gfield_label {
  margin-bottom: 6px;
}

.gf_login_form .validation_message, .gf_login_form input[type="submit"].gform_button {
  margin: var(--spacing-16) 0 0 0 !important;
}

.gform-theme--foundation .gform_fields {
    row-gap: var(--spacing-16) !important;
}

/* ================================
   PROFILE PAGE
   ================================ */

.profile-photo {
  margin-bottom: 1.5rem;
}

.profile-photo img {
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 50%;
  display: block;
  margin-bottom: 0.5rem;
}

.profile-heading-photo {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  cursor: pointer;
}

.profile-photo-placeholder--static {
  pointer-events: none;
  cursor: default;
}

.profile-photo-placeholder--static:hover {
  background-color: var(--light-gray, #f0f0f0);
  border-color: var(--warm-gray, #aaa);
  color: var(--warm-gray, #aaa);
}

.profile-photo-placeholder {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background-color: var(--light-gray, #f0f0f0);
  border: 2px dashed var(--warm-gray, #aaa);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 0.5rem;
  color: var(--warm-gray, #aaa);
  font-size: 2.5rem;
  text-decoration: none;
}

.profile-photo-placeholder:hover {
  background-color: var(--light-green, #e8f5e9);
  border-color: var(--green, #4caf50);
  color: var(--green, #4caf50);
}

.profile-photo__hint {
  font-size: 0.875rem;
  color: var(--warm-gray);
  margin: 0;
}

/* ================================
 NOTIFICATIONS
 ================================ */
 
.notifications-item {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
}

.notifications-label {
    cursor: pointer;
}

/* ================================
 FOOTER
 ================================ */

.portal-footer {
  background-color: var(--dark-purple);
  border-radius: var(--spacing-8);
  color: var(--white);
  width: 100%;
  padding: var(--spacing-16) var(--spacing-24);
  margin: 0;
  font-size: 0.75rem;
  font-weight: 600;
 }
 
 .portal-footer ul.portal-footer-menu {
  display: flex;
  gap: var(--spacing-24);
  list-style: none;
  margin: 0;
  padding: 0;
 }
 
 .portal-footer ul.portal-footer-menu li a {
  color: var(--white);
  text-decoration: underline;
 }
 
/* ── Alert Banners ── */
.alert-banner {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.85rem 1.25rem;
  margin: 2rem 0;
  font-size: 0.9375rem;
  line-height: 1.4;
  border-radius: var(--spacing-8);
}
.alert-banner--review {
  background-color: #fff8e1;
  border-left: 8px solid #ffc107;
  color: #5a4200;
}
.alert-banner--info {
  background-color: #e8f4fd;
  border-left: 8px solid #2196f3;
  color: #0d3a5c;
}
.alert-banner--approved {
  background-color: #eaf4e4;
  border-left: 8px solid #618832;
  color: #2d4a0f;
}
.alert-banner--awaiting {
  background-color: #fff8e1;
  border-left: 8px solid #ff9800;
  color: #5a3200;
}
.alert-banner--completed {
  background-color: #f3e8ff;
  border-left: 8px solid #9c27b0;
  color: #3d0a5c;
}
.alert-banner--cancelled {
  background-color: #fdecea;
  border-left: 8px solid #f44336;
  color: #5c1010;
}
.alert-banner--matched {
  background-color: var(--purple-10);
  border-left: 8px solid var(--purple);
  color: var(--dark-purple);
}

/* ── Status Badges ── */
.badge-status-review {
  background-color: #ffc107;
  color: #5a4200;
}
.badge-status-info {
  background-color: #2196f3;
  color: #fff;
}
.badge-status-approved {
  background-color: #618832;
  color: #fff;
}
.badge-status-progress {
  background-color: #618832;
  color: #fff;
}
.badge-status-awaiting {
  background-color: #ff9800;
  color: #5a3200;
}
.badge-status-completed {
  background-color: #9c27b0;
  color: #fff;
}
.badge-status-cancelled {
  background-color: #f44336;
  color: #fff;
}

/* ── Field Add Link ── */
.field-add-link {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--purple);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.field-add-link:hover {
  text-decoration: underline;
}

/* ── Alert Banner Message (feedback below banner) ── */
.alert-banner-message {
  padding: 0.85rem 1.25rem;
  font-size: 0.9375rem;
  line-height: 1.6;
}
.alert-banner-message--info {
  background-color: #d6eaf8;
  border-left: 8px solid #2196f3;
  color: #0d3a5c;
}

/* ── Profile Portfolio Gallery ── */
.profile-portfolio-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 0.75rem;
  margin-top: 0.5rem;
}
.profile-portfolio-gallery a {
  display: block;
  border-radius: 4px;
  overflow: hidden;
}
.profile-portfolio-gallery img {
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
  display: block;
  transition: opacity 0.15s ease;
}
.profile-portfolio-gallery a:hover img {
  opacity: 0.8;
}

/* ── Profile Skills List ── */
.profile-skills {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* ── Profile Skill Tags ── */
.profile-skills-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.profile-skill-tag {
  background-color: var(--purple-10);
  color: var(--purple);
  font-size: 0.8125rem;
  font-weight: 500;
  padding: 0.3em 0.75em;
  margin: 0.5rem 0.5rem 0 0;
  border-radius: 100px;
}
