/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */
/* Document
   ========================================================================== */
/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
  line-height: 1.15;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */ }

/* Sections
   ========================================================================== */
/**
 * Remove the margin in all browsers.
 */
body {
  margin: 0; }

/**
 * Render the `main` element consistently in IE.
 */
main {
  display: block; }

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0; }

/* Grouping content
   ========================================================================== */
/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
  -webkit-box-sizing: content-box;
     -moz-box-sizing: content-box;
          box-sizing: content-box;
  /* 1 */
  height: 0;
  /* 1 */
  overflow: visible;
  /* 2 */ }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/* Text-level semantics
   ========================================================================== */
/**
 * Remove the gray background on active links in IE 10.
 */
a {
  background-color: transparent; }

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
  border-bottom: none;
  /* 1 */
  text-decoration: underline;
  /* 2 */
  -webkit-text-decoration: underline dotted;
     -moz-text-decoration: underline dotted;
          text-decoration: underline dotted;
  /* 2 */ }

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
  font-weight: bolder; }

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
  font-family: monospace, monospace;
  /* 1 */
  font-size: 1em;
  /* 2 */ }

/**
 * Add the correct font size in all browsers.
 */
small {
  font-size: 80%; }

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* Embedded content
   ========================================================================== */
/**
 * Remove the border on images inside links in IE 10.
 */
img {
  border-style: none; }

/* Forms
   ========================================================================== */
/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
  font-family: inherit;
  /* 1 */
  font-size: 100%;
  /* 1 */
  line-height: 1.15;
  /* 1 */
  margin: 0;
  /* 2 */ }

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
  /* 1 */
  overflow: visible; }

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
  /* 1 */
  text-transform: none; }

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button; }

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0; }

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText; }

/**
 * Correct the padding in Firefox.
 */
fieldset {
  padding: 0.35em 0.75em 0.625em; }

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *    `fieldset` elements in all browsers.
 */
legend {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  color: inherit;
  /* 2 */
  display: table;
  /* 1 */
  max-width: 100%;
  /* 1 */
  padding: 0;
  /* 3 */
  white-space: normal;
  /* 1 */ }

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
  vertical-align: baseline; }

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
  overflow: auto; }

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */ }

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto; }

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  outline-offset: -2px;
  /* 2 */ }

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* 1 */
  font: inherit;
  /* 2 */ }

/* Interactive
   ========================================================================== */
/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
  display: block; }

/*
 * Add the correct display in all browsers.
 */
summary {
  display: list-item; }

/* Misc
   ========================================================================== */
/**
 * Add the correct display in IE 10+.
 */
template {
  display: none; }

/**
 * Add the correct display in IE 10.
 */
[hidden] {
  display: none; }

* {
  -webkit-box-sizing: border-box;
     -moz-box-sizing: border-box;
          box-sizing: border-box; }

body {
  background: #f0e6cc;
  font-size: 14px;
  font-family: 'Noto Sans TC', sans-serif;
  letter-spacing: 0.05em;
  line-height: 1.2; }

.wrapper {
  overflow: hidden; }

a {
  color: inherit;
  text-decoration: none; }

img {
  display: block;
  width: 100%; }

img.pad,
img.pc {
  display: none; }

.container {
  padding: 0 1.5em;
  margin: 0 auto; }

.container::after {
  content: '';
  display: block;
  clear: both; }

.bt-link {
  display: block;
  background: #e36c39 url("../img/bt_link.svg") no-repeat 50% 50%;
  -webkit-background-size: contain;
          background-size: contain;
  width: 1.5em;
  height: 1.5em;
  border-radius: 50%;
  -webkit-transform: translate(-50%, -50%);
      -ms-transform: translate(-50%, -50%);
       -o-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  position: absolute;
  -webkit-box-shadow: 0 0 5px rgba(227, 108, 57, 0.5);
          box-shadow: 0 0 5px rgba(227, 108, 57, 0.5);
  padding: 0;
  margin: 0;
  line-height: 1; }

@-webkit-keyframes btLink_circleInner {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(2.5);
    transform: translate3d(0, 0, 0) scale(2.5); }
  51% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(0.5);
    transform: translate3d(0, 0, 0) scale(0.5); }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@-o-keyframes btLink_circleInner {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(2.5);
    transform: translate3d(0, 0, 0) scale(2.5); }
  51% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(0.5);
    transform: translate3d(0, 0, 0) scale(0.5); }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

@keyframes btLink_circleInner {
  0% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); }
  50% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(2.5);
    transform: translate3d(0, 0, 0) scale(2.5); }
  51% {
    opacity: 0;
    -webkit-transform: translate3d(0, 0, 0) scale(0.5);
    transform: translate3d(0, 0, 0) scale(0.5); }
  100% {
    opacity: 1;
    -webkit-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0); } }

.bt-link::before {
  content: '';
  width: 3em;
  height: 3em;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.5);
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -1.5em 0 0 -1.5em;
  pointer-events: none;
  -webkit-animation: btLink_circleInner 1500ms ease-in-out 0s infinite;
  -o-animation: btLink_circleInner 1500ms ease-in-out 0s infinite;
  animation: btLink_circleInner 1500ms ease-in-out 0s infinite; }

.bt-link::after {
  content: '';
  width: 2em;
  height: 2em;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.2);
  position: absolute;
  left: 50%;
  top: 50%;
  margin: -1em 0 0 -1em;
  opacity: 0; }

.bt-link:hover::after {
  -webkit-animation: btLink_circleInner 1500ms ease-in-out 0s;
  -o-animation: btLink_circleInner 1500ms ease-in-out 0s;
  animation: btLink_circleInner 1500ms ease-in-out 0s; }

.sect1 {
  position: relative; }

.sect1 .bt-link.pos1 {
  left: 83%;
  top: 25%; }

.sect1 .bt-link.pos2 {
  left: 26%;
  top: 40.7%; }

.sect1 .bt-link.pos3 {
  left: 49%;
  top: 48.5%; }

.sect1 .bt-link.pos4 {
  left: 49%;
  top: 48.5%; }

.sect1 .bt-link.pos5 {
  left: 83.5%;
  top: 55%; }

.sect1 .bt-link.pos6 {
  left: 24%;
  top: 60.5%; }

.sect1 .bt-link.pos7 {
  left: 56%;
  top: 64%; }

.sect1 .bt-link.pos8 {
  left: 14%;
  top: 66%; }

.sect1 .bt-link.pos9 {
  left: 83.5%;
  top: 68%; }

.sect1 .bt-link.pos10 {
  left: 68%;
  top: 89.5%; }

.sect1 .bt-link.pos11 {
  left: 46%;
  top: 92.7%; }

.faq-sect {
  padding: 1em 0 2em; }

.faq-top {
  position: relative; }

.faq-top .deco1 {
  margin: 0 auto 0.5em;
  width: 2em; }

.faq-top .deco2 {
  display: none; }

.faq-heading {
  color: #ef8200;
  font-size: 1.3em;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.1em;
  margin: 0; }

.faq-box {
  background: #f9e8c2;
  -webkit-box-shadow: 3px 5px 10px rgba(0, 0, 0, 0.3);
          box-shadow: 3px 5px 10px rgba(0, 0, 0, 0.3);
  border-radius: 0.5em;
  overflow: hidden;
  max-width: 20em;
  margin: 1.5em auto 0;
  text-align: center;
  color: #fff;
  font-weight: 500; }

.faq-q {
  padding: 1em;
  background: #EF8200; }

.faq-a {
  padding: 1em; }

.faq-option {
  display: inline-block;
  position: relative;
  margin: 0 1em;
  cursor: pointer; }

.faq-option input {
  position: absolute;
  width: 0;
  height: 0;
  z-index: -1;
  opacity: 0;
  visibility: hidden; }

.faq-option span {
  display: block;
  border-radius: 0.5em;
  padding: 0.35em 0.5em;
  width: 4em;
  font-size: 1.1em;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s; }

.faq-option.yes span {
  background: #e5af2c; }

.faq-option.no span {
  background: #ADA697; }

.faq-option.yes span:hover,
.faq-option.yes input:checked + span {
  background: #ef8200; }

.faq-option.no span:hover,
.faq-option.no input:checked + span {
  background: #888; }

.faq-option input:checked + span {
  -webkit-box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5);
          box-shadow: inset 0 0 10px rgba(0, 0, 0, 0.5); }

.contact-sect {
  color: #fff;
  background: #ef8200;
  border-radius: 0 4.5em 0 0;
  padding: 1em 0 2em;
  margin-right: -4px;
  padding-right: 4px; }

.contact-top {
  position: relative;
  padding: 0.5em 0;
  margin-bottom: 1em; }

.contact-top .deco1 {
  position: absolute;
  left: 50%;
  top: 0;
  margin-left: 3.5em;
  width: 4.5em; }

.contact-heading {
  font-size: 1.3em;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0.1em;
  margin: 0;
  color: #f0e6cc; }

.contact-form {
  max-width: 80%;
  margin: 0 auto; }

.contact-form label {
  display: none; }

.contact-form .field {
  display: block;
  width: 100%;
  background: rgba(231, 208, 157, 0.52);
  border: 1px solid transparent;
  border-radius: 0.5em;
  line-height: 2em;
  padding: 0 0.75em;
  margin-bottom: 0.75em; }

.contact-form textarea.field {
  padding: 0.4em 0.75em;
  line-height: 1.5;
  height: 5.3em; }

.contact-form .field:focus {
  border-color: #fff;
  outline: none; }

.contact-form .form-footer {
  text-align: right;
  padding-top: 0.5em; }

.contact-form .captcha {
  display: inline-block;
  vertical-align: middle;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  margin: 0.5em 0; }

.contact-form .bt-submit {
  position: relative;
  cursor: pointer;
  display: inline-block;
  vertical-align: middle;
  background: #cb4e00;
  color: #fff;
  border-radius: 0.5em;
  font-weight: 700;
  padding: 0.5em 1em;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
  border: 0;
  margin-left: 1em; }

.contact-form .bt-submit:hover {
  background: #e5af2c; }

.contact-form .bt-submit::after {
  content: '';
  display: inline-block;
  vertical-align: middle;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0.4em 0 0.4em 0.6em;
  border-color: transparent transparent transparent #fff;
  margin: 0 0 0.15em 0.5em; }

.contact-info {
  width: 80%;
  margin: 2em auto 0; }

.contact-info-txt {
  padding: 0 1em; }

.contact-info-logo {
  margin-bottom: 1em; }

.contact-info-logo img {
  width: 10em; }

.contact-info-list {
  color: #f0e6cc;
  list-style-type: none;
  padding: 0;
  margin: 0 0 2em; }

.contact-info-list li {
  position: relative;
  padding-left: 1.75em;
  margin-bottom: 0.5em; }

.contact-info-list a:hover {
  color: #fff; }

.contact-info-list .ic {
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  background: no-repeat 50% 50%;
  -webkit-background-size: contain;
          background-size: contain;
  width: 1.25em;
  height: 1.25em; }

.contact-info-list .ic.phone {
  background-image: url("../img/ic_phone.png");
  -webkit-background-size: auto 82%;
          background-size: auto 82%; }

.contact-info-list .ic.map {
  background-image: url("../img/ic_map.png"); }

.contact-info-map {
  position: relative; }

.contact-info-map iframe {
  width: 100% !important;
  height: 240px !important; }

.header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  padding: 1.5em; }
  .header .logo {
    width: 9em; }

.result-body {
  background: url("../img/result_bg.jpg") no-repeat 30% 0;
  -webkit-background-size: cover;
          background-size: cover; }

.result-sect {
  height: 100vh;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
  padding-top: 5em;
  letter-spacing: 0.1em; }

.result-txt {
  color: #516a7c;
  font-size: 1.2em;
  margin-bottom: 2em; }
  .result-txt span {
    display: inline-block; }

.result-btn .bt-back {
  display: inline-block;
  vertical-align: middle;
  color: #fff;
  background: #ef8200;
  font-weight: 500;
  border-radius: 0.5em;
  padding: 0.4em 1em; }

@media (min-width: 640px) {
  body {
    font-size: 16px; }
  img.m {
    display: none; }
  img.pad {
    display: block; }
  .bt-link {
    width: 2em;
    height: 2em; }
  .faq-top {
    padding: 3.5em 0 1.5em; }
  .faq-top .deco1 {
    position: absolute;
    bottom: 0;
    left: 50%;
    width: 3em;
    margin-left: -10em;
    -webkit-transform: rotate(-30deg);
        -ms-transform: rotate(-30deg);
         -o-transform: rotate(-30deg);
            transform: rotate(-30deg); }
  .faq-top .deco2 {
    display: block;
    position: absolute;
    left: 50%;
    bottom: 0.75em;
    width: 9.5em;
    margin-left: 5.5em; }
  .faq-heading,
  .contact-heading {
    font-size: 1.75em; }
  .faq-box {
    max-width: 80%;
    border-radius: 1.25em;
    text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.5);
    margin-bottom: 2em; }
  .faq-option span {
    border-radius: 0.75em; }
  .contact-top .deco1 {
    margin-left: 5em;
    width: 6.75em; } }

@media (min-width: 768px) {
  .contact-sect {
    padding-top: 2em; }
  .container {
    width: 92%;
    max-width: 60em; }
  .contact-top {
    margin-bottom: 2.5em; }
  .contact-info {
    float: left;
    width: 42%;
    margin-top: 0; }
  .contact-form {
    float: right;
    width: 50%; }
  .contact-form .field {
    line-height: 2.5em;
    border-radius: 0.75em; }
  .contact-form .bt-submit {
    border-radius: 0.75em; }
  .contact-form textarea.field {
    height: 6.8em; }
  .contact-info-map iframe {
    height: 14.5em !important; } }

@media (min-width: 1200px) {
  body {
    font-size: 18px; }
  img.pad {
    display: none; }
  img.pc {
    display: block; }
  .faq-box {
    max-width: 70%; }
  .contact-sect {
    border-radius: 0 8em 0 0; } }

@media (min-width: 1440px) {
  body {
    font-size: 21px; } }

@media (min-width: 1680px) {
  body {
    font-size: 28px; } }

/*# sourceMappingURL=all.css.map */
