@import url(reset.css);
@import url(common.css);
@import url(header.css);
@import url(footer.css);
@import url(swiper-bundle.css);
@import url(index.css);
/*----------------------------------*\
  # works                    
\*----------------------------------*/
.bg_works::before {
  content: "";
  position: fixed;
  inset: 0;
  background: url(../images/bg_works2.webp) 0 0/cover fixed; 
  opacity: 0.81;
  z-index: -1;
}
.works {
  padding: var(--gap-5) var(--gap-10);   
  column-count: 2;  
  column-gap: .9rem;  
}
.work {
  place-self: center;  
  position: relative;  
  border: solid .81rem transparent;  
  padding: 0.9rem; /*白邊*/
  -webkit-clip-path: polygon(0 2.5em, 2.5em 0, 100% 0, 100% calc(100% - 2.5em), calc(100% - 2.5em) 100%, 0 100%);
          clip-path: polygon(0 2.5em, 2.5em 0, 100% 0, 100% calc(100% - 2.5em), calc(100% - 2.5em) 100%, 0 100%);
  display: inline-block;  
  box-shadow: var(--box-sd);
}
.works.frameWorks .work{
  padding: 0rem;/*不要白邊*/
}
.work::before, 
.work::after {  
  --i: 0;
  --s: calc(2*var(--i) - 1);  
  position: absolute;  
  top: calc(var(--i)*100% - var(--s)*0.25em);
  left: calc(var(--i)*100% - var(--s)*0.25em);
  width: 3.5355339059em;  
  height: 0.5em;
  transform-origin: 50% 0;  
  transform: translate(-50%) rotate(calc(var(--i)*.5turn - 45deg)) translatey(-1px);
  background: radial-gradient(farthest-side at 50% 0, #0008, #0004 30%, transparent);
  content: "";
}
.work::after {
  --i: 1 ;
}
.work figcaption::before {  
  position: absolute;
  content: "";
  inset: 0;  
  z-index: -1;  
  box-shadow: 3px 3px 13px #0007;
  background: #FFF;  
}
.work img.show { 
  animation: reveal-down .63s both;
  animation-delay: 0s; 
}
@media (max-width: 1199px){
  .works {
    padding: var(--gap-2) var(--gap-5); 
  }  
}
@media (max-width: 991px){
  .works {
    padding: var(--gap-2); 
  }  
}
@media (max-width: 768px){
  .works {    
    column-count: 1;
  }  
}

/*----------------------------------*\
  # service                    
\*----------------------------------*/
.bg_service::before {
  content: "";
  position: fixed;
  inset: 0;  
  background: url('../images/bg_service.webp') center/cover no-repeat,linear-gradient(to top, #FFE8D8 30%, #F0F1F2);
  opacity: 0.3;
  z-index: -1;
}
.services {
  display: grid;
  gap: 1.35rem; 
  grid-template-columns: repeat(3, 1fr);   
}
.service-box {
  padding: var(--gap-2) var(--gap_1);  
  border-radius: .45rem;  
  box-shadow: var(--box-sd);
  text-align: center;
  background-color: rgba(255, 255, 255, 0.36);
  backdrop-filter: blur(18px); 
  -webkit-backdrop-filter: blur(18px);
}
.service-box { 
  animation: reveal-up .63s both;   
}
.service-box:nth-child(3n-2){
  animation-delay: .54s;
}
.service-box:nth-child(3n-1){
  animation-delay: .72s;
}
.service-box:nth-child(3n){
  animation-delay: .9s;
}
.service-box h2 {
  margin-bottom: var(--gap);
  font-size: var(--title); 
  padding-bottom: var(--gap-1);
  border-bottom: .045rem dotted var(--main); 
}
.service-box h2 span {
  font-weight: 300;
  font-size: 81%;
}
.service-box p {
  text-align: left; 
}
.service-box a {
  animation-delay: .36;
}
.service-box h5 { 
  font-weight: 500;
  font-size: var(--big);
  margin: var(--gap-1) 0 var(--gap);  
}
.service-box ul {
  display: inline-block;
  text-align: left;
  margin: 0 auto;
  padding-left: 0;
}
.service-box ul li {
  position: relative;
  padding-left: 1.2rem;
  margin-bottom: 0.5rem;
}
.service-box ul li::before {
  content: "✔";          
  position: absolute;
  left: 0;
  color: var(--main);           
  font-size: 0.9rem;
}
/*———————service說明圖*/
.service_imgs {
  display: flex;  
  padding: 0 var(--gap-6) var(--gap-10);  
}
.service_imgs img {
  display: inline-block;  
  max-width: 36%;
  min-width: 24rem;
  margin:0 var(--gap-1) var(--gap-1) 0;  
  box-shadow: var(--box-sd);
  border-radius: .36rem;
}
/*———————service預約區*/
.service_cta {  
  position: relative;
  background-color: var(--main);
  text-align: center;
  color: #FFF;   
}
.service_cta svg {
  position: absolute;
  bottom: 100%;
  bottom: calc(100% - 1px);
  left: 0;
  width: 100%;
  height: 80px; 
  display: block;
  fill: var(--main);
}
.service_cta h2 {  
  margin-bottom: var(--gap-2);
}
.service_cta.show h2{ 
  animation: reveal-right .63s both;
  animation-delay: 0s; 
}
.service_cta p {  
  margin-bottom: var(--gap-2);
}
.service_cta.show p{ 
  animation: reveal-right .63s both;
  animation-delay: .36s; 
}
.service_cta.show a { 
  animation: fadeIn .36s both;
  animation-delay: .54s; 
}
@media (max-width: 1199px){  
  .services {    
    grid-template-columns: repeat(2, 1fr); 
    padding: var(--gap-2) var(--gap-2) var(--gap-6);         
  }
  /*———————service說明圖*/
  .service_imgs {
    justify-content: center;
    padding: 0 var(--gap-2) var(--gap-10);
  }
  .service_imgs img { 
    min-width: 360px;    
  }
  /*———————service預約區*/
  .service_cta {  
    padding: var(--gap-5) var(--gap-2); 
  }
  .service_cta svg {    
    height: 45px; 
  } 
  .service-box:nth-child(3n-2){
    animation-delay: unset;
  }
  .service-box:nth-child(3n-1){
    animation-delay: unset;
  }
  .service-box:nth-child(3n){
    animation-delay: unset;
  } 
  .service-box:nth-child(2n-1){
    animation-delay: .45s;
  }
  .service-box:nth-child(2n){
    animation-delay: .63s;
  } 
}
@media (max-width: 767px){  
  .services {    
    grid-template-columns: repeat(1, 1fr);     
  }
  .service-box {
    margin: .9rem 0;
  }
  .service-box.show {
    animation: reveal-right .63s both;
    animation-delay: .45s;
  }  
  .service-box:nth-child(2n-1).show{
    animation-delay: .45s;
  }
  .service-box:nth-child(2n).show{
    animation-delay: .45s;
  }
  /*———————service說明圖*/
  .service_imgs {
    flex-wrap: wrap;    
  }
  .service_imgs img {
    display:block;
    max-width: 100%;
    min-width: 100%;
    margin:0 auto 18px;    
  }  
}

/*----------------------------------*\
	# testimonials                    
\*----------------------------------*/
.testimonials-section {   
  margin: 0 auto var(--gap-3);
  min-width: 63%;
  max-width: 54rem;  
}
.chat-bubble {
  display: flex;
  align-items: flex-start;
  margin-bottom: 1.5rem;
}
.chat-bubble.show { 
  animation: reveal-right .63s both;  
}
.chat-bubble.user {
  flex-direction: row;
}
.chat-bubble.company {
  flex-direction: row-reverse;
}
.avatar {
  width: 2.34rem;  
  margin: 0 0.8rem;
}
.avatar img {
  width: 100%;
  border-radius: 50%;
}
.bubble {  
  background: var(--weak);
  padding: 1rem;
  border-radius: 1rem;
  max-width: 75%;
  position: relative;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);  
}
.company .bubble {
  background: var(--main);
  color: #fff;
}
.bubble p {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.5;
}
.name {
  display: block;
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: #999;  
}
.company .name {
  color: #ffeaea;
}
@media (max-width: 600px) {
  .chat-bubble {
    flex-direction: column;
    align-items: flex-start;
  }
  .chat-bubble.company {
    align-items: flex-end;
  }
  .bubble {
    max-width: 100%;
  }
  .avatar {
    width: 60px;
    margin-bottom: 0.5rem;
  }
}

/*----------------------------------*\
	# frames                
\*----------------------------------*/
.frames { 
  padding: var(--gap-5) 15.3vw;  
  column-count: 2; 
  column-gap: 1.8vw;  
}
.frame-item {
  display: inline-block;
  background: #FFF;  
  margin-bottom: var(--gap-1);
  width: 100%;
  -webkit-transition:1s ease all;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-shadow: 3px 3px 5px 0 #ccc;
  box-shadow:var(--box-sd);
}
.frame-item.show {
  animation: reveal-right .63s both;
  animation-delay: 0s; 
}
.frame-item img {width:100%;}
.frames-msg {
  display: table;  
  margin: 0 auto;  
  text-align: left; 
  word-break: break-word;
}
@media (max-width: 1199px){
  .frames { 
    padding: var(--gap-2) 12vw;
  }  
}
@media (max-width: 601px){
  .frames { 
    padding: var(--gap-2) var(--gap-2) var(--gap-5);    
    column-count: 1;
  }  
}

/*----------------------------------*\
	# works                    
\*----------------------------------*/
.works-section { 
  min-width: 63%;
  max-width: 60rem;
  margin:0 auto var(--gap-5);
  text-align: center;
}
.works-grid {
  display: grid;  
  grid-template-columns: repeat(3, 1fr);
  gap: 1.8rem;
}
.work-card {
  background: #fff;
  border-radius: .36rem;
  overflow: hidden;
  box-shadow: 0 4px 12px rgba(0,0,0,0.05);
  box-shadow: var(--box-sd);
  display: flex;
  flex-direction: column;
  transition: transform 0.3s ease;
}
.work-card:hover {
  transform: translateY(-5px);
}
.work-card img {
  width: 100%;
  height: auto;
  object-fit: cover;  
}
/*—————animation*/
.work-card img.show { 
  animation: reveal-right .63s both;
  animation-delay: 0s; 
}
.work-card:nth-child(3n-1) img {
  animation-delay: .27s;
}
.work-card:nth-child(3n) img {
  animation-delay: .54s;
}

.work-content {
  padding: 1rem;
  text-align: left;
}
.work-content h2 {
  color: var(--main);
  margin-bottom: 0.5rem;
  font-size: var(--keyword);
  font-family: var(--base);
  font-weight: 700;
}
.work-content p {  
  margin-bottom: 0.9rem;
}
.tag {
  background-color: var(--main);
  color: #fff;
  font-size: var(--tiny);
  padding: 0.3rem 0.6rem;
  border-radius: .99rem;
  display: inline-block;
}
@media (max-width: 1199px){
  .works-section { 
    /*padding: var(--gap-2) var(--gap-2) var(--gap-10);*/
   
  }
  .works-grid {    
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
  }
  /*—————animation*/  
  .work-card:nth-child(3n-1) img {
    animation-delay: unset;
  }
  .work-card:nth-child(3n) img {
    animation-delay: unset;
  }
  .work-card:nth-child(2n-1) img {
    animation-delay: .27s;
  }
  .work-card:nth-child(2n) img {
    animation-delay: .54s;
  }
} 
@media (max-width: 541px){
  .works-grid {    
    grid-template-columns: repeat(1, 1fr);    
  }
  .work-card {
    min-width: 63%;
    max-width: 300px;
    margin:.45rem auto;
  }
  /*—————animation*/
  .work-card:nth-child(2n-1) img {
    animation-delay: unset;
  }
  .work-card:nth-child(2n) img {
    animation-delay: unset;
  }
} 

/*----------------------------------*\
	# contact                    
\*----------------------------------*/
.form-section { 
  min-width: 63%;
  max-width: 45rem;
  margin: auto;
  padding: var(--gap-5) var(--gap-6) var(--gap-8);
}
.contact-form { 
  display: flex;
  flex-direction: column;
}
.contact-form.show { 
  animation: reveal-right .63s both;
  animation-delay: .63s; 
}
.contact-form label {  
  font-weight: 500;
  font-size: var(--p);
  line-height: 1.35;
  margin-bottom: var(--gap);
}
.contact-form input,
.contact-form textarea {
  padding: 0.72rem 0.54rem;
  border: .045rem solid var(--border);
  border-radius: .36rem;  
  margin-bottom: 1.2rem;
  font-size: var(--big);
}
.contact-form textarea {
  resize: vertical;
}
.contact-form .btn-primary {
  margin-top: var(--gap_2);
  padding: 0.72rem;
  background-color: var(--main);
  border: none;
  color: #fff;
  font-size: var(--p);
  font-weight: 500;
  border-radius: 2.4rem;
  cursor: pointer;
}
.contact-form .btn-primary:hover {
  background-color: var(--mate);
}
/* ———————聯絡資訊 */
.contact-info {
  position: relative;
  text-align: center;
  background-color: var(--soft-main);
  padding: var(--gap-3) var(--gap-6) var(--gap-5);
  display: flex;
  flex-direction: column;
  justify-content: center;  
}
.contact-info svg {
  position: absolute;  
  bottom: calc(100% - 1px);
  left: 0;
  width: 100%;
  height: 80px; 
  display: block;
  fill: var(--soft-main);
}
.contact-info h2 {
  margin-bottom: .81rem;   
}
.contact-info address { 
  display: table;  
  margin: 0 auto;  
  text-align: left; 
  word-break: break-word;
}
.contact-info div {
  margin: .27rem 0;
  transition: transform 0.54s ease-in-out, color 0.3s ease-in-out;  
}
.contact-info div:hover {
  transform: translate(0, -5.4%) scale(1);     
  color: var(--mate);
}
@media (max-width: 1199px){
  .form-section {    
    padding: var(--gap-2) var(--gap-2) var(--gap-6);
  }
  .contact-info {    
    padding: var(--gap-2) var(--gap-2) var(--gap-3);    
  }
  .contact-info svg {   
    height: 45px; 
  }
}
@media (max-width: 351px){
  .contact-info h2 {    
    letter-spacing: normal;   
  }
  .contact-info address {    
    letter-spacing: normal;
  }   
}  