/*
Theme Name: Konsultan Html
Theme URI: https://html.themesawesome.com/konsultanhtml
Author: Themes Awesome
Author URI: https://www.themesawesome.com
Version: 1.0      

-----------------------------------------------------------------------------------
[Color Codes]

#Black (text) = #000000
#Orange (border,hr,text,button, hover) = #ed8204
#Dark Blue (title, text)= #1b2e63
#Gray (text)= #555555
#Dark Gray (border)= #7a7a7a
#Light Gray (background)= #f5f5f5
#Light Blue (background)= #f4f7fc

[Typography]

Headers: 54px/26px/17px/16px/14px/12px Roboto
Heading: 50px/32px/30px Roboto
paragraph: 16px Roboto
FooterNav: 14px Roboto
Input,Textarea & Option: 15px/13px Roboto,Roboto 
Links: 16px Roboto,Roboto
Icons: 30px/25px/15px Fontawesome

Notes: To change the font, install it manually with convert the download zipped font to transfonter.org

-----------------------------------------------------------------------------------
  1. CSS Reset
    1.1 Button Style / .style-1
  2. Header / .main-header
    2.1 Header Style 1(Transparant) / .main-nav
    2.2 Header Style 2(White) /.nav-white
    2.3 Header Img Block / .header-text
  3. Home Page
    3.1 Header Swiper / .header-swiper
    3.2 About / .About
    3.3 Homepage Services loop / .Services
    3.4 Homepage Appointment / .Appointment
    3.5 Homepage Team list / .Team
    3.6 Experience / .Experience
    3.7 Homepage Blog Loop / .Blog
    3.8 Homepage Testimoni / .Testimoni
    3.9 Newsletter / .Newsletter
  4. About Page
    4.1 About Us / .About-us
    4.2 Aboutpage Team list / .Teams
    4.3 Aboutpage Testimoni / .Testimoni-img-bg
    4.4 Partner / .Partner
    4.5 Aboutpage Appointment / .Appointment-bg-img 
  5. Services Page
    5.1 Services loop / .Services-list
    5.2 Service Experience / .service-experience
  6. Single Service Page
    6.1 Single Service / .single-service-wrapper
      6.1.1 Service Title / .single-title-wrapper
      6.1.2 Single Service Post / .single-service-post
      6.1.3 Single Service Sidebar / .service-sidebar
  7. Blog Page
    7.1 Blog loop / .blog-loop-wrapper
    7.2 Blog Page & Single Blog Post Sidebar / .blogPost-side-menu
  8. Single Post
    8.1 single Post Article / .blog-single
  9. Contact Page
    9.1 Information & Contact Form / .Contact-detail
    9.2 Maps / .GoogleMaps
  10. Appointment Page
    10.1 Appointment Page Services List / .appointment-services
    10.2 Appointment Page Testimoni / .appointment-testimoni
  11. Footer / .footer
    11.1 Footer Widget / .footer-widget
    11.2 Footer Copyright / .footer-bottom
-----------------------------------------------------------------------------------*/

/*-----------------------------------------------------------------------------------*/
/*  1. CSS Reset
/*-----------------------------------------------------------------------------------*/

html {
    scroll-behavior: smooth !important;
}

/* This prevents the sticky header from covering your quiz title when you arrive */
#profile-quiz {
    scroll-margin-top: 100px;
}

body {
    margin: 0;
    font-family: "Roboto";
}

body p {
    font-family: "Roboto";
    font-weight: 300;
    font-size: 16px;
    line-height: 26.5px;
}

::-moz-selection {
    background-color: #ed8204;
    color: #fff;
}

::selection {
    background-color: #ed8204;
    color: #fff;
}

.column {
    display: inline-block;
    float: left;
}

.column-1 {
    width: 100%;
}

.column-2 {
    width: 50%;
}

.column-3 {
    width: 33.33333%;
}

.column-2of3 {
    width: 66.66667%;
}

.column-4 {
    width: 25%;
}

.column-5 {
    width: 20%;
}

.column-25 {
    width: 25%;
}

.column-75 {
    width: 75%;
}

.column-40 {
    width: 40%;
}

.column-60 {
    width: 60%;
}

.column {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
    padding-right: 15px;
    padding-left: 15px;
    max-width: 100%;
}
.clearfix:before,
.clearfix:after {
    content: "";
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    zoom: 1;
}

.row {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -15px;
    margin-right: -15px;
}

.row1 {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -15px;
    margin-right: -15px;
	padding-bottom:50px;
}

a {
    text-decoration: none ;
    color: #000;
}

a:hover {
    text-decoration: none ;
}

.img-left {
    float: left;
}

.img-right {
    float: right;
}

.res-img {
    max-width: 100%;
    height: auto;
}

.text-center {
    text-align: center;
}

.text-black {
    color: #ed8204;
}

.letter-space5 {
    letter-spacing: 5px;
}

.left-hr {
    margin-left: 0px;
    width: 10%;
    height: 4px;
    background-color: #ed8204;
    border: none;
}

.flex-hr {
    margin: 0px;
    width: 30%;
    height: 3px;
    background-color: #ed8204;
    border: none;
}

.center-hr {
    width: 5%;
    height: 3px;
    background-color: #ed8204;
    border: none;
}

.text-white {
    color: #fff;
}

.text-green {
    color: #ed8204;
}

.text-blue {
    color: #1b2e63;
}

.text-gray {
    color: #555;
}

.text-light-gray {
    color: #676a6a;
}

.text-bold {
    font-weight: bold;
}

.text-italic {
    font-style: italic;
}

.bg-light-blue {
    background-color: #f4f7fc;
}

.bg-gray {
    background-color: #f8f8f8;
}

.m-a {
    margin: auto;
}

.m-0 {
    margin: 0;
}

.mt-1 {
    margin-top: 1rem;
}

.mt-2 {
    margin-top: 2rem;
}

.mb-2 {
    margin-bottom: 2rem;
}

.mr-10px {
    margin-right: 10px;
}

.pd-l-3 {
    padding-left: 3%;
}

.pd-5 {
    padding: 5%;
}

.img-zoom-wrapper {
    position: relative;
    overflow: hidden;
}

.img-zoom-wrapper img {
    display: block;
    transition: all 0.4s;
    height: auto;
    transform: scale(1);
}

.img-zoom-wrapper:hover img {
    transform: scale(1.1);
    filter: brightness(75%);
}

.img-translate-wrapper {
    position: relative;
    overflow: hidden;
}

.img-translate-wrapper img {
    display: block;
    transition: all 0.4s;
    height: auto;
    transform: scale(1.06);
}

.img-translate-wrapper:hover img {
    transform: translate3d(3%, 0, 0) scale(1.06);
    filter: brightness(75%);
}


/* 1.1 button style / .style-1 */
.button {
    font-family: "Roboto";
    border-radius: 30px;
    border: 2px solid #ed8204;
    padding: 10px 20px;
    color: #FFF;
    font-weight: 500;
    cursor: pointer;
    transition: 0.3s;
    outline: none;
}

button:hover {
    outline: none !important;
}

button:focus {
    outline: none !important;
}

.style-1 {
    background-color: rgba(0, 0, 0, 0);
    border: 2px solid #ed8204;
    padding: 10px 22px;
    outline: none;
}

