/*=================================================================
                             Color
=================================================================*/
:root {

	--color1: #8e5437;
  --color2: #d39617;
  --color3: #b3b9bd;
  --color4: #eae2d0;

  --tag_01: var(--color1);
  --tag_02: var(--color2);

  --default: #333333;
  --money: var(--color4);
  --yellow: var(--color4);
  --white: #fff;

  --c-spacing: 8px;
  --gap: 8px;
  --rounded: 8px;

  --ease: cubic-bezier(.250,.100,.250,1.000);
  --easeIn: cubic-bezier(.420,.000,1.000,1.000);
  --easeOut: cubic-bezier(.000,.000,.580,1.000);
  --easeInOut: cubic-bezier(.420,.000,.580,1.000);

  --base-shadow: hsl(214 80% 27% / 4%);
  --shade: hsl(from var(--base-shadow) calc(h + 8) 25 calc(l - 5));
  --shadow:
    0 0 0 1px var(--base-shadow),
    0 1px 1px -0.5px var(--shade),
    0 3px 3px -1.5px var(--shade),
    0 6px 6px -3px var(--shade),
    0 12px 12px -6px var(--base-shadow),
    0 24px 24px -12px var(--base-shadow);
}

/*=================================================================
                              設定
=================================================================*/
a {
  color: var(--default);
  @media (hover: hover) and (pointer: fine) {
    &:hover {
      color: var(--color1);
    }
  }
}
input, select, .form-control:not(textarea) {
  color: var(--color1);}
select.form-control:not(textarea) {
  padding-right: 1.5rem;}
.text-primary {
  color: var(--color1) !important;}
label[for="agree"] {
  color: var(--default) !important;}
#donate_tooltip {
  img {
    width: 25px;
  }
  &:is(:hover, :focus, :active) {
    background: transparent;
  }
}
figure {
  &:before, &.img_4by3:before {
    display: none;
  }
  &.img_4by3:hover {
    img {
      transform: scale(1.05);
    }
  }
}


/*== Main ==*/
@media (width > 375px) {
  .main_content [class$="section"] {
    padding-block: calc(3 * var(--c-spacing));}
}


/*================================
                 Nav
==================================*/
.main_content .nav .nav-item {
  a.nav-link {
    color: var(--default);
    background-color: var(--white);
    border-color: var(--color1);
    border-radius: 2rem;
  }
  :is(a.nav-link, a.nav-link.active):hover,
  a.nav-link.active {
    color: var(--white);
    background-color: var(--color1);
    border-color: var(--color1);
  }
}
/* [捐款] */
.help_section .nav-item {
  margin-inline: .5rem;
  a.nav-link {
    background-color: var(--color2);
    border-radius: 1rem;
  }
}


/*================================
                Slick
==================================*/
.slick-arrow {
  top: 50%;
  width: 50px;
  height: 50px;
}
:is(.slick-prev, .slick-next):before {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 50px;
  height: 50px;
  color: var(--color1);
  background-color: var(--white);
  background-image: none;
  font-size: 30px;
  font-family: 'Font Awesome 5 Free';
  font-weight: 700;
  border-radius: 50%;
  box-shadow: 0 0 15px -3px rgb(0 0 0 / 15%), 0 0 6px -4px rgb(0 0 0 / 10%);
  transition: background .15s var(--easeIn);
}
.slick-prev:before {
  content: '\f053';
}
.slick-next:before {
  content: '\f054';
}
.slick-dots :is(li, li.slick-active) button:before {
  opacity: 1;
  color: var(--white);
}
.page_main .slick-dots li.slick-active button:before {
  color: var(--color1);
}
@media (width < 992px) {
  .slick_banner .slick-arrow,
  .slick_banner .slick-prev:before, 
  .slick_banner .slick-next:before {
    width: 50px;
  }
  :is(.slick_donatewrap, .slick_goods, .slick_brand, .slick_issuu, .slick_photo, .slick_youtube) .slick-prev {
    left: 0px;
  }
  :is(.slick_donatewrap, .slick_goods, .slick_brand, .slick_issuu, .slick_photo, .slick_youtube) .slick-next {
    right: 0px;
  }
}
@media (width < 480px) {
  :is(.slick_news, .slick_events, .slick_goods, .slick_brand, .slick_issuu, .slick_photo, .slick_youtube) .slick-arrow {
    display: inline-block !important;
  }
  :is(.slick_news, .slick_events, .slick_goods, .slick_brand, .slick_issuu, .slick_photo, .slick_youtube) .slick-arrow:before {
    width: 50px;
    height: 50px;    
  }
  :is(.slick_news, .slick_events) .slick-prev {
    left: -10px;
  }
  :is(.slick_news, .slick_events) .slick-next {
    right: -10px;
  }
}

