/* Hero */
.hero {
    background-color: var(--color-yellow-background);
}

.hero h1 span {
    color: var(--color-orange);
}

.social-proof {
    margin: var(--space-24) 0 44px 0;
    border-radius: var(--radius-md);
    filter: drop-shadow(-4px 4px 0px rgba(0, 0, 0, 0.25));
    position: relative;
    max-width: var(--width-384);
    width: 100%;
}

.social-proof .example-image {
    max-width: var(--width-384);
    border-radius: 50px 50px 0 0;
    display: block;
    width: 100%;
}

.image-overlay {
    display: flex;
    flex-direction: column;
    margin-top: -31px;
}

.image-overlay .svg-shape {
    width: 100%;
    height: 100%;
    margin-bottom: -1px;
}

.feedbak-container {
    background-color: var(--color-light-green);
    border-radius: 0 0 50px 50px;
    max-width: var(--width-384);
    padding: 0.5rem 1rem 2rem 1rem;
    z-index: 1;
}

.feedback {
    display: flex;
    gap: var(--space-8);
}

.feedback-text {
    color: var(--color-white-text);
    font-weight: var(--font-main-medium);
}

.feedback img {
    width: 60px;
    height: 60px;
}

.feedback-verify {
    position: absolute;
    color: var(--color-white-text);
    bottom: -20px;
    left: 50%;
    transform: translateX(-50%);
    background-color: var(--color-green);
    border-radius: var(--radius-md);
    padding: 10px;
    font-weight: var(--font-main-medium);
    z-index: 1;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
}

.social-proof-quote {
    font-size: 1.25rem;
    font-weight: var(--font-main-semibold);
    color: var(--color-white-text);
    text-align: center;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    /* text-wrap: nowrap; */
    padding: var(--space-8) var(--space-24);
    background-color: rgb(0, 0, 0, 0.5);
    width: 100%;
    border-radius: 50px 50px 0 0;
}

@media (max-width: 368px) {
    .feedback {
        flex-direction: column;
        align-items: center;
    }

    .feedback-text {
        text-align: center;
    }

    .feedback-verify {
        width: fit-content;
        text-wrap: nowrap;
    }
}

/* Introduction */
.introduction-cards-container {
    display: flex;
    gap: var(--space-24);
    flex-wrap: wrap;
    justify-content: center;
}

.introduction-card {
    background-color: var(--color-yellow-background);
    border-radius: var(--radius-sm);
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    width: 180px;
    height: 180px;
    padding: var(--space-12) var(--space-4);
    box-shadow: var(--shadow-bottom-left);
    transition: var(--transition);
}

.introduction-card i {
    color: var(--color-orange);
    transition: var(--transition);
}

.introduction-card .card-title {
    font-weight: var(--font-main-medium);
    font-size: var(--font-28);
}

.introduction-card:hover {
    transform: scale(1.05);
    box-shadow: var(--shadow-bottom-left-yellow);
}
.introduction-card:hover i {
    color: var(--color-dark-orange);
}

/* How It Works */
.steps-container {
    margin-top: var(--space-24);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.step {
    text-align: center;
    max-width: var(--width-384);
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 12px 0;
}

.step .step-number {
    font-size: var(--font-36);
    font-weight: var(--font-main-medium);
    background-color: var(--color-yellow);
    width: 52px;
    height: 52px;
    border-radius: var(--radius-round);
    margin: 0 auto;
}

.step .step-title {
    font-size: var(--font-28);
    font-weight: var(--font-main-semibold);
}

.step .step-text {
    font-size: var(--font-24);
    font-weight: var(--font-main-light);
}

.step i {
    color: var(--color-light-green);
}

/* Fully Customizable Fully Yours */
.customizable-cards-container {
    max-width: var(--width-588);
    columns: 2;
    column-gap: 48px;
}

.customizable-card {
    background-color: var(--color-green-background);
    width: 240px;
    height: 240px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: space-between;
    padding: var(--space-20) var(--space-12);
    border-radius: var(--radius-sm);
    filter: drop-shadow(-4px 4px 0px rgba(0, 0, 0, 0.25));
    transition: var(--transition);
    z-index: 2;
}

.customizable-card .card-title {
    font-weight: var(--font-main-medium);
}

.customizable-card i {
    font-weight: 800;
    color: var(--color-dark-green);
    position: absolute;
    bottom: -16px;
    background-color: var(--color-green-background);
    width: 40px;
    height: 40px;
    border-radius: var(--radius-round);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: var(--transition-fast);
    z-index: 2;
}

.customizable-card:hover {
    cursor: pointer;
    filter: drop-shadow(-4px 4px 0px var(--color-light-green));
}

.customizable-card:hover i {
    color: var(--color-white-text);
    background-color: var(--color-light-green);
}

.customizable-card-info-container {
    position: relative;
    break-inside: avoid;
    /* margin-bottom: 24px; */
}

.customizable-card-info {
    text-align: center;
    background-color: var(--color-green-background);
    width: 240px;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--space-20) var(--space-12);
    border-radius: var(--radius-sm);
    filter: drop-shadow(-4px 4px 0px var(--color-light-green));
    transition: var(--transition);
    z-index: -2;
    margin-top: 4px;
    margin-bottom: 0;
    /* display: none; */
    position: relative;

    transition: max-height 0.3s ease, opacity 0.3s ease, transform 0.3s ease, margin-bottom 0.4s ease;
    max-height: 0;
    opacity: 0;
    transform: translateY(-10px);
    overflow: hidden;

}