.style-1:hover {
    background-color: #ed8204;
    outline: none;
}

.style-2 {
    background-color: #ffff;
    border: 3px solid #ed8204;
    color: #1b2e63;
    outline: none;
}

.style-2:hover {
    background-color: #ed8204;
    color: #ffff;
    transform: translateY(2px);
    outline: none;
}

.style-3 {
    background-color: #ed8204;
    outline: none;
}

.style-3:hover {
    background: none;
    color: #1b2e63;
    transform: translateY(10px);
    outline: none;
}

.style-4 {
    border-radius: 0;
    background-color: #ed8204;
    color: #fff;
    text-align: center;
    width: 100%;
    outline: none;
}

.style-5 {
    background-color: #ed8204;
    outline: none;
}

.style-5:hover {
    background: none;
    color: #fff;
    transform: translateY(10px);
    outline: none;
}

.style-6 {
    border: none;
    background-color: #191919;
    color: #ffffff;
    font-weight: bold;
    padding: 10px 24px;
    transition: 0.4s;
    font-size: 16px;
    outline: none;
}

.style-6:hover {
    background-color: #fff;
    color: #000;
    outline: none;
}

.style-7 {
    background-color: #191919;
    color: #fff;
    outline: none;
}

.style-7:hover {
    background-color: #ed8204;
    outline: none;
}

.style-8 {
    background-color: #ed8204;
    border: none;
    border-radius: 0;
    color: #fff;
}

.style-8:hover {
    background-color: #fff;
    color: #000;
}

.style-9 {
    background-color: #ed8204;
    border: none;
    border-radius: 0;
    color: #fff;
}

.style-10 {
    background-color: #ffff;
    color: #1b2e63;
    outline: none;
}

.style-10:hover {
    background-color: #ed8204;
    color: #ffff;
    outline: none;
}

.style-11 {
    background-color: #fff;
    font-family: "Roboto";
    font-size: 15px;
    font-weight: 700;
    color: #000;
    padding: 10px 24px;
    border: 3px solid #ed8204;
    outline: none;
}

.style-11:hover {
    background-color: #ed8204;
    color: #fff;
}

.style-pagination {
    border-radius: 0;
    background-color: #ffff;
    padding: 7px 19px;
    color: #ed8204;
    outline: none;
    text-transform: uppercase;
    font-weight: normal;
}

.style-pagination:hover {
    background-color: #ed8204;
    color: #fff;
}

.current {
    background-color: #ed8204;
    color: #fff;
}
/* end button style */
/*-----------------------------------------------------------------------------------*/
/*  2. Header / .main-header
/*-----------------------------------------------------------------------------------*/
/* 2.1 Header Style 1(Transparant) / .main-nav */

.main-nav {
    position: absolute;
    padding: 10px 25px 10px 25px;
    z-index: 10;
    right: 0;
    left: 0;
    background-color: rgb(255 255 255 / 90%);
}

.main-nav .container {
    display: flex;
    align-items: center; /* Vertically centers everything */
    justify-content: space-between; /* Spreads elements to the edges */
    max-width: 100% ;
    padding: 0 15px;
}

.left-nav {
    position: relative;
    z-index: 10;
    display: flex;
    width: 100%;
}

.right-nav {
    display: flex;
    width: 100%;
    justify-content: flex-end;
}

.main-nav:after {
    clear: both;
    content: "\00a0";
    display: block;
    height: 0;
    font: 0px/0 serif;
    overflow: hidden;
}

.nav-brand {
    float: left;
    padding: 10px 0 0 0;
    cursor: pointer;
}

.nav-menu {
    display: flex;
    padding: 3px 0;
}

.contact-button {
    padding: 0;
    align-items: center;
    display: flex;
}

.contact-button .style-1 {
    border: 3px solid #ed8204;
    font-size: 13px;
    font-weight: 700;
    padding: 8px 12px;
}

.menu-item {
    margin-right: 20px;

}

.menu-item-white {
    margin-right: 10%;
}

#main-menu {
    margin: 0;
    padding: 0 0 0 10px;
    display: flex;
    clear: both;
    border-bottom: 0;

}

.nav-link {
    color: #1b2e63;
    font-weight: 500;
    transition: 0.4s;
    white-space: nowrap;
    font-size: 14px;
}

.nav-link:hover {
    opacity: 0.7;
    color: #1b2e63;
}
.active {
    color: #ed8204;
}

.contact {
    margin-top: 5px;
    margin-right: 10px;
    display: flex;
    justify-content: space-between;
}

.telp-icon {
    color: #ed8204;
    font-size: 25px;
    padding: 0 10px;
}

.small-text {
    display: block;
    margin-top: 5px;
    font-family: "Roboto";
    font-style: italic;
    font-size: 12px;
}

.telp-text {
    font-family: "Roboto";
    font-size: 16px;
    color: #1b2e63;
}

/* 2.2 Header Style 2(White) /.nav-white */
.nav-white {
    position: relative;
    background-color: #fff;
    padding: 20px 0 20px 0;
}

.white-nav .style-11 {
    padding: 10px 23px;
    border: 3px solid #ed8204;
    font-weight: 700;
}

.brand-nav-white {
    margin-left: 0;
}

.menu-item-white {
    color: #000;
    margin-right: 30px;
}

.nav-link-black {
    color: #000;
    font-weight: 500;
    transition: 0.4s;
}

.nav-link-black:hover {
    color: #ed8204;
}
/* end white nav */

/* Mobile menu toggle button */

.main-menu-btn {
    position: relative;
    margin: 14px 0 10px;
    display: inline-block;
    width: 29px;
    height: 29px;
    text-indent: 29px;
    white-space: nowrap;
    overflow: hidden;
    cursor: pointer;
    -webkit-tap-highlight-color: rgb(0, 0, 0, 0);
}

/* hamburger icon */

.main-menu-btn-icon,
.main-menu-btn-icon:before,
.main-menu-btn-icon:after {
    position: absolute;
    top: 50%;
    left: 2px;
    height: 2px;
    width: 24px;
    background: #000;
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
}

.main-menu-btn-icon-gray,
.main-menu-btn-icon-gray:before,
.main-menu-btn-icon-gray:after {
    position: absolute;
    top: 50%;
    left: 2px;
    height: 2px;
    width: 24px;
    background: #bbb;
    -webkit-transition: all 0.25s;
    transition: all 0.25s;
}

.main-menu-btn-icon:before,
.main-menu-btn-icon-gray:before {
    content: "";
    top: -7px;
    left: 0;
}

.main-menu-btn-icon:after,
.main-menu-btn-icon-gray:after {
    content: "";
    top: 7px;
    left: 0;
}

/* x icon */

#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon,
#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon-gray {
    height: 0;
    background: transparent;
}

#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon:before,
#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon-gray:before {
    top: 0;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon:after,
#main-menu-state:checked ~ .main-menu-btn .main-menu-btn-icon-gray:after {
    top: 0;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

/* hide menu state checkbox (keep it visible to screen readers) */

#main-menu-state {
    position: absolute;
    width: 1px;
    height: 1px;
    margin: -1px;
    border: 0;
    padding: 0;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
}

/* hide the menu in mobile view */

#main-menu-state:not(:checked) ~ #main-menu {
    display: none;
}

#main-menu-state:checked ~ #main-menu {
    display: block;
}