/*================================
                Button
==================================*/
.btn:is(.btn-primary, .btn-success, .btn-orange) {
  background-color: var(--color1);
  border-color: var(--color1);}
.btn:is(.btn-primary, .btn-success, .btn-orange):not(:disabled):not(.disabled):is(:hover, :focus, :active),
.link-orange a {
  &:before {
    display: none;
  }
  &:hover, &:focus {
    background-color: var(--color2);
    border-color: var(--color2);
  }
} 

.btn:is(.btn-outline-primary, .btn-outline-orange) {
  color: var(--default);
	border-color: var(--color1);}
.btn:is(.btn-outline-primary, .btn-outline-orange):not(:disabled):not(.disabled):is(:hover, :focus, :active) {
  color: var(--white);
  background-color: var(--color2);
  border-color: var(--color2);}

.btn-outline-brightgreen, .btn-outline-brightgreen:hover, .btn-outline-brightgreen:focus {
  color: var(--color1);
}

.btn-brightgreen {
  background: var(--color1);}
.btn-brightgreen:is(:hover, :focus, :active) {
  background: var(--color2);}

.btn-link {
  color: var(--default);}
.btn-link:is(:hover, :focus, :active) {
  color: var(--color1);}

:is(.finish_info, .records_content, .receipt_content) .custom_button {
  background-color: var(--color1);}
:is(.finish_info, .records_content, .receipt_content) .custom_button:is(:hover, :focus, :active) {
  color: var(--default);
  background-color: var(--color2);}

.stepwizard_btn :is(.previousBtn, .prev-step3-Btn):is(:hover, :focus, :active) {
  color: var(--color1);}
.stepwizard_btn :is(.previousBtn, .prev-step3-Btn, .prev-step3-Btn):before,
.stepwizard_btn :is(.previousBtn, .prev-step3-Btn, .prev-step3-Btn):after,
.stepwizard_btn :is(.previousBtn, .prev-step3-Btn, .prev-step3-Btn):is(:hover, :focus, :active):before,
.stepwizard_btn :is(.previousBtn, .prev-step3-Btn, .prev-step3-Btn):is(:hover, :focus, :active):after {
  background-color: var(--color2);}

.btn-gray {
  color: var(--default) !important;
}
.pay_group .btn-pay:hover, .pay_group .btn-pay:focus {
  border-color: var(--color1) !important;
}

/*================================
               ReadMore
==================================*/
.readMore {
  text-align: center;
  .read_more {
    z-index: 1;
    position: relative;
    display: inline-flex;
    padding-block: calc(5 * var(--c-spacing)) calc(3 * var(--c-spacing));
    align-items: center;
    .more {
      margin-inline-end: 1rem;
      font-size: 1.25rem;
      text-transform: uppercase;
    }
    .arrow {
      display: flex;
      justify-content: center;
      align-items: center;
      inline-size: 50px; 
      block-size: 50px;
      aspect-ratio: 1;
      background-color: var(--white);
      border: 1px solid var(--color1);
      border-radius: 50%;
      overflow: hidden;
      i {
        font-size: 1rem;
      }
    }
    /*__ [狀態] __*/
    &:where(:hover, :focus, :active) :is(.more, .arrow i) {
      color: var(--color2);
    }
    &:where(:hover, :focus, :active) .arrow i {
      animation: MoveRightInitial .2s forwards, MoveRightEnd .4s forwards .2s;
    }
  }  
}
@keyframes MoveRightInitial {
  100% {
    transform: translate3d(250%, 0, 0);
  }
}
@keyframes MoveRightEnd {
  0% {
    transform: translate3d(-150%, 0, 0);
  }
  100% {
    transform: translate3d(0, 0, 0);
  }
}


/*================================
                Title
==================================*/
.main_content {
  .section_title {
    padding-block: 4rem;
    .title_img {
      display: none;
    }
    .title {
      position: relative;
      padding-inline-start: calc(2 * var(--c-spacing));
      color: var(--default);
      letter-spacing: 1px;
      &:before {
        opacity: .6;
        content: '\f111';
        position: absolute;
        inset-block-start: 15%;
        inset-inline-start: calc(-1.5 * var(--c-spacing));
        color: var(--color2);
        font-size: 18px;
        font-family: 'Font Awesome 6 Free';
        font-weight: 900;
        transform: translateY(-50%);
      }
    }
  }
}


