/*
Theme Name: Hello Elementor Child
Theme URI: https://elementor.com/
Description: Child theme for Hello Elementor
Author: Your Name
Template: hello-elementor
Version: 1.0.0
Text Domain: hello-elementor-child
*/

/* Custom CSS Starts Here */

:root{
    /* --- global palette --- */
    --color-primary: #E8185D;
    --color-primary-rgb: 232,24,93;
    --color-primary-hover: #c9154f;
    --color-secondary: #F97316;
    --color-secondary-rgb: 249,115,22;
    --color-gradient: linear-gradient(135deg, var(--color-primary), var(--color-secondary));

    --color-dark-1: #0F172A;
    --color-dark-2: #1C2130;

    --color-white: #ffffff;
    --color-white-rgb: 255,255,255;
    --color-black: #000000;
    --color-black-rgb: 0,0,0;

    --color-meta: #6B7280;
    --color-border: #E2E5EC;
    --color-input-text: #d1d5db;

    --color-focus: #ff4d6d;
    --color-white-translucent-70: #FFFFFFB3;

    --color-accent-start: #ff0066;
    --color-accent-end: #ff6a00;
    --color-iso-start: #ff2d55;
    --color-iso-end: #ff7a18;
    --color-process-start: #e63946;
    --color-process-end: #ff7a18;

    /* legacy helpers (maintain existing variable names for backward compatibility) */
    --qw-primary: var(--color-primary);
    --qw-secondary: var(--color-secondary);
    --qw-gradient: var(--color-gradient);
}

.color-primary{
	color: var(--color-primary);
}

.gradient-background {
    background: var(--color-gradient);
}

