@import url('https://fonts.googleapis.com/css2?family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

* {
	margin: 0;
	padding: 0;
}

body {
	font-family: Poppins, serif;
	font-size: 14px;
}

html, body {
    overflow-x: hidden;
    max-width: 100%;
}

.row>* {
	padding-right: calc(var(--bs-gutter-x) * 1);
    padding-left: 0;
}
.mobile-header, .mobile-menu { display: none; }
.menu {
	background: #F6F6F6; 
	/* filter: drop-shadow(0px 4px 4px rgba(0,0,0,0.25)); */
	margin-bottom: 95px;
}

.menu-right { 
	text-align: right;
	display: flex;
    justify-content: flex-end;
    align-items: center;
}
.menu-right a {
	padding-right: 40px;
	color: rgba(40, 40, 40, 0.7);
	text-decoration: none;
	
}
.menu-right a:hover { color: #000; }

.menu-right a.menu-cta { 
	background-color: #49B948;
    border-radius: 10px;
    text-align: right;
    color: #fff;
    display: inline-block;
    padding: 12px 20px;
	font-size: 12px;
}
.menu-right a.menu-cta:hover {
	background-color: #3A9438;
}

.hero-container { margin-bottom: 95px; }

.hero-subtitle { font-size: 21px; color: #282828; padding-bottom: 15px; }
.hero-title { font-size: 34px; font-weight: bold; color: #282828; line-height: 43px; padding-bottom: 10px; margin-bottom: 0; }
.hero-title .h { color: rgba(73, 185, 72, 1); }
.h { color: rgba(73, 185, 72, 1); }
.hero-intro { font-size: 21px; color: rgba(40, 40, 40, 0.8); padding-bottom: 40px; padding-right: 60px; /* 50px */ }
.hero-intro .h { color: rgba(73, 185, 72, 1); font-weight: 600; }

.hero-message { display: flex;
    flex-direction: column;
    justify-content: center;
}
.hero-img img { width: 100%; }
.hero-message.hero-message-right {
	padding-left: 85px;
}

.btn-inbp {
    border-radius: 100px;
    text-align: center;
    color: #fff;
    display: inline-block;
    padding: 19px 43.5px;
	text-decoration: none;
	border: 1px solid #49B948;
	margin-right: 10px;
}
.btn-inbp-primary {
	background-color: #49B948;
}
.btn-inbp-primary:hover {
	background-color: #3A9438;
	border-color: #3A9438;
}
.btn-inbp-secondary {
	background-color: transparent;
	color: #49B948;
	border: 1px solid #49B948;
	padding: 19px 33px;
}
.btn-inbp-secondary:hover {
	background-color: rgba(0, 0, 0, 0.1)
}

.bg-grey { background: #F6F6F6; }
.bg-black { backround: #000; }

/* Cards */
.cards-container {
	padding: 95px 0;
}
.row-cards { justify-content: space-evenly; display: flex; gap: 36px; }
.col-card { 
	/*width: calc(33.33333333% - 24px);
    margin-right: 36px;*/
    text-align: center;
    padding-right: 0;
	display: flex;
    flex-direction: column;
    flex: 1;
}
.col-card:last-child {
	margin-right: 0;
}
.card-img img { 
	width: 100%; 
	border-radius: 10px 10px 0 0;
}
.card-bottom {
	background: #fff;
	padding-bottom: 40px; 
	border-radius: 0 0 10px 10px;
	flex: 1;
}
.card-title { font-size: 21px; font-weight: 700; padding: 40px 0 15px 0; }
.card-desc { font-size: 13px; padding: 0 13%; color: #575558; margin-bottom: 25px;  }
.btn-inbp-more { padding: 9px 26px; font-size: 12px; }

/* Carousel */
.carousel-container {
	background: #FFF; 
	padding: 90px 0 40px;
}
.carousel-title {
	font-size: 34px;
	font-weight: 700;
	color: rgba(40, 40, 40, 1);
	margin-bottom: 20px;
}
.carousel-desc {
	font-size: 16px;
	font-weight: normal;
	color: rgba(87, 85, 88, 1);
}
.carousel-img img { border-radius: 16px; }
.carousel-left {
	display: flex;
    flex-direction: column;
    justify-content: center;
}

.carousel-item {
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.5s ease, visibility 0.5s ease;
	display: block !important;
}
.carousel-item.active {
  opacity: 1;
  visibility: visible;
  overflow: hidden;
}
.dots {
	/*position: absolute;
	bottom: 0;
	left: 0;
	transform: translateX(-50%);
	*/
	display: flex;
	justify-content: center;
	padding: 70px 0 0 0;
	border-radius: 10px;
}

.dot {
	width: 12px;
	height: 12px;
	margin: 0 5px;
	background-color: #C3C3C3;
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.3s;
}

.dot.active {
	background-color: #1F1F1F;
}

/* Services */
.services-container { padding: 90px 0; }
.page-student .services-container { padding: 90px 0 0 0 }

.service-list {  }
.service-item { width: 33.333%; padding-right: 10%; float: left; margin-bottom: 85px; }
.service-icon { width: 53px; margin-bottom: 8px; }
.service-title { font-size: 16px; font-weight: 600; margin-bottom: 6px; }
.page-buy .service-title { color: #282828; }
.service-desc { font-size: 16px; font-weight: normal; }

/* Location box */

.location-container {
	padding: 90px 0; 
}
.location-title {
	font-size: 26px;
	font-weight: 700;
	color: rgba(40, 40, 40, 1);
	margin-bottom: 5px;
}
.location-desc {
	font-size: 16px;
	font-weight: normal;
	color: rgba(87, 85, 88, 1);
	padding-top: 10px;
}
.location-address {
	padding-top: 20px;
	text-decoration: underline;
	font-size: 14px;
}
.col-location {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/* Gallery */
.gallery-container {
	padding: 90px 0;
	overflow-x: hidden;
}

#gallery { display: flex; gap: 50px; margin: 0; padding: 0; overflow: hidden; }
#gallery li { list-style: none; cursor: pointer; }

/* Media */
.media-container {
	padding: 95px 0;
}

.bg-media {
	background: #E2DAFF; 
}
.col-media-right { text-align:center; }
.col-media-left { 
	display: flex;
	flex-direction: column;
	justify-content: center;
}
.media-title {
	font-size: 26px;
	font-weight: 700;
	color: rgba(40, 40, 40, 1);
	margin-bottom: 10px;
	color: #281855;
}
.media-desc {
	font-size: 16px;
	font-weight: normal;
	color: rgba(87, 85, 88, 1);
	color: #291952;
}

/* Award */

.award-container { padding: 90px 0; text-align: center; }
.award-title {
	padding-top: 25px;
	font-size: 21px;
	font-weight: 700;
	color: rgba(40, 40, 40, 1);
	margin-bottom: 10px;
}
.award-desc {
	padding: 5px 25%;
	font-weight: normal;
	color: rgba(87, 85, 88, 1);
	font-size: 16px;
}

.footer-container { padding: 90px 0; }
.footer-container .footer-info { align-items: center; }
.bg-footer { background: #000; }
.footer-social { text-align:right; }
.footer-social img { width: 40px; }
.col-powered { text-align:center;color: #F6F6F6; font-size:16px;}
.footer-table { border-top: 1px solid #F6F6F6; margin-top:30px; padding-top: 30px; }
.footer-table ul { margin: 0; padding: 0; }
.footer-table ul li { margin: 0; padding: 0; list-style: none; padding-bottom: 15px; }
.footer-table a { color: rgba(246,246,246,0.7); font-size: 16px;text-decoration: none; }
.footer-table a:hover { color: #fff; }
.footer-table .col-end {
	flex-direction: column;
    justify-content: flex-end;
    display: flex;
    align-items: flex-end;
}
.footer-table .btn-inbp { padding: 10px 29px; font-size: 12px; color: #fff; margin-right: 0; }
.footer-table .col-end {text-align:right;}
/* BUY PAGE */

.apartment-type-container {
	padding: 95px 0;
}
.apartment-type-container .row-title { margin-bottom: 70px; }
.apartment-type-container .row-desc { font-size: 16px; padding-right: 60px; }
.apartment-type-card {
	width: 368px;
	float: left;
	margin-right: 50px;
	background: #fff;
	border-radius: 10px;
}
.apartment-type-content {
	padding: 20px;
	float: left;
	width: 100%;
}
.apartment-type-title {
	font-size: 16px;
	padding-bottom: 10px;
}
.apartment-type-desc {
	float: left;
	width: 60%;
	font-size: 12px;
}
.apartment-type-btn {
	float: left;
	width: 40%;
	text-align: right;
}
.apartment-type-info {
	display: block;
	width: 100%;
	background: url('../img/svg/person.svg') 0 0 scroll no-repeat;
	padding-left: 30px;
	margin-bottom: 9px;
	min-height: 20px;
	padding-top: 2px;
}
.apartment-type-price {
	display: block;
	width: 100%;
	background: url('../img/svg/euro.svg') 0 0 scroll no-repeat;
	padding-left: 30px;
	min-height: 20px;
	padding-top: 2px;
}
.apartment-type-btn .btn-inbp {
	padding: 11px 15px;
    font-size: 11px;
}

.phase-i-container {
	padding: 95px 0;
}

.phase-i-container .hero-intro {
	font-size: 17px;
    color: rgba(40, 40, 40, 0.8);
    padding-bottom: 40px;
    padding-right: 50px;
}
.phase-i-container .col-services {
	display: flex;
	flex-direction: row;
	align-content: center;
	justify-content: flex-end;
	align-items: center;
	gap: 100px;
	padding-right: 0;
}
.phase-i-container .service-item {
	width: auto;
	padding-right: 0;
}
.phase-i-container .service-desc {
	color: #575558;
}

.col-testimonals {
	display: flex;
	gap: 40px;
	padding-right: 0;
    margin-top: 3rem;
}
.col-testimonal { background: #fff; border-radius: 10px; position: relative; padding: 60px 14% 40px 40px; width: 50%; }
.col-testimonal img { position: absolute; top: -40px; left: 40px; }
.testimonal-name { font-size: 18px; font-weight: 600; margin-bottom: 10px; }
.testimonal-desc { line-height: 28px; }

/* Ownership */
.ownership-container {
    padding: 90px 0;
	color: #575558;
}
.ownership-left { display: flex; align-items: center; 7}
.ownership-top img { width: 100%; margin-bottom: 60px; }
.ownership-title { font-size: 24px; font-weight: 700; color: #282828; }
.ownership-desc { font-size: 14px; line-height: 21px; }
.row-ownership-services { margin-top: 60px; }

.ownership-container .col-services {
	display: flex;
	flex-direction: row;
	align-content: center;
	justify-content: flex-end;
	align-items: center;
	gap: 100px;
	padding-right: 0;
}
.ownership-container .service-item {
	width: auto;
	padding-right: 0;
}
.ownership-container .service-desc {
	color: #575558;
}

/*Brouscure*/
.broschure-container { 
	padding: 100px 0; 
	height: 402px; 
	text-align: center; 
	background: url('../img/broschure-bg.png') scroll no-repeat 50% 0; 
	display: flex; 
	align-items: center;
}
.broschure-title { color: #fff; font-size: 26px; font-weight: 600; padding-bottom: 10px; }
.broschure-desc { color: #B4B4B4; font-size: 16px; padding: 0 30% 30px; line-height: 26px; }
.broschure-btn { background: #49B948; color: #fff; font-size: 14px; padding: 19px 23.5px; }
.broschure-btn:hover { background-color: #3A9438; border-color: #3A9438;}


/* FAQ */
.faq-container { padding: 90px 0; font-size: 21px; }
.faq-title { text-align: center; font-size: 50px; font-weight: 600; padding-bottom: 50px; }
.faq-item { background: #F6F6F6; padding: 35px 40px; border-radius: 16px; position: relative; cursor: pointer; margin-bottom: 30px; }
.faq-item:last-child { margin-bottom: 90px; }
.faq-q { }
.faq-a { 
	opacity: 0;
    visibility: hidden;
	height: 0;
    transition: opacity 0.5s ease;
	font-size: 16px;
	border-top: 1px solid #A6A6A6;
	}
.faq-s { position: absolute; top: 35px; right: 35px; background: #000; color: #fff; border-radius: 100%; width: 40px; height: 40px; line-height: 40px; text-align: center; }
.faq-s::before { content: "+"; }

.faq-item.open .faq-a { opacity: 1; visibility: visible; height: auto; margin-top: 35px; padding-top: 20px; color: rgba(40, 40, 40, 0.8); }
.faq-item.open .faq-s::before { content: "-"; }

/* SERVICES */

.col-services {
	display: flex;
	flex-direction: row;
	align-content: center;
	justify-content: flex-end;
	align-items: center;
	gap: 100px;
	padding-right: 0;
}
.col-services .service-item {
	width: auto;
	padding-right: 0;
}

.student-location-container {
	padding: 90px 0 0 0;
}
.student-location-container .col-services {
	margin-top: 85px;
}
.phase-i-container-student { margin-bottom: 95px; }
.phase-i-container-student .col-testimonal { background: #F6F6F6; }
.phase-i-container-student .hero-container { margin-bottom: 0; }
.carousel-student-container { padding-top: 0; padding-bottom: 70px; }

.dark-hero-container { padding: 90px 0; height: 486px; text-align: center; background: url('../img/student-black-bg.png') scroll no-repeat 50% 0; display: flex; align-items: center; }
.dark-hero-title { color: #fff; font-size: 34px; font-weight: 600; padding-bottom: 30px;  }

/* search-container */
.apartment-list-container { margin: 65px 0 130px 0; }
.search-container { 	
	background: #000;
}
.search-box {
	background: rgba(0,0,0);
	background: url('../img/apartment-list.jpg');
	max-width: 1440px;
	height: 485px;
	margin: 0 auto;
	position: relative;
}
body.page-apartment-list .menu { margin-bottom: 0; }
.search-title { color: #fff; font-size: 50px; font-weight: 600; text-align: center; padding: 130px 0 70px 0; }

.search-bar {
	display: flex;
    background: #fff;
    border-radius: 100px;
    padding: 31px 45px;
    flex-direction: row;
    align-content: stretch;
    justify-content: space-around;
    align-items: center;
}
.search-btn { cursor: pointer; }
.search-dropdown { background: #F6F6F6; border-radius: 60px; margin-left: 16px; float: left; padding: 19px 39px; cursor: pointer; position: relative; }
.search-dropdown:hover { background: #D0D0D0; }
.search-dropdown-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100% }
.search-dropdown-title { float: left; }
.search-dropdown-arrow { float: left; margin-left: 18px; }

.search-dropdown-options { 
	position: absolute; top: 40px; left: 0; background: #fff; border-radius: 0 10px 10px 10px; padding: 22px 10px 5px 10px;
	opacity: 0;
    visibility: hidden;
	height: 0;
    transition: opacity 0.5s ease;
}
.search-dropdown.open .search-dropdown-options {
	opacity: 1;
    visibility: visible;
	height: auto;
	box-shadow: 0px 14px 74px 0px rgba(0, 0, 0, 0.4);
}
.search-dropdown-option .arrow { display: inline-block; width: 15px; height: 15px; background: #C6C6C6; border-radius: 3px; position: relative; top: 3px; margin-right: 14px; }
.search-dropdown-option { white-space: nowrap; padding: 10px 50px 10px 25px; }
.search-dropdown-option:hover { background: #ececec; }
/* .search-dropdown-option:hover .arrow, */
.search-dropdown-option.selected .arrow { background: #49B948 url('../img/svg/tick-white.svg') no-repeat 55% 55% / 11px auto; }
.search-dropdown-option:last-child { margin-bottom: 10px; }

.table-apartments thead { font-weight: 600; }
.table-apartments tr td { padding: 15px 10px; cursor: pointer; border: none; width: 12.5%; }
.table-apartments tr td.det { text-decoration: underline; }
.table-apartments thead img { width: 10px; left: 4px; position: relative; top: -1px; }
.table-apartments a { color: #000; text-decoration: none; }

.table-apartments tr td.status-Available-For-Sale { color: #49B948; }
.table-apartments tr td.status-Sold { color: #FF0000;  }

.table-striped>tbody>tr:nth-of-type(odd)>* { --bs-table-bg-type: #F6F6F6; }
.table-hover>tbody>tr:hover>* { background-color: #E4E3E3; }

#apartmentModal .modal-dialog { --bs-modal-margin: 0; }
@media (min-width: 1200px) {
    #apartmentModal .modal-xl {
        --bs-modal-width: 1152px;
    }
	#contactModal .modal-xl {
		--bs-modal-width: 1196px;
	}

}

.apartment-modal-content { padding: 0 8% }
.apartment-modal-content img.apartment-pic-top { width: 100%; }

.modal-content { border-radius: 10px; border: none; }
.modal-content iframe { border-radius: 10px; }
.btn-close.btn-close-back {
	background: transparent url('../img/arrow-left.svg') center / 1em auto no-repeat;
	width: 31px;
	height: 31px;
}

.pp-top .btn-close.btn-close-back {
    background: transparent url(../img/svg/arrow-left-grey.svg) left / 1em auto no-repeat !important;
    width: 21px;
    height: 31px;
	opacity: 1;
}

.txt-back { position: relative;
    top: -10px;
    font-size: 16px;
    color: rgba(40, 40, 40, 0.7);
    font-weight: 500;
    left: -4px;
}
.back { cursor: pointer; padding-top: 6px; }
.back:hover .txt-back {
	opacity: 1;
	color: #000;
}
.pp-top .back:hover .btn-close.btn-close-back {
	opacity: 1;
	background: transparent url(../img/svg/arrow-left-black.svg) left / 1em auto no-repeat !important;
}

.pp-top { height: 95px; padding: 25px 0px;  }
.pp-tab { padding: 12px 40px; border-radius: 60px; display: inline-block; border: 1px solid rgba(166, 166, 166, 1); margin: 0 4px; cursor: pointer; }
.pp-tab:hover { background: rgba(208, 208, 208, 1); border-color: rgba(208, 208, 208, 1); }
.pp-tab.active {  background: #282828; color: #fff; border: 1px solid #282828; }

.pp-tab-content { opacity: 0;
	visibility: hidden;
	height: 0;
	transition: opacity 0.5s ease, visibility 0.5s ease;
	display: none; }
.pp-tab-content.active { opacity: 1; visibility: visible; height: auto; display: block;  }

.pp-status { padding-top: 14px; }
.pp-status.Available-For-Sale { color: #49B948; }
.pp-status.Sold { color: #FF0000; }

.pp-content { padding-top: 37px; color: #282828; padding-bottom: 4rem; }
.pp-content h1 { font-size: 34px; font-weight: 600; }
.pp-content h2 { font-size: 19px; }
.pp-content .btn-inbp { padding: 19px 37.5px; margin-right: 0; }
.pp-desc { padding-top: 30px; padding-bottom: 37px; font-size: 19px; padding-right: 40px; color: rgba(40, 40, 40, 0.8) }

.pp-details { float: left; width: 100%; }
.pp-details-block { float: left; width: 50%; }
.pp-details-block ul li { font-size: 19px; padding-top: 12px; }
.pp-details-block ul { margin-bottom: 40px; }
.pp-detail-title { font-size: 24px; font-weight: 600; padding-bottom: 10px; }


.pp-top { float: left; width: 100%; }
.pp-row { float: left; width: 100%; margin-left: -12px; margin-right: -12px; }
.pp-col-left { float: left; width:20%;}
.pp-col-center { float: left; width:60%;}
.pp-col-right { float: left; width:20%;}
.pp-col-pp { position: relative; }
.pp-col-pp .btn-apartment-enquire { display: none; }

.btn-broschure { padding: 12px 40px; border-radius: 60px; display: inline-block; border: 1px solid #282828; margin: 0 4px; color: rgba(40, 40, 40, 0.8); margin-left: 10px; position: relative; top: -1px; 
	text-decoration: none;
}
.btn-broschure:hover { background: #A6A6A6; }

.modal { z-index: 99999; }
#contactModal .modal-content { flex-direction: row; height: 665px; }
#contactModal .contact-left { width: 43%; padding: 50px; color: #fff; }
#contactModal .contact-right { width: 57%; padding: 50px; color: #000; }

.error-message { font-size: 13px; padding-top: 4px; color: #da3232; }

#contactModal .contact-left { background: url('../img/contact-left-bg.png?v=3') no-repeat scroll 50% 9px; }
.contact-title { font-size: 28px; font-weight: 600; }
.contact-subtitle { font-size: 18px; font-weight: 300; }
.contact-information { margin-top: 104px; margin-bottom: 185px; }
.contact-information div { font-size: 16px; padding-left: 35px; margin-bottom: 49px; }
.contact-information .contact-phone { background: url('../img/svg/phone-call.svg') no-repeat scroll 0 0; }
.contact-information .contact-email { background: url('../img/svg/email.svg') no-repeat scroll 0 0; }
.contact-information .contact-address { background: url('../img/svg/location.svg') no-repeat scroll 0 0; }

.contact-social { position: absolute; bottom: 45px; left: 50px; }
.contact-social div { width: 30px; height: 30px; float: left; margin-right: 10px; position: relative; }
.contact-social .contact-whatsapp { background: url('../img/svg/contact-whatsapp.svg') no-repeat scroll 0 0; }
.contact-social .contact-facebook { background: url('../img/svg/contact-fb.svg') no-repeat scroll 0 0; }
.contact-social .contact-instagram { background: url('../img/svg/contact-instagram.svg') no-repeat scroll 0 0; }
.contact-social a { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.contact-form-fields { display: flex; display: flex; flex-direction: row; flex-wrap: wrap; }
.contact-form-field { width: 50%; margin-bottom: 45px; }
.contact-form-field input, .contact-form-field textarea { display: block; border: none; border-bottom: 1px solid #8D8D8D; color: #000; font-weight: 600; padding: 5px 0; }
.contact-form-field input:focus, .contact-form-field textarea:focus { outline: none; }
.contact-form-field label { display: block; font-size: 12px; color: #000; color: #8D8D8D; font-weight: 500; }

.contact-form-subjects { width: 100%; display: flex; font-size: 12px; }
.contact-form-subject-title { font-weight: 600; padding-bottom: 20px; }
.contact-form-subject-option:first-child { width: 45%; }
.contact-form-subject-option { cursor: pointer; width: 27.5%; background: url('../img/svg/checkbox.svg') no-repeat scroll 0 2px; padding-left: 23px;  }
.contact-form-subject-option.active { background: url('../img/svg/checkbox-checked.svg') no-repeat scroll 0 2px; }

.contact-form-fields-message { margin-top: 35px; }
.contact-form-fields-message .contact-form-field { width: 100%; }
.contact-form-fields-message textarea { width: 100%; min-height: 1.5em; /* height for one line */
    max-height: 200px; /* optional limit */
    resize: none;       /* prevent manual resizing */
    overflow: hidden;   /* hide scrollbars */
	box-sizing: border-box; }

.contact-form-btn { text-align: right; }	
.contact-form-btn .btn-inbp { border-radius: 5px; padding: 11px 36px; }

.about-fullwidth { background: #F6F6F6; text-align: center; padding-bottom: 100px; }
.about-top { padding: 100px 24.5%; }
.about-fullwidth-title { font-size: 34px; font-weight: 600; color: #282828; padding-bottom: 20px; }
.about-fullwidth-desc { font-size: 21px; font-weight: 400; color: #575558; }

.about-boxes { display: flex; }
.about-box { width: 49%; border-radius: 10px; background: #fff; padding: 50px 42px; text-align: left; }
.about-box:nth-child(1) { margin-right: 1%; }
.about-box:nth-child(2) { margin-left: 1%; }
.about-box-title { color: #282828; font-size: 26px; font-weight: 600; padding-bottom: 25px; }
.about-box-desc { color: #575558; font-size: 16px; }

.about-counters { margin: 95px 0; }
.counter-container {
	display: flex;
}
.counter-box { color: #282828; text-align: center; padding: 0 7%; width: 33.3333%; }
.counter-nr { font-size: 34px; font-weight: 700; }
.counter-desc { font-size: 16px; }

.about-title { font-size: 34px; text-align:center; font-weight: 600; color: #282828; padding-bottom: 50px; }

.about-activities { padding: 90px 0;  }
.about-activities-row { display: flex; gap: 4%; }
.about-activity-item { margin-bottom: 60px; }
.about-activity-title { font-size: 26px; font-weight: 700; text-align: center; margin-bottom: 5px; } 
.about-activity-desc { padding: 0 14%; text-align:center; }

.about-portfolio { padding: 90px 0;  }
.about-portfolio-row { display: flex; justify-content: space-evenly; gap: 4%; }

.about-portfolio-item { /*width: 294px; width: 30%; margin-right: 3.333%;*/ width: 100%; background: #fff; margin-bottom: 55px; border-radius: 10px; }
.about-portfolio-row.about-portfolio-row-second .about-portfolio-item { margin-bottom: 0; }
.about-portfolio-item img { width: 100%; }
.about-portfolio-item.transparent { background: transparent; }
.about-portfolio-info {  text-align: center; }
.about-portfolio-title { font-size: 20px; font-weight: 700; padding: 25px 0; }
.about-portfolio-desc { padding: 0 7% 60px 7%; font-size: 12px; }

.about-founder { display: flex; }
.about-founder .about-title { text-align:left; padding-bottom: 30px; }
.about-founder-left { width: 463px; }
.about-founder-right { padding: 0 105px 0 70px; font-size: 16px; display: flex; flex-direction: column; justify-content: center; }

/*.page-student h2 { font-size: 26px; font-weight: bold; line-height: 32px; }
.page-student h2.carousel-title { font-size: 32px; font-weight: bold; line-height: 38px; }*/
/*.page-student h1.hero-title { font-size: 34px; }*/

#apartment-type-carousel {
  position: relative;
  overflow: hidden;
  /*width: 100%;*/
  max-width: 1200px;
  margin: auto;
}
.no-select {
  -webkit-user-select: none; /* Chrome, Safari, iOS */
  -moz-user-select: none;    /* Firefox */
  -ms-user-select: none;     /* IE/Edge legacy */
  user-select: none;         /* Standard */
  -webkit-touch-callout: none; /* disable iOS long-press menu (optional) */
}
.carousel-track {
  display: flex;
  gap: 16px;
  transition: transform 0.4s ease-in-out;
  will-change: transform;
}

.apartment-type-card {
  flex: 0 0 368px;
  /*background: #fff;
  border-radius: 12px;
  box-shadow: 0 2px 10px rgba(0,0,0,0.1);*/
  overflow: hidden;
  box-sizing: border-box;
}

.apartment-type-pic img {
  width: 100%;
  display: block;
  height: auto;
}
/*
.apartment-type-content {
  padding: 16px;
}

.apartment-type-title {
  font-weight: bold;
  font-size: 1.1rem;
  margin-bottom: 8px;
}

.apartment-type-desc {
  font-size: 0.9rem;
  color: #555;
}

.apartment-type-price {
  font-weight: bold;
  margin-top: 4px;
}

.apartment-type-btn {
  margin-top: 12px;
}
*/
.carousel-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
 
  cursor: pointer;
  
  z-index: 5;
  transition: background 0.2s;
  
  background: rgba(0,0,0,0.5);
  color: #fff;
  border: none;
  font-size: 2rem;
  padding: 0.4rem 0.8rem;
  border-radius: 50%;
  
  display: none;
}

.carousel-btn:hover {
  background: rgba(0,0,0,0.7);
}

.carousel-btn.prev { left: 10px; }
.carousel-btn.next { right: 10px; }

/* Scrollbar hidden on mobile */
.carousel-track::-webkit-scrollbar {
  display: none;
}