/*

TemplateMo 569 Edu Meeting

https://templatemo.com/tm-569-edu-meeting

*/

/* ---------------------------------------------
Table of contents
------------------------------------------------
01. font & reset css
02. reset
03. global styles
04. header
05. banner
06. features
07. testimonials
08. contact
09. footer
10. preloader
11. search
12. portfolio

--------------------------------------------- */
/*
---------------------------------------------
font & reset css
---------------------------------------------
*/
@import url("https://fonts.googleapis.com/css?family=Poppins:100,200,300,400,500,600,700,800,900");
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400..700&display=swap');

/*
---------------------------------------------
reset
---------------------------------------------
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
div pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
font,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
figure,
header,
nav,
section,
article,
aside,
footer,
figcaption {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
}

.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0;
}

.clearfix {
  display: inline-block;
}

html[xmlns] .clearfix {
  display: block;
}

* html .clearfix {
  height: 1%;
}

header,
nav,
section,
article,
aside,
footer,
hgroup {
  display: block;
}

* {
  box-sizing: border-box;
}

html,
body {
  font-weight: 400;
  background-color: #fff;
  font-size: 16px;
  -ms-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a {
  text-decoration: none !important;
  color: #0a58ca;
}

a:hover {
  color: #0a58ca;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0px;
  margin-bottom: 0px;
}

ul {
  margin-bottom: 0px;
}

ul,
li {
  padding: 0;
  margin: 0;
  list-style: none;
}

li {
  line-height: 30px;
}

ul.indent>li {
  margin-left: 0 !important;
}

ul.disc>li {
  list-style-type: disc;
}

ul.decimal>li {
  list-style-type: decimal;
}

ul.square>li {
  list-style-type: square;
}

ul.circle>li {
  list-style-type: circle;
}

ul.speaker>li {
  list-style-type: '\1F56A';
  padding-left: 10px;
}

ul.diamond>li {
  list-style-type: '\1F79B';
  padding-left: 5px;
}

ul.asterisk>li {
  list-style-type: '\1F7BA';
  padding-left: 5px;
}

ul.barb-arrow>li {
  list-style-type: '\1F86A';
}

ul.tick>li {
  list-style-image: url(/assets/images/tick.png);
}

ul.list-outside {
  list-style-position: outside;
}

ul.horizontal>li {
  display: inline;
}

li.none_style {
  list-style: none !important;
  margin-left: 0 !important;
}

p {
  font-size: 14px;
  line-height: 25px;
  color: #2a2a2a;
}

img {
  overflow: hidden;
}

/*
---------------------------------------------
global styles
---------------------------------------------
*/
html,
body {
  background: #fff;
  font-family: "Lora", "Noto Sans TC", sans-serif;
  font-optical-sizing: auto;
}

::selection {
  background: #f5a425;
  color: #fff;
}

::-moz-selection {
  background: #f5a425;
  color: #fff;
}

@media (max-width: 991px) {

  html,
  body {
    overflow-x: hidden;
  }

  .mobile-top-fix {
    margin-top: 30px;
    margin-bottom: 0px;
  }

  .mobile-bottom-fix {
    margin-bottom: 30px;
  }

  .mobile-bottom-fix-big {
    margin-bottom: 60px;
  }
}

.list-d {
  list-style-type: disc !important;
}

.main-button-red a {
  font-size: 1.1rem;
  color: #F7F7F7;
  /*  background-color: #a12c2f; */
  background-color: #c30d23;
  padding: 12px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 500;
  text-transform: uppercase;
  transition: all .3s;
}

.main-button-red a:hover {
  opacity: 0.9;
}

.main-button-yellow a {
  font-size: 13px;
  color: #fff;
  background-color: #f5a425;
  padding: 12px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 500;
  text-transform: uppercase;
  transition: all .3s;
}

.main-button-yellow a:hover {
  opacity: 0.9;
}

.section-heading h2 {
  line-height: 40px;
  margin-top: 0px;
  margin-bottom: 50px;
  padding-bottom: 20px;
  /*border-bottom: 1px solid rgba(250,250,250,0.15);*/
  border-bottom: 1px solid #DBDCDC;
  font-size: 40px;
  font-weight: 700;
  text-transform: uppercase;
  color: #2C66B0;
  /*color: #bddbf5;*/
  text-align: center;
}

.c-red {
  color: red;
}

/*
---------------------------------------------
header
---------------------------------------------
*/

.sub-header {
  background-color: rgba(163, 31, 52, .9);
}

.sub-header .left-content p {
  color: #fff;
  padding: 8px 20px;
  font-size: 14px;
}

.sub-header .left-content a {
  display: inline;
  color: #fff;
}

.sub-header .right-icons {
  text-align: right;
  padding: 8px 20px;
}

.sub-header .right-icons ul li {
  display: inline-block;
  margin-left: 15px;
}

.sub-header .right-icons ul li a {
  color: #fff;
  font-size: 14px;
  transition: all .3s;
}

.sub-header .right-icons ul li a:hover {
  color: #f5a425;
}

.sub-header .left-content p em {
  font-style: normal;
  color: #f5a425;
}

.background-header {
  background-color: #F3EDE1 !important;
  position: fixed !important;
  top: 0 !important;
  left: 0;
  right: 0;
  box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.15) !important;
}

.background-header .main-nav .menu-items li a {
  color: #1e1e1e !important;
}

.background-header .main-nav .menu-items li:hover a {
  color: #078fc5 !important;
}

.background-header .main-nav .menu-items .mega-links li a {
  color: #1e1e1e !important;
}

.background-header .main-nav .menu-items .mega-links li:hover a {
  color: #078fc5 !important;
}

.background-header .nav li a.active {
  color: #fb5849 !important;
}

.background-header .main-nav .nav li a {
  color: #1e1e1e !important;
}

.background-header .logo,
.background-header .main-nav .nav li a {
  color: #1e1e1e !important;
}

.background-header .main-nav .nav li:hover a {
  color: #fb5849 !important;
}

.background-header .nav li a.active {
  color: #fb5849 !important;
}

.background-header .main-nav .nav li:hover a,
.background-header .main-nav .nav li a.active {
  color: #f5a425 !important;
  opacity: 1;
}

.header-area {
  background-color: #F3EDE1;
  /*background-color:rgba(255, 255, 255, .05);  */
  position: absolute;
  left: 0;
  right: 0;
  z-index: 100;
  -webkit-transition: all .5s ease 0s;
  -moz-transition: all .5s ease 0s;
  -o-transition: all .5s ease 0s;
  transition: all .5s ease 0s;
}

.header-area .main-nav {
  min-height: 80px;
  /*background: transparent;*/
}

.header-area .main-nav .logo {
  line-height: 95px;
  letter-spacing: 2px;
  float: left;
  padding: 10px 20px;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
}

.background-header .main-nav .logo {
  line-height: 75px;
}

.background-header .nav {
  margin-top: 20px !important;
}

.background-header .main-nav .nav li.has-sub:after {
  color: #1e1e1e;
}

.header-area .main-nav .menu-items li a {
  color: #ffffff;
  /*color: #231815;*/
  margin-top: 20px;
}

.header-area .main-nav .menu-items li:hover a {
  color: #02212e;
  /*color: #f9eecf;*/
}

.header-area .main-nav .menu-items li:hover .mega-links li a {
  color: #1e1e1e;
  /*color: #231815;*/
}

.header-area .main-nav .menu-items li:hover .mega-links li:hover a {
  color: #078fc5;
  /*color: #231815;*/
}

.header-area .main-nav .nav {
  float: right;
  margin-top: 30px;
  margin-right: 0px;
  background-color: transparent;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
  position: relative;
  z-index: 999;
}

.header-area .main-nav .nav li {
  padding-left: 15px;
  padding-right: 15px;
}

.header-area .main-nav .nav li:last-child {
  padding-right: 0px;
}

.header-area .main-nav .nav li a {
  display: block;
  font-weight: 600;
  font-size: 1.3rem;
  text-transform: uppercase;
  color: #fff;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
  height: 40px;
  line-height: 40px;
  border: transparent;
  letter-spacing: 1px;
}

.header-area .main-nav .nav li:hover a,
.header-area .main-nav .nav li a.active {
  color: #f5a425 !important;
}

.header-area .main-nav .nav li.has-sub {
  position: relative;
  padding-right: 15px;
}

.header-area .main-nav .nav li.has-sub:after {
  font-family: FontAwesome;
  content: "\f107";
  font-size: 12px;
  color: #fff;
  position: absolute;
  right: 5px;
  top: 12px;
}

.header-area .main-nav .nav li.has-sub ul.sub-menu {
  position: absolute;
  width: 200px;
  box-shadow: 0 2px 28px 0 rgba(0, 0, 0, 0.06);
  overflow: hidden;
  top: 40px;
  opacity: 0;
  transition: all .3s;
  transform: translateY(+2em);
  visibility: hidden;
  z-index: -1;
}

.header-area .main-nav .nav li.has-sub ul.sub-menu li {
  margin-left: 0px;
  padding-left: 0px;
  padding-right: 0px;
}

.header-area .main-nav .nav li.has-sub ul.sub-menu li a {
  opacity: 1;
  display: block;
  background: #f7f7f7;
  color: #2a2a2a !important;
  padding-left: 20px;
  height: 40px;
  line-height: 40px;
  -webkit-transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -o-transition: all 0.3s ease 0s;
  transition: all 0.3s ease 0s;
  position: relative;
  font-size: 13px;
  font-weight: 400;
  border-bottom: 1px solid #eee;
}

.header-area .main-nav .nav li.has-sub ul li a:hover {
  background: #fff;
  color: #f5a425 !important;
  padding-left: 25px;
}

.header-area .main-nav .nav li.has-sub ul li a:hover:before {
  width: 3px;
}

.header-area .main-nav .nav li.has-sub:hover ul.sub-menu {
  visibility: visible;
  opacity: 1;
  z-index: 1;
  transform: translateY(0%);
  transition-delay: 0s, 0s, 0.3s;
}

.header-area .main-nav .menu-trigger {
  cursor: pointer;
  display: block;
  position: absolute;
  top: 33px;
  width: 32px;
  height: 40px;
  text-indent: -9999em;
  z-index: 99;
  right: 40px;
  display: none;
}

.background-header .main-nav .menu-trigger {
  top: 23px;
}

.header-area .main-nav .menu-trigger span,
.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-color: #1e1e1e;
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 0;
}

.background-header .main-nav .menu-trigger span,
.background-header .main-nav .menu-trigger span:before,
.background-header .main-nav .menu-trigger span:after {
  background-color: #1e1e1e;
}

.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  -moz-transition: all 0.4s;
  -o-transition: all 0.4s;
  -webkit-transition: all 0.4s;
  transition: all 0.4s;
  background-color: #1e1e1e;
  display: block;
  position: absolute;
  width: 30px;
  height: 2px;
  left: 0;
  width: 75%;
}

.background-header .main-nav .menu-trigger span:before,
.background-header .main-nav .menu-trigger span:after {
  background-color: #1e1e1e;
}

.header-area .main-nav .menu-trigger span:before,
.header-area .main-nav .menu-trigger span:after {
  content: "";
}

.header-area .main-nav .menu-trigger span {
  top: 16px;
}

.header-area .main-nav .menu-trigger span:before {
  -moz-transform-origin: 33% 100%;
  -ms-transform-origin: 33% 100%;
  -webkit-transform-origin: 33% 100%;
  transform-origin: 33% 100%;
  top: -10px;
  z-index: 10;
}