.customizable-card.open {
    filter: drop-shadow(-4px 4px 0px var(--color-light-green));
}

.customizable-card i.open {
    color: var(--color-white-text);
    background-color: var(--color-light-green);
    transform: rotate(180deg);
}

.customizable-card i.open:hover {
    color: var(--color-white-text);
    background-color: var(--color-light-green);
}

.customizable-card-info.open {
    /* display: block; */
    max-height: 500px; /* or however much space your content needs */
    opacity: 1;
    transform: translateY(0);
    margin-bottom: 24px;
}

@media (max-width: 600px) {
   .customizable-cards-container {
    max-width: var(--width-588);
    columns: 1;
    column-gap: 48px;
    } 
}

/* What Makes This Personal */
.personal-cards-container {
    max-width: var(--width-588);
    margin: var(--space-24) 0 var(--space-48) 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
    gap: 48px;
}

.personal-card {
    text-align: center;
    width: 240px;
    height: 240px;
    background-color: var(--color-yellow-background);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-bottom-left);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: var(--space-24) var(--space-4);
    transition: var(--transition);
}

.personal-card i {
    color: var(--color-orange);
    transition: var(--transition);
}

.personal-card .personal-card-title {
    font-weight: var(--font-main-medium);
    font-size: var(--font-28);
}

.personal-card:hover {
    transform: scale(1.05);
    box-shadow: var(--shadow-bottom-left-yellow);
}

.personal-card:hover i {
    color: var(--color-dark-orange);
}

/* From Sketch to Canvas */
.paintings-steps-container {
    display: flex;
    max-width: var(--width-792);
    width: 100%;
    align-items: center;
    justify-content: space-between;
}

.painting-container {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.painting-container img {
    box-shadow: var(--shadow-bottom-left);
    width: 200px;
    transition: var(--transition);
}

.painting-container .painting-title {
    font-weight: var(--font-main-medium);
    text-align: center;
}

.paintings-steps-container i {
    color: var(--color-orange);
    transition: var(--transition);
}

.painting-container img:hover {
    transform: scale(1.05);
}

@media (max-width: 768px) {
    .paintings-steps-container {
        flex-direction: column;
        gap: 24px;
    }

    .paintings-steps-container i {
        transform: rotate(90deg);
    }
}

/* What Clients Are Saying */
.review-cards-container {
    display: flex;
    flex-direction: column;
    gap: 24px;
    margin-bottom: var(--space-24);
}

.review-card {
    --img-width: 344px;
    --img-rotation: 0deg;
    --divider-width: 64px;

    display: flex;
    flex-direction: row;
    background-color: var(--color-yellow-background);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-bottom-left);
    height: 332px;
    position: relative;
    overflow: hidden;
    width: 100%;
    max-width: var(--width-588);
    transition: var(--transition-fast);
}

/* Image with variable width and rotation */
.review-image {
  width: var(--img-width);
  height: 100%;
  overflow: hidden;
}

.review-image img {
    height: 100%;
    width: 100%;
    object-fit: cover;
    border-radius: 50px 0 0 50px;
    transition: var(--transition);
}

/* Custom polygon divider */
.review-card-divider {
    position: absolute;
    left: calc(var(--img-width) - var(--divider-width));
    top: 0;
    width: 0;
    height: 100%;
    border-right: var(--divider-width) solid transparent;
    border-top: 332px solid var(--color-yellow-background);
    transform: rotate(180deg);
    z-index: 2;
}

.review-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    gap: 24px;
    padding: var(--space-4) var(--space-24);
    margin: auto;
    transform: translateX(-12px);
}

.review-profile {
    width: 60px;
    height: 60px;
    border-radius: var(--radius-round);
    object-fit: cover;
}

.review-text {
    max-width: 180px;
}

.review-stars {
    display: flex;
    gap: 4px;
}

.review-content i {
    color: var(--color-yellow);
    font-size: var(--font-24);
    filter: drop-shadow(-1px 1px 0px rgba(0, 0, 0, 0.25));
}

