div.textbox.bullet-sentence div.value:before {
  content: '• ';  /* Adds the bullet */
  display: inline; /* Keeps the bullet on the same line as the sentence */
}

div.textbox.bullet-sentence div.value:after {
  content: '\A';   /* Inserts a newline character */
  white-space: pre; /* Ensures the newline is respected */
}


.c-mybigproject {
    font-size: 1em;
}
@media (max-width: 768px) {
    .c-mybigproject {
        font-size: 0.8em;
    }
}


body, p, button, h1, h2 {
  font-family: "Geologica", sans-serif;
}

body {
height: auto !important;
}

#belowsite a {
    text-decoration: none;
}

.c-border-image {
   border-radius: 20px;
}

.c-button {
    text-decoration: none;
    display: inline-block;
    padding: 10px 20px;
    background-color: #6a84bf;
    color: white;
    border-radius: 50px;
    font-weight: 800;
    transition: 0.3s;
}

.c-download-button {
margin-bottom: 20px;
}
.c-download-button a.c-button {
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
}
.c-download-button a.c-button::after {
    content: '';
    width: 35px;
    height: 35px;
    background-color: white;
    border-radius: 50%;
    background-image: url('/cache/files/7c765d0d0a76742c7ed213164148c4e1433e4212.svg');
    background-size: 50%;
    transform: rotate(90deg);
    background-repeat: no-repeat;
    background-position: center;
}

button {
    text-decoration: none;
    display: inline-block;
    padding: 10px 20px;
    background-color: #6a84bf;
    color: white;
    border-radius: 50px;
    font-weight: 800;
    border: 0;
    transition: 0.3s;
}

.c-button:hover, button:hover {
    background-color: #26385f;
    color: white;
}

.c-title-box {
    position: relative;
}

.c-footer-container .c-title-box, #contact .c-title-box {
    margin-top: 20px;
}

#contenttop .c-title-box h1, #contentbottom .c-title-box h1, #belowsite .c-title-box h1 {
    text-align: left;
    font-size: 26px;
    font-weight: 300;
    display: flex;
    align-items: center;
    gap: 20px;
}

#belowsite .c-title-box h1 {
   color: white;
}

#contenttop #contact .c-title-box h1 {
    margin: 0;
    padding: 0;
}

/*
#contenttop .c-title-box h1::after, #contentbottom .c-title-box h1::after, #belowsite .c-title-box h1::after {
    content: '';
    height: 1px;
    display: block;
    width: 20%;
    background-color: #acacac;
}*/



div.items div.date.c-news-date {
    background-color: #6a84bf;
    display: inline-block;
    padding: 2px 6px;
    font-size: 12px;
    color: white;
    font-style: normal;
    border-radius: 20px;
    margin-bottom: 5px;
}

div.horizontalitemsnews div.item .c-news-boxy div.photos {
    height: 100%;
}

#contenttop div.horizontalitemsnews div.item .c-news-boxy div.photos img {
    width: 100%;
    object-fit: cover;
    max-height: none;
    height: 100%;
    border-radius: 20px;
}

div.horizontalitemsnews div.list div.item .c-news-boxy h3 {
   padding-top: 10px;
   padding-bottom: 10px;
}

h3 a, div.items div.list h3 a, div.items h3 a {
    color: #222;
    font-size: 18px;
    font-weight: 300;
}

div.horizontalitemsnews div.list div.item .c-news-boxy .textbox {
    line-height: 1.6em;
    padding: 10px 0;
}

div.horizontalitemsnews div.textboxy.c-news-content {
    padding-top: 15px;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 15px;
}

.slick-next, .slick-prev {
    height: 50px;
    width: 80px;
    border: 1px solid rgb(26 26 26 / 20%);
    opacity: 1;
    background-color: white;
    border-radius: 90px;
    overflow: hidden;
    transform: translateY(-50%);
}

.slick-next::after, .slick-prev::after {
    content: '';
    background-color: #6a84bf;
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 100%;
    z-index: 1;
    left: 0;
    border-radius: 90px;
    transition: .4s cubic-bezier(.165,.84,.44,1);
}

.slick-prev {
    left: 20px;
    top: 50%;
    bottom: auto;
}

.slick-next {
    right: 20px;
    left: auto;
    top: 50%;
    bottom: auto;
}

.slick-prev:before, .slick-next:before {
    background-image: url('/cache/files/40cdc840e15f74636b36af2cf7563844f3cd635b.svg');
    background-size: 13px;
    background-repeat: no-repeat;
    background-position: 33px center;
    z-index: 2;
    transition: 0.2s;
}

.slick-prev:hover:before, .slick-next:hover:before {
    background-image: url('/cache/files/c003e26bdec978cfd9c67fac37e92dc315102969.svg');
}

.slick-prev.slick-disabled, .slick-next.slick-disabled {
    display: inline-block !important;
    opacity: 1;
}

.slick-prev.slick-disabled, .slick-next.slick-disabled {
    border: 1px solid rgb(26 26 26 / 20%);
}

.slick-prev.slick-disabled:before, .slick-next.slick-disabled:before {
    opacity: 0.2;
}

.slick-prev:hover, .slick-prev:focus, .slick-next:hover, .slick-next:focus {
    color: transparent;
    outline: none;
    background-color: rgba(0, 0, 0, 0);
}

.slick-next:hover::after, .slick-prev:hover::after {
    top: 0;
}

.slick-prev.slick-disabled:hover::after, .slick-next.slick-disabled:hover::after {
    top: 100%;
}

.slick-prev.slick-disabled:hover::before, .slick-next.slick-disabled:hover::before {
    opacity: 0.2;
    background-image: url('/cache/files/40cdc840e15f74636b36af2cf7563844f3cd635b.svg');

}


/* END NEWS SECTION */
/* =================================== */

.c-main-inner {
    padding-top: 50px;
    padding-bottom: 70px;
    padding-left: 20px;
    padding-right: 20px;
    max-width: 1280px;
    margin: 0 auto;
}


.c-title-text {
    font-size: 24px;
    font-weight: 500;
}

/* =================================== */

/* FOOTER */

.c-footer-container {
    border-top: 2px solid #6a84bf;
}

.c-footer-inner {
    padding: 70px 20px 70px 20px;
    max-width: 1280px;
    margin: 0 auto;
}

.c-footer-container p, #contact p {
    margin-bottom: 0;
}

.c-footer-locations {
    border-top: 1px solid white;
    margin-top: 50px;
    padding-top: 25px;
}

.c-footer-extralinks {
    max-width: 1280px;
    margin: 0 auto;
    padding-bottom: 50px;
}

.c-footer-extralinks a {
    margin-right: 15px;
}

.c-social-follow {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 70px;
flex-wrap: wrap;
    justify-content: flex-end;
}

.c-social-title {
   color: #a5a5a5;
   color: white;
   font-size: 24px;
   font-weight: 600;
}

.c-social-box {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    width: 100%;
    justify-content: flex-end;
}

.c-social-box a {
    display: flex;
    flex-direction: row;
    align-items: center;
    width: 100%;
    gap: 10px;
    justify-content: flex-end;
}

.c-social-icon {
    border: 1px solid;
    width: 40px;
    height: 40px;
    display: inline-block;
    border-radius: 50%;
}

.c-social-text {
   font-size: 24px;
   font-weight: 600;
}

/* END FOOTER */

/* =================================== */

/* PRODUCT DETAILS DESIGN */



/* =================================== */

#contenttop div.htmlbox ul {
    padding-top: 0;
    padding-bottom: 0;
    margin: 0;
    line-height: 1.6em;
}


/* FIXED SUPPORT BUTTON */

.c-call-support-box {
    position: fixed;
    z-index: 99;
    right: -251px;
    bottom: 110px;
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    transition: 0.3s;
}

.c-call-support-box:hover {
    right: 0px;
}

.c-call-support-icon {
    background-color: #6a84bf;
    padding: 10px;
    border-radius: 10px 0px 0px 10px;
    border: 1px solid #6a84bf;
}

.c-call-support-content {
    width: 230px;
    text-align: center;
    padding: 10px;
    border: 1px solid #6a84bf;
    border-radius: 0px 0px 0px 10px;
    position: relative;
    margin-right: -1px;
    background-color: white;
}

.c-call-support-content p {
    margin-top: 10px;
}

.c-call-support-content a {
    display: block;
    color: white;
    background-color: #6a84bf;
    padding: 10px;
    border-radius: 10px;
    margin-bottom: 10px;
    text-decoration: none;
}

.path {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0px 20px 20px 20px;
}

.c-link-boxy {
    display: flex;
    gap: 10px;
    flex-direction: row;
    flex-wrap: wrap;
}

/*SCROLL TOP BUTTON*/
.scrolltopbutton {
  display: block; /* Hidden by default */
  position: fixed; /* Fixed/sticky position */
  bottom: 4vh; /* Place the button at the bottom of the page */
  right: 10px; /* Place the button 30px from the right */
  cursor: pointer; /* Add a mouse pointer on hover */
z-index: 300;
    width: 50px;
    height: 50px;
    background-color: #6a84bf;
    border: 1px solid #9cafd8;
    border-radius: 50%;
    text-align: center;
   transition: 0.3s;
}

.detail .scrolltopbutton {
    bottom: 100px;
    right: 35px;
}

.scrolltopbutton img {
    transform: rotate(-90deg);
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 15px;
    box-sizing: border-box;
}

.scrolltopbutton:hover {
  background-color: #546ea8; /* Add a dark-grey background on hover */
}



/*END OF SCROLL BUTTON*/.c-newlogo {
    background-image: url('/cache/files/e97aaaf1e7cf7946876ead3c560a6d4f690eb75b.svg');
    background-position: center;
    background-size: contain;
background-repeat: no-repeat;
}


a.mobile-header-startlink {
    background-image: url('/cache/files/e97aaaf1e7cf7946876ead3c560a6d4f690eb75b.svg');
    background-position: center;
    background-size: contain;
background-repeat: no-repeat;
width: 220px;
    transform: translate(-50%, 0%);
}

.side-nav__header {
    background-color: white;
    background-image: url('/cache/files/e97aaaf1e7cf7946876ead3c560a6d4f690eb75b.svg') !important;
    color: #333;
    background-repeat: no-repeat;
    background-position: 50% 50%;
    background-size: contain;
    margin-left: 8vh;
    margin-right: 8vh;
}


/* MENU */

.notloggedin #innertopmenu {
    max-width: 100%;
}

.notloggedin #innertopbanner {
    max-width: 100%;
    height: 50px;
}


.notloggedin #topbanner .langchooser {
    padding-top: 13px;
    padding-right: 15px;
}.c-newsletter {
padding-top: 100px;
padding-bottom: 100px;
width: 60%;
margin: auto;
}

.c-newsletter form {
    margin: auto;
}

.c-newsletter form label {
    display: block;
    margin-bottom: 20px;
    text-align: center;
    font-size: 1.4em;
    font-weight: 800;
font-family: 'Manrope', sans-serif;
}

.c-newsletter form input {
    padding: 10px;
    border: 2px solid #d3d3d3;
    border-radius: 5px;
    text-align: center;
    width: 100%;
    box-sizing: border-box;
}


.c-newsletter form input:focus-visible {
outline: none;
    box-shadow: 0px 0px 10px rgb(0 0 0 / 20%);
}

.c-newsletter form input::placeholder {
color: #d1d1d5;
font-size: 14px;
}

.c-newsletter form .submit {
margin-top: 20px;
text-align: center;
}

.c-newsletter form .submit button {
    font-size: 14px;
    font-weight: 400;
    padding: 20px 25px;
    color: white;
    background-color: #595959;
    transition: 0.3s;
    letter-spacing: 1px;
    border-radius: 3px;
    border-color: transparent;
    min-width: 170px;
}

.c-newsletter form .submit button:hover {
color: white;
background-color: #e0751b;
}

@media only screen and (max-width: 768px) {
.c-newsletter {
width: 90%;
}
}div.topmenu div.megamenu, div.megamenu {
    padding-left: 0px;
}

.column0, .column1, .column2, .column3, .column4 {
    padding-right: 2% !important;
    border-right: 1px solid #e6e6e6;
}

div.megamenucols4 {
    width: 100vw;
}

.column1, .column2, .column3, .column4, .column5 {
    padding-left: 2% !important;
}

.megafirstlevelitemmegafirstlevelitem {
    border-bottom: 1px solid #e6e6e6;
    padding-bottom: 5px;
    padding-top: 5px;
    margin-bottom: 10px;
    padding-left: 10px;
}

.acolumn .megafirstlevelitemmegafirstlevelitem:nth-last-child(1) {
    border-bottom: 0px solid #e6e6e6;
}

div.fullsize.megamenucols6 div.acolumn {
    width: 16.66%;
}

#topmenu {
    border-bottom: 2px solid black;
}

div.horizmenu.topmenu div.megamenu ul {
   display: none;
}

div.megafirstlevelitemmegafirstlevelitem h2::before {
   content: '.' !important;
   display: inline-block !important;
   font-size: 0px;
   width: 10px;
   color: #6a84bf;
   background-image: url('/cache/files/5019a45a98e51744f1116a62de62b50aca94dfae.svg') !important;
   background-size: contain;
   background-repeat: no-repeat;
   background-position: center;
   position: absolute;
   top: 1px;
   left: 0px;
}

div.topmenu div.megamenu h2, div.megafirstlevelitemmegafirstlevelitem h2 {
   font-size: 16px;
   font-weight: normal;
   color: #333;
   position: relative;
   padding-left: 15px;
}


/* FIXED MENU 6-6 */

.notloggedin div.topmenu div.megamenu.megamenucols1 {
    position: fixed;
    width: 100vw;
    top: calc(50px + 52px + 43.5px);
    left: 0;
}

div.fullsize.megamenucols1 div.acolumn, div.megamenucols1 div.acolumn {
    display: grid;
    grid-auto-flow: column;
    grid-auto-rows: auto;
    grid-template-rows: repeat(6, auto);
    gap: 10px;
}

div.megamenu div.acolumn {
   width: 100%;
}

.c-abovemenu-links {
    display: flex;
    gap: 5px;
    justify-content: flex-end;
align-items: center;
    margin-top: 20px;

}
#topbanner .c-abovemenu-links a.c-link {
    font-size: 14px;
    padding: 3px 10px;
    background-color: #6a84bf;
    color: white;
    border-radius: 20px;
}

.megafirstlevelitemmegafirstlevelitem:hover {
    background-color: #6a84bf
}