.header-area .main-nav .menu-trigger span:after {
  -moz-transform-origin: 33% 0;
  -ms-transform-origin: 33% 0;
  -webkit-transform-origin: 33% 0;
  transform-origin: 33% 0;
  top: 10px;
}

.header-area .main-nav .menu-trigger.active span,
.header-area .main-nav .menu-trigger.active span:before,
.header-area .main-nav .menu-trigger.active span:after {
  background-color: transparent;
  width: 100%;
}

.header-area .main-nav .menu-trigger.active span:before {
  -moz-transform: translateY(6px) translateX(1px) rotate(45deg);
  -ms-transform: translateY(6px) translateX(1px) rotate(45deg);
  -webkit-transform: translateY(6px) translateX(1px) rotate(45deg);
  transform: translateY(6px) translateX(1px) rotate(45deg);
  background-color: #1e1e1e;
}

.background-header .main-nav .menu-trigger.active span:before {
  background-color: #1e1e1e;
}

.header-area .main-nav .menu-trigger.active span:after {
  -moz-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  -ms-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  -webkit-transform: translateY(-6px) translateX(1px) rotate(-45deg);
  transform: translateY(-6px) translateX(1px) rotate(-45deg);
  background-color: #1e1e1e;
}

.background-header .main-nav .menu-trigger.active span:after {
  background-color: #1e1e1e;
}

.header-area.header-sticky {
  min-height: 80px;
}

.header-area .nav {
  margin-top: 30px;
}

.header-area .header-container .sub-menu .logo img {
  margin: 10px 20px;
}

.header-area.header-sticky .nav li a.active {
  color: #f5a425;
}

@media (max-width: 1200px) {
  .header-area .main-nav .nav li {
    padding-left: 7px;
    padding-right: 7px;
  }

  .header-area .main-nav:before {
    display: none;
  }
}

@media (max-width: 767px) {

  .header-area.header-sticky .nav li a:hover,
  .header-area.header-sticky .nav li a.active {
    color: #f5a425 !important;
    opacity: 1;
  }

  .header-area.header-sticky .nav li.search-icon a {
    width: 100%;
  }

  .header-area {
    background-color: #f7f7f7;
    padding: 0px 15px;
    height: 100px;
    box-shadow: none;
    text-align: center;
  }

  .header-area .container {
    padding: 0px;
  }

  .header-area .logo {
    margin-left: 30px;
  }

  .header-area .menu-trigger {
    display: block !important;
  }

  .header-area .main-nav {
    overflow: hidden;
  }

  .header-area .main-nav .nav {
    float: none;
    width: 100%;
    display: none;
    -webkit-transition: all 0s ease 0s;
    -moz-transition: all 0s ease 0s;
    -o-transition: all 0s ease 0s;
    transition: all 0s ease 0s;
    margin-left: 0px;
  }

  .header-area .main-nav .nav li:first-child {
    border-top: 1px solid #eee;
  }

  .header-area.header-sticky .nav {
    margin-top: 100px !important;
  }

  .header-area .main-nav .nav li {
    width: 100%;
    background: #fff;
    border-bottom: 1px solid #eee;
    padding-left: 0px !important;
    padding-right: 0px !important;
  }

  .header-area .main-nav .nav li a {
    height: 50px !important;
    line-height: 50px !important;
    padding: 0px !important;
    border: none !important;
    background: #f7f7f7 !important;
    color: #191a20 !important;
  }

  .header-area .main-nav .nav li a:hover {
    background: #eee !important;
    color: #f5a425 !important;
  }

  .header-area .main-nav .nav li.has-sub ul.sub-menu {
    position: relative;
    visibility: inherit;
    opacity: 1;
    z-index: 1;
    transform: translateY(0%);
    top: 0px;
    width: 100%;
    box-shadow: none;
    height: 0px;
    transition: all 0s;
  }

  .header-area .main-nav .nav li.submenu ul li a {
    font-size: 12px;
    font-weight: 400;
  }

  .header-area .main-nav .nav li.submenu ul li a:hover:before {
    width: 0px;
  }

  .header-area .main-nav .nav li.has-sub ul.sub-menu {
    height: auto;
  }

  .header-area .main-nav .nav li.has-sub:after {
    color: #3B566E;
    right: 30px;
    font-size: 14px;
    top: 15px;
  }

  .header-area .main-nav .nav li.submenu:hover ul,
  .header-area .main-nav .nav li.submenu:focus ul {
    height: 0px;
  }
}

@media (min-width: 767px) {
  .header-area .main-nav .nav {
    display: flex !important;
  }
}


/*
---------------------------------------------
heading page
---------------------------------------------
*/

section.heading-page {
  padding-top: 143px;
  text-align: center;
}

section.heading-page h6 {
  margin-top: 0px;
  font-size: 15px;
  text-transform: uppercase;
  font-weight: 600;
  color: #fff;
  letter-spacing: 1px;
}

section.heading-page h2 {
  margin-top: 20px;
  margin-bottom: 20px;
  font-size: 36px;
  text-transform: uppercase;
  font-weight: 800;
  color: #000;
  letter-spacing: 1px;
}

/*
---------------------------------------------
banner
---------------------------------------------
*/

.main-banner {
  position: relative;
  max-height: 100%;
  overflow: hidden;
  margin-bottom: -7px;
}

#bg-video {
  min-width: 100%;
  min-height: 100vh;
  max-width: 100%;
  max-height: 100vh;
  object-fit: cover;
  z-index: -1;
}

#random-image {
  min-width: 100%;
  min-height: 100vh;
  max-width: 100%;
  max-height: 100vh;
  object-fit: cover;
  z-index: -1;
}

#bg-video::-webkit-media-controls {
  display: none !important;
}

#random-image::-webkit-media-controls {
  display: none !important;
}

.video-overlay {
  position: absolute;
  /*background-color: rgba(31,39,43,0.35);*/
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
}

.main-banner .caption {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.main-banner .caption h6 {
  margin-top: 0px;
  font-size: 15px;
  text-transform: uppercase;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.8);
  letter-spacing: 1px;
}

.main-banner .caption h2 {
  margin-top: 20px;
  margin-bottom: 20px;
  font-size: 36px;
  text-transform: uppercase;
  font-weight: 800;
  color: rgba(255, 255, 255, 0.8);
  letter-spacing: 1px;
}

.main-banner .caption h2 em {
  font-style: normal;
  color: #f5a425;
  font-weight: 900;
}

.main-banner .caption p {
  color: rgba(255, 255, 255, 0.8);
  font-size: 14px;
  max-width: 570px;
}

.main-banner .caption .main-button-red {
  margin-top: 30px;
}

@media screen and (max-width: 767px) {

  .main-banner .caption h6 {
    font-weight: 500;
  }

  .main-banner .caption h2 {
    font-size: 36px;
  }
}

/*
---------------------------------------------
main content
---------------------------------------------
*/

section.main-content {
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 10px;
  padding-bottom: 0px;
}

section.background-image-search {
  background-image: url(../images/template_background-04.png);
}

section.background-image-service {
  background-image: url(../images/template_background-07.png);
}

section.background-image-teaching {
  background-image: url(../images/template_background-05.png);
}

section.background-image-reader {
  background-image: url(../images/template_background-09.png);
}

section.main-content .filters {
  text-align: center;
  margin-bottom: 60px;
}

section.main-content .filters li {
  font-size: 13px;
  color: #a12c2f;
  background-color: #fff;
  padding: 11px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 600;
  text-transform: uppercase;
  transition: all .3s;
  cursor: pointer;
  margin: 0px 3px;
}

section.main-content .filters ul li.active,
section.main-content .filters ul li:hover {
  background-color: #a12c2f;
  color: #fff;
}

section.main-content .pagination {
  text-align: center;
  width: 100%;
  margin-top: 30px;
  display: inline-block;
}

section.main-content .pagination ul li {
  display: inline-block;
}

section.main-content .pagination ul li a {
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 10px;
  color: #1f272b;
  display: inline-block;
  text-align: center;
  line-height: 40px;
  font-weight: 600;
  font-size: 15px;
  transition: all .3s;
}

section.main-content .main-button-red {
  text-align: center;
}

section.main-content .main-button-red a {
  padding: 12px 60px;
  text-align: center;
  margin-top: 30px;
}

section.main-content .pagination ul li.active a,
section.main-content .pagination ul li a:hover {
  background-color: #a12c2f;
  color: #fff;
}

section.main-content .heading-title {
  padding-top: 50px;
  padding-bottom: 30px;
  text-align: center;
}

section.main-content .heading-title h1 {
  font-size: 3rem;
}

section.main-content .page-contact {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
  padding-top: 10px;
  padding-bottom: 10px;
}

section.main-content .page-contact h5 {
  margin-right: 10px;
  margin-bottom: 0px;
  font-size: 14px;
}

section.main-content .page-contact a {
  display: inline;
  transition: all .3s;
}

section.main-content .page-contact ul li {
  text-align: right;
}

section.main-content .main-content-item {
  padding-bottom: 40px;
}

section.main-content .main-content-item .thumb {
  position: relative;
}

section.main-content .main-content-item .thumb img {
  border-top-right-radius: 20px;
  border-top-left-radius: 20px;
}

section.main-content .main-content-item .thumb .price {
  position: absolute;
  left: 20px;
  top: 20px;
}

section.main-content .main-content-item .thumb .price span {
  font-size: 16px;
  color: #1f272b;
  font-weight: 600;
  background-color: rgba(250, 250, 250, 0.9);
  padding: 7px 12px;
  border-radius: 10px;
}

section.main-content .main-content-item .down-content {
  background-color: rgba(250, 250, 250, 0.5);
  padding: 60px 80px;
  border-radius: 20px;
}

section.main-content .main-content-item .thumb .date {
  position: absolute;
  background-color: rgba(250, 250, 250, 0.9);
  width: 80px;
  height: 80px;
  text-align: center;
  padding: 15px 0px;
  border-radius: 10px;
  right: 20px;
  top: 20px;
}

section.main-content .main-content-item .thumb .date h6 {
  font-size: 13px;
  text-transform: uppercase;
  font-weight: 600;
  color: #a12c2f;
}

section.main-content .main-content-item .thumb .date span {
  display: block;
  color: #1f272b;
  font-size: 22px;
  margin-top: 7px;
}

section.main-content .main-content-item .down-content h4 {
  font-size: 22px;
  color: #1f272b;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 15px;
}

section.main-content .main-content-item .down-content h5 {
  font-size: 20px;
  color: #1f272b;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 15px;
}

section.main-content .main-content-item .down-content a {
  display: inline;
  color: #336dc4;
  font-size: 18px;
}

section.main-content .main-content-item .down-content p {
  color: #1f272b;
  font-size: 18px;
  margin: 20px 0px 40px 0px;
}

section.main-content .main-content-item .down-content li {
  margin: 20px 20px;
  font-size: 18px;
}

section.main-content .main-content-item .down-content p.description {
  border: 1px ridge #f7f0f0;
  border-radius: 10px;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.1);
  padding: 0;
  background-color: #fff;

  /*
  margin-top: 4px;
  padding-top: 4px;
  border-top: 1px solid #eee;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #eee;
  */
}

section.main-content .main-content-item .down-content .panel-heading {
  background-color: #39ADB4;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  border-bottom: 1px solid transparent;
  color: white;
  padding: 20px;
}


