/* Top page bundled styles */
/* Generated from individual section styles */
/* ===== header.css ===== */
/* Site Header */
.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; backdrop-filter: blur(10px); background: rgba(255, 255, 255, 0.64); border-bottom: 1px solid #ff6216; }
.site-header__inner { width: 100%; padding-left: min(166px,8.64vw); margin: 0 auto; display: flex; align-items: center; justify-content: flex-end; position: relative; }
.site-header__logo { position: absolute; left: 0; top: 0; }
.site-header__logo > a { display: block; position: relative; color: inherit; text-decoration: none; }
.site-header__logo-vector { object-fit: contain; }
.site-header__logo-mark { position: absolute; left: 16px; top: 16px; width: 64px; height: 64px; object-fit: contain; transition: .15s ease; }
.site-header__logo-link:hover .site-header__logo-mark { opacity: .7;}
.site-header__nav { flex: 1 1 auto; font-weight: 500; }
.site-header__menu-btn { display: none; }
.site-header__nav ul { display: flex; align-items: stretch; justify-content: flex-end; gap: 0; margin: 0; padding: 0; }
.site-header__nav li { list-style: none; display: flex; align-items: stretch; }
.site-header__nav-beginner--pc, .site-header__nav-language__pc { border-left: 1px solid #ff6216; }
.site-header__nav a { display: flex; align-items: center; justify-content: center; padding: 30px min(20px,1.04vw); color: inherit; font-size: clamp(14px,16px,0.83vw); line-height: 1.25; transition: color 0.15s ease, background-color 0.15s ease; }
.site-header__nav a:hover { color: #ff6216; }
.site-header__nav-beginner--pc > a { background: transparent; color: inherit; }
.site-header__nav-beginner--pc > a:hover { background: #ff6216; color: #fff; }
.site-header__nav a span { display: none; }
.site-header__nav-cta { display: none; }
.site-header__nav-footer { display: none; }
@media (max-width: 768px) {
.site-header { backdrop-filter: none; background: transparent; border-bottom: 0; }
.site-header__inner { justify-content: space-between; padding-left: 0; min-height: 74px; }
.site-header__logo { position: relative; }
.site-header__logo-vector { width: 74px; height: 74px; }
.site-header__logo-mark { width: 33px; height: 33px; left: 6px; top: 6px; }
.site-header__menu-btn { margin-right: 20px; height: 74px; padding: 0; border: 0; background: transparent; color: #ff6216; display: inline-flex; flex-direction: column; align-items: flex-end; justify-content: center; gap: 6px; cursor: pointer; z-index: 2; }
.site-header__menu-btn-line { width: 30px; height: 5px; border: 1px solid #ff6216; background: #fff; transition: transform 0.22s ease, opacity 0.22s ease; }
.site-header__menu-btn-text { font-family: "Jost", sans-serif; font-size: 12px; line-height: 1; }
.site-header__nav { position: fixed; top: 0; right: 0; width: 80%; height: 100vh; background: #464646; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.25s ease, visibility 0.25s ease; overflow-y: auto; padding: 100px 0 0; }
.site-header__nav-inner__sp { width: 100%; padding-bottom: 40px; }
.site-header__nav ul { display: block; padding: 0 0 24px; width: 86%; margin: 0 auto; }
.site-header__nav li { border-bottom: 1px solid rgba(255, 255, 255, 0.3); }
.site-header__nav li:not(:last-child) { margin-bottom: 20px; }
.site-header__nav-beginner--pc, .site-header__nav-language__pc { display: none !important; border-left: 0; }
.site-header__nav a { width: 100%; justify-content: space-between; color: #fff; padding: 0 0 20px; line-height: 1.2; }
.site-header__nav a span { display: block; font-family: "Jost", sans-serif; font-size: 10px; line-height: 1; color: #ff6216; padding-right: 18px; position: relative; letter-spacing: 0.1em; }
.site-header__nav a span::after { content: ""; position: absolute; right: 4px; top: 50%; transform: translateY(-50%) rotate(45deg); width: 8px; height: 8px; border-top: 1px solid #ff6216; border-right: 1px solid #ff6216; display: block; }
.site-header--menu-open .site-header__nav-cta { display: grid; grid-template-columns: 1fr 1fr; width: 86%; margin: 0 auto; }
.site-header--menu-open .site-header__nav-cta a { height: 100px; border: 1px solid rgba(255, 255, 255, 0.3); line-height: 1.4; padding: 0; justify-content: center; }
.site-header--menu-open .site-header__nav-footer { display: block; background: #fff; padding: 20px 7% 0; width: 100%; }
.site-header--menu-open .site-header__nav-footer a { color: #464646;}
.site-header--menu-open .site-header__nav { opacity: 1; visibility: visible; pointer-events: auto; }
.site-header--menu-open .site-header__menu-btn-line:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.site-header--menu-open .site-header__menu-btn-line:nth-child(2) { opacity: 0; }
.site-header--menu-open .site-header__menu-btn-line:nth-child(3) { transform: translateY(-13px) rotate(-45deg); }
}
.site-header__lang-btn { display: flex; align-items: center; justify-content: center; padding: 30px min(20px, 1.04vw); margin: 0; color: inherit; font-size: clamp(14px, 16px, 0.83vw); line-height: 1.25; font-weight: 500; background: none; border: 0; cursor: pointer; text-align: center; transition: color 0.15s ease; }
.site-header__lang-btn:hover { color: #ff6216; }
@media (max-width: 768px) {
.site-header--menu-open .site-header__lang-btn--cta { display: flex; width: 100%; height: 100px; border: 1px solid rgba(255, 255, 255, 0.3); padding: 0; color: #fff; line-height: 1.4; justify-content: center; align-items: center; }
}

/* ===== footer.css ===== */
/* Footer */
.site-footer { background: #fff; width: 100%; }
.site-footer__wrapper { width: min(80%, 1400px); margin: 0 auto; padding: min(90px, 6.25vw) 0; }
.site-footer__top { display: flex; align-items: center; justify-content: space-between; gap: 16px; border-bottom: 1px solid #464646; padding-bottom: 20px; }
.site-footer__top-inner { display: flex; align-items: center; justify-content: flex-start; gap: 16px; }
.site-footer__brand { width: 45px; height: 45px; flex: 0 0 auto; }
.site-footer__brand-img { width: 100%; height: 100%; object-fit: cover; }
.site-footer__brand-text { font-weight: 700; text-align: left; }
.site-footer__social { display: flex; gap: 9px; align-items: center; }
.site-footer__social-box { width: 45px; height: 45px; border: 1px solid #000; display: grid; place-items: center; font-weight: 500; background: #fff; }
.site-footer__columns { padding: 30px 0 30px; border-bottom: 1px solid #000; }
.site-footer__col:not(:last-of-type) { margin-bottom: 30px; }
.site-footer__heading { font-family: "Jost", system-ui, sans-serif; color: #ff6216; letter-spacing: 1.92px; margin-bottom: 10px; }
.site-footer__list { display: flex; flex-wrap: wrap; gap: 16px; }
.site-footer__link { font-size: 14px; line-height: 1.4; transition: .15s ease; }
.site-footer__link:hover { color: #ff6216;}
.site-footer__offers { width: 100%; display: flex; justify-content: flex-end; gap: min(16px, 2vw); padding-top: 30px; }
.site-footer__offer { width: min(200px, 30%); height: 100px; background: #464646; color: #fff; display: grid; place-items: center; font-weight: 500; }
.site-footer__copyright { display: flex; justify-content: center; padding-top: 60px; }
.site-footer__copyright p { font-weight: 500; font-size: 12px; color: #ff6216; }
@media (max-width: 768px) {
.site-footer__top { display: block; text-align: center; }
.site-footer__top > *:not(:last-child) { margin-bottom: 12px; }
.site-footer__brand-text { white-space: normal; font-size: 14px; }
.site-footer__list { max-width: 100%; }
.site-footer__offers { justify-content: center; flex-wrap: wrap; }
}

