/*
Theme Name: rProcess Child
Template: rprocess
Author: Laeeq, Ravi
Tags: custom-background,custom-colors,featured-images,flexible-header,microformats,post-formats,rtl-language-support,theme-options,translation-ready,accessibility-ready
Version: 3.6.1.1762246351
Updated: 2025-11-04 08:52:31

*/

#main {
    margin-top: 0rem;
    background: #fff !important;
}
body {
    font-weight: 400;
    overflow-x: hidden;
}
.navbar-brand img {
    height: 63px !important;
}
.logobrand {   
 height: 120px;
 display: flex;}
.marquee_text h2{color:#0AA1DD !important;}
button.burger-menu-toggle.light {
    background: transparent !important;
}
.how-we {min-height:250px;}

/* Add smooth transition to the background layer */
.industries-zoom > .elementor-motion-effects-layer {
    transition: transform 0.5s ease;
    background-size: cover;
    background-position: center;
}

/* Zoom in effect on hover */
.industries-zoom:hover > .elementor-motion-effects-layer {
    transform: scale(1.1);
}
/* Add smooth transition to the background layer */
.industries-zoom > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    transition: transform 0.5s ease;
}

/* Zoom in effect on hover */
.industries-zoom:hover > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    transform: scale(1.1);
}

/* Alternative: If you want to ensure it overrides, use the full selector */
.elementor-2 .elementor-element.elementor-element-f8b36d5:hover > .elementor-motion-effects-container > .elementor-motion-effects-layer {
    transform: scale(1.1);
}
/* Initial state - hide elements before animation */
.elementor-element-305aee4,
.elementor-element-4a8f0f0,
.elementor-element-c48c140,
.elementor-element-98a8aa5,
.elementor-element-d55de3c,
.elementor-element-7157acc,
.elementor-element-9d98ff8 {
    opacity: 0;
    transform: translateY(50px);
    transition: opacity 0.8s ease, transform 0.8s ease;
}

/* Visible state when in viewport */
.elementor-element-305aee4.animated,
.elementor-element-4a8f0f0.animated,
.elementor-element-c48c140.animated,
.elementor-element-98a8aa5.animated,
.elementor-element-d55de3c.animated,
.elementor-element-7157acc.animated,
.elementor-element-9d98ff8.animated {
    opacity: 1;
    transform: translateY(0);
}

/* Stagger delays for sequential reveal */
.elementor-element-305aee4 { transition-delay: 0.1s; }
.elementor-element-4a8f0f0 { transition-delay: 0.3s; }
.elementor-element-c48c140 { transition-delay: 0.5s; }
.elementor-element-98a8aa5 { transition-delay: 0.7s; }
.elementor-element-d55de3c { transition-delay: 0.9s; }
.elementor-element-7157acc { transition-delay: 1.1s; }
.elementor-element-9d98ff8 { transition-delay: 1.3s; }

/* Fade in elements on scroll */
.elementor-widget-container {
    animation: fadeInUp 0.8s ease-out;
}