@media (min-width: 780px) {
    /* hide the button in desktop view */
    .main-menu-btn {
        position: absolute;
        top: -99999px;
    }
    /* always show the menu in desktop view */
    #main-menu-state:not(:checked) ~ #main-menu {
        display: flex;
        list-style: none;
        align-items: center;
        justify-content: space-between;
        margin-left: 35px;
    }
}

/* 2.3 Header Img Block / .header-text */

.header-text.about {
    position: relative;
    background: url("About 1.png") rgba(0, 0, 0, 0.5);
    background-attachment: fixed;
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply;
    padding: 210px 0 168px;
    width: 100%;
}

.header-text.service {
    position: relative;
    background: url("Services Head.jpg") rgba(0, 0, 0, 0.5);
    background-attachment: fixed;
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply;
    padding: 203px 0 155px;
    width: 100%;
}

.header-text.team {
    position: relative;
    background: url("our_team.jpg") rgba(0, 0, 0, 0.5);
    background-attachment: fixed;
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply;
    padding: 203px 0 155px;
    width: 100%;
}

.header-text.contact-header {
    position: relative;
    background: url("Contact Us.jpg") rgba(0, 0, 0, 0.5);
    background-attachment: fixed;
    background-position: bottom center;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply;
    padding: 203px 0 254px;
    width: 100%;
    border-bottom: 4px solid #7a7a7a;
}

.header-text.faq-header {
    position: relative;
    background: url("FAQ.jpg") rgba(0, 0, 0, 0.5);
    background-attachment: fixed;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
    background-blend-mode: multiply;
    padding: 210px 0 168px; /* Matching your About page padding */
    width: 100%;
}

.header-text hr {
    margin-top: 12px;
    height: 4px;
    width: 60px;
}

.header-title {
    text-align: center;
}

.header-title p {
    font-family: "Karla", Sans-serif;
    font-size: 14px;
    letter-spacing: 5px;
    margin: 0;
}

.header-desc {
    text-align: center;
}

.header-desc h1 {
    font-size: 45px;
    font-weight: 400;
    margin: 0;
}
/* end header */

/*-----------------------------------------------------------------------------------*/
/*  3. Home Page
/*-----------------------------------------------------------------------------------*/

/* 3.1 Header Swiper / .header-swiper */
.swiper-slide {
    z-index: -10;
}

.swiper-bg {
    position: relative;
    z-index: -15;
    background: url("./images/slider-1s.jpg");
    background-size: cover;
    background-position: center center;
    filter: brightness(95%);
    height: 100vh;
    width: 100%;
}

.header-text-wrap {
    position: relative;
    top: 50%;
    transform: translateY(-50%);
}

.header-text {
    position: relative;
    padding: 0 60px 0 80px;
}

.header-shape {
    position: relative;
    width: 550px;
    left: 25px;
}

.header-swiper .header-title p {
    font-family: "Roboto";
    font-size: 26px;
    font-weight: 300;
    letter-spacing: 12px;
    text-transform: uppercase;
}

.header-swiper .header-desc p {
    font-family: "Roboto";
    font-size: 17px;
    line-height: 25px;
}

.header-swiper .header-desc a {
    color: #fff;
}

.header-swiper .header-button {
    position: absolute;
    bottom: 8%;
    left: 13%;
}

.header-swiper .swiper-container-horizontal > .swiper-pagination-bullets {
    display: block;
    border-radius: 20px;
    border: 3px solid #fff;
    padding: 0 5px;
    width: 20px;
    left: 50%;
    bottom: 9%;
    transform: translate(-50%, -9%);
}

.swiper-pagination span {
    background-color: #fff;
}

.header-swiper .swiper-button-next {
    background-color: #000;
    opacity: 0.5;
    color: rgb(233, 182, 182);
    height: 11%;
    width: 1.5%;
    top: 46.5%;
    right: 0;
}

.header-swiper .swiper-button-next::after {
    font-size: 15px;
}

.header-swiper .swiper-button-prev {
    background-color: #000;
    opacity: 0.5;
    color: #fff;
    height: 11%;
    width: 1.5%;
    top: 46.5%;
    left: 0;
}

.header-swiper .swiper-button-prev::after {
    font-size: 15px;
}

.header-swiper .header-title {
    position: absolute;
    top: 9%;
    left: 14%;
}

.header-swiper .header-sub-title {
    position: absolute;
    top: 17px;
    left: -63px;
    width: 100%;
    z-index: 10;
    font-size: 54px;
    line-height: 100px;
}

.header-swiper .header-desc {
    position: absolute;
    bottom: 19%;
    left: 13%;
    max-width: 480px;
    text-align: left;
}

.header-swiper .learn-more {
    margin-top: 10px;
    font-family: "Roboto";
    font-size: 14px;
    font-weight: 500;
    -webkit-animation: learn-more-animation 3s ease infinite alternate;
}

@keyframes learn-more-animation {
    0%,
    100% {
        transform: translate(0, 0);
    }

    50% {
        transform: translate(5px, 0);
    }

    80% {
        transform: translate(-5px, 0);
    }
}

/* 3.2 About / .About*/

.About {
    padding: 100px 0px 110px 0px;
}

.about-section-title h3 {
    font-size: 34px;
    color: #1b2e63; /* Navy Blue */
    line-height: 1.2;
    margin-bottom: 18px;
    max-width: 400px;
}

.about-section-title hr {
    height: 4px;
}


.about-button a {
    padding: 10px 25px;
}

.sub-title {
    font-family: "Roboto";
    font-style: italic;
    font-size: 16px;
    margin-bottom: 0;
    line-height: 45px;
    color: #1b2e63;
    font-weight: 400;
}

.gallery-section {
    padding: 25px 4px 0 0;
}

.gallery {
    position: relative;
    display: flex;
    justify-content: space-between;
}

.column-2.gallery-section .gallery {
    height: 100%;
    align-items: flex-end;
}

.column-2.gallery-section .gallery img {
    height: 317px;
    object-fit: cover;
}

.img-gallery {
    position: relative;
    margin-right: 15px;
}

.on-hover-component {
    overflow: hidden;
    background-color: rgba(0, 0, 0, 0.46);
    position: absolute;
    bottom: 0;
    width: 100%;
    height: 100%;
    text-align: center;
    -webkit-transform: scale(0);
    -ms-transform: scale(0);
    transform: scale(0);
    transition: 0.4s ease-in-out;
}

.on-hover-component i {
    position: absolute;
    left: 50%;
    top: 50%;
    color: #ffff;
    font-size: 30px;
    transform: translate(-50%, -50%);
}

.gallery-image {
    width: 100%;
    display: block;
}

.img-gallery:hover .on-hover-component {
    opacity: 90%;
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
}

.images {
    display: block;
    margin-right: auto;
    margin-top: -5px;
    height: 305px;
    max-width: 100%;
}

.about-text {
    padding: 8% 0 0 0;
}

.about-text p {
    padding-right: 15px;
}

.about-button {
    display: flex;
    justify-content: flex-end;
    margin-top: 10px;
    margin-bottom: 20px;
}

/* 3.3 Homepage Services loop / .Services */

.Services {
    background-color: #f4f7fc;
    padding: 80px 0 120px;
}

.services-title {
    padding-right: 15px;
}