/*
section.main-content .main-content-item .font-large h5 {
  font-size: 22px;
  line-height: 40px;
}

section.main-content .main-content-item .font-large a {
  font-size: 22px;
}

section.main-content .main-content-item .font-large p {
  font-size: 18px;
}

section.main-content .main-content-item .font-large li {
  margin: 20px 20px;
  line-height: 50px;
}
*/
/*
---------------------------------------------
services
---------------------------------------------
*/

.services {
  margin-top: 50px;
  position: absolute;
  width: 100%;
}

.services .item {
  /*background-image: url(../images/service-item-bg.jpg);*/
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  border-radius: 20px;
  text-align: center;
  color: #fff;
  padding: 40px;
}

.services .item .icon {
  max-width: 320px;
  margin: 0 auto;
}

.services .item h4 {
  margin-top: 25px;
  margin-bottom: 15px;
  font-size: 18px;
  font-weight: 600;
}

.services .item p {
  color: #fff;
  font-size: 13px;
}

.services .owl-nav {
  display: inline-block !important;
  text-align: center;
  position: absolute;
  width: 100%;
  top: 50%;
  transform: translateY(-25px);
}

.services .owl-nav .owl-prev {
  margin-right: 10px;
  outline: none;
  position: absolute;
  left: -80px;
}

.services .owl-nav .owl-prev span,
.services .owl-nav .owl-next span {
  opacity: 0;
}

.services .owl-nav .owl-prev:before {
  display: inline-block;
  font-family: 'FontAwesome';
  color: #1e1e1e;
  font-size: 25px;
  font-weight: 700;
  content: '\f104';
  background-color: #fff;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  line-height: 50px;
}

.services .owl-nav .owl-prev {
  opacity: 1;
  transition: all .5s;
}

.services .owl-nav .owl-prev:hover {
  opacity: 0.9;
}

.services .owl-nav .owl-next {
  opacity: 1;
  transition: all .5s;
}

.services .owl-nav .owl-next:hover {
  opacity: 0.9;
}

.services .owl-nav .owl-next {
  margin-left: 10px;
  outline: none;
  position: absolute;
  right: -85px;
}

.services .owl-nav .owl-next:before {
  display: inline-block;
  font-family: 'FontAwesome';
  color: #1e1e1e;
  font-size: 25px;
  font-weight: 700;
  content: '\f105';
  background-color: #fff;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  line-height: 50px;
}


/*
---------------------------------------------
upcoming meetings
---------------------------------------------
*/

section.upcoming-meetings {
  background-image: url(../images/apply-bg2.png);
  /*background-color: #EEEEEF;*/
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 100px;
  padding-bottom: 100px;
}

section.upcoming-meetings .section-heading {
  text-align: center;
}

.meeting-item {
  margin-bottom: 30px;
}

.meeting-item .thumb {
  position: relative;
  text-align: center;
}

.meeting-item .thumb img {
  border-top-right-radius: 20px;
  border-top-left-radius: 20px;
}

.meeting-item .thumb .price {
  position: absolute;
  left: 20px;
  top: 20px;
}

.meeting-item .thumb .price span {
  font-size: 16px;
  color: #1f272b;
  font-weight: 600;
  background-color: rgba(250, 250, 250, 0.9);
  padding: 7px 12px;
  border-radius: 10px;
}

.meeting-item .down-content {
  /*background-color: #FFFFFF;*/
  padding: 30px;
  border-bottom-right-radius: 20px;
  border-bottom-left-radius: 20px;
}

.meeting-item .down-content .date {
  float: left;
  text-align: center;
  display: inline-block;
  margin-right: 20px;
}

.meeting-item .down-content .date h6 {
  font-size: 13px;
  text-transform: uppercase;
  font-weight: 600;
  color: #a12c2f;
}

.meeting-item .down-content .date span {
  display: block;
  color: #1f272b;
  font-size: 22px;
  margin-top: 7px;
}

.meeting-item .down-content h4 {
  font-size: 18px;
  color: #1f272b;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 15px;
}

.meeting-item .down-content p {
  color: #1f272b;
  font-size: 14px;
}



/*
---------------------------------------------
apply now
---------------------------------------------
*/

section.apply-now {
  background-image: url(../images/facts-bg.png);
  /*background-color: #F7F7F7;*/
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 100px 0px;
}

section.apply-now .item {
  /*background-color: rgba(250,250,250,0.15);*/
  background-color: rgba(0, 0, 0, 0.8);
  padding: 20px;
  text-align: center;
}

section.apply-now .item h3 {
  color: #fff;
  text-transform: uppercase;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 20px;
}

section.apply-now .item h4 {
  margin: 20px auto 10px;
  color: #fff;
  font-size: 24px;
}

section.apply-now .item p {
  color: #fff;
  margin-bottom: 20px;
}


/*
---------------------------------------------
News accordions
---------------------------------------------
*/

.accordions {
  border-radius: 20px;
  padding: 40px;
  margin-left: 45px;
  /*background-color: #fff;*/
}

.accordions .accordion {
  /*border-bottom: 1px solid #eee;*/
  border-bottom: 1px solid #C8C9CA;
}

.accordions .last-accordion {
  border-bottom: none;
}

.accordions>.news_class {

  font-weight: 600;
  margin-left: 1.5rem;
}

.accordions>.news_class h4 {

  display: inline;
  padding: 6px 10px;
  font-size: 14px;
  color: #faf6f6;
  background-color: #011933;
  border-bottom: 1px solid #C8C9CA;
}

.accordion-head {
  padding: 15px 26px;
  font-size: 1.2em;
  font-weight: 500;
  color: #2C66B0;
  cursor: pointer;
  transition: color 200ms ease-in-out;
  /*border-bottom: 1px solid #fff;*/
}

.accordion-head a {
  color: #2C66B0;
  cursor: pointer;
  font-weight: 500;
  transition: color 200ms ease-in-out;
}

.accordion-head a:hover {
  color: #007bff;
  font-weight: 700;
}

.accordion-head .news_title {
  padding-left: 0.5em;
}

.accordion-head .news_title a {
  font-size: 1.2em;
  color: #0a58ca;
  display: inline;
}

.accordion-head .news-content-title {
  font-size: 2em;
}

.accordion-head .index-publish-time {
  background-color: #2d7827;
  color: #fff;
  font-size: 0.7em;
  padding: 3px 10px;
  margin-right: 20px;
  border-radius: 10px;
}

.accordion-head .all-list-publish-time {
  background-color: #2d7827;
  color: #fff;
  padding: 3px 10px;
  border-radius: 10px;
}

.accordion-head .icon {
  float: right;
  transition: transform 200ms ease-in-out;
}

.accordion-head.is-open {
  color: #f5a425 !important;
  border-bottom: none;
}

.accordion-head.is-open .icon {
  transform: rotate(45deg);
}

.accordion-body {
  overflow: hidden;
  height: 0;
  transition: height 300ms ease-in-out;
  border-bottom: 1px solid #fff;
  padding: 0 1.3rem;
  font-size: 1em;
}

.accordion-view {
  overflow: hidden;
  height: 0;
  transition: height 300ms ease-in-out;
  border-bottom: 1px solid #fff;
  padding: 1em 1.3rem 3.5em;
  font-size: 1em;
  text-align: right;
}

.accordion-body .content {
  text-align: right;
}

.accordion-body .content a {
  /*background-color: #2c51a1;*/
  padding: 6px 20px;
  border-radius: 10px;
}

.accordion-body>.content {
  padding: 20px 5px;
  padding-top: 0;
}

.accordion-body>.content p {
  font-size: 1em;
  text-align: left;
}

.accordion-content-body {
  padding-top: 2em;
  margin: 5px 30px;
  overflow: hidden;
  transition: height 300ms ease-in-out;
  border-bottom: 1px solid #fff;
  line-height: 28px;
}

.accordion-content-body p {
  font-size: 1em;
  line-height: 30px;
  width: 90%;
}

.accordion-content-body a {
  display: inline;
  color: #4169e1;
}

.accordion-content-body img {
  max-width: 100% !important; /* 確保圖片永遠不會寬過父容器 */
  height: auto !important;    /* 保持比例，避免圖片被壓扁 */
}

.accordion-button-red a {
  font-size: 16px;
  color: #fff;
  background-color: #a12c2f;
  padding: 10px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 500;
  text-transform: uppercase;
  transition: all .3s;
}

.accordion-button-red a:hover {
  color: #F2F2F2 !important;
}

.attachment-file {
  margin: 20px;
}

.news-contact {
  display: flex;
  padding-top: 30px;
}

.news-contact>.info {
  padding: 10px 25px;
  border: 1px solid #747775;
  box-shadow: none;
  border-radius: 40px;
  margin-right: 18px;
}

/*
---------------------------------------------
Attachment
---------------------------------------------
*/

/* 外層容器：橫向捲動 */
.attachment-list {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding: 20px;
  scrollbar-width: thin;
}

.attachment-item {
  position: relative;
  flex: 0 0 160px;
  margin-right: 30px;
  background: #f5f5f5;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.attachment-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.2);
}

/* 圖片預覽 */
.attachment-thumb {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
  background: #ddd;
}

/* 非圖片檔案的圖示 */
.attachment-icon {
  height: 160px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 40px;
  color: #5f6368;
  background: #eaeaea;
  background-color: #fff;
}

.attachment-icon img {
  width: 100px;
  height: 100px;
}

/* 檔案資訊 */
.attachment-info {
  padding: 8px 10px;
}