.megafirstlevelitemmegafirstlevelitem:hover h2 a {
color: white !important;
}
.megafirstlevelitemmegafirstlevelitem:hover h2::before {
   background-image: url('/cache/files/82b8b543c5538ece6f091d79165cfdc8264c808e.svg') !important;
}/* LIST */

div.items.horizontalitems{
    max-width: 1280px;
    margin: 0 auto;
}

#contenttop h1.pagetitle {
    margin-top: 80px;
   font-weight: 800;
}

div.list div.textbox {
    padding: 20px;
}

.horizontalitemsnews div.list div.textbox {
    padding: 0px;
}

div.horizontalitems div.list div.item h3 {
    text-align: left;
    padding: 1.6rem 6.6rem 0 1.6rem;
}

h3 a, div.items div.list h3 a, div.items h3 a {
    font-size: 1.5rem;
    font-weight: 800;
}

div.list div.textbox {
   text-align: left;
}


/* BUTTON */

div.items div.back {
    border: 0px solid #cbcbcb;
}

#contenttop h1 a.backtocat {
    font-weight: 800;
    color: #acacac;
}

h1 a.backtocat:before {
    top: 0.3em;
    border-right-color: #acacac;
}

#contenttop h1 a.backtocat:hover {
    color: #222222;
}

h1 a.backtocat:hover:before {
    border-right-color: #222222;
}

div.items div.detail .back a {
    background-color: #6a84bf;
    color: white;
    font-weight: normal;
    text-decoration: none;
    display: block;
    padding: 10px;
    padding-left: 15px;
    padding-right: 20px;
    border-radius: 50px;
    display: flex;
    line-height: 0.9;
}

div.items div.detail .back a::before {
    content: '';
    background-image: url('/cache/files/c003e26bdec978cfd9c67fac37e92dc315102969.svg');
    width: 15px;
    height: 15px;
    display: inline-block;
    transform: rotate(180deg);
    background-repeat: no-repeat;
    background-position: center;
    margin-right: 7px;
}


/* END BUTTON */

div.items div.detail {
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px;
}

.c-benefits-box {
    background-color: #f5f5f5;
    padding: 30px;
    box-sizing: border-box;
    border-radius: 20px;
}

.c-benefits-box span.label, .c-technical-data-box span.label {
    font-size: 40px;
    display: inline-block;
    margin-bottom: 30px;
    font-weight: 800;
}

.c-technical-data-box {
    margin-top: 50px;
}

.c-technical-data-box .table tr:hover {
    background-color: #f5f5f5;
}

.notloggedin .group.wishlistbutton{
   display: none;
}

.c-pdf-form-box {
    display: flex;
    padding: 50px 0;
    gap: 20px;
}

.c-pdf-form-box > div {
    width: 50%;
    background-color: #f5f5f5;
    border-radius: 20px;
    padding: 40px 20px;
    box-sizing: border-box;
}

div.items div.contactform {
    max-width: none;
}

div.contactform form p {
    position: relative;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
}

div.contactform form p.notrequired input, .contactform p.required input, .contactform p.textarea textarea {
    width: 100%;
    box-sizing: border-box;
    border: 0;
    border-bottom: 1px solid;
    background-color: transparent;
}

.c-button-pdfs a {
    text-decoration: none;
    display: inline-block;
    padding: 10px 20px;
    background-color: #6a84bf;
    color: white;
    border-radius: 50px;
    font-weight: 800;
    transition: 0.3s;
    display: flex;
    align-items: center;
    gap: 10px;
    justify-content: center;
margin-bottom: 20px;
}

.c-button-pdfs a::after {
    content: '';
    width: 35px;
    height: 35px;
    background-color: white;
    border-radius: 50%;
    background-image: url('/cache/files/7c765d0d0a76742c7ed213164148c4e1433e4212.svg');
    background-size: 50%;
    transform: rotate(90deg);
    background-repeat: no-repeat;
    background-position: center;
}

.htmlbox.c-button-pdfs::before {
    content: 'Σχετικά Αρχεία';
    display: block;
    margin-bottom: 20px;
    color: #222222;
    background-color: transparent;
    border-bottom: 1px solid transparent;
    text-align: center;
    font-size: 1.6em;
    font-weight: normal;
    font-weight: 300;
    padding-left: 0;
    padding-bottom: 2px;
    padding-bottom: 10px;
    margin-top: 20px;
}


html[lang="en"] .htmlbox.c-button-pdfs::before {
  content: 'Related Files';
}

div.horizontalitemsnews div.textboxy {
padding: 20px;
}

.notloggedin .itemcontent {
    border: 1px solid #e3e7f0 !important;
    border-radius: 25px;
    overflow: hidden;
}

.detail .itemcontent {
    border: 0px solid #e3e7f0 !important;
    border-radius: 0px;
    overflow: visible;
}

.contactform {
    max-width: 720px;
}

.c-button-pdfs {
    display: inline-block;
}

/* RESPONSIVE */
@media (max-width: 990px) {
.c-pdf-form-box {
    flex-direction: column;
}

.c-pdf-form-box > div {
    width: 100%;
}

}.c-fixedbutton {
    position: fixed;
    bottom: 30px;
    right: 30px;
    display: flex;
    background-color: #6a84bf;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    padding: 5px;
    border-radius: 70px;
cursor: pointer;
   z-index: 90;
    display: none;
}

.detail .c-fixedbutton {
   display: flex;
}

.c-fixedbutton-text {
  color: white;
  font-size: 18px;  
  padding-left: 10px;
}

.c-fixedbutton-icon img {
    height: 50px;
    width: 50px;
}.cont{
    width: 100%;
    overflow: hidden;
    background-color: white;
    border-top: 1px solid #6a84bf;
}

.scorri{
    position: relative;
    display: flex;
    width: 100%;
    justify-content: space-between;
}

#belowsite ul.tithome{
    animation-name: marquee;
    animation-duration: 120s;
    animation-iteration-count: infinite;
    animation-timing-function: linear;
    flex-shrink: 0;
}

#belowsite ul.tithome li{
    width: fit-content;
    display: inline-block;
    list-style: none;
    padding-right: 30px;
    font-size: 40px;
}

#belowsite ul.tithome li img {
margin-left: 10px;
margin-right: 10px;
    height: 80px;
    width: auto;
}

@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}.am_1513 .langchooser {
    display: none;
}

.c-menu-social-box  div.langlist ul {
    padding: 10px;
}

.c-menu-social-box  div.langlist ul li img {
    width: 25px;
    height: auto;
    max-width: none;
}

.c-menu-lang-box {
    position: relative;
    margin-right: 5px;
}

.c-menu-lang-button {
    background-color: white;
    padding: 1px;
    border-radius: 50%;
    border: 1px solid #6a84bf;
    box-shadow: 0px 0px 0px #6a84bf;
    transition: 0.3s;
    position: relative;
    cursor: pointer;
}

.c-menu-lang-button:hover {
    box-shadow: 0px 0px 10px #6a84bf;
}

.c-menu-lang {
    max-height: 0px;
    transition: 1s;
    overflow: hidden;
    position: absolute;
    top: calc(100% + 5px);
    left: -8px;
    background-color: white;
    border-radius: 10px;
    z-index: 19;
    border: 1px solid #ffffff;
}

.c-menu-lang.c-openlang {
    max-height: 160px;
    border: 1px solid #6a84bf;
}

#topbanner .langchooser ul li {
padding-right: 0px;
    float: none;
}

#topbanner .langchooser div.langlist ul, #topbanner .langchooser {
    float: none;
}

#topbanner .langchooser {
    padding-top: 10px;
    padding-right: 15px;
    padding: 10px;
    padding-bottom: 33px;
    padding-left: 12px;
}

@media (max-width: 990px) {
#mobile-header .langchooser {
    top: 6px;
}
}#content {
    background: transparent;
}

.pagetitle {
    display: none;
}

.wrapper {
   width: 100%;
   overflow: hidden;
}

@media (min-width: 992px) {
   #services .col-md-3 {
width: 20%;
        text-align: center;
        aspect-ratio: 1 / 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
        gap: 15px;
        font-size: 16px;
        font-weight: bold;
    }
}

#services .col-md-3 p{
    min-height: 80px;
    margin-top: 10px;
}

#contenttop #services .c-title-box h1 {
      justify-content: center;
}

#contenttop #services .c-title-box p {
    font-size: 20px;
    text-align: center;
    max-width: 1000px;
    margin: 0 auto;
    margin-bottom: 30px;
}

#services .c-main-inner {
    padding-top: 100px;
}

.c-service-icon img {
    width: 80px;
    height: auto;
}

#services a {
   color: #333333;
   text-decoration: none;
}

#services a > div{
    padding: 30px 10px 10px 10px;
    box-sizing: border-box;
    background-color: transparent;
    border-radius: 20px;
    border: 1px solid #cacaca;
}

#services a:hover > div {
    background-color: #f1f1f1;
}


/* ============ */

    :root {
      --primary: #1f4ca4;
      --secondary: #63b3ff;
      --bg: #f7faff;
      --text: #1e1e1e;
      --muted: #5f5f5f;
      --beam-blue-deep: #1f4ca4;
      --beam-blue-mid: #2b5cc8;
      --beam-blue-soft: #74b6ff;
      --beam-blue-cyan: #9fd2ff;
      --navy-900: #0e214e;
      --royal-700: #1f4ca4;
      --cobalt-600: #2a5bd7;
      --sky-400: #63b3ff;
      --ice-50: #eaf2ff;
    }

    * {
      margin: 0;
      padding: 0;
      box-sizing: border-box;
    }

    body {
      background: var(--bg);
      color: var(--text);
      line-height: 1.6;
      overflow-x: hidden;
    }

    /* ---------- BACKGROUND GRID ---------- */
    body::before {
      content: "";
      position: fixed;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      background-image:
        radial-gradient(rgba(31, 76, 164, 0.05) 1px, transparent 1px),
        radial-gradient(rgba(31, 76, 164, 0.04) 1px, transparent 1px);
      background-position: 0 0, 25px 25px;
      background-size: 50px 50px;
      z-index: -1;
    }

    /* ---------- HERO ---------- */
    .hero {
      text-align: center;
      padding: 6rem 1.5rem 4rem;
      background: linear-gradient(180deg, #f0f6ff 0%, #ffffff 90%);
      position: relative;
      overflow: hidden;
    }

    .hero::before {
      content: "";
      position: absolute;
      inset: 0;
      background-image:
        radial-gradient(rgba(31, 76, 164, 0.05) 1px, transparent 1px),
        radial-gradient(rgba(31, 76, 164, 0.04) 1px, transparent 1px);
      background-size: 60px 60px;
      z-index: 0;
    }

#contenttop .hero h1 {
      color: var(--primary);
      font-size: 2.8rem;
      margin-bottom: 1.2rem;
      font-weight: 700;
      letter-spacing: 0.4px;
      line-height: 1.25;
      position: relative;
      z-index: 1;
      text-shadow: 0 2px 6px rgba(31, 76, 164, 0.05);
    }

#contenttop .hero h1 span {
      color: var(--secondary);
      background: linear-gradient(90deg, var(--primary), var(--secondary));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      font-weight: 700;
    }

    .hero p {
      color: #51607a;
      max-width: 780px;
      margin: 0 auto;
      font-size: 1.1rem;
      line-height: 1.65;
      position: relative;
      z-index: 1;
    }

    /* ---------- RESPONSIVE HERO ---------- */
    @media (max-width: 1024px) {
      .hero {
        padding: 5rem 1rem 3rem;
      }

#contenttop .hero h1 {
        font-size: 2.4rem;
      }

      .hero p {
        font-size: 1rem;
        max-width: 90%;
      }
    }

    @media (max-width: 768px) {
      .hero {
        padding: 4rem 1rem 2.5rem;
        background: linear-gradient(180deg, #f3f8ff 0%, #ffffff 100%);
      }

#contenttop .hero h1 {
        font-size: 2rem;
        line-height: 1.3;
        margin-bottom: 1rem;
      }

      .hero h1::after {
        width: 50px;
        height: 2.5px;
      }

      .hero p {
        font-size: 0.95rem;
        line-height: 1.55;
      }
    }

    @media (max-width: 480px) {
      .hero {
        padding: 3rem 1rem 2rem;
      }

#contenttop .hero h1 {
        font-size: 1.6rem;
        line-height: 1.3;
        letter-spacing: 0.3px;
      }

#contenttop .hero h1 span {
        display: block;
        margin-top: 0.2rem;
      }

      .hero p {
        font-size: 0.88rem;
        line-height: 1.45;
        max-width: 95%;
      }
    }

    /* ---------- TIMELINE ---------- */
    .timeline {
      position: relative;
      width: 90%;
      max-width: 1000px;
      margin: 5rem auto;
    }

    .timeline::before {
      content: "";
      position: absolute;
      top: 0;
      left: 50%;
      transform: translateX(-50%);
      width: 2px;
      height: 100%;
      background: linear-gradient(to bottom, var(--primary), var(--secondary));
      opacity: 0.4;
    }

    /* ---------- STEP ---------- */
    .step {
      position: relative;
      width: 50%;
      padding: 2rem 2rem 5rem;
    }

    .step:nth-child(odd) {
      left: 0;
      text-align: right;
    }

    .step:nth-child(even) {
      left: 50%;
    }

    .step-content {
      background: white;
      padding: 2rem;
      border-radius: 18px;
      box-shadow: 0 8px 25px rgba(0, 0, 0, 0.08);
      position: relative;
      border-left: 6px solid transparent;
      border-image: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%) 1;
      border-image-slice: 1;
      transition: transform 0.3s ease, box-shadow 0.3s ease;
    }

    .step:nth-child(odd) .step-content {
      border-left: none;
      border-right: 6px solid transparent;
      border-image: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%) 1;
      border-image-slice: 1;
    }

    .step-content:hover {
      transform: translateY(-6px);
      box-shadow: 0 12px 30px rgba(31, 76, 164, 0.15);
    }

    .step-icon {
      width: 70px;
      height: 70px;
      background: linear-gradient(135deg, var(--primary), var(--secondary));
      display: flex;
      align-items: center;
      justify-content: center;
      border-radius: 50%;
      position: absolute;
      top: -35px;
      left: calc(50% - 35px);
      box-shadow: 0 4px 15px rgba(0, 0, 0, 0.1);
    }

    .step-icon svg {
      width: 36px;
      height: 36px;
      stroke: white;
      stroke-width: 1.5;
      fill: none;
    }