.services-title h3 {
    font-size: 34px;
    color: #1b2e63; /* Navy Blue */
    line-height: 1.2;
    margin-bottom: 18px;
    max-width: 400px;
}

.services-title p {
    font-size: 16px; /* Fixed typo from 'pfont-size' */
    line-height: 26px;
    color: #555555;
    margin-bottom: 30px;
}

.service-button {
    transition: 0.4s;
}

.service-button:hover {
    transform: translateY(10px);
}

.service-card-loop {
    display: flex;
    flex-wrap: wrap;
    width: 61%;
    padding: 10px 0;
}

.service-card-wrapper {
    display: flex;
    margin-bottom: 10px;
}

.services-card {
    display: flex;
    height: 292px;
    width: 50%;
    text-align: left;
    background-color: #fff;
    border-radius: 10px;
    transition: 0.4s;
    box-shadow: 0px 5px 5px 5px rgba(64, 64, 64, 0.05);
    margin-top: 15px;
    margin-right: 25px;
    overflow: hidden; /* Ensures images don't bleed out of rounded corners */
}

.services-card:hover {
    box-shadow: 0px 8px 15px rgba(0, 0, 0, 0.1); /* Adds a slight lift on hover */
    transform: translateY(-5px);
}

/* Fixed Image Centering */
.service-images {
    display: flex;
    align-items: center;
    justify-content: center;

}

.services-card-body .card-title {
    cursor: unset;
    line-height: 1.4;
    margin-bottom: 5px;
    color: #1b2e63; /* Updated to match Navy Blue */
    font-weight: 600;
}

.service-card-desc {
    margin-top: 0;
    font-size: 14px;
    line-height: 22px;
    font-weight: 300;
    color: #777;
}
/* 3.4 Homepage Appointment / .Appointment */

.Appointment {
    position: relative;
    background-color: #1b2e63;
    border: 1px solid #1b2e63;
    padding: 90px 0 0px;
}

.Appointment::before {
    border-bottom: 41px solid #1b2e63;
    border-left: 25vw solid transparent;
    border-right: 73vw solid transparent;
    width: 0;
    height: 0;
    content: "";
    overflow: hidden;
    position: absolute;
    bottom: 100%;
}

.Appointment .desc-wrap {
    padding-right: 26px;
}

.appointment-body h2 {
    color: #fff;
    margin: 0;
}

.appointment-title h3 {
    font-size: 32px;
    color: #FFF;
    line-height: 1.2;
    margin-bottom: 18px;
    max-width: 400px;
}

.appointment-title hr {
    width: 50%;
}

.left-hr.mobile-hide {
    display: block;
}

.Appointment .main-office {
    padding-left: 50px;
    padding-right: 0;
}

.main-office h2,
.branc-office h2 {
    font-size: 20px;
    line-height: 23px;
}

.appoitnment-form{
    display:flex;
    align-items:center;
    gap:30px;
}

.appoitnment-form .column-1,
.appoitnment-form .column-2{
    width:48%;
}

.appoitnment-form img{
    max-width:100%;
    height:auto;
}

.Appointment .appointment-telp {
    color: #aaa;
    line-height: 20px;
    margin-top: 10px;
}

.main-office p,
.branc-office p {
    margin: 0;
}

.Appointment .branc-office {
    padding-left: 0;
}

.left-hr.mobile {
    display: none;
}

.appoitnment-form {
    margin-top: 5px;
}

.left-form {
    padding-left: 18px;
    padding-right: 23px;
}

.right-form {
    padding-left: 0;
    padding-right: 42px;
}

.input-field {
    display: flex;
    justify-content: space-between;
    margin-top: 21px;
}

.form-input {
    font-family: "Roboto";
    outline: none;
    background: none;
    color: #fff;
    padding: 10px;
    border: 1px solid #eaeaea;
    width: 100%;
}

.form-input::placeholder {
    color: #fff;
}

.form-input:hover {
    background-color: rgba(66, 66, 66, 0.5);
    border: 1px solid #ed8204;
}

.form-input:focus {
    outline: none;
    background-color: rgba(66, 66, 66, 0.5);
    border: 1px solid #ed8204;
}

.form-textarea {
    font-family: "Roboto";
    outline: none;
    background: none;
    color: #fff;
    padding: 10px;
    border: 1px solid #eaeaea;
    width: 100%;
}

.form-textarea::placeholder {
    color: #fff;
}

.form-textarea:hover {
    background-color: rgba(66, 66, 66, 0.5);
    border: 1px solid #ed8204;
}

.form-textarea:focus {
    background-color: rgba(66, 66, 66, 0.5);
    border: 1px solid #ed8204;
}

.form-select {
    font-family: "Roboto";
    outline: none;
    background: none;
    color: #fff;
    padding: 10px;
    border: 1px solid #aaa;
    width: 100%;
}

option {
    background-color: #1b1b1b;
}

.form-select:hover {
    border: 1px solid #ed8204;
}

.form-select:focus {
    border: 1px solid #ed8204;
}


.map-wrap {
    position: relative;
    padding: 0;
}

.gMaps {
    position: absolute;
    z-index: 10;
    width: 432px;
    height: 100%;
    bottom: 205px;
    right: 20px;
}

.gMaps #gmap_canvas {
    width: 100%;
    height: 700px;
}

/* 3.5 Homepage Team list / .Team */
.Team {
    margin-top: 0px;
    padding: 180px 0 94px;
    background-color: #f9f9f9;
}

.team-section-desc {
    width: 27%;
}

.team-title {
    margin: auto;
    margin-top: 80px;
}

.team-title p {
    margin-top: 24px;
    margin-bottom: 0;
    letter-spacing: 5px;
    text-transform: uppercase;
}

.team-title h3 {
    font-size: 32px;
    margin: 0;
    line-height: 60px;
}

.team-title hr {
    width: 15%;
}

.team-body {
    margin-top: 28px;
}

.team-body a {
    color: #1b2e63;
    font-weight: 600;
    border-bottom: 1px solid #1b2e63;
    transition: 0.4s;
}

.team-body a:hover {
    color: #ed8204;
}

.team-list {
    width: 70%;
    padding-left: 10px;
    padding-right: 15px;
}

.team-wrapper {
    padding-left: 10px;
    padding-right: 0;
}

.team-img-wrapper {
    display: inline-block;
}

.team-img {
    position: relative;
    overflow: hidden;
    display: block;
}

.team-img .res-img {
    display: block;
    transition: all 0.4s;
    transform: scale(1);
}

.team-img:hover .res-img {
    transform: scale(1.1);
}

.overlay {
    position: absolute;
    bottom: 0;
    width: -webkit-fill-available;
    height: -webkit-fill-available;
    padding: 15px;
    background-color: #ed8204;
    opacity: 0;
    transition: 0.4s ease-in;
}

.team-img:hover .overlay {
    opacity: 90%;
}

.overlay-body p {
    line-height: 20px;
}

.overlay-icon {
    position: absolute;
    display: flex;
    bottom: 10%;
    left: 20px;
}

.icon {
    background-color: #fff;
    color: #000;
    margin-left: 7px;
    font-size: 15px;
    border-radius: 50%;
    width: 35px;
    height: 35px;
    text-align: center;
    line-height: 37px;
    transition: 0.3s;
    cursor: pointer;
}