.attachment-name {
  display: block;
  font-weight: 500;
  color: #202124;
  font-size: 14px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.attachment-size {
  font-size: 12px;
  color: #5f6368;
}

/* 操作按鈕（hover時顯示） */
.attachment-actions {
  position: absolute;
  top: 6px;
  right: 6px;
  display: flex;
  gap: 6px;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.attachment-item:hover .attachment-actions {
  opacity: 1;
}

.attachment-actions a {
  background: rgba(255, 255, 255, 0.9);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  padding: 6px;
  color: #5f6368;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
  text-decoration: none;
}

.attachment-actions a:hover {
  color: #1a73e8;
}

/*
---------------------------------------------
courses
---------------------------------------------
*/

section.our-courses {
  background-image: url(../images/facts-bg.png);
  /*background-color: #EEEEEF;*/
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 100px;
  padding-bottom: 130px;
}

.our-courses .item .down-content {
  /*background-color: #fff;*/
}

.our-courses .item .down-content h4 {
  padding: 25px;
  font-size: 18px;
  color: #1f272b;
  text-align: center;
  /*border-bottom: 1px solid #DBDCDC*/
  ;
}

.our-courses .item .down-content .info {
  padding: 25px;
}

.our-courses .item .down-content .info ul li {
  display: inline-block;
  margin-right: 1px;
}

.our-courses .item .down-content .info ul li i {
  color: #f5a425;
  font-size: 14px;
}

.our-courses .item .down-content .info span {
  color: #a12c2f;
  font-size: 15px;
  font-weight: 600;
  text-align: right;
  display: inline-block;
  width: 100%;
}

.our-courses .owl-nav {
  text-align: center;
  position: absolute;
  width: 100%;
  top: 50%;
  transform: translateY(-45px);
}

.our-courses .owl-dots {
  display: inline-block;
  text-align: center;
  width: 100%;
  margin-top: 40px;
}

.our-courses .owl-dots .owl-dot {
  transition: all .5s;
  width: 7px;
  height: 7px;
  background-color: #DBDCDC;
  margin: 0px 5px;
  border-radius: 50%;
  outline: none;
}

.our-courses .owl-dots .active {
  width: 24px;
  height: 8px;
  border-radius: 4px;
  background-color: #C30D23;
}

.our-courses .owl-nav .owl-prev {
  margin-right: 10px;
  outline: none;
  position: absolute;
  left: -80px;
}

.our-courses .owl-nav .owl-prev span,
.our-courses .owl-nav .owl-next span {
  opacity: 0;
}

.our-courses .owl-nav .owl-prev:before {
  display: inline-block;
  font-family: 'FontAwesome';
  color: #C30D23;
  font-size: 25px;
  font-weight: 700;
  content: '\f104';
  background-color: #fff;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  line-height: 50px;
}

.our-courses .owl-nav .owl-prev {
  opacity: 1;
  transition: all .5s;
}

.our-courses .owl-nav .owl-prev:hover {
  opacity: 0.9;
}

.our-courses .owl-nav .owl-next {
  opacity: 1;
  transition: all .5s;
}

.our-courses .owl-nav .owl-next:hover {
  opacity: 0.9;
}

.our-courses .owl-nav .owl-next {
  margin-left: 10px;
  outline: none;
  position: absolute;
  right: -85px;
}

.our-courses .owl-nav .owl-next:before {
  display: inline-block;
  font-family: 'FontAwesome';
  color: #C30D23;
  font-size: 25px;
  font-weight: 700;
  content: '\f105';
  background-color: #fff;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  line-height: 50px;
}


/*
---------------------------------------------
our facts
---------------------------------------------
*/

section.our-facts {
  /*background-image: url(../images/meetings-bg.jpg);*/
  background-color: #EEEEEF;
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 100px 0px 100px 0px;
}

.count-area-content {
  text-align: center;
  /* background-color: rgba(250,250,250,0.15);*/
  background-color: #F7F7F7;
  border-radius: 20px;
  /* padding: 25px 30px 35px 30px; */
  padding: 15px 30px 15px 30px;
  margin: 10px 0px;
}

.percentage .count-digit:after {
  content: '%';
  margin-left: 3px;
}

.count-digit {
  margin: 5px 0px;
  color: #2C66B0;
  /*color: #f5a425;*/
  font-weight: 700;
  font-size: 36px;
}

.count-title {
  font-size: 18px;
  font-weight: 500;
  color: #231815;
  letter-spacing: 0.5px;
}

.new-students {
  margin-top: 45px;
}

section.our-facts .video {
  display: flex;
  text-align: center;
  margin-left: 70px;
  background-color: rgba(22, 27, 29, 0.75);
  /*
  background-image: url(../images/video-item-bg.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  */
  border-radius: 20px;
  min-height: 300px;
}

section.our-facts .video .opentime {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
  border-radius: 10px;
  padding: 2em 1.5em;
  width: 80%;
}

section.our-facts .video .opentime .opendate time {
  font-size: 1.188rem;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
  width: 133px;
  height: 133px;
  border-radius: 4px;
  background-color: #65bdb8;
  color: #fff;
}

section.our-facts .video .opentime .opendate span {
  text-align: center;
  width: 100%;
  display: block;
  font-size: 2.188rem;
  line-height: 2rem;
}

section.our-facts .video .opentime .openhour {
  display: flex;
  align-items: center;
  background-color: #fff;
}

section.our-facts .video img {
  padding: 170px 0px;
  max-width: 56px;
}

section.our-facts .modal-button {
  cursor: pointer;
}

section.our-facts .service-item {
  position: relative;
  height: 100%;
  padding: 20px;
  /*background: var(--bs-white);*/
  box-shadow: 0 0 45px rgba(0, 0, 0, .05);
}

section.our-facts .service-item::before {
  position: absolute;
  content: "";
  width: 100%;
  height: 0;
  left: 0;
  bottom: 0;
  transition: .5s;
  background: var(--bs-primary);
  /*background: #C30D23;*/
}

section.our-facts .service-item:hover::before {
  height: 100%;
  top: 0;
}

section.our-facts .service-item * {
  position: relative;
  transition: .5s;
  z-index: 1;
}

section.our-facts .service-item:hover h5,
section.our-facts .service-item:hover p {
  color: var(--bs-white);
}

section.our-facts .service-item:hover .icon-box-primary::before {
  background: var(--bs-dark);
}

section.our-facts .service-item:hover .icon-box-primary i {
  color: var(--bs-white) !important;
}

section.our-facts .service-item img {
  width: 100%;
  height: 511px;
}

/*
---------------------------------------------
contact us
---------------------------------------------
*/

section.contact-us {
  background-image: url(../images/apply-bg2.png);
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 100px 0px;
}

section.contact-us h2 {
  text-transform: uppercase;
  color: #231815;
  border-bottom: 1px solid #DBDCDC;
  margin-bottom: 0px;
  padding-bottom: 10px;
  font-size: 22px;
  font-weight: 700;
}

section.contact-us #contact {
  background-color: #fff;
  border-radius: 20px;
  padding: 40px;
}

section.contact-us #contact h2 {
  text-transform: uppercase;
  color: #1f272b;
  border-bottom: 1px solid #eee;
  margin-bottom: 40px;
  padding-bottom: 20px;
  font-size: 22px;
  font-weight: 700;
}

section.contact-us #contact input {
  width: 100%;
  height: 40px;
  border-radius: 20px;
  background-color: #f7f7f7;
  outline: none;
  border: none;
  box-shadow: none;
  font-size: 13px;
  font-weight: 500;
  color: #7a7a7a;
  padding: 0px 15px;
  margin-bottom: 30px;
}

section.contact-us #contact textarea {
  width: 100%;
  min-height: 140px;
  max-height: 180px;
  border-radius: 20px;
  background-color: #f7f7f7;
  outline: none;
  border: none;
  box-shadow: none;
  font-size: 13px;
  font-weight: 500;
  color: #7a7a7a;
  padding: 15px;
  margin-bottom: 30px;
}

section.contact-us #contact button {
  font-size: 13px;
  color: #fff;
  background-color: #a12c2f;
  padding: 12px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 500;
  text-transform: uppercase;
  transition: all .3s;
  border: none;
  outline: none;
}

section.contact-us #contact button:hover {
  opacity: 0.9;
}

section.contact-us .right-info {
  background-color: #a12c2f;
  border-radius: 20px;
  padding: 40px;
}

section.contact-us .right-info ul li {
  display: inline-block;
  border-bottom: 1px solid rgba(250, 250, 250, 0.15);
  margin-bottom: 30px;
  padding-bottom: 30px;
}

section.contact-us .right-info ul li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

section.contact-us .right-info ul li h6 {
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 10px;
}

section.contact-us .right-info ul li span {
  display: block;
  font-size: 18px;
  color: #fff;
  font-weight: 700;
}

section.contact-us .categories {
  margin-right: 0px;
  margin-bottom: 30px;
}

section.contact-us .categories {
  background-color: #F7F7F7;
  /*background-color: rgba(250, 250, 250, 0.15);*/
  border-radius: 20px;
  padding: 40px;
}

section.contact-us .categories h4 {
  font-size: 18px;
  font-weight: 600;
  color: #231815;
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid #DBDCDC;
}

section.contact-us .categories ul li {
  margin-bottom: 15px;
}

section.contact-us .categories ul li a {
  font-size: 15px;
  color: #231815;
  font-weight: 600;
  transition: all .3s;
}

section.contact-us .categories ul li a:hover {
  color: #a12c2f;
}

section.contact-us .categories .main-button-red {
  border-top: 1px solid #DBDCDC;
  padding-top: 30px;
  margin-top: 15px;
}

section.contact-us .categories .main-button-red a {
  width: 100%;
  text-align: center;
}

section.contact-us .categories .open-time {
  display: flex;
}

section.contact-us .categories .open-time .field-items {
  width: 120px;
  /*background-color: rgb(4 91 122 / 45%);*/
  background-color: #2C66B0;
  text-align: center;
  color: #fff;
  font-weight: 600;
  border-radius: 10px;
}

section.contact-us .categories .open-time .field-items .date-display-month {
  font-size: 30px;
  border-bottom: 3px solid rgb(255 255 255 / 53%);
  padding-top: 10px;
  padding-bottom: 10px;
  margin: 10px;
}

section.contact-us .categories .open-time .field-items .eng-date-display-month {
  font-size: 25px;
  border-bottom: 3px solid rgb(255 255 255 / 53%);
  padding-top: 10px;
  padding-bottom: 10px;
  margin: 10px;
}

section.contact-us .categories .open-time .field-items .date-display-day {
  font-size: 32px;
  font-weight: 600;
}

section.contact-us .categories .semester-date {
  margin-top: 10px;
  margin-left: 30px;
}

section.contact-us .categories .semester-date li a {
  font-size: 20px !important;
}

/*
---------------------------------------------
contact-infomation
---------------------------------------------
*/

section.contact-infomation {
  background-color: #F1EBDF;
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding: 100px 0px;
}

section.contact-infomation h2 {
  text-transform: uppercase;
  color: #231815;
  border-bottom: 1px solid #DBDCDC;
  margin-bottom: 0px;
  padding-bottom: 10px;
  font-size: 22px;
  font-weight: 700;
}

section.contact-infomation #contact {
  background-color: #fff;
  border-radius: 20px;
  padding: 40px;
}

section.contact-infomation #contact h2 {
  text-transform: uppercase;
  color: #1f272b;
  border-bottom: 1px solid #eee;
  margin-bottom: 40px;
  padding-bottom: 20px;
  font-size: 22px;
  font-weight: 700;
}

section.contact-infomation #contact input {
  width: 100%;
  height: 40px;
  border-radius: 20px;
  background-color: #f7f7f7;
  outline: none;
  border: none;
  box-shadow: none;
  font-size: 13px;
  font-weight: 500;
  color: #7a7a7a;
  padding: 0px 15px;
  margin-bottom: 30px;
}

section.contact-infomation #contact textarea {
  width: 100%;
  min-height: 140px;
  max-height: 180px;
  border-radius: 20px;
  background-color: #f7f7f7;
  outline: none;
  border: none;
  box-shadow: none;
  font-size: 13px;
  font-weight: 500;
  color: #7a7a7a;
  padding: 15px;
  margin-bottom: 30px;
}

section.contact-infomation #contact button {
  font-size: 13px;
  color: #fff;
  background-color: #a12c2f;
  padding: 12px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 500;
  text-transform: uppercase;
  transition: all .3s;
  border: none;
  outline: none;
}

section.contact-infomation #contact button:hover {
  opacity: 0.9;
}

section.contact-infomation .right-info {
  background-color: #a12c2f;
  border-radius: 20px;
  padding: 40px;
}

section.contact-infomation .right-info ul li {
  display: inline-block;
  border-bottom: 1px solid rgba(250, 250, 250, 0.15);
  margin-bottom: 30px;
  padding-bottom: 30px;
}

section.contact-infomation .right-info ul li:last-child {
  margin-bottom: 0;
  padding-bottom: 0;
  border-bottom: none;
}

section.contact-infomation .right-info ul li h6 {
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 10px;
}

section.contact-infomation .right-info ul li span {
  display: block;
  font-size: 18px;
  color: #fff;
  font-weight: 700;
}

section.contact-infomation .categories {
  margin-right: 0px;
  margin-bottom: 30px;
}