/*================================
                Header
==================================*/
/* [Logo] */
.header .navbar-brand {
  max-height: 70px;
  @media ( 480px < width < 992px) {
    width: 40%;
  }
  img {
    @media (width > 992px) {
      height: 70px;
    }
  }
}
/* [Top] */
.list-inline-item {
  .dropdown-menu {
    top: 0 !important;
    padding: 0;
    border-color: #f2f2f2;
    border-radius: var(--rounded);
    box-shadow: var(--shadow);
    .dropdown-item:not(.search_link) {
      @media(hover: hover)and (pointer: fine) {
        &:hover {
          background-color: var(--color4);
        }
      }
    }
  }
}
/* [Menu] */
.header_nav {
  @media (width > 992px) {
    margin-block var(--c-spacing);
  }
  nav {
    /* [第一層] */
    ul li {
      &:has(.sub_menu) {
        > a {
          padding-inline-end: 1.5rem;
          &:before {
            content: '\f0dd';
            position: absolute;
            inset-block-start: 47%;
            inset-inline-end: var(--c-spacing);
            color: var(--color2);
            font-size: 16px;
            font-family: 'Font Awesome 6 Free';
            font-weight: 900;
            transform: translateY(-50%);
          }
          &.menu_scale {
            &:before {
              inset-inline-end: 0;
            }
          }
        }
      }
      a {
        @media (hover: hover) and (pointer: fine) {
          &:hover {
            background-color: var(--color4);
          }
        }
        &:after {
          display: none;
        }
      }
    }
    /* [第二層] */
    .sub_menu {
      top: 100%;
      border: 1px solid #f2f2f2;
      border-radius: var(--rounded);
      box-shadow: var(--shadow);
      li {
        background-color: transparent;
        &:first-of-type {
          a {
            border-start-start-radius: var(--rounded);
            border-start-end-radius: var(--rounded);
          }
        }
        &:last-of-type {
          a {
            border-end-start-radius: var(--rounded);
            border-end-end-radius: var(--rounded);
          }
        }
        a {
          background-color: var(--white);
          border: 0;
          @media(hover: hover)and (pointer: fine) {
            &:hover {
              background-color: var(--color4);
            }
          }
        }
      } 
    }
  }
} 
#menu {
  .mm-navbar__tab_selected {
    background-color: var(--color1) !important;
  }
  .mm-listitem__text {
    .m_icon_default {
      width: 35px;
      height: 35px;
      line-height: 2;
      i {
        color: var(--color1);
        font-size: 1.5rem;
        filter: brightness(1.5);
      }
    }
    .m_icon {
      width: 30px;
      height: 30px;
      filter: brightness(1.5);
    }
  } 
}


/*================================
                Sidebar
==================================*/
@media (width > 992px) {
  /* [快速連結] */
  .sidebar_link {
    .sidebar_link_toggle,
    .sidebar_link_title {
      background-color: var(--color1);
    }
    &, 
    .sidebar_link_toggle,
    .sidebar_link_title {
      border-radius: 0;
    }
  }

  /* [立即捐款] */
  .sidebar_donate {
    right: -75px;
    bottom: 40%;
    width: 140px;
    transition: .3s ease;
    &:hover {
      right: 0;
    }
    span {
      letter-spacing: 0;
    }
    .donate_text {
      padding-left: 22px;
    }
    a {
      display: flex;
      justify-content: space-between;
      padding: 10px;
      width: auto;
      height: auto;
      color: var(--default);
      background: var(--color1);
      font-size: 16px;
      writing-mode: initial;
      border-radius: 0;
      &:hover {
        background: var(--color2);
      }
      i {
        padding: 5px;    
        width: 25px;
        height: 25px;
        color: var(--color1);
        background-color: var(--white);
        text-align: center;
        border-radius: 50%;
        animation: none;
      }
    }
  }

  /* [購物車] */
  .sidebar_cart {
    right: -75px;
    bottom: 33%;
    padding: 10px;
    width: 140px;
    height: auto;
    font-size: 16px;    
    background-color: var(--white);
    border-radius: 0;
    box-shadow: 0 0 5px 0.5px rgba(0, 0, 0, 0.1); 
    transition: .3s ease;
    &:hover {
      right: 0;
    }
    a {
      display: flex;
      justify-content: center;
      align-items: center;
    }
    p {
      display: inline-block;
      margin-bottom: 0;
    }
    i {
      padding: 0;
      padding-right: 12px;
      color: var(--color1);
      font-size: 18px;
    }
    span {
      margin: 0;
      padding: 0;
      padding-right: 30px;
      width: 25px;
      height: 25px;
      line-height: 25px;
      border-radius: 0;
    }
  }

  /*== 收合、ToTop ==*/
  #sidebar_showHide, .go_top {
    display: none;
  }
}