#contenttop .step h3 {
      color: var(--primary);
      font-size: 1.2rem;
      margin-bottom: 0.5rem;
    }

    .step p {
      color: var(--muted);
      font-size: 0.95rem;
    }

    .connector {
      position: absolute;
      width: 100px;
      height: 2px;
      background: linear-gradient(90deg, var(--secondary), var(--primary));
      opacity: 0.4;
    }

    .step:nth-child(odd) .connector {
      right: -50px;
      bottom: 35px;
      transform: rotate(25deg);
    }

    .step:nth-child(even) .connector {
      left: -50px;
      bottom: 35px;
      transform: rotate(-25deg);
    }

    .connector::after {
      content: "";
      position: absolute;
      width: 10px;
      height: 10px;
      background: var(--secondary);
      border-radius: 50%;
      box-shadow: 0 0 10px var(--secondary);
      animation: pulse 1.5s infinite ease-in-out;
    }

    .step:nth-child(odd) .connector::after {
      right: -5px;
      top: -4px;
    }

    .step:nth-child(even) .connector::after {
      left: -5px;
      top: -4px;
    }

    @keyframes pulse {

      0%,
      100% {
        transform: scale(1);
        opacity: 0.8;
      }

      50% {
        transform: scale(1.5);
        opacity: 0.3;
      }
    }

    /* ---------- RESPONSIVE ---------- */
    @media (max-width:800px) {
      .timeline::before {
        left: 20px;
      }

      .step {
        width: 100%;
        padding-left: 3rem;
        padding-right: 1rem;
        text-align: left;
      }

      .step:nth-child(even) {
        left: 0;
      }

      .step-content {
        border-left: 6px solid var(--secondary) !important;
        border-right: none;
      }

      .step-icon {
        left: -5px;
      }

      .connector {
        display: none;
      }
    }

    /* ---------- TREE SECTION ---------- */
    .tree-section {
      text-align: center;
      margin-top: 2rem;
      margin-bottom: 0rem;
      padding: 1rem 1rem 0;
    }

#contenttop .tree-section h2 {
      color: var(--primary);
      font-size: 1.8rem;
      margin-bottom: 2rem;
    }

    .tree-section img {
      width: 90%;
      max-width: 600px;
      animation: fadein 1.2s ease both;
      transform: translateY(0px);
      mix-blend-mode: multiply;
      transition: transform 0.4s ease, scale 0.4s ease;
    }

    .tree-section img:hover {
      transform: translateY(5px) scale(1.05);
    }

    /* ---------- CERTIFICATIONS ---------- */
    .certs {
      background-color: #6B82C1;
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      color: #fff;
      text-align: center;
      padding: 12rem 7rem;
      position: relative;
    }

#contenttop .certs h2 {
      font-size: 2rem;
      margin-bottom: 2.5rem;
      color: white;
    }

    .cert-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
      gap: 2rem;
      max-width: 1000px;
      margin: 0 auto;
    }

    .cert-card {
      background: rgba(255, 255, 255, 0.1);
      border: 1px solid rgba(255, 255, 255, 0.25);
      border-radius: 14px;
      padding: 1.8rem 1rem;
      box-shadow: inset 0 0 8px rgba(255, 255, 255, 0.15);
      transition: transform .3s ease, box-shadow .3s ease;
    }

    .cert-card:hover {
      transform: translateY(-6px);
      box-shadow: 0 0 18px rgba(99, 179, 255, 0.4);
    }

    .cert-card svg {
      width: 36px;
      height: 36px;
      stroke: white;
      stroke-width: 1.5;
      fill: none;
      margin-bottom: .8rem;
    }

#contenttop .cert-card h3 {
      font-size: 1.05rem;
      color: white;
      margin-bottom: .3rem;
    }

    .cert-card p {
      color: rgba(255, 255, 255, 0.85);
      font-size: 0.9rem;
    }

    /* ---------- RESPONSIVE FOR CERTIFICATIONS SECTION ---------- */
    @media (max-width: 1024px) {
      .certs {
        padding: 8rem 3rem;
      }

#contenttop .certs h2 {
        font-size: 1.8rem;
        margin-bottom: 2rem;
      color: white;
      }

      .cert-grid {
        gap: 1.5rem;
        max-width: 90%;
      }

      .cert-card {
        padding: 1.5rem 1rem;
      }
    }

    @media (max-width: 768px) {
      .certs {
        padding: 6rem 1.5rem;
        background: linear-gradient(180deg, #6B82C1 0%, #6E86CE 60%, #728FDC 100%);
      }

#contenttop .certs h2 {
        font-size: 1.6rem;
        margin-bottom: 1.8rem;
        line-height: 1.3;
      color: white;
      }

      .cert-grid {
        grid-template-columns: 1fr;
        gap: 1.5rem;
      }

      .cert-card {
        max-width: 350px;
        margin: 0 auto;
        padding: 1.3rem 1rem;
        border-radius: 12px;
      }

      .cert-card svg {
        width: 32px;
        height: 32px;
        margin-bottom: 0.6rem;
      }

#contenttop .cert-card h3 {
        font-size: 1rem;
      }

      .cert-card p {
        font-size: 0.85rem;
        line-height: 1.4;
      }
    }

    @media (max-width: 480px) {
      .certs {
        padding: 5rem 1rem;
      }

#contenttop .certs h2 {
        font-size: 1.4rem;
      color: white;
      }

      .cert-card {
        padding: 1.1rem 0.8rem;
      }

#contenttop .cert-card h3 {
        font-size: 0.95rem;
      }

      .cert-card p {
        font-size: 0.8rem;
      }
    }

    /* ---------- WHY CHOOSE US ---------- */
    .why {
      background: white;
      text-align: center;
      padding: 5rem 1rem 6rem;
      position: relative;
      z-index: 2;
      box-shadow: 0 -3px 15px rgba(0, 0, 0, 0.05);
    }