section.contact-infomation .categories {
  background-color: #F6F6F2;
  /*background-color: rgba(250, 250, 250, 0.15);*/
  border-radius: 20px;
  padding: 40px;
}

section.contact-infomation .categories h4 {
  font-size: 18px;
  font-weight: 600;
  color: #231815;
  margin-bottom: 30px;
  padding-bottom: 20px;
  border-bottom: 1px solid #DBDCDC;
}

section.contact-infomation .categories ul li {
  margin-bottom: 15px;
}

section.contact-infomation .categories ul li a {
  font-size: 15px;
  color: #231815;
  font-weight: 600;
  transition: all .3s;
}

section.contact-infomation .categories ul li a:hover {
  color: #a12c2f;
}

section.contact-infomation .categories .main-button-red {
  border-top: 1px solid #eee;
  padding-top: 30px;
  margin-top: 15px;
}

section.contact-infomation .categories .main-button-red a {
  width: 100%;
  text-align: center;
}

section.contact-infomation .categories .open-time {
  display: flex;
}

section.contact-infomation .categories .open-time .field-items {
  width: 120px;
  /*background-color: rgb(4 91 122 / 45%);*/
  background-color: #0D6490;
  text-align: center;
  color: #fff;
  font-weight: 600;
  border-radius: 10px;
}

section.contact-infomation .categories .open-time .field-items .date-display-month {
  font-size: 24px;
  border-bottom: 3px solid rgb(255 255 255 / 53%);
  padding-top: 10px;
  padding-bottom: 10px;
  margin: 10px;
}

section.contact-infomation .categories .open-time .field-items .date-display-day {
  font-size: 32px;
  font-weight: 600;
}

section.contact-infomation .categories .semester-date {
  margin-top: 10px;
  margin-left: 30px;
}

section.contact-infomation .categories .semester-date li a {
  font-size: 20px !important;
}

/*
---------------------------------------------
footer-links
---------------------------------------------
*/

section.footer-links {
  background-color: #000;
}

section.footer-links .container {
  font-size: 16px;
  color: #fff;
  text-align: center;
  padding-top: 15px;
  padding-bottom: 5px;
}

section.footer-links .footer-column .footer-nav-items li {
  margin: 5px auto;
}

section.footer-links .footer-column .footer-nav-items a {
  color: rgba(175, 175, 175, 0.8);
  font-size: 16px;
}

section.footer-links .footer-column .footer-nav-items .footer-nav-items-title {
  font-size: 24px;
  color: #3ab0e2;
}

section.footer-links .footer-content .linked-list li {
  margin: 5px auto;
  font-size: 16px;
}

section.footer-links .footer-content .linked-list a {
  color: #fff;
}


section.footer-links .footer-info p {
  color: rgba(255, 255, 255, 0.5);
  text-align: center;
  font-size: 12px;
}


/*
---------------------------------------------
upcoming meetings page
---------------------------------------------
*/

section.meetings-page {
  /*background-color: #F6F2EF;*/
  /*background-image: url(../images/apply-bg2.png);*/
  background-position: center center;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-size: cover;
  padding-top: 10px;
  padding-bottom: 0px;
}

section.meetings-page .filters {
  text-align: center;
  margin-bottom: 60px;
}

section.meetings-page .filters li {
  font-size: 13px;
  color: #a12c2f;
  background-color: #fff;
  padding: 11px 30px;
  display: inline-block;
  border-radius: 22px;
  font-weight: 600;
  text-transform: uppercase;
  transition: all .3s;
  cursor: pointer;
  margin: 0px 3px;
}

section.meetings-page .filters ul li.active,
section.meetings-page .filters ul li:hover {
  background-color: #a12c2f;
  color: #fff;
}

section.meetings-page .pagination {
  text-align: center;
  width: 100%;
  margin-top: 30px;
  display: inline-block;
}

section.meetings-page .pagination ul li {
  display: inline-block;
}

section.meetings-page .pagination ul li a {
  width: 40px;
  height: 40px;
  background-color: #fff;
  border-radius: 10px;
  color: #1f272b;
  display: inline-block;
  text-align: center;
  line-height: 40px;
  font-weight: 600;
  font-size: 15px;
  transition: all .3s;
}

section.meetings-page .main-button-red {
  text-align: center;
}

section.meetings-page .main-button-red a {
  padding: 12px 60px;
  text-align: center;
  margin-top: 30px;
}

section.meetings-page .pagination ul li.active a,
section.meetings-page .pagination ul li a:hover {
  background-color: #a12c2f;
  color: #fff;
}

section.meetings-page .heading-title {
  padding-top: 50px;
  padding-bottom: 30px;
  text-align: center;
}

section.meetings-page .heading-title h1 {
  font-size: 3rem;
}

.page-contact {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
  padding-top: 10px;
  padding-bottom: 10px;
}

.page-contact h5 {
  margin-right: 10px;
  margin-bottom: 0px;
  font-size: 14px;
}

.page-contact a {
  display: inline;
  transition: all .3s;
}

.page-contact ul li {
  text-align: right;
}

.meeting-single-item {
  padding-bottom: 40px;
}

.meeting-single-item .thumb {
  position: relative;
}

.meeting-single-item .thumb img {
  border-top-right-radius: 20px;
  border-top-left-radius: 20px;
}

.meeting-single-item .thumb .price {
  position: absolute;
  left: 20px;
  top: 20px;
}

.meeting-single-item .thumb .price span {
  font-size: 16px;
  color: #1f272b;
  font-weight: 600;
  background-color: rgba(250, 250, 250, 0.9);
  padding: 7px 12px;
  border-radius: 10px;
}

.meeting-single-item .down-content {
  background-color: #fff;
  padding: 60px 120px;

  border-radius: 20px;
}

.meeting-single-item .thumb .date {
  position: absolute;
  background-color: rgba(250, 250, 250, 0.9);
  width: 80px;
  height: 80px;
  text-align: center;
  padding: 15px 0px;
  border-radius: 10px;
  right: 20px;
  top: 20px;
}

.meeting-single-item .thumb .date h6 {
  font-size: 13px;
  text-transform: uppercase;
  font-weight: 600;
  color: #a12c2f;
}

.meeting-single-item .thumb .date span {
  display: block;
  color: #1f272b;
  font-size: 22px;
  margin-top: 7px;
}

.meeting-single-item .down-content h4 {
  font-size: 22px;
  color: #1f272b;
  font-weight: 600;
  display: inline-block;
  margin-bottom: 15px;
}

.meeting-single-item .down-content h5 {
  font-size: 20px;
  color: #1f272b;
  font-weight: 700;
  display: inline-block;
  margin-bottom: 15px;
}

.meeting-single-item .down-content a {
  display: inline;
  color: #336dc4;
  font-size: 18px;
}

.meeting-single-item .down-content p {
  color: #1f272b;
  font-size: 18px;
  margin: 10px;
}

.meeting-single-item .down-content li {
  margin: 20px 20px;
  font-size: 18px;
}

.meeting-single-item .down-content p.description {
  margin-top: 4px;
  padding-top: 4px;
  /*border-top: 1px solid #eee;*/
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #eee;
}

.meeting-single-item .down-content .panel-heading {
  background-color: #39ADB4;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  border-bottom: 1px solid transparent;
  color: white;
  padding: 20px;
}

.meeting-single-item .font-large h5 {
  font-size: 22px;
  line-height: 40px;
}

.meeting-single-item .font-large a {
  font-size: 22px;
}

.meeting-single-item .font-large p {
  font-size: 18px;
}

.meeting-single-item .font-large li {
  margin: 20px 20px;
  line-height: 50px;
}


/* Meeting item column */
.templatemo-item-col {
  width: 31%;
}

@media (max-width: 992px) {
  .templatemo-item-col {
    width: 45%;
  }
}

@media (max-width: 767px) {
  .templatemo-item-col {
    width: 100%;
  }
}

/*
---------------------------------------------
Portfolio
---------------------------------------------
*/

.our-portfolio {
  padding-top: 80px;
  background-image: url(../images/template_background-01.png);
}

.our-portfolio .section-heading {
  margin-bottom: 50px;
  text-align: center;
}

.our-portfolio .section-heading h1 {
  font-size: 3rem;
}

.our-portfolio .container-fluid {
  padding-right: 15px;
  padding-left: 15px;
  padding-bottom: 55px;
  position: relative;
  z-index: 2;
}

.our-portfolio .link-grid {
  margin: 0 auto;
  max-width: 1600px;
  display: grid;
  grid-template-columns: repeat(4, 284px);
  justify-content: space-around;
}

.our-portfolio .item {
  position: relative;
  z-index: 222;
}

.portfolio-item {
  border-radius: 25px;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.1);
  margin: 20px 0;
}

.portfolio-item .thumb {
  position: relative;
  border-radius: 50px;
}

.portfolio-item:hover .down-content h4,
.portfolio-item:hover .down-content span {
  color: #4da6e7;
}

.portfolio-item .thumb img {
  border-top-right-radius: 23px;
  border-top-left-radius: 23px;
  overflow: hidden;
}

.portfolio-item .down-content {
  background-color: #fff;
  text-align: center;
  padding: 18px 0px;
  border-bottom-right-radius: 23px;
  border-bottom-left-radius: 23px;
}

.portfolio-item .down-content h4 {
  font-size: 20px;
  font-weight: 700;
  color: #2a2a2a;
  margin-bottom: 8px;
  transition: all .3s;
}

.portfolio-item .down-content span {
  font-size: 15px;
  color: #afafaf;
  transition: all .3s;
}

.our-portfolio .owl-nav {
  display: inline-block !important;
  position: absolute;
  top: -125px;
  right: 15%;
  max-width: 1320px;
}

.our-portfolio .owl-nav .owl-next {
  margin-left: 10px;
}

.our-portfolio .owl-nav span {
  width: 46px;
  height: 46px;
  display: inline-block;
  text-align: center;
  line-height: 46px;
  font-size: 30px;
  background-color: #eee;
  border-radius: 50%;
  color: #fff;
  transition: all 0.5s;
}

.our-portfolio .owl-nav span:hover {
  color: #fff;
  background-color: #4da6e7;
}

/*
---------------------------------------------
responsive
---------------------------------------------
*/

@media (max-width: 1300px) {
  .services .owl-nav .owl-next {
    right: -30px;
  }

  .services .owl-nav .owl-prev {
    left: -25px;
  }

  .our-courses .owl-nav .owl-next {
    right: -30px;
  }

  .our-courses .owl-nav .owl-prev {
    left: -25px;
  }
}

@media (max-width: 1200px) {
  .services .owl-nav .owl-next {
    right: -70px;
  }

  .services .owl-nav .owl-prev {
    left: -65px;
  }

  .our-courses .owl-nav .owl-next {
    right: -70px;
  }

  .our-courses .owl-nav .owl-prev {
    left: -65px;
  }
}

@media (max-width: 1085px) {
  .services .owl-nav .owl-next {
    right: -30px;
  }

  .services .owl-nav .owl-prev {
    left: -25px;
  }

  .our-courses .owl-nav .owl-next {
    right: -30px;
  }

  .our-courses .owl-nav .owl-prev {
    left: -25px;
  }
}

@media (max-width: 1005px) {
  .services .owl-nav .owl-next {
    display: none;
  }

  .services .owl-nav .owl-prev {
    display: none;
  }

  .our-courses .owl-nav .owl-next {
    display: none;
  }

  .our-courses .owl-nav .owl-prev {
    display: none;
  }
}