/*=================================================================
                              首頁
=================================================================*/
/*================================
                Banner
==================================*/
.main-slider .container-fluid {
  padding: 0;}
.slick_banner {
  .slick-arrow:before {
    background-image: none;
  }
  .slick-dots {
    bottom: .5rem;
  }
}


/*================================
              服務項目
==================================*/
.service_content {
  a {
    padding-block-start: calc(3 * var(--c-spacing));
    background-color: var(--white);
    &:hover {
      .service_circle {
        &:after {
          opacity: 1;
          transform: translate(-50%, -50%) scale(1);
        }
        i {
          color: var(--color2);
        }
      }
      .service_title {
        color: var(--color2);
      }
    }
  }
  .service_circle {
    position: relative;
    background: url(../images/bg-frame.svg) no-repeat center;
    background-size: contain;
    border-radius: calc(2 * var(--rounded));
    &:before {
      display: none;
    }
    &:after {
      z-index: -1;
      opacity: 0;
      pointer-events: none;
      content: '';
      position: absolute;
      inset: 50%;
      display: block;
      inline-size: 100%;
      block-size: 100%;
      background-color: #f7f2e7;
      transition: transform .4s var(--easeIn), opacity .4s var(--easeIn);
      transform: translate(-50%, -50%) scale(0);
    }
    i {
      color: var(--color1);
      transition: color .4s var(--easeIn);
    }
  }
  .service_title {
    color: #aa965c;
    font-size: 24px;
  }
}


/*================================
              最新消息
==================================*/
.news_section {
  position: relative;
  overflow: clip;
  .slick_news {
    z-index: 1;
    position: relative;
  }
  .news-bg {
    opacity: .7;
    pointer-events: none;
    .img-fluid, .news-bg-ball {
      position: absolute;
      inset-block-start: 50%;
      inset-inline-start: calc(-5 * var(--c-spacing));
      inline-size: 600px;
      aspect-ratio: 1;
      transform: translateY(-50%);
    }
    .news-bg-ball {
      inset-inline-start: 0;
      margin: auto;
      .circle {
        display: block;
        inline-size: 8px;
        aspect-ratio: 1;
        offset-path: path("M316.99,1c174.24,0,316,141.76,316,315.99,0,174.23-141.76,315.99-316,315.99S1,491.23,1,316.99c0-174.24,141.75-315.99,315.99-315.99");
        animation: moveCircle 10s linear infinite;
        background-color: #e2ddd3;
        border-radius: 50%;
      }
    }
  }  
}
@keyframes moveCircle {
  0% {
    offset-distance: 0%;
  }
  100% {
    offset-distance: 100%;
  }
}


/*================================
              幫助我們
==================================*/
.help_section {
  position: relative;
  background-color: #fcfaf5;
  border-inline: 10px solid #bfb28f;
  overflow: clip;
  @media (width > 1200px) {
    border-width: 40px;
  }
  &:after {
    opacity: .5;
    pointer-events: none;
    content: '';
    position: absolute;
    inset-block-end: calc(-5 * var(--c-spacing));
    inset-inline-end: calc(-5 * var(--c-spacing));
    inline-size: 200px;
    aspect-ratio: 1;
    background: url(../images/bg-hand.svg) no-repeat center;
    background-size: contain;
    @media (width > 1200px) {
      inline-size: 400px;
    }
  }
  .slick_donatewrap {
    z-index: 1;
    position: relative;
  }
}
.donate_case {
  block-size: 100%;
  background-color: var(--white);
  border-width: 1px;
  border-bottom-color: #ddd;
  border-radius: var(--rounded);
  .slick_donateitem {
    .img-fluid {
      border-start-start-radius: var(--rounded);
      border-start-end-radius: var(--rounded);        
    }
  }
  .donate_info {
    background-color: var(--white);
    border-end-start-radius: var(--rounded);
    border-end-end-radius: var(--rounded);
  }
}
.stepwizard {
  padding: calc(3 * var(--c-spacing));
  background-color: var(--white);
  block-size: 100%;
  border: 1px solid #ddd;
  border-radius: var(--rounded);
  .stepwizard_top {
    position: relative;
    &:before {
      height: 2px;
    }
  }
  .pay_group {
    .btn-pay:where(:hover, :focus) {
      border-color: var(--color1) !important;
    }
  }
  .cycle_group {
    .btn {
      color: var(--default) !important;
    }
  }
  .stepwizard_btn :is(.previousBtn, .prev-step3-Btn) {
    padding-bottom: .5rem;
    &:before, &:after {
      display: none;
    }
    @media(hover: hover)and (pointer: fine) {
      &:hover {
        padding-left: 1.5rem;
        background-color: var(--color4);
      }
    }
  }
}