#contenttop .why h2 {
      color: var(--primary);
      font-size: 2rem;
      margin-bottom: 2rem;
    }

    .reasons {
      display: flex;
      justify-content: center;
      flex-wrap: wrap;
      gap: 2rem;
      max-width: 1100px;
      margin: 0 auto;
    }

    .reason {
      flex: 1 1 280px;
      background: linear-gradient(180deg, #fafdff, #f0f6ff);
      border-radius: 16px;
      box-shadow: 0 6px 20px rgba(0, 0, 0, 0.05);
      padding: 2rem;
      transition: transform .3s ease;
    }

    .reason:hover {
      transform: translateY(-6px);
    }

    .reason svg {
      width: 40px;
      height: 40px;
      stroke: var(--primary);
      stroke-width: 1.5;
      fill: none;
      margin-bottom: 1rem;
    }

#contenttop .reason h3 {
      color: var(--primary);
      margin-bottom: .5rem;
    }

    .reason p {
      color: var(--muted);
      font-size: .95rem;
    }

    .hero {
      --hero-bg: linear-gradient(180deg, #eaf2ff 0%, #ffffff 100%);
      --hero-accent: #1f4ca4;
      --hero-accent-2: #63b3ff;
      background: var(--hero-bg);
      position: relative;
      overflow: hidden;
      padding: clamp(3.5rem, 6vw, 6rem) 1rem;
    }

    .hero::after {
      content: "";
      position: absolute;
      inset: auto -20% -25% -20%;
      height: 55%;
      pointer-events: none;
    }

    .hero__inner {
      max-width: 1080px;
      margin: 0 auto;
      text-align: center;
    }

    .hero__kicker {
      display: inline-block;
      font-size: .78rem;
      letter-spacing: .14em;
      font-weight: 600;
      text-transform: uppercase;
      color: #4064b6;
      background: rgba(99, 179, 255, .15);
      border: 1px solid rgba(99, 179, 255, .35);
      padding: .35rem .6rem;
      border-radius: 999px;
      margin-bottom: .9rem;
    }

#contenttop .hero h1 {
      font-weight: 800;
      line-height: 1.08;
      letter-spacing: -0.015em;
      font-size: clamp(1.9rem, 4.6vw, 3.2rem);
      color: #0f2c6b;
      margin: 0 auto .9rem;
      max-width: 24ch;
    }

    .hero__accent {
      background-color: #6B82C1;
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      -webkit-background-clip: text;
      background-clip: text;
      color: transparent;
    }

    .hero__lead {
      color: #4d5872;
      font-size: clamp(1rem, 1.6vw, 1.15rem);
      line-height: 1.75;
      max-width: 65ch;
      margin: 0 auto;
      letter-spacing: 0.005em;
    }

    .hero__inner h1+.hero__lead::before {
      content: "";
      display: block;
      width: clamp(60px, 12vw, 110px);
      height: 3px;
      margin: .9rem auto 1.1rem;
      border-radius: 3px;
      background: linear-gradient(90deg, var(--hero-accent), var(--hero-accent-2));
      opacity: .7;
    }

    @media (prefers-reduced-motion: reduce) {
      .hero::after {
        background: none;
      }
    }

    /* =====  BRIDGE  ===== */
    .bridge-connected {
      background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
      position: relative;
      padding: 0;
      display: flex;
      justify-content: center;
      align-items: center;
      min-height: 320px;
      overflow: hidden;
    }

    .bridge-inner {
      display: flex;
      align-items: center;
      justify-content: center;
      text-align: center;
      gap: 4rem;
      max-width: 1200px;
      width: 100%;
      padding: 3rem 1rem;
      position: relative;
    }

    .bridge-left,
    .bridge-right {
      flex: 1;
      max-width: 320px;
    }

    .bridge-left h4,
    .bridge-right h4 {
      color: #1f4ca4;
      font-size: 1.2rem;
      font-weight: 700;
      margin-bottom: 0.5rem;
      letter-spacing: 0.3px;
    }

    .bridge-left p,
    .bridge-right p {
      color: #4a5780;
      font-size: 0.95rem;
      line-height: 1.6;
      opacity: 0.9;
    }

    .bridge-center {
      display: flex;
      flex-direction: column;
      align-items: center;
      justify-content: center;
      flex: 0 0 auto;
      position: relative;
    }

    .beam-container {
      position: relative;
      width: 8px;
      height: 240px;
      display: flex;
      align-items: center;
      justify-content: center;
      margin-bottom: 1.2rem;
    }

    .beam-core {
      position: absolute;
      width: 3px;
      height: 100%;
      border-radius: 30px;
      background: linear-gradient(180deg, #ffffff 0%, #a7d4ff 30%, #63b3ff 60%, #1f4ca4 100%);
      z-index: 2;
    }

    .beam-glow {
      position: absolute;
      width: 10px;
      height: 100%;
      border-radius: 50px;
      background: linear-gradient(180deg, rgba(99, 179, 255, 0.4), rgba(31, 76, 164, 0.25));
      filter: blur(3px);
      opacity: 0.8;
      animation: beamPulse 4s ease-in-out infinite;
    }

    .beam-light {
      position: absolute;
      width: 4px;
      height: 80px;
      border-radius: 50px;
      background: linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.8), transparent);
      animation: moveLight 3s linear infinite;
      opacity: 0.9;
    }

    @keyframes moveLight {
      0% {
        transform: translateY(-120px);
        opacity: 0.3;
      }

      25% {
        opacity: 1;
      }

      50% {
        transform: translateY(120px);
        opacity: 0.5;
      }

      75% {
        opacity: 1;
      }

      100% {
        transform: translateY(-120px);
        opacity: 0.3;
      }
    }

    @keyframes beamPulse {

      0%,
      100% {
        opacity: 0.75;
      }

      50% {
        opacity: 1;
        filter: blur(4px);
      }
    }

    .bridge-text {
      font-size: 1rem;
      color: #1f4ca4;
      font-style: italic;
      letter-spacing: 0.3px;
      margin-top: 0.5rem;
      opacity: 0.85;
    }

    @media (max-width: 900px) {
      .bridge-inner {
        flex-direction: column;
        gap: 2rem;
        text-align: center;
      }

      .beam-container {
        height: 200px;
      }

      .bridge-left,
      .bridge-right {
        max-width: 100%;
      }
    }

    .energy-bridge {
      padding: 6rem 0 7rem;
      min-height: 420px;
      background: transparent;
    }

    .energy-line {
      width: 8px;
      height: 420px;
      border-radius: 60px;
      box-shadow:
        0 0 28px rgba(99, 179, 255, 0.40),
        0 0 90px rgba(31, 76, 164, 0.30),
        inset 0 0 10px rgba(255, 255, 255, 0.65);
      margin: 1.6rem 0;
      animation: subtle-glow 5.2s ease-in-out infinite alternate;
    }

    .energy-line .glow {
      opacity: 0.9;
      animation: energy-flow 3.2s linear infinite;
    }

    .particle {
      width: 12px;
      height: 12px;
      box-shadow: 0 0 18px rgba(99, 179, 255, 0.85);
      animation: rise 4.2s ease-in-out infinite;
    }

    .particle.delay {
      animation-delay: 2.1s;
    }

    @keyframes rise {
      0% {
        transform: translate(-50%, 160px) scale(0.6);
        opacity: 0;
      }

      25% {
        opacity: 1;
      }

      75% {
        opacity: 1;
      }

      100% {
        transform: translate(-50%, -180px) scale(1);
        opacity: 0;
      }
    }

    @keyframes subtle-glow {

      0%,
      100% {
        box-shadow: 0 0 28px rgba(99, 179, 255, 0.36), 0 0 90px rgba(31, 76, 164, 0.26);
      }

      50% {
        box-shadow: 0 0 48px rgba(99, 179, 255, 0.52), 0 0 140px rgba(31, 76, 164, 0.34);
      }
    }

    @media (max-width: 700px) {
      .energy-bridge {
        padding: 4.5rem 0 5rem;
        min-height: 360px;
      }

      .energy-line {
        height: 360px;
        width: 7px;
      }

      .particle {
        width: 10px;
        height: 10px;
      }

      @keyframes rise {
        0% {
          transform: translate(-50%, 130px) scale(0.6);
          opacity: 0;
        }

        100% {
          transform: translate(-50%, -150px) scale(1);
          opacity: 0;
        }
      }
    }

    /* =====  BRIDGE ===== */
    .bridge-evo.big {
      position: relative;
      display: flex;
      justify-content: center;
      align-items: center;
      background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
      /* same as Why Choose Us */
      padding: 0;
      margin: 0;
      overflow: hidden;
    }

    .bridge-evo.big::before {
      content: "";
      position: absolute;
      top: 0;
      height: 130%;
      width: 100%;
      background: linear-gradient(180deg, #ffffff 0%, #f5f9ff 40%, #eaf3ff 100%);
      z-index: 0;
      opacity: 0.8;
    }

    .bridge-wrap-evo {
      display: flex;
      flex-direction: column;
      align-items: center;
      text-align: center;
      position: relative;
      z-index: 1;
      padding: 6rem 1rem 6rem;
      gap: 3rem;
    }

#contenttop .bridge-head h3,
#contenttop .bridge-foot h3 {
      font-size: 1.6rem;
      font-weight: 700;
      letter-spacing: 0.3px;
      background: linear-gradient(90deg, #1f4ca4, #63b3ff);
      -webkit-background-clip: text;
      color: transparent;
    }

    .bridge-head p,
    .bridge-foot p {
      font-size: 1.2rem;
      color: #4b5c85;
      opacity: 0.85;
    }

    .bridge-foot {
      margin-top: clamp(1.15rem, 3vw, 3rem);
    }

    .bridge-foot .bridge-cta {
      margin-top: clamp(0.75rem, 1.8vw, 1.5rem);
    }

    .energy-core {
      position: relative;
      width: 10px;
      height: 520px;
      display: flex;
      justify-content: center;
      align-items: center;
      margin: 0 auto;
    }

    .beam {
      position: absolute;
      width: 4px;
      height: 100%;
      border-radius: 50px;
      background: linear-gradient(180deg, #ffffff 0%, #a7d4ff 25%, #63b3ff 60%, #1f4ca4 100%);
      filter: blur(0.3px);
      opacity: 0.9;
    }

    .beam-glow {
      position: absolute;
      width: 10px;
      height: 100%;
      border-radius: 50px;
      background: linear-gradient(180deg, rgba(99, 179, 255, 0.5), rgba(31, 76, 164, 0.3));
      box-shadow:
        0 0 45px rgba(99, 179, 255, 0.4),
        0 0 100px rgba(31, 76, 164, 0.3),
        0 0 160px rgba(31, 76, 164, 0.2);
      animation: beamGlow 5s ease-in-out infinite alternate;
    }

    @keyframes beamGlow {

      0%,
      100% {
        opacity: 0.8;
      }

      50% {
        opacity: 1;
        box-shadow: 0 0 60px rgba(99, 179, 255, 0.6), 0 0 160px rgba(31, 76, 164, 0.35);
      }
    }

    .beam-pulse {
      position: absolute;
      width: 5px;
      height: 100px;
      border-radius: 50px;
      background: linear-gradient(180deg, transparent, rgba(255, 255, 255, 0.9), transparent);
      opacity: 0.9;
      animation: movePulse 3.8s linear infinite;
    }

    @keyframes movePulse {
      0% {
        transform: translateY(-250px);
        opacity: 0.2;
      }

      25% {
        opacity: 1;
      }

      50% {
        transform: translateY(250px);
        opacity: 0.5;
      }

      75% {
        opacity: 1;
      }

      100% {
        transform: translateY(-250px);
        opacity: 0.2;
      }
    }

    .spark {
      position: absolute;
      width: 12px;
      height: 12px;
      border-radius: 50%;
      background: radial-gradient(circle at 30% 30%, #fff, #63b3ff 60%, #1f4ca4 100%);
      box-shadow: 0 0 20px rgba(99, 179, 255, 0.9);
      animation: floatSpark 6s ease-in-out infinite;
    }

    .spark.one {
      left: -25px;
      animation-delay: 0.5s;
    }

    .spark.two {
      right: -25px;
      animation-delay: 2s;
    }

    .spark.three {
      left: 15px;
      animation-delay: 3.3s;
    }

    @keyframes floatSpark {
      0% {
        transform: translateY(140px) scale(0.5);
        opacity: 0;
      }

      20% {
        opacity: 1;
      }

      50% {
        transform: translateY(-140px) scale(1);
        opacity: 0.8;
      }

      80% {
        opacity: 1;
      }

      100% {
        transform: translateY(140px) scale(0.5);
        opacity: 0;
      }
    }

    @media (max-width: 700px) {

#contenttop .bridge-head h3,
#contenttop .bridge-foot h3 {
        font-size: 1.3rem;
      }

      .energy-core {
        height: 400px;
      }
    }

    .bridge-wrap-evo {
      padding-top: 2.15rem;
      padding-bottom: 6.25rem;
      gap: 1.2rem;
    }

    .energy-core {
      height: 560px;
    }

    .bridge-evo.big {
      --beamTopOffset: -12px;
    }

    .energy-core {
      margin-top: var(--beamTopOffset);
    }

    .bridge-head p {
      margin-bottom: 0.35rem;
    }

    .bridge-evo.big {
      min-height: 90vh;
      padding: 10vh 0 12vh;
      background: linear-gradient(180deg, #ffffff 0%, #f7faff 100%);
    }

    .why {
      margin-bottom: 0 !important;
    }

    .certs {
      margin-top: 0 !important;
    }

    .energy-core {
      height: clamp(520px, 62vh, 780px);
      margin-top: -8px;
    }

    .bridge-wrap-evo {
      padding-top: 2rem;
      padding-bottom: 2rem;
      gap: 1.2rem;
    }

    .bridge-head p {
      margin-bottom: 0.35rem;
    }

    @media (min-width: 1280px) {
      .bridge-evo.big {
        padding: 12vh 0 14vh;
      }

      .energy-core {
        height: clamp(620px, 65vh, 880px);
      }
    }

    @media (max-width: 700px) {
      .bridge-evo.big {
        min-height: 90vh;
        padding: 8vh 0 9vh;
      }

      .energy-core {
        height: clamp(420px, 58vh, 640px);
      }
    }

    /* ---- Bridge CTA ---- */
    .bridge-cta {
      margin-top: .8rem;
    }

    .btn-medical {
      --btn-start: #5E78B6;
      --btn-end: #6F8ED6;
      --btn-border: rgba(255, 255, 255, .25);
      display: inline-flex;
      align-items: center;
      gap: .55rem;
      padding: .78rem 1.15rem;
      border-radius: 999px;
      font-weight: 600;
      letter-spacing: .2px;
      color: #fff;
      background: linear-gradient(135deg, var(--btn-start), var(--btn-end));
      border: 1px solid var(--btn-border);
      box-shadow:
        0 6px 18px rgba(31, 76, 164, .18),
        inset 0 0 0 1px rgba(255, 255, 255, .25);
      transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
      text-decoration: none;
    }

    .btn-medical svg {
      width: 18px;
      height: 18px;
      stroke: #fff;
      stroke-width: 2;
      fill: none;
      transition: transform .18s ease, opacity .18s ease;
      opacity: .95;
    }

    .btn-medical:hover {
      transform: translateY(-2px);
      box-shadow:
        0 10px 26px rgba(31, 76, 164, .24),
        inset 0 0 0 1px rgba(255, 255, 255, .3);
    }

    .btn-medical:hover svg {
      transform: translateX(2px);
    }

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

    .btn-medical:focus-visible {
      outline: none;
      box-shadow:
        0 0 0 3px rgba(99, 179, 255, .35),
        0 10px 26px rgba(31, 76, 164, .24),
        inset 0 0 0 1px rgba(255, 255, 255, .3);
    }

    .btn-medical.is-outline {
      background: rgba(255, 255, 255, .55);
      color: #1f3e8a;
      border: 1px solid rgba(31, 76, 164, .25);
      box-shadow: 0 6px 16px rgba(31, 76, 164, .10);
    }

    .btn-medical.is-outline svg {
      stroke: #1f3e8a;
    }

    .beam-label {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      pointer-events: none;
      white-space: nowrap;
      filter: drop-shadow(0 6px 16px rgba(31, 76, 164, .18));
      animation: labelFloat 6s ease-in-out infinite;
    }

    @keyframes labelFloat {

      0%,
      100% {
        transform: translateX(-50%) translateY(0);
      }

      50% {
        transform: translateX(-50%) translateY(-6px);
      }
    }

    .beam-label span {
      display: inline-block;
      font-weight: 700;
      font-size: clamp(1.05rem, 1.6vw, 1.25rem);
      letter-spacing: .2px;
      color: #3674b2;
      text-shadow: 0 1px 0 #fff, 0 10px 24px rgba(31, 76, 164, .12);
      position: relative;
      padding-bottom: .35rem;
    }

    .beam-label span::after {
      content: "";
      position: absolute;
      left: 0;
      right: 0;
      bottom: 0;
      height: 3px;
      border-radius: 3px;
      background: linear-gradient(180deg, #8ec6ff, #2f6ccf);
      box-shadow:
        0 2px 6px rgba(31, 76, 164, .22),
        inset 0 1px 0 rgba(255, 255, 255, .6);
    }

    .lbl-innovation {
      top: 22%;
    }

    .lbl-reliability {
      top: 48%;
    }

    .lbl-expertise {
      top: 74%;
    }

    .beam-label.left {
      transform: translateX(calc(-50% - 80px));
      text-align: right;
    }

    .beam-label.right {
      transform: translateX(calc(-50% + 80px));
      text-align: left;
    }

    @keyframes labelFloat {

      0%,
      100% {
        transform: translateX(var(--x, -50%)) translateY(0);
      }

      50% {
        transform: translateX(var(--x, -50%)) translateY(-6px);
      }
    }

    .beam-label.left {
      --x: calc(-50% - 80px);
    }

    .beam-label.right {
      --x: calc(-50% + 80px);
    }

    .beam-label.left::before,
    .beam-label.right::before {
      content: "";
      position: absolute;
      top: calc(100% - 8px);
      width: 10px;
      height: 2px;
      background: linear-gradient(90deg, rgba(31, 76, 164, .0), rgba(31, 76, 164, .25));
      filter: blur(.2px);
    }

    .beam-label.left::before {
      right: -16px;
      transform: rotate(0.5deg);
    }

    .beam-label.right::before {
      left: -16px;
      transform: scaleX(-1) rotate(0.5deg);
    }

    @media (max-width: 900px) {
      .beam-label.left {
        --x: calc(-50% - 56px);
      }

      .beam-label.right {
        --x: calc(-50% + 56px);
      }

      .beam-label span {
        font-size: clamp(1rem, 2.6vw, 1.1rem);
      }
    }

    @media (max-width: 600px) {
      .beam-label.left {
        --x: calc(-50% - 44px);
      }

      .beam-label.right {
        --x: calc(-50% + 44px);
      }

      .lbl-innovation {
        top: 26%;
      }

      .lbl-reliability {
        top: 50%;
      }

      .lbl-expertise {
        top: 74%;
      }
    }

    .beam-labels {
      position: absolute;
      inset: 0;
      pointer-events: none;
    }

    .beam-tag {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      width: 0;
    }

    .beam-tag span {
      position: relative;
      display: inline-block;
      color: var(--beam-blue-mid);
      font-weight: 700;
      font-size: clamp(1.05rem, 1.4vw, 1.2rem);
      letter-spacing: .2px;
      text-shadow:
        0 1px 0 #ffffff,
        0 2px 10px rgba(38, 99, 197, 0.22),
        0 6px 18px rgba(31, 76, 164, 0.18);
      padding: .15rem .35rem;
      pointer-events: auto;
    }

    .beam-tag span::after {
      content: "";
      position: absolute;
      left: 8px;
      right: 8px;
      bottom: -6px;
      height: 2px;
      border-radius: 2px;
      background: linear-gradient(90deg, var(--beam-blue-deep), var(--beam-blue-soft));
      box-shadow:
        0 1px 0 #ffffffcc inset,
        0 6px 14px rgba(31, 76, 164, .18);
    }

    .beam-tag::before {
      content: "";
      position: absolute;
      top: 50%;
      width: 10px;
      height: 10px;
      border-radius: 999px;
      background: radial-gradient(circle at 30% 30%, #fff, var(--beam-blue-soft) 60%, var(--beam-blue-deep) 100%);
      box-shadow: 0 0 16px var(--beam-blue-soft), 0 0 28px rgba(31, 76, 164, .25);
      transform: translate(-50%, -50%);
    }

    .beam-tag::after {
      content: "";
      position: absolute;
      top: 50%;
      width: 14px;
      height: 2px;
      border-radius: 2px;
      background: linear-gradient(90deg, var(--beam-blue-soft), var(--beam-blue-deep));
      filter: blur(.2px);
      transform: translateY(-50%);
    }

    .beam-tag.left span {
      transform: translateX(-18px);
    }

    .beam-tag.right span {
      transform: translateX(18px);
    }

    .beam-tag.left::before {
      left: calc(-8px);
    }

    .beam-tag.left::after {
      left: calc(-8px);
      transform: translateY(-50%) scaleX(-1);
    }

    .beam-tag.right::before {
      left: calc(8px);
    }

    .beam-tag.right::after {
      left: calc(8px);
    }

    @keyframes labelFloat {

      0%,
      100% {
        transform: translateX(var(--x, 0)) translateY(-50%);
      }

      50% {
        transform: translateX(calc(var(--x, 0) + 1px)) translateY(calc(-50% - 2px));
      }
    }

    .beam-tag::before {
      animation: labelFloat 4.5s ease-in-out infinite;
    }

    .beam-tag.left {
      --x: -50%;
    }

    .beam-tag.right {
      --x: -50%;
    }

    .section-flash {
      animation: sectionFlash 1.1s ease-out;
    }

    @keyframes sectionFlash {
      0% {
        box-shadow: 0 0 0 rgba(99, 179, 255, 0);
      }

      25% {
        box-shadow: 0 0 0 6px rgba(99, 179, 255, .18);
      }

      100% {
        box-shadow: 0 0 0 rgba(99, 179, 255, 0);
      }
    }

    /* ---------- RESPONSIVE FOR HERO, TIMELINE & TREE ---------- */
    @media (max-width: 1024px) {
      .hero {
        padding: 4rem 1.5rem 3rem;
      }

#contenttop .hero h1 {
        font-size: 2rem;
        line-height: 1.3;
      }

      .hero p {
        font-size: 1rem;
        max-width: 90%;
      }

      .timeline {
        width: 95%;
        margin: 4rem auto;
      }

      .step-content {
        padding: 1.8rem;
      }

      .step-icon {
        width: 60px;
        height: 60px;
        top: -30px;
      }

      .step-icon svg {
        width: 30px;
        height: 30px;
      }

      .tree-section img {
        max-width: 550px;
        width: 85%;
      }
    }

    @media (max-width: 768px) {
      .hero {
        padding: 3.5rem 1rem 2.5rem;
        background: linear-gradient(180deg, #eaf2ff 0%, #ffffff 100%);
      }

#contenttop .hero h1 {
        font-size: 1.7rem;
        line-height: 1.25;
        margin-bottom: 0.8rem;
      }

#contenttop .hero h1 .hero__accent {
        display: block;
        color: var(--primary);
      }

      .hero p {
        font-size: 0.95rem;
        max-width: 95%;
      }

      .timeline::before {
        left: 24px;
      }

      .step {
        width: 100%;
        padding: 2rem 1.5rem 3.5rem;
        text-align: left !important;
      }

      .step-content {
        border-left: 6px solid var(--secondary) !important;
        border-right: none !important;
        margin-left: 2.2rem;
        border-radius: 14px;
      }

      .step-icon {
        left: -5px;
      }

      .connector {
        display: none;
      }

#contenttop .step h3 {
        font-size: 1.05rem;
      }

      .step p {
        font-size: 0.9rem;
        line-height: 1.45;
      }

      .tree-section {
        margin-top: 2.5rem;
        padding: 1rem;
      }

      .tree-section img {
        width: 90%;
        max-width: 460px;
        transform: translateY(-15px);
      }

#contenttop .tree-section h2 {
        font-size: 1.4rem;
        margin-bottom: 1.2rem;
      }
    }

    @media (max-width: 480px) {
      .hero {
        padding: 3rem 0.8rem 2rem;
      }

#contenttop .hero h1 {
        font-size: 1.4rem;
      }

      .hero p {
        font-size: 0.88rem;
        line-height: 1.45;
      }

      .timeline {
        width: 100%;
        margin: 3rem auto 2rem;
      }

      .step {
        padding: 1.5rem 1rem 2.5rem;
      }

      .step-content {
        padding: 1.2rem 1rem;
        margin-left: 2rem;
      }

#contenttop .step h3 {
        font-size: 1rem;
      }

      .step p {
        font-size: 0.85rem;
      }

      .step-icon {
        width: 50px;
        height: 50px;
        top: -25px;
      }

      .step-icon svg {
        width: 26px;
        height: 26px;
      }

      .tree-section {
        margin-top: 2rem;
      }

      .tree-section img {
        width: 92%;
        max-width: 380px;
        transform: translateY(-10px);
      }
    }

    /* ---------- RESPONSIVE ENERGY BRIDGE ---------- */
    @media (max-width: 1024px) {
      .bridge-evo {
        padding: 5rem 2rem 4rem;
      }

      .bridge-wrap-evo {
        flex-direction: column;
        text-align: center;
        gap: 3rem;
      }

#contenttop .bridge-head h3,
#contenttop .bridge-foot h3 {
        font-size: 1.6rem;
      }

      .energy-core {
        width: 90%;
        margin: 0 auto 2rem;
        transform: scale(0.95);
      }

      .beam-label span {
        font-size: 0.95rem;
      }

      .bridge-foot p {
        font-size: 0.95rem;
      }

      .btn-medical {
        padding: 0.9rem 1.6rem;
        font-size: 0.95rem;
      }
    }

    /* ===  Arrow  === */
    .energy-core::after {
      content: "";
      position: absolute;
      bottom: -28px;
      left: 50%;
      transform: translateX(-50%);
      width: 40px;
      height: 30px;
      clip-path: polygon(50% 100%, 0 0, 100% 0);
      border-radius: 2px;
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      box-shadow:
        0 -4px 10px rgba(107, 130, 193, 0.6),
        0 0 25px rgba(103, 128, 200, 0.4),
        inset 0 2px 4px rgba(255, 255, 255, 0.6);
      animation: beamArrowPulse 3s ease-in-out infinite;
    }

    @keyframes beamArrowPulse {

      0%,
      100% {
        transform: translateX(-50%) scale(1);
        box-shadow:
          0 -4px 10px rgba(107, 130, 193, 0.55),
          0 0 25px rgba(103, 128, 200, 0.35);
      }

      50% {
        transform: translateX(-50%) scale(1.1);
        box-shadow:
          0 -4px 14px rgba(107, 130, 193, 0.85),
          0 0 35px rgba(103, 128, 200, 0.5);
      }
    }

    .energy-core::after {
      content: "";
      position: absolute;
      bottom: -28px;
      left: 50%;
      transform: translateX(-0%);
      width: 0;
      height: 0;
      border-left: 20px solid transparent;
      border-right: 20px solid transparent;
      border-top: 32px solid #63b3ff;
      background: linear-gradient(to bottom, #a7d4ff 0%, #63b3ff 50%, #1f4ca4 100%);
      border-top: none;
      clip-path: polygon(50% 100%, 0 0, 100% 0);
      width: 20px;
      height: 30px;
      background: linear-gradient(to bottom, #a7d4ff 0%, #63b3ff 50%, #1f4ca4 100%);
      box-shadow:
        0 -4px 10px rgba(99, 179, 255, 0.7),
        0 0 25px rgba(31, 76, 164, 0.4),
        inset 0 2px 4px rgba(255, 255, 255, 0.6);
      border-radius: 2px;
      animation: beamArrowPulse 3s ease-in-out infinite;
    }

    @keyframes beamArrowPulse {

      0%,
      100% {
        transform: translateX(-50%) scale(1);
        box-shadow:
          0 -4px 10px rgba(99, 179, 255, 0.6),
          0 0 25px rgba(31, 76, 164, 0.35);
      }

      50% {
        transform: translateX(-50%) scale(1.1);
        box-shadow:
          0 -4px 14px rgba(99, 179, 255, 0.9),
          0 0 35px rgba(31, 76, 164, 0.5);
      }
    }

    .timeline .step {
      width: 50%;
      position: relative;
      padding: 2rem 2rem 5rem;
    }

    .timeline .step {
      left: 0;
      text-align: right;
    }

    .timeline .step:nth-of-type(2n) {
      left: 50%;
      text-align: left;
    }

    .timeline .step:nth-of-type(odd) .connector {
      right: -50px;
      bottom: 35px;
      transform: rotate(25deg);
    }

    .timeline .step:nth-of-type(even) .connector {
      left: -50px;
      bottom: 35px;
      transform: rotate(-25deg);
    }

    .timeline .step:nth-of-type(odd) .step-content {
      border-right: 6px solid var(--secondary);
      border-left: none;
    }

    .timeline .step:nth-of-type(even) .step-content {
      border-left: 6px solid var(--secondary);
      border-right: none;
    }

    .timeline .step-content {
      text-align: center !important;
    }

    .timeline .step-content h3,
    .timeline .step-content p {
      margin-left: auto;
      margin-right: auto;
    }

    @media (max-width: 768px) {
      .timeline .step-content {
        margin-left: 0 !important;
      }
    }

    /* ===== Readability C BRIDGE ===== */
    .bridge-evo.big {
      --fz-h: clamp(1.6rem, 1.2vw + 1.1rem, 2.2rem);
      --fz-sub: clamp(1.1rem, 0.6vw + 0.9rem, 1.35rem);
      --fz-cta: clamp(1.0rem, 0.55vw + 0.85rem, 1.18rem);
      --lh-tight: 1.2;
      --lh-normal: 1.55;
    }

    /* Headings */
#contenttop .bridge-head h3,
#contenttop .bridge-foot h3 {
      font-size: var(--fz-h);
      line-height: var(--lh-tight);
      letter-spacing: 0.2px;
    }

    /* ISO line  */
    .bridge-head p,
    .bridge-foot p {
      font-size: var(--fz-sub);
      line-height: var(--lh-normal);
      color: #3d4f7a;
      opacity: .95;
    }

    /* CTA button */
    .bridge-foot .bridge-cta .btn-medical {
      font-size: var(--fz-cta);
      padding: clamp(.9rem, 0.8vw + .6rem, 1.15rem) clamp(1.2rem, 1.2vw + 1rem, 1.8rem);
      border-radius: 999px;
      box-shadow: 0 10px 26px rgba(31, 76, 164, .18), inset 0 -2px 0 rgba(255, 255, 255, .25);
    }

    .bridge-foot .bridge-cta .btn-medical svg {
      width: 1.15em;
      height: 1.15em;
      margin-left: .5rem;
    }

    .bridge-foot {
      margin-top: clamp(1.6rem, 2.4vw, 3.4rem);
    }

    .energy-core {
      margin-bottom: clamp(1rem, 1.8vw, 2rem);
    }

    /* ----------------- Tablet  ----------------- */
    @media (max-width: 1024px) {
      .bridge-evo.big {
        --fz-h: clamp(1.5rem, 1vw + 1rem, 2rem);
        --fz-sub: clamp(1.05rem, 0.7vw + 0.85rem, 1.2rem);
        --fz-cta: clamp(.95rem, 0.6vw + .8rem, 1.1rem);
      }

      .bridge-wrap-evo {
        gap: 2.2rem;
      }
    }

    /* ----------------- Mobile  ----------------- */
    @media (max-width: 600px) {
      .bridge-evo.big {
        --fz-h: clamp(1.35rem, 4vw + 0.6rem, 1.7rem);
        --fz-sub: clamp(.98rem, 3.2vw + .5rem, 1.1rem);
        --fz-cta: clamp(.95rem, 3vw + .55rem, 1.05rem);
      }

      .bridge-wrap-evo {
        padding: 5rem 1rem 5rem;
        gap: 1.6rem;
      }

      .bridge-head p,
      .bridge-foot p {
        max-width: 90ch;
        margin-inline: auto;
      }

      .bridge-foot .bridge-cta .btn-medical {
        padding: .9rem 1.35rem;
      }

      .bridge-foot {
        margin-top: 2.1rem;
      }
    }

    @media (max-width: 380px) {
      .bridge-evo.big {
        --fz-h: 1.25rem;
        --fz-sub: .95rem;
        --fz-cta: .95rem;
      }

      .bridge-foot .bridge-cta .btn-medical {
        padding: .85rem 1.1rem;
      }
    }

    .beam-label {
      position: absolute;
      left: 50%;
      transform: translate(-50%, -50%);
      display: inline-block;
      padding: .32rem .6rem;
      border-radius: 8px;
      background: rgba(255, 255, 255, .92);
      color: #0d2c6b;
      font-weight: 600;
      font-size: 1rem;
      line-height: 1.2;
      white-space: nowrap;
      box-shadow: 0 3px 10px rgba(31, 76, 164, .12);
    }

    .lbl-innovation {
      top: 18%;
    }

    .lbl-reliability {
      top: 50%;
    }

    .lbl-expertise {
      top: 82%;
    }

    .beam-label.left {
      transform: translate(-150%, -50%);
      text-align: right;
    }

    .beam-label.right {
      transform: translate(60%, -50%);
      text-align: left;
    }

    .bridge-evo.big {
      overflow-x: hidden;
    }

    @media (max-width: 1024px) {
      .energy-core {
        height: clamp(440px, 60vh, 640px);
      }

      .beam {
        width: 3px;
      }

      .beam-glow {
        width: 8px;
      }

      .beam-label {
        font-size: .98rem;
      }

      .beam-label.left {
        transform: translate(-165%, -50%);
      }

      .beam-label.right {
        transform: translate(75%, -50%);
      }
    }

    @media (max-width: 768px) {
      .bridge-wrap-evo {
        gap: 1.6rem;
        padding: 5rem 1rem;
      }

      .energy-core {
        height: clamp(380px, 58vh, 520px);
      }

      .spark {
        display: none;
      }

      .beam {
        width: 3px;
      }

      .beam-glow {
        width: 7px;
      }

      .beam-label {
        font-size: .92rem;
        padding: .28rem .55rem;
      }

      .beam-label.left {
        transform: translate(-185%, -50%);
      }

      .beam-label.right {
        transform: translate(95%, -50%);
      }
    }

    @media (max-width: 430px) {
      .energy-core {
        height: clamp(340px, 56vh, 480px);
      }

      .beam-label {
        font-size: .88rem;
        padding: .26rem .5rem;
      }

      .beam-label.left {
        transform: translate(-200%, -50%);
      }

      .beam-label.right {
        transform: translate(110%, -50%);
      }
    }

    @media (max-width: 360px) {
      .beam-label {
        font-size: .84rem;
      }

      .beam-label.left {
        transform: translate(-210%, -50%);
      }

      .beam-label.right {
        transform: translate(120%, -50%);
      }
    }

    .beam-label {
      position: absolute;
      left: 50%;
      transform: translate(-50%, -50%);
      display: inline-block;
      padding: .38rem .7rem;
      border-radius: 999px;
      background: #fff;
      border: 1px solid rgba(15, 40, 90, .12);
      box-shadow: 0 6px 18px rgba(31, 76, 164, .18);
      color: #0d2c6b;
      font-weight: 700;
      font-size: 1rem;
      line-height: 1.2;
      white-space: nowrap;
    }

    .lbl-innovation {
      top: 18%;
    }

    .lbl-reliability {
      top: 50%;
    }

    .lbl-expertise {
      top: 82%;
    }

    .beam-label.left {
      transform: translate(-165%, -50%);
      text-align: right;
    }

    .beam-label.right {
      transform: translate(85%, -50%);
      text-align: left;
    }

    .beam-label::after {
      content: "";
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      width: 0;
      height: 0;
      filter: drop-shadow(0 2px 2px rgba(31, 76, 164, .15));
    }

    .beam-label.left::after {
      right: -10px;
      border-top: 7px solid transparent;
      border-bottom: 7px solid transparent;
      border-left: 10px solid #fff;
    }

    .beam-label.right::after {
      left: -10px;
      border-top: 7px solid transparent;
      border-bottom: 7px solid transparent;
      border-right: 10px solid #fff;
    }

    .hero h1::after,
    .bridge-head h3::after,
    .bridge-foot h3::after {
      content: none !important;
    }

    .btn-medical,
    .btn-medical:hover,
    .btn-medical:focus {
      text-decoration: none !important;
    }

    @media (max-width:1024px) {
      .beam-label {
        font-size: .98rem;
        padding: .32rem .62rem;
      }

      .beam-label.left {
        transform: translate(-180%, -50%);
      }

      .beam-label.right {
        transform: translate(100%, -50%);
      }
    }

    @media (max-width:768px) {
      .beam-label {
        font-size: .92rem;
        padding: .28rem .56rem;
      }

      .beam-label.left {
        transform: translate(-195%, -50%);
      }

      .beam-label.right {
        transform: translate(115%, -50%);
      }
    }

    @media (max-width:430px) {
      .beam-label {
        font-size: .88rem;
        padding: .26rem .5rem;
      }

      .beam-label.left {
        transform: translate(-210%, -50%);
      }

      .beam-label.right {
        transform: translate(128%, -50%);
      }
    }

    /* ==== REMOVE BLUE UNDERLINE  ==== */
    .beam-label span::after,
    .beam-tag span::after {
      content: none !important;
      display: none !important;
      background: none !important;
      box-shadow: none !important;
    }

    @media (max-width: 768px) {
      .timeline {
        width: 100%;
        max-width: 720px;
        margin: 3rem auto;
        padding: 0 1rem;
        position: relative;
      }

      .timeline::before {
        content: "";
        position: absolute;
        top: 0;
        left: 28px;
        width: 3px;
        height: 100%;
        background: linear-gradient(to bottom, var(--primary), var(--secondary));
        opacity: .3;
      }

      .step {
        display: grid;
        grid-template-columns: 56px 1fr;
        column-gap: 12px;
        align-items: start;
        width: 100%;
        padding: 1.2rem 0;
        text-align: left !important;
        left: 0 !important;
      }

      .step-icon {
        position: static;
        width: 56px;
        height: 56px;
        border-radius: 50%;
        background: linear-gradient(135deg, var(--primary), var(--secondary));
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 4px 15px rgba(0, 0, 0, .15);
        margin-top: .25rem;
        z-index: 1;
      }

      .step-icon svg {
        width: 26px;
        height: 26px;
        stroke: #fff;
        stroke-width: 1.6;
      }

      .connector {
        display: none !important;
      }

      .step-content {
        grid-column: 2 / 3;
        width: 100%;
        background: #fff;
        padding: 1.3rem 1.1rem;
        border-radius: 16px;
        border-left: 5px solid var(--secondary) !important;
        border-right: none !important;
        box-shadow: 0 6px 18px rgba(0, 0, 0, .06);
        transition: transform .25s ease, box-shadow .25s ease;
        word-wrap: break-word;
      }

      .step-content:hover {
        transform: translateY(-3px);
        box-shadow: 0 10px 22px rgba(31, 76, 164, .14);
      }

#contenttop .step h3 {
        margin: 0 0 .35rem;
        font-size: 1.06rem;
        font-weight: 600;
        color: var(--primary);
        line-height: 1.3;
      }

      .step p {
        font-size: .96rem;
        line-height: 1.55;
        color: var(--muted);
        margin: 0;
      }

      .step:nth-child(odd) .step-content,
      .step:nth-child(even) .step-content {
        border-left: 5px solid var(--secondary) !important;
      }
    }

    @media (max-width: 480px) {
      .timeline {
        padding: 0 .8rem;
      }

      .timeline::before {
        left: 24px;
        width: 2.5px;
      }

      .step {
        grid-template-columns: 52px 1fr;
        column-gap: 10px;
        padding: 1rem 0;
      }

      .step-icon {
        width: 52px;
        height: 52px;
      }

      .step-icon svg {
        width: 24px;
        height: 24px;
      }

      .step-content {
        padding: 1rem .9rem;
        border-left-width: 4px !important;
        border-radius: 14px;
      }

#contenttop .step h3 {
        font-size: 1rem;
      }

      .step p {
        font-size: .9rem;
        line-height: 1.5;
      }
    }

    @media (max-width: 768px) {
      .timeline {
        width: 100%;
        max-width: 720px;
        margin: 3rem auto;
        padding: 0 0.5rem;
        position: relative;
      }

      .timeline::before {
        content: "";
        position: absolute;
        top: 0;
        left: 32px;
        width: 3px;
        height: 100%;
        background: linear-gradient(to bottom, var(--primary), var(--secondary));
        opacity: 0.3;
        border-radius: 2px;
      }

      .step {
        display: grid;
        grid-template-columns: 64px 1fr;
        align-items: start;
        gap: 1rem;
        padding: 1.5rem 0;
        width: 100%;
        text-align: left !important;
        position: relative;
      }

      .step-icon {
        position: relative;
        width: 56px;
        height: 56px;
        border-radius: 50%;
        background: linear-gradient(135deg, var(--primary), var(--secondary));
        display: flex;
        align-items: center;
        justify-content: center;
        box-shadow: 0 4px 15px rgba(0, 0, 0, 0.15);
        z-index: 2;
        margin-left: 4px;
      }

      .step-icon svg {
        width: 26px;
        height: 26px;
        stroke: #fff;
        stroke-width: 1.6;
      }

      .step-content {
        grid-column: 2 / 3;
        background: #fff;
        border-radius: 16px;
        border-left: 5px solid var(--secondary);
        box-shadow: 0 6px 18px rgba(0, 0, 0, 0.06);
        padding: 1.4rem 1.2rem;
        width: 100%;
        max-width: 100%;
        transition: transform 0.3s ease, box-shadow 0.3s ease;
      }

      .step-content:hover {
        transform: translateY(-3px);
        box-shadow: 0 10px 25px rgba(31, 76, 164, 0.14);
      }

#contenttop .step h3 {
        font-size: 1.15rem;
        color: var(--primary);
        font-weight: 600;
        margin-bottom: 0.4rem;
      }

      .step p {
        font-size: 0.97rem;
        color: var(--muted);
        line-height: 1.55;
        margin: 0;
      }

      .connector {
        display: none !important;
      }
    }

    @media (max-width: 480px) {
      .timeline {
        padding: 0 0.3rem;
      }

      .timeline::before {
        left: 26px;
        width: 2.5px;
      }

      .step {
        grid-template-columns: 56px 1fr;
        gap: 0.8rem;
        padding: 1.2rem 0;
      }

      .step-icon {
        width: 50px;
        height: 50px;
        margin-left: 2px;
      }

      .step-icon svg {
        width: 24px;
        height: 24px;
      }

      .step-content {
        border-left-width: 4px;
        padding: 1rem 0.9rem;
        border-radius: 14px;
      }

#contenttop .step h3 {
        font-size: 1rem;
      }

      .step p {
        font-size: 0.9rem;
        line-height: 1.5;
      }
    }

    /* ===== HERO on mobile ===== */
    @media (max-width: 768px) {
      .hero {
        position: relative;
        width: 100vw;
        max-width: 100vw;
        left: 50%;
        right: 50%;
        margin-left: -50vw;
        margin-right: -50vw;
        padding: 4.25rem clamp(1rem, 4vw, 2rem) 3.95rem;
        background: linear-gradient(180deg, #eef5ff 0%, #ffffff 95%);
      }

      .hero__inner {
        max-width: none;
        width: 100%;
      }

#contenttop .hero h1 {
        font-size: clamp(1.8rem, 5.6vw, 2.3rem);
        line-height: 1.25;
        margin-bottom: 1rem;
      }

      .hero p {
        max-width: 94%;
        font-size: 1rem;
        line-height: 1.6;
      }
    }

    @media (max-width: 430px) {
      .hero {
        padding: 3.5rem 1rem 2.3rem;
      }

#contenttop .hero h1 {
        font-size: clamp(1.6rem, 6.2vw, 2rem);
      }

      .hero p {
        max-width: 96%;
      }
    }

    .principles-sub {
      margin: .6rem auto 0;
      max-width: 58ch;
      font-size: clamp(1rem, 0.6vw + 0.85rem, 1.15rem);
      line-height: 1.95;
      letter-spacing: .2px;
      color: #3d4f7a;
      opacity: .95;
      text-wrap: pretty;
    }

    .bridge-head h3+.principles-sub::before {
      content: "";
      display: block;
      width: clamp(56px, 9vw, 96px);
      height: 3px;
      margin: .8rem auto .9rem;
      border-radius: 3px;
      background: linear-gradient(90deg, var(--primary), var(--secondary));
      opacity: .7;
    }

    @media (max-width: 480px) {
      .principles-sub {
        max-width: 62ch;
        font-size: 1rem;
        line-height: 1.6;
      }
    }

    .step-icon svg {
      width: 38px;
      height: 38px;
      stroke-width: 1.6;
      stroke-linecap: round;
      stroke-linejoin: round;
      transition: transform 0.3s ease, stroke 0.3s ease;
    }

    .step-icon:hover svg {
      transform: scale(1.08);
      stroke: #bcdfff;
    }

    .step-icon svg {
      transition: transform .25s ease;
    }

    .step:hover .step-icon svg {
      transform: translateY(-1px) scale(1.04);
    }

    @media (max-width: 820px) {
      .timeline .step {
        padding: 1.2rem 0 2.6rem;
      }

      .timeline .step:not(:last-child) {
        margin-bottom: 1.1rem;
      }

      .timeline .step .step-content {
        margin-right: 16px;
        width: calc(100% - 16px) !important;
        max-width: none !important;
      }
    }

    @media (max-width: 420px) {
      .timeline .step {
        padding-bottom: 2.9rem;
      }

      .timeline .step .step-content {
        margin-right: 14px;
        width: calc(100% - 14px) !important;
      }
    }

    /* === COLOR UPDATE  === */