.icon:hover {
    background-color: #000;
    color: #fff;
}

.team-desc {
    margin-top: 1rem;
}

.team-name {
    font-family: "Roboto";
    color: #3a3a3a;
    font-weight: 600;
    font-size: 20px;
    margin: 0;
}

.team-job {
    font-size: 15px;
    margin: 0;
}

/* 3.6 Experience / .Experience */
.Experience {
    position: relative;
    background: url("Appointment.png");
    height: auto;
    background-attachment: fixed;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.Experience::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background: #101c3f;
    opacity: 0.9;
    z-index: 1;
}

.Experience .container {
    padding: 100px 0;
    position: relative;
    z-index: 2;
}

.experience-body {
    color: #bababa;
    line-height: 1.4;
    text-align: center;
}

.experience-body h3 {
    font-size: 40px;
    line-height: 50px;
    margin: 0;
}

.experience-body p {
    font-size: 18px;
}

.
{
    margin-top: 35px;
    padding: 15px 25px;
    transition: 0.4s;
}

.experience-button:hover {
    transform: translateY(5px);
}

/* 3.7 Homepage Blog Loop / .Blog  */
.Blog {
    padding: 93px 0 100px;
}

.blog-title-wrap {
    width: 70%;
    padding-right: 15px;
    margin: 0 auto;
}

.blog-title {
    font-weight: 300;
    color: #000;
    cursor: pointer;
}

.title-text {
    text-transform: uppercase;
    margin: 0;
}

.blog-title h3 {
    font-size: 32px;
    margin: 0;
    line-height: 63px;
}

/* Reduce gap between description & FAQ list */
.blog-sub-desc {
    margin-bottom: 28px; /* was visually too large */
}

.blog-button{
    float: inline-end;
}
.Blog .column{
    width: 100%;
}

/* Align FAQ questions with description text */
.home-faq .faq-item {
    padding-left: 0;
    margin-bottom: 10px;
}
/* FIX excessive gap above FAQs on homepage */

.home-faq .faq-question {
    padding-left: 0;
}

/* Keep + icon aligned without shifting text */
.home-faq .faq-question::after {
    right: 2px;
}
/* Reduce space above "Frequently Asked Questions" */
.home-faq h3 {
    margin-top: 12px;
    margin-bottom: 18px;
}

/* FAQ Wrapper */
.faq-wrapper {
    padding: 40px 0;
}

/* Section Headings (Students / Parents) */
.faq-wrapper h2 {
    font-size: 34px;
    font-weight: 600;
    letter-spacing: -0.3px;
}

.faq-wrapper h3 {
    font-size: 20px;
    font-weight: 600;
    letter-spacing: -0.2px;
    color: #1b2e63;
    margin-top: 48px;
    margin-bottom: 22px;
}

/* Individual FAQ Item */
.faq-item {
    margin-bottom: 14px;
    border-bottom: 1px solid #e5e7eb;
    padding-bottom: 10px;
}

/* Question Button */
.faq-question {
    width: 100%;
    background: none;
    border: none;
    padding: 12px 25px 0 0;
    text-align: left;
    cursor: pointer;
    font-size: 17px;
    font-weight: 500;
    letter-spacing: -0.1px;
    line-height: 1.4;
    color: #1f2937;
    position: relative;
}

/* Plus / Minus indicator */
.faq-question::after {
    content: "+";
    position: absolute;
    right: 0;
    font-size: 22px;
    font-weight: 400;
    color: #f59e0b;
    transition: transform 0.35s ease;
}

/* Expanded state */
.faq-item.active .faq-question::after {
    transform: rotate(45deg);
}

/* Answer */
.faq-answer {
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    padding-top: 0;
    padding-bottom: 0;
    transition:
        max-height 0.55s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.35s ease,
        padding 0.4s ease;
}

.faq-answer p {
    margin: 0;
    color: #4b5563;
    ;
    line-height: 1.75;
    font-size: 15px;
}

/* Show answer */
.faq-item.active .faq-answer {
    max-height: 1000px; /* safely above tallest answer */
    opacity: 1;
    padding-top: 10px;
    padding-bottom: 6px;
}
/* 3.8 Homepage Testimoni / .Testimoni */
.Testimoni {
    background-color: #f5f5f5;
    padding: 83px 0 89px;
}

.testimoni-title {
    line-height: 33px;
    margin-bottom: 50px;
    padding: 0 15px;
}

.testimoni-title p {
    margin: 0;
    text-transform: uppercase;
    font-size: 16px;
}

.testimoni-title h3 {
    font-size: 32px;
    margin: 0;
}

.testimoni-title hr {
    width: 25%;
    margin-top: 22px;
}

.slider-wrap {
    padding: 0 15px;
}

.testimoni-wrapper .client-image {
    width: 191px;
}

.testimoni-quote-wrapper {
    width: 100%;
}

.testimoni-quote {
    display: flex;
}

.dot-img {
    background: none
}

.testimoni-icon {
    text-align: center;
    width: 100%;
    padding: 13% 0 0 0;
}

.testimoni-img-wrapper {
    display: block; /* Changed from flex to allow simple block positioning */
    width: 150px;   /* Set a consistent width for the portrait */
    height: auto;
    margin-bottom: 15px;
    overflow: hidden;
    border-radius: 8px; /* Optional: adds a professional rounded corner */
}

.testimoni-img {
    width: 100% ;
    height: 150px ; /* Set a fixed height to keep portraits uniform */
    object-fit: cover ; /* This is the key: it prevents stretching */
    display: block ;
}

.client-testimoni-text {
    padding-left: 27px;
    padding-right: 30px;
}

.testimoni-text p {
    font-style: italic;
    font-size: 24px;
    line-height: 37px;
    margin-top: 0;
}

.client-name {
    color: #ed8204;
    font-weight: bold;
    font-size: 20px;
    margin: 0;
}

.client-job {
    font-style: italic;
    font-weight: 300;
    margin: 0;
}

.testimoni-wrapper .owl-carousel button.owl-dot {
    background-color: #ed8204;
    border-radius: 50%;
    width: 10px;
    height: 10px;
    opacity: 0.5;
}

.owl-dots {
    position: relative;
    display: flex;
    justify-content: space-evenly;
    width: 5%;
    left: -20px;
    margin: auto;
    margin-top: 56px;
}

.owl-carousel button.owl-dot.active {
    opacity: 1;
}

/* 3.9 Newsletter / .Newsletter */

.Newsletter {
    position: relative;
    background: url("./images/newsletter.png");
    background-size: cover;
    background-position: center center;
    padding: 26px 0;
}

.newsletter-title {
    text-align: left;
    color: #fff;
}

.newsletter-title h3 {
    font-size: 30px;
    font-weight: bold;
    line-height: 37px;
    margin: 0;
}

.newsletter-title p {
    margin: 0;
}

.newsletter-form {
    margin-top: 7px;
    display: flex;
}

.newsletter-form form {
    display: inline-block;
    width: 68%;
}

.newsletter-input {
    font-family: "Roboto";
    color: #000;
    outline: none;
    background-color: #fff;
    border: none;
    padding: 13px 27px;
    border-radius: 25px;
    font-size: 15px;
    width: 100%;
    box-sizing: border-box;
}

.Newsletter button {
    margin-left: auto;
}