.review-card.card-backwards {
    flex-direction: row-reverse;
}

.review-card.card-backwards .review-card-divider {
    left: auto;
    right: calc(var(--img-width) - var(--divider-width));
    transform: rotate(180deg) scaleX(-1);
}

.review-card.card-backwards .review-content {
    margin-left: auto;
    margin-right: auto;
    transform: translateX(12px);
}

@media (max-width: 648px) {
    .review-card, .review-card.card-backwards{
        flex-direction: column;
        height: auto;
        flex-wrap: wrap;
        max-width: var(--width-384);
    }

    .review-content, .review-card.card-backwards .review-content{
        transform: translateX(0);
        padding: var(--space-24) var(--space-8) var(--space-48) var(--space-8);
        /* flex-wrap: wrap; */
        flex-direction: row;
        justify-content: center;
        gap: 8px;
        align-items: center;
        position: relative;
    }
    
    .review-image {
        width: 100%;
    }

    .review-card-divider, .review-card.card-backwards .review-card-divider {
        display: none;
    }

    .review-text {
        /* text-align: left; */
        order: 1;
    }

    .review-profile {
        order: 2;
    }

    .review-stars {
        order: 3;
        width: 100%;
        position: absolute;
        bottom: 12px;
        left: 24px;
    }
}

@media (max-width: 312px) {
    .review-content, .review-card.card-backwards .review-content {
        flex-wrap: wrap;
    }

    .review-text  {
        text-align: center;
    }

    /* .review-stars  {
        left: 50%;
        transform: translateX(-27.5%);
    } */
}

/* Meet Sharon, the Artist Behind the Brush */
.about {
    background-color: var(--color-green-background);
    display: flex;
    flex-direction: column;
    gap: 48px;
}

.about img {
    width: 180px;
    height: 180px;
    border-radius: var(--radius-round);
}

.about p {
    text-align: center;
    max-width: var(--width-588);
}

.about-quote {
    max-width: var(--width-588);
    background-color: var(--color-light-grey);
    min-height: 64px;
    border-radius: var(--radius-round);
    display: flex;
    align-items: center;
    justify-content: flex-start; /* align text after icon */
    padding-left: 80px;           /* icon width + gap */
    padding-right: 16px;
    position: relative;
    transition: var(--transition-fast);
}

.quote-icon-wrapper {
    position: absolute;
    left: 0;
    width: 64px;
    height: 64px;
    background-color: var(--color-light-green);
    border-radius: var(--radius-round);
    display: flex;
    justify-content: center;
    align-items: center;
    transition: var(--transition-fast);
}

.about-quote small {
    font-weight: var(--font-main-medium);
    text-align: left;
    flex: 1;
    padding: 4px 0;
    transition: var(--transition-fast);
}

/* Responsive tweaks */
@media (max-width: 406px) {
    .about-quote {
        flex-direction: column;
        min-height: auto;
        padding-left: 0;
        padding-right: 0;
        text-align: center;
        border-radius: var(--radius-sm);
    }

    .quote-icon-wrapper {
        position: static;
        margin-bottom: 8px;
        width: 48px;
        height: 48px;
        width: 100%;
        border-radius: var(--radius-sm) var(--radius-sm) 0 0;
    }

    .about-quote small {
        text-align: center;
        padding: 4px 8px;
    }
}

.about-button {
    display: flex;
    align-items: center;
    gap: 8px;
    background-color: var(--color-light-green);
    box-shadow: none;
    filter: drop-shadow(0px 4px 0px rgba(0, 0, 0, 0.25));
}

.about-button i {
    transition: var(--transition);
}

.about-button:hover {
    background-color: var(--color-green);
    box-shadow: none;
    filter: drop-shadow(0px 4px 0px var(--color-light-green));
}

.about-button:hover i {
    transform: translateX(4px);
    color: var(--color-green-background);
}

/* Frequently Asked Questions */
.faq {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 24px;
}

.questions-answers-container {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 24px;
    max-width: var(--width-384);
}

.question {
    background-color: var(--color-light-grey);
    border-radius: var(--radius-sm);
    display: flex;
    justify-content: space-between;
    min-height: 80px;
    align-items: center;
    padding: 16px 24px;
    cursor: pointer;
    gap: 12px;
    box-shadow: var(--shadow-bottom-left);
    transition: var(--transition-fast);

}

.question p {
    font-weight: var(--font-main-regular);
}

.question:hover {
    box-shadow: var(--shadow-bottom-left-yellow);
}