#contenttop .why h2 {
      background: linear-gradient(180deg, #6B82C1 0%, #617dd2 55%, #708DD6 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
    }

#contenttop .reason h3 {
      background: linear-gradient(180deg, #6B82C1 0%, #000000 55%, #708DD6 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
    }

    .reason p {
      color: #46609c;
    }

#contenttop .why h2 {
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      -webkit-text-stroke: 0.5px rgba(15, 40, 90, 0.25);
      text-shadow:
        0 1px 0 rgba(0, 0, 0, 0.06),
        0 2px 14px rgba(12, 28, 80, 0.18);
    }

#contenttop .timeline .step-content h3 {
      color: #1c3f8a;
      background: none;
      -webkit-background-clip: unset;
      -webkit-text-fill-color: unset;
    }

#contenttop .timeline .step-content:hover h3 {
      filter: brightness(1.05);
    }

    .step-icon {
      background: linear-gradient(135deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%) !important;
    }

    .step:hover .step-icon {
      filter: brightness(1.03);
    }

#contenttop .bridge-head h3,
#contenttop .bridge-foot h3 {
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
    }

    /* === last changes on color edges === */
    .timeline .step-content {
      position: relative;
      overflow: hidden;
      border-left: none !important;
      border-right: none !important;
    }

    .timeline .step-content::before {
      content: "";
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      width: 6px;
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      border-top-left-radius: inherit;
      border-bottom-left-radius: inherit;
      z-index: 0;
    }

    .timeline .step:nth-child(odd) .step-content::before {
      left: auto;
      right: 0;
      border-radius: 0 18px 18px 0;
    }

    .timeline .step-content>* {
      position: relative;
      z-index: 1;
    }

    @media (max-width: 800px) {
      .timeline .step-content::before {
        width: 5px;
      }
    }

    @media (max-width: 480px) {
      .timeline .step-content::before {
        width: 4px;
      }
    }

    @media (max-width: 768px) {
      .timeline {
        width: 100% !important;
        max-width: 700px !important;
        margin: 3rem auto !important;
        padding: 0 1rem !important;
        position: relative !important;
      }

      .timeline::before {
        content: "";
        position: absolute !important;
        top: 0;
        left: 32px;
        width: 3px;
        height: 100%;
        background: linear-gradient(to bottom, var(--primary), var(--secondary));
        opacity: 0.35;
        border-radius: 2px;
        z-index: 0;
      }

      .step {
        display: grid !important;
        grid-template-columns: 60px 1fr;
        align-items: start;
        gap: 0.9rem;
        position: relative !important;
        width: 100% !important;
        text-align: left !important;
        padding: 1.2rem 0 !important;
        left: 0 !important;
      }

      .step-icon {
        position: relative !important;
        width: 56px !important;
        height: 56px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, var(--primary), var(--secondary)) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
        z-index: 2 !important;
      }

      .step-icon svg {
        width: 26px !important;
        height: 26px !important;
        stroke: #fff !important;
        stroke-width: 1.6 !important;
      }

      .step-content {
        background: #fff !important;
        border-radius: 18px !important;
        box-shadow: 0 6px 20px rgba(0, 0, 0, 0.07) !important;
        padding: 1.4rem 1.2rem !important;
        position: relative !important;
        border: none !important;
        overflow: hidden !important;
      }

      .step-content::before {
        content: "" !important;
        position: absolute !important;
        top: 0 !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 5px !important;
        background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%) !important;
        border-top-left-radius: inherit !important;
        border-bottom-left-radius: inherit !important;
        z-index: 0 !important;
      }

      .step-content>* {
        position: relative !important;
        z-index: 1 !important;
      }

