*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}html,body{width:100%;overflow-x:hidden;font-family:Arial,sans-serif;color:#111;background:#fff}body{margin:0}#root{width:100%}a,button{color:inherit}button{border:none;background:none;cursor:pointer;font:inherit}img{display:block;width:100%}.header{width:100%;position:fixed;top:0;left:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:18px 40px;background:#000000b8;color:#fff}.header__logo{font-size:36px;font-weight:700;color:#fff}.header__nav{display:flex;gap:28px}.header__nav-button{color:#fff;font-size:21px;font-weight:600}.header__phone{font-size:22px;font-weight:700;color:#fff}.hero{width:100%;min-height:100vh;background-size:cover;background-position:center;background-repeat:no-repeat;position:relative}.hero__overlay{min-height:100vh;background:#00000073;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#fff;padding:120px 20px 80px;position:relative}.hero__subtitle{font-size:clamp(18px,2vw,26px);margin-bottom:18px;font-weight:600}.hero__title{font-size:clamp(42px,6vw,80px);line-height:1.15;font-weight:800;margin-bottom:18px}.hero__description{max-width:760px;font-size:clamp(16px,2vw,22px);line-height:1.6;margin-bottom:28px}.hero__button{background:#caa66a;color:#fff;padding:16px 34px;border-radius:6px;font-size:18px;font-weight:700}.scroll-indicator{position:absolute;bottom:50px;font-size:84px;color:#fff;opacity:.9;text-shadow:0 4px 20px rgba(0,0,0,.55);animation:scrollBounce 1.8s infinite}@keyframes scrollBounce{0%{transform:translateY(0)}50%{transform:translateY(12px)}to{transform:translateY(0)}}.content-section{width:100%;max-width:1240px;margin:0 auto;padding:90px 20px}.content-section__header{text-align:center;margin-bottom:40px}.content-section__title{font-size:clamp(30px,4vw,46px);margin-bottom:14px}.content-section__description{font-size:18px;color:#555;line-height:1.6}.content-card-list{display:flex;flex-direction:column;gap:36px}.content-card{border:1px solid #e5e5e5;background:#fff;overflow:hidden}.content-card--single{max-width:1100px;margin:0 auto}.content-card__image-wrap{width:100%;background:#fff}.content-card__image{display:block;width:100%;height:auto;object-fit:contain}.content-card__body{padding:28px}.content-card__title{font-size:30px;margin-bottom:14px}.content-card__text{font-size:17px;line-height:1.7;color:#444}.reservation-section{background:#f7f7f7;padding:90px 20px}.reservation-section__inner{max-width:820px;margin:0 auto}.reservation-section__small-text{text-align:center;font-size:16px;color:#666;margin-bottom:10px}.reservation-section__title{text-align:center;font-size:clamp(30px,4vw,44px);margin-bottom:12px}.reservation-section__subtitle{text-align:center;font-size:17px;color:#444;margin-bottom:20px;line-height:1.6}.reservation-modal{position:fixed;inset:0;z-index:999;background:#0000008c;display:flex;align-items:center;justify-content:center;padding:20px}.reservation-modal__content{width:100%;max-width:520px;background:#fff;border-radius:14px;padding:30px 24px;box-shadow:0 18px 50px #00000038}.reservation-modal__small-text{font-size:14px;font-weight:700;color:#666;margin-bottom:10px}.reservation-modal__title{font-size:28px;line-height:1.4;margin-bottom:20px;color:#111}.reservation-modal__info{padding:18px;background:#f7f7f7;border:1px solid #e5e5e5;margin-bottom:18px}.reservation-modal__info p{font-size:16px;line-height:1.7;color:#222}.reservation-modal__description{font-size:15px;line-height:1.7;color:#555;margin-bottom:22px}.reservation-modal__button{width:100%;padding:16px;background:#111;color:#fff;font-size:17px;font-weight:700;border-radius:8px}.reservation-section__contact-time{text-align:center;font-size:16px;font-weight:700;color:#111;margin-bottom:28px}.reservation-form{display:flex;flex-direction:column;gap:16px}.reservation-form input,.reservation-form select,.reservation-form textarea{width:100%;padding:15px;font-size:16px;border:1px solid #cfcfcf;background:#fff;color:#111}.reservation-form input,.reservation-form select{height:56px}.reservation-form input[type=date]{appearance:auto;-webkit-appearance:auto;color:#111;-webkit-text-fill-color:#111;background:#fff;min-width:0}.reservation-form input[type=date]::-webkit-datetime-edit{color:#111}.reservation-form input[type=date]::-webkit-datetime-edit-fields-wrapper{color:#111}.reservation-form input[type=date]::-webkit-calendar-picker-indicator{opacity:1;cursor:pointer}.reservation-form textarea{resize:vertical;min-height:140px}.reservation-form__field-wrap{position:relative;width:100%;cursor:pointer}.reservation-form__date-input{position:relative;z-index:2;width:100%;height:56px;padding:15px;font-size:16px;border:1px solid #cfcfcf;background:#fff;color:#111;-webkit-text-fill-color:#111}.reservation-form__date-fake-placeholder{display:none;position:absolute;top:50%;left:15px;transform:translateY(-50%);color:#666;font-size:16px;line-height:1;pointer-events:none;z-index:3}.reservation-form__agree{display:flex;align-items:center;gap:10px;font-size:15px;color:#444}.reservation-form__agree input{width:auto;height:auto}.reservation-form button{padding:18px;background:#111;color:#fff;font-size:18px;font-weight:700}.reservation-section__notice{margin-top:18px;text-align:center;font-size:14px;color:#666;line-height:1.6}.footer{background:#111;color:#fff;text-align:center;padding:24px 20px;font-size:15px}.call-button{position:fixed;right:18px;bottom:18px;z-index:200;background:#caa66a;color:#fff;padding:16px 22px;border-radius:999px;font-weight:700;font-size:15px;box-shadow:0 8px 24px #00000038}@media(max-width:768px){.header{padding:14px 16px;flex-direction:column;gap:10px}.header__logo{font-size:30px}.header__nav{gap:18px;flex-wrap:wrap;justify-content:center}.header__nav-button,.header__phone{font-size:18px}.hero__overlay{padding:130px 16px 80px}.hero__title{font-size:clamp(30px,9vw,46px)}.hero__description{font-size:15px}.hero__button{width:100%;max-width:220px;font-size:16px}.scroll-indicator{font-size:48px;bottom:36px}.content-section{padding:70px 16px}.content-card__image{height:auto}.content-card__body{padding:20px}.content-card__title{font-size:24px}.content-card__text{font-size:15px}.reservation-section{padding:70px 16px}.reservation-section__subtitle{font-size:15px}.reservation-section__contact-time{font-size:15px;line-height:1.5}.reservation-form input,.reservation-form select,.reservation-form textarea{font-size:16px}.reservation-section__notice{font-size:13px}.reservation-modal__content{padding:24px 18px}.reservation-modal__title{font-size:22px}.reservation-modal__info p{font-size:15px}.reservation-modal__description{font-size:14px}.reservation-modal__button{font-size:16px;padding:14px}.reservation-form__date-fake-placeholder{display:block}}
