/* reset by patrimovel */
* { margin: 0px; padding: 0px; border: 0px; font-weight: normal; font-size: 100%; list-style: none; line-height: 1; outline: 0px; background: none; -moz-box-sizing: border-box; -webkit-box-sizing: border-box; box-sizing: border-box; text-rendering: optimizeLegibility; -webkit-font-smoothing: antialiased; -moz-font-smoothing: antialiased; -ms-font-smoothing: antialiased; -o-font-smoothing: antialiased; font-smoothing: antialiased; }

/* var */
:root { --black: #2A2A2A; --blackhover: #666; --red: #F12303; --redhover: #B11800; }

/* global class */
.container { display: block; width: auto; max-width: 1200px; height: auto; margin: 0px auto; }

/* base */
a { text-decoration: none; transition: all .5s ease; }
body { background: #EDEDED; color: var(--black); font: normal 14px 'Cabin', sans-serif; overflow-x: hidden; }
input, textarea, select, button { font: normal 14px 'Cabin', sans-serif; appearance: none; -webkit-appearance: none; border-radius: 0px; cursor: pointer; }
input[type=submit], button { transition: all .5s ease; }

/* feat */
#feat { position: relative; width: calc(100% - 60px); height: calc(100vh - 60px); margin: 30px; background-color: #000; border-radius: 20px; overflow: hidden; visibility: hidden; }
#feat figure.logo img { position: absolute; z-index: 2; top: 50px; left: 50%; width: 120px; height: auto; transform: translateX(-50%); }
#feat figure.bg img { position: absolute; top: 0px; left: 0px; width: 100%; height: 100%; object-fit: cover; opacity: .5; }
#feat section { position: absolute; z-index: 2; bottom: 70px; left: 50%; width: 780px; margin-left: -390px; text-align: center; }
#feat section h1 { display: block; font-weight: 700; font-size: 80px; color: #fff; }
#feat section p { display: block; margin-top: 10px; font-weight: 700; font-size: 22px; color: #fff; line-height: 1.4; }
#feat section .bts { display: flex; gap: 20px; margin-top: 40px; justify-content: center; align-items: center; }
#feat section .bts span a { display: block; min-width: 240px; padding: 20px 30px; font-weight: 700; color: #fff; border: 1px solid #fff; border-radius: 10px; }
#feat section .bts span:first-of-type a:hover { background-color: #fff; color: var(--black); }
#feat section .bts span:last-of-type a { background-color: var(--red); border-color: var(--red); }
#feat section .bts span:last-of-type a:hover { background-color: var(--redhover); }

/* txt1 */
#txt1 { margin: 100px 0px; overflow: hidden; }
#txt1 .container { display: flex; align-items: center; }
#txt1 section { width: 50%; padding-right: 50px; }
#txt1 section h2 { display: block; font-weight: 700; font-size: 50px; }
#txt1 section p { display: block; margin-top: 30px; line-height: 1.8; }
#txt1 aside { position: relative; width: 50%; height: 430px; }
#txt1 aside::after { position: absolute; top: 0px; left: 50%; width: 800px; height: 100%; margin-left: 330px; background-color: #D9D9D9; border-radius: 40px; content: ''; }
#txt1 aside figure { width: 100%; height: 100%; border-radius: 40px; overflow: hidden; background-color: #000; }
#txt1 aside figure img { width: 100%; height: 100%; object-fit: cover; }

/* txt2 */
#txt2 { margin-bottom: 100px; }
#txt2 .container { display: flex; align-items: center; }
#txt2 sup img { position: absolute; bottom: 250px; left: 50%; width: 600px; margin-left: 250px; }
#txt2 aside { position: relative; width: 360px; height: 460px; background-color: #000; border-radius: 40px; overflow: hidden; }
#txt2 aside img { width: 100%; height: 460px; object-fit: cover; opacity: .5; }
#txt2 aside span { position: absolute; top: 50%; left: 50%; width: auto; transform: translate(-50%, -50%); color: #fff; font-weight: 700; cursor: pointer; }
#txt2 aside span i { display: block; margin-bottom: 10px; font-size: 30px; text-align: center; }
#txt2 section { width: calc(100% - 360px); height: auto; padding: 0px 120px 0px 50px; }
#txt2 section h2 { display: block; width: 70%; font-weight: 700; font-size: 50px; }
#txt2 section p { display: block; margin-top: 30px; line-height: 1.8; }

/* cta */
span#cta { display: block; width: 100%; text-align: center; }
span#cta a { display: inline-block; width: auto; padding: 10px 100px; background-color: var(--red); color: #fff; text-align: center; font-weight: 700; border-radius: 10px; line-height: 1.4; }
span#cta a:hover { background-color: var(--redhover); }

/* bar */
#bar { margin: 100px 0px; }
#bar section { display: flex; justify-content: space-between; background-color: #fff; box-shadow: 0px 60px 60px rgba(0,0,0,.2); border-radius: 20px; overflow: hidden; }
#bar section .item { display: flex; width: 100%; height: 130px; align-items: center; justify-content: center; flex-direction: column; gap: 10px; white-space: nowrap; }
#bar section .item.price { padding: 0px 40px; background-color: var(--black); color: #fff; }
#bar section img { width: auto; height: 40px; }
#bar section strong,
#bar section small { display: block; font-weight: 700; font-size: 16px; }
#bar section .item.price strong { font-size: 30px; }

/* grid */
#grid { position: relative; margin-bottom: 100px; background: transparent url('../img/logo-p.svg') no-repeat center center; background-size: contain; }
#grid::before { position: absolute; top: 0px; left: 0px; width: 50px; height: 100%; background-color: #D9D9D9; border-top-right-radius: 40px; border-bottom-right-radius: 40px; content: ''; }
#grid::after { position: absolute; top: 0px; right: 0px; width: 50px; height: 100%; background-color: #D9D9D9; border-top-left-radius: 40px; border-bottom-left-radius: 40px; content: ''; }
#grid section { display: grid; padding: 0px 60px; grid-template-columns: repeat(2, 1fr); grid-gap: 40px; }
#grid section article { position: relative; padding-left: 120px; }
#grid section article h3 { width: 80%; font-weight: 700; font-size: 24px; line-height: 1.2; }
#grid section article p { display: block; margin-top: 20px; line-height: 1.8; }
#grid section article img { position: absolute; top: 0px; left: 10px; width: 60px; height: auto; }

/* form */
#form { display: block; width: 100%; margin: 100px 0px; }
#form .container { display: flex; align-items: flex-start; gap: 30px; }
#form aside { position: relative; width: calc(100% - 340px); height: 550px; border-radius: 100px; background-color: #000; overflow: hidden; }
#form aside figure { position: relative; width: 100%; height: 550px; }
#form aside figure img { width: 100%; height: 100%; object-fit: cover; opacity: .7; }
#form aside figure h4 { position: absolute; z-index: 2; top: 50%; left: 80px; width: 80%; font-weight: 900; font-size: 80px; color: #fff; line-height: 0.9; transform: translateY(-50%); }
#form section { width: 340px; height: 550px; padding: 100px 30px 0px 30px; border-radius: 100px; background-color: #fff; box-shadow: 0px 60px 60px rgba(0,0,0,.2); }
#form section legend { display: block; font-weight: 900; font-size: 24px; line-height: 1.1; }
#form section label { display: block; margin-top: 20px; }
#form section label input { width: 100%; height: 40px; border-bottom: 1px solid var(--black); color: var(--black); }
#form section label input::placeholder { color: var(--black); }
#form section label input:focus,
#form section label input:active { border-color: var(--red); }
#form section label input.wpcf7-not-valid, #form section label input.wpcf7-not-valid { border-color: var(--red); }
#form section label input[type=submit] { height: 88px; margin-top: 20px; padding: 20px 0px 5px 35px; background: var(--black) url('../img/form-submit-arrow.svg') no-repeat 92% 25%; color: #fff; border-radius: 100px; font-weight: 900; font-size: 24px; text-align: left; }
#form section label input[type=submit]:hover { background-color: var(--blackhover); }
#form [data-status=sent] fieldset { opacity: 0; }
#form [data-status=sent]::before { position: absolute; z-index: 10; top: 40%; left: 50%; width: 150px; height: 150px; background-color: #25D366; border-radius: 100%; transform: translate(-50%, -50%); font-family: 'Font Awesome 5 Pro'; font-size: 60px; text-align: center; line-height: 150px; color: #fff; content: '\f00c'; }
#form .wpcf7-spinner { position: absolute; top: 20px; left: 50%; transform: translateX(-50%); }

    /* wpcf7 */
    .wpcf7 form { position: relative; }
    .wpcf7 form.invalid .wpcf7-response-output { color: #F12303 !important; }
    .wpcf7 form.sent .wpcf7-response-output { color: #25D366 !important; }
    .wpcf7-not-valid-tip,
    .wpcf7 br { display: none !important; }
    .wpcf7 .wpcf7-response-output { margin: 0px !important; padding: 10px 0px 0px 0px !important; border: none !important; text-align: center; font-weight: bold; font-size: 14px; line-height: 1.2; }

/* gal */
#gal { margin: 100px 0px; }
#gal h6 { display: block; font-weight: 700; font-size: 50px; text-align: center; }
#gal figure { width: 100%; height: 240px; margin: 0% 10px; background-color: #ccc; border-radius: 20px; overflow: hidden; }
#gal figure img { width: 100%; height: 100%; object-fit: cover; opacity: .3; transition: all .4s ease; }
#gal .slick-active { background-color: #000; }
#gal .slick-active img { opacity: 1; }
#gal section { margin-top: 40px; padding: 0px 20px; }
#gal .slick-list { overflow: visible; }
#gal .arrow { position: absolute; z-index: 20; top: 50%; transform: translateY(-50%); font-size: 30px; color: var(--black); }
#gal .arrow.arrow-prev { left: -15px; }
#gal .arrow.arrow-next { right: -15px; }

/* price */
#price { margin: 100px 0px; }
#price h6 { display: block; font-weight: 700; font-size: 50px; text-align: center; }
#price .table { display: block; width: 100%; height: auto; margin-top: 40px; border-radius: 20px; overflow: hidden; background-color: #fff; box-shadow: 0px 60px 60px rgba(0,0,0,.2); border: 1px solid #ccc; }
#price .table .tr { display: grid; grid-template-columns: repeat(6, 1fr); }
#price .table .tr.head { background-color: var(--black); color: #fff; }
#price .table .tr span,
#price .table .tr strong { padding: 15px; border-right: 1px solid #ccc; font-size: 15px; }
#price .table .tr.head span { border-right-color: var(--black); }
#price .table .tr span:first-of-type { font-weight: bold; font-size: 14px; text-transform: uppercase; }
#price .table .tr strong { font-weight: bold; }
#price .table .tr a { color: var(--red); text-decoration: underline; }
#price .table .tr b { display: none; }

/* map */
#map { margin: 100px 0px; }
#map h6 { display: block; font-weight: 700; font-size: 50px; text-align: center; }
#map address { display: block; margin-top: 20px; text-align: center; font-weight: 700; font-size: 24px; font-style: normal; }
#map iframe { width: 100%; height: 400px; margin-top: 40px; border-radius: 40px; }

/* faq */
#faq { margin: 100px 0px; }
#faq h6 { display: block; margin-bottom: 40px; font-weight: 700; font-size: 50px; text-align: center; }
#faq section { width: 800px; margin: 0px auto; }
#faq details { position: relative; margin-bottom: 10px; padding: 15px 20px; background-color: #f9f9f9; border: 1px solid #ddd; border-radius: 20px; }
#faq details > div { height: auto; overflow: hidden; transition: height 0.4s ease; }
#faq details[open] > div { height: auto; }
#faq summary { position: relative; font-weight: bold; padding-right: 30px; font-size: 18px; cursor: pointer; }
#faq summary::after { content: '\f0dd'; font-family: 'Font Awesome 5 Pro'; font-weight: 900; position: absolute; right: 0; top: 0; font-size: 16px; transition: transform 0.3s ease; }
#faq details[open] summary::after { transform: rotate(180deg); }
#faq details p { display: block; margin-top: 16px; line-height: 1.6; }

/* footer */
#footer { margin-bottom: 100px; }
#footer .container { display: flex; justify-content: center; align-items: center; gap: 40px; }
#footer img { height: 30px; }

/* chat */
#chat { position: fixed; z-index: 100; bottom: 20px; left: -300px; width: 300px; height: auto; opacity: 0; transition: all .5s ease; }
#chat a { display: flex; padding: 22px 20px; align-items: center; background-color: rgba(255,255,255,.7); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); box-shadow: 0px 30px 30px rgba(0,0,0,.3); color: var(--black); border-radius: 40px; }
#chat p { width: calc(100% - 40px); padding-right: 10px; font-weight: bold; font-size: 16px; line-height: 1.2; }
#chat i { width: 50px; height: 50px; background-color: #25D366; color: #fff; font-size: 24px; border-radius: 100%; line-height: 50px; text-align: center; transition: all .5s ease; }
#chat.on { left: 20px; opacity: 1; }
#chat a:hover { background-color: #25D366; color: #fff }
#chat a:hover i { background-color: #fff; color: #25D366; }

/* box */
#box { display: none; position: fixed; z-index: 9999; top: 0px; left: 0px; width: 100%; height: 100%; background-color: rgba(0,0,0,.7); } 
#box-int { position: absolute; top: 50%; left: 50%; width: 360px; height: auto; padding: 40px; background-color: #fff; box-shadow: 0px 40px 40px rgba(0,0,0,.5); border-radius: 40px; transform: translate(-50%, -50%); }
#box-int legend { display: block; font-weight: 900; font-size: 24px; line-height: 1.1; }
#box-int label { display: block; margin-top: 20px; }
#box-int label input { width: 100%; height: 40px; border-bottom: 1px solid var(--black); color: var(--black); }
#box-int label input::placeholder { color: var(--black); }
#box-int label input.wpcf7-not-valid, #cta section label input.wpcf7-not-valid { border-color: var(--red); }
#box-int label input[type=submit] { height: 88px; margin-top: 20px; padding: 20px 0px 5px 35px; background: var(--black) url('../img/form-submit-arrow.svg') no-repeat 92% 25%; color: #fff; border-radius: 100px; font-weight: 900; font-size: 24px; text-align: left; }
#box-int label input[type=submit]:hover { background-color: #000; }
#box-int sup { position: absolute; top: 15px; right: 15px; font-size: 20px; cursor: pointer; }