@keyframes fadeInUp {
    from {
        opacity: 0;
        transform: translateY(30px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

/* Hover animations for images */
.elementor-image img {
    transition: transform 0.3s ease;
}

.elementor-image img:hover {
    transform: scale(1.05);
}

/* Button hover effects */
.elementor-button {
    transition: all 0.3s ease;
}

.elementor-button:hover {
    transform: translateY(-3px);
    box-shadow: 0 5px 15px rgba(0,0,0,0.3);
}

/* Card/Box hover lift */
.elementor-widget-wrap {
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.elementor-widget-wrap:hover {
    transform: translateY(-5px);
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
}

/* Certification badges animation */
.elementor-image-box-wrapper {
    transition: transform 0.4s ease;
}

.elementor-image-box-wrapper:hover {
    transform: rotate(0deg) scale(1.1);
	overflow:hidden;
}

/* Text color transition */
.elementor-heading-title {
    transition: color 0.3s ease;
}

.elementor-heading-title:hover {
    color: #ff6b6b;
}

.about-rpcocess-values .elementor-icon, .career-rpcocess-values .elementor-icon {background: white;
    border-radius: 8px;
    box-shadow: 0 3px #00000029;}
.about-rpcocess-values .elementor-widget-icon-box {min-height:250px;}
.career-rpcocess-values .elementor-widget-icon-box {min-height:200px;}

 

/* Common styling for dots */
.R-red::after,
.E-green::after,
.h-blue::after,
.A-dark::after {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 0%;
  z-index: 1000;
  top: 50%;               /* Vertically center */
  transform: translateY(-50%);
}

/* Individual dot colors and left offsets */
.R-red::after  { background-color: #FF0000; left: calc(100% + 20px); }
.E-green::after  { background-color: #74CC00; left: calc(100% + 20px); }
.h-blue::after  { background-color: #0AA1DD; left: calc(100% + 20px); }
.A-dark::after  { background-color: #011E3D; left: calc(100% + 20px); }

.T-brown, .R-red, .E-green, .H-blue, .A-dark, .elementor-image-box-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;  /* important for ::after positioning */
}

/* ✅ Responsive adjustment for mobile (below the box) */
@media (max-width: 767px) {
  .R-red::after,
  .E-green::after,
  .h-blue::after,
  .A-dark::after {
    top: auto;
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
  }
}

.testimonial .elementor-widget-testimonial  {
	min-height:320px;
width:100%;
}

/* Application Form Styling */

/* ========================================
   BASE STYLES - Mobile First - ULTRA COMPACT
======================================== */

.application-form {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 20px;
    box-sizing: border-box;
}

.application-form * {
    box-sizing: border-box;
}

/* ========================================
   FORM LAYOUT - MINIMAL SPACING
======================================== */

.form-row {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: 0px; /* Removed all margin */
    width: 100%;
}

.form-col-half,
.form-col-full {
    width: 100%;
    margin-bottom: 8px; /* Minimal spacing */
}

.form-col-full {
    margin-bottom: 8px;
}

/* Last row - no bottom margin */
.form-row:last-child .form-col-full {
    margin-bottom: 0;
}

/* ========================================
   FORM ELEMENTS - COMPACT
======================================== */

.application-form label {
    display: block;
    font-size: 13px;
    color: #333;
    margin-bottom: 4px; /* Minimal label spacing */
    font-weight: 500;
}

.application-form input[type="text"],
.application-form input[type="email"],
.application-form input[type="tel"],
.application-form select,
.application-form textarea {
    width: 100%;
    padding: 8px 12px; /* Reduced padding */
    border: 1px solid #d1d5db;
    border-radius: 4px;
    background: white;
    font-size: 14px;
    transition: all 0.3s;
    box-sizing: border-box;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.application-form input[type="text"]:focus,
.application-form input[type="email"]:focus,
.application-form input[type="tel"]:focus,
.application-form select:focus,
.application-form textarea:focus {
    outline: none;
    border-color: #1e5a96;
    box-shadow: 0 0 0 3px rgba(30, 90, 150, 0.1);
}

.application-form textarea {
    height: 100px; /* Reduced height */
    resize: vertical;
    font-family: inherit;
    line-height: 1.5;
}

/* ========================================
   FILE UPLOAD
======================================== */

.application-form input[type="file"] {
    width: 100%;
    padding: 8px; /* Reduced padding */
    border: 1px solid #707070;
    border-radius: 8px;
    background: #D8D8D8;
    cursor: pointer;
    font-size: 13px;
}

.application-form input[type="file"]::-webkit-file-upload-button {
    padding: 6px 10px; /* Reduced padding */
    background: #D8D8D8;
    color: #000;
    border: none;
    border-radius: 8px;
    cursor: pointer;
    font-size: 12px;
    margin-right: 8px;
}

.application-form input[type="file"]::-webkit-file-upload-button:hover {
    background: #C8C8C8;
}

/* ========================================
   SELECT DROPDOWN
======================================== */

.application-form select {
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23333' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 18px;
    padding-right: 35px;
    cursor: pointer;
}

/* ========================================
   SUBMIT BUTTON
======================================== */

.application-form .submit-btn {
    width: 100%;
    padding: 12px 25px; /* Reduced padding */
    background: #C53D3D;
    color: white;
    border: none;
    border-radius: 5px;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s;
    text-transform: none;
    -webkit-appearance: none;
    margin-top: 10px; /* Small top margin */
}

.application-form .submit-btn:hover {
    background: #C75757;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(201, 66, 66, 0.3);
}

.application-form .submit-btn:active {
    transform: translateY(0);
}

/* ========================================
   VALIDATION STYLES
======================================== */

.wpcf7-form-control-wrap {
    display: block;
    width: 100%;
    position: relative;
}

.wpcf7-not-valid {
    border-color: #dc2626 !important;
    background-color: #fef2f2 !important;
}

.wpcf7-not-valid:focus {
    border-color: #dc2626 !important;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1) !important;
}

.wpcf7-not-valid-tip {
    display: block;
    font-size: 11px;
    color: #dc2626;
    margin-top: 2px;
    font-weight: 500;
}

/* ========================================
   RESPONSE MESSAGES
======================================== */

.wpcf7-response-output {
    margin: 10px 0 0;
    padding: 10px 12px; /* Reduced padding */
    border-radius: 4px;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.5;
}

.wpcf7-mail-sent-ok {
    background: #d1fae5;
    border: 1px solid #10b981;
    color: #065f46;
}

.wpcf7-mail-sent-ng,
.wpcf7-validation-errors,
.wpcf7-acceptance-missing {
    background: #fee2e2;
    border: 1px solid #dc2626;
    color: #991b1b;
}

.wpcf7-spinner {
    margin-left: 8px;
    display: inline-block;
}

/* ========================================
   FORM SUBMISSION STATE
======================================== */

.wpcf7 form.submitting * {
    pointer-events: none;
    opacity: 0.6;
}

/* ========================================
   TABLET RESPONSIVE (768px and up) - ULTRA COMPACT
======================================== */

@media only screen and (min-width: 768px) {
    .application-form {
        padding: 30px; /* Reduced from 35px */
        max-width: 670px;
    }
    
    .application-form h2 {
        font-size: 26px;
        margin-bottom: 15px; /* Reduced */
    }
    
    .form-row {
        flex-direction: row;
        gap: 15px; /* Reduced from 20px */
        margin-bottom: 0px; /* No bottom margin */
    }
    
    .form-col-half {
        flex: 1;
        margin-bottom: 12px; /* Minimal spacing */
    }
    
    .form-col-full {
        flex: 1 1 100%;
        margin-bottom: 12px;
    }
    
    .application-form label {
        font-size: 14px;
        margin-bottom: 4px;
    }
    
    .application-form input[type="text"],
    .application-form input[type="email"],
    .application-form input[type="tel"],
    .application-form select {
        padding: 9px 12px; /* Slightly larger on desktop */
    }
    
    .application-form textarea {
        min-height: 100px; /* Reduced */
    }
    
    .application-form .submit-btn {
        padding: 13px 30px;
        font-size: 16px;
        margin-top: 8px;
    }
    
    .application-form input[type="file"] {
        font-size: 14px;
        padding: 9px;
    }
    
    .application-form input[type="file"]::-webkit-file-upload-button {
        font-size: 13px;
        padding: 7px 12px;
    }
}

/* ========================================
   DESKTOP RESPONSIVE (1024px and up)
======================================== */

@media only screen and (min-width: 1024px) {
    .application-form {
        padding: 35px;
    }
    
    .application-form h2 {
        font-size: 28px;
        margin-bottom: 18px;
    }
    
    .form-row {
        gap: 18px;
        margin-bottom: 0px;
    }
    
    .form-col-half {
        margin-bottom: 12px;
    }
    
    .form-col-full {
        margin-bottom: 12px;
    }
    
    .application-form input[type="text"],
    .application-form input[type="email"],
    .application-form input[type="tel"],
    .application-form select,
    .application-form textarea {
        font-size: 15px;
    }
}

/* ========================================
   SMALL MOBILE (max 480px)
======================================== */

@media only screen and (max-width: 480px) {
    .application-form {
        padding: 15px;
        border-radius: 6px;
    }
    
    .application-form h2 {
        font-size: 20px;
        margin-bottom: 12px;
    }
    
    .form-row {
        margin-bottom: 0px;
    }
    
    .form-col-half {
        margin-bottom: 8px;
    }
    
    .form-col-full {
        margin-bottom: 8px;
    }
    
    .application-form label {
        font-size: 12px;
        margin-bottom: 3px;
    }
    
    .application-form input[type="text"],
    .application-form input[type="email"],
    .application-form input[type="tel"],
    .application-form select,
    .application-form textarea {
        padding: 8px 10px;
        font-size: 14px;
    }
    
    .application-form textarea {
        min-height: 80px;
    }
    
    .application-form .submit-btn {
        padding: 11px 20px;
        font-size: 14px;
        margin-top: 6px;
    }
    
    .application-form input[type="file"] {
        padding: 7px;
        font-size: 12px;
    }
    
    .application-form input[type="file"]::-webkit-file-upload-button {
        padding: 5px 8px;
        font-size: 11px;
    }
    
    .wpcf7-response-output {
        font-size: 12px;
        padding: 8px 10px;
        margin-top: 8px;
    }
}

/* ========================================
   LANDSCAPE MOBILE FIX
======================================== */

@media only screen and (max-height: 500px) and (orientation: landscape) {
    .application-form {
        padding: 12px;
    }
    
    .application-form h2 {
        font-size: 18px;
        margin-bottom: 8px;
    }
    
    .form-row {
        margin-bottom: 0px;
    }
    
    .form-col-half {
        margin-bottom: 6px;
    }
    
    .application-form textarea {
        min-height: 60px;
    }
}

/* ========================================
   iOS SPECIFIC FIXES
======================================== */

@supports (-webkit-touch-callout: none) {
    .application-form input[type="text"],
    .application-form input[type="email"],
    .application-form input[type="tel"],
    .application-form select,
    .application-form textarea {
        font-size: 16px;
    }
}

/* ========================================
   TOUCH DEVICE IMPROVEMENTS
======================================== */

@media (hover: none) and (pointer: coarse) {
    .application-form .submit-btn:hover {
        transform: none;
    }
    
    .application-form input[type="text"],
    .application-form input[type="email"],
    .application-form input[type="tel"],
    .application-form select,
    .application-form textarea {
        font-size: 16px;
    }
}

/* ========================================
   ACCESSIBILITY
======================================== */

.application-form input:focus,
.application-form select:focus,
.application-form textarea:focus {
    outline: 2px solid #1e5a96;
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .application-form *,
    .application-form *::before,
    .application-form *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
    }
}

/* ========================================
   LOCATION ICONS FIX
======================================== */

.locations .elementor-widget-icon-box.elementor-position-top .elementor-icon-box-wrapper {
    top: 0 !important;
    z-index: 1 !important;
    overflow: visible !important;
}

.locations .elementor-widget-icon-box.elementor-position-top .elementor-icon-box-icon {
    position: relative;
    top: -40px;
    margin-bottom: -25px;
    z-index: 999;
}

/* ========================================
   CAREER SLIDE OVERLAY
======================================== */

.career-slide .elementor-1085 .elementor-element.elementor-element-70cdb55::before {
    content: "";
    position: absolute;
    inset: 0;
    background: inherit;
    filter: grayscale(100%) brightness(0.8);
    z-index: 0;
}

.career-slide .elementor-1085 .elementor-element.elementor-element-70cdb55::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.45);
    z-index: 1;
}
/* Remove all <br> tag spacing in Contact Form 7 */
.application-form br,
.wpcf7-form br,
.wpcf7 br {
    display: none !important;
}

/* Remove extra spacing from CF7 elements */
.application-form p {
    margin: 0 !important;
    padding: 0 !important;
}

/* Ensure labels are inline with inputs */
.application-form label br {
    display: none !important;
}

/* Remove any auto-generated spacing */
.wpcf7-form-control-wrap br {
    display: none !important;
}

.locatons .elementor-element {
  position: relative;
  /* Makes space for the floating icon */
  text-align: center;
  overflow: visible !important; /* Ensures the icon isn't clipped */
}

.locatons .elementor-icon-box-icon {
  position: absolute;
  top: -25px; /* Adjust this value for the overlap depth */
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
}

.locatons .elementor-icon-box-content {
  margin-top: 30px; /* Optional: adds space between icon and text */
}

/* ========================================
   CONTACT FORM STYLING
======================================== */

.contact-form-wrapper {
    max-width: 100%;
    margin: 0 auto;
    padding: 30px 55px;
    background: #EFF5FC;
    border: 1px solid #006FDE;
    border-radius: 8px;
    box-sizing: border-box;
}

.contact-form-wrapper * {
    box-sizing: border-box;
}

/* Form Title */
.contact-form-title {
    font-size: 30px;
    font-weight: 700;
    color: #024288;
    text-align: center;
    margin: 0 0 25px 0;
    padding: 0;
}

/* Form Container */
.contact-form-container {
    width: 100%;
}

/* Form Rows */
.contact-form-row {
    width: 100%;
    margin-bottom: 15px;
}

.contact-form-row:last-child {
    margin-bottom: 0;
    margin-top: 20px;
}

/* Labels */
.contact-form-wrapper label {
    display: block;
    font-size: 16px;
    font-weight: 500;
    color: #1E1E1E;
    margin-bottom: 6px;
}

/* Input Fields */
.contact-input {
    width: 100%;
    padding: 10px 15px;
    border: 1px solid #B8C9D9;
    border-radius: 6px;
    background: #FFFFFF;
    font-size: 14px;
    color: #333;
    transition: all 0.3s ease;
    box-sizing: border-box;
    font-family: inherit;
}

.contact-input:focus {
    outline: none;
    border-color: #0A5C99;
    box-shadow: 0 0 0 3px rgba(10, 92, 153, 0.1);
}

/* Submit Button */
.contact-submit-btn {
    width: 100%;
    padding: 14px 25px;
    background: #C53D3D !important;
    color: #FFFFFF;
    border: none;
    border-radius: 6px;
    font-size: 18px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-align: center;
    text-transform: none;
    -webkit-appearance: none;
}

.contact-submit-btn:hover {
    background: #C53D3D !important;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(197, 61, 61, 0.3);
}

.contact-submit-btn:active {
    transform: translateY(0);
}

/* ========================================
   CONTACT FORM 7 VALIDATION
======================================== */

.wpcf7-form-control-wrap {
    display: block;
    width: 100%;
    position: relative;
}

/* Invalid Field */
.contact-form-wrapper .wpcf7-not-valid {
    border-color: #dc2626 !important;
    background-color: #fef2f2 !important;
}

.contact-form-wrapper .wpcf7-not-valid:focus {
    border-color: #dc2626 !important;
    box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1) !important;
}

/* Error Messages */
.wpcf7-not-valid-tip {
    display: block;
    font-size: 12px;
    color: #dc2626;
    margin-top: 4px;
    font-weight: 500;
}

/* Response Messages */
.contact-form-wrapper .wpcf7-response-output {
    margin: 15px 0 0;
    padding: 12px 15px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: 500;
    text-align: center;
}

.wpcf7-mail-sent-ok {
    background: #d1fae5;
    border: 1px solid #10b981;
    color: #065f46;
}

.wpcf7-mail-sent-ng,
.wpcf7-validation-errors,
.wpcf7-acceptance-missing {
    background: #fee2e2;
    border: 1px solid #dc2626;
    color: #991b1b;
}

/* Spinner */
.wpcf7-spinner {
    margin-left: 10px;
}

/* Form Submitting State */
.wpcf7 form.submitting * {
    pointer-events: none;
    opacity: 0.6;
}

/* ========================================
   RESPONSIVE - TABLET
======================================== */

@media only screen and (max-width: 768px) {
    .contact-form-wrapper {
        max-width: 100%;
        padding: 25px;
    }
    
    .contact-form-title {
        font-size: 22px;
        margin-bottom: 20px;
    }
    
    .contact-form-row {
        margin-bottom: 12px;
    }
}

/* ========================================
   RESPONSIVE - MOBILE
======================================== */

@media only screen and (max-width: 480px) {
    .contact-form-wrapper {
        padding: 20px;
        border-width: 1px;
    }
    
    .contact-form-title {
        font-size: 20px;
        margin-bottom: 18px;
    }
    
    .contact-form-row {
        margin-bottom: 12px;
    }
    
    .contact-form-wrapper label {
        font-size: 13px;
        margin-bottom: 5px;
    }
    
    .contact-input {
        padding: 10px 12px;
        font-size: 14px;
    }
    
    .contact-submit-btn {
        padding: 12px 20px;
        font-size: 15px;
    }
}

/* ========================================
   iOS FIXES
======================================== */

@supports (-webkit-touch-callout: none) {
    .contact-input {
        font-size: 16px; /* Prevents iOS zoom */
    }
}

/* ========================================
   ACCESSIBILITY
======================================== */

.contact-input:focus {
    outline: 2px solid #0A5C99;
    outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
    .contact-form-wrapper *,
    .contact-form-wrapper *::before,
    .contact-form-wrapper *::after {
        animation-duration: 0.01ms !important;
        transition-duration: 0.01ms !important;
    }
}