#contenttop .step h3 {
        font-size: 1.05rem !important;
        font-weight: 600 !important;
        color: var(--primary) !important;
        margin-bottom: 0.35rem !important;
        line-height: 1.3 !important;
      }

      .step p {
        font-size: 0.95rem !important;
        color: var(--muted) !important;
        line-height: 1.55 !important;
        margin: 0 !important;
      }

      .connector {
        display: none !important;
      }
    }

    @media (max-width: 480px) {
      .timeline::before {
        left: 26px !important;
        width: 2.5px !important;
      }

      .step {
        grid-template-columns: 54px 1fr !important;
        gap: 0.8rem !important;
      }

      .step-icon {
        width: 50px !important;
        height: 50px !important;
      }

      .step-icon svg {
        width: 22px !important;
        height: 22px !important;
      }

      .step-content::before {
        width: 4px !important;
      }

      .step-content {
        border-radius: 14px !important;
        padding: 1rem 1rem !important;
      }

#contenttop .step h3 {
        font-size: 1.2rem !important;
      }

      .step p {
        font-size: 0.9rem !important;
        line-height: 1.5 !important;
      }
    }

    @media (max-width: 768px) {
      .timeline {
        width: 100% !important;
        max-width: 720px !important;
        margin: 4rem auto !important;
        padding: 0 1.2rem !important;
        position: relative !important;
      }

      .timeline::before {
        content: "";
        position: absolute !important;
        top: 0;
        left: 32px;
        width: 3px;
        height: 100%;
        background: linear-gradient(to bottom, var(--primary), var(--secondary));
        opacity: 0.25;
        border-radius: 2px;
        z-index: 0;
      }

      .step {
        display: grid !important;
        grid-template-columns: 64px 1fr;
        align-items: flex-start;
        gap: 1rem;
        position: relative !important;
        width: 100% !important;
        text-align: left !important;
        padding: 1.6rem 0 !important;
        left: 0 !important;
      }

      .step-icon {
        position: relative !important;
        width: 58px !important;
        height: 58px !important;
        border-radius: 50% !important;
        background: linear-gradient(135deg, var(--primary), var(--secondary)) !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
        margin-top: 0.4rem !important;
        z-index: 2 !important;
      }

      .step-icon svg {
        width: 28px !important;
        height: 28px !important;
        stroke: #fff !important;
        stroke-width: 1.6 !important;
      }

      .step-content {
        background: #fff !important;
        border-radius: 18px !important;
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06) !important;
        padding: 1.6rem 1.3rem !important;
        border: none !important;
        overflow: hidden !important;
        margin-top: 0.2rem !important;
      }

      .step-content::before {
        content: none !important;
      }