.newsletter-form-input {
    padding-right: 20px;
}

/*-----------------------------------------------------------------------------------*/
/*  4. About Page
/*-----------------------------------------------------------------------------------*/

/* 4.1 About Us / .About-us  */
.About-us {
    padding: 100px 0 65px;
}

.about-img-wrapper {
    width: 53%;
}

.about-us {
    width: 40%;
    margin-left: 35px;
    padding: 15px 0;
}

.about-title {
    margin-bottom: 29px;
}

.about-title h3 {
    font-weight: bold;
    font-size: 32px;
    line-height: 30px;
    margin: 0;
}

.about-body p {
    line-height: 25px;
}

.about-name {
    padding: 13px 10px;
}

.ceo-name {
    font-family: "Roboto";
    font-size: 15px;
    font-weight: 300;
    margin: 0;
    width: 40%;
    line-height: 48px;
}

.relatedPost-wrapper {
    margin-top: -15px;
}

.signature-img {
    width: 115px;
    height: auto;
}

/* 4.2 Aboutpage team list / .Teams */

.Teams {
    padding: 90px 0 90px;
}

.Teams .team-title {
    margin-top: 0;
}

.team-about .team-title p {
    margin-top: 0;
}

.team-about .team-title h3 {
    line-height: 25px;
    margin-bottom: 35px;
}

.Teams hr {
    width: 35%;
}

.team-about .team-list {
    width: 100%;
}

.about-team-wrapper {
    margin-top: 38px;
    padding-left: 10px;
    padding-right: 10px;
}

.team-about .team-desc {
    margin-top: 7px;
}

/* 4.3 Aboutpage testimoni / .Testimoni-img-bg */

.Testimoni-img-bg {
    height: auto;
    background: url("Testimonials BG.jpg") rgba(0, 0, 0, 0.7);
    background-size: cover;
    background-blend-mode: multiply;
    background-position: center center;
    padding: 113px 0px;
}

.Testimoni-img-bg .testimoni-title {
    margin: auto;
    line-height: 27px;
    margin-bottom: 40px;
}

.Testimoni-img-bg .testimoni-title p {
    line-height: 21px;
}

.Testimoni-img-bg .testimoni-title h3 {
    line-height: 57px;
}

.Testimoni-img-bg .testimoni-about {
    margin-top: 0;
}

.Testimoni-img-bg .owl-dots {
    margin-top: 97px;
}

/* 4.4 Partner / .Partner */

.Partner {
    padding: 80px 0 63px 0;
}

.partner-wrapper {
    display: flex;
    padding: 0 15px;
}

.partner-body {
    width: 30%;
}

.partner-text {
    text-align: left;
    margin-top: 33%;
    padding-right: 15px;
}

.partner-title {
    margin-bottom: 15px;
}

.partner-title p {
    margin: 0;
}

.partner-text h3 {
    font-size: 32px;
    margin-top: 0;
    margin-bottom: 25px;
    line-height: 29px;
}

.partner-text hr {
    width: 15%;
}

.partner-list {
    display: flex;
    justify-content: center;
}

.logo-wrapper {
    margin-bottom: 10px;
    margin-left: 15px;
    margin-right: 5px;
}

/* 4.5 Aboutpage Appointment / .Appointment-bg-img */
.Appointment-bg-img {
    background: url("images/hero-image.png");
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center center;
    position: relative;
}

.Appointment-bg-img::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    background: #1b1b1b;
    opacity: 0.9;
    top: 0;
    left: 0;
    z-index: 1;
}

.Appointment-bg-img .container {
    padding: 80px 0;
    position: relative;
    z-index: 2;
}

.appointment-text {
    line-height: 65px;
}

.appointment-text h2 {
    font-size: 50px;
    line-height: 84px;
    margin: 0;
}

.appointment-text h3 {
    font-size: 35px;
    line-height: 32px;
    margin: 0;
    font-weight: normal;
}

.appointment-button {
    padding: 37px;
    transition: 0.4s;
}

.appointment-button:hover {
    transform: translateY(10px);
}

/*-----------------------------------------------------------------------------------*/
/*  5. Services Page
/*-----------------------------------------------------------------------------------*/

/* 5.1 Services Loop / .Services-list */

.Services-list {
    padding: 90px 0px 73px 0;
    background-color: #f6f6f7;
}

.Services-list .row {
    position: relative;
    margin-left: 15px;
    margin-right: 15px;
}

.service-card-tablet {
    margin-bottom: 20px;
    padding: 0 10px;
    
}

.service-cards {
    border: 1px solid #efefef;
    border-radius: 0;
    transition: 0.4s;
    margin: 0;
    height: 501px;
}

.service-cards:hover {
    box-shadow: 0px 5px 5px 5px rgba(64, 64, 64, 6%);
}

.service-cards .service-card-img {
    height: auto;
}

.service-card-body {
    padding: 20px;
}

.serviceman-name {
    display: flex;
}

.serviceman-name p {
    font-size: 15px;
    margin-bottom: 10px;
}

.s-name {
    color: #ed8204;
    cursor: pointer;
    transition: 0.4s;
}

.s-name:hover {
    color: #555;
}

.service-card-title h3 {
    font-size: 20px;
    line-height: 31px;
    margin-top: 10px;
    transition: 0.4s;
    cursor: pointer;
}

.service-card-title h3:hover {
    color: #ed8204;
}

.service-card-button {
    padding-top: 15px;
}

.service-card-button .style-8 {
    font-size: 14px;
    padding: 8px 13px;
}

/* 5.2 Service Experience / .service-experience */

.service-experience .container {
    padding: 100px 0 106px;
}

.service-experience .experience-button {
    margin-top: 19px;
}

.service-experience .experience-body p {
    font-size: 16px;
}

/*-----------------------------------------------------------------------------------*/
/*  7. Blog Page
/*-----------------------------------------------------------------------------------*/
/* 7.1 Blog Loop / .blog-loop-wrapper */
.Blogs {
    padding: 60px 0 105px;
}

.Blogs .column.column-75 {
    padding-right: 30px;
}

.Blogs .row.blog-loop-wrapper {
    margin-left: -20px;
    margin-right: -20px;
}

.card-blog-loop {
    margin-bottom: 40px;
    padding-left: 20px;
    padding-right: 20px;
}

.blog-card .blog-card-img {
    width: 100%;
    height: auto;
}

.blog-card-img {
    width: 100%;
    transition: 0.4s;
}

.blog-card-img:hover {
    filter: brightness(70%);
}

.blog-card-body {
    position: relative;
    padding: 45px;
}

.blog-card-title {
    font-weight: bold;
    font-size: 27px;
    line-height: 34px;
    margin-top: 0;
    margin-bottom: 21px;
    cursor: pointer;
    transition: 0.4s;
    color: #000;
}

.blog-card-title:hover {
    color: #ed8204;
    text-decoration: none;
}

.blog-card-body .card-desc {
    font-size: 16px;
    color: #333;
}

.pagination-row {
    position: absolute;
    z-index: 10;
    top: 100%;
}

.pagination {
    display: flex;
    justify-content: flex-start;
    height: auto;
    padding: 5px 5px;
}

.left-border-none {
    border-left: none;
}