/*================================
                花絮
==================================*/
.photo_section {
  position: relative;
  background: #eae3d2;
  overflow: clip;
  &:before, &:after {
    opacity: .3;
    pointer-events: none;
    content: '';
    position: absolute;
    inset-block-end: calc(-15 * var(--c-spacing));    
    inline-size: 200px;
    aspect-ratio: 1;
    @media (width > 1200px) {
      inline-size: 500px;
    }     
  }
  &:before {
    left: auto;
    top: auto;
    inset-inline-start: calc(-5 * var(--c-spacing));
    background: url(../images/bg-flower-1.svg) no-repeat center;
    background-size: contain;
  }
  &:after {
    inset-inline-end: calc(-5 * var(--c-spacing));
    background: url(../images/bg-flower-2.svg) no-repeat center;
    background-size: contain;
  }
  .slick-list {
    overflow-y: unset;
  }
  .section_content {
    z-index: 1;
    position: relative;
  }

  .gallery_item {
    a {
      &:hover {
        .gallery-photo:after, .youtube-photo:after {
          transform: rotate(5deg);
        }
      }
    }
    .gallery-photo {
      position: relative;
      &:after {
        pointer-events: none;
        content: '';
        position: absolute;
        inset: 0;
        display: block;
        background-color: #d8ccc3;
        border: 0;
        transition: transform .5s cubic-bezier(.215, .61, .355, 1);      
      }
      .img_4by3 {
        z-index: 1;
      }
    }
  }
  .youtube_item {
    .youtube-photo {
      &:before, &:after {
        display: none;
      }
    }
    .youtube_title {
      color: var(--default);
    }    
  }

}


/*================================
              活動區塊
==================================*/
.custom_column .custom_wrap {
  border-width: 2px;
}


/*================================
              Footer
==================================*/
.footer_toggle_wrap {
  margin-block-end: -5rem;
  text-align: start;
  #footer_toggle {
    padding: 0;
    inline-size: 44px;
    aspect-ratio: 1;
    color: var(--default);
    background: transparent;
    border-radius: calc(0.5 * var(--rounded));
    &:hover {
      color: var(--color1);
      i {
        transform: rotate(180deg);
      }
    }
    i {
      transition: transform .3s var(--ease);
    }
  }
  &.wrap_page {
    background-color: transparent;
  }
}
.footer_area, .section_footer {
  background: url(../images/bg-footer.png) repeat top left;
}
.footer_area {
  padding-block-start: calc(15 * var(--c-spacing));
}
.section_footer {
  padding-block-start: calc(10 * var(--c-spacing));
}


/*=================================================================
                                內頁
=================================================================*/
.page_main {
  margin-top: 7em;
  padding-block-end: calc(5 * var(--c-spacing));
}
.post_wrap {
  margin: 3rem auto;
}


/*================================
              管理員登入
==================================*/
#body.authors_login {
  background-color: #f8f5f3;}


/*================================
               愛心車
==================================*/
.cart_content .pay :where(label, a.ml-auto) {
  flex-shrink: 0;}
.cart_content .pay_group {
  display: flex;
  flex-wrap: wrap;
  gap: calc(0.5 * var(--gap));}


/*================================
               義賣
==================================*/
.goods_money {
  color: var(--color2);}


/*================================
              志工/捐物
==================================*/
.volunteer_table .volunteer_tag {
  color: var(--default);
  background-color: var(--color2);
  font-weight: 400;
  border-radius: calc(0.5 * var(--rounded));
}


/*================================
              會員中心
==================================*/
.edit_content .nav-tabs > li.active > a, .edit_content .nav-tabs > li > a:hover {
  color: var(--color1);
}