.fpt-overlay{padding:0px;
position:fixed;
top:0px;
left:0;
width:100%;
height:100%;border-radius: 0;
background-color:#ffffff;
backdrop-filter:blur(12px);
-webkit-backdrop-filter:blur(12px);
display:none;
z-index:99999;
overflow:auto;
animation:fptFade .25s ease;
}
@keyframes fptSlide{
from{
transform:translateY(60px);
opacity:.4;
}
to{
transform:translateY(0);
opacity:1;
}
}
.thanh-tim-kiem .large-11{padding-bottom:0!important; padding-right: 0 !important;flex-basis:82%;max-width:82%}
.thanh-tim-kiem .large-1{flex-basis:18%;max-width:18%;padding-bottom:0 !important}
.fpt-close{
	top: 12px;
    right: -8px;
    position: fixed;
    width: 27px;
    height: 27px;
    border: none;
    border-radius: 50%;
    background: black;
    font-size: 18px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform .15s ease, background .15s;
    border: 2px solid black;
    color: white;z-index:9999
}

.fpt-close:active{
transform:scale(.9);
background:#e5e5ea;
}
.icon-search{max-width:24px}

.fpt-province-header{
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-weight: 600;
    font-size: 16px;
    padding: 0 0 8px 0px;
    cursor: pointer;
    color: black;
}
.count{
background:#eee;
padding:2px 6px;
border-radius:10px;
font-size:12px;
}
.fpt-search-bar input{
width:100%;
padding:10px 14px;
border-radius:30px;
border:1px solid #ddd;
} .fpt-search-bar input:focus{border:2px solid red !important}
.fpt-input::placeholder{color:#333;font-size:15px}
.fpt-input{    box-shadow: 2px 2px 5px #9eccec;
    width: 100%;
    font-size: 14px;
    padding: 12px;
    border-radius: 15px;
    border: 1.3px solid #007adb;
    margin-bottom: 0px !important;
}
#fpt-results{padding-top:12px}
.thanh-tim-kiem{display: flex;
    align-items: center;
    margin-bottom: 10px !important;
    padding-top: 5px;}
.fpt-search-header{
position: sticky;
    top: 0;
    background: #fff;
    z-index: 5;
    padding: 5px 10px 1px 10px;
    box-shadow:2px 2px 20px #80808042
}
.fpt-panel{
position:relative;transition:transform .2s ease;
will-change:transform;
}
.fpt-search-bar {
      display: flex;
    background: #ffffff;
    border-radius: 10px;
    color: black;
    line-height: 44px;
    padding-left: 10px;
    font-size: 15px;
    justify-content: space-between;
    padding-right: 10px;
}
.fpt-card .large-8{padding-bottom:10px;max-width: 65%;
    flex-basis: 65%;padding-left:0 !important}
.fpt-card .large-4{padding-bottom:10px;max-width: 35%;
    flex-basis: 35%;}
.fpt-card h4{font-size: 15px;
    line-height: 20px;
    margin-bottom: 4px;  -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;}
.fpt-card .col{padding-bottom:10px !important}
.fpt-card .dia-chi{    font-size: 14px;
    color: #888;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    line-height: 19px;}
.fpt-regions{justify-content: space-between;
display:flex;
gap:0px;
margin-bottom:7px;
}

.fpt-regions button{
padding: 0px 13px;
    border-radius: 10px;
    border: none;
    background: #eee;
    margin-right: 0 !important;
    text-transform: none;
    letter-spacing: 0;
    font-weight: normal;
    font-size: 14px;
    color: #333;
    border: 1px solid #d8d8d8;
}


.fpt-regions .active{
background:#007aff;
color:white;
}

#fpt-provinces{
display:flex;
flex-wrap:wrap;
gap:6px;
margin-bottom:15px;
}

.fpt-province{
background:#f1f1f1;
padding:4px 10px;
border-radius:12px;
font-size:12px;
cursor:pointer;
}

.fpt-card{
background:#fff;
border-radius:20px;
padding:10px;border: 1px solid #b5bbd5;
margin-bottom:10px;
box-shadow:
0 2px 6px rgba(0,0,0,.04),
0 8px 20px rgba(0,0,0,.05);
transition:transform .15s ease, box-shadow .15s ease;
}

.fpt-card:active{
transform:scale(.97);
box-shadow:
0 1px 4px rgba(0,0,0,.06);
}

.fpt-card img{
width:120px;
height:80px;
border-radius:12px;
object-fit:cover;
}
.fpt-card a img{height: auto;max-width:20px}
.fpt-card a{
display:inline-block;
padding:6px 14px;
border-radius:18px;
font-size:13px;
text-decoration:none;
}

.fpt-card a:first-child{
background:#ff7a00;
color:#fff;
}
body.fpt-lock-scroll{
position: fixed;
width: 100%;
overflow: hidden;
}
body.fpt-lock{
position:fixed;
width:100%;
overflow:hidden;
}
.fpt-drag{
width:50px;
height:5px;
background:white;
border-radius:5px;
margin:0 auto 14px;
}
.fpt-card a:nth-child(2){background:#0076d4;color:white}
.fpt-card a:last-child{
background:#3a8d5c;
color:#fff;
}

.fpt-province-header .count{background:#f1f1f4;

padding:4px 10px;

border-radius:12px;

font-size:12px;

color:#666;}
.fpt-actions{
display:flex;
gap:6px;
}

.fpt-actions a{
flex:1;
text-align:center;
padding: 5px 5px;
    border-radius: 10px;
font-size:14px;
font-weight:500;
transition:transform .12s;
}

.fpt-actions a:active{
transform:scale(.95);
}

.fpt-map{
background:#ff7a00;
color:#fff;
}

.fpt-phone{
background:#3a8d5c;
color:#fff;
}

.fpt-page{
background:#007aff;
color:#fff;
}

.fpt-province-header:after{
    content: "";
    transition: transform .2s;
    width: 15px;
    height: 15px;
    display: block;
    background-image: url(https://fschool.fpt.edu.vn/wp-content/uploads/2026/03/arrow-down-338-svgrepo-com.svg);
    background-repeat: no-repeat;
background-size: contain;
    margin-top: -3px;
}
.fpt-campus-list{
display:block;
overflow:hidden;
}
.fpt-province-header.open:after{
transform:rotate(180deg);
}
.fpt-province-group{background-image: linear-gradient(to bottom, #c3cdf8, #ffffff00);
    border-radius: 15px;
    padding: 10px;}
.thanh-tim-kiem{position:relative}