@media (max-width: 992px) {

  .main-banner .caption {
    top: 60%;
  }

  .main-banner .caption h2 {
    margin-top: 10px;
    margin-bottom: 10px;
    font-size: 22px;
  }

  .main-banner .caption .main-button-red {
    margin-top: 15px;
  }

  .services {
    margin-top: 60px;
  }

  section.upcoming-meetings {
    padding-top: 400px;
  }

  section.upcoming-meetings .categories {
    margin-right: 0px;
    margin-bottom: 30px;
  }

  .accordions {
    margin-left: 0px;
  }

  .new-students {
    margin-top: 15px;
  }

  section.our-facts .video {
    margin-left: 0px;
    margin-top: 15px;
  }

  section.contact-us #contact {
    margin-bottom: 30px;
  }

}

@media (max-width: 767px) {

  .sub-header .left-content p {
    display: none;
  }

  .sub-header .right-icons {
    text-align: center;
  }

  .main-nav .nav .sub-menu {
    display: none;
  }

  .header-area .main-nav .nav li ul.sub-menu li a {
    color: #1f272b;
  }

}

/*
---------------------------------------------
Features
---------------------------------------------
*/

.features {
  box-shadow: 0px 2px 8px 0px rgba(50, 50, 50, 0.08);
  padding-top: 50px;
  padding-bottom: 50px;
}

.features .fa {
  border: 1px solid #7AD03A;
  border-radius: 50%;
  color: #7AD03A;
  font-size: 26px;
  width: 60px;
  height: 60px;
  line-height: 58px;
  text-align: center;
}

.features h4 {
  color: #000;
  font-weight: bold;
  padding-top: 10px;
  font-size: 20px !important;
  margin-left: 8px !important;
}

/*
---------------------------------------------
GLOSS
---------------------------------------------
*/

.templatemo_home_mid {
  display: flex;
  background-color: transparent;
}

.shadow {
  box-shadow: 0px 0px 7px #011933;
}

.templatemo_box {
  background-color: #000;
}

.templatemo_box_last {
  border-right: 1px solid #fff;
}

.templatemo_box,
.templatemo_box_last {
  border-top: 1px solid #fff;
  border-left: 1px solid #fff;
  border-bottom: 1px solid #fff;
}

.templatemo_box img,
.templatemo_box_last img {
  width: 100px;
  display: block;
  margin: 0px auto 30px auto;
  padding-top: 70px;
}

.templatemo_box:hover,
.templatemo_box_last:hover {
  background: #217eb9;
  border-top: 1px solid #217eb9;
  border-left: 1px solid #519dcd;
  border-bottom: 1px solid #519dcd;
  border-radius: 10px;
  color: #ffffff;
}

.templatemo_box:hover div.templatemo_home_midheader,
.templatemo_box_last:hover div.templatemo_home_midheader {
  color: #fff;
}