#contenttop .step h3 {
        font-size: 1.08rem !important;
        font-weight: 600 !important;
        color: var(--primary) !important;
        margin-bottom: 0.45rem !important;
        line-height: 1.35 !important;
      }

      .step p {
        font-size: 0.96rem !important;
        line-height: 1.6 !important;
        color: var(--muted) !important;
        margin: 0 !important;
      }

      .connector {
        display: none !important;
      }
    }

    @media (max-width: 480px) {
      .timeline {
        padding: 0 1rem !important;
      }

      .timeline::before {
        left: 26px;
        width: 2.5px;
      }

      .step {
        grid-template-columns: 56px 1fr;
        gap: 0.9rem;
        padding: 1.5rem 0 !important;
      }

      .step-icon {
        width: 52px !important;
        height: 52px !important;
      }

      .step-icon svg {
        width: 24px !important;
        height: 24px !important;
      }

      .step-content {
        padding: 1.2rem 1rem !important;
        border-radius: 16px !important;
        margin-top: 0.3rem !important;
      }

#contenttop .step h3 {
        font-size: 1rem !important;
      }

      .step p {
        font-size: 0.9rem !important;
        line-height: 1.55 !important;
      }
    }

    @media (max-width: 768px) {
      .timeline .step {
        margin-bottom: 2.8rem !important;
        padding: 1.8rem 0 !important;
      }

      .timeline .step-icon {
        margin-bottom: 1rem !important;
      }

      .timeline .step-content {
        padding: 1.8rem 1.4rem !important;
      }
    }

    @media (max-width: 480px) {
      .timeline .step {
        margin-bottom: 3rem !important;
        padding: 1.6rem 0 !important;
      }

      .timeline .step-icon {
        margin-bottom: 1.2rem !important;
      }

      .timeline .step-content {
        padding: 1.6rem 1.2rem !important;
      }
    }

    @media (max-width: 768px) {
      .timeline .step {
        margin-bottom: 3.5rem !important;
        padding: 1.2rem 0 !important;
      }

      .timeline .step-icon {
        margin-bottom: 1.4rem !important;
        transform: scale(0.9);
      }

      .timeline .step-content {
        padding: 1.3rem 1.1rem !important;
        border-radius: 14px !important;
        transform: scale(0.96);
      }

#contenttop .timeline .step h3 {
        font-size: 1.02rem !important;
      }

      .timeline .step p {
        font-size: 0.9rem !important;
        line-height: 1.55 !important;
      }
    }

    @media (max-width: 480px) {
      .timeline .step {
        margin-bottom: 4rem !important;
        padding: 1rem 0 !important;
      }

      .timeline .step-icon {
        margin-bottom: 1.5rem !important;
        transform: scale(0.88);
      }

      .timeline .step-content {
        padding: 1.1rem 0.9rem !important;
        transform: scale(0.94);
        border-radius: 13px !important;
      }

#contenttop .timeline .step h3 {
        font-size: 0.98rem !important;
      }

      .timeline .step p {
        font-size: 0.88rem !important;
        line-height: 1.5 !important;
      }
    }

    /* =====  BACKGROUND for brdige section  ===== */
    .bridge-evo.big.with-theme-bg {
      position: relative;
      isolation: isolate;
    }

    .bridge-evo.big.with-theme-bg::before {
      content: "";
      position: absolute;
      inset: 0;
      z-index: -1;
      background:
        radial-gradient(60rem 40rem at 12% 8%, rgba(68, 209, 255, 0.18), rgba(68, 209, 255, 0) 60%),
        radial-gradient(70rem 50rem at 85% 88%, rgba(0, 102, 204, 0.12), rgba(0, 102, 204, 0) 65%),
        linear-gradient(180deg, #f7fbff 0%, #eef6fd 60%, #f8fbff 100%);
      background-blend-mode: normal, normal, normal;
    }

    .bridge-evo.big.with-theme-bg::after {
      content: "";
      position: absolute;
      inset: 0;
      z-index: -1;
      pointer-events: none;
      background-image:
        repeating-linear-gradient(0deg,
          rgba(0, 64, 128, 0.035) 0px,
          rgba(0, 64, 128, 0.035) 1px,
          transparent 1px,
          transparent 22px),
        repeating-linear-gradient(90deg,
          rgba(0, 64, 128, 0.035) 0px,
          rgba(0, 64, 128, 0.035) 1px,
          transparent 1px,
          transparent 22px);
      mask-image: radial-gradient(85% 85% at 50% 50%, black 55%, transparent 100%);
      opacity: 0.6;
    }

    @media (max-width: 640px) {
      .bridge-evo.big.with-theme-bg::before {
        background:
          radial-gradient(50rem 35rem at 12% 8%, rgba(68, 209, 255, 0.20), rgba(68, 209, 255, 0) 60%),
          radial-gradient(60rem 40rem at 85% 88%, rgba(0, 102, 204, 0.14), rgba(0, 102, 204, 0) 65%),
          linear-gradient(180deg, #f6faff 0%, #eef6fd 60%, #f8fbff 100%);
      }
    }

    @media (prefers-reduced-transparency: reduce) {
      .bridge-evo.big.with-theme-bg::after {
        display: none;
      }
    }

    /* ===== CTA ARROW UPGRADE new ===== */
    .btn-medical svg {
      width: 20px;
      height: 20px;
      fill: none;
      stroke: currentColor;
      stroke-width: 2.2;
      transition: transform 0.35s ease, stroke 0.35s ease, filter 0.35s ease;
      transform-origin: center;
      filter: drop-shadow(0 0 2px rgba(68, 209, 255, 0.25));
    }

    .btn-medical:hover svg {
      transform: translateX(4px) scale(1.05);
      stroke: #44d1ff;
      filter: drop-shadow(0 0 6px rgba(68, 209, 255, 0.6));
    }

    @keyframes arrowPulse {

      0%,
      100% {
        transform: translateX(0);
        opacity: 1;
      }

      50% {
        transform: translateX(2px);
        opacity: 0.8;
      }
    }

    .btn-medical svg {
      animation: arrowPulse 2.6s ease-in-out infinite;
      animation-delay: 0.8s;
    }

    .btn-medical span {
      display: inline-flex;
      align-items: center;
      gap: 0.35rem;
    }

    /* ===== "Μάθετε περισσότερα" CTA under each timeline card ===== */
    .learn-more {
      display: inline-flex;
      align-items: center;
      gap: 0.4rem;
      margin-top: 1rem;
      font-weight: 600;
      font-size: 0.95rem;
      color: #1c3f8a !important;
      text-decoration: none;
      transition: color 0.3s ease, transform 0.3s ease;
    }

    .learn-more svg {
      width: 18px;
      height: 18px;
      stroke: currentColor;
      stroke-width: 2;
      fill: none;
      transition: transform 0.3s ease, stroke 0.3s ease;
    }

    .learn-more:hover {
      color: #1c3f8a !important;
      transform: translateX(2px);
    }

    .learn-more:hover svg {
      transform: translateX(4px);
      stroke: var(--beam-blue-cyan);
      filter: drop-shadow(0 0 4px rgba(99, 179, 255, 0.6));
    }

    @keyframes arrowFloat {

      0%,
      100% {
        transform: translateX(0);
      }

      50% {
        transform: translateX(2px);
      }
    }

    .learn-more svg {
      animation: arrowFloat 3s ease-in-out infinite;
      animation-delay: 1s;
    }

    /* ===== MODAL DESIGN ===== */
    .modal {
      position: fixed;
      inset: 0;
      display: none;
      align-items: center;
      justify-content: center;
      background: rgba(15, 40, 90, 0.45);
      backdrop-filter: blur(8px);
      z-index: 2000;
      animation: fadeIn 0.3s ease;
    }

    .modal.active {
      display: flex;
    }

    .modal-content {
      background: white;
      border-radius: 16px;
      max-width: 520px;
      width: 90%;
      padding: 2rem 1.8rem;
      position: relative;
      box-shadow:
        0 12px 30px rgba(31, 76, 164, 0.15),
        0 0 0 2px rgba(99, 179, 255, 0.15);
      border-top: 4px solid var(--secondary);
      animation: popUp 0.35s cubic-bezier(0.18, 0.89, 0.32, 1.28);
    }

#contenttop .modal-content h2 {
      color: var(--primary);
      font-size: 1.4rem;
      margin-bottom: 1rem;
      text-align: center;
    }

    .modal-content p {
      color: #455678;
      font-size: 1rem;
      line-height: 1.65;
      margin-bottom: 1rem;
      text-align: justify;
    }

    .modal-content ul {
      list-style: none;
      margin: 0;
      padding: 0;
    }

    .modal-content li {
      margin-bottom: 0.5rem;
      padding-left: 1.4rem;
      position: relative;
      color: #3d4f7a;
    }

    .modal-content li::before {
      content: "•";
      position: absolute;
      left: 0;
      color: var(--secondary);
      font-weight: bold;
    }

    .modal-close {
      position: absolute;
      top: 12px;
      right: 16px;
      font-size: 1.6rem;
      background: none;
      border: none;
      color: var(--primary);
      cursor: pointer;
      transition: transform 0.25s ease, color 0.25s ease;
    }

    .modal-close:hover {
      transform: scale(1.15);
      color: var(--secondary);
    }

    @keyframes fadeIn {
      from {
        opacity: 0;
      }

      to {
        opacity: 1;
      }
    }

    @keyframes popUp {
      0% {
        transform: scale(0.9);
        opacity: 0;
      }

      100% {
        transform: scale(1);
        opacity: 1;
      }
    }

    .modal {
      display: none;
      position: fixed;
      inset: 0;
      z-index: 999;
      background: rgba(0, 0, 0, 0.4);
      justify-content: center;
      align-items: center;
      padding: 1.5rem;
    }

    .modal.show {
      display: flex;
    }

    .modal-content {
      background: #fff;
      max-width: 620px;
      width: 100%;
      border-radius: 14px;
      padding: 1.8rem 1.6rem 1.6rem;
      position: relative;
      box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
    }

#contenttop .modal-content h2 {
      margin-top: 0;
      margin-bottom: 0.8rem;
    }

    .modal-content p {
      margin-bottom: 0.8rem;
      line-height: 1.6;
    }

    .modal-content ul {
      margin: 0 0 1rem;
      padding-left: 1.1rem;
    }

    .modal-content ul li {
      margin-bottom: 0.5rem;
    }

    .modal-content ul li ul {
      margin-top: 0.35rem;
      padding-left: 1.1rem;
      font-size: 0.92rem;
    }

    .support-cta {
      background: #f4f8fc;
      border-left: 4px solid #0a71b5;
      padding: 0.8rem 1rem;
      border-radius: 10px;
    }

    .support-cta p {
      margin: 0.25rem 0;
    }

    .modal-close {
      position: absolute;
      top: 0.5rem;
      right: 0.7rem;
      background: none;
      border: none;
      font-size: 1.6rem;
      cursor: pointer;
      line-height: 1;
    }

    .goal-block {
      margin-top: 1rem;
      background: radial-gradient(circle at top, #f4f8fc 0%, #ffffff 70%);
      border: 1px solid rgba(10, 113, 181, 0.12);
      border-left: 5px solid #4293c9;
      padding: 0.85rem 1rem 0.85rem 1rem;
      border-radius: 14px;
      font-weight: 500;
      line-height: 1.5;
      display: flex;
      gap: 0.6rem;
      align-items: flex-start;
    }

    .goal-block::before {
      font-size: 1.15rem;
      line-height: 1;
      margin-top: 0.1rem;
    }

    @media (max-width: 540px) {
      .goal-block {
        flex-direction: row;
        border-radius: 12px;
      }
    }

    .intro-text {
      font-size: 1rem;
      color: #2f3f55;
      line-height: 1.7;
      margin-bottom: 0.85rem;
      font-weight: 400;
    }

    .hero__accent {
      color: #6a89cb;
      text-shadow: 0 1px 0 rgba(255, 255, 255, 0.23);
    }

    @media (max-width: 768px) {
      .timeline .step-content {
        background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%) !important;
        border-radius: 18px !important;
        box-shadow:
          0 4px 10px rgba(31, 76, 164, 0.08),
          0 0 0 1px rgba(107, 130, 193, 0.12) !important;
        padding: 1.6rem 1.2rem !important;
        transition: all 0.3s ease;
      }

      .timeline .step-content:hover {
        transform: translateY(-3px);
        box-shadow:
          0 8px 20px rgba(31, 76, 164, 0.12),
          0 0 0 1px rgba(107, 130, 193, 0.2) !important;
      }

      .timeline .step-content::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        width: 5px;
        background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
        border-top-left-radius: 18px;
        border-bottom-left-radius: 18px;
      }

