.flex { display: flex; align-items: center; justify-content: space-between; gap: 100px; }
.flex > * { flex: calc(50% - 50px); display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; gap: 40px; }
.flex.wrap { flex-wrap: wrap; }
.flex img { max-width: 100%; }
.highlight { position: relative; z-index: 1; display: inline-block; }
.highlight:before { content: ""; position: absolute; top: 0; left: 0; width: calc(100% + 16px); height: calc(100% - 16px); background: var(--blue); z-index: -1; }
.image img { max-width: 100%; }

section { padding: 80px 0; position: relative; }
h1 { font-size: 64px; font-weight: 700; }
h2 { font-size: 64px; font-weight: 700; }
h3 { font-size: 32px; font-weight: 400; color: var(--gray); }
h4 { font-size: 28px; }
h5 { font-size: 24px; }
p { font-size: 18px;  line-height: 180%; }

ul.list { list-style-type: none; margin: 0; padding: 0; }
ul.list li { font-size: 20px; padding-left: 40px; color: var(--gray); position: relative; }
ul.list li:not(:last-child) { margin: 0 0 40px; }
ul.list li::before { content: '■'; color: var(--blue); transform: rotate(45deg); display: inline-block; position: absolute; left: 6px; top: 0; }

a.button { font-size: 18px; padding: 12px 32px; border-radius: 10px; display: inline-block; transition: 0.2s; font-weight: 500; }
a.button:hover { text-decoration: none; }
a.button.blue { background: var(--blue); color: white; }
a.button.blue:hover { background: #2863e9; }
a.button.orange { background: var(--orange); color: black; }
a.button.orange:hover { background: #ffa200; }

#hero { color: black; padding-top: 200px; }
#hero h1 .highlight:before { top: 16px; left: 14px; }
#hero h4 { display: inline-block; font-weight: 400; text-align: left; }
#hero h4.highlight:before { top: 6px; left: 1px; height: calc(100% + 16px); }
#hero .image { text-align: right; }
#hero .counters { font-size: 36px; font-weight: 700; }
#hero .counters span { color: var(--blue); font-weight: 900; }

#highlights { background: white; }
#highlights .contents ul { display: inline-block; text-align: left; }

#mentionbot h2 span.highlight:before { top: 16px; left: 0px; }
#mentionbot .flex { margin: 80px 0 20px; gap: 20px; align-items: stretch; }
#mentionbot .flex > div { padding: 60px 40px; border-radius: 10px; }
#mentionbot .flex > div:nth-child(1) { background: white; }
#mentionbot .flex > div:nth-child(2) { background: var(--gradient); }
#mentionbot .flex > div:nth-child(1) h3 { color: var(--red); font-weight: 600; }
#mentionbot .flex > div:nth-child(2) h3 { color: var(--green); font-weight: 600; }
#mentionbot .flex > div:nth-child(1) li { color: var(--gray); }
#mentionbot .flex > div:nth-child(2) li { color: white; }
#mentionbot ul { font-size: 23px; list-style-type: none; margin: 0; padding: 0; } 
#mentionbot li { padding: 24px 0; }
#path { background: var(--gradient); color: white; }

#packages h3 { margin: 40px 0; max-width: 70%; }
#packages .wrapper { display: flex; align-items: center; justify-content: flex-start; gap: 20px; }
#packages .wrapper > div { flex: 1; background: white; border-radius: 10px; text-align: center; padding: 60px 10px 30px; display: flex; align-items: center; justify-content: center; flex-direction: column; gap: 10px; transition: 0.3s; }
#packages .wrapper > div:hover { transform: translateY(-10px); box-shadow: 0 0 20px rgba(0,0,0,0.06); }
#packages .wrapper .popular { border: 2px solid var(--blue); position: relative; }
#packages .wrapper .popular .title { position: absolute; top: -17px; left: 50%; transform: translateX(-50%); background: var(--blue); color: white; height: 34px; line-height: 34px; padding: 0px 26px; border-radius: 50px; white-space: nowrap; }
#packages .wrapper img { margin-bottom: 16px; }
#packages .wrapper p { color: var(--gray); margin: auto; }
#packages .wrapper h5 { font-weight: 700; }
#packages .wrapper ul.list li { font-size: 16px; text-align: left; margin: 20px auto; padding-left: 26px; }
#packages .wrapper ul.list li.disabled { opacity: 0.4; filter: grayscale(100%); }
#packages .wrapper .price { font-size: 24px; font-weight: 700; color: var(--blue); }

#testimonials { background: white; }
#testimonials .wrapper { padding: 40px 0 20px; }
#testimonials .box { width: 32vw; padding: 30px 40px; background: var(--gray_bg); border-radius: 12px; margin: auto; }

#contact { text-align: left; }
#contact .form { padding: 40px 0 20px; } 
#contact .form .flex { display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap; margin-bottom: 16px; }
#contact .form .flex div { flex: 1; }
#contact label { color: var(--gray); }
#contact input[type="text"], #contact textarea { border: 0; box-shadow: 0 0 20px rgba(0,0,0,0.05); border-radius: 12px; }
#contact textarea { resize: none; }
#contact a.button { margin: 20px auto; display: inline-block; padding: 12px 52px; }
#contact p { color: var(--gray); }

#contact > .container > .flex { align-items: flex-end; } 
#contact .image { position: relative; height: 284px; }
#contact .image img { position: absolute; bottom: 0%; left: 50%; transform: translateX(-70%); }

#path .landscape { display: flex; align-items: flex-end; justify-content: center; margin: 60px 0; padding: 0 80px; }
#path .landscape > div { flex: 1; }
#path .landscape .line { position: relative; margin-left: 32px; }
#path .landscape > div:not(:last-child) .line { border-bottom: 2px solid white; }
#path .landscape .line:before { content: ""; position: absolute; bottom: -18px; left: -32px; width: 30px; height: 30px; border: 2px solid white; border-radius: 30px; }
#path .landscape .line:after { content: ""; position: absolute; bottom: -8px; left: -22px; width: 14px; height: 14px; background: var(--green); border-radius: 14px; }
#path .landscape .box { display: flex; align-items: stretch; justify-content: flex-start; font-size: 28px; gap: 20px; position: relative; height: 200px; }
#path .landscape .top .content { padding-bottom: 60px; }
#path .landscape .bottom .content { padding-top: 60px; }
#path .landscape .number { font-weight: 700; font-size: 58px; position: relative; display: flex; align-items: center; justify-content: flex-start; flex-direction: column; width: 30px; }
#path .landscape .number .dashed { width: 2px; flex-grow: 1; background-image: repeating-linear-gradient(to bottom, white, white 8px, transparent 8px, transparent 16px); }
#path .landscape .top .number .dashed { margin: 0 0 20px 3px; }
#path .landscape .bottom .number .dashed { margin: 26px 0 0px 3px; }
#path .landscape a { margin-top: 30px; }
#path .portrait, #path a.mobile { display: none; }


.stars { display: flex; align-items: center; justify-content: flex-start; }
.stars img { width: initial !important; }

@media (max-width: 1680px) { 
h1 { font-size: 52px; }
h2 { font-size: 52px; }
}


@media (max-width: 1440px) { 
section { padding: 60px 0; }
h1 { font-size: 52px; }
h2 { font-size: 52px; }
h3 { font-size: 28px; }
h4 { font-size: 25px; }
h5 { font-size: 22px; }
p { font-size: 16px; }
a.button { font-size: 17px; }
ul.list li { font-size: 18px; padding-left: 38px; }
ul.list li:not(:last-child) { margin: 0 0 34px; }
.image img { max-width: 80%; margin: auto; }

#hero { padding-top: 100px; }
#hero .counters { font-size: 32px; }

#mentionbot .flex { margin: 50px 0 20px; }
#mentionbot .flex > div { padding: 48px 38px; }
#mentionbot ul { font-size: 21px; }
#mentionbot li { padding: 20px 0; }

#path .landscape { padding: 0px; }
#contact .image img { width: 350px; }
}

@media (max-width: 1280px) { 

#path .landscape { display: none; }
#path .portrait { display: block; padding: 20px 0; }
#path .portrait > div { display: flex; align-items: stretch; justify-content: flex-start; gap: 20px; }
#path .portrait .content { padding: 10px 0 40px; margin-top: -10px; }
#path .portrait .number { font-weight: 700; font-size: 34px; margin-top: -10px; min-width: 20px; text-align: center; } 
#path .portrait .figure { display: flex; align-items: center; justify-content: flex-start; flex-direction: column; }
#path .portrait .circle { position: relative; width: 15px; height: 15px; }
#path .portrait .circle:before { content: ""; position: absolute; top: 0px; left: 0px; width: 15px; height: 15px; border: 1px solid white; border-radius: 30px; }
#path .portrait .circle:after { content: ""; position: absolute; top: 5px; left: 5px; width: 7px; height: 7px; background: var(--green); border-radius: 14px; }
#path .portrait .line { width: 1px; flex-grow: 1; background: white; margin-left: 2px; }
#path a.mobile { display: initial; }

#testimonials .box { width: 48vw; }

}

@media (max-width: 1024px) { 
.flex { flex-direction: column; gap: 40px; }
.flex > * { gap: 20px; }
section { padding: 40px 0; }
h1 { font-size: 32px; }
h2 { font-size: 32px; }
h3 { font-size: 23px; }
h4 { font-size: 22px; }
h5 { font-size: 20px; }
p { font-size: 16px; }
ul.list li { font-size: 16px; padding-left: 32px; }
ul.list li:not(:last-child) { margin: 0 0 28px; }

#hero { padding-top: 100px; }
#hero .counters { font-size: 26px; }

#mentionbot .flex { margin: 30px 0 20px; }
#mentionbot .flex > div { padding: 30px 26px; }
#mentionbot ul { font-size: 19px; }
#mentionbot li { padding: 15px 0; }

#packages h3 { max-width: initial; margin: 20px 0; } 
#packages .wrapper { overflow-x: auto; padding: 20px 0 0; }
#packages .wrapper::-webkit-scrollbar { height: 0px !important; }
#packages .wrapper > div { min-width: 240px; }
#packages .wrapper > div:hover { transform: initial; box-shadow: 0 0 20px rgba(0,0,0,0.06); }

#testimonials .box { width: 100%; }

#contact .form .flex div { width: 100%; }

#contact > .container > .flex { align-items: center; }
#contact .image { height: initial; }
#contact .image img { position: relative; bottom: initial; left: initial; transform: initial; width: initial; }

}