.templatemo_box:hover div.boxsub1,
.templatemo_box_last:hover div.boxsub1 {
  background: rgba(16, 88, 130, 1);
  background: -moz-linear-gradient(-45deg, rgba(16, 88, 130, 1) 0%, rgba(18, 95, 139, 0) 28%, rgba(23, 112, 163, 0) 100%);
  background: -webkit-gradient(left top, right bottom, color-stop(0%, rgba(16, 88, 130, 1)), color-stop(28%, rgba(18, 95, 139, 0)), color-stop(100%, rgba(23, 112, 163, 0)));
  background: -webkit-linear-gradient(-45deg, rgba(16, 88, 130, 1) 0%, rgba(18, 95, 139, 0) 28%, rgba(23, 112, 163, 0) 100%);
  background: -o-linear-gradient(-45deg, rgba(16, 88, 130, 1) 0%, rgba(18, 95, 139, 0) 28%, rgba(23, 112, 163, 0) 100%);
  background: -ms-linear-gradient(-45deg, rgba(16, 88, 130, 1) 0%, rgba(18, 95, 139, 0) 28%, rgba(23, 112, 163, 0) 100%);
  background: linear-gradient(135deg, rgba(16, 88, 130, 1) 0%, rgba(18, 95, 139, 0) 28%, rgba(23, 112, 163, 0) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#105882', endColorstr='#1770a3', GradientType=1);
  margin: 0px -2px;
}

.templatemo_box:hover div.boxsub2,
.templatemo_box_last:hover div.boxsub2 {
  background: rgba(23, 112, 163, 0);
  background: -moz-linear-gradient(45deg, rgba(23, 112, 163, 0) 0%, rgba(18, 95, 139, 0) 72%, rgba(16, 88, 130, 1) 100%);
  background: -webkit-gradient(left bottom, right top, color-stop(0%, rgba(23, 112, 163, 0)), color-stop(72%, rgba(18, 95, 139, 0)), color-stop(100%, rgba(16, 88, 130, 1)));
  background: -webkit-linear-gradient(45deg, rgba(23, 112, 163, 0) 0%, rgba(18, 95, 139, 0) 72%, rgba(16, 88, 130, 1) 100%);
  background: -o-linear-gradient(45deg, rgba(23, 112, 163, 0) 0%, rgba(18, 95, 139, 0) 72%, rgba(16, 88, 130, 1) 100%);
  background: -ms-linear-gradient(45deg, rgba(23, 112, 163, 0) 0%, rgba(18, 95, 139, 0) 72%, rgba(16, 88, 130, 1) 100%);
  background: linear-gradient(45deg, rgba(23, 112, 163, 0) 0%, rgba(18, 95, 139, 0) 72%, rgba(16, 88, 130, 1) 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#1770a3', endColorstr='#105882', GradientType=1);
}

.templatemo_home_midheader {
  font-size: 26px;
  color: #0383d0;
  font-weight: bold;
  text-align: center;
}

.templatemo_home_midtext {
  text-align: center;
  margin: 0px 50px;
}

.templatemo_readmore {
  width: 120px;
  margin: 60px auto;
  border: 1px solid #ffffff;
  outline: 1px solid #82b4d4;
  text-align: center;
  line-height: 30px;
  color: #0a71b3;
  font-size: 14px;
  font-weight: 600;
}

.gradient {
  /* IE10+ */
  background-image: -ms-radial-gradient(center, ellipse closest-corner, #ffffff 30%, #9fbed1 100%);
  /* Mozilla Firefox */
  background-image: -moz-radial-gradient(center, ellipse closest-corner, #ffffff 30%, #9fbed1 100%);
  /* Opera */
  background-image: -o-radial-gradient(center, ellipse closest-corner, #ffffff 30%, #9fbed1 100%);
  /* Webkit (Safari/Chrome 10) */
  background-image: -webkit-gradient(radial, center center, 0, center center, 286, color-stop(30, #ffffff), color-stop(100, #9fbed1));
  /* Webkit (Chrome 11+) */
  background-image: -webkit-radial-gradient(center, ellipse closest-corner, #ffffff 30%, #9fbed1 100%);
  /* W3C Markup */
  background-image: radial-gradient(ellipse closest-corner at center, #ffffff 30%, #9fbed1 100%);
}

.knowledge-image img {
  margin: 20px;
  width: 250px;
  height: 150px;
}

.conference-table img {
  width: 350px;
  height: 300px;
}

.auditorium-table {
  width: 520px;
  height: 390px;
}

.group_view_image {
  width: 423px;
  height: 423px;
}

/*
---------------------------------------------
TM Features
---------------------------------------------
*/

#tmFeatures {
  padding-top: 68px;
  padding-bottom: 60px;
  max-width: 1260px;
  margin-left: auto;
  margin-right: auto;
}

.tm-feature-box {
  max-width: 360px;
  min-height: 480px;
  border-radius: 10px;
  text-align: center;
  padding: 40px 50px;
  margin-left: auto;
  margin-right: auto;
}

.tm-bg-white-transparent {
  background-color: rgba(231, 225, 225, 0.5);
}

.tm-feature-name {
  color: black;
  margin-bottom: 50px;
}

.tm-feature-icon-container {
  width: 110px;
  height: 110px;
  border: 1px solid #3E3F40;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 60px;
}

/*
---------------------------------------------
TM Features
---------------------------------------------
*/

.apply-btn {
  --bg1: #4f46e5;
  /* 主色（靛藍） */
  --bg2: #7c3aed;
  /* 次色（紫）   */
  --text: #ffffff;
  --shadow: 0 6px 16px rgba(79, 70, 229, .35);

  appearance: none;
  border: 0;
  border-radius: 6px;
  padding: .9rem 1.35rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .02em;
  color: var(--text);
  background: linear-gradient(135deg, var(--bg1), var(--bg2));
  box-shadow: var(--shadow);
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, filter .15s ease;
}

.apply-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(79, 70, 229, .45);
  filter: saturate(1.1);
}

.apply-btn:active {
  transform: translateY(0) scale(.98);
  box-shadow: 0 4px 12px rgba(79, 70, 229, .35);
}

.apply-btn:focus-visible {
  outline: 3px solid #c7d2fe;
  /* 聚焦外框 */
  outline-offset: 3px;
}

.apply-btn:disabled {
  opacity: .6;
  cursor: not-allowed;
  filter: grayscale(.2);
}

@media (prefers-reduced-motion: reduce) {
  .apply-btn {
    transition: none;
  }
}

/*
---------------------------------------------
tm-mb-1
---------------------------------------------
*/

.tm-container {
  margin-bottom: 100px;
}

.tm-container i {
  color: #ABC;
}

.tm-mb-1 {
  margin-bottom: 100px;
}

.tm-icon-2 {
  padding: 80px 30px;
}

.tm-bg-gray {
  background-color: #F2F2F2;
}

.tm-box-2 {
  padding: 53px 50px;
  max-width: 460px;
  margin-left: auto;
  margin-right: auto;
}

.tm-h3 {
  font-size: 1.6rem;
  margin-bottom: 25px;
}

.tm-text-primary {
  color: #06C;
}

.tm-mb-5 {
  margin-bottom: 30px
}

.tm-btn {
  font-size: 1.2rem;
  padding: 10px 25px;
  border: none;
}

.tm-btn-primary {
  background-color: #399;
  color: #fff;
  background-color: #007bff;
  border-color: #007bff;
}

.tm-btn-primary:hover {
  background-color: #2d827f;
  color: #fff;
}

.tm-link {
  display: inline !important;
}

.rounded-0 {
  border-radius: 0 !important;
}

/*
---------------------------------------------
Usege
---------------------------------------------
*/

.usage-portfolio {
  padding-top: 3rem !important;
}

.usage-portfolio .section-heading {
  margin-bottom: 50px;
  text-align: center;
}

.usage {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  margin-bottom: 40px;
  gap: 30px;
}

.usage-card {
  text-align: center;
  color: white;
  padding: 40px 30px;
}

.usage-glass {
  backdrop-filter: blur(20px);
  box-shadow: rgba(0, 0, 0, 0.1) 0px 8px 32px;
  position: relative;
  background: rgba(255, 255, 255, 1);
  border-width: 1px;
  border-style: solid;
  border-color: rgba(255, 255, 255, 0.2);
  border-image: initial;
  border-radius: 20px;
  transition: 0.3s;
  overflow: hidden;
}

.usage h3 {
  font-size: 1.5rem;
  margin-bottom: 15px;
  color: rgb(32, 32, 32);
}

.usage-icon {
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  margin: 0px auto 20px;
  background: rgba(255, 255, 255, 0.2);
  border-radius: 50%;
}

/*
---------------------------------------------
Activities
---------------------------------------------
*/

.activities img {
  width: 340px;
  height: 480px;
}

.activities .att-file-label {
  font-size: 1.2em;
}

/*
---------------------------------------------
Form Download
---------------------------------------------
*/
.form-label ul {
  display: flex;
  flex-wrap: wrap;
}

.form-label li {
  margin: 10px !important;
  padding: 8px 20px;
  border: 1px solid #12538d3d;
  border-radius: 1.5rem;
  font-size: 24px !important;
  background-color: #fff;
}

.magazine-label ul {
  display: flex;
  flex-wrap: wrap;
}

.magazine-label li {
  margin: 0px 30px !important;
  padding: 0px 30px;
  border: 1px solid rgb(22, 184, 243);
  border-radius: 1.8rem;
  font-size: 24px !important;
  background-color: #fff;
}

.form-box {
  margin-bottom: 1em;
  padding: 0.5em 1em;
  background-color: rgba(254, 254, 255, 0.6);
  border-radius: 5px;
  border-top: 8px solid #12538d3d;
  box-shadow: 3px 3px 5px rgba(0, 0, 0, .5);
}

.form-title {
  margin-top: 10px;
  text-indent: 5px;
  font-size: 1.2em;
  background-color: #e1e6f9;
}

.form-content p {
  text-align: right;
  margin-bottom: 20px !important;
}

.form-content hr {
  margin-top: 0 !important;
}

.form-content img {
  width: 60px;
  height: 60px;
}

/*
---------------------------------------------
divider
---------------------------------------------
*/
.divider {
  display: flex;

  &:before,
  &:after {
    content: "";
    flex: 1;
  }
}

.gradient {
  align-items: stretch;
  margin: 1em 0;
  height: 2em;
  line-height: 2em;
  color: white;
  background: black;

  &:before {
    background: linear-gradient(to right, white, black);
  }

  &:after {
    background: linear-gradient(to left, white, black);
  }
}

/*
---------------------------------------------
Coures Reserver
---------------------------------------------
*/
.input-group input,
.input-group input[type="radio"]+label,
.input-group input[type="checkbox"]+label:before,
.input-group select option,
.input-group select {
  width: 80%;
  padding: 1em;
  line-height: 1.4;
  background-color: #f9f9f9;
  border: 1px solid #e5e5e5;
  border-radius: 3px;
  -webkit-transition: 0.35s ease-in-out;
  -moz-transition: 0.35s ease-in-out;
  -o-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
  transition: all 0.35s ease-in-out;
}

input:focus {
  outline: 0;
  border-color: #bd8200;
}

input:focus+.input-icon i {
  color: #f0a500;
}

input:focus+.input-icon:after {
  border-right-color: #f0a500;
}

/*
input[type="radio"] {
  display: none;
}

input[type="radio"]+label,
select {
  display: inline-block;
  width: 50%;
  text-align: center;
  float: left;
  border-radius: 0;
}

input[type="radio"]+label:first-of-type {
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
}

input[type="radio"]+label:last-of-type {
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}

input[type="radio"]+label i {
  padding-right: 0.4em;
}

input[type="radio"]:checked+label,
input:checked+label:before,
select:focus,
select:active {
  background-color: #f0a500;
  color: #fff;
  border-color: #bd8200;
}

input[type="checkbox"] {
  display: none;
}

input[type="checkbox"]+label {
  position: relative;
  display: block;
  padding-left: 1.6em;
}

input[type="checkbox"]+label:before {
  position: absolute;
  top: 0.2em;
  left: 0;
  display: block;
  width: 1em;
  height: 1em;
  padding: 0;
  content: "";
}

input[type="checkbox"]+label:after {
  position: absolute;
  top: 0.45em;
  left: 0.2em;
  font-size: 0.8em;
  color: #fff;
  opacity: 0;
  font-family: FontAwesome;
  content: "\f00c";
}

input:checked+label:after {
  opacity: 1;
}
*/

select {
  height: 3.4em;
  line-height: 2;
}

select:first-of-type {
  border-top-left-radius: 3px;
  border-bottom-left-radius: 3px;
}

select:last-of-type {
  border-top-right-radius: 3px;
  border-bottom-right-radius: 3px;
}

select:focus,
select:active {
  outline: 0;
}

select option {
  background-color: #f0a500;
  color: #fff;
  color: #000;
}

.input-group {
  margin-bottom: 1em;
  zoom: 1;
}

.input-group:before,
.input-group:after {
  content: "";
  display: table;
}

.input-group:after {
  clear: both;
}

.input-group-icon {
  position: relative;
}

.input-group-icon input {
  padding-left: 4.4em;
}

.input-group-icon select {
  padding-left: 4.4em;
}

.input-group-icon .input-icon {
  position: absolute;
  top: 0;
  left: 0;
  width: 3.4em;
  height: 3.4em;
  line-height: 3.4em;
  text-align: center;
  pointer-events: none;
  margin-left: 1em !important;
}

.input-group-icon .input-icon:after {
  position: absolute;
  top: 0.6em;
  bottom: 0.6em;
  left: 3.4em;
  display: block;
  border-right: 1px solid #e5e5e5;
  content: "";
  -webkit-transition: 0.35s ease-in-out;
  -moz-transition: 0.35s ease-in-out;
  -o-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
  transition: all 0.35s ease-in-out;
}

.input-group-icon .input-icon i {
  -webkit-transition: 0.35s ease-in-out;
  -moz-transition: 0.35s ease-in-out;
  -o-transition: 0.35s ease-in-out;
  transition: 0.35s ease-in-out;
  transition: all 0.35s ease-in-out;
}

.col-half {
  padding-right: 10px;
  float: left;
  width: 50%;
}

.col-half:last-of-type {
  padding-right: 0;
}

.col-third {
  padding-right: 10px;
  float: left;
  width: 33.33333333%;
}

.col-third:last-of-type {
  padding-right: 0;
}

@media only screen and (max-width: 540px) {
  .col-half {
    width: 100%;
    padding-right: 0;
  }
}


/*
---------------------------------------------
button-18
---------------------------------------------
*/
.button-18 {
  align-items: center;
  background-color: #0A66C2;
  border: 0;
  border-radius: 100px;
  box-sizing: border-box;
  color: #ffffff;
  cursor: pointer;
  display: inline-flex;
  font-family: -apple-system, system-ui, system-ui, "Segoe UI", Roboto, "Helvetica Neue", "Fira Sans", Ubuntu, Oxygen, "Oxygen Sans", Cantarell, "Droid Sans", "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Lucida Grande", Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 600;
  justify-content: center;
  line-height: 20px;
  max-width: 180px;
  min-height: 40px;
  min-width: 0px;
  overflow: hidden;
  padding: 0px;
  padding-left: 20px;
  padding-right: 20px;
  text-align: center;
  touch-action: manipulation;
  transition: background-color 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s, box-shadow 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s, color 0.167s cubic-bezier(0.4, 0, 0.2, 1) 0s;
  user-select: none;
  -webkit-user-select: none;
  vertical-align: middle;
}

.button-18:hover,
.button-18:focus {
  background-color: #16437E;
  color: #ffffff;
}

.button-18:active {
  background: #09223b;
  color: rgb(255, 255, 255, .7);
}

.button-18:disabled {
  cursor: not-allowed;
  background: rgba(0, 0, 0, .08);
  color: rgba(0, 0, 0, .3);
}

/*
---------------------------------------------
FAQ
---------------------------------------------
*/

section.main-content .main-content-item .faq-content {
  background-color: rgba(250, 250, 250, 0.5);
  padding: 10px;
  border-radius: 20px;
}

/*
---------------------------------------------
Fulfillment
---------------------------------------------
*/

.fulfillment-content {
  padding: 115px 80px;
  border-radius: 20px;
}

.fulfillment .item:hover .image {
  background-color: #ee626b;
}

.fulfillment .item {
  padding: 35px;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.15);
  border-radius: 25px;
  background-color: #fff;
  text-align: center;
}

.fulfillment .item .image {
  width: 90px;
  height: 90px;
  display: inline-block;
  text-align: center;
  line-height: 90px;
  background-color: #0071f8;
  border-radius: 50%;
  transition: all .3s;
}

.fulfillment .item h4 {
  font-size: 22px;
  margin-top: 25px;
  display: block !important;
}

/*
---------------------------------------------
Site Map
---------------------------------------------
*/

/* ------------------------------------------------------------
	NUMBER OF COLUMNS: Adjust #primaryNav li to set the number
	of columns required in your site map. The default is
	4 columns (25%). 5 columns would be 20%, 6 columns would
	be 16.6%, etc.
------------------------------------------------------------ */

#primaryNav li {
  width: 25%;
}

#primaryNav li ul li {
  width: 100% !important;
}

#primaryNav.col1 li {
  width: 99.9%;
}

#primaryNav.col2 li {
  width: 50.0%;
}

#primaryNav.col3 li {
  width: 33.3%;
}

#primaryNav.col4 li {
  width: 25.0%;
}

#primaryNav.col5 li {
  width: 20.0%;
}

#primaryNav.col6 li {
  width: 16.6%;
}

#primaryNav.col7 li {
  width: 14.2%;
}

#primaryNav.col8 li {
  width: 12.5%;
}

#primaryNav.col9 li {
  width: 11.1%;
}

#primaryNav.col10 li {
  width: 10.0%;
}

/* ------------------------------------------------------------
	General Styles
------------------------------------------------------------ */
.sitemap {
  margin: 0 0 40px 0;
  float: left;
  width: 100%;
}

/* ------------------------------------------------------------
	Site Map Styles
------------------------------------------------------------ */

/* --------	Top Level --------- */

#primaryNav {
  margin: 0;
  float: left;
  width: 100%;
}

#primaryNav #home {
  display: block;
  float: none;
  position: relative;
  z-index: 2;

  padding: 0 0 30px 0;
}

#primaryNav li {
  float: left;
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L1-center.png') center top no-repeat;
  padding: 30px 0;
  margin-top: -30px;
}

#primaryNav li a {
  margin: 0 20px 0 0;
  padding: 20px 0;
  display: block;
  font-size: 1.5em;
  font-weight: 500;
  text-align: center;
  color: black;
  background: #c3eafb url('http://idefisc-corp.fr/wp-content/themes/konzept/images/white-highlight.png') top left repeat-x;
  border: 2px solid #b5d9ea;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -webkit-box-shadow: rgba(0, 0, 0, 0.5) 2px 2px 2px;
  -moz-box-shadow: rgba(0, 0, 0, 0.5) 2px 2px 2px;
  /* FF 3.5+ */
}

#primaryNav li a:hover {
  background-color: #e2f4fd;
  border-color: #97bdcf;
}

#primaryNav li:last-child {
  background: url(/assets/images/L1-right.png) center top no-repeat;
}

#primaryNav a:link:before,
#primaryNav a:visited:before {
  /*content: " "attr(title)" ";*/
  display: block;
  text-transform: uppercase;
  font-size: 14px;
  margin-bottom: 5px;
  word-wrap: break-word;
}

#primaryNav li a:link:before,
#primaryNav li a:visited:before {
  color: #78a9c0;
}

/* --------	Second Level --------- */

#primaryNav li li {
  width: 100%;
  clear: left;
  margin-top: 0;
  padding: 10px 0 0 0;
  background: url('https://i.ibb.co/bNhMjBF/vertical-line.png') center bottom repeat-y;
}