.answer {
    max-width: var(--width-384);
    width: 100%;
    background-color: var(--color-light-grey);
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-bottom-left);
    display: flex;
    padding: 16px 24px;
    
    transition: max-height 0.3s ease, opacity 0.3s ease, transform 0.3s ease, margin-bottom 0.4s ease, border-radius 0.3s ease;
    max-height: 0;
    opacity: 0;
    transform: translateY(-10px);
    overflow: hidden;

}

.question.open {
    box-shadow: var(--shadow-bottom-left-yellow);
    border-radius: var(--radius-sm) var(--radius-sm) 0 0;
}

.question i {
    transition: var(--transition-fast);
}

/* Make icon rotate smoothly */
.rotate {
    transform: rotate(-180deg);

}

.answer.open {
    max-height: 500px; /* or however much space your content needs */
    opacity: 1;
    transform: translateY(0);
    margin-bottom: 24px;
    box-shadow: var(--shadow-bottom-left-yellow);
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}

.faq-contact-link {
    text-align: center;
    max-width: var(--width-384);
}

/* Ready to Begin? */
.contact-form-container {
    max-width: var(--width-384);
    width: 100%;
    text-align: center;
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.pr_form_input {
    width: 100%;
    background-color: var(--color-yellow-background);
    padding: 1.5rem calc(1.35rem + 2px) calc(0.75rem - 2px) calc((1.35rem + 2px) * 2.5);
    border: none;
    outline: none;
    font-family: inherit;
    border-radius: var(--radius-sm);
    color: var(--color-black-text);
    font-weight: var(--font-main-medium);
    font-size: var(--font-16);
    border: 2px solid transparent;
    box-shadow: 0 0 0 0px var(--color-yellow);
    transition: var(--transition);
}

.form-wrapper {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

.input-wrapper {
    position: relative;
}

.w-100 {
    grid-column: span 2;
}

.single-column {
    grid-column: span 2;
    justify-self: center;
    width: 100%;
}

.pr_form_input:hover {
    background-color: var(--color-yellow);
}

.input-wrapper:hover .icon {
    color: var(--color-orange);
}

.input-wrapper label {
    position: absolute;
    top: 50%;
    left: calc((1.35rem + 2px) * 2.5);
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--color-form-input-text);
    transition: 0.25s;
    font-size: var(--font-24);
    font-weight: var(--font-main-light);
    text-align-last: left;
}

.input-wrapper .icon {
    position: absolute;
    left: calc(1.35rem + 2px);
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    color: var(--color-yellow);
    font-size: var(--font-24);
    transition: var(--transition);
}

textarea.pr_form_input {
    resize: none;
    /* width: 90%; */
    min-height: 200px;
    padding: 1.5rem calc(1.35rem + 2px) calc(0.75rem - 2px) calc((1.35rem + 2px) * 2.5);
    word-wrap: break-word;
}

textarea.pr_form_input ~ label {
    top: 1.2rem;
    transform: none;
    text-align: left;
    padding-right: calc(1.35rem + 2px);
}

textarea.pr_form_input ~ .icon {
    top: 1.3em;
    transform: none;
}

.input-wrapper.focus .pr_form_input {
    background-color: var(--color-white-text);
    border: 2px solid var(--color-yellow);
    box-shadow: 0 0 0 5px var(--color-yellow-background);
}

.input-wrapper.focus label{
    color: var(--color-orange);
}

.input-wrapper.focus .icon{
    color: var(--color-orange);
}

.input-wrapper.not-empty label {
    font-size: .88rem;
    top: 0.75rem;
    transform: translateY(0);
}

.submit-button {
    border: none;
    text-wrap: wrap;
    font-family: var(--font-main);
} 

/* Phone county codes */
.iti {
    width: 100%;
}

.iti__flag-container {
    position: absolute;
    left: calc(1.35rem + 2px);
    padding-right: 8px;
    z-index: 2;
}

.iti__flag-container:hover .iti__selected-flag{
    background-color: transparent;
}

/* Highlight hovered country in the dropdown */
.iti__country:hover {
    background-color: var(--color-yellow-background) !important;
    color: var(--color-black-text) !important;
}

/* Highlight the currently active/selected country in the dropdown */
.iti__country.iti__active {
    background-color: var(--color-yellow) !important;
    color: var(--color-black-text) !important;
}

.iti__selected-flag {
    border-radius: var(--radius-sm);
    transition: var(--transition);
}

.iti__selected-flag .iti__flag {
    margin-left: 0.75rem;
}

.iti__selected-flag .iti__arrow {
    margin-right: -0.1rem;
}

/* Optional: you can set your own hover color */
.iti__selected-flag:hover{
    background-color: var(--color-yellow) !important; /* or any color you like */
}

/* input text should start after flag */
#Phone-Number {
    padding-left: calc(1.35rem + 37px); 
}

.iti__flag-container {
    direction: ltr;
}