.color-gradient {
  background: var(--color-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gradient h2 {
  background: linear-gradient(135deg, var(--color-primary), var(--color-secondary));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Number Gradient Box */
.gradient-number-bg{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:42px;
    height:42px;
    margin-right:14px;

    font-size:16px;
    font-weight:700;
    color:var(--color-white);

    background:var(--color-gradient);
    border-radius:10px;

    line-height:1;
}

.round-gradient-number-bg{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:48px;
    height:48px;
    margin-right:14px;

    font-size:16px;
    font-weight:700;
    color:var(--color-white);

    background:var(--color-gradient);
    border-radius:99px;

    line-height:1;
}

.small-round-gradient-number-bg{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:32px;
    height:32px;
    margin-right:14px;

    font-size:16px;
    font-weight:700;
    color:var(--color-white);

    background:var(--color-gradient);
    border-radius:99px;

    line-height:1;
}
.elementor-progress-bar {
  background: linear-gradient(135deg, #E8185D, #F97316) !important;
}

.icon-gradient-bg .elementor-icon {
  background: var(--color-gradient);
  /* color: var(--color-white); */
  /* fill: var(--color-white); */
  border-radius: 12px;
  padding: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.card-hover-lift {
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.card-hover-lift:hover {
  transform: translateY(-8px);
  box-shadow: 0 18px 40px rgba(var(--color-black-rgb), 0.12);
}

/* Hover transform modifier */
.gradient-icon-box--hover-lift:hover {
  transform: translateY(-6px);
}

/* Gradient Button */
.qw-gradient-btn .elementor-button{
    background:var(--qw-gradient);
    color:var(--color-white);
    border:none;
    border-radius:10px;
    transition:all .35s ease;
}

.qw-gradient-btn .elementor-button:hover{
transform:translateY(-2px);
box-shadow:0 12px 30px rgba(232,24,93,.25);
}

/* Gradient Text */
.qw-gradient-text{
background:var(--qw-gradient);
-webkit-background-clip:text;
-webkit-text-fill-color:transparent;
background-clip:text;
color:transparent;
display:inline-block;
}

/* Learn More Link */
.qw-learn-more{
    display:inline-flex;
    align-items:center;
    gap:6px;
    font-family:'DM Sans',sans-serif;
    font-size:14px;
    font-weight:600;
    color:var(--color-primary);
    text-decoration:none !important;
    transition:all .3s ease;
}

/* Hover color */
.qw-learn-more:hover{
    color:var(--color-primary-hover);
}

/* Arrow animation */
.qw-arrow-icon{
transition:transform .3s ease;
}

.qw-learn-more:hover .qw-arrow-icon{
transform:translateX(4px);
}

/* Training Section Background */
.qw-training-bg{
    position:relative;
    overflow:hidden;
    background:
        radial-gradient(circle at 20% 25%, rgba(232,24,93,0.18), transparent 40%),
        radial-gradient(circle at 80% 70%, rgba(249,115,22,0.18), transparent 40%),
        linear-gradient(135deg,var(--color-dark-1),var(--color-dark-2));
}



/* Gradient Icon Background */
.qw-gradient-icon .elementor-icon{
    background: var(--color-gradient) !important;
    color: var(--color-white) !important;
    border-radius:10px;
    padding:14px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    transition:all .35s ease;
}

/* Hover Effect */
.qw-gradient-icon:hover .elementor-icon{
transform:translateY(-3px);
box-shadow:0 12px 30px rgba(232,24,93,.25);
}


/* ===== Lovable CF7 Form ===== */

.cf7-lovable-form{
    border-radius:16px;
    border:1px solid rgba(255,255,255,.08);
    background:rgba(255,255,255,.04);
    padding:32px;
    backdrop-filter:blur(10px);
    color:var(--color-white);
} 
.cf7-header {
    margin-bottom: 20px;
}

.cf7-header h3{
    font-size:22px;
    font-weight:700;
    margin-bottom:5px;
    color: var(--color-accent-start);
}

.cf7-header p{
color: var(--color-dark-2);
font-size:14px;
margin-bottom:25px;
}

.cf7-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:20px;
}

@media(max-width:768px){
.cf7-grid{
grid-template-columns:1fr;
}
}

.cf7-field{
display:flex;
flex-direction:column;
gap:6px;
margin-bottom:18px;
}

.cf7-field label{
font-size:12px;
font-weight:600;
color:var(--color-dark-1);
}

/* Inputs */
.cf7-lovable-form input,
.cf7-lovable-form textarea,
.cf7-lovable-form select{
    width:100%;
    height:44px;
    border-radius:8px;
    border:1px solid var(--color-dark-2);
    background:rgba(255,255,255,.08);
    color:var(--color-dark-2);
    padding:10px 14px;
    outline:none;
}

.cf7-lovable-form textarea{
height:120px;
resize:none;
}

.cf7-lovable-form input::placeholder,
.cf7-lovable-form textarea::placeholder{
color:var(--color-dark-2);
}

/* Focus */
.cf7-lovable-form input:focus,
.cf7-lovable-form textarea:focus,
.cf7-lovable-form select:focus{
    border-color:var(--color-focus);
    box-shadow:0 0 0 2px rgba(255,77,109,.3);
}

/* Submit Button */
.cf7-submit input[type=submit]{
    width:100%;
    height:48px;
    border:none;
    border-radius:10px;
    font-weight:600;
    cursor:pointer;
    background: var(--color-gradient);
    color: var(--color-white);
    transition:.3s;
}

.cf7-submit input[type=submit]:hover{
transform:translateY(-2px);
box-shadow:0 12px 30px rgba(232,24,93,.25);
}

/* Remove CF7 default spacing */
.wpcf7-form p{
margin:0;
}

/* Security note */
.cf7-note{
margin-top:15px;
text-align:center;
font-size:12px;
color:var(--color-dark-2);
}

/* ================================
   CF7 Lovable Form Select Styling
================================ */

/* Wrapper */
.cf7-lovable-form select{
    appearance:none;
    -webkit-appearance:none;
    -moz-appearance:none;

    width:100%;
    height:48px;

    background:rgba(255,255,255,.08);
    color:var(--color-dark-2);

    border:1px solid var(--color-dark-1);
    border-radius:10px;

    padding:0 45px 0 15px;
    font-size:14px;
    outline:none;
    cursor:pointer;
    transition:.3s;
}

/* Hover */
.cf7-lovable-form select:hover{
    border-color:var(--color-focus);
}

/* Focus */
.cf7-lovable-form select:focus{
    border-color:var(--color-focus);
    box-shadow:0 0 0 2px rgba(255,77,109,.25);
}

/* Custom Arrow */
.cf7-field{
position:relative;
}

.cf7-field select{
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
background-repeat:no-repeat;
background-position:right 14px center;
background-size:16px;
}

/* Option text */
.cf7-lovable-form select option{
    color: var(--color-black);
}

/* Remove CF7 default spacing */
.cf7-lovable-form .wpcf7-form-control-wrap{
display:block;
}

/* Label styling */
.cf7-field label{
    display:block;
    font-size:12px;
    font-weight:600;
    margin-bottom:6px;
    color: var(--color-dark-2);
}


/* BLOG GRID */
.qw-blog-grid{
max-width:1400px;
margin:auto;
display:grid;
gap:24px;
grid-template-columns:repeat(3,1fr);
}

/* Responsive */
@media(max-width:1024px){
.qw-blog-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:767px){
.qw-blog-grid{grid-template-columns:1fr;}
}

/* Card */
.qw-blog-card{
    background: var(--color-white);
    border:1px solid var(--color-border);
    border-radius:16px;
    overflow:hidden;
    transition:.35s;
    display:flex;
    flex-direction:column;
}

.qw-blog-card:hover{
transform:translateY(-6px);
box-shadow:0 20px 40px rgba(0,0,0,.08);
border-color:rgba(232,24,93,.25);
}

/* Image */
.qw-blog-image{
position:relative;
height:200px;
overflow:hidden;
}

.qw-blog-image img{
width:100%;
height:100%;
object-fit:cover;
transition:.5s;
}

.qw-blog-card:hover img{
transform:scale(1.06);
}

/* Badge */
.qw-blog-badge{
    position:absolute;
    top:14px;
    left:14px;
    background: var(--color-gradient);
    color: var(--color-white);
    font-size:11px;
    font-weight:700;
    padding:6px 12px;
    border-radius:50px;
}

/* Content */
.qw-blog-content{
padding:20px;
display:flex;
flex-direction:column;
flex:1;
}

.qw-blog-meta{
    font-size:12px;
    color:var(--color-meta);
    margin-bottom:12px;
    display:flex;
    gap:16px;
}

.qw-blog-title{
font-family:'Outfit';
font-size:18px;
font-weight:700;
line-height:1.4;
margin-bottom:10px;
}

.qw-blog-title a{
    text-decoration:none;
    color:var(--color-dark-2);
}

.qw-blog-card:hover .qw-blog-title a{
    color:var(--color-primary);
}

.qw-blog-excerpt{
    font-family:'DM Sans';
    font-size:14px;
    color:var(--color-meta);
    flex:1;
    margin-bottom:18px;
}

.qw-blog-readmore{
    font-weight:600;
    color:var(--color-primary);
    text-decoration:none;
    transition:.3s;
}

.qw-blog-readmore:hover{
letter-spacing:.4px;
}


/* Center Alignment */
.footer-cta {
    text-align: center;
}

/* CTA Link */
.footer-cta-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background-color: none!important;
    background-image: none !important;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;

    color: var(--color-white-translucent-70); /* Default color */
    transition: color 0.3s ease;
}

/* Arrow Icon */
.footer-cta-link .cta-arrow {
    width: 16px;
    height: 16px;
    transition: transform 0.3s ease;
}

/* Hover Color */
.footer-cta-link:hover {
    color: var(--e-global-color-primary);
}

/* Arrow Animation */
.footer-cta-link:hover .cta-arrow {
    transform: translateX(4px);
}

.gradient-card,
.service-card-hover{
    position: relative;
    overflow: hidden;
    border-radius: 16px;
}

/* Gradient Top Border */
.gradient-card::before,
.service-card-hover::before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 4px; /* thickness */

    background: linear-gradient(
        90deg,
        var(--color-accent-start),
        var(--color-accent-end)
    );

    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
}

.service-card-hover {
    transition: transform 0.3s ease;
}

.service-card-hover:hover {
    transform: translateY(-10px);
}

/* ===== Service Item Layout ===== */

.lovable-service-list .elementor-icon-list-item{
    position: relative;
    display: flex;
    align-items: center;
    gap:12px;
    transition: all .35s ease;
}

/* ===== Gradient Dot ===== */

.lovable-service-list .elementor-icon-list-item::before{
    content:"";
    width:6px;
    height:6px;
    border-radius:50%;
    flex-shrink:0;
    background:linear-gradient(135deg,
        var(--e-global-color-primary),
        var(--e-global-color-secondary)
    );
}

/* ===== Text ===== */

.lovable-service-list .elementor-icon-list-text{
    flex:1;
    transition:all .3s ease;
}

/* ===== Arrow (Hidden Default) ===== */

.lovable-service-list .elementor-icon-list-item::after{
    content:"\2192"; /* arrow */
    font-size:14px;
    opacity:0;
    transform:translateX(-8px);
    transition:all .3s ease;
    color:var(--e-global-color-primary);
}

/* ===== Hover Animation ===== */

.lovable-service-list .elementor-icon-list-item:hover{
    transform:translateX(6px) !important;
}

.lovable-service-list .elementor-icon-list-item:hover::after{
    opacity:1 !important;
    transform:translateX(0) !important;
}

/* Gradient Icon Background */
.gradient-icon .elementor-icon{
    background: linear-gradient(135deg,
        var(--e-global-color-primary),
        var(--e-global-color-secondary)
    );
    
    padding:14px;
    border-radius:12px;
    /*display:flex;*/
    /*align-items:center;*/
    /*justify-content:center;*/
}

/* Hover Interaction from Card */
.gradient-card:hover .service-card-icon .elementor-icon{
    transform: scale(1.02);
    /* box-shadow: 0 12px 30px rgba(232,24,93,.25); */
}

/* Default Icon Background */
.gradient-icon-hover .elementor-icon-box-icon .elementor-icon{
    background:#FDE8F0;
    border-radius:10px;
    padding:14px;
    transition:all .3s ease;
}

/* Default Icon Color */
/*.gradient-icon-hover .elementor-icon svg{*/
/*    color:#E8185D;*/
/*    fill:#E8185D;*/
/*    transition:all .3s ease;*/
/*}*/


/* ===== HOVER EFFECT ===== */

/* When Card Hovered */
.gradient-icon-hover .e-con:hover .elementor-icon-box-icon .elementor-icon{
    background:linear-gradient(135deg,#E8185D,#F97316);
}

.image-gradient-bg{
    position:relative;
    display:inline-block;
}

.image-gradient-bg::after{
    content:"";
    position:absolute;
    width:90%;
    height:100%;
    background:linear-gradient(135deg,#E8185D,#F97316);
    opacity:0.12;
    border-radius:20px;
    z-index:0;
}

.image-gradient-bg img{
    border-radius:20px;
    position:relative;
    z-index:1;
}

.gradient-right::after{
    bottom:-10px;
    right:65px;
}

.gradient-left::after{
    bottom:-20px;
    left:50px;
}

.gradient-top-right::after{
    top:-20px;
    right:-20px;
}

.gradient-top-left::after{
    top:-20px;
    left:-20px;
}

.removeHeadingMargin .elementor-icon-box-title {
    margin-top: 0px !important;
}

/* ===============================
   SERVICE CARD ONLY
================================*/

.service-card-hover .e-con-inner > .e-con{
    position: relative;
    overflow: hidden;
    transition: all .35s ease;
}

/* Gradient Top Line */
.service-card-hover .e-con-inner > .e-con::before{
    content:"";
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:3px;

    background:linear-gradient(90deg,#E8185D,#F97316);

    opacity:0;
    transform:scaleX(0);
    transform-origin:left;
    transition:all .35s ease;
}

/* Hover Lift */
.service-card-hover .e-con-inner > .e-con:hover{
    transform:translateY(-8px);
    box-shadow:0 12px 30px rgba(0,0,0,0.08);
}

/* Show Gradient */
.service-card-hover .e-con-inner > .e-con:hover::before{
    opacity:1;
    transform:scaleX(1);
}


.process-section{
    position:relative;
    margin-top:60px;
}

.process-line{
    width: 82%;
    position:absolute;
    top:52px;
    left:90px;
    right:0;
    height:2px;
    background:linear-gradient(90deg,var(--color-process-start),var(--color-process-end),var(--color-process-start));
}

.process-grid{
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:30px;
    text-align:center;
}

.process-item{
    position:relative;
}

.process-icon-box{
    width:110px;
    height:110px;
    margin:auto;
    background:#fff;
    border:2px solid #e5e7eb;
    border-radius:18px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
}

.step-number{
    font-size:26px;
    font-weight:700;
    background:linear-gradient(90deg,#e63946,#ff7a18);
    -webkit-background-clip:text;
    color:transparent;
}

.process-icon{
    width:22px;
    height:22px;
    margin-top:6px;
    stroke:#6b7280;
    fill:none;
    stroke-width:2;
}

.process-item h3{
    margin-top:20px;
    font-size:16px;
    font-weight:700;
}

.process-item p{
    font-size:13px;
    color:#6b7280;
    line-height:1.6;
}

/* Responsive */

@media(max-width:1024px){
    .process-grid{
        grid-template-columns:repeat(2,1fr);
    }
    .process-line{
        display:none;
    }
}

@media(max-width:576px){
    .process-grid{
        grid-template-columns:1fr;
    }
}


/*.iso-list{*/
/*    margin-top:20px;*/
/*}*/

.iso-item{
    display:flex;
    align-items:center;
    gap:18px;
    padding:14px 0;
}

/* Number Gradient Box */
.iso-number{
    width:36px;
    height:36px;
    display:flex;
    align-items:center;
    justify-content:center;
    border-radius:10px;
    font-size:14px;
    font-weight:700;
    color:#fff;
    background:linear-gradient(135deg,var(--color-iso-start),var(--color-iso-end));
    flex-shrink:0;
}

/* Divider Line */
.iso-divider{
    flex:1;
    height:1px;
    background:rgba(255,255,255,0.15);
}

/* Text */
.iso-text{
    font-size:15px;
    font-weight:500;
    color: rgba(var(--color-white-rgb),0.8);
    margin:0;
    white-space:nowrap;
}

/* Arrow */
.iso-arrow{
    font-size:20px;
    color: rgba(var(--color-white-rgb),0.4);
    margin-left:8px;
}

/* Responsive */
@media(max-width:768px){

    .iso-item{
        flex-wrap:wrap;
    }

    .iso-divider{
        display:none;
    }

    .iso-text{
        width:100%;
        margin-left:54px;
    }
}

/* Default: Hide arrow for mobile & tablet */
.beforeArrow::after{
    display:none;
}

/* Show arrow only on laptop and desktop */
@media (min-width:1024px){

    /* Arrow between cards */
    .beforeArrow {
        position: relative;
    }

    .beforeArrow::after {
        content: '›';
        position: absolute;
        right: -18px;
        top: 50%;
        transform: translateY(-50%);
        font-size: 36px;
        font-weight: 300;
        color: #e8334a;
        z-index: 10;
        line-height: 1;
        display:block;
    }

    /* Hide arrow on last card */
    .beforeArrow:last-child::after {
        display: none;
    }

}