#contenttop .timeline .step-content h3 {
        font-size: 1.08rem !important;
        font-weight: 600;
        color: #1f4ca4 !important;
        margin-bottom: 0.45rem;
      }

      .timeline .step-content p {
        font-size: 0.95rem !important;
        color: #425379 !important;
        line-height: 1.6 !important;
      }

      .timeline .step {
        margin-bottom: 2.6rem !important;
      }
    }

    @media (max-width: 480px) {
      .timeline .step-content {
        padding: 1.3rem 1rem !important;
        border-radius: 14px !important;
        box-shadow:
          0 3px 10px rgba(31, 76, 164, 0.08),
          0 0 0 1px rgba(107, 130, 193, 0.12) !important;
      }

      .timeline .step-content::before {
        width: 4px;
      }

#contenttop .timeline .step-content h3 {
        font-size: 1rem !important;
      }

      .timeline .step-content p {
        font-size: 0.9rem !important;
      }
    }

    @media (max-width: 768px) {
      .timeline .step-content {
        padding: 1.9rem 1.4rem !important;
      }

      .timeline .step-content h3,
      .timeline .step-content p {
        letter-spacing: 0.3px !important;
      }

      .timeline .step-content p {
        line-height: 1.75 !important;
      }
    }

    @media (max-width: 480px) {
      .timeline .step-content {
        padding: 1.6rem 1.2rem !important;
      }

      .timeline .step-content h3,
      .timeline .step-content p {
        letter-spacing: 0.35px !important;
      }

      .timeline .step-content p {
        line-height: 1.8 !important;
      }
    }

    @media (max-width: 768px) {
      .timeline .step-content {
        position: relative;
        background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%) !important;
        border-radius: 18px !important;
        box-shadow:
          0 4px 10px rgba(31, 76, 164, 0.08),
          0 0 0 1px rgba(107, 130, 193, 0.12) !important;
        padding: 1.9rem 1.4rem 1.9rem 1.6rem !important;
        margin-left: -10px !important;
        letter-spacing: 0.3px !important;
        line-height: 1.75 !important;
        transition: all 0.3s ease;
      }

      .timeline .step-content::before {
        content: "";
        position: absolute;
        top: 0;
        bottom: 0;
        left: 0;
        width: 6px;
        background: linear-gradient(180deg, #1c4db0 0%, #1f4ca4 100%) !important;
        border-top-left-radius: 18px;
        border-bottom-left-radius: 18px;
      }

#contenttop .timeline .step-content h3 {
        font-size: 1.08rem !important;
        font-weight: 600 !important;
        color: #305eba !important;
        letter-spacing: 0.4px !important;
        margin-bottom: 0.55rem !important;
      }

      .timeline .step-content p {
        font-size: 0.95rem !important;
        color: #425379 !important;
        letter-spacing: 0.3px !important;
        line-height: 1.75 !important;
      }

      .timeline .step {
        margin-bottom: 2.8rem !important;
      }

      .timeline .step-content:hover {
        transform: translateY(-3px);
        box-shadow:
          0 8px 20px rgba(31, 76, 164, 0.12),
          0 0 0 1px rgba(107, 130, 193, 0.2) !important;
      }
    }

    @media (max-width: 480px) {
      .timeline .step-content {
        padding: 1.7rem 1.2rem 1.7rem 1.4rem !important;
        margin-left: -12px !important;
        border-radius: 15px !important;
        letter-spacing: 0.17px !important;
        line-height: 1.8 !important;
      }

      .timeline .step-content::before {
        width: 5px;
        background: #1f4ca4 !important;
      }

#contenttop .timeline .step-content h3 {
        font-size: 1rem !important;
      }

      .timeline .step-content p {
        font-size: 0.9rem !important;
      }
    }

    @media (max-width: 768px) {
      .bridge-evo.big .beam-label {
        left: 50% !important;
        transform: translate(-50%, -50%) !important;
        margin: 0 !important;
        z-index: 2;
      }

      .bridge-evo.big .beam-label.left {
        transform: translate(calc(-50% - 72px), -50%) !important;
      }

      .bridge-evo.big .beam-label.right {
        transform: translate(calc(-50% + 72px), -50%) !important;
      }

      .bridge-evo.big .beam-label::after {
        content: "" !important;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 0;
        height: 0;
        filter: drop-shadow(0 2px 2px rgba(31, 76, 164, .15));
      }

      .bridge-evo.big .beam-label.left::after {
        right: -8px;
        border-top: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-left: 8px solid #fff;
      }

      .bridge-evo.big .beam-label.right::after {
        left: -8px;
        border-top: 6px solid transparent;
        border-bottom: 6px solid transparent;
        border-right: 8px solid #fff;
      }

      .bridge-evo.big .beam-label::before {
        content: "";
        position: absolute;
        top: 50%;
        width: 8px;
        height: 2px;
        background: linear-gradient(90deg, rgba(99, 179, 255, .65), rgba(31, 76, 164, .65));
        opacity: .75;
        transform: translateY(-50%);
        filter: blur(.2px);
      }

      .bridge-evo.big .beam-label.left::before {
        right: -4px;
      }

      .bridge-evo.big .beam-label.right::before {
        left: -4px;
      }

      .bridge-evo.big .lbl-innovation {
        top: 26% !important;
      }

      .bridge-evo.big .lbl-reliability {
        top: 50% !important;
      }

      .bridge-evo.big .lbl-expertise {
        top: 74% !important;
      }
    }

    @media (max-width: 430px) {
      .bridge-evo.big .beam-label.left {
        transform: translate(calc(-50% - 62px), -50%) !important;
      }

      .bridge-evo.big .beam-label.right {
        transform: translate(calc(-50% + 62px), -50%) !important;
      }
    }

    @media (max-width: 768px) {
      .timeline .step-content {
        position: relative !important;
        background: linear-gradient(180deg, #ffffff 0%, #f8faff 100%) !important;
      }

      .timeline .step-icon {
        background: #6B82C1 !important;
        box-shadow:
          0 6px 18px rgba(31, 76, 164, .18),
          inset 0 0 0 2px rgba(255, 255, 255, .35) !important;
      }

      .timeline .step-icon svg {
        stroke: #fff !important;
        opacity: .95;
      }
    }

    @media (max-width: 480px) {
      .timeline .step-content::before {
        width: 9px;
        top: 8px;
        bottom: 8px;
      }

      .timeline .step-content::after {
        left: 3px;
        top: 10px;
        bottom: 10px;
        width: 3px;
      }

      .timeline .step-icon {
        transform: translateY(1px);
      }

      /* tiny optical nudge */
    }

    @media (max-width: 768px) {

      .timeline .step-content::before,
      .timeline .step-content::after {
        content: none !important;
        display: none !important;
      }

      .timeline .step-content {
        position: relative !important;
        background-image:
          linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(255, 255, 255, 0.65)),
          linear-gradient(180deg, #1f4ca4, #1f4ca4),
          linear-gradient(180deg, #ffffff, #f8faff);
        background-size:
          10px 100%,
          3px 100%,
          100% 100%;
        background-position:
          0 0,
          3.5px 0,
          0 0;
        background-repeat: no-repeat;
        border-radius: 18px !important;
        box-shadow:
          0 6px 18px rgba(31, 76, 164, 0.10),
          0 0 0 1px rgba(107, 130, 193, 0.14) !important;
        padding: 1.9rem 1.4rem 1.9rem 1.6rem !important;
      }

      .timeline .step-content {
        --edge-glow: 0 0 8px rgba(31, 76, 164, .28);
        filter: drop-shadow(var(--edge-glow));
      }

      .timeline .step-icon {
        background: #6B82C1 !important;
        box-shadow:
          0 6px 18px rgba(31, 76, 164, .18),
          inset 0 0 0 2px rgba(255, 255, 255, .35) !important;
      }

      .timeline .step-icon svg {
        stroke: #fff !important;
        opacity: .95 !important;
      }
    }

    @media (max-width: 480px) {
      .timeline .step-content {
        background-size: 9px 100%, 3px 100%, 100% 100%;
        background-position: 0 0, 3px 0, 0 0;
        padding-left: 1.4rem !important;
        border-radius: 15px !important;
      }
    }

    /* === CERTIFICATIONS background === */
    .certs {
      position: relative;
      color: #fff;
      --certs-start: #5f73a9;
      --certs-mid: #566da4;
      --certs-end: #4b629b;
      background: linear-gradient(180deg,
          var(--certs-start) 0%,
          var(--certs-mid) 55%,
          var(--certs-end) 100%) !important;
      padding: 12rem 7rem;
    }

    .certs::after {
      content: "";
      position: absolute;
      inset: 0;
      pointer-events: none;
      background:
        repeating-linear-gradient(135deg,
          rgba(255, 255, 255, 0.05) 0px,
          rgba(255, 255, 255, 0.05) 8px,
          rgba(255, 255, 255, 0.02) 8px,
          rgba(255, 255, 255, 0.02) 16px),
        radial-gradient(120% 90% at 50% 10%, rgba(255, 255, 255, 0.06), transparent 60%),
        radial-gradient(120% 90% at 50% 90%, rgba(0, 0, 0, 0.10), transparent 60%);
      mix-blend-mode: soft-light;
      opacity: 0.9;
    }

    @media (max-width: 768px) {
      .certs {
        padding: 6rem 1.5rem;
      }

      .certs::after {
        opacity: 0.75;
      }
    }

    @media (max-width: 480px) {
      .certs::after {
        opacity: 0.7;
      }
    }

    .certs::after {
      content: "";
      position: absolute;
      inset: 0;
      pointer-events: none;
      background:
        repeating-linear-gradient(135deg,
          rgba(255, 255, 255, 0.03) 0px,
          rgba(255, 255, 255, 0.03) 1px,
          rgba(255, 255, 255, 0.00) 20px),
        radial-gradient(120% 90% at 50% 12%, rgba(255, 255, 255, 0.05), transparent 60%),
        radial-gradient(120% 90% at 50% 88%, rgba(0, 0, 0, 0.10), transparent 60%);
      mix-blend-mode: soft-light;
      opacity: .9;
    }

    @media (max-width:768px) {
      .certs::after {
        opacity: .75;
      }
    }

    @media (max-width: 768px) {
      .cert-grid {
        grid-template-columns: 1fr !important;
        justify-items: center !important;
        max-width: 480px !important;
        margin: 0 auto !important;
        row-gap: 1.6rem !important;
      }

      .cert-card {
        --card-min-h: 200px;
        display: grid !important;
        grid-template-rows: auto auto 1fr;
        align-items: start;
        justify-items: center;
        text-align: center;
        width: 100% !important;
        max-width: 330px !important;
        min-height: var(--card-min-h) !important;
        padding: 1.6rem 1.2rem !important;
        border-radius: 18px !important;
        background: rgba(255, 255, 255, 0.10) !important;
        backdrop-filter: blur(10px) !important;
        border: 1px solid rgba(255, 255, 255, 0.22) !important;
        box-shadow:
          0 4px 14px rgba(31, 76, 164, 0.15),
          inset 0 0 0 1px rgba(255, 255, 255, 0.08) !important;
      }

      .cert-card svg {
        width: 42px !important;
        height: 42px !important;
        margin-bottom: .8rem !important;
        stroke: #fff !important;
        opacity: .9;
      }

#contenttop .cert-card h3 {
        margin: 0 0 .4rem !important;
        font-size: 1.05rem !important;
        font-weight: 700 !important;
      }

      .cert-card p {
        font-size: .95rem !important;
        line-height: 1.55 !important;
        opacity: .88 !important;
        align-self: stretch;
        margin: 0 !important;
      }
    }

    @media (max-width: 480px) {
      .cert-card {
        --card-min-h: 190px;
        max-width: 310px !important;
        border-radius: 16px !important;
        padding: 1.4rem 1rem !important;
      }
    }

#contenttop .hero h1 span {
      background: none;
      -webkit-text-fill-color: initial;
      color: #0f2c6b;
    }

    .hero__accent {
      background: linear-gradient(180deg, #6B82C1 0%, #6780C8 55%, #708DD6 100%);
      -webkit-background-clip: text;
      color: transparent;
    }

    .hero__inner h1+.hero__lead::before {
      content: none !important;
    }

#contenttop .hero h1 {
      color: #5E78B6;
    }

#contenttop .hero h1 span {
      background: none !important;
      -webkit-text-fill-color: initial !important;
      color: inherit !important;
    }

    .hero__accent {
      background: none !important;
      -webkit-text-fill-color: initial !important;
      color: inherit !important;
    }

    .hero__inner h1+.hero__lead::before {
      content: none !important;
    }

    :root .lang-en {
      display: none !important;
    }

    html.lang-en .lang-en {
      display: initial !important;
    }

    html.lang-en .lang-el {
      display: none !important;
    }

    body[data-lang="en"] .lang-en {
      display: initial !important;
    }

    body[data-lang="en"] .lang-el {
      display: none !important;
    }

/* -----------------------------
   Last changes services
------------------------------ */


.modal {
  padding: 20px;
}

.modal-content {
  max-height: 90vh;
  overflow-y: auto;
  padding: 25px;
  border-radius: 12px;
}


@media (max-width: 992px) {
  .modal-content {
    width: 95% !important;
    max-height: 85vh !important;
    font-size: 15px !important;
    line-height: 1.5 !important;
  }

  .modal-content h2 {
    font-size: 20px !important;
    line-height: 1.3;
  }

  .modal-content ul,
  .modal-content p {
    font-size: 15px !important;
  }

  .modal-close {
    font-size: 32px;
    top: 10px;
    right: 15px;
  }
}


@media (max-width: 576px) {
  .modal-content {
    padding: 18px !important;
    max-height: 80vh !important;
    width: 92% !important;
  }

  .modal-content h2 {
    font-size: 18px !important;
  }

  .modal-content p,
  .modal-content ul {
    font-size: 14px !important;
  }
}



@media (max-width: 992px) {


  .timeline .step {
    display: flex;
    flex-direction: column;
    padding-left: 0 !important;
    position: relative;
    margin-top: 35px;
  }

 
  .timeline .step::before {
    content: "";
    width: 100%;
    height: 10px;
    background: #1f4ca4; 
    border-radius: 10px;
    box-shadow: 0 0 12px rgba(31, 76, 164, 0.35);
    margin-bottom: 18px;
    display: block;
  }


  .timeline .step {
    border-left: none !important;
    background-image: none !important;
  }


  .timeline .step-content h3 {
    color: #1f4ca4 !important;
  }

  .timeline .step-icon svg {
    stroke: #ffffff;
  }
}


@media (max-width: 576px) {
  .timeline .step::before {
    height: 8px;
    border-radius: 8px;
  }
}



@media (max-width: 992px) {

  .timeline .step {
    display: flex;
    flex-direction: column;
    padding-left: 0 !important;
    background-image: none !important;
    position: relative;
    margin-top: 40px;
  }

  
  .timeline .step::before {
    content: "";
    width: 100%;
    height: 6px;               
    background: #6E89C3;        
    border-radius: 6px;
    display: block;
    margin-bottom: 14px;
    box-shadow: 0 0 8px rgba(110, 137, 195, 0.35);  
  }

  
  .timeline .step-content h3 {
    color: #6E89C3 !important;
  }
}


@media (min-width: 993px) {
  .timeline .step {
    border-left-color: #6E89C3 !important;
  }
}


/* ===== FIX BULLET STYLES IN POPUPS / REMOVE CUSTOM DOT DESIGN ===== */

.step-content ul,
.step-content li {
    list-style: disc !important;     /* classic black dots */
    margin-left: 1.2rem !important;  /* proper spacing */
    padding-left: 0 !important;
}

.step-content ul {
    list-style-position: outside !important;
}

/* Remove custom pseudo-element bullets from any design */
.step-content li::before {
    content: none !important;
    display: none !important;
}