#primaryNav li li a {
  background-color: #cee3ac;
  border-color: #b8da83;
  font-size: 1.2em;
  padding: 10px 0;
}

#primaryNav li li a:hover {
  border-color: #94b75f;
  background-color: #e7f1d7;
}

#primaryNav li li:first-child {
  padding-top: 30px;
}

#primaryNav li li:last-child {
  background: url('https://i.ibb.co/bNhMjBF/vertical-line.png') center bottom repeat-y;
}

#primaryNav li li a:link:before,
#primaryNav li li a:visited:before {
  color: #8faf5c;
}

/* --------	Third Level --------- */

#primaryNav li li ul {
  margin: 10px 0 0 0;
  width: 100%;
  float: right;
  padding: 9px 0 10px 0;
}

#primaryNav li li li {
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L3-center.png') left center no-repeat;
  padding: 5px 0;
}

#primaryNav li li li a {
  background-color: #fff7aa;
  border-color: #e3ca4b;
  font-size: 1em;
  padding: 5px 0;
  width: 80%;
  float: right;
}

#primaryNav li li li a:hover {
  background-color: #fffce5;
  border-color: #d1b62c;
}

#primaryNav li li li:first-child {
  padding: 15px 0 5px 0;
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L3-li-top.png') left center no-repeat;
}

#primaryNav li li li:last-child {
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L3-bottom.png') left center no-repeat;
}

#primaryNav li li li a:link:before,
#primaryNav li li li a:visited:before {
  color: #ccae14;
  font-size: 9px;
}

/* --------	Fourth Level --------- */

#primaryNav li li li ul {
  margin: 10px 0 0 0;
  width: 100%;
  float: right;
  padding: 9px 0 10px 0;
}

#primaryNav li li li li {
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L3-center.png') left center no-repeat;
  padding: 5px 0;
}

#primaryNav li li li li a {
  background-color: #ff9ac0;
  border-color: #b24a6f;
  font-size: 0.8em;
  padding: 5px 0;
  width: 60%;
  float: right;
}

#primaryNav li li li li a:hover {
  background-color: #fffce5;
  border-color: #d1b62c;
}

#primaryNav li li li li:first-child {
  padding: 15px 0 5px 0;
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L3-li-top.png') left center no-repeat;
}

#primaryNav li li li li:last-child {
  background: url('http://idefisc-corp.fr/wp-content/themes/konzept/images/L3-bottom.png') left center no-repeat;
}

#primaryNav li li li li a:link:before,
#primaryNav li li li li a:visited:before {
  color: #ccae14;
  font-size: 9px;
}

/* ------------------------------------------------------------
	Utility Navigation
------------------------------------------------------------ */

#utilityNav {
  float: right;
  max-width: 50%;
  margin-right: 10px;
}

#utilityNav li {
  float: left;
  margin-bottom: 10px;
}

#utilityNav li a {
  margin: 0 10px 0 0;
  padding: 5px 10px;
  display: block;
  border: 2px solid #e3ca4b;
  font-size: 12px;
  font-weight: bold;
  text-align: center;
  color: black;
  background: #fff7aa url('http://idefisc-corp.fr/wp-content/themes/konzept/images/white-highlight.png') top left repeat-x;
  -moz-border-radius: 5px;
  -webkit-border-radius: 5px;
  -webkit-box-shadow: rgba(0, 0, 0, 0.5) 2px 2px 2px;
  -moz-box-shadow: rgba(0, 0, 0, 0.5) 2px 2px 2px;
  /* FF 3.5+ */
}

#utilityNav li a:hover {
  background-color: #fffce5;
  border-color: #d1b62c;
}

#utilityNav li a:link:before,
#utilityNav li a:visited:before {
  color: #ccae14;
  font-size: 9px;
  margin-bottom: 3px;
}

/*
---------------------------------------------
GuestBook
---------------------------------------------
*/
.guestbook {
  width: 80%;
  border-radius: 20px;
  box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1);
  margin: 0 auto;
  padding: 50px;
}

.form-label {
  font-weight: 600;
  font-size: 1.1rem;
}

.form-control {
  border-radius: 12px;
  padding: 15px;
  font-size: 1.1rem;
}

.input-group-text {
  width: 150px;
  background-color: #007bff;
  color: white;
  border-radius: 12px 0 0 12px;
  font-size: 1.3rem;
  padding: 0 20px;
  justify-content: center;
}

.guestbook-btn {
  display: inline-block;
  font-weight: 400;
  line-height: 1.5;
  color: #edf0f3;
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  background-color: transparent;
  border: 1px solid transparent;
  padding: .375rem .75rem;
  font-size: 1rem;
  border-radius: .25rem;
  transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out
}

.guestbook-btn-primary {
  background-color: #007bff;
  border: none;
  border-radius: 12px;
  font-size: 1.2rem;
  padding: 12px 25px;
}

.guestbook-btn-primary:hover {
  background-color: #0056b3;
  color: #F2F2F2;
}

.checkbox-box {
  padding: 15px 20px;
}

.form-check-input {
  width: 1.2em;
  height: 1.2em;
  border: 2px solid #007bff;
  border-radius: 4px;
  background-color: #fff;
  appearance: none;
  cursor: pointer;
  position: relative;
  margin-right: 10px;
  transition: all 0.2s ease-in-out;
}

.form-check-input:checked {
  border-color: #007bff;
}

.form-check-input:checked::after {
  position: absolute;
  top: 0;
  left: 3px;
  font-size: 1.2em;
  color: white;
}

.form-check-label {
  font-size: 1.05rem;
  font-weight: 500;
  color: #333;
  user-select: none;
}

.form-check-label a {
  display: inline;
  color: #1a73e8;
  padding-top: 12px;
}

.alert-card {
  text-align: center;
}

.back-button-zone {
  text-align: center;
  margin-top: 50px;
}

.back-button {
  /* 讓連結看起來像按鈕 */
  display: inline-block;
  text-decoration: none;
  /* 移除底線 */

  /* 顏色和填充 */
  background-color: #1c3149;
  /* 主藍色 */
  color: white;
  padding: 10px 40px;
  border-radius: 15px;
  /* 圓角 */

  /* 字體 */
  font-size: 16px;
  font-weight: bold;
  text-align: center;

  /* 避免邊框影響大小 */
  border: none;
  cursor: pointer;
  /* 提示可點擊 */
  transition: background-color 0.3s ease;
  /* 平滑過渡效果 */
}

/* 懸停效果：滑鼠移上去時變暗 */
.back-button:hover {
  background-color: #0056b3;
  color: #fff;
}

/*
---------------------------------------------
Calendar
---------------------------------------------
*/

:root {
  --w: 160px;
  --h: 190px;
  --radius: 12px;
}

/* 日曆卡片主體 */
.calendar-card {
  width: var(--w);
  height: var(--h);
  border-radius: var(--radius);
  background: linear-gradient(180deg, #fff8dc 0%, #fff5c9 100%);
  position: relative;
  box-shadow:
    0 6px 18px rgba(80, 60, 20, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.5);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  border: 1px solid rgba(120, 90, 20, 0.25);
  overflow: hidden;
  transition: transform 0.2s ease;
}

/* 模擬紙質紋理（noise pattern） */
.calendar-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(0deg,
      rgba(255, 255, 255, 0.05) 0px,
      rgba(0, 0, 0, 0.03) 1px,
      transparent 2px),
    repeating-linear-gradient(90deg,
      rgba(255, 255, 255, 0.05) 0px,
      rgba(0, 0, 0, 0.03) 1px,
      transparent 2px);
  opacity: 0.25;
  pointer-events: none;
}

/* 滑過微浮起效果 */
.calendar-card:hover {
  transform: translateY(-3px);
}

/* 月份條 */
.calendar-card__month {
  width: 100%;
  padding: 10px 8px;
  text-align: center;
  font-weight: 700;
  letter-spacing: 1px;
  font-size: 1.8rem;
  background: linear-gradient(180deg, #ffe7a1 0%, #ffd86b 100%);
  color: #6a3e00;
  border-bottom: 1px solid rgba(120, 80, 0, 0.15);
  box-shadow: inset 0 -4px 8px rgba(0, 0, 0, 0.05);
  position: relative;
  z-index: 1;
}

/* 日期區 */
.calendar-card__date {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  position: relative;
  z-index: 1;
}

.calendar-card__num {
  font-size: 58px;
  line-height: 1;
  font-weight: 800;
  color: #5a3300;
  text-shadow: 0 2px 0 rgba(255, 255, 255, 0.6);
  transform: translateY(6px);
}

/* 星期幾欄位 */
.calendar-card__weekday {
  width: 100%;
  text-align: center;
  font-size: 0.9rem;
  font-weight: 600;
  color: #7a4b05;
  letter-spacing: 1px;
  margin-bottom: 4px;
}

/* 手機微調 */
@media (max-width: 420px) {
  :root {
    --w: 130px;
    --h: 160px;
  }

  .calendar-card__num {
    font-size: 46px;
  }
}

/*
---------------------------------------------
Journal Usage
---------------------------------------------
*/
.journal-usage {
  padding-top: 50px;
  padding-bottom: 60px;
}

.service-item {
  position: relative;
  z-index: 1;
  padding: 30px;
  box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.1);
  background-color: #fff;
  border-radius: 10px;
  border-top-right-radius: 50px;
  transition: all .3s;
}

.service-item:hover {
  background-image: url(../images/service-usage-bg.jpg);
  background-position: right top;
  background-repeat: no-repeat;
  background-size: cover;
}

.service-item .icon {
  margin-left: 0px;
  margin-bottom: 30px;
  background-repeat: no-repeat;
  width: 50px;
  height: 50px;
  transition: all .3s;
}

.service-item h4 {
  transition: all .3s;
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 15px;
}

.service-item p {
  transition: all .3s;
  min-height: 150px;
  font-size: 15px;
  margin-bottom: 20px;
  line-height: 30px;
  font-weight: 400;
  color: #3a3939;
}

.service-item:hover h4,
.service-item:hover p,
.service-item:hover .text-button a {
  color: #fff;
}

.first-service .icon {
  background-image: url(../images/service-usage-icon-01.png);
}

.first-service:hover .icon {
  background-image: url(../images/service-usage-icon-hover-01.png);
}

.second-service .icon {
  background-image: url(../images/service-usage-icon-02.png);
}

.second-service:hover .icon {
  background-image: url(../images/service-usage-icon-hover-02.png);
}

.third-service .icon {
  background-image: url(../images/service-usage-icon-03.png);
}

.third-service:hover .icon {
  background-image: url(../images/service-usage-icon-hover-03.png);
}

.fourth-service .icon {
  background-image: url(../images/service-usage-icon-04.png);
}

.fourth-service:hover .icon {
  background-image: url(../images/service-usage-icon-hover-04.png);
}

/*
---------------------------------------------
OA Article
---------------------------------------------
*/
.OA-article>li {
  margin-bottom: 60px !important;
}

.text-accent {
  font-size: 1.2em;
  font-weight: 600;
}

.custom-list img {
  max-width: 100%; /* 關鍵！圖片最大寬度不能超過父容器（col-4）的寬度 */
  height: auto;    /* 保持圖片比例，不會變形 */
  display: block;  /* 移除圖片下方的預設微小留白 */
  margin: 0 auto;  /* 讓圖片在格子內置中（選用） */
}

