@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;900&family=Noto+Sans+JP:wght@300;400;500&family=Shippori+Mincho:wght@500;600;700;800&display=swap"); #header, #index_header_content, #footer, #return_top, 
#drawer_menu, #mobile_menu, #menu_button, .cb_content, #bread_crumb
{
display: none !important;
} :root {
--navy: #0B2347;
--gold: #B68D40;
--white: #FFFFFF;
--gray-bg: #F4F5F7;
--text-body: #333333;
--footer-bg: #111111;
--footer-text: #999999;
--footer-heading: #FFFFFF;
--font-serif: 'Shippori Mincho', serif;
--font-sans: 'Montserrat', sans-serif;
--font-jp: 'Noto Sans JP', sans-serif;
} .factkey-custom-wrapper {
position: relative; width: 100%; z-index: 10;
color: var(--text-body); font-family: var(--font-jp); line-height: 1.8;
}
.factkey-custom-wrapper * { box-sizing: border-box; }
.factkey-custom-wrapper a { text-decoration: none; color: inherit; transition: opacity 0.3s; }
.factkey-custom-wrapper img { max-width: 100%; height: auto; display: block; box-shadow: none; border: none; }
.factkey-custom-wrapper .container { max-width: 1100px; margin: 0 auto; padding: 0 40px; position: relative; z-index: 2; } .factkey-custom-wrapper .js-fade-in-up { opacity: 0; transform: translateY(30px); transition: opacity 0.8s ease, transform 0.8s ease; }
.factkey-custom-wrapper .js-fade-in-up.is-visible { opacity: 1; transform: translateY(0); } .factkey-custom-wrapper header { position: fixed; top: 0; left: 0; width: 100%; height: 100px; z-index: 1000; } #custom-content-wrapper .hero { position: relative; height: 100vh; width: 100%; display: flex; align-items: center; justify-content: center; background-size: cover; background-position: center bottom; background-attachment: fixed; overflow: hidden; }
#custom-content-wrapper .hero::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(11, 35, 71, 0.4); z-index: 1; }
#custom-content-wrapper .hero::after { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: linear-gradient(180deg, rgba(11,35,71,0.2) 0%, rgba(11,35,71,0.6) 100%); z-index: 1; }
#custom-content-wrapper .hero-content { position: relative; z-index: 2; width: 100%; max-width: 1000px; text-align: center; color: #fff; padding: 0 20px; margin-top: 40px; }
#custom-content-wrapper .hero-copy-en { font-family: var(--font-sans); font-size: 16px; letter-spacing: 0.3em; color: rgba(255, 255, 255, 0.9); margin-bottom: 30px; display: block; text-transform: uppercase; font-weight: 500; animation: fadeInUp 1s ease forwards 0.5s; opacity: 0; }
#custom-content-wrapper .hero-copy-jp { font-family: var(--font-serif); font-size: clamp(36px, 5vw, 72px); font-weight: 700; line-height: 1.3; letter-spacing: 0.05em; margin-bottom: 40px; color: #fff; animation: fadeInUp 1s ease forwards 0.8s; opacity: 0; }
#custom-content-wrapper .hero-sub { font-family: var(--font-serif); font-size: 20px; font-weight: 500; line-height: 2; opacity: 0; animation: fadeInUp 1s ease forwards 1.1s; display: inline-block; border-top: 1px solid rgba(255,255,255,0.6); padding-top: 30px; margin-top: 10px; }
@keyframes fadeInUp { to { opacity: 1; transform: translateY(0); } } #custom-content-wrapper section { padding: 160px 0; position: relative; }
#custom-content-wrapper .bg-deco-text { position: absolute; font-family: var(--font-sans); font-weight: 900; font-size: 18vw; color: var(--navy); opacity: 0.03; line-height: 1; z-index: 0; white-space: nowrap; pointer-events: none; }
#custom-content-wrapper .sec-heading-group { margin-bottom: 60px; }
#custom-content-wrapper .sec-title-large-en { font-family: var(--font-sans); font-size: clamp(40px, 5vw, 80px); color: rgba(11, 35, 71, 0.08); font-weight: 700; line-height: 0.8; letter-spacing: -0.02em; margin-bottom: -20px; position: relative; z-index: 0; display: block; }
#custom-content-wrapper .sec-title-large-jp { font-family: var(--font-serif); font-size: clamp(28px, 3.5vw, 48px); color: var(--navy); font-weight: 700; line-height: 1.4; letter-spacing: 0.1em; position: relative; z-index: 1; padding-left: 5px; }
#custom-content-wrapper .sec-lead-text { font-size: 18px; font-weight: 500; line-height: 2.2; color: var(--text-body); margin-top: 40px; max-width: 800px; margin-left: auto; margin-right: auto; } #custom-content-wrapper .philosophy { overflow: hidden; }
#custom-content-wrapper .philosophy .bg-deco-text { top: 10%; left: -5%; }
#custom-content-wrapper .philosophy-inner { display: flex; gap: 80px; align-items: center; position: relative; z-index: 2; }
#custom-content-wrapper .ph-text { flex: 1; }
#custom-content-wrapper .ph-img { flex: 1; position: relative; }
#custom-content-wrapper .ph-img img { width: 100%; height: 500px; object-fit: cover; box-shadow: 20px 20px 0 var(--gray-bg); position: relative; z-index: 2; }
#custom-content-wrapper .ph-img::before { content: ''; position: absolute; top: -30px; left: -30px; width: 100%; height: 100%; border: 1px solid var(--gold); z-index: 1; }
#custom-content-wrapper .business { background-color: var(--gray-bg); overflow: hidden; }
#custom-content-wrapper .business .bg-deco-text { bottom: 5%; right: -5%; color: #fff; opacity: 0.5; }
#custom-content-wrapper .business-list { display: flex; flex-direction: column; gap: 120px; margin-top: 100px; position: relative; z-index: 2; }
#custom-content-wrapper .biz-row { display: flex; align-items: center; background: #fff; box-shadow: 0 30px 60px rgba(0,0,0,0.05); position: relative; }
#custom-content-wrapper .biz-row:nth-child(even) { flex-direction: row-reverse; }
#custom-content-wrapper .biz-img-box { width: 55%; height: 550px; overflow: hidden; position: relative; }
#custom-content-wrapper .biz-img-box img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s; }
#custom-content-wrapper .biz-row:hover .biz-img-box img { transform: scale(1.05); }
#custom-content-wrapper .biz-info-box { width: 45%; padding: 60px 50px; position: relative; }
#custom-content-wrapper .biz-num { font-family: var(--font-sans); font-size: 80px; font-weight: 700; color: #f0f0f0; position: absolute; top: 20px; right: 30px; }
#custom-content-wrapper .biz-title-en { font-family: var(--font-sans); font-size: 14px; letter-spacing: 0.2em; color: var(--gold); display: block; margin-bottom: 15px; font-weight: 600; }
#custom-content-wrapper .biz-title-jp { font-family: var(--font-serif); font-size: 32px; color: var(--navy); margin-bottom: 30px; font-weight: 700; position: relative; z-index: 1; }
#custom-content-wrapper .faq { background-color: #fff; padding: 140px 0; }
#custom-content-wrapper .faq-list { margin-top: 60px; border-top: 1px solid #eee; }
#custom-content-wrapper .faq-item { border-bottom: 1px solid #eee; padding: 40px 0; display: flex; flex-direction: column; gap: 20px; }
#custom-content-wrapper .faq-question { font-family: var(--font-serif); font-size: 20px; font-weight: 700; color: var(--navy); display: flex; align-items: flex-start; gap: 15px; }
#custom-content-wrapper .faq-question .q-mark { color: var(--gold); font-family: var(--font-sans); font-size: 20px; font-weight: 700; flex-shrink: 0; margin-top: 2px; }
#custom-content-wrapper .faq-answer { padding-left: 36px; font-size: 16px; color: var(--text-body); line-height: 1.9; }
#custom-content-wrapper .section-split { display: flex; }
#custom-content-wrapper .col-split { width: 50%; padding: 120px 8%; position: relative; }
#custom-content-wrapper .col-company { background-color: #fff; }
#custom-content-wrapper .col-contact { background-color: var(--navy); color: #fff; }
#custom-content-wrapper .col-company::after { content: 'COMPANY'; position: absolute; bottom: 20px; right: 20px; font-family: var(--font-sans); font-weight: 900; font-size: 80px; color: var(--navy); opacity: 0.05; pointer-events: none; }
#custom-content-wrapper .col-contact .sec-title-large-en { color: rgba(255,255,255,0.1); }
#custom-content-wrapper .col-contact .sec-title-large-jp { color: #fff; }
#custom-content-wrapper .col-contact .sec-lead-text { color: rgba(255,255,255,0.8); border-color: rgba(255,255,255,0.2); }
#custom-content-wrapper .contact-tel { font-family: var(--font-sans); font-size: 42px; font-weight: 300; letter-spacing: 0.05em; display: block; margin: 30px 0 10px; }
#custom-content-wrapper .btn-line { display: inline-flex; align-items: center; font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--navy); gap: 15px; position: relative; z-index: 1; }
#custom-content-wrapper .btn-line::after { content: ''; width: 40px; height: 1px; background: var(--navy); }
#custom-content-wrapper .btn-gold { background: var(--gold); color: #fff; padding: 18px 50px; font-family: var(--font-sans); font-weight: 600; letter-spacing: 0.1em; display: inline-block; margin-top: 30px; } #custom-sub-page-wrapper { width: 100%; position: relative; z-index: 1; } #custom-sub-page-wrapper .page-header {
position: relative; width: 100%; height: 400px; margin-top: 100px; 
background-color: var(--navy); display: flex; align-items: center; justify-content: center; overflow: hidden;
}
#custom-sub-page-wrapper .page-header::before {
content: attr(data-title-en); 
position: absolute; font-family: var(--font-sans); font-weight: 900; font-size: 15vw;
color: rgba(255,255,255,0.03); white-space: nowrap;
top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 0;
}
#custom-sub-page-wrapper .page-header-inner { text-align: center; position: relative; z-index: 2; color: #fff; }
#custom-sub-page-wrapper .page-title-en {
font-family: var(--font-sans); font-size: 16px; letter-spacing: 0.2em; color: var(--gold);
display: block; margin-bottom: 15px; font-weight: 600;
}
#custom-sub-page-wrapper .page-title-jp {
font-family: var(--font-serif); font-size: 40px; font-weight: 700; letter-spacing: 0.1em; margin: 0;
} #custom-sub-page-wrapper .breadcrumbs { background-color: var(--gray-bg); padding: 15px 0; font-size: 12px; color: #666; }
#custom-sub-page-wrapper .breadcrumbs a { text-decoration: underline; opacity: 0.8; }
#custom-sub-page-wrapper .breadcrumbs span { margin: 0 10px; opacity: 0.5; } #custom-sub-page-wrapper .page-content { padding: 100px 0 140px; background-color: #fff; }
#custom-sub-page-wrapper .container-narrow { max-width: 800px; margin: 0 auto; padding: 0 20px; } #custom-sub-page-wrapper .content-body h2 {
font-family: var(--font-serif); font-size: 28px; color: var(--navy);
margin-top: 60px; margin-bottom: 30px; padding-bottom: 15px;
border-bottom: 1px solid #ddd; position: relative;
}
#custom-sub-page-wrapper .content-body h2::after {
content: ''; position: absolute; bottom: -1px; left: 0; width: 60px; height: 3px; background-color: var(--gold);
}
#custom-sub-page-wrapper .content-body h2:first-child { margin-top: 0; }
#custom-sub-page-wrapper .content-body p { margin-bottom: 30px; font-size: 16px; line-height: 2; text-align: justify; } #custom-sub-page-wrapper .content-image { position: relative; width: 50%; margin: 60px auto; z-index: 1; }
#custom-sub-page-wrapper .content-image::before {
content: ''; position: absolute; top: -20px; left: -20px; width: 100%; height: 100%;
border: 1px solid var(--gold); z-index: -1;
}
#custom-sub-page-wrapper .content-image img { width: 100%; height: auto; display: block; box-shadow: 20px 20px 0 var(--gray-bg); } #custom-sub-page-wrapper .profile-box { background-color: var(--gray-bg); padding: 50px; margin-top: 60px; border-radius: 4px; }
#custom-sub-page-wrapper .profile-header { display: flex; align-items: baseline; gap: 20px; margin-bottom: 20px; border-bottom: 1px solid rgba(0,0,0,0.1); padding-bottom: 20px; }
#custom-sub-page-wrapper .profile-title { font-family: var(--font-serif); font-size: 20px; font-weight: 700; color: var(--navy); }
#custom-sub-page-wrapper .profile-name { font-size: 24px; font-weight: 700; }
#custom-sub-page-wrapper .profile-name span { font-size: 14px; font-weight: 400; margin-left: 10px; font-family: var(--font-sans); color: #666; }
#custom-sub-page-wrapper .profile-body p { font-size: 15px; margin-bottom: 15px; } #custom-sub-page-wrapper .company-table { width: 100%; border-collapse: collapse; margin-top: 40px; border-top: 1px solid #ddd; }
#custom-sub-page-wrapper .company-table th,
#custom-sub-page-wrapper .company-table td { padding: 20px; border-bottom: 1px solid #ddd; text-align: left; vertical-align: top; }
#custom-sub-page-wrapper .company-table th { width: 25%; background-color: #f9f9f9; font-weight: 600; color: var(--navy); font-family: var(--font-serif); }
#custom-sub-page-wrapper .company-table td { width: 75%; } #custom-sub-page-wrapper .intro-text { text-align: center; margin-bottom: 100px; }
#custom-sub-page-wrapper .intro-lead { font-family: var(--font-serif); font-size: 28px; color: var(--navy); font-weight: 700; margin-bottom: 40px; line-height: 1.6; }
#custom-sub-page-wrapper .intro-desc { font-size: 16px; line-height: 2; max-width: 800px; margin: 0 auto; text-align: justify; }
#custom-sub-page-wrapper .synergy-section { background-color: var(--gray-bg); padding: 80px 60px; border-radius: 4px; margin-bottom: 120px; }
#custom-sub-page-wrapper .synergy-title { text-align: center; font-family: var(--font-serif); font-size: 24px; color: var(--navy); margin-bottom: 60px; line-height: 1.5; font-weight: 700; }
#custom-sub-page-wrapper .synergy-grid { display: flex; gap: 40px; justify-content: space-between; }
#custom-sub-page-wrapper .synergy-item { background: #fff; padding: 40px 30px; flex: 1; border-radius: 4px; position: relative; box-shadow: 0 5px 15px rgba(0,0,0,0.05); }
#custom-sub-page-wrapper .synergy-item:not(:last-child)::after { content: '▶'; position: absolute; right: -28px; top: 50%; transform: translateY(-50%); color: var(--gold); font-size: 14px; }
#custom-sub-page-wrapper .synergy-head { display: flex; flex-direction: column; margin-bottom: 20px; border-bottom: 1px solid #eee; padding-bottom: 20px; }
#custom-sub-page-wrapper .synergy-en { font-family: var(--font-sans); font-size: 14px; color: var(--gold); font-weight: 700; letter-spacing: 0.05em; }
#custom-sub-page-wrapper .synergy-jp { font-family: var(--font-sans); font-size: 18px; color: var(--navy); font-weight: 700; margin-top: 5px; }
#custom-sub-page-wrapper .synergy-desc { font-size: 14px; line-height: 1.8; }
#custom-sub-page-wrapper .service-index-list { display: flex; flex-direction: column; gap: 60px; margin-bottom: 60px; }
#custom-sub-page-wrapper .service-card { display: flex; align-items: center; background-color: #fff; border: 1px solid #eee; border-radius: 4px; overflow: hidden; transition: all 0.3s ease; box-shadow: 0 5px 15px rgba(0,0,0,0.03); }
#custom-sub-page-wrapper .service-card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0,0,0,0.08); }
#custom-sub-page-wrapper .service-card-img { width: 50%; height: 350px; overflow: hidden; }
#custom-sub-page-wrapper .service-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
#custom-sub-page-wrapper .service-card:hover .service-card-img img { transform: scale(1.05); }
#custom-sub-page-wrapper .service-card-info { width: 50%; padding: 40px 50px; }
#custom-sub-page-wrapper .card-num { font-family: var(--font-sans); color: #f0f0f0; font-size: 60px; font-weight: 700; line-height: 1; margin-bottom: -10px; display: block; }
#custom-sub-page-wrapper .card-sub-catch { display: block; font-size: 14px; font-weight: 600; color: var(--gold); margin-bottom: 10px; letter-spacing: 0.1em; }
#custom-sub-page-wrapper .card-title-jp { font-family: var(--font-serif); font-size: 24px; font-weight: 700; color: var(--navy); margin-bottom: 20px; }
#custom-sub-page-wrapper .card-desc { font-size: 15px; margin-bottom: 30px; color: #666; }
#custom-sub-page-wrapper .btn-arrow { font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--navy); display: inline-flex; align-items: center; gap: 10px; }
#custom-sub-page-wrapper .btn-arrow::after { content: '→'; font-size: 18px; transition: transform 0.3s; }
#custom-sub-page-wrapper .service-card:hover .btn-arrow::after { transform: translateX(5px); } #custom-sub-page-wrapper .detail-lead-area { text-align: center; max-width: 800px; margin: 0 auto 100px; }
#custom-sub-page-wrapper .detail-catch { font-family: var(--font-serif); font-size: 32px; font-weight: 700; color: var(--navy); margin-bottom: 40px; line-height: 1.5; border-bottom: none; }
#custom-sub-page-wrapper .detail-desc { text-align: justify; font-size: 16px; }
#custom-sub-page-wrapper .detail-section-row { display: flex; align-items: center; gap: 60px; margin-bottom: 120px; }
#custom-sub-page-wrapper .detail-section-row:nth-child(even) { flex-direction: row-reverse; }
#custom-sub-page-wrapper .detail-img-col { width: 50%; position: relative; }
#custom-sub-page-wrapper .detail-img-col img { width: 100%; border-radius: 4px; box-shadow: 20px 20px 0 var(--gray-bg); }
#custom-sub-page-wrapper .detail-text-col { width: 50%; }
#custom-sub-page-wrapper .detail-num { font-family: var(--font-sans); font-size: 50px; font-weight: 700; color: #eee; line-height: 1; margin-bottom: 10px; }
#custom-sub-page-wrapper .detail-h3 { font-family: var(--font-serif); font-size: 24px; color: var(--navy); font-weight: 700; margin-bottom: 20px; border-bottom: 2px solid var(--gold); padding-bottom: 10px; display: inline-block; }
#custom-sub-page-wrapper .detail-sub-h3 { display: block; font-size: 16px; font-weight: 600; margin-bottom: 20px; color: #555; }
#custom-sub-page-wrapper .detail-p { font-size: 15px; margin-bottom: 20px; text-align: justify; }
#custom-sub-page-wrapper .detail-list { list-style: none; padding: 0; margin: 0; }
#custom-sub-page-wrapper .detail-list li { position: relative; padding-left: 20px; font-size: 14px; margin-bottom: 5px; font-weight: 500; color: var(--navy); }
#custom-sub-page-wrapper .detail-list li::before { content: '✔'; position: absolute; left: 0; color: var(--gold); }
#custom-sub-page-wrapper .other-services { background-color: var(--gray-bg); padding: 80px 0; margin-top: 60px; }
#custom-sub-page-wrapper .other-services-title { text-align: center; font-family: var(--font-sans); font-size: 20px; color: var(--navy); font-weight: 700; margin-bottom: 40px; letter-spacing: 0.1em; }
#custom-sub-page-wrapper .other-services-list { display: flex; gap: 30px; justify-content: center; }
#custom-sub-page-wrapper .other-service-btn { background: #fff; padding: 20px 40px; border-radius: 4px; font-family: var(--font-serif); font-weight: 600; color: var(--navy); box-shadow: 0 5px 10px rgba(0,0,0,0.05); transition: all 0.3s; }
#custom-sub-page-wrapper .other-service-btn:hover { background: var(--navy); color: #fff; transform: translateY(-3px); } @media (max-width: 900px) {
#custom-sub-page-wrapper .page-header { height: 250px; margin-top: 70px; }
#custom-sub-page-wrapper .page-title-jp { font-size: 28px; }
#custom-sub-page-wrapper .page-content { padding: 60px 0 100px; }
#custom-sub-page-wrapper .content-image { width: 80%; margin: 40px auto; }
#custom-sub-page-wrapper .content-image::before { top: -15px; left: -15px; }
#custom-sub-page-wrapper .profile-box { padding: 30px; }
#custom-sub-page-wrapper .profile-header { flex-direction: column; gap: 5px; } #custom-sub-page-wrapper .company-table th,
#custom-sub-page-wrapper .company-table td { display: block; width: 100%; }
#custom-sub-page-wrapper .company-table th { background-color: #f4f4f4; padding-bottom: 10px; }
#custom-sub-page-wrapper .company-table td { padding-top: 10px; padding-bottom: 30px; } #custom-sub-page-wrapper .intro-lead { font-size: 22px; text-align: left; }
#custom-sub-page-wrapper .synergy-grid { flex-direction: column; gap: 30px; }
#custom-sub-page-wrapper .synergy-item:not(:last-child)::after { content: '▼'; right: auto; left: 50%; top: auto; bottom: -24px; transform: translateX(-50%); }
#custom-sub-page-wrapper .synergy-section { padding: 40px 20px; }
#custom-sub-page-wrapper .service-card { flex-direction: column; }
#custom-sub-page-wrapper .service-card-img { width: 100%; height: 220px; }
#custom-sub-page-wrapper .service-card-info { width: 100%; padding: 30px; } #custom-sub-page-wrapper .detail-catch { font-size: 24px; text-align: left; }
#custom-sub-page-wrapper .detail-section-row { flex-direction: column !important; gap: 40px; margin-bottom: 80px; }
#custom-sub-page-wrapper .detail-img-col, #custom-sub-page-wrapper .detail-text-col { width: 100%; }
#custom-sub-page-wrapper .other-services-list { flex-direction: column; align-items: stretch; }
#custom-sub-page-wrapper .other-service-btn { text-align: center; }
} #custom-footer-wrapper { position: relative; width: 100%; z-index: 10; color: #999999; font-family: var(--font-jp); background-color: #111111; }
#custom-footer-wrapper footer { padding: 100px 0 40px; }
#custom-footer-wrapper .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1.3fr; gap: 60px; margin-bottom: 80px; }
#custom-footer-wrapper .footer-logo { max-width: 240px; width: 100%; height: auto; margin-bottom: 30px; opacity: 0.9; }
#custom-footer-wrapper .footer-address { font-size: 14px; line-height: 2; margin-bottom: 30px; }
#custom-footer-wrapper .footer-tel { font-family: var(--font-sans); font-size: 24px; color: #FFFFFF; font-weight: 300; display: block; margin-bottom: 5px; }
#custom-footer-wrapper .footer-hours { font-size: 13px; opacity: 0.7; }
#custom-footer-wrapper .footer-nav-col h3 { font-family: var(--font-sans); font-size: 14px; font-weight: 600; color: var(--gold); margin-bottom: 25px; letter-spacing: 0.1em; text-transform: uppercase; }
#custom-footer-wrapper .footer-nav-list { list-style: none; padding: 0; margin: 0; }
#custom-footer-wrapper .footer-nav-list li { margin-bottom: 15px; list-style: none; }
#custom-footer-wrapper .footer-nav-list a { font-family: var(--font-serif); font-size: 15px; color: var(--footer-text); transition: color 0.3s; position: relative; display: inline-block; }
#custom-footer-wrapper .footer-nav-list a::before { content: ''; position: absolute; bottom: -2px; left: 0; width: 0; height: 1px; background-color: var(--gold); transition: width 0.3s; }
#custom-footer-wrapper .footer-nav-list a:hover { color: var(--footer-heading); }
#custom-footer-wrapper .footer-nav-list a:hover::before { width: 100%; }
#custom-footer-wrapper .footer-nav-list .sub-menu { display: none !important; }
#custom-footer-wrapper .footer-contact-box { display: flex; flex-direction: column; justify-content: space-between; background-color: var(--white); padding: 35px 30px; height: auto; min-height: 220px; text-decoration: none; position: relative; transition: all 0.3s ease; border-radius: 12px; box-shadow: 0 10px 30px rgba(0,0,0,0.3); color: #333; }
#custom-footer-wrapper .footer-contact-box:hover { transform: translateY(-5px); box-shadow: 0 15px 40px rgba(0,0,0,0.4); }
#custom-footer-wrapper .footer-contact-box .contact-lead { font-size: 13px; color: #666; margin-bottom: 20px; line-height: 1.6; font-weight: 500; }
#custom-footer-wrapper .footer-contact-box .contact-en { font-family: var(--font-sans); font-size: 14px; font-weight: 600; letter-spacing: 0.1em; color: var(--gold); display: block; margin-bottom: 5px; }
#custom-footer-wrapper .footer-contact-box .contact-jp { font-family: var(--font-serif); font-size: 24px; font-weight: 700; color: var(--navy); line-height: 1.4; margin: 0; }
#custom-footer-wrapper .footer-contact-box .contact-arrow { align-self: flex-end; font-family: var(--font-sans); font-size: 28px; color: var(--navy); transition: transform 0.3s; line-height: 1; margin-top: 20px; }
#custom-footer-wrapper .footer-contact-box:hover .contact-arrow { transform: translateX(10px); }
#custom-footer-wrapper .footer-bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 40px; border-top: 1px solid rgba(255,255,255,0.1); font-size: 12px; font-family: var(--font-sans); }
#custom-footer-wrapper .footer-bottom-links { display: flex; gap: 20px; }
#custom-footer-wrapper .footer-bottom-links a { color: var(--footer-text); }
#custom-footer-wrapper .footer-bottom-links a:hover { color: var(--footer-heading); }
#custom-footer-wrapper .copyright { opacity: 0.6; }
@media (max-width: 900px) {
#custom-footer-wrapper .footer-grid { grid-template-columns: 1fr; gap: 50px; }
#custom-footer-wrapper .footer-bottom { flex-direction: column-reverse; gap: 20px; text-align: center; }
#custom-footer-wrapper .footer-contact-box { min-height: 160px; }
}