/* 7.2 Blog Page & Single BLog Post Sidebar / .blogpost-side-menu */
.sidebar-wrapper {
    position: static;
    display: block;
    padding-right: 20px;
}

.blogPost-side-menu {
    background-color: #fff;
}

.recent-post {
    margin-top: 47px;
}

.recent-comments {
    margin-top: 30px;
}

.user-name {
    font-weight: 600;
    font-size: 16px;
    line-height: 25px;
}

.categories {
    margin-top: 30px;
}

.side-post-img-wrapper {
    display: table-cell;
    position: relative;
    overflow: hidden;
    width: 85px;
    height: auto;
}

.side-post-img-wrapper img {
    display: block;
    height: 85px;
    max-width: 100%;
    transition: all 0.4s;
    transform: scale(1);
    object-fit: cover;
}

.side-post-img-wrapper:hover img {
    transform: scale(1.1);
    filter: brightness(75%);
}

.side-blog-desc {
    display: table-cell;
    vertical-align: top;
    padding-top: 2px;
    padding-left: 22px;
}

.side-post {
    display: block;
    width: 100%;
    padding: 15px 0;
    border-bottom: 1px solid #efefef;
}

.comment-wrapper {
    display: -webkit-inline-box;
    border-bottom: 1px solid #efefef;
}

.recent-post .sideBar-title {
    margin-bottom: 10px;
}

.side-blog {
    margin-top: 11px;
}

.side-title {
    font-family: "Roboto";
    margin: 0;
    cursor: pointer;
    line-height: 22px;
}

.side-blog .side-title {
    line-height: 35px;
}

.side-title a {
    transition: 0.4s;
}

.side-title a:hover {
    color: #ed8204;
}

.side-date {
    font-family: "Roboto";
    font-size: 11px;
    font-weight: 300;
}

.follow-us {
    margin-top: 30px;
}

.icon-wrapper {
    display: inline-block;
    margin: 10px 5px 10px 0;
    border: 1px solid #ed8204;
    border-radius: 50%;
    text-align: center;
    font-size: 17px;
    width: 40px;
    height: 40px;
    line-height: 40px;
    transition: 0.4s;
    cursor: pointer;
}

.icon-wrapper:hover {
    background-color: #ed8204;
    color: #fff;
}

.category-wrapper {
    border-top: 1px solid #efefef;
}

.category-name {
    font-size: 15px;
    line-height: 15px;
    font-weight: 500;
    cursor: pointer;
    transition: 0.4s;
}

.category-name:hover {
    color: #ed8204;
}

.sosmed-icon-wrapper {
    display: block;
}

.featured-post-img {
    max-width: 100%;
    margin-top: 23px;
}

.blog-title a {
    transition: 0.4s;
}

.blog-title a:hover {
    color: #ed8204;
}

/*-----------------------------------------------------------------------------------*/
/*  9. Contact Page
/*-----------------------------------------------------------------------------------*/
/* 9.1 Information & Contact Form / .Contact-detail */
.Contact-detail {
    position: relative;
    padding: 70px 0 90px;
}

.information-wrapper {
    padding: 0 75px 0 15px;
}

.contact-detail-title {
    padding: 10px 0 0;
}

.contact-detail-title h2 {
    font-size: 45px;
    line-height: 49px;
    color: #262626;
    margin-top: 0;
    margin-bottom: 30px;
}

.info-detail hr {
    position: relative;
}

.contact-detail-title hr {
    width: 32%;
    height: 4px;
}

.info-offset.detail-tablet-2 {
    padding-left: 30px;
}

.office-detail {
    padding: 5px 0 0;
}

.office-site {
    font-family: "Roboto";
    font-size: 20px;
    line-height: 10px;
    font-weight: 600;
    color: #262626;
}

.contact-list {
    font-size: 14px;
    font-weight: 300;
    line-height: 28px;
}

.contact-desc {
    padding: 0 15px;
}

.office-info-wrapper {
    display: flex;
    justify-content: space-around;
}

.office-site-card {
    width: 39%;
    display: flex;
    padding: 20px;
    margin-right: 20px;
}

.icon-site {
    margin-left: 15px;
    margin-right: 15px;
    margin-top: 5px;
}

.icon-site i {
    font-size: 25px;
}

.site-type {
    font-family: "Roboto";
    margin: 0;
    font-size: 18px;
    line-height: 36px;
    margin-bottom: 7px;
}

.site-text .site-address {
    margin: 0;
}

.contact-form-wrap {
    margin-top: -213px;
}

.contact-form {
    position: relative;
    bottom: 0;
    left: -77px;
    background-color: #1b2e63;
    border: 4px solid #7a7a7a;
    padding: 59px 40px 183px;
    height: 100%;
    width: 397px;
    margin-top: 0;
}

.contact-form form {
    padding: 0 37px;
}

.contact-form .style-9 {
    width: 160px;
    margin-top: 25px;
}

.Contact-detail .form-input {
    padding: 11px;
}

.Contact-detail .form-textarea {
    padding: 13px;
}

.input-spacer {
    margin-right: 30px;
}

.contact p {
    margin: 0;
}

/* 9.2 Maps / .GoogleMaps */
.GoogleMaps {
    margin-bottom: 180px;
}

.contact-map {
    height: 400px;
}

#gmap_canvas {
    border-width: 0;
    width: 100%;
    height: 580px;
}

/*-----------------------------------------------------------------------------------*/
/*  10. Appointment
/*-----------------------------------------------------------------------------------*/
/* 10.1 Appointment Page Services List / .appointment-services */
.appointment-services {
    margin-top: 0;
    padding: 30px 0 215px;
}

.services-text {
    width: 35%;
    padding: 0 15px;
}


.appointment-services .services-title p {
    color: #000000;
    margin-top: 0;
    padding: 0 30px 20px 0;
}

/* 10.2 Appointment Page Testimoni / .appointment-testimoni */
.appointment-testimoni {
    margin-top: 0;
    padding: 110px 0 117px;
}

.appointment-testimoni .testimoni-title {
    line-height: 0;
    margin-bottom: 40px;
}

.appointment-testimoni .testimoni-title h3 {
    line-height: 43px;
}

.appointment-testimoni .testimoni-title hr {
    margin-top: 38px;
}

/*-----------------------------------------------------------------------------------*/
/*  11. Footer
/*-----------------------------------------------------------------------------------*/
/* 11.1 Footer Widget / .footer-widget */
/*-----------------------------------------------------------------------------------*/
/* 11. Footer
/*-----------------------------------------------------------------------------------*/

/* 11.1 Footer Widget / .footer-widget */

.footer-widget {
    padding: 80px 0;
    background-color: #ffffff;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    max-width: 1200px;
    margin: 0 auto;
    flex-wrap: wrap;
}


.footer-widget-component {
    flex: 1;
    padding: 0 20px;
    min-width: 250px;
}

.footer-widget-component:nth-child(1) {
    flex: 1.5; /* Gives your description more room */
    padding-right: 60px;
}

.footer-widget-component:nth-child(2) {
    flex: 1;
    margin-left: auto; /* This pushes the column and the next one to the right */
    padding-left: 20px;  /* Adjust this value to push it more or less */
}

.footer-widget-component:nth-child(3) {
    flex: 1;
    padding-left: 20px;
}

.footer-logo {
    width: 100%;
    max-width: 200px;
}

.footer-text,
.footer-widget-component .footer-desc,
.footer-email {
    color: #000000;
    line-height: 28px;
}

.footer-widget-component .footer-desc {
    padding-bottom: 16px;
    margin-top: 14px;
    line-height: 24px;
}

.footer-widget-component .style-7 {
    border: 2px solid #ed8204;
    padding: 10px 25px;
    color: #000000;
    text-decoration: none;
    border-radius: 25px;
    display: inline-block;
}

.footer-title {
    font-family: "Roboto", sans-serif;
    font-size: 18px;
    font-weight: bold;
    color: #1b2e63;
    transition: 0.4s;
    margin: 0;
    line-height: 30px;
}

.footer-widget-component hr {
    width: 18%;
    height: 2px;
    background-color: #ed8204;
    border: none;
    margin: 10px 0 20px 0;
}

.footer-icon-wrapper {
    display: flex;
    list-style: none;
    padding: 0;
}

.footer-icon {
    font-size: 16px;
    margin-right: 10px;
    color: #000000;
    width: 36px;
    height: 36px;
    text-align: center;
    line-height: 37px;
    border: 1px solid #000000;
    border-radius: 50%;
    cursor: pointer;
    transition: 0.4s;
}

.footer-icon:hover {
    color: #ed8204;
    border: 1px solid #ed8204;
}


/* 11.2 Footer Copyright / .footer-bottom */

.footer-bottom {
    padding: 30px 0;
    background-color: #1b2e63;
}

.footer-copyright {
    color: #FFF;
    font-size: 16px;
}

.footer-copyright a {
    text-decoration: none;
}

.footer-copyright a:hover {
    color: #ed8204;
    text-decoration: none;
}

.footer-menu-wrapper {
    display: flex;
    justify-content: flex-end;
}

.footer-menu {
    margin-right: 10px;
}

.footer-link {
    font-family: "Roboto";
    font-size: 14px;
    color: #fff;
    text-decoration: none;
    transition: 0.4s;
}

.footer-link:hover {
    color: #ed8204;
    text-decoration: none;
}

/* Profile Evaluation Quiz */
.profile-quiz {
    max-width: 500px;
}

/* Scholar Strides Eligibility Quiz */
.eligibility-quiz {
    max-width: 520px;
}

.quiz-subtitle {
    margin-bottom: 30px;
    opacity: 0.9;
}

.quiz-step {
    display: none;
    animation: fadeUp 0.4s ease forwards;
}

.quiz-step.active {
    display: block;
}

.quiz-question {
    font-size: 18px;
    margin-bottom: 20px;
    color: #fff;
    text-align: center;
}

.quiz-options {
    display: grid;
    gap: 8px;
}

.quiz-option {
    background: rgba(255,255,255,0.05);
    border: 1px solid #ed8204;
    color: #fff;
    padding: 14px 18px;
    font-size: 14px;
    cursor: pointer;
    border-radius: 30px;
    text-align: center;
    transition: all 0.25s ease;
}

.quiz-option:hover {
    background: #ed8204;
}

.quiz-option.active {
    background: #ed8204;
    color: #fff;
    font-weight: 600;
}
.quiz-option:hover {
    background: #ed8204;
    color: #fff;
}

.quiz-form {
    display: grid;
    gap: 14px;
}

.quiz-form input,
.quiz-form select {
    width: 100% ;
    height: 55px ;
    padding: 14px 20px ;
    border-radius: 8px ;
    border: 1px solid #ed8204 ;
    font-size: 15px ;
    background-color: #ffffff ;
    color: #000000 ;
    box-sizing: border-box ;
}


.quiz-form select option {
    background-color: #ffffff !important;
    color: #000;
}

.quiz-submit {
    background-color: #ed8204 !important; /* Brand Orange */
    color: #ffffff !important; /* Forced white text as requested */
    padding: 16px 20px;
    border: none !important;
    font-weight: 700;
    cursor: pointer;
    border-radius: 50px !important; /* Attractive oval base */
    text-transform: none;
    width: 100%;
    max-width: 520px;
    display: block;
    margin: 10px auto;
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

/* Quiz Back Button (CTA style) */
/* Quiz Back Button – Small Oval CTA */
.quiz-back-pill {
    margin: 20px auto 0;   /* auto centers horizontally */
    padding: 8px 20px;
    display: block;        /* required for margin auto */
    background: #f59e0b;
    color: #ffffff;
    border: none;
    border-radius: 999px;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    width: fit-content;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.quiz-back-pill:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

.quiz-form input::placeholder {
    color: #7a7a7a ; /* Visible light grey */
    opacity: 1;
}

/* Ensure text stays dark while typing for readability */
.quiz-form input,
.quiz-form select {
    padding: 14px;
    border-radius: 6px;
    border: none;
    font-size: 14px;
    background: #ffffff ; /* Solid white background */
    color: #333333 ; /* Dark text for contrast */
}

/* Fix blending issue on hover */
.quiz-submit:hover {
    background-color: #ed8204 ;
    transform: scale(1.02); /* Subtle pop effect instead of color change */
    box-shadow: 0 4px 15px rgba(227, 105, 30, 0.4); /* Professional glow */
}

@keyframes fadeUp {
    from {
        opacity: 0;
        transform: translateY(10px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.services-card .service-images img.services-card-img {
    width: 80px !important;
    height: 80px !important;
    object-fit: cover !important;
    border-radius: 50% !important;
    border: 2px solid #ed8204;
    padding: 0 !important;
    margin: 15px !important;
}


.service-images {
    display: flex;
    align-items: center;
    justify-content: center;
}


.appointment-title {
    color: #fff;
}

.quiz-section{
background:#081a34;
padding:80px 20px;
font-family:Inter,sans-serif;
}

.quiz-container{
max-width:700px;
margin:auto;
text-align:center;
}

.quiz-title{
color:#fff;
font-size:36px;
font-weight:700;
margin-bottom:10px;
}

.quiz-subtitle{
color:#b7c0ce;
margin-bottom:40px;
}

.quiz-question{
color:#fff;
font-size:22px;
margin-bottom:30px;
}

.quiz-options{
display:flex;
flex-direction:column;
gap:18px;
}

.option{
background:#1b2c4b;
border:2px solid #ff9f1a;
color:#fff;
padding:16px;
border-radius:40px;
font-size:16px;
cursor:pointer;
transition:0.3s;
}

.option:hover{
background:#ff9f1a;
color:#000;
}

.quiz-input{
width:100%;
padding:16px;
margin-bottom:20px;
border-radius:8px;
border:none;
font-size:15px;
}

.submit-btn{
width:100%;
padding:18px;
background:#f2690d;
border:none;
color:#fff;
font-size:16px;
border-radius:40px;
cursor:pointer;
}

.quiz-step{
display:none;
}

.quiz-step.active{
display:block;
}

.button-group{
display:flex;
flex-direction:column;
align-items:center;
margin-top:20px;
}

.submit-btn{
width:300px;
padding:18px;
background:#f2690d;
border:none;
color:#fff;
font-size:18px;
border-radius:40px;
cursor:pointer;
text-align:center;
}

.back{
display:block;
margin:25px auto 0;
background:#ff9f1a;
border:none;
color:#fff;
padding:10px 25px;
border-radius:30px;
cursor:pointer;
}