@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&family=Noto+Serif+TC:wght@200;300;400;500;600;700;900&display=swap");

@font-face {
    font-family: "Futura Std Medium";
    src: url(../fonts/Futura\ Std\ Medium.otf);
}

@font-face {
    font-family: "Futura Std Heavy";
    src: url(../fonts/Futura\ Std\ Heavy.otf);
}

@font-face {
    font-family: "Futura Std Bold";
    src: url(../fonts/Futura\ Std\ Bold.otf);
}

@font-face {
    font-family: "Futura Std Light";
    src: url(../fonts/Futura\ Std\ Light.otf);
}

@font-face {
    font-family: "Futura Std Book";
    src: url(../fonts/Futura\ Std\ Book.otf);
}

@font-face {
    font-family: "DFHeiStd-W5";
    src: url(../fonts/DFHeiStd-W5.otf);
}

@font-face {
    font-family: "GlowSansTC-Extended-Book";
    src: url(../fonts/GlowSansTC-Extended-Book.otf);
}

.Futura-Std-light {
    font-family: "Futura Std light";
}


.Futura-Std-light-l {
    font-family: "Futura Std light";
    font-weight: lighter;
    opacity: 0.8;
}

.Futura-Std-Book {
    font-family: "Futura Std Book";
}

.Futura-Std-Medium {
    font-family: "Futura Std Medium";
}

.Futura-Std-Heavy {
    font-family: "Futura Std Heavy";
}

[data-aos="opacity-up"] {
    opacity: 1;
    clip-path: inset(100% 0 0% 0);
    /* 初始状态下完全隐藏 */
}

    [data-aos="opacity-up"].aos-animate {
        opacity: 1;
        clip-path: inset(0 0 0 0);
        /* 显示全部图片 */
    }


[data-aos="opacity-down"] {
    opacity: 1;
    clip-path: inset(0% 0 100% 0);
    /* 初始状态下完全隐藏 */
}

    [data-aos="opacity-down"].aos-animate {
        opacity: 1;
        clip-path: inset(0 0 0 0);
        /* 显示全部图片 */
    }

[data-aos="opacity-left"] {
    opacity: 0;
    clip-path: inset(0% 100% 0 0);
    /* 初始状态下完全隐藏 */
}

    [data-aos="opacity-left"].aos-animate {
        opacity: 1;
        clip-path: inset(0 0 0 0);
        /* 显示全部图片 */
    }

[data-aos="opacity-right"] {
    opacity: 0;
    clip-path: inset(0 0 0% 100%);
    /* 初始状态下完全隐藏 */
}

    [data-aos="opacity-right"].aos-animate {
        opacity: 1;
        clip-path: inset(0 0 0 0);
        /* 显示全部图片 */
    }


[data-aos="opacity-x"] {
    opacity: 1;
    clip-path: inset(0% 100% 0 100%);
    /* 初始状态下完全隐藏 */
}

    [data-aos="opacity-x"].aos-animate {
        opacity: 1;
        clip-path: inset(0 0 0 0);
        /* 显示全部图片 */
    }

[data-aos="opacity-filter"] {
    opacity: 0;
    filter: sepia(100%);
}

    [data-aos="opacity-filter"].aos-animate {
        opacity: 1;
        filter: sepia(0%);
    }

[data-aos="test-right"] {
    opacity: 1;
    clip-path: polygon(0 0, 0 100%, 0 100%, 0 0);
    /* 初始状态下完全隐藏 */
}

    [data-aos="test-right"].aos-animate {
        opacity: 1;
        clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
        /* 显示全部图片 */
    }


:root {
}

body,
html {
    position: relative;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    scroll-behavior: smooth;
    --vw-base: calc(100vw / 1920);
}

    body > * {
    }

h1,
h2,
h3,
h4,
h5,
h6 {
    margin: 0;
    padding: 0;
}

a:link,
a:visited,
a:hover,
a:active {
    text-decoration: none;
}

button,
input,
textarea,
select,
option {
    margin: 0;
    padding: 0;
    -webkit-appearance: none;
    -webkit-border-radius: 0px;
    border-radius: 0;
    -moz-appearance: none;
    appearance: none;
    outline: none;
}

ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.pic-txt {
    position: absolute;
    bottom: calc(15* var(--vw-base));
    left: calc(15* var(--vw-base));
    color: #fff;
    font-size: calc(18* var(--vw-base));
    font-family: "FZLTZHB";
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: calc(20* var(--vw-base));
    z-index: 10;
    text-shadow: #4e484698 1px 1px 1px;
}

.header-bg-light {
    z-index: 20;
}

.container {
    position: relative;
    width: 100%;
    height: auto;
    opacity: 0;
    display: flex;
    flex-direction: row;
    overflow: clip;
}

.desktop {
    opacity: 1;
}

.loading {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 99999;
    background-color: #fff;
}

.spinner {
    width: 5vw;
    height: 5vw;
    position: absolute;
    left: 47.5%;
    top: 47.5%;
    transform: translate(-50%, -50%);
    background-color: #D5C1AA;
    border-radius: 100%;
    -webkit-animation: sk-scaleout 1.0s infinite ease-in-out;
    animation: sk-scaleout 1.0s infinite ease-in-out;
}

@-webkit-keyframes sk-scaleout {
    0% {
        -webkit-transform: scale(0)
    }

    100% {
        -webkit-transform: scale(1.0);
        opacity: 0;
    }
}

.header {
    background-color: #fff;
}

.header-bg-light {
    position: absolute;
    left: 0;
    top: 0;
    width: calc(147*var(--vw-base));
    height: 100%;
    border-right: rgba(0, 0, 0, 0.3) 1px solid;
    z-index: 20 !important;
}

.main1 {
    position: relative;
    width: calc(1773*var(--vw-base));
    height: calc(1556*var(--vw-base));
    z-index: 1;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    box-sizing: border-box;
    padding: calc(150*var(--vw-base)) calc(0*var(--vw-base)) calc(197*var(--vw-base)) calc(0*var(--vw-base));
    background-color: #ebeded;
}

.main1-bg {
    position: absolute;
    width: calc(1772*var(--vw-base));
    height: calc(1556*var(--vw-base));
    top: 0;
    left: 0;
}

.box1 {
    position: absolute;
    left: calc(258*var(--vw-base));
    top: calc(341*var(--vw-base));
    width: calc(220*var(--vw-base));
    height: calc(530*var(--vw-base));
    z-index: 3;
}

    .box1 .jp {
        position: absolute;
        width: calc(200*var(--vw-base));
        height: calc(27*var(--vw-base));
        right: calc(-200*var(--vw-base));
        top: calc(63*var(--vw-base));
    }

.jp-ani {
    position: relative;
    width: 100%;
    height: 100%;
    color: rgba(0, 0, 0, 0.2);
    font-size: calc(27*var(--vw-base));
    letter-spacing: 0.1em;
    font-family: "GlowSansTC-Extended-Book";
    transform: rotate(90deg);
    transform-origin: left top;
}

.box1 .chi {
    position: absolute;
    right: calc(30*var(--vw-base));
    top: calc(3*var(--vw-base));
    color: rgba(0, 0, 0, 1);
    font-size: calc(29*var(--vw-base));
    letter-spacing: 0.1em;
    font-family: "Noto Sans TC";
    font-weight: 100;
    writing-mode: vertical-rl;
}

.red-txt {
    color: #ca3923;
}

.red-txt-2 {
    color: rgb(202, 57, 35, 0.7);
}

.box1 .txt {
    position: absolute;
    right: calc(0);
    top: calc(0);
    color: rgba(0, 0, 0, 1);
    font-size: calc(17*var(--vw-base));
    letter-spacing: 0.1em;
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    writing-mode: vertical-rl;
    line-height: calc(37*var(--vw-base));
}

.boxline {
    position: absolute;
    left: calc(104*var(--vw-base));
    top: calc(-56*var(--vw-base));
    height: calc(115*var(--vw-base));
    width: 1px;
    background-color: #d40c13;
}

.contain-bg {
    position: relative;
    width: calc(1171*var(--vw-base));
    height: calc(1242*var(--vw-base));
    background-image: url(../img/07/bg2.jpg);
    background-size: cover;
    background-position: center center;
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    padding: calc(120*var(--vw-base)) calc(0*var(--vw-base)) calc(0*var(--vw-base)) calc(288*var(--vw-base));
}

.contain {
    position: relative;
    width: calc(673*var(--vw-base));
    display: flex;
    flex-direction: column;
}

    .contain .info {
        position: relative;
        display: flex;
        flex-direction: column;
        align-items: center;
    }

.info-title {
    position: relative;
    width: 100%;
    height: calc(61*var(--vw-base));
    display: flex;
    align-items: center;
    color: rgb(62, 58, 57, 0.5);
    font-family: "Futura Std Medium";
    font-size: calc(31*var(--vw-base));
    letter-spacing: 0.075em;
    background-color: #fff;
    box-sizing: border-box;
    padding-left: calc(30*var(--vw-base));
}

.fb-icon {
    position: absolute;
    bottom: calc(20*var(--vw-base));
    right: calc(78*var(--vw-base));
    width: calc(11*var(--vw-base));
    height: calc(23*var(--vw-base));
    background-color: #ca3923;
    mask-image: url(../img/07/icon-fb.png);
    mask-size: contain;
    mask-repeat: no-repeat;
    transition: background-color 0.4s ease;
}

.link-icon {
    position: absolute;
    bottom: calc(20*var(--vw-base));
    right: calc(33*var(--vw-base));
    width: calc(19*var(--vw-base));
    height: calc(21*var(--vw-base));
    background-color: #ca3923;
    mask-image: url(../img/07/icon-link.png);
    mask-size: contain;
    mask-repeat: no-repeat;
    transition: background-color 0.4s ease;
}

    .fb-icon:hover,
    .link-icon:hover {
        background-color: #a11e2d;
    }

.i1 {
    position: relative;
    display: flex;
    align-items: center;
    width: calc(608*var(--vw-base));
    height: calc(97*var(--vw-base));
    box-sizing: border-box;
    padding: calc(8*var(--vw-base)) 0;
    border-bottom: rgb(62, 58, 57, 0.5) solid 1px;
    margin-top: calc(10*var(--vw-base));
}

.i1-1 {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: calc(13*var(--vw-base));
}

.i1-2 {
    position: relative;
    margin-left: calc(194*var(--vw-base));
    display: flex;
    flex-direction: column;
    gap: calc(13*var(--vw-base));
}

.i-chi {
    position: relative;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.05em;
    color: #313131;
}

.i1-1 {
    position: relative;
    display: flex;
    flex-direction: column;
}


.i-num {
    position: relative;
    color: #313131;
    font-size: calc(18*var(--vw-base));
    font-family: "Futura Std Light";
    letter-spacing: 0.15em;
}

.info-line {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: calc(1*var(--vw-base));
    height: 70%;
    background-color: rgb(62, 58, 57, 0.5);
}

.i2 {
    position: relative;
    width: calc(608*var(--vw-base));
    margin-top: calc(14*var(--vw-base));
    display: flex;
    flex-direction: column;
    gap: calc(5*var(--vw-base));
}

.i-chi2 {
    position: relative;
    color: #000000;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.1em;
}

.map-icon {
    position: relative;
    top: calc(7*var(--vw-base));
    display: inline-block;
    margin-left: calc(10*var(--vw-base));
    width: calc(29*var(--vw-base));
    height: calc(32*var(--vw-base));
    background-image: url(../img/07/map.png);
    background-size: contain;
    background-repeat: no-repeat;
    transition: background-image 0.4s ease;
}

    .map-icon:hover {
        background-image: url(../img/07/map-hover.png);
        background-size: contain;
        background-repeat: no-repeat;
    }

.form {
    position: relative;
    margin-top: calc(80*var(--vw-base));
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.form-title {
    position: relative;
    width: 100%;
    height: calc(61*var(--vw-base));
    display: flex;
    align-items: center;
    color: rgb(62, 58, 57, 0.5);
    font-family: "Futura Std Medium";
    font-size: calc(31*var(--vw-base));
    letter-spacing: 0.075em;
    background-color: #fff;
    box-sizing: border-box;
    padding-left: calc(30*var(--vw-base));
}

.input {
    position: relative;
    width: calc(608*var(--vw-base));
    height: calc(51*var(--vw-base));
    margin-top: calc(16*var(--vw-base));
    display: flex;
    align-items: center;
    border-bottom: rgb(62, 58, 57, 0.5) solid 1px;
}

    .input.input-name {
        position: relative;
        border: none;
    }

.name-line {
    position: absolute;
    bottom: 0;
    left: 0;
    width: calc(450*var(--vw-base));
    height: 1px;
    background-color: rgb(62, 58, 57, 0.5);
}

title {
    position: relative;
    width: calc(97*var(--vw-base));
}

.label {
    color: #313131;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.05em;
    height: 100%;
    display: flex;
    align-items: center;
    width: calc(100*var(--vw-base));
}


input[type="text"],
input[type="email"],
input[type="password"] {
    border: none;
    outline: none;
    width: calc(428*var(--vw-base));
    height: 100%;
    background-color: transparent;
    color: #000;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.05em;
}

.check-item-sex {
    position: absolute;
    top: calc(15*var(--vw-base));
    right: calc(0*var(--vw-base));
    display: flex;
    gap: calc(15*var(--vw-base));
    font-size: calc(18 * var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
}

    .check-item-sex label {
        cursor: pointer;
        width: calc(80* var(--vw-base));
        text-align: end;
    }

        .check-item-sex label input[type="radio"] {
            position: relative;
            top: calc(3.2 * var(--vw-base));
            width: 1.2vw;
            height: 1.2vw;
            -webkit-appearance: none;
            -moz-appearance: none;
            appearance: none;
            background-image: url(../img/07/check.png);
            background-size: calc(17 * var(--vw-base)) calc(17 * var(--vw-base));
            background-repeat: no-repeat;
            background-position: center center;
            cursor: pointer;
        }

        .check-item-sex label input:checked {
            background-image: url(../img/07/check-click.png);
            background-size: calc(17 * var(--vw-base)) calc(17 * var(--vw-base));
        }

.input.select {
    position: relative;
    justify-content: space-between;
}

.custom-select {
    width: calc(510*var(--vw-base));
    /* padding: 10px; */
    cursor: pointer;
    background-color: transparent;
    position: relative;
}

    .custom-select::after {
        content: "▼";
        position: absolute;
        right: calc(6*var(--vw-base));
        top: 50%;
        transform: translateY(-50%);
        pointer-events: none;
        font-size: calc(14*var(--vw-base));
        color: #000;
    }

    .custom-select.show::after {
        content: "▼";
        position: absolute;
        right: calc(6*var(--vw-base));
        top: 50%;
        transform: translateY(-50%);
        pointer-events: none;
        font-size: calc(14*var(--vw-base));
        color: #ca3923;
    }



.selected {
    color: #000;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.05em;
    height: 100%;
    display: flex;
    align-items: center;
}

    .selected.placeholder {
        color: rgb(62, 58, 57, 0.5);
    }


.options {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: #fff;
    border: 1px solid #ccc;
    z-index: 10;
    color: #000;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.05em;
}

    .options li {
        /* padding: 10px; */
        cursor: pointer;
        background-color: #fff;
    }

        .options li:hover {
            background-color: #ca3923;
            color: #fff;
        }

.verify {
    position: absolute;
    right: calc(0*var(--vw-base));
    bottom: calc(10*var(--vw-base));
    width: calc(69*var(--vw-base));
    height: calc(28*var(--vw-base));
    background-color: #313131;
    text-align: center;
    box-sizing: border-box;
    padding-top: calc(4*var(--vw-base));
    color: #ffffff;
    font-size: calc(18* var(--vw-base));
    font-family: "Futura Std Light";
    letter-spacing: 0.15em;
}

.input.textarea {
    flex-direction: column;
    align-items: start;
    height: calc(150*var(--vw-base));
}

textarea {
    position: relative;
    margin-top: calc(10*var(--vw-base));
    border: none;
    outline: none;
    width: 100%;
    height: 100%;
    background-color: transparent;
    color: #313131;
    font-size: calc(18*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    letter-spacing: 0.05em;
    resize: none;
    width: 100%;
}

.check-item {
    position: relative;
    width: calc(608*var(--vw-base));
    margin-top: calc(33*var(--vw-base));
    display: flex;
    gap: calc(15*var(--vw-base));
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    color: #313131;
    font-size: calc(18*var(--vw-base));
    letter-spacing: 0.05em;
}

.check-label {
    white-space: nowrap;
    cursor: pointer;
}

.check-item label input {
    position: relative;
    top: calc(4 * var(--vw-base));
    width: calc(20 * var(--vw-base));
    height: calc(20 * var(--vw-base));
    margin: 0% 5% -2.5% 0;
    border: none;
    cursor: pointer;
    background-image: url(../img/07/check-Y.png);
    background-size: calc(19 * var(--vw-base)) calc(16 * var(--vw-base));
    background-position: top left;
    background-repeat: no-repeat;
}

    .check-item label input:checked {
        background-image: url(../img/07/check-Y-click.png);
        background-size: calc(19 * var(--vw-base)) calc(16 * var(--vw-base));
        background-position: top left;
        background-repeat: no-repeat;
    }

.openTxtBtn {
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
    color: #313131;
    cursor: pointer;
    border-bottom: #313131 solid 1px;
}

.form-btns {
    position: relative;
    margin-top: calc(33*var(--vw-base));
    width: calc(608*var(--vw-base));
    display: flex;
    justify-content: start;
    gap: calc(15*var(--vw-base));
}

.form-btn {
    border: none;
    background-color: transparent;
    position: relative;
    width: calc(183*var(--vw-base));
    height: calc(39*var(--vw-base));
    background-image: url(../img/07/btn.png);
    background-position: center center;
    background-size: contain;
    background-repeat: no-repeat;
    cursor: pointer;
    transition: all 0.4s ease-in-out;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #020202;
    font-size: calc(18*var(--vw-base));
    letter-spacing: 0.1em;
    font-family: "Noto Sans TC", serif;
    font-weight: 200;
}

    .form-btn:hover {
        background-image: url(../img/07/btn-hover.png);
        color: #ffffff;
    }








































/*同意書照片預覽*/

.black {
    display: none;
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0px;
    top: 0px;
    background-color: rgba(0, 0, 0, 0.9);
    z-index: 11111;
    font-family: "Noto Sans TC";
}

.closeBtn {
    width: 30px;
    position: absolute;
    right: 5%;
    top: 4%;
    cursor: pointer;
}

.infoWrap {
    width: 100%;
    margin: 0 auto;
    max-width: 65%;
    position: relative;
    height: 100vh;
    overflow: auto;
}

    .infoWrap ul {
        list-style: none;
        font-size: 1vw;
        padding-inline-start: 2vw;
    }

        .infoWrap ul > li > ul {
            list-style: none;
            font-size: 1vw;
            padding-inline-start: 1vw;
        }

.li1::before {
    content: "一、";
    position: absolute;
    left: 0vw;
}

.li2::before {
    content: "二、";
    position: absolute;
    left: 0vw;
}

.li3::before {
    content: "三、";
    position: absolute;
    left: 0vw;
}

.li4::before {
    content: "四、";
    position: absolute;
    left: 0vw;
}

.li5::before {
    content: "五、";
    position: absolute;
    left: 0vw;
}

.li1-li::before {
    content: "（１）";
    position: absolute;
    left: 0vw;
}

.li2-li::before {
    content: "（２）";
    position: absolute;
    left: 0vw;
}

.li3-li::before {
    content: "（３）";
    position: absolute;
    left: 0vw;
}

.li4-li::before {
    content: "（４）";
    position: absolute;
    left: 0vw;
}

.infoBox {
    width: 100%;
    height: calc(100% - 20vw);
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    overflow-y: auto;
    color: #fff;
    text-align: left;
}

    .infoBox h3 {
        font-size: 1.2vw;
        line-height: 180%;
        margin-bottom: 25px;
        text-align: center;
    }

    .infoBox h4 {
        font-size: 1vw;
        line-height: 180%;
        margin-bottom: 1vw;
    }

    .infoBox h5 {
        font-size: 1.2vw;
        line-height: 180%;
        margin-bottom: 1vw;
    }

    .infoBox p {
        font-size: 1vw;
        line-height: 180%;
    }
