/*
Theme Name: WIN Corporate Theme
Theme URI: https://example.invalid/
Author: WIN
Description: Corporate + Recruit combined theme (two nav sets, news & interview CPTs)
Version: 0.1.0
Text Domain: win
*/

/* Basic reset for safety; real styles will be implemented later */
:root { --primary: #00B4E3; --ls-tight: .01em; --ls-wide: .02em; }
html { overflow-x: hidden; width: 100%; }
body { margin: 0; font-family: 'Noto Sans JP', sans-serif; overflow-x: hidden; width: 100%; max-width: 100%; }
main { padding-top: 0; }
body.home main { padding-top: 0; }
body.recruit main { padding-top: 0; }
.header, h1, h2, h3, h4 { font-weight: 700; letter-spacing: var(--ls-wide); }
p { letter-spacing: var(--ls-tight); }
.hero-sub { font-weight: 700; font-size: 26px; }
.container { margin-left: 140px; margin-right: 140px; margin-top: 0; margin-bottom: 0; padding: 0; overflow-x: visible; }
.header { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: transparent; border-bottom: none; border-bottom-left-radius: 16px; border-bottom-right-radius: 16px; padding-top: 0; height: 64px; }
.header .container { max-width: none; padding: 0; margin-left: 50px; margin-right: 50px; height: 100%; display: flex; align-items: center; background: transparent; }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 20px; width: 100%; overflow: visible; }
.footer { padding: 80px 0 0; border-top: none; background: #fff; box-sizing: border-box; max-width: 100%; overflow-x: hidden; }
.company-recruit-block + .footer { border-top: none; }
.footer-nav { padding: 0 24px 0; box-sizing: border-box; }
.footer-nav-inner { max-width: 1200px; margin: 0 auto; width: 100%; box-sizing: border-box; }
.footer-nav-columns { display: flex; flex-direction: row; flex-wrap: wrap; gap: 40px; justify-content: center; width: 100%; box-sizing: border-box; }
.footer-nav-col { display: flex; flex-direction: column; gap: 0; flex: 1 1 auto; min-width: 0; text-align: left; }
.footer-nav-column { margin-bottom: 16px; min-width: 0; }
.footer-nav-column.footer-nav-gap-after { margin-bottom: 16px; }
.footer-nav-title { font-size: 16px; font-weight: 600; margin: 0 0 12px; color: #222; letter-spacing: var(--ls-wide); line-height: 1.4; white-space: normal; word-break: break-word; }
.footer-nav-title:not(:first-child) { margin-top: 28px; }
.footer-nav-title a { color: inherit; text-decoration: none; transition: opacity 0.5s; }
.footer-nav-title a:hover { opacity: 0.7; }
.footer-nav-list { list-style: none; padding: 0; margin: 0 0 4px; }
.footer-nav-list:last-child { margin-bottom: 0; }
.footer-nav-list li { margin-bottom: 6px; }
.footer-nav-list li:last-child { margin-bottom: 0; }
.footer-nav-list.footer-nav-gap-after { margin-bottom: 0.75em !important; }
.footer-nav-list a { color: #aaa; text-decoration: none; font-size: 14px; letter-spacing: var(--ls-tight); line-height: 1.4; transition: opacity 0.3s; }
.footer-nav-item-title a { font-size: 16px; font-weight: 600; color: #777; letter-spacing: var(--ls-wide); }
.footer-logo { padding: 80px 24px; text-align: center; }
.footer-logo .logo { display: inline-block; text-decoration: none; }
.footer-logo img.footer-logo-img { width: 150px !important; min-width: 150px !important; height: auto !important; max-width: 150px !important; display: block; object-fit: contain; }

.footer-nav-list a:hover,
.footer-nav-item-title a:hover,
.footer-logo .logo:hover {
  opacity: 0.6;
}
.footer-copyright { max-width: 1200px; margin: 0 auto; padding: 0 24px 40px; text-align: center; width: 100%; box-sizing: border-box; }
.footer-copyright small { color: #555; font-size: 12px; letter-spacing: var(--ls-tight); }
@media (max-width: 1024px) {
  .footer-nav { padding: 0 30px 0; }
  .footer-nav-inner { max-width: 100%; overflow: hidden; }
  .footer-nav-columns { gap: 24px; padding: 0; width: 100%; box-sizing: border-box; }
  .footer-nav-title { font-size: 16px; margin-bottom: 8px; }
  .footer-nav-title:not(:first-child) { margin-top: 20px; }
  .footer-nav-list a { font-size: 15px; line-height: 1.35; }
  .footer-nav-item-title a { font-size: 16px; font-weight: 600; color: #777; }
  .footer-nav-list li { margin-bottom: 4px; }
  .footer { display: flex; flex-direction: column; }
  .footer-inner { display: flex; flex-direction: column; }
  .footer-nav { order: 1; }
  .footer-logo { order: 2; padding: 80px 24px; }
  .footer-copyright { order: 3; }
  .footer-logo img.footer-logo-img { width: 150px !important; min-width: 150px !important; height: auto !important; max-width: 150px !important; }
  .footer-copyright { padding: 0 16px 40px; }
}
.menu-toggle { display: none; background: none; border: none; cursor: pointer; padding: 0; z-index: 1001; position: relative; width: 44px; height: 44px; align-items: center; justify-content: center; flex-direction: column; overflow: visible; min-width: 44px; }
.menu-toggle-line { display: block; width: 20px; height: 2px; background: #222; margin: 3px 0; transition: all 0.3s ease; border-radius: 1px; flex-shrink: 0; position: absolute; left: 50%; transform: translateX(-50%); }
.menu-toggle-line:nth-child(1) { top: 12px; height: 2px; }
.menu-toggle-line:nth-child(2) { bottom: 12px; height: 2px; top: auto; margin-top: 0; }
.menu-toggle[aria-expanded="true"] .menu-toggle-line:nth-child(1) { transform: translateX(-50%) rotate(45deg); top: 50%; margin-top: -1px; height: 2px; }
.menu-toggle[aria-expanded="true"] .menu-toggle-line:nth-child(2) { transform: translateX(-50%) rotate(-45deg); top: 50%; margin-top: -1px; height: 2px; opacity: 1; }
.nav { display: flex; gap: 16px; flex-wrap: wrap; box-shadow: 0 2px 8px rgba(0,0,0,.08); border-radius: 8px; background: #fff; height: 50px; min-height: 50px; align-items: center; }
.nav .menu { display: flex; gap: 0; margin: 0; padding: 0; align-items: stretch; }
.nav .menu > li { list-style: none; }
.nav a { display: flex; align-items: center; justify-content: center; white-space: nowrap; text-align: center; color: #222; text-decoration: none; padding: 0 16px; height: 50px; min-height: 50px; border-radius: 0; background: #fff; border: none; font-weight: 700; letter-spacing: var(--ls-wide); box-shadow: none; }
.nav a:hover { box-shadow: 0 4px 10px rgba(0,0,0,.12); }
.nav .menu > li:first-child a { border-top-left-radius: 8px; border-bottom-left-radius: 8px; }
.nav .menu > li:last-child a { border-top-right-radius: 8px; border-bottom-right-radius: 8px; }
.nav a:hover { background: rgba(0, 180, 227, 0.3); }
#menu-item-136 > a {
  display: flex !important;
  align-items: center;
  justify-content: center;
  position: relative;
  width: auto !important;
  height: 100% !important;
  min-height: 50px !important;
  padding: 0 24px !important;
  margin: 0;
  line-height: 1;
  box-sizing: border-box;
  border-radius: 0 !important;
  background: #fff;
}
#menu-item-136 {
  display: flex;
  align-self: stretch;
  height: 100%;
}
#menu-item-136 > a::after {
  content: '';
  position: absolute;
  top: 16px;
  bottom: 16px;
  left: 12px;
  right: 12px;
  border: 1px solid #555;
  pointer-events: none;
  box-sizing: border-box;
}
#menu-item-136 > a:hover {
  background: rgba(0, 180, 227, 0.5) !important;
}
.nav .nav__cta { background: #FCEE21; color: #111; font-weight: 700; box-shadow: none; }
.nav .nav__cta:hover { background: #00B4E3; color: #fff; filter: none; }

/* 企業サイトヘッダー PC: 画面幅に応じて縮小（拡大なし） */
@media (min-width: 1025px) and (max-width: 1200px) {
    .header { height: 56px; }
    .header .container { margin-left: 24px; margin-right: 24px; }
    .header-inner { gap: 12px; }
    .header .logo img { height: 44px; width: auto; }
    .header .nav { height: 44px !important; min-height: 44px !important; gap: 12px; border-radius: 6px; }
    .header .nav a { padding: 0 12px !important; height: 44px !important; min-height: 44px !important; font-size: 14px; }
    .header .nav .menu > li:first-child a { border-top-left-radius: 6px; border-bottom-left-radius: 6px; }
    .header .nav .menu > li:last-child a { border-top-right-radius: 6px; border-bottom-right-radius: 6px; }
}
@media (min-width: 1201px) and (max-width: 1400px) {
    .header { height: 60px; }
    .header .container { margin-left: 36px; margin-right: 36px; }
    .header-inner { gap: 16px; }
    .header .logo img { height: 52px; width: auto; }
    .header .nav { height: 48px !important; min-height: 48px !important; gap: 14px; }
    .header .nav a { padding: 0 14px !important; height: 48px !important; min-height: 48px !important; font-size: 15px; }
}
@media (min-width: 1301px) and (max-width: 1400px) {
    .header-recruit { height: 68px; }
    .header-recruit-logo { margin-left: 20px; }
    .logo-recruit img { height: 26px; }
    .logo-recruit-text { font-size: 16px; }
    .logo-recruit-label { font-size: 13px; }
    /* .nav-recruit { margin-right: 12px; } */
    /* .menu-recruit { gap: 6px; } */
    .menu-recruit a { font-size: 9px; padding: 24px 5px; }
    .header-recruit-entry { flex-shrink: 1; }
    .recruit-entry-button {
        padding: 0 10px;
        min-width: 0;
        width: auto;
        max-width: 96px;
        height: 64px;
    }
    .recruit-entry-button-en { font-size: 18px; }
    .recruit-entry-button-ja { display: inline-block; font-size: 11px; margin-top: 2px; }
}
@media (min-width: 1401px) {
    .header { height: 64px; }
    .header .container { margin-left: 50px; margin-right: 50px; }
    .header-inner { gap: 20px; }
    .header .logo img { height: 60px; width: auto; }
    .header .nav { height: 50px !important; min-height: 50px !important; gap: 16px; }
    .header .nav a { padding: 0 16px !important; height: 50px !important; min-height: 50px !important; }
}

/* Recruit Header */
.header-recruit { position: fixed; top: 0; left: 0; right: 0; z-index: 1000; background: #fff; border-bottom: none; border-bottom-left-radius: 20px; border-bottom-right-radius: 20px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1); height: 80px; padding: 0; }
.header-recruit .container { max-width: none; padding: 0; margin: 0; height: 100%; display: flex; align-items: center; }
@media (min-width: 1024px) { .header-recruit .container { padding: 0; margin: 0; } }
.header-recruit-inner { display: flex; align-items: center; justify-content: space-between; width: 100%; overflow: visible; }
.header-recruit-logo { flex-shrink: 0; margin-left: 50px; margin-right: 0; }
.logo-recruit { display: flex; align-items: center; gap: 6px; text-decoration: none; transition: opacity 0.2s; }
.logo-recruit:hover { opacity: 0.8; }
.logo-recruit img { height: 32px; width: auto; display: block; }
.logo-recruit-text { font-size: 24px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.logo-recruit-separator { width: 2px; height: 20px; background: #00B4E3; margin-left: 8px; margin-right: 8px; }
.logo-recruit-label { font-size: 16px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.menu-toggle-recruit .menu-toggle-line { background: #222; }
.nav-recruit { flex: 1; display: flex; justify-content: flex-end; }
.menu-recruit { display: flex; gap: 0px; margin: 0; padding: 0; align-items: center; list-style: none; }
.menu-recruit > li { list-style: none; }
.menu-recruit a { display: block; color: #222; text-decoration: none; padding: 28px 28px; font-weight: 700; font-size: 16px; letter-spacing: var(--ls-wide); transition: opacity 0.2s; white-space: nowrap; }
.menu-recruit a:hover { opacity: 1; background: rgba(0, 180, 227, 0.3); }
.header-recruit-entry { flex-shrink: 0; margin-left: 0; height: 80px; display: flex; align-items: center; }
.recruit-entry-button { display: flex; flex-direction: column; align-items: center; justify-content: center; background: #00B4E3; color: #fff; text-decoration: none; padding: 0 32px; height: 80px; border-radius: 0 0 20px 0; transition: background 0.2s, color 0.2s; min-width: 120px; }
.recruit-entry-button:hover { background: rgba(252, 238, 33); color: #222; }
.recruit-entry-button-en { font-size: 30px; font-weight: 700; letter-spacing: var(--ls-wide); line-height: 1; }
.recruit-entry-button-ja { font-size: 14px; font-weight: 700; letter-spacing: var(--ls-wide); margin-top: 4px; line-height: 1; color: #222; }
/* Recruit Header: PC 幅 1025〜1300px の縮小調整（横並びのまま収める） */
@media (min-width: 1025px) and (max-width: 1300px) {
    .header-recruit { height: 64px; }
    /* .header-recruit-inner { gap: 8px; } */
    .header-recruit-logo { margin-left: 16px; }
    .logo-recruit img { height: 24px; }
    .logo-recruit-text { font-size: 18px; }
    .logo-recruit-separator { display: inline-block; }
    .logo-recruit-label { display: inline-block; }

    /* .nav-recruit { margin-right: 8px; } */
    /* .menu-recruit { gap: 8px; } */
    .menu-recruit a { font-size: 11px; padding: 24px 24px; letter-spacing: 0; }

    .header-recruit-entry { height: 64px; }
    .recruit-entry-button {
        padding: 0 16px;
        min-width: 0;
        width: auto;
        height: 64px;
    }
    .recruit-entry-button-en { font-size: 18px; }
    .recruit-entry-button-ja { display: inline-block; font-size: 11px; margin-top: 2px; }
}
.hero { padding: 0; position: relative; z-index: 1; overflow: hidden; }
.hero__slider { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; }
.hero__slider .swiper-wrapper { height: 100%; }
.hero__slider .swiper-slide { height: 100%; }
.hero-slide-inner { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-slide-img { display: block; width: 100%; height: 100%; object-fit: cover; }
.hero-slide-img-sp { display: none; }
/* 企業TOPヒーロースライドのみ 768/769px で画像切替（他は1024/1025px） */
@media (max-width: 768px) {
    .hero .hero-slide-img-pc { display: none; }
    .hero .hero-slide-img-sp { display: block; }
}
.hero__slider .swiper-pagination { z-index: 2; }
.hero__slider .swiper-pagination-bullet { background: #fff; opacity: 0.5; }
.hero__slider .swiper-pagination-bullet-active { opacity: 1; }
.hero-overlay { position: absolute; inset: 0; display: flex; align-items: center; z-index: 1; }
.hero .edge-pad { display: flex; align-items: center; height: 100%; }
.card { border: 1px solid #e5e5e5; padding: 16px; margin-bottom: 16px; }
.link { color: var(--primary); text-decoration: none; }
.link:hover { opacity: .8; }

/* Recruit palette */
.recruit-color { color: var(--primary); }
.logo { display: inline-flex; align-items: center; gap: 8px; text-decoration: none; color: inherit; }
.logo img { height: 60px; width: auto; transition: opacity 0.2s; }
.logo:hover img { opacity: 0.8; }

/* ヘッダーと同じ左右余白を付けるための共通クラス */
.edge-pad { padding-left: 12px; padding-right: 12px; }
@media (min-width: 1024px) { .edge-pad { padding-left: 80px; padding-right: 24px; } }

/* TOP sections */
.section { padding: 56px 0; }
.section h2 { margin: 0 0 16px; font-size: 28px; }
.news-block { position: relative; overflow-x: visible; overflow-y: hidden; margin-left: -140px; margin-right: -140px; padding-left: 140px; padding-right: 140px; padding-top: 120px !important; padding-bottom: 120px !important; display: flex; justify-content: space-between; align-items: flex-start; }
.news-block::before { content: ''; position: absolute; top: 0; bottom: 0; left: calc(50% - 50vw); width: 100vw; background: #e6e6e6; z-index: -1; }
.news-head { margin-bottom: 0; }
.news-block .news-title { font-size: 60px !important; margin: 0; }
.news-block .news-sub { color:#666; font-size: 18px !important; margin-top: 4px; letter-spacing: .08em; }
.news-content { width: 860px; max-width: 100%; margin: 0; margin-left: auto; text-align: right; display: flex; flex-direction: column; }
.news-viewall { display:inline-flex; align-items:center; gap:8px; color:#00B4E3; text-decoration:none; font-weight:700; font-size: 22px; margin: 0; margin-left: auto; }
.news-viewall .news-icon { width: 22px; height: 22px; border:1px solid #00B4E3; border-radius: 50%; display:inline-block; position: relative; }
.news-viewall .news-icon::after { content:''; position:absolute; top:50%; left:50%; width:0; height:0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%,-50%); }
.news-list { list-style: none; padding: 0; margin: 0; margin-top: calc(60px * 1.1 + 4px + 18px * 1.6 - 22px); }
.news-item { display: grid; grid-template-columns: 120px 1fr 24px; align-items:center; gap: 16px; padding: 14px 0; border-top: 1px solid rgba(0,0,0,.1); }
.news-item:last-child { border-bottom: 1px solid rgba(0,0,0,.1); }
.news-item-meta { display: flex; align-items: center; gap: 8px; }
.news-date { color:#666; font-size:14px; text-align: left; }
.news-category { color:#222; font-size:14px; }
.news-link { color:#222; text-decoration:none; text-align: left; }
.news-link:hover { text-decoration: underline; }
.news-arrow { justify-self:end; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; }
.cta-more { display: inline-flex; align-items: center; gap: 6px; color: #666; text-decoration: none; }
/* Pagination */
.news-content .wp-pagenavi,
.news-content .page-numbers { display: flex; justify-content: center; gap: 8px; margin-top: 40px; list-style: none; padding: 0; }
.news-content .page-numbers li { list-style: none; }
.news-content .page-numbers a,
.news-content .page-numbers span { display: inline-block; padding: 8px 12px; color: #222; text-decoration: none; border: 1px solid #ddd; border-radius: 4px; transition: all 0.2s; }
.news-content .page-numbers a:hover { background: #00B4E3; color: #fff; border-color: #00B4E3; }
.news-content .page-numbers .current { background: #00B4E3; color: #fff; border-color: #00B4E3; }
.news-content .page-numbers .prev,
.news-content .page-numbers .next { font-weight: 700; }

/* News Archive Page */
.breadcrumb { padding: 0; margin-top: 100px; margin-bottom: 80px; }
body:not(.recruit):not(.page-template-page-recruit):not(.post-type-archive-interview) .breadcrumb { margin-top: 150px; }
.breadcrumb-list { list-style: none; padding: 0; margin: 0; display: flex; align-items: center; flex-wrap: wrap; font-size: 14px; color: #999; gap: 0; }
.breadcrumb-list li { display: flex; align-items: center; }
.breadcrumb-list li + li::before { content: "|"; margin: 0 8px; color: #999; }
.breadcrumb-list li a { color: #999; text-decoration: none; }
.breadcrumb-list li a:hover { color: #00B4E3; }
.news-archive-wrapper { width: 100%; }
.news-archive-wrapper .news-archive-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.news-archive-wrapper .news-archive-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.news-archive-wrapper .news-archive-sub { font-size: 18px; color: #222; letter-spacing: var(--ls-tight); }
.news-archive-wrapper .news-archive-content { display: flex; gap: 48px; align-items: flex-start; margin-top: 60px; padding-left: 10px; padding-right: 10px; }
.news-archive-wrapper .news-archive-sidebar { flex-shrink: 0; width: 280px; }
.news-archive-wrapper .news-archive-sidebar-title { font-size: 26px; font-weight: 700; margin: 0 0 24px; color: #333; letter-spacing: var(--ls-wide); }
.news-archive-wrapper .news-archive-category-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 20px 20px; }
.news-archive-wrapper .news-archive-category-item { margin-bottom: 0; display: flex; justify-content: center; align-items: center; }
.news-archive-wrapper .news-archive-category-item a { display: flex; align-items: center; gap: 8px; color: #888; text-decoration: none; font-size: 16px; letter-spacing: var(--ls-tight); }
.news-archive-wrapper .news-archive-category-item a::before { content: ''; width: 12px; height: 12px; border: 2px solid #B0B0B0; border-radius: 50%; display: inline-block; flex-shrink: 0; box-sizing: border-box; }
.news-archive-wrapper .news-archive-category-item.active a { color: #333; font-weight: 500; }
.news-archive-wrapper .news-archive-category-item.active a::before { background: #00B4E3; border-color: #00B4E3; }
.news-archive-wrapper .news-archive-category-item a:hover { color: #00B4E3; }
.news-archive-wrapper .news-archive-category-item a:hover::before { border-color: #00B4E3; }
.news-archive-wrapper .news-archive-main { flex: 1; margin-bottom: 150px; }
.news-archive-wrapper .news-archive-list { list-style: none; padding: 0; margin: 0; }
.news-archive-wrapper .news-archive-item { padding: 20px 0; border-bottom: 1px solid rgba(0,0,0,.1); }
.news-archive-wrapper .news-archive-item:last-child { border-bottom: none; }
.news-archive-wrapper .news-archive-item-header { display: flex; align-items: center; gap: 16px; margin-bottom: 8px; }
.news-archive-wrapper .news-archive-date { font-size: 14px; color: #666; }
.news-archive-wrapper .news-archive-category { font-size: 14px; color: #222; }
.news-archive-wrapper .news-archive-link { display: flex; align-items: center; justify-content: space-between; gap: 16px; color: #222; text-decoration: none; }
.news-archive-wrapper .news-archive-link:hover { color: #00B4E3; }
.news-archive-wrapper .news-archive-title-text { flex: 1; font-size: 16px; line-height: 1.6; letter-spacing: var(--ls-tight); }
.news-archive-wrapper .news-archive-arrow { width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; flex-shrink: 0; }
.news-archive-wrapper .news-archive-pagination { margin-top: 48px; text-align: center; }
.news-archive-wrapper .news-archive-pagination .nav-links { display: flex; justify-content: center; align-items: center; gap: 12px; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; }
.news-archive-wrapper .news-archive-pagination .nav-links .page-numbers { display: inline-flex; align-items: center; justify-content: center; color: #999; text-decoration: none; font-size: 16px; font-weight: 500; transition: color 0.2s; background: transparent; border: none; padding: 0; }
.news-archive-wrapper .news-archive-pagination .nav-links .page-numbers:hover { color: #00B4E3; }
.news-archive-wrapper .news-archive-pagination .nav-links .page-numbers.current { color: #00B4E3; font-weight: 500; }
.news-archive-wrapper .news-archive-pagination .nav-links .page-numbers.dots { color: #999; }
.news-archive-wrapper .news-archive-pagination .nav-links a.prev,
.news-archive-wrapper .news-archive-pagination .nav-links a.next { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border: 1px solid #00B4E3; border-radius: 50%; text-decoration: none; color: transparent; background: transparent; }
.news-archive-wrapper .news-archive-pagination .nav-links a.prev:hover,
.news-archive-wrapper .news-archive-pagination .nav-links a.next:hover { background: transparent; }
.news-archive-wrapper .news-archive-pagination .nav-links span.prev,
.news-archive-wrapper .news-archive-pagination .nav-links span.next { display: none; }
.news-archive-wrapper .news-archive-pagination .page-numbers .prev.disabled a,
.news-archive-wrapper .news-archive-pagination .page-numbers .next.disabled a,
.news-archive-wrapper .news-archive-pagination .nav-links .prev.disabled a,
.news-archive-wrapper .news-archive-pagination .nav-links .next.disabled a { border-color: #999; }
.news-archive-wrapper .pagination-prev-icon,
.news-archive-wrapper .pagination-next-icon { width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; display: inline-block; flex-shrink: 0; }
.news-archive-wrapper .pagination-prev-icon { transform: rotate(180deg); border-left-color: #00B4E3; }
.news-archive-wrapper .news-archive-pagination .page-numbers .prev.disabled .pagination-prev-icon,
.news-archive-wrapper .news-archive-pagination .page-numbers .next.disabled .pagination-next-icon,
.news-archive-wrapper .news-archive-pagination .nav-links .prev.disabled .pagination-prev-icon,
.news-archive-wrapper .news-archive-pagination .nav-links .next.disabled .pagination-next-icon { border-left-color: #999; }

/* News Single Page */
.news-single { max-width: 860px; margin: 0 auto; padding: 120px 0 0; }
.news-single-header { margin-bottom: 100px; padding-bottom: 0; border-bottom: none; }
.news-single-meta { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.news-single-date { font-size: 14px; color: #666; }
.news-single-category { font-size: 14px; color: #222; }
.news-single-title { font-size: 24px; font-weight: 700; margin: 0 0 16px; color: #222; letter-spacing: var(--ls-wide); line-height: 1.5; }
.news-single-content { margin-bottom: 48px; }
.news-single-content p { margin: 0 0 24px; line-height: 1.8; letter-spacing: var(--ls-tight); }
.news-single-content img { max-width: 100%; height: auto; margin: 24px 0; }
.news-single-content h2,
.news-single-content h3,
.news-single-content h4 { font-weight: 700; margin: 32px 0 16px; letter-spacing: var(--ls-wide); }
.news-single-content h2 { font-size: 24px; }
.news-single-content h3 { font-size: 20px; }
.news-single-content h4 { font-size: 18px; }
.news-single-content ul,
.news-single-content ol { margin: 24px 0; padding-left: 24px; }
.news-single-content li { margin-bottom: 8px; line-height: 1.8; letter-spacing: var(--ls-tight); }
.news-single-footer { padding: 0; margin-top: 120px; margin-bottom: 150px; text-align: center; }
.news-single-back { display: inline-flex; align-items: center; gap: 8px; color: #00B4E3; text-decoration: none; font-weight: 700; font-size: 16px; }
.news-single-back:hover { text-decoration: underline; }
.news-single-back-icon { width: 22px; height: 22px; border: 1px solid #00B4E3; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.news-single-back-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-right: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Brands Page */
.brands-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.brands-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.brands-page-sub { font-size: 18px; color: #222; letter-spacing: var(--ls-tight); }
.brands-page-intro { max-width: 860px; margin: 120px 0 80px; text-align: left; }
.brands-page-intro-title { font-size: 40px; font-weight: 600; margin: 0 0 56px; color: #222; letter-spacing: var(--ls-wide); line-height: 1.5; }
.brands-page-intro-text { font-size: 16px; line-height: 1.8; color: #222; margin: 0; letter-spacing: var(--ls-tight); }
.brands-page-showcase { padding: 0; margin-bottom: 100px; }
.brands-page-cards { display: flex; gap: 40px; max-width: 1200px; margin: 0 auto; }
.brands-page-card { flex: 1; background: #efefef; border-radius: 8px; overflow: visible; display: flex; flex-direction: column; box-shadow: 0 2px 8px rgba(0,0,0,.08); height: 640px; }
.brands-page-card-image { position: relative; width: 500px; height: 320px; padding: 26px 0; margin: 0 auto; box-sizing: border-box; }
.brands-page-card-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 8px; }
.brands-page-card-content { padding: 0 48px 32px; display: flex; flex-direction: column; flex: 1; text-align: center; }
.brands-page-card-title { font-size: 26px; font-weight: 700; margin: 0 0 16px; color: #222; letter-spacing: var(--ls-wide); }
.brands-page-card-desc { font-size: 16px; line-height: 1.8; color: #222; margin: 0 0 0px; flex: 1; letter-spacing: var(--ls-tight); text-align: left; }
.brands-page-card-link { display: inline-flex; align-items: center; gap: 8px; color: #00B4E3; text-decoration: none; font-weight: 700; font-size: 22px; margin: 0 auto; margin-top: auto; }
.brands-page-card-icon { width: 22px; height: 22px; border: 1px solid #00B4E3; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.brands-page-card-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* ブランドページ PC 画面幅が小さいとき: 中央揃え・画像とカードの余白を維持 */
@media (min-width: 1025px) and (max-width: 1400px) {
    .brands-page-wrapper .brands-page-cards { justify-content: center; gap: 32px; }
    .brands-page-wrapper .brands-page-card { flex: 0 1 400px; min-width: 320px; max-width: 500px; height: auto; min-height: 560px; }
    .brands-page-wrapper .brands-page-card-image { width: 100%; max-width: 500px; height: auto; aspect-ratio: 500 / 320; padding: 20px 16px 0; margin: 0 auto; box-sizing: border-box; }
    .brands-page-wrapper .brands-page-card-image img { width: 100%; height: 100%; object-fit: cover; }
    .brands-page-wrapper .brands-page-card-content { padding: 20px 20px 28px; flex: 1; min-height: 0; }
}
@media (min-width: 1025px) and (max-width: 1200px) {
    .brands-page-wrapper .brands-page-cards { gap: 24px; }
    .brands-page-wrapper .brands-page-card { flex: 0 1 340px; min-width: 300px; max-width: 420px; min-height: 520px; }
    .brands-page-wrapper .brands-page-card-image { padding: 16px 12px 0; }
    .brands-page-wrapper .brands-page-card-content { padding: 16px 16px 24px; }
}

@media (max-width: 1024px) {
  .brands-page-wrapper .brands-page-cards { flex-direction: column; max-width: 800px; }
  .brands-page-wrapper .brands-page-intro { padding: 0 24px; }
  .brands-page-wrapper .brands-page-card { overflow: hidden; }
  .brands-page-wrapper .brands-page-card-image { width: 100%; max-width: 500px; margin: 0 auto; padding-left: 20px; padding-right: 20px; box-sizing: border-box; }
}

/* Brand Single Page */
.brand-single-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.brand-single-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.brand-single-sub { font-size: 18px; color: #222; letter-spacing: var(--ls-tight); }
.brand-single-main { display: flex; flex-direction: column; gap: 24px; margin: 60px 0 80px; }
.brand-single-name { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.brand-single-image { width: 100%; max-width: 640px; height: 430px; margin-bottom: 36px; }
.brand-single-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 8px; }
.brand-single-content p { font-size: 16px; line-height: 1.8; color: #222; margin: 0 0 24px; letter-spacing: var(--ls-tight); }
.brand-stores-section { margin: 56px 0 80px; width: 100%; }
.brand-stores-content { display: grid; grid-template-columns: 160px 1fr; gap: 60px; align-items: start; margin-top: 40px; width: 100%; box-sizing: border-box; }
.brand-stores-sidebar { width: 160px; }
.brand-stores-sidebar-title { font-size: 24px; font-weight: 700; margin: 0 0 16px; color: #222; letter-spacing: var(--ls-wide); }
.brand-stores-region-list { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 32px; justify-content: center; }
.brand-stores-region-item { margin-bottom: 0; display: flex; justify-content: center; align-items: center; }
.brand-stores-region-item a { display: flex; align-items: center; gap: 8px; color: #888; text-decoration: none; font-size: 16px; letter-spacing: var(--ls-tight); cursor: pointer; }
.brand-stores-region-item a::before { content: ''; width: 12px; height: 12px; border: 2px solid #B0B0B0; border-radius: 50%; display: inline-block; flex-shrink: 0; box-sizing: border-box; }
.brand-stores-region-item.active a { color: #333; font-weight: 500; }
.brand-stores-region-item.active a::before { background: #00B4E3; border-color: #00B4E3; }
.brand-stores-region-item a:hover { color: #00B4E3; }
.brand-stores-region-item a:hover::before { border-color: #00B4E3; }
.brand-stores-main { min-width: 0; width: 100%; }
.brand-stores-list { list-style: none; padding: 0; margin: 0; border-top: none; border-bottom: 1px solid rgba(0,0,0,.1); width: 100%; }
.brand-store-item { padding: 20px 0; border-bottom: 1px solid rgba(0,0,0,.1); }
.brand-store-item:first-child { padding-top: 0; }
.brand-store-item:last-child { border-bottom: none; }
.brand-store-item.hidden { display: none; }
.brand-store-link { display: flex; align-items: center; justify-content: space-between; gap: 16px; color: #222; text-decoration: none; }
.brand-store-link:hover { color: #00B4E3; }
.brand-store-link.is-disabled,
.brand-store-link:not([href]),
.brand-store-link[href=""],
.brand-store-link[href="#"] { color: #222; cursor: default; pointer-events: none; }
.brand-store-link.is-disabled:hover,
.brand-store-link:not([href]):hover,
.brand-store-link[href=""]:hover,
.brand-store-link[href="#"]:hover { color: #222; }
.brand-store-link.is-disabled .brand-store-arrow,
.brand-store-link:not([href]) .brand-store-arrow,
.brand-store-link[href=""] .brand-store-arrow,
.brand-store-link[href="#"] .brand-store-arrow { opacity: .25; }
.brand-store-info-wrapper { flex: 1; min-width: 0; }
.brand-store-name { font-size: 16px; font-weight: 700; margin: 0 0 8px; color: inherit; letter-spacing: var(--ls-wide); line-height: 1.4; }
.brand-store-details { font-size: 14px; line-height: 1.6; letter-spacing: var(--ls-tight); }
.brand-store-detail-line { margin-bottom: 2px; }
.brand-store-detail-line:last-child { margin-bottom: 0; }
.brand-store-postal { color: #222; }
.brand-store-address { color: #222; }
.brand-store-phone { color: #222; }
.brand-store-arrow { width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; flex-shrink: 0; }

/* Company Page */
.company-page-header { margin-bottom: 120px; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.company-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.company-page-sub { font-size: 18px; color: #222; letter-spacing: var(--ls-tight); font-weight: 700; }

/* Company Slider (full width) */
.company-slider-block { overflow: hidden; padding: 0; width: 100%; max-width: 100vw; height: 440px; margin-bottom: 150px; }
.company-slider-container { width: 100%; height: 100%; overflow: hidden; }
.company-slider-track { display: flex; gap: 16px; animation: slide-left 30s linear infinite; height: 100%; }
.company-slider-item { flex-shrink: 0; width: 440px; height: 440px; }
.company-slider-item img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* Company Philosophy Block */
.company-philosophy-block { background: #fff; text-align: center; padding: 0; width: 100%; display: flex; flex-direction: column; align-items: center; box-sizing: border-box; }
.company-philosophy-content { max-width: 860px; width: 100%; padding: 0; box-sizing: border-box; }
.company-philosophy-text { text-align: center; }
.company-philosophy-text p { font-size: 16px; line-height: 1.8; color: #222; margin: 0 0 24px; letter-spacing: var(--ls-tight); }
.company-philosophy-text p:last-child { margin-bottom: 0; }


/* Company Cards Section */
.company-cards-section { padding: 0; margin-top: 80px; margin-bottom: 100px; }
.company-cards-section .container { margin-left: 30px; margin-right: 30px; max-width: none; }
.company-cards { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; }
.company-card { display: flex; flex-direction: column; align-items: center; justify-content: space-between; background: #00B4E3; border-radius: 8px; padding: 32px 24px; text-decoration: none; color: #fff; min-width: 200px; flex: 1; max-width: none; height: 170px; transition: transform 0.2s, box-shadow 0.2s, opacity 0.5s; box-sizing: border-box; }
.company-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.16); opacity: 0.6; }
.company-card-title-en { font-size: 18px; font-weight: 700; margin: 0 0 8px; color: #fff; letter-spacing: var(--ls-wide); }
.company-card-title-ja { font-size: 24px; font-weight: 700; margin: 0 0 auto; color: #fff; letter-spacing: var(--ls-wide); }
.company-card-link { display: inline-flex; align-items: center; gap: 8px; color: #fff; text-decoration: none; font-weight: 700; font-size: 22px; margin-top: 24px; }
.company-card-icon { width: 22px; height: 22px; border: 1px solid #fff; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.company-card-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #fff; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Message Page */
.message-page-header { margin-bottom: 120px; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.message-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.message-page-sub { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.message-page-top { display: flex; gap: 40px; align-items: center; margin-top: 0; margin-bottom: 140px; }
.message-page-header-section { flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; }
.message-page-header-content { display: flex; flex-direction: column; align-items: flex-start; text-align: left; }
.message-page-section-title { font-size: 40px; font-weight: 700; margin: 0 0 8px; color: #222; letter-spacing: var(--ls-wide); }
.message-page-section-sub { font-size: 28px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.message-page-image { width: 640px; height: 430px; flex: none; }
.message-page-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 8px; }
.message-page-bottom { display: flex; gap: 40px; align-items: flex-start; margin-top: 0; margin-bottom: 40px; }
.message-page-quote { flex: 1; min-width: 0; font-size: 48px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); line-height: 1.4; word-break: keep-all; text-align: left; }
.message-page-text { width: 640px; flex: none; font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); }
.message-page-text p { margin: 0 0 24px; }
.message-page-text-pc { display: none; }
.message-page-quote-pc { display: none; }
.message-page-additional-content { font-size: 16px; line-height: 1.8; color: #222; margin: 0 0 32px; letter-spacing: var(--ls-tight); }
.message-page-additional-content p { margin: 0 0 24px; }
.message-page-signature { text-align: right; }
.message-page-signature-title { font-size: 16px; color: #222; margin: 0 0 8px; letter-spacing: var(--ls-tight); }
.message-page-signature-name { font-size: 24px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.message-cards-section { padding: 0; margin-top: 150px; margin-bottom: 150px; }
.message-cards { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; width: 100%; }
.message-card { display: flex; flex-direction: row; align-items: center; justify-content: space-between; background: #00B4E3; border-radius: 8px; padding: 32px 24px; text-decoration: none; color: #fff; min-width: 200px; flex: 1; transition: transform 0.2s, box-shadow 0.2s, opacity 0.5s; }
.message-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.16); opacity: 0.6; }
.message-card-left { display: flex; flex-direction: column; }
.message-card-title-en { font-size: 20px; font-weight: 700; margin: 0 0 8px; color: #fff; letter-spacing: var(--ls-wide); }
.message-card-title-ja { font-size: 28px; font-weight: 700; margin: 0; color: #fff; letter-spacing: var(--ls-wide); }
.message-card-link { display: inline-flex; align-items: center; gap: 8px; color: #fff; text-decoration: none; font-weight: 700; font-size: 22px; margin: 0; }
.message-card-icon { width: 22px; height: 22px; border: 1px solid #fff; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.message-card-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #fff; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Vision Page */
.vision-page-header { margin-bottom: 120px; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.vision-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.vision-page-sub { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.vision-section { margin: 80px 0; }
.vision-section:first-of-type { margin-top: 0; }
.vision-section-row { display: flex; gap: 40px; align-items: center; margin-bottom: 40px; }
.vision-section-row-1 { margin-bottom: 140px; }
.vision-section-row:last-child { margin-bottom: 0; }
.vision-section-2 { display: flex; gap: 40px; align-items: flex-start; }
.vision-section-content-wrapper { flex: 1; min-width: 0; display: flex; flex-direction: column; max-width: 640px; }
.vision-section-header { flex: 1; min-width: 0; }
.vision-section-title { font-size: 40px; font-weight: 700; margin: 0 0 8px; color: #222; letter-spacing: var(--ls-wide); }
.vision-section-sub { font-size: 28px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.vision-section-title-2 { font-size: 24px; font-weight: 700; margin: 0 0 32px; color: #222; letter-spacing: var(--ls-wide); }
.vision-section-quote { flex: 1; min-width: 0; font-size: 48px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); line-height: 1.4; word-break: keep-all; text-align: left; align-self: flex-start; }
.vision-section-text { width: 100%; max-width: 640px; flex: none; font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); }
.vision-section-text p { margin: 0 0 24px; }
.vision-section-text p:last-child { margin-bottom: 0; }
.vision-section-note { font-size: 14px; color: #666; }
.vision-section-image { width: 640px; height: 430px; flex: none; }
.vision-section-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 8px; }
.vision-cards-section { padding: 0; margin-top: 150px; margin-bottom: 150px; }
.vision-cards { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; width: 100%; }
.vision-card { display: flex; flex-direction: row; align-items: center; justify-content: space-between; background: #00B4E3; border-radius: 8px; padding: 32px 24px; text-decoration: none; color: #fff; min-width: 200px; flex: 1; transition: transform 0.2s, box-shadow 0.2s, opacity 0.5s; }
.vision-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,.16); opacity: 0.6; }
.vision-card-left { display: flex; flex-direction: column; }
.vision-card-title-en { font-size: 20px; font-weight: 700; margin: 0 0 8px; color: #fff; letter-spacing: var(--ls-wide); }
.vision-card-title-ja { font-size: 28px; font-weight: 700; margin: 0; color: #fff; letter-spacing: var(--ls-wide); }
.vision-card-link { display: inline-flex; align-items: center; gap: 8px; color: #fff; text-decoration: none; font-weight: 700; font-size: 22px; margin: 0; }
.vision-card-icon { width: 22px; height: 22px; border: 1px solid #fff; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.vision-card-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #fff; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Outline Page */
.outline-page-header { margin-bottom: 120px; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.outline-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.outline-page-sub { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.outline-page-top { display: flex; gap: 40px; align-items: center; margin-top: 0; margin-bottom: 140px; }
.outline-page-header-section { flex: 1; min-width: 0; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; }
.outline-page-section-title { font-size: 40px; font-weight: 700; margin: 0 0 8px; color: #222; letter-spacing: var(--ls-wide); }
.outline-page-section-sub { font-size: 28px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.outline-page-image { width: 640px; height: 430px; flex: none; }
.outline-page-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 8px; }
.outline-page-info { width: 880px; margin-left: auto; margin-right: auto; margin-bottom: 80px; }
.outline-info-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid #ddd; }
.outline-info-item { display: flex; border-bottom: 1px solid #ddd; align-items: flex-start; height: auto; padding: 12px 0; }
.outline-info-list dt { padding: 0; margin: 0; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); flex: 0 0 140px; display: flex; align-items: flex-start; }
.outline-info-list dd { padding: 0; margin: 0; color: #222; letter-spacing: var(--ls-tight); flex: 1; display: block; }
.outline-info-label { display: block; }
.outline-info-value { display: block; }
.outline-map-placeholder { width: 880px; height: 340px; margin-top: 40px; border-radius: 8px; overflow: hidden; }
.outline-map-placeholder iframe { width: 100%; height: 100%; border: 0; border-radius: 8px; }
.outline-page-history { display: flex; gap: 40px; align-items: flex-start; background: rgba(0, 180, 227, 0.1); border-radius: 8px; padding: 40px; margin: 80px 0; }
.outline-history-header { flex: 0 0 200px; }
.outline-history-title { font-size: 30px; font-weight: 700; margin: 0 0 8px; color: #222; letter-spacing: var(--ls-wide); }
.outline-history-sub { font-size: 20px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.outline-history-content { flex: 1; min-width: 0; }
.outline-history-list { margin: 0; padding: 0; list-style: none; }
.outline-history-item { padding: 10px 0; display: flex; gap: 16px; align-items: flex-start; position: relative; padding-left: 24px; }
.outline-history-item::before { content: ''; position: absolute; left: 0; top: 22px; width: 8px; height: 8px; background: #00B4E3; border-radius: 50%; }
.outline-history-date { flex: 0 0 100px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); line-height: 1.8; }
.outline-history-event { flex: 1; color: #222; letter-spacing: var(--ls-tight); line-height: 1.8; }
.outline-history-event br { display: block; content: ""; margin-top: 0.4em; }
.outline-cards-section { padding: 0; margin-top: 150px; margin-bottom: 150px; }
.outline-cards { display: flex; gap: 24px; justify-content: center; flex-wrap: wrap; width: 100%; }
.outline-card { display: flex; flex-direction: row; align-items: center; justify-content: space-between; background: #00B4E3; border-radius: 8px; padding: 32px 24px; text-decoration: none; color: #fff; min-width: 200px; flex: 1; transition: transform 0.2s, box-shadow 0.2s, opacity 0.5s; }
.outline-card:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,.16); opacity: 0.6; }
.outline-card-left { display: flex; flex-direction: column; }
.outline-card-title-en { font-size: 20px; font-weight: 700; margin: 0 0 8px; color: #fff; letter-spacing: var(--ls-wide); }
.outline-card-title-ja { font-size: 28px; font-weight: 700; margin: 0; color: #fff; letter-spacing: var(--ls-wide); }
.outline-card-link { display: inline-flex; align-items: center; gap: 8px; color: #fff; text-decoration: none; font-weight: 700; font-size: 22px; margin: 0; }
.outline-card-icon { width: 22px; height: 22px; border: 1px solid #fff; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.outline-card-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #fff; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Other Brand Section */
.brand-other-section { margin: 140px 0 150px; }
.brand-other-content { display: flex; gap: 48px; align-items: flex-start; margin-top: 40px; }
.brand-other-sidebar { flex-shrink: 0; width: 200px; }
.brand-other-title { font-size: 22px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.brand-other-main { flex: 1; }
.brand-other-card { background: #efefef; border-radius: 8px; padding: 24px; display: flex; gap: 24px; width: 100%; }
.brand-other-image { flex-shrink: 0; width: 300px; aspect-ratio: 4/3; padding: 20px; box-sizing: border-box; }
.brand-other-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 4px; }
.brand-other-info { flex: 1; display: flex; flex-direction: column; margin: 0; }
.brand-other-name { font-size: 26px; font-weight: 700; margin: 0 0 16px; color: #222; letter-spacing: var(--ls-wide); text-align: center; }
.brand-other-desc { font-size: 15px; line-height: 1.8; color: #222; margin: 0 0 24px; flex: 1; letter-spacing: var(--ls-tight); }
.brand-other-link { display: inline-flex; align-items: center; gap: 8px; color: #00B4E3; text-decoration: none; font-weight: 700; font-size: 22px; margin-top: auto; align-self: center; padding: 20px 0; }
.brand-other-link:hover { text-decoration: underline; }
.brand-other-icon { width: 22px; height: 22px; border: 1px solid #00B4E3; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; position: relative; }
.brand-other-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Brands section (same style as News) */
.brands-head { margin-bottom: 80px; }
.brands-block { padding-top: 150px !important; padding-bottom: 150px !important; }
.brands-block .brands-title { font-size: 60px !important; margin: 0; }
.brands-block .brands-sub { color:#666; font-size: 18px !important; margin-top: 4px; letter-spacing: .08em; }
.brands-content { width: 860px; max-width: 100%; margin: 0 0 0 auto; }
.brands-intro { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 80px; width: 100%; max-width: 100%; padding: 0; }
.brands-viewall { display:inline-flex; align-items:center; gap:8px; color:#00B4E3; text-decoration:none; font-weight:700; font-size: 22px; flex-shrink: 0; }
.brands-intro-text { flex: 1; color: #222; font-size: 18px; font-weight: 700; line-height: 1.8; margin: 0; text-align: left; max-width: 860px; }
.brands-viewall .brands-icon { width: 22px; height: 22px; border:1px solid #00B4E3; border-radius: 50%; display:inline-block; position: relative; }
.brands-viewall .brands-icon::after { content:''; position:absolute; top:50%; left:50%; width:0; height:0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%,-50%); }
.brands-list { display: flex; flex-direction: column; gap: 50px; width: 100%; max-width: 100%; }
.brand-item { position: relative; display: flex; gap: 24px; padding: 48px 0; border-radius: 16px; border-top-right-radius: 0; border-bottom-right-radius: 0; max-width: none; width: calc(100% + 140px); margin: 0; margin-right: -140px; align-items: center; overflow: hidden; height: 420px; }
.brand-item::before { content: ''; position: absolute; top: 0; bottom: 0; left: 0; right: 0; background: #f5f5f5; border-top-left-radius: 16px; border-bottom-left-radius: 16px; border-top-right-radius: 0; border-bottom-right-radius: 0; z-index: -1; }
.brand-item::after { content: ''; position: absolute; top: 0; bottom: 0; left: 50%; right: -140px; width: calc(50vw + 140px); margin-left: 0; background: #f5f5f5; border-top-right-radius: 0; border-bottom-right-radius: 0; z-index: -1; }
.brand-item-content { flex: 1; padding: 0 96px; display: flex; flex-direction: column; min-height: 300px; }
.brand-item-title { font-size: 26px; font-weight: 700; margin: 0 0 16px; color: #222; letter-spacing: var(--ls-wide); }
.brand-item-desc { font-size: 16px; line-height: 1.8; color: #222; margin: 0 0 16px; letter-spacing: var(--ls-tight); }
.brand-item-link { display:inline-flex; align-items:center; gap:8px; color:#00B4E3; text-decoration:none; font-weight:700; font-size: 22px; margin-top: auto; }
.brand-item-link .brands-icon { width: 22px; height: 22px; border:1px solid #00B4E3; border-radius: 50%; display:inline-block; position: relative; }
.brand-item-link .brands-icon::after { content:''; position:absolute; top:50%; left:50%; width:0; height:0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%,-50%); }
.brand-item-image { flex-shrink: 0; width: 500px; height: 320px; margin-left: auto; margin-right: 140px; }
.brand-item-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 4px; }

/* PC 画面幅が小さいとき: brand-item-content の細くなりすぎを防ぐ */
@media (min-width: 1025px) and (max-width: 1400px) {
    .brand-item-content { min-width: 320px; padding: 0 48px; }
    .brand-item-image { width: 400px; height: 256px; margin-right: 80px; }
}
@media (min-width: 1025px) and (max-width: 1200px) {
    .brand-item-content { min-width: 300px; padding: 0 32px; }
    .brand-item-image { width: 340px; height: 218px; margin-right: 48px; }
}

/* Made in WIN section */
.madein-block { padding: 0 0 100px; }
.madein-container { display: flex; flex-direction: column; gap: 40px; align-items: flex-start; max-width: none; width: 100%; margin: 0; padding: 0; }
.madein-hero-img { width: calc(100% + 140px); margin-left: -140px; height: auto; display: block; border-radius: 8px; }
.madein-link { display: inline-flex; align-items: center; gap: 8px; color: #00B4E3; text-decoration: none; font-weight: 700; font-size: 22px; align-self: center; }
.madein-icon { width: 22px; height: 22px; border:1px solid #00B4E3; border-radius: 50%; display:inline-block; position: relative; }
.madein-icon::after { content:''; position:absolute; top:50%; left:50%; width:0; height:0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%,-50%); }

/* Unified hover opacity for CTA/inline links (PC & SP) */
.news-viewall,
.brands-viewall,
.brand-item-link,
.madein-link,
.philosophy-cta,
.company-card-link,
.message-card-link,
.vision-card-link,
.outline-card-link,
.brands-page-card-link,
.brand-other-link,
.recruit-know-card-link,
.company-recruit-card-link {
  transition: opacity 0.5s;
}

.news-viewall:hover,
.brands-viewall:hover,
.brand-item-link:hover,
.madein-link:hover,
.philosophy-cta:hover,
.company-card-link:hover,
.message-card-link:hover,
.vision-card-link:hover,
.outline-card-link:hover,
.brands-page-card-link:hover,
.brand-other-link:hover,
.recruit-know-card-link:hover,
.company-recruit-card-link:hover {
  opacity: 0.6;
}

/* Philosophy section */
.philosophy-block { background: #fff; text-align: center; padding: 0 !important; margin-top: 150px; margin-bottom: 100px; }
.philosophy-content { max-width: 800px; margin: 0 auto; padding: 0; display: flex; flex-direction: column; align-items: center; text-align: center; }
.philosophy-label { font-size: 18px; color: #666; letter-spacing: .08em; margin: 0 0 18px; }
.philosophy-visual { position: relative; width: 100%; }
.philosophy-title-wrap { position: relative; width: 100%; padding: 24px 0; }
.philosophy-bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; pointer-events: none; }
.philosophy-bg-img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 100%; max-width: 600px; height: auto; }
.philosophy-title { font-size: 48px !important; line-height: 1.3; margin: 0; color: #222; position: relative; z-index: 1; }
.philosophy-text { font-size: 18px; line-height: 1.8; margin: 24px 0 0; color: #222; }
.philosophy-cta { display: inline-flex; align-items: center; gap: 8px; color: #00B4E3; text-decoration: none; font-weight: 700; font-size: 22px; margin-top: 32px; }
.philosophy-icon { width: 22px; height: 22px; border: 1px solid #00B4E3; border-radius: 50%; display: inline-block; position: relative; }
.philosophy-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Slider section - Swiper で左方向等速無限ループ（company-slider は従来の keyframes を使用） */
@keyframes slide-left {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.slider-block { overflow: hidden; padding-top: 0; padding-bottom: 0; width: 100%; max-width: 100vw; height: 440px; margin-top: 60px; }
.slider-block .slider-block-swiper { width: 100%; height: 100%; overflow: hidden; }
.slider-block-swiper .swiper-wrapper { transition-timing-function: linear !important; }
.slider-block .slider-item,
.slider-block .swiper-slide.slider-item { flex-shrink: 0; width: 440px; height: 440px; }
.slider-item img { width: 100%; height: 100%; object-fit: cover; display: block; }

.win-philosophy-visual-block { padding: 0 20px; margin: 0; width: 100%; max-width: 100%; overflow: hidden; box-sizing: border-box; display: flex; justify-content: center; }
.win-philosophy-visual-img { max-width: 100%; height: auto; display: block; vertical-align: bottom; }
.win-philosophy-visual-img-pc { display: none; }

/* Company / Recruit section */
.company-recruit-block { position: relative; padding: 0 !important; height: 400px; overflow: visible; }
.company-recruit-bg { position: absolute; top: 0; left: 0; width: 100vw; height: 400px; z-index: 0; overflow: hidden; margin-left: calc(50% - 50vw); }
.company-recruit-bg-img { width: 100%; height: 100%; object-fit: cover; display: block; }
.company-recruit-content { position: absolute; bottom: 0; left: 50%; transform: translate(-50%, 50%); z-index: 1; max-width: 1200px; width: 100%; padding: 0 30px; box-sizing: border-box; }
.company-recruit-cards { display: flex; flex-direction: row; gap: 40px; justify-content: center; flex-wrap: nowrap; width: 100%; height: 100%; align-items: center; }
.company-recruit-card { display: flex; flex-direction: row; align-items: center; justify-content: space-between; background: #fff; border-radius: 16px; padding: 16px 24px; text-decoration: none; color: inherit; box-shadow: 0 4px 20px rgba(0,0,0,.15); width: 100%; height: 110px; min-height: 110px; flex: 1; min-width: 0; transition: box-shadow 0.2s; box-sizing: border-box; }
.company-recruit-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,.15); }
.company-recruit-card-text { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.company-recruit-card-title { font-size: 46px; font-weight: 700; margin: 0; color: #222; text-align: left; letter-spacing: var(--ls-wide); line-height: 1.2; transition: opacity 0.5s; }
.company-recruit-card-sub { font-size: 18px; margin: 0; color: #222; text-align: left; letter-spacing: var(--ls-tight); transition: opacity 0.5s; }
.company-recruit-card-link { display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; color: #00B4E3; text-decoration: none; }
.company-recruit-card-link-text { transition: opacity 0.5s; }
.company-recruit-card:hover .company-recruit-card-title,
.company-recruit-card:hover .company-recruit-card-sub,
.company-recruit-card:hover .company-recruit-card-link-text { opacity: 0.6; }
.company-recruit-icon { width: 30px; height: 30px; border: 1px solid #00B4E3; border-radius: 50%; display: inline-block; position: relative; flex-shrink: 0; }
.company-recruit-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }

/* Contact Page */
.contact-page-header { margin-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.contact-page-divider { height: 1px; background: #00B4E3; margin: 0; padding: 0; width: 100%; }
.contact-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.contact-page-sub { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.contact-page-instructions { margin-bottom: 0; }
.contact-instruction-text { font-size: 16px; color: #222; margin-bottom: 12px; letter-spacing: var(--ls-tight); line-height: 1.6; }
.contact-instruction-text .required-mark { color: #ef4444; font-weight: 700; }
.contact-instruction-note { font-size: 14px; color: #666; margin-bottom: 12px; letter-spacing: var(--ls-tight); line-height: 1.6; }
.contact-page-content { max-width: 100%; margin: 0 0 80px 0; }
.contact-form-wrapper {
  background: #fff;
  border-radius: 12px;
  padding: 40px 30px;
  max-width: 800px;
  margin: 0 auto;
}

/* Contact Privacy Notice — CF7フォーム内に同内容があるため非表示 */
.contact-privacy-notice {
  max-width: 800px;
  margin: 32px auto 0;
  padding: 0;
  display: none;
}

/* 確認画面と完了画面では非表示（CF7 送信完了・確認プラグインの画面でも非表示） */
body .mw_wp_form_confirm ~ .contact-privacy-notice,
body .mw_wp_form_complete ~ .contact-privacy-notice,
body .contact-form-wrapper:has(.mw_wp_form_confirm) ~ .contact-privacy-notice,
body .contact-form-wrapper:has(.mw_wp_form_complete) ~ .contact-privacy-notice,
body .contact-form-wrapper:has(.wpcf7-mail-sent-ok) ~ .contact-privacy-notice,
body .contact-form-wrapper:has(form.wpcf7-form.sent) ~ .contact-privacy-notice,
body .contact-form-wrapper:has(.wpcf7-mail-sent-ok) .contact-privacy-notice,
body .contact-form-wrapper:has(form.wpcf7-form.sent) .contact-privacy-notice,
body .contact-form-wrapper:has(.wpcf7-confirm) .contact-privacy-notice,
body .contact-form-wrapper:has(.cf7-confirm) .contact-privacy-notice {
  display: none;
}

.contact-privacy-notice-text {
  font-size: 15px;
  font-weight: 600;
  color: #1f2937;
  margin: 0 0 20px 0;
  text-align: center;
  letter-spacing: var(--ls-tight);
  line-height: 1.6;
}

.contact-privacy-content {
  background: #f9fafb;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 24px;
  margin: 0;
}

.contact-privacy-title {
  font-size: 16px;
  font-weight: 700;
  color: #1f2937;
  margin: 0 0 16px 0;
  letter-spacing: var(--ls-wide);
}

.contact-privacy-text {
  font-size: 14px;
  color: #374151;
  margin: 0 0 12px 0;
  letter-spacing: var(--ls-tight);
  line-height: 1.7;
}

.contact-privacy-text:last-child {
  margin-bottom: 0;
}

.contact-privacy-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px 20px;
}

.contact-privacy-list li {
  font-size: 14px;
  color: #374151;
  margin: 0 0 8px 0;
  padding-left: 20px;
  position: relative;
  letter-spacing: var(--ls-tight);
  line-height: 1.7;
}

.contact-privacy-list li::before {
  content: "・";
  position: absolute;
  left: 0;
  color: #6b7280;
  font-weight: 700;
}

.contact-privacy-list li:last-child {
  margin-bottom: 0;
}

@media (max-width: 1024px) {
  .contact-privacy-content {
    padding: 20px;
  }
  
  .contact-privacy-notice-text {
    font-size: 14px;
  }
  
  .contact-privacy-title {
    font-size: 15px;
  }
  
  .contact-privacy-text,
  .contact-privacy-list li {
    font-size: 13px;
  }
}

/* MW WP Form Styles - Entry Form のみ（お問い合わせは Contact Form 7 へ移行済み） */
.recruit-entry-form-wrapper .mw_wp_form {
  margin: 0;
  padding: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .form-row {
  margin: 0 0 28px 0;
  padding: 0;
  display: flex;
  align-items: flex-start;
  gap: 20px;
  position: relative;
}

.recruit-entry-form-wrapper .mw_wp_form .form-row:last-child {
  margin-bottom: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .form-label {
  flex: 0 0 180px;
  font-size: 14px;
  font-weight: 600;
  color: #1f2937;
  line-height: 1.5;
  padding-top: 12px;
  box-sizing: border-box;
  min-width: 180px;
  max-width: 180px;
}

.recruit-entry-form-wrapper .mw_wp_form .form-label .required {
  color: #ef4444;
  margin-left: 4px;
  font-weight: 600;
}

.recruit-entry-form-wrapper .mw_wp_form .form-field {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
}

.recruit-entry-form-wrapper .mw_wp_form .form-field-group {
  display: flex;
  flex-direction: row;
  gap: 12px;
  flex: 1;
  min-width: 0;
  width: 100%;
}

.recruit-entry-form-wrapper .mw_wp_form .form-field-group .form-field {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
}

/* Name & Kana Groups */
.recruit-entry-form-wrapper .mw_wp_form .name-group .form-field-group,
.recruit-entry-form-wrapper .mw_wp_form .kana-group .form-field-group {
  display: flex;
  flex-direction: row;
  gap: 12px;
  flex: 1;
  min-width: 0;
  width: 100%;
}

.recruit-entry-form-wrapper .mw_wp_form .name-group .form-field-group .form-field,
.recruit-entry-form-wrapper .mw_wp_form .kana-group .form-field-group .form-field {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .name-group input[type="text"],
.recruit-entry-form-wrapper .mw_wp_form .kana-group input[type="text"],
.recruit-entry-form-wrapper .mw_wp_form .name-group .mwform-text,
.recruit-entry-form-wrapper .mw_wp_form .kana-group .mwform-text {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #1f2937;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .name-group input[type="text"]::placeholder,
.recruit-entry-form-wrapper .mw_wp_form .kana-group input[type="text"]::placeholder {
  color: #9ca3af;
  opacity: 0.7;
}

.recruit-entry-form-wrapper .mw_wp_form .name-group input[type="text"]:hover,
.recruit-entry-form-wrapper .mw_wp_form .kana-group input[type="text"]:hover {
  border-color: #9ca3af;
}

.recruit-entry-form-wrapper .mw_wp_form .name-group input[type="text"]:focus,
.recruit-entry-form-wrapper .mw_wp_form .kana-group input[type="text"]:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.1);
}

/* Birthday Group */
.recruit-entry-form-wrapper .mw_wp_form .birthday-group .form-field-group {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 6px;
  width: auto;
  max-width: 100%;
}

.recruit-entry-form-wrapper .mw_wp_form .birthday-group .form-field {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
  height: 44px;
  flex: 0 1 auto;
  min-width: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .birthday-group input[type="number"],
.recruit-entry-form-wrapper .mw_wp_form .birthday-group .mwform-number {
  width: 100%;
  max-width: 90px;
  padding: 12px 8px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #1f2937;
  text-align: center;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
  flex: 1;
  min-width: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .birthday-group input[type="number"]::placeholder {
  color: #9ca3af;
  opacity: 0.7;
}

.recruit-entry-form-wrapper .mw_wp_form .birthday-group input[type="number"]:hover {
  border-color: #9ca3af;
}

.recruit-entry-form-wrapper .mw_wp_form .birthday-group input[type="number"]:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.1);
}

.recruit-entry-form-wrapper .mw_wp_form .birthday-group .birthday-label {
  font-size: 13px;
  color: #6b7280;
  font-weight: 500;
  padding: 0 0 0 2px;
  margin: 0;
  white-space: nowrap;
  height: 44px;
  display: flex;
  align-items: center;
  line-height: 1;
}

/* Gender Group */
.recruit-entry-form-wrapper .mw_wp_form .gender-group .form-field {
  display: flex;
  flex-direction: row;
  gap: 16px;
}

.recruit-entry-form-wrapper .mw_wp_form .gender-group label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  cursor: pointer;
  margin: 0;
  padding: 0;
  font-size: 14px;
  color: #1f2937;
  transition: color 0.15s ease;
}

.recruit-entry-form-wrapper .mw_wp_form .gender-group input[type="radio"],
.recruit-entry-form-wrapper .mw_wp_form .gender-group .mwform-radio {
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  accent-color: #00B4E3;
  flex-shrink: 0;
  transition: all 0.15s ease;
}

.recruit-entry-form-wrapper .mw_wp_form .gender-group input[type="radio"]:checked ~ label,
.recruit-entry-form-wrapper .mw_wp_form .gender-group input[type="radio"]:checked + label {
  color: #00B4E3;
  font-weight: 600;
}

.recruit-entry-form-wrapper .mw_wp_form .gender-group label:hover {
  color: #00B4E3;
}

/* Phone Group */
.recruit-entry-form-wrapper .mw_wp_form .phone-group .form-field-group {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
}

.recruit-entry-form-wrapper .mw_wp_form .phone-group .form-field {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .phone-group input[type="text"],
.recruit-entry-form-wrapper .mw_wp_form .phone-group .mwform-text {
  flex: 1;
  min-width: 0;
  padding: 12px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #1f2937;
  text-align: center;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .phone-group input[type="text"]::placeholder {
  color: #9ca3af;
  opacity: 0.7;
}

.recruit-entry-form-wrapper .mw_wp_form .phone-group input[type="text"]:hover {
  border-color: #9ca3af;
}

.recruit-entry-form-wrapper .mw_wp_form .phone-group input[type="text"]:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.1);
}

.recruit-entry-form-wrapper .mw_wp_form .phone-group .phone-separator {
  color: #6b7280;
  font-size: 14px;
  font-weight: 500;
  flex-shrink: 0;
  padding: 0 2px;
}

/* Email & Other Text Inputs */
.recruit-entry-form-wrapper .mw_wp_form input[type="email"],
.recruit-entry-form-wrapper .mw_wp_form input[type="text"]:not(.name-group input):not(.kana-group input):not(.birthday-group input):not(.phone-group input),
.recruit-entry-form-wrapper .mw_wp_form .mwform-email,
.recruit-entry-form-wrapper .mw_wp_form .mwform-text:not(.name-input):not(.kana-input):not(.birthday-input):not(.phone-input) {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #1f2937;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.recruit-entry-form-wrapper .mw_wp_form input[type="email"]::placeholder,
.recruit-entry-form-wrapper .mw_wp_form input[type="text"]::placeholder {
  color: #9ca3af;
  opacity: 0.7;
}

.recruit-entry-form-wrapper .mw_wp_form input[type="email"]:hover,
.recruit-entry-form-wrapper .mw_wp_form input[type="text"]:hover {
  border-color: #9ca3af;
}

.recruit-entry-form-wrapper .mw_wp_form input[type="email"]:focus,
.recruit-entry-form-wrapper .mw_wp_form input[type="text"]:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.1);
}

/* Select Box */
.recruit-entry-form-wrapper .mw_wp_form select,
.recruit-entry-form-wrapper .mw_wp_form .mwform-select {
  width: 100%;
  padding: 12px 36px 12px 16px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #1f2937;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L2 4h8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  cursor: pointer;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.recruit-entry-form-wrapper .mw_wp_form select:hover {
  border-color: #9ca3af;
}

.recruit-entry-form-wrapper .mw_wp_form select:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.1);
}

.recruit-entry-form-wrapper .mw_wp_form select option {
  padding: 8px;
  color: #1f2937;
}

/* Textarea */
.recruit-entry-form-wrapper .mw_wp_form textarea,
.recruit-entry-form-wrapper .mw_wp_form .mwform-textarea {
  width: 100%;
  padding: 12px 16px;
  border: 1.5px solid #d1d5db;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
  color: #1f2937;
  resize: vertical;
  min-height: 120px;
  font-family: inherit;
  line-height: 1.6;
  box-sizing: border-box;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.recruit-entry-form-wrapper .mw_wp_form textarea::placeholder {
  color: #9ca3af;
  opacity: 0.7;
}

.recruit-entry-form-wrapper .mw_wp_form textarea:hover {
  border-color: #9ca3af;
}

.recruit-entry-form-wrapper .mw_wp_form textarea:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.1);
}

/* Recruit Source Group (Radio Buttons) */
.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .form-field {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .form-field > * {
  margin: 0;
  padding: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 500;
  cursor: pointer;
  margin: 0;
  padding: 0;
  font-size: 14px;
  color: #1f2937;
  line-height: 1.5;
  transition: color 0.15s ease;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group label:first-child {
  margin-top: 0;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group input[type="radio"],
.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .mwform-radio {
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  accent-color: #00B4E3;
  flex-shrink: 0;
  transition: all 0.15s ease;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group input[type="radio"]:checked ~ label,
.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group input[type="radio"]:checked + label {
  color: #00B4E3;
  font-weight: 600;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group label:hover {
  color: #00B4E3;
}

/* MW WP Formのラジオボタンのラッパー要素のスタイル調整 */
.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .mwform-radio-wrapper,
.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .mwform-form-control-wrap {
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  gap: 10px;
}

.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .mwform-radio-wrapper:first-child,
.recruit-entry-form-wrapper .mw_wp_form .recruit-source-group .mwform-form-control-wrap:first-child {
  margin-top: 0;
}

/* Submit Button */
.recruit-entry-form-wrapper .mw_wp_form input[type="submit"],
.recruit-entry-form-wrapper .mw_wp_form .mwform-submit {
  background: #00B4E3;
  color: #fff;
  border: none;
  padding: 12px 40px;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s ease;
  display: block;
  margin: 40px auto 0;
  min-width: 180px;
  height: 44px;
  box-sizing: border-box;
  box-shadow: 0 2px 4px rgba(0, 180, 227, 0.2);
}

.recruit-entry-form-wrapper .mw_wp_form input[type="submit"]:hover {
  background: #0099cc;
  box-shadow: 0 4px 8px rgba(0, 180, 227, 0.3);
  transform: translateY(-1px);
}

.recruit-entry-form-wrapper .mw_wp_form input[type="submit"]:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.2), 0 4px 8px rgba(0, 180, 227, 0.3);
}

.recruit-entry-form-wrapper .mw_wp_form input[type="submit"]:active {
  background: #0088b3;
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 180, 227, 0.2);
}

/* Error Messages */
.recruit-entry-form-wrapper .mw_wp_form .mwform-error {
  font-size: 12px;
  color: #ef4444;
  margin-top: 6px;
  display: block;
  line-height: 1.4;
  padding: 0;
  margin-bottom: 0;
  position: relative;
  top: 0;
  left: 0;
  font-weight: 500;
}

/* Error State */
.recruit-entry-form-wrapper .mw_wp_form .mwform-invalid {
  border-color: #ef4444 !important;
  border-width: 1.5px !important;
}

.recruit-entry-form-wrapper .mw_wp_form .mwform-invalid:hover {
  border-color: #dc2626 !important;
}

.recruit-entry-form-wrapper .mw_wp_form .mwform-invalid:focus {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.15) !important;
}

/* Responsive for MW WP Form */
@media (max-width: 1024px) {
  .recruit-entry-form-wrapper .mw_wp_form .form-row {
    flex-direction: column;
    gap: 8px;
    margin-bottom: 20px;
  }

  .recruit-entry-form-wrapper .mw_wp_form .form-label {
    flex: 0 0 auto;
    min-width: auto;
    max-width: none;
    padding-top: 0;
  }

  .recruit-entry-form-wrapper .mw_wp_form .name-group .form-field-group,
  .recruit-entry-form-wrapper .mw_wp_form .kana-group .form-field-group,
  .recruit-entry-form-wrapper .mw_wp_form .phone-group .form-field-group {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .recruit-entry-form-wrapper .mw_wp_form .birthday-group .form-field-group {
    flex-direction: row;
    align-items: center;
    gap: 6px;
  }

  .recruit-entry-form-wrapper .mw_wp_form .birthday-group .form-field {
    flex-direction: row;
    justify-content: flex-start;
    width: auto;
  }

  .recruit-entry-form-wrapper .mw_wp_form .birthday-group input[type="number"] {
    width: 100%;
    flex: 1;
  }

  .recruit-entry-form-wrapper .mw_wp_form .phone-group input[type="text"] {
    width: 100%;
    flex: 1;
  }

  .recruit-entry-form-wrapper .mw_wp_form .phone-group .phone-separator {
    display: none;
  }
}

/* Contact Form 7 — お問い合わせページ（contact-form-7-contact-form.txt の .contactForm 構造） */
.contact-form-wrapper .wpcf7 {
  margin: 0;
  padding: 0;
}

.contact-form-wrapper .wpcf7-form {
  margin: 0;
  padding: 0;
}

/* テーマ共通の .wpcf7-form p { display:flex } を打ち消し */
.contact-form-wrapper .wpcf7-form > p {
  display: block;
  margin: 0;
  padding: 0;
  flex: none;
  gap: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm {
  margin: 0;
  padding: 0;
}

/* ── dl 各行 ── */
.contact-form-wrapper .wpcf7-form .contactForm dl {
  margin: 0;
  padding: 20px 24px;
  display: flex;
  align-items: flex-start;
  gap: 20px;
  position: relative;
  background: transparent;
}

/* ── dt ラベル ── */
.contact-form-wrapper .wpcf7-form .contactForm dt {
  flex: 0 0 160px;
  font-size: 15px;
  font-weight: 700;
  color: #333;
  line-height: 1.5;
  padding-top: 10px;
  box-sizing: border-box;
  min-width: 160px;
  max-width: 160px;
  margin: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm dt .blueTxt {
  color: #e74c3c;
  margin-left: 4px;
  font-weight: 700;
}

.contact-form-wrapper .wpcf7-form .contactForm dt p {
  display: inline;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  line-height: inherit;
}

/* ── dd 入力エリア ── */
.contact-form-wrapper .wpcf7-form .contactForm dd {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* ── .formParts 共通 ── */
.contact-form-wrapper .wpcf7-form .contactForm .formParts {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 8px;
  width: 100%;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts br.sp {
  display: none;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts .nameLabel {
  font-size: 14px;
  font-weight: 600;
  color: #555;
  margin: 0;
  padding: 0;
  flex-shrink: 0;
  flex: 0 0 auto;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts .wpcf7-form-control-wrap {
  flex: 1;
  min-width: 80px;
  margin: 0;
}

/* ── 入力フィールド共通スタイル: グレー背景 ── */
.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formName,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formName.wpcf7-not-valid {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 15px;
  background: #e8e8e8;
  color: #333;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formName::placeholder {
  color: #999;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formName:focus {
  outline: none;
  border-color: #00B4E3;
  background: #fff;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── 電話番号 ── */
.contact-form-wrapper .wpcf7-form .contactForm .formParts .wpcf7-form-control-wrap:has(input.formTel),
.contact-form-wrapper .wpcf7-form .contactForm .formParts .wpcf7-form-control-wrap:has(input[type="tel"]) {
  flex: 0 1 120px;
  min-width: 80px;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formTel,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input[type="tel"] {
  width: 100%;
  padding: 10px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 15px;
  background: #e8e8e8;
  color: #333;
  text-align: center;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formTel::placeholder,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input[type="tel"]::placeholder {
  color: #999;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formTel:focus,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input[type="tel"]:focus {
  outline: none;
  border-color: #00B4E3;
  background: #fff;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── メールアドレスの注釈 p ── */
.contact-form-wrapper .wpcf7-form .contactForm .formParts p {
  display: block;
  width: 100%;
  margin: 0 0 4px 0;
  padding: 0;
  font-size: 13px;
  color: #666;
  font-weight: 500;
  flex: 0 0 100%;
}

/* ── メール formLarge ── */
.contact-form-wrapper .wpcf7-form .contactForm .formParts .wpcf7-form-control-wrap:has(.formLarge) {
  flex: 0 0 100%;
  min-width: 100%;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts .formLarge,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formLarge {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 15px;
  background: #e8e8e8;
  color: #333;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  display: block;
  margin: 0 0 10px 0;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts .formLarge:last-of-type,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formLarge:last-of-type {
  margin-bottom: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts .formLarge::placeholder {
  color: #999;
}

.contact-form-wrapper .wpcf7-form .contactForm .formParts .formLarge:focus,
.contact-form-wrapper .wpcf7-form .contactForm .formParts input.formLarge:focus {
  outline: none;
  border-color: #00B4E3;
  background: #fff;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── Select ── */
.contact-form-wrapper .wpcf7-form .contactForm select {
  width: 100%;
  padding: 10px 36px 10px 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 15px;
  background: #e8e8e8;
  color: #333;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L2 4h8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  cursor: pointer;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm select:focus {
  outline: none;
  border-color: #00B4E3;
  background-color: #fff;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── Textarea ── */
.contact-form-wrapper .wpcf7-form .contactForm textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 15px;
  background: #e8e8e8;
  color: #333;
  resize: vertical;
  min-height: 160px;
  font-family: inherit;
  line-height: 1.6;
  box-sizing: border-box;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.contact-form-wrapper .wpcf7-form .contactForm textarea::placeholder {
  color: #999;
}

.contact-form-wrapper .wpcf7-form .contactForm textarea:focus {
  outline: none;
  border-color: #00B4E3;
  background: #fff;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

.contact-form-wrapper .wpcf7-form .contactForm .wai-sankaku-down {
  display: none;
}

/* ── contactPoint（注意テキスト）── 表示 */
.contact-form-wrapper .wpcf7-form > p.contactPoint {
  display: block;
  font-size: 15px;
  font-weight: 400;
  color: #333;
  margin: 28px 20px 16px 20px;
  padding: 0;
  text-align: center;
  line-height: 1.7;
}

/* ── 個人情報テキスト ── 表示 */
.contact-form-wrapper .wpcf7-form > p:not(.contactPoint):not([class]) {
  display: block;
  font-size: 14px;
  font-weight: 400;
  color: #333;
  margin: 0 20px 24px 20px;
  padding: 0;
  line-height: 1.8;
}

/* ── btnSubmit — [confirm][back] 生テキスト非表示 & ボタンスタイル ── */
.contact-form-wrapper .wpcf7-form .btnSubmit {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 32px 0 0 0;
  padding: 0;
  font-size: 0;
  line-height: 0;
}

.contact-form-wrapper .wpcf7-form .btnSubmit input[type="submit"],
.contact-form-wrapper .wpcf7-form .btnSubmit input[type="button"],
.contact-form-wrapper .wpcf7-form .btnSubmit button {
  background: #00B4E3;
  color: #fff;
  border: none;
  padding: 16px 60px;
  border-radius: 6px;
  font-size: 18px;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 240px;
  height: 54px;
  box-sizing: border-box;
  box-shadow: 0 2px 6px rgba(0, 180, 227, 0.25);
  letter-spacing: 0.05em;
}

.contact-form-wrapper .wpcf7-form .btnSubmit input[type="submit"]:hover,
.contact-form-wrapper .wpcf7-form .btnSubmit input[type="button"]:hover,
.contact-form-wrapper .wpcf7-form .btnSubmit button:hover {
  background: #0099cc;
  box-shadow: 0 2px 6px rgba(0, 180, 227, 0.25);
}

.contact-form-wrapper .wpcf7-form .btnSubmit input[type="submit"]:focus,
.contact-form-wrapper .wpcf7-form .btnSubmit input[type="button"]:focus,
.contact-form-wrapper .wpcf7-form .btnSubmit button:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 180, 227, 0.25), 0 4px 10px rgba(0, 180, 227, 0.35);
}

.contact-form-wrapper .wpcf7-form .btnSubmit input[type="submit"]:active,
.contact-form-wrapper .wpcf7-form .btnSubmit input[type="button"]:active,
.contact-form-wrapper .wpcf7-form .btnSubmit button:active {
  background: #0088b3;
  transform: translateY(0);
  box-shadow: 0 2px 4px rgba(0, 180, 227, 0.2);
}

/* ── Error ── */
.contact-form-wrapper .wpcf7-form .wpcf7-form-control-wrap .wpcf7-not-valid-tip {
  font-size: 12px;
  color: #ef4444;
  margin-top: 6px;
  display: block;
  line-height: 1.4;
  font-weight: 500;
}

.contact-form-wrapper .wpcf7-form .contactForm .wpcf7-custom-item-error {
  display: block;
  font-size: 12px;
  color: #ef4444;
  margin-top: 6px;
  width: 100%;
}

.contact-form-wrapper .wpcf7-form .contactForm .wpcf7-not-valid {
  border-color: #ef4444 !important;
}

.contact-form-wrapper .wpcf7-form .contactForm .wpcf7-not-valid:focus {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.15) !important;
}

.contact-form-wrapper .wpcf7-response-output {
  margin-top: 24px;
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 14px;
  line-height: 1.5;
  border: 1px solid;
  font-weight: 500;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .contact-form-wrapper .wpcf7-form .contactForm dl {
    flex-direction: column;
    gap: 8px;
    padding: 16px;
  }

  .contact-form-wrapper .wpcf7-form .contactForm dt {
    flex: 0 0 auto;
    min-width: auto;
    max-width: none;
    padding-top: 0;
  }

  .contact-form-wrapper .wpcf7-form .contactForm .formParts {
    flex-wrap: wrap;
  }

  .contact-form-wrapper .wpcf7-form .contactForm .formParts br.sp {
    display: block;
    flex-basis: 100%;
    height: 0;
  }

  .contact-form-wrapper .wpcf7-form .contactForm .formParts .wpcf7-form-control-wrap:has(input.formTel),
  .contact-form-wrapper .wpcf7-form .contactForm .formParts .wpcf7-form-control-wrap:has(input[type="tel"]) {
    flex: 1 1 0;
    min-width: 50px;
  }

  .contact-form-wrapper .wpcf7-form .btnSubmit input[type="submit"],
  .contact-form-wrapper .wpcf7-form .btnSubmit input[type="button"],
  .contact-form-wrapper .wpcf7-form .btnSubmit button {
    width: 100%;
    min-width: 100%;
  }
}

.contact-form-notice { text-align: center; padding: 40px; background: #f5f5f5; border-radius: 8px; color: #666; }

/* Recruit Entry Page Styles */
.recruit-entry-page { position: relative; overflow: hidden; }
.recruit-entry-page::before { content: ''; position: absolute; top: 0; left: 0; width: 100%; height: 620px; background: #ccf0f9; clip-path: polygon(0 0, 100% 0, 100% 75%, 0 100%); z-index: 0; pointer-events: none; }
.recruit-entry-page .container { position: relative; z-index: 2; }
.recruit-entry-page-header { margin-bottom: 40px; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.recruit-entry-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.recruit-entry-page-sub { font-size: 18px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.recruit-entry-page-instructions { margin-bottom: 40px; font-size: 16px; color: #000; }
.recruit-entry-instruction-text { font-size: 16px; color: #000; margin-top: 0; margin-bottom: 0; letter-spacing: var(--ls-tight); line-height: 1.6; }
.recruit-entry-instruction-text .required-mark { color: #ef4444; font-weight: 700; }
.recruit-entry-instruction-note { font-size: 16px; color: #000; margin-top: 0; margin-bottom: 0; letter-spacing: var(--ls-tight); line-height: 1.6; }
.recruit-entry-instruction-text + .recruit-entry-instruction-note { margin-top: 15px; }
.recruit-entry-page-content { max-width: 100%; margin: 0 0 80px 0; }
.recruit-entry-form-notice { text-align: center; padding: 40px; background: #f5f5f5; border-radius: 8px; color: #666; }

/* Entry Form Specific Styles - Clean, Modern, Simple */
.recruit-entry-form-wrapper {
  /* background: #fff; */
  border-radius: 12px;
  padding: 40px;
  max-width: 800px;
  margin: 0 auto;
}

.recruit-entry-form-wrapper:has(.mw_wp_form.mw_wp_form_complete) {
  border: 1px solid #e5e7eb;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
}

/* Recruit Entry Privacy Notice */
.recruit-entry-privacy-notice {
  max-width: 800px;
  margin: 32px auto 0;
  padding: 0;
}

.recruit-entry-privacy-notice-text {
  font-size: 15px;
  font-weight: 600;
  color: #1f2937;
  margin: 0;
  text-align: center;
  letter-spacing: var(--ls-tight);
  line-height: 1.6;
}

.recruit-entry-privacy-link {
  text-decoration: underline;
  transition: opacity 0.2s ease;
}

.recruit-entry-privacy-link:hover {
  opacity: 0.8;
}

@media (max-width: 1024px) {
  .recruit-entry-privacy-notice-text {
    font-size: 14px;
  }
}

/* === Contact Form 7 — エントリーフォーム (.entryForm dl/dt/dd — 白背景デザイン) === */
.recruit-entry-form-wrapper .wpcf7-form {
  margin: 0;
  padding: 0;
}

.recruit-entry-form-wrapper .wpcf7-form > p {
  display: block;
  margin: 0;
  padding: 0;
  flex: none;
  gap: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm {
  margin: 0;
  padding: 0;
}

/* ── dl 各行: 白背景 ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm dl {
  margin: 0;
  padding: 20px 24px;
  display: flex;
  align-items: flex-start;
  gap: 20px;
  position: relative;
  background: #fff;
}

/* ── dt ラベル ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm dt {
  flex: 0 0 120px;
  font-size: 15px;
  font-weight: 700;
  color: #333;
  line-height: 1.5;
  padding-top: 10px;
  box-sizing: border-box;
  min-width: 160px;
  max-width: 160px;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm dt .blueTxt {
  color: #e74c3c;
  margin-left: 4px;
  font-weight: 700;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm dt p {
  display: inline;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  line-height: inherit;
}

/* ── dd 入力エリア ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm dd {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* ── .formParts 共通 ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 8px;
  width: 100%;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts br.sp {
  display: none;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .nameLabel {
  font-size: 14px;
  font-weight: 600;
  color: #555;
  margin: 0;
  padding: 0;
  flex-shrink: 0;
  flex: 0 0 auto;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap {
  flex: 1;
  min-width: 80px;
  margin: 0;
}

/* ── 入力フィールド共通: 白背景 + 黒縁 ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formName {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formName::placeholder {
  color: #999;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formName:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── 生年月日 text input — 横並び ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input.formBirth) {
  flex: 0 0 auto;
  min-width: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formBirth {
  width: 80px;
  padding: 10px 8px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  text-align: center;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formBirth::placeholder {
  color: #999;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formBirth:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* 生年月日 — select 版（後方互換） */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(select.birth) {
  flex: 0 0 auto;
  min-width: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts select.birth {
  width: auto;
  min-width: 80px;
  padding: 10px 28px 10px 10px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  height: 44px;
  box-sizing: border-box;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L2 4h8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 6px center;
  cursor: pointer;
  transition: all 0.2s ease;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts select.birth:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── 性別 radio — 横並び ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input[type="radio"]) {
  flex: 0 1 auto;
  padding-top: 4px;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap .wpcf7-radio {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  gap: 24px;
  align-items: center;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap .wpcf7-list-item {
  display: inline-flex;
  align-items: center;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 15px;
  font-weight: 500;
  color: #333;
  cursor: pointer;
  flex: none;
  min-width: auto;
  max-width: none;
  padding-top: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input[type="radio"] {
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  accent-color: #00B4E3;
  flex-shrink: 0;
}

/* ── 電話番号 ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input.formTel),
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input[type="tel"]) {
  flex: 0 1 120px;
  min-width: 80px;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formTel,
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input[type="tel"] {
  width: 100%;
  padding: 10px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  text-align: center;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formTel::placeholder,
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input[type="tel"]::placeholder {
  color: #999;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formTel:focus,
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input[type="tel"]:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── メールアドレス ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts p {
  display: block;
  width: 100%;
  margin: 0 0 4px 0;
  padding: 0;
  font-size: 13px;
  color: #666;
  font-weight: 500;
  flex: 0 0 100%;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(.formLarge) {
  flex: 0 0 100%;
  min-width: 100%;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .formLarge,
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formLarge {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  line-height: 1.5;
  height: 44px;
  box-sizing: border-box;
  transition: all 0.2s ease;
  display: block;
  margin: 0 0 10px 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .formLarge:last-of-type,
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formLarge:last-of-type {
  margin-bottom: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .formLarge::placeholder {
  color: #999;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .formLarge:focus,
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formLarge:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── Select（職業など） ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm select:not(.birth) {
  width: auto;
  min-width: 200px;
  padding: 10px 36px 10px 14px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  height: 44px;
  box-sizing: border-box;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L2 4h8z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  cursor: pointer;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm select:not(.birth):focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── Textarea ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #333;
  border-radius: 4px;
  font-size: 15px;
  background: #fff;
  color: #333;
  resize: vertical;
  min-height: 140px;
  font-family: inherit;
  line-height: 1.6;
  box-sizing: border-box;
  transition: all 0.2s ease;
  display: block;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm textarea::placeholder {
  color: #999;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm textarea:focus {
  outline: none;
  border-color: #00B4E3;
  box-shadow: 0 0 0 2px rgba(0, 180, 227, 0.15);
}

/* ── Checkbox（何を見て応募されましたか）— 縦1列 ── */
.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input[type="checkbox"]) {
  flex: 1 1 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-start;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap .wpcf7-list-item {
  display: flex;
  align-items: center;
  margin: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap .wpcf7-list-item label {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  font-weight: 400;
  color: #333;
  cursor: pointer;
  flex: none;
  min-width: auto;
  max-width: none;
  padding-top: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input[type="checkbox"] {
  width: 18px;
  height: 18px;
  margin: 0;
  cursor: pointer;
  accent-color: #00B4E3;
  flex-shrink: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .wai-sankaku-down {
  display: none;
}

.recruit-entry-form-wrapper .wpcf7-form .entryForm .wpcf7-custom-item-error {
  display: block;
  font-size: 12px;
  color: #ef4444;
  margin-top: 6px;
  width: 100%;
}

/* ── entryPoint（個人情報リンク） ── */
.recruit-entry-form-wrapper .wpcf7-form > p.entryPoint {
  display: block;
  font-size: 14px;
  color: #333;
  text-align: center;
  margin: 28px 0 16px 0;
  line-height: 1.7;
}

.recruit-entry-form-wrapper .wpcf7-form > p.entryPoint a {
  color: #00B4E3;
  text-decoration: underline;
}

/* ── btnSubmit — 枠線ボタン ── */
.recruit-entry-form-wrapper .wpcf7-form .btnSubmit {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
  margin: 24px 0 0 0;
  padding: 0;
  font-size: 0;
  line-height: 0;
}

.recruit-entry-form-wrapper .wpcf7-form .btnSubmit input[type="submit"],
.recruit-entry-form-wrapper .wpcf7-form .btnSubmit input[type="button"],
.recruit-entry-form-wrapper .wpcf7-form .btnSubmit button {
  background: #fff;
  color: #333;
  border: 2px solid #333;
  padding: 14px 50px;
  border-radius: 4px;
  font-size: 16px;
  line-height: 1;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s ease;
  min-width: 200px;
  height: 50px;
  box-sizing: border-box;
}

.recruit-entry-form-wrapper .wpcf7-form .btnSubmit input[type="submit"]:hover,
.recruit-entry-form-wrapper .wpcf7-form .btnSubmit button:hover {
  background: #333;
  color: #fff;
}

.recruit-entry-form-wrapper .wpcf7-form .btnSubmit input[type="submit"]:focus,
.recruit-entry-form-wrapper .wpcf7-form .btnSubmit button:focus {
  outline: none;
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.1);
}

.recruit-entry-form-wrapper .wpcf7-form .btnSubmit input[type="submit"]:active,
.recruit-entry-form-wrapper .wpcf7-form .btnSubmit button:active {
  background: #222;
  color: #fff;
}

/* ── Error ── */
.recruit-entry-form-wrapper .wpcf7-form .wpcf7-form-control-wrap .wpcf7-not-valid-tip {
  font-size: 12px;
  color: #ef4444;
  margin-top: 6px;
  display: block;
  line-height: 1.4;
  font-weight: 500;
}

.recruit-entry-form-wrapper .wpcf7-form .wpcf7-not-valid {
  border-color: #ef4444 !important;
}

.recruit-entry-form-wrapper .wpcf7-form .wpcf7-not-valid:focus {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 2px rgba(239, 68, 68, 0.15) !important;
}

.recruit-entry-form-wrapper .wpcf7-form .wpcf7-response-output {
  margin-top: 24px;
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 14px;
  line-height: 1.5;
  border: 1px solid;
  font-weight: 500;
}

.recruit-entry-form-wrapper .wpcf7-mail-sent-ok {
  background: #d4edda;
  color: #155724;
  border-color: #c3e6cb;
}

.recruit-entry-form-wrapper .wpcf7-mail-sent-ng {
  background: #f8d7da;
  color: #721c24;
  border-color: #f5c6cb;
}

.recruit-entry-form-wrapper .wpcf7-validation-errors {
  background: #fff3cd;
  color: #856404;
  border-color: #ffeaa7;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .recruit-entry-form-wrapper {
    padding: 24px 0px;
  }

  .recruit-entry-form-wrapper .wpcf7-form .entryForm dl {
    flex-direction: column;
    gap: 8px;
    padding: 16px;
  }

  .recruit-entry-form-wrapper .wpcf7-form .entryForm dt {
    flex: 0 0 auto;
    min-width: auto;
    max-width: none;
    padding-top: 0;
  }

  .recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts br.sp {
    display: block;
    flex-basis: 100%;
    height: 0;
  }

  .recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input.formTel),
  .recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input[type="tel"]) {
    flex: 1 1 0;
    min-width: 50px;
  }

  .recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts .wpcf7-form-control-wrap:has(input.formBirth) {
    flex: 0 0 auto;
    min-width: 0;
  }

  .recruit-entry-form-wrapper .wpcf7-form .entryForm .formParts input.formBirth {
    width: 60px;
    min-width: 50px;
  }

  .recruit-entry-form-wrapper .wpcf7-form .btnSubmit input[type="submit"],
  .recruit-entry-form-wrapper .wpcf7-form .btnSubmit button {
    width: 100%;
    min-width: 100%;
  }
}

/* Contact Form 7 スタイル調整 */
.wpcf7-form { max-width: 100%; }
.wpcf7-form p { margin-bottom: 24px; display: flex; align-items: flex-start; gap: 24px; }
.wpcf7-form label { display: block; font-size: 16px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); flex: 0 0 180px; padding-top: 12px; }
.wpcf7-form label .wpcf7-required { color: #e74c3c; }
.wpcf7-form label .label-note { display: block; font-size: 14px; font-weight: 400; color: #666; margin-top: 4px; letter-spacing: var(--ls-tight); }
.wpcf7-form .wpcf7-form-control-wrap { display: block; flex: 1; min-width: 0; margin: 0; padding: 0; }
.wpcf7-form p > label { margin-bottom: 0; }
.wpcf7-form .wpcf7-form-control-wrap .wpcf7-not-valid-tip { font-size: 14px; color: #e74c3c; margin-top: 4px; }
.wpcf7-form input[type="text"],
.wpcf7-form input[type="email"],
.wpcf7-form input[type="tel"],
.wpcf7-form input[type="url"],
.wpcf7-form textarea,
.wpcf7-form select { width: 100%; padding: 12px 16px; border: 1px solid #ddd; border-radius: 4px; font-size: 16px; font-family: inherit; letter-spacing: var(--ls-tight); box-sizing: border-box; background: #fff; }
.wpcf7-form input[type="text"]:focus,
.wpcf7-form input[type="email"]:focus,
.wpcf7-form input[type="tel"]:focus,
.wpcf7-form input[type="url"]:focus,
.wpcf7-form textarea:focus,
.wpcf7-form select:focus { outline: none; border-color: #00B4E3; }
.wpcf7-form textarea { resize: vertical; min-height: 200px; }
.wpcf7-form select { appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 9L1 4h10z'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 16px center; padding-right: 40px; }
.wpcf7-form .wpcf7-submit { background: #00B4E3; color: #fff; border: none; padding: 16px 48px; border-radius: 8px; font-size: 18px; font-weight: 700; letter-spacing: var(--ls-wide); cursor: pointer; transition: background 0.2s, transform 0.2s; display: block; margin: 32px auto 0; }
.wpcf7-form .wpcf7-submit:hover { background: #0099cc; transform: translateY(-2px); }
.wpcf7-form .wpcf7-submit:active { transform: translateY(0); }
.contact-form-wrapper .wpcf7-form .wpcf7-submit,
.contact-form-wrapper .wpcf7-form .wpcf7-submit:hover,
.contact-form-wrapper .wpcf7-form .wpcf7-submit:active {
  transform: none !important;
}
.recruit-entry-form-wrapper .wpcf7-form .wpcf7-submit,
.recruit-entry-form-wrapper .wpcf7-form .wpcf7-submit:hover,
.recruit-entry-form-wrapper .wpcf7-form .wpcf7-submit:active {
  transform: none !important;
}
.wpcf7-form .wpcf7-response-output { margin-top: 24px; padding: 16px; border-radius: 4px; }
.wpcf7-mail-sent-ok { background: #d4edda; color: #155724; border: 1px solid #c3e6cb; }
.wpcf7-mail-sent-ng { background: #f8d7da; color: #721c24; border: 1px solid #f5c6cb; }
.wpcf7-validation-errors { background: #fff3cd; color: #856404; border: 1px solid #ffeaa7; }
.wpcf7-spam { background: #fff3cd; color: #856404; border: 1px solid #ffeaa7; }

/* 電話番号フィールドの3分割スタイル */
.wpcf7-form .phone-group { display: flex; gap: 8px; align-items: center; }
.wpcf7-form .phone-group input[type="tel"] { flex: 1; }
.wpcf7-form .phone-group .phone-separator { flex: 0 0 auto; color: #666; font-size: 16px; }

/* メールアドレスフィールドの注意書き */
.wpcf7-form .email-note { font-size: 14px; color: #666; margin-top: 4px; letter-spacing: var(--ls-tight); text-align: left; }
.wpcf7-form .wpcf7-form-control-wrap .email-note { 
    margin-top: 8px !important; 
    margin-left: 0 !important; 
    margin-right: 0 !important; 
    margin-bottom: 0 !important; 
    padding: 0 !important; 
    display: block !important;
    text-align: left !important;
}

/* プライバシーポリシーセクションは横並びにしない */
.wpcf7-form .contact-privacy-section { display: block; }

/* プライバシーポリシーセクション */
.contact-privacy-section { margin-top: 40px; padding: 24px; background: #f9f9f9; border-radius: 8px; }
.contact-privacy-attention { font-size: 14px; font-weight: 700; color: #222; margin-bottom: 16px; letter-spacing: var(--ls-wide); }
.contact-privacy-title { font-size: 14px; font-weight: 700; color: #222; margin-bottom: 0; letter-spacing: var(--ls-wide); }
.contact-privacy-text { font-size: 14px; color: #666; line-height: 1.8; letter-spacing: var(--ls-tight); margin: 0; }
.contact-privacy-section p { margin: 0; }
.contact-privacy-text + p { margin: 0 !important; }
.contact-privacy-list { font-size: 14px; color: #666; line-height: 1.8; letter-spacing: var(--ls-tight); margin: 12px 0; list-style: none; padding-left: 0; }
.contact-privacy-list li { margin-bottom: 0; position: relative; padding-left: 20px; }
.contact-privacy-list li::before { content: '・'; position: absolute; left: 0; }

/* Privacy Policy Page */
.privacy-page-header { margin-bottom: 120px; padding-bottom: 0; padding-left: 20px; padding-right: 20px; border-bottom: 1px solid #00B4E3; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
.privacy-page-title { font-size: 40px; font-weight: 700; margin: 0; color: #222; letter-spacing: var(--ls-wide); }
.privacy-page-sub { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.privacy-page-separator { display: none; }
.privacy-page-content { width: 880px; margin-left: auto; margin-right: auto; margin-top: 60px; margin-bottom: 100px; }
.privacy-content { font-size: 16px; color: #222; line-height: 1.8; letter-spacing: var(--ls-tight); }
.privacy-content p { margin-bottom: 24px; }
.privacy-content p:empty { display: none; }
.privacy-content > *:first-child { margin-top: 0; }
.privacy-content > *:last-child { margin-bottom: 0; }
.privacy-content h2 { font-size: 24px; font-weight: 700; color: #222; margin: 40px 0 16px; letter-spacing: var(--ls-wide); }
.privacy-content h2:first-of-type { margin-top: 0; }
.privacy-content h3 { font-size: 18px; font-weight: 700; color: #222; margin: 24px 0 12px; letter-spacing: var(--ls-wide); }
.privacy-content ul { margin: 16px 0 24px 20px; padding: 0; list-style: none; }
.privacy-content ul li { margin-bottom: 12px; position: relative; padding-left: 20px; }
.privacy-content ul li::before { content: '・'; position: absolute; left: 0; }
.privacy-content a { color: #00B4E3; text-decoration: underline; }
.privacy-content a:hover { opacity: 0.8; }

/* Recruit Front Page */
body.recruit main { padding-top: 0; }

/* Recruit Front Page (SP: minimal base only. PC styles in @media (min-width: 1025px)) */
.recruit-hero { position: relative; width: 100%; overflow: hidden; }
.recruit-hero-image img { width: 100%; height: auto; display: block; }
.recruit-about { background: #ccf0f9; }

/* Recruit TOP About: 画像レイアウト共通 */
.recruit-about-picture {
  display: block;
}
.recruit-about-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
}
@media (max-width: 768px) {
  .recruit-about-img {
    max-width: 85%;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  .recruit-about-img {
    max-width: 70%;
  }
}
.recruit-know { background: #ccf0f9; }
.recruit-interview { background: #fff; }
.recruit-join { background: #fff; padding-top: 200px; }

@media (max-width: 1024px) {
  /* Recruit TOP (SP) */
  body.recruit .recruit-about .container,
  body.recruit .recruit-know .container,
  body.recruit .recruit-interview > .container,
  body.recruit .recruit-join .container {
    margin-left: 20px;
    margin-right: 20px;
    padding: 0;
    max-width: 100%;
    box-sizing: border-box;
  }
  body.recruit .recruit-about .container {
    margin-left: auto;
    margin-right: auto;
    padding: 0 20px;
    max-width: 800px;
  }
  body.recruit .recruit-know .container {
    margin-left: 30px;
    margin-right: 30px;
  }
  body.recruit .recruit-hero {
    margin-top: 0;
    height: 700px;
    position: relative;
    z-index: 20;
  }
  body.recruit .recruit-hero-container {
    position: relative;
    height: 100%;
  }
  body.recruit .recruit-hero-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
  }
  body.recruit .recruit-hero-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: top center;
    display: block;
  }
  body.recruit .recruit-hero-text {
    position: absolute;
    left: 0;
    right: auto;
    bottom: 0;
    transform: none;
    width: 80%;
    max-width: 660px;
    margin-right: 0;
    height: auto;
    padding: 0;
    z-index: 30;
    display: flex;
    align-items: flex-end;
    justify-content: flex-start;
    box-sizing: border-box;
  }
  body.recruit .recruit-hero-text-img {
    width: 100%;
    height: auto;
    object-fit: contain;
    object-position: left bottom;
    display: block;
  }

  body.recruit .recruit-about {
    padding: 56px 0 100px;
    position: relative;
    z-index: 0;
  }
  body.recruit .recruit-about-text2 p {
    font-size: 22px;
    font-weight: 600;
    color: #534741;
    letter-spacing: var(--ls-wide);
    margin: 0;
  }
  body.recruit .recruit-about-right {
    display: flex;
    flex-direction: column;
    gap: 30px;
  }
  body.recruit .recruit-about-image1 {
    width: 270px;
    height: 210px;
    flex: none;
    align-self: flex-end;
    overflow: hidden;
    border-radius: 12px;
  }
  body.recruit .recruit-about-image2 {
    width: 210px;
    height: 270px;
    flex: none;
    align-self: flex-start;
    overflow: hidden;
    border-radius: 12px;
  }
  body.recruit .recruit-about-image1 img,
  body.recruit .recruit-about-image2 img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
  }

  body.recruit .recruit-know {
    padding: 56px 0 100px;
  }
  body.recruit .recruit-know-header {
    margin-bottom: 60px;
    text-align: center;
  }
  body.recruit .recruit-know-title {
    font-size: 30px;
    font-weight: 700;
    color: #222;
    letter-spacing: var(--ls-wide);
    margin: 0 0 4px;
  }
  body.recruit .recruit-know-sub {
    font-size: 20px;
    font-weight: 700;
    color: #00b4e3;
    letter-spacing: var(--ls-wide);
  }
  body.recruit .recruit-know-cards {
    display: flex;
    flex-direction: column;
    gap: 30px;
    justify-content: flex-start;
  }
  body.recruit .recruit-know-card {
    width: 100%;
    height: 160px;
    background: #fff;
    border-radius: 12px;
    text-decoration: none;
    color: #222;
    position: relative;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  body.recruit .recruit-know-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
      linear-gradient(to right, transparent 10px, rgba(0, 180, 227, 0.3) 11px),
      linear-gradient(to bottom, transparent 10px, rgba(0, 180, 227, 0.3) 11px);
    background-size: 11px 11px;
    pointer-events: none;
    z-index: 0;
  }
  body.recruit .recruit-know-card-content {
    position: relative;
    z-index: 1;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    align-content: center;
  }
  body.recruit .recruit-know-card-label {
    font-size: 18px;
    font-weight: 700;
    color: #00B4E3;
    letter-spacing: var(--ls-wide);
    margin: 0;
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 1;
    flex: 0 0 100%;
    width: 100%;
  }
  body.recruit .recruit-know-card-title {
    font-size: 46px;
    font-weight: 700;
    color: #00B4E3;
    letter-spacing: var(--ls-wide);
    margin: 0;
    text-align: center;
    line-height: 1.1;
    flex: 0 0 auto;
  }
  body.recruit .recruit-know-card-subtitle {
    font-size: 24px;
    font-weight: 700;
    color: #222;
    letter-spacing: var(--ls-wide);
    margin: 0 0 0 4px;
    text-align: center;
    flex: 0 0 auto;
  }
  body.recruit .recruit-know-card-link {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #00B4E3;
    text-decoration: none;
    font-weight: 700;
    font-size: 22px;
    bottom: 14px;
    z-index: 1;
    margin: 0;
  }
  body.recruit .recruit-know-card-icon {
    width: 18px;
    height: 18px;
    border: 1px solid #00B4E3;
    border-radius: 50%;
    background: transparent;
    display: inline-block;
    position: relative;
    flex-shrink: 0;
  }
  body.recruit .recruit-know-card-icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-left: 5px solid #00B4E3;
    border-top: 3.5px solid transparent;
    border-bottom: 3.5px solid transparent;
    transform: translate(-50%, -50%);
  }

  body.recruit .recruit-interview {
    padding: 56px 0 0;
  }
  body.recruit .recruit-interview-header {
    padding: 0;
    text-align: right;
    margin-right: -20px;
    line-height: 0;
  }
  body.recruit .recruit-interview-header picture {
    display: block;
  }
  body.recruit .recruit-interview-header-img {
    display: block;
    max-width: 340px;
    margin-left: auto;
    margin-right: 0;
  }
  body.recruit .recruit-interview-cards-wrapper {
    width: 100%;
    margin-top: 0;
    display: flex;
    justify-content: center;
  }
  body.recruit .recruit-interview-cards-wrapper .container {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  body.recruit .recruit-interview-card {
    flex: 0 0 auto;
    width: 100%;
    max-width: 520px; /* 画面幅に応じて拡大縮小（上限のみ固定） */
    margin-left: auto;
    margin-right: auto;
    min-width: 0;
    min-height: 460px;
    background: transparent;
    border-radius: 12px;
    position: relative;
    overflow: visible;
    transition: transform 0.2s;
  }
  body.recruit a.recruit-interview-card {
    color: inherit;
    text-decoration: none;
  }
  body.recruit .recruit-interview-card-image {
    width: 100%;
    height: 100%;
    overflow: hidden;
    position: relative;
    z-index: 1;
    border-radius: 12px 12px 0 12px;
    background: transparent;
    isolation: isolate;
  }
  body.recruit .recruit-interview-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
  }
  body.recruit .recruit-join {
    padding: 100px 0;
  }
  body.recruit .recruit-join-content {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 20px;
  }
  body.recruit .recruit-join-title-wrapper {
    width: 100%;
  }
  body.recruit .recruit-join-title-wrapper picture {
    display: block;
    width: 100%;
  }
  body.recruit .recruit-join-title {
    display: block;
    width: 100%;
    max-width: none;
  }
  body.recruit .recruit-join-buttons {
    width: calc(100% - 20px);
    margin-left: 10px;
    margin-right: 10px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    gap: 12px;
  }
  body.recruit .recruit-join-button {
    width: 100%;
    height: 72px;
    border-radius: 12px;
    padding: 0 20px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    background: #ccf0f9;
    text-decoration: none;
    color: #00b4e3;
    font-weight: 700;
    font-size: 18px;
    letter-spacing: var(--ls-wide);
    box-sizing: border-box;
  }
  body.recruit .recruit-join-button-icon {
    width: 18px;
    height: 18px;
    border: 1px solid #00B4E3;
    border-radius: 50%;
    display: inline-block;
    position: relative;
    flex-shrink: 0;
  }
  body.recruit .recruit-join-button-icon::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 0;
    height: 0;
    border-left: 5px solid #00B4E3;
    border-top: 3.5px solid transparent;
    border-bottom: 3.5px solid transparent;
    transform: translate(-50%, -50%);
  }
}

/* Recruit Page Styles */
.recruit-page-hero { padding: 0 0 80px 0; position: relative; overflow: visible; }
.recruit-page-hero::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(to right, transparent 10px, rgba(0, 180, 227, 0.3) 11px), linear-gradient(to bottom, transparent 10px, rgba(0, 180, 227, 0.3) 11px); background-size: 11px 11px; z-index: 0; pointer-events: none; }
.recruit-page-hero::after { content: ''; position: absolute; top: -200px; left: -4px; width: calc(100% + 8px); height: 550px; background: #ccf0f9; clip-path: polygon(-2% 0, 102% 0, 102% 60%, -2% 100%); z-index: 1; pointer-events: none; }
body.recruit main > .container .breadcrumb,
body.page-template-page-recruit main > .container .breadcrumb,
body.post-type-archive-interview main > .container .breadcrumb { position: relative; z-index: 2; margin-top: 130px; }
.recruit-page-hero-content { display: flex; flex-direction: row; gap: 40px; align-items: flex-start; position: relative; z-index: 2; }
.recruit-page-hero-top { flex: 1; min-width: 0; max-height: 440px; display: flex; flex-direction: column; gap: 60px; align-items: flex-start; position: relative; z-index: 1; overflow: hidden; }
.recruit-job-page .recruit-page-hero-top { flex-direction: row; gap: 390px; max-height: none; overflow: visible; }
.recruit-page-hero-title-wrapper { display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; position: relative; }
.recruit-page-hero-title { font-size: 48px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0; }
.recruit-page-hero-sub { font-size: 18px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); margin: 0; }
.recruit-page-hero-description { flex: 1; min-width: 0; font-size: 16px; font-weight: 700; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); min-height: 0; }
.recruit-page-hero-description p { margin: 0; }
.recruit-page-hero-image { width: 600px; height: 440px; flex: 0 0 auto; position: relative; z-index: 1; overflow: hidden; border-radius: 12px; }
.recruit-page-hero-image img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: 12px; }
@media (min-width: 1025px) {
  .recruit-page-hero-image {
    margin-top: -80px;
  }
}

.recruit-page-content { padding: 0; position: relative; z-index: 2; }
.recruit-page-content-works { padding-bottom: 200px; }
.recruit-page-content-support { padding-bottom: 200px; }
.recruit-page-content::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(to right, transparent 10px, rgba(0, 180, 227, 0.3) 11px), linear-gradient(to bottom, transparent 10px, rgba(0, 180, 227, 0.3) 11px); background-size: 11px 11px; pointer-events: none; }
.recruit-page-content-inner { display: flex; flex-direction: row; gap: 140px; align-items: flex-start; }
.recruit-page-content-left { flex: 0 0 auto; }
.recruit-page-content-right { flex: 1; min-width: 0; }
.recruit-page-section { display: flex; gap: 80px; align-items: flex-start; margin-bottom: 80px; }
.recruit-page-section:last-child { margin-bottom: 0; }
.recruit-page-section:last-child .recruit-page-section-content { padding-bottom: 0; border-bottom: none; }
.recruit-page-section-content { flex: 1; position: relative; z-index: 1; padding-bottom: 80px; border-bottom: 1px solid #00B4E3; min-height: 420px; }
.recruit-page-section-heading { font-size: 20px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); margin: 0; }
.recruit-page-section-label-ja { display: inline-block; font-size: 18px; font-weight: 700; color: #ffffff; letter-spacing: var(--ls-wide); margin-bottom: 24px; padding: 8px 24px; background: #00B4E3; border-radius: 0 calc(Infinity * 1px) calc(Infinity * 1px) 0; }
.recruit-page-section-title { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0 0 24px; line-height: 1.4; }
.recruit-page-section-text { font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); }
.recruit-page-section-text p { margin: 0; }
.recruit-page-section-image { width: 420px; height: 420px; flex: 0 0 auto; position: relative; z-index: 1; overflow: hidden; border-radius: 12px; }
.recruit-page-section-image img { width: 100%; height: 100%; display: block; border-radius: 12px; object-fit: cover; }

.recruit-page-seeks { padding: 200px 0; position: relative; }
.recruit-page-seeks::before { content: ''; position: absolute; inset: 0; background-image: linear-gradient(to right, transparent 10px, rgba(0, 180, 227, 0.3) 11px), linear-gradient(to bottom, transparent 10px, rgba(0, 180, 227, 0.3) 11px); background-size: 11px 11px; pointer-events: none; z-index: 0; }
.recruit-page-seeks-inner { margin: 0 140px; position: relative; z-index: 1; }
.recruit-page-seeks-img { display: block; width: 100%; height: auto; max-width: 100%; vertical-align: bottom; }

/* Recruit Works Page Styles */
.recruit-works-section { margin-bottom: 80px; background: #fff; padding: 40px; padding-top: 100px; padding-bottom: 120px; border-radius: 12px; position: relative; z-index: 1; border: 1px solid #ddd; }
.recruit-works-section:last-child { margin-bottom: 0; }
.recruit-works-section-header { margin-bottom: 60px; }
.recruit-works-section-title { font-size: 30px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0; }
.recruit-works-section-title-bullet { color: #00B4E3; }
.recruit-works-section-business .recruit-works-section-title-bullet { display: inline-block; width: 8px; height: 8px; background: #00B4E3; border-radius: 50%; margin-right: 10px; vertical-align: middle; color: transparent; }
.recruit-works-section-business { background: none; border: none; padding: 120px 0 200px; margin-top: 0; margin-bottom: 0; }
.recruit-works-business-grid { display: grid; grid-template-columns: repeat(3, 1fr); row-gap: 80px; column-gap: 55px; margin-bottom: 0; }
.recruit-works-business-card { background: #fff; padding: 24px; border-radius: 12px; box-shadow: 0 1px 3px rgba(0,0,0,0.06); border: 1px solid #eee; display: flex; flex-direction: column; align-items: flex-start; text-align: left; }
.recruit-works-business-card-title { font-size: 20px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); margin: 0 0 12px; padding-bottom: 8px; border-bottom: 2px solid #00B4E3; align-self: stretch; text-align: center; }
.recruit-works-business-card-text { font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); margin: 0; text-align: left; white-space: pre-line; }
.recruit-works-career-intro { font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); margin-bottom: 0; }
.recruit-works-career-chart { display: block; margin-bottom: 120px; height: auto; border-bottom: none; }
.recruit-works-career-chart-image { display: block; width: 85%; margin-left: auto; margin-right: auto; }
.recruit-works-career-chart-image picture { display: block; width: 100%; }
.recruit-works-career-chart-image img { width: 100%; height: auto; display: block; vertical-align: bottom; }
.recruit-works-career-chart-bars { display: none !important; }
.recruit-works-career-bar { background: #00B4E3; position: relative; display: flex; flex-direction: column; justify-content: center; width: 100%; min-width: 0; border-top-left-radius: 12px; border-top-right-radius: 12px; }
.recruit-works-career-bar-1 { height: 20%; background: #ccf0f9; }
.recruit-works-career-bar-2 { height: 30%; background: #99e1f4; }
.recruit-works-career-bar-3 { height: 45%; background: #66d2ee; }
.recruit-works-career-bar-4 { height: 70%; background: #33c3e9; }
.recruit-works-career-bar-5 { height: 100%; background: #00b4e3; }
.recruit-works-career-bar-period { font-size: 20px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin-bottom: 8px; text-align: center; position: absolute; top: -36px; left: 0; right: 0; }
.recruit-works-career-bar-1 .recruit-works-career-bar-period { display: none; }
.recruit-works-career-bar-2 .recruit-works-career-bar-period { color: #99e1f4; }
.recruit-works-career-bar-3 .recruit-works-career-bar-period { color: #66d2ee; }
.recruit-works-career-bar-4 .recruit-works-career-bar-period { color: #33c3e9; }
.recruit-works-career-bar-5 .recruit-works-career-bar-period { color: #00b4e3; }
.recruit-works-career-bar-content { padding: 16px 12px; display: flex; flex-direction: column; gap: 4px; justify-content: center; align-items: flex-start; width: fit-content; margin: 0 auto; }
.recruit-works-career-bar-label { font-size: 20px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); line-height: 1.4; text-align: left; }
.recruit-works-career-details { display: flex; flex-direction: column; gap: 40px; }
.recruit-works-career-detail-item { margin-bottom: 0; padding-bottom: 40px; border-bottom: 1px solid #00B4E3; }
.recruit-works-career-detail-item:last-child { padding-bottom: 0; border-bottom: none; }
.recruit-works-career-detail-title { display: inline-block; font-size: 20px; font-weight: 700; color: #ffffff; letter-spacing: var(--ls-wide); margin: 0 0 24px; padding: 8px 24px; background: #00B4E3; border-radius: 0 calc(Infinity * 1px) calc(Infinity * 1px) 0; }
.recruit-works-career-detail-text { display: flex; gap: 24px; margin: 0; }
.recruit-works-career-detail-subtitle { flex: 1; display: flex; align-items: center; justify-content: flex-start; margin-left: 70px; font-size: 20px; font-weight: 700; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); text-align: left; }
.recruit-works-career-detail-description { flex: 1; font-size: 16px; font-weight: 400; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); }

/* Recruit Support Page Styles */
.recruit-support-section { margin-bottom: 100px; padding: 0; position: relative; z-index: 1; }
.recruit-support-section:last-child { margin-bottom: 0; }
.recruit-support-section-header { margin-bottom: 120px; }
.recruit-support-section-title { font-size: 30px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0; }
.recruit-support-section-title-bullet { color: #00B4E3; }
.recruit-support-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.recruit-support-grid picture { display: block; width: 100%; grid-column: 1 / -1; }
.recruit-support-grid-image { width: 100%; height: auto; display: block; grid-column: 1 / -1; }
@media (max-width: 1024px) {
    .recruit-support-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }
}
@media (max-width: 1024px) {
    .recruit-works-business-grid { grid-template-columns: 1fr; }
    .recruit-works-section { margin-top: 100px; padding: 40px 20px; }
    .recruit-works-section-business { padding: 0; margin-top: 0; }
    .recruit-works-section-header .recruit-works-section-title { font-size: 24px; }
    .recruit-works-career-chart { display: block; height: auto; margin-top: 40px; margin-bottom: 60px; border-bottom: none; }
    .recruit-works-career-chart-image { display: block; width: 85%; margin-left: auto; margin-right: auto; }
    .recruit-works-career-chart-bars { display: none !important; }
    .recruit-works-career-detail-title { font-size: 18px; }
    .recruit-works-career-detail-subtitle { font-size: 20px; margin-left: 0; }
    .recruit-works-career-detail-description { font-size: 15px; }
    .recruit-works-career-detail-text { flex-direction: column; gap: 40px; }
    .recruit-support-grid { grid-template-columns: 1fr; gap: 24px; }
    .recruit-support-grid picture { display: block; width: 100%; grid-column: 1 / -1; }
    .recruit-support-grid picture img { width: 100%; height: auto; display: block; }
    .recruit-support-section-header { margin-bottom: 40px; }
    .recruit-support-section-title { font-size: 24px; }
}

@media (min-width: 769px) and (max-width: 1024px) {
    .recruit-works-business-grid { grid-template-columns: repeat(2, 1fr); column-gap: 24px; row-gap: 40px; }
    .recruit-works-section { margin-top: 100px; padding: 40px 20px; }
    .recruit-works-section-business { padding: 0; margin-top: 0; }
    .recruit-works-section-header .recruit-works-section-title { font-size: 24px; }
    .recruit-works-career-chart { display: block; height: auto; margin-top: 40px; margin-bottom: 60px; border-bottom: none; }
    .recruit-works-career-chart-image { display: block; width: 85%; margin-left: auto; margin-right: auto; }
    .recruit-works-career-chart-bars { display: none !important; }
    .recruit-works-career-detail-title { font-size: 18px; }
    .recruit-works-career-detail-subtitle { font-size: 20px; margin-left: 0; }
    .recruit-works-career-detail-description { font-size: 15px; }
    .recruit-works-career-detail-text { flex-direction: column; gap: 40px; }
    .recruit-support-grid { grid-template-columns: 1fr; gap: 24px; }
    .recruit-support-grid picture { display: block; width: 100%; grid-column: 1 / -1; }
    .recruit-support-grid picture img { width: 100%; height: auto; display: block; }
    .recruit-support-section-header { margin-bottom: 40px; }
    .recruit-support-section-title { font-size: 24px; }
}
.recruit-support-item { background: #fff; padding: 40px 32px; border-radius: 16px; display: flex; flex-direction: column; align-items: center; border: 1px solid #e8e8e8; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06); transition: all 0.3s ease; }
.recruit-support-item:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0, 180, 227, 0.12); border-color: #00B4E3; }
.recruit-support-item-icon { width: 120px; height: 120px; display: flex; align-items: center; justify-content: center; margin-bottom: 24px; transition: all 0.3s ease; }
.recruit-support-item:hover .recruit-support-item-icon { transform: scale(1.05); }
.recruit-support-item-icon i { font-size: 64px; color: #00B4E3; transition: all 0.3s ease; }
.recruit-support-item:hover .recruit-support-item-icon i { color: #0099c7; }
.recruit-support-item-icon img { width: auto; height: auto; max-width: 64px; max-height: 64px; object-fit: contain; display: block; transition: all 0.3s ease; }
.recruit-support-item-title { font-size: 20px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0 0 12px; text-align: center; line-height: 1.4; }
.recruit-support-item-text { font-size: 15px; line-height: 1.8; color: #666; letter-spacing: var(--ls-tight); margin: 0; text-align: center; }

/* Recruit Interview Page Styles */
.recruit-interview-hero { padding: 40px 0 80px; position: relative; }
.recruit-interview-hero-content { position: relative; z-index: 1; display: flex; gap: 40px; align-items: flex-start; }
.recruit-interview-hero-left { flex: 1; display: flex; flex-direction: column; gap: 32px; }
.recruit-interview-tag { display: inline-block; margin-bottom: 0; }
.recruit-interview-tag img.recruit-interview-tag-flag { display: block !important; height: auto; width: 150px; max-width: 100%; object-fit: contain; visibility: visible !important; opacity: 1 !important; position: relative !important; z-index: 1 !important; }
.recruit-interview-tag img { display: block !important; }
.recruit-interview-tag .recruit-interview-tag-en,
.recruit-interview-tag .recruit-interview-tag-ja { display: none !important; }
.recruit-interview-hero-text { flex: 1; }
.recruit-interview-title { font-size: 34px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0 0 24px; line-height: 1.4; }
.recruit-interview-name { display: flex; flex-direction: column; align-items: flex-start; gap: 0; }
.recruit-interview-name-ja { font-size: 30px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin-bottom: 16px; text-align: left; }
.recruit-interview-name-meta { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; font-size: 15px; }
.recruit-interview-year { font-size: inherit; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.recruit-interview-name-en { font-size: inherit; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); text-transform: uppercase; }
.recruit-interview-summary { margin-top: 16px; max-width: 500px; font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); text-align: left; }
.recruit-interview-hero-image { width: 640px; height: 480px; flex: 0 0 auto; position: relative; align-self: flex-start; overflow: hidden; border-radius: 12px; }
.recruit-interview-hero-image img { width: 100%; height: 100%; display: block; border-radius: 12px; position: relative; z-index: 1; object-fit: cover; }

.recruit-interview-questions { padding: 80px 0; position: relative; overflow: hidden; }
.recruit-interview-questions-wrapper { display: flex; gap: 60px; align-items: flex-start; position: relative; }
.recruit-interview-questions-nav { flex-shrink: 0; width: 280px; position: sticky; top: 100px; align-self: flex-start; }
.recruit-interview-questions-nav.is-fixed { position: fixed; top: 100px; z-index: 50; }
.recruit-interview-questions-nav.is-bottom { position: fixed; top: auto; z-index: 50; }
.recruit-interview-questions-wrapper.has-nav-out-of-flow { padding-left: 340px; }
.recruit-interview-questions-nav-list { list-style: none; padding: 0; margin: 0; }
.recruit-interview-questions-nav-list li { margin-bottom: 16px; }
.recruit-interview-questions-nav-list li:last-child { margin-bottom: 0; }
.recruit-interview-questions-nav-item { display: block; padding: 12px 16px; color: #999; text-decoration: none; font-size: 14px; font-weight: 400; letter-spacing: var(--ls-tight); line-height: 1.6; border-radius: 8px; transition: all 0.3s ease; }
.recruit-interview-questions-nav-item.active { font-size: 16px; font-weight: 700; color: #00B4E3; background: none; border: none; box-shadow: none; }
.recruit-interview-questions-content { flex: 1; }
.recruit-interview-question { position: relative; z-index: 1; margin-bottom: 80px; }
.recruit-interview-question:last-child { margin-bottom: 0; }
.recruit-interview-question-label { font-size: 16px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); margin: 0 0 16px; line-height: 1.4; }
.recruit-interview-question-title { font-size: 30px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0 0 24px; line-height: 1.4; }
.recruit-interview-question-content { font-size: 16px; line-height: 1.8; color: #222; letter-spacing: var(--ls-tight); margin-bottom: 24px; }
.recruit-interview-question-content p { margin: 0 0 16px; }
.recruit-interview-question-content p:last-child { margin-bottom: 0; }
.recruit-interview-question-image { margin-top: 24px; }
.recruit-interview-question-image img { width: 100%; height: auto; display: block; border-radius: 12px; background: #f0f0f0; min-height: 300px; object-fit: cover; }

/* Interview Archive Page Styles */
.interview-archive-content { margin-top: 40px; }
.interview-archive-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(2, 1fr); gap: 40px; }
.interview-archive-item { margin: 0; padding: 0; }
.interview-archive-link { display: block; text-decoration: none; color: inherit; background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); transition: all 0.3s ease, opacity 0.5s; position: relative; }
.interview-archive-link:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0, 180, 227, 0.15); opacity: 0.6; }
.interview-archive-image-wrapper { position: relative; width: 100%; aspect-ratio: 4 / 3; overflow: hidden; background: #f0f0f0; }
.interview-archive-image { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s ease; }
.interview-archive-link:hover .interview-archive-image { transform: scale(1.05); }
.interview-archive-image-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, rgba(0, 180, 227, 0.1) 0%, rgba(0, 180, 227, 0.05) 100%); }
.interview-archive-image-placeholder-text { font-size: 24px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.interview-archive-overlay { position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(to bottom, transparent 0%, rgba(0, 0, 0, 0.3) 100%); opacity: 0; transition: opacity 0.3s ease; }
.interview-archive-link:hover .interview-archive-overlay { opacity: 1; }
.interview-archive-content-wrapper { padding: 32px; position: relative; }
.interview-archive-title-text { font-size: 20px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0 0 16px; line-height: 1.4; }
.interview-archive-meta { display: flex; align-items: flex-start; justify-content: flex-start; gap: 16px; margin-bottom: 12px; flex-wrap: wrap; }
.interview-archive-name { display: flex; flex-direction: column; align-items: flex-start; gap: 4px; }
.interview-archive-name-ja { font-size: 18px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
.interview-archive-name-en { font-size: 14px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); text-transform: uppercase; }
.interview-archive-year { font-size: 14px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); }
.interview-archive-excerpt { font-size: 14px; line-height: 1.7; color: #666; letter-spacing: var(--ls-tight); margin: 0 0 16px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.interview-archive-arrow { position: absolute; bottom: 24px; right: 24px; width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background: #00B4E3; border-radius: 50%; transition: all 0.3s ease; }
.interview-archive-arrow::after { content: ''; width: 0; height: 0; border-left: 6px solid #fff; border-top: 5px solid transparent; border-bottom: 5px solid transparent; }
.interview-archive-link:hover .interview-archive-arrow { background: #0099c7; transform: translateX(4px); }
.interview-archive-empty { text-align: center; padding: 80px 20px; font-size: 16px; color: #666; }
.interview-archive-pagination { margin-top: 60px; text-align: center; }
.interview-archive-pagination .nav-links { display: flex; justify-content: center; align-items: center; gap: 12px; list-style: none; padding: 0; margin: 0; flex-wrap: wrap; }
.interview-archive-pagination .nav-links .page-numbers { display: inline-flex; align-items: center; justify-content: center; color: #999; text-decoration: none; font-size: 16px; font-weight: 500; transition: color 0.2s; background: transparent; border: none; padding: 0; }
.interview-archive-pagination .nav-links .page-numbers:hover { color: #00B4E3; }
.interview-archive-pagination .nav-links .page-numbers.current { color: #00B4E3; font-weight: 500; }
.interview-archive-pagination .nav-links .page-numbers.dots { color: #999; }
.interview-archive-pagination .nav-links a.prev,
.interview-archive-pagination .nav-links a.next { display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; border: 1px solid #00B4E3; border-radius: 50%; text-decoration: none; color: transparent; background: transparent; }
.interview-archive-pagination .nav-links a.prev:hover,
.interview-archive-pagination .nav-links a.next:hover { background: transparent; }
.interview-archive-pagination .nav-links span.prev,
.interview-archive-pagination .nav-links span.next { display: none; }
.interview-archive-pagination .page-numbers .prev.disabled a,
.interview-archive-pagination .page-numbers .next.disabled a,
.interview-archive-pagination .nav-links .prev.disabled a,
.interview-archive-pagination .nav-links .next.disabled a { border-color: #999; }
.interview-archive-pagination .page-numbers .prev.disabled .pagination-prev-icon,
.interview-archive-pagination .page-numbers .next.disabled .pagination-next-icon,
.interview-archive-pagination .nav-links .prev.disabled .pagination-prev-icon,
.interview-archive-pagination .nav-links .next.disabled .pagination-next-icon { border-left-color: #999; }

@media (max-width: 1024px) {
    .interview-archive-list { grid-template-columns: repeat(2, 1fr); gap: 32px; }
}

@media (max-width: 1024px) {
    /* 想いを知る（About）SP */
    .recruit-page-hero::after { height: 500px; clip-path: polygon(-2% 0, 102% 0, 102% 90%, -2% 100%); }
    .recruit-page-hero { padding-bottom: 0; }
    .recruit-page-hero .container { margin-left: 20px; margin-right: 20px; padding: 0; max-width: 100%; box-sizing: border-box; }
    .recruit-page-hero-content { flex-direction: column; gap: 60px; align-items: stretch; }
    .recruit-page-hero-top { flex-direction: column; max-height: none; gap: 60px; overflow: visible; }
    .recruit-job-page .recruit-page-hero-top { flex-direction: column; gap: 60px; }
    .recruit-page-hero-title { font-size: 36px; }
    .recruit-page-hero-sub { font-size: 16px; }
    .recruit-page-hero-description { font-size: 16px; line-height: 1.8; margin-left: 10px; margin-right: 10px; font-weight: 600; }
    .recruit-job-page .recruit-page-hero-description { font-size: 15px; }
    .recruit-job-page .recruit-page-hero-description br { display: none; }
    .recruit-page-hero-description p { margin: 0; }
    .recruit-page-hero-image { width: 100%; height: auto; min-height: 240px; flex: none; }
    .recruit-page-hero-image img { width: 100%; height: auto; min-height: 240px; object-fit: cover; }
    .recruit-page-content { padding: 80px 0 48px; }
    .recruit-page-content .container { margin-left: 20px; margin-right: 20px; padding: 0; max-width: 100%; box-sizing: border-box; }
    .recruit-page-content.recruit-page-content-works .container { margin-left: 30px; margin-right: 30px; }
    .recruit-page-content-inner { flex-direction: column; gap: 32px; align-items: stretch; }
    .recruit-page-content-left { margin-bottom: 0; }
    .recruit-page-section-heading { font-size: 20px; margin-bottom: 0; }
    .recruit-page-section { flex-direction: column; gap: 60px; align-items: stretch; margin-bottom: 60px; padding-bottom: 60px; border-bottom: 1px solid #00B4E3; }
    .recruit-page-section:last-child { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
    .recruit-page-section-content { padding-bottom: 0; border-bottom: none; min-height: 0; }
    .recruit-page-section-label-ja { font-size: 18px; padding: 6px 20px; margin-bottom: 16px; }
    .recruit-page-section-title { font-size: 20px; margin-bottom: 40px; line-height: 1.5; }
    .recruit-page-section-text { font-size: 15px; line-height: 1.8; }
    .recruit-page-section-text p { margin: 0; }
    .recruit-page-section-image { width: 100%; height: auto; min-height: 240px; flex: none; }
    .recruit-page-section-image img { width: 100%; height: auto; min-height: 240px; object-fit: cover; }
    .recruit-page-seeks { padding: 60px 0; }
    .recruit-page-seeks-inner { margin: 0 20px; }
    .recruit-page-seeks-img { display: block; width: 100%; height: auto; }
    .interview-archive-list { grid-template-columns: 1fr; gap: 32px; }
    .interview-archive-content-wrapper { padding: 24px; }
    .interview-archive-title-text { font-size: 18px; }
    .interview-archive-name-ja { font-size: 16px; }
    .interview-archive-meta { flex-direction: column; align-items: flex-start; gap: 12px; }
    .interview-archive-arrow { bottom: 20px; right: 20px; width: 28px; height: 28px; }
    .interview-archive-arrow::after { border-left-width: 5px; border-top-width: 4px; border-bottom-width: 4px; }
    /* インタビュー詳細（single-interview）SP */
    body.single-interview main > .container .breadcrumb,
    body.post-type-archive-interview main > .container .breadcrumb { margin-top: 100px; }
    .recruit-interview-hero { padding: 24px 0 48px; }
    .recruit-interview-hero .container { margin-left: 20px; margin-right: 20px; padding: 0; max-width: 100%; box-sizing: border-box; }
    .recruit-interview-hero-content { flex-direction: column; gap: 60px; align-items: flex-start; overflow: visible; }
    .recruit-interview-hero-left { display: contents; }
    body.single-interview .recruit-interview-tag { order: 1; position: relative; z-index: 2; transform: translateY(50%); width: 150px; height: auto; align-self: flex-start; margin-right: auto; margin-left: 0; }
    body.single-interview .recruit-interview-tag img.recruit-interview-tag-flag { width: 150px; height: auto; max-width: 100%; object-fit: contain; }
    .recruit-interview-hero-image { order: 2; position: relative; z-index: 1; width: 100%; height: auto; min-height: 240px; flex: none; margin-top: -50px; }
    .recruit-interview-hero-image img { width: 100%; height: auto; min-height: 240px; object-fit: cover; }
    .recruit-interview-hero-text { order: 3; margin-left: 10px; margin-right: 10px; }
    .recruit-interview-hero-title { font-size: 24px; margin-bottom: 20px; line-height: 1.45; }
    .recruit-interview-name-ja { font-size: 22px; margin-bottom: 12px; }
    .recruit-interview-name-meta { font-size: 14px; }
    .recruit-interview-summary { margin-top: 12px; font-size: 15px; }
    .recruit-interview-questions { padding: 40px 0 0; }
    .recruit-interview-questions .container { margin-left: 30px; margin-right: 30px; padding: 0; max-width: 100%; box-sizing: border-box; }
    .recruit-interview-questions-wrapper { flex-direction: column; gap: 24px; padding-left: 0; }
    .recruit-interview-questions-wrapper.has-nav-out-of-flow { padding-left: 0; }
    .recruit-interview-questions-nav { display: none !important; }
    .recruit-interview-questions-nav-list { display: none; }
    .recruit-interview-questions-nav-item { display: none; }
    .recruit-interview-questions-content { flex: 1; min-width: 0; }
    .recruit-interview-question { margin-bottom: 48px; }
    .recruit-interview-question:last-child { margin-bottom: 0; }
    .recruit-interview-question-label { font-size: 14px; margin-bottom: 12px; }
    .recruit-interview-question-title { font-size: 20px; margin-bottom: 16px; line-height: 1.4; }
    .recruit-interview-question-content { font-size: 15px; line-height: 1.8; margin-bottom: 20px; }
    .recruit-interview-question-image { margin-top: 16px; }
    .recruit-interview-question-image img { min-height: 200px; }
    .recruit-interview-message { padding: 48px 0; }
    .recruit-interview-message .container { margin-left: 30px; margin-right: 30px; padding: 0; max-width: 100%; box-sizing: border-box; }
    .recruit-interview-message-content { flex-direction: column; overflow: visible; }
    .recruit-interview-message-image { width: 100%; order: unset; margin-top: 0; }
    .recruit-interview-message-image img { width: 100%; height: auto; display: block; object-fit: contain; }
    /* SP: 背景画像（asset-5-2x）→ カード表示 */
    .recruit-interview-others { padding: 0 0 20px; margin-top: 0; background: #ccf0f9 url('assets/img/asset-5-2x.png') no-repeat center center; background-size: cover; display: block; }
    .recruit-interview-others .container { margin-left: 20px; margin-right: 20px; padding: 0; max-width: 100%; box-sizing: border-box; }
    .recruit-interview-others-wrapper { display: flex; flex-direction: column; gap: 0; align-items: stretch; }
    .recruit-interview-others-grid { display: flex; flex-direction: column; gap: 24px; width: 100%; }
    .recruit-interview-others-item { flex-basis: 100% !important; max-width: 100% !important; width: 100% !important; }
}

/* Recruit Job Page: PC 幅が狭いときに hero トップが細長くなりすぎないよう調整 */
@media (min-width: 1025px) and (max-width: 1400px) {
    .recruit-job-page .recruit-page-hero .container {
        margin-left: 40px;
        margin-right: 40px;
    }
    .recruit-job-page .recruit-page-hero-content {
        flex-direction: column;
        gap: 40px;
        align-items: stretch;
    }
    .recruit-job-page .recruit-page-hero-top {
        flex: 1 1 auto;
        min-width: 0;
        max-width: 100%;
        gap: 32px;
    }
}

.recruit-interview-message { padding: 80px 0; position: relative; }
.recruit-interview-message-content { display: flex; gap: 0; align-items: stretch; justify-content: center; position: relative; z-index: 1; overflow: hidden; }
.recruit-interview-message-image { width: 100%; flex: 1 1 auto; margin: 0; position: relative; z-index: 1; display: block; }
.recruit-interview-message-image img { width: 100%; height: auto; display: block; vertical-align: bottom; object-fit: cover; }

@media (max-width: 1024px) {
    .recruit-interview-message { overflow: visible; padding-top: 64px; }
    .recruit-interview-message .container { overflow: visible; }
    .recruit-interview-message-content { overflow: visible; }
    .recruit-interview-message-image { width: 100%; }
    .recruit-interview-message-image img { width: 100%; height: auto; object-fit: contain; }
    .recruit-interview-others { padding: 0 0 20px; margin-top: 0; }
    .recruit-interview-others-wrapper { flex-direction: column; gap: 0; }
}

.recruit-interview-others { padding: 80px 0; background: #ccf0f9; width: 100%; max-width: 100%; position: relative; overflow: visible; box-sizing: border-box; }
.recruit-interview-others-wrapper { display: flex; gap: 60px; align-items: flex-start; overflow: visible; }
.recruit-interview-others .container { overflow: visible; }
.recruit-interview-others-grid { flex: 1; display: flex; flex-direction: row; gap: 24px; justify-content: flex-start; flex-wrap: nowrap; align-items: stretch; width: auto; box-sizing: border-box; overflow: visible; }
.recruit-interview-others-item { display: block !important; flex: none !important; flex-basis: calc((100% - 24px) / 2) !important; flex-grow: 0 !important; flex-shrink: 0 !important; min-width: 0 !important; max-width: calc((100% - 24px) / 2) !important; width: calc((100% - 24px) / 2) !important; float: none !important; clear: none !important; box-sizing: border-box !important; background: transparent; border-radius: 12px; overflow: hidden; box-shadow: none; transition: transform 0.2s, opacity 0.5s; position: relative; }
a.recruit-interview-others-item { color: inherit; text-decoration: none; }
.recruit-interview-others-item:hover { opacity: 0.6; }
.recruit-interview-others-item-image { width: 100%; min-height: 280px; height: auto; overflow: hidden; position: relative; z-index: 1; border-radius: 12px; background: transparent; isolation: isolate; display: flex; align-items: center; justify-content: center; }
.recruit-interview-others-item-image > img { width: 100%; height: auto; max-width: 100%; object-fit: cover; display: block; border-radius: 0; border: none; outline: none; margin: 0; vertical-align: bottom; }
.recruit-interview-others-item-image img { width: 100%; height: auto; max-width: 100%; object-fit: cover; display: block; border-radius: 0; border: none; outline: none; margin: 0; vertical-align: bottom; }

/* Made in WIN 左カラム画像（PC） */
.recruit-interview-others-image {
    display: none;
}

@media (min-width: 1025px) {
    body.single-interview .recruit-interview-others { background: #ccf0f9; width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); box-sizing: border-box; }
    body.single-interview .recruit-interview-others .container { margin-left: 80px; margin-right: 80px; max-width: none; }

    /* PC版: 左から画像1カラム + カード2カラム */
    body.single-interview .recruit-interview-others-wrapper {
        display: flex;
        flex-direction: row;
        gap: 40px;
        align-items: stretch;
    }
    body.single-interview .recruit-interview-others-image {
        display: block;
        flex: 0 0 360px;
        max-width: 360px;
        height: 540px;
    }
    body.single-interview .recruit-interview-others-image img {
        width: 100%;
        height: 100%;
        display: block;
        object-fit: contain;
    }
    body.single-interview .recruit-interview-others-grid {
        flex: 1 1 auto;
        display: flex;
        flex-direction: row;
        gap: 24px;
        justify-content: flex-start;
        align-items: stretch;
    }
    /* PC版: カードサイズを画面幅に依存しない固定サイズにする */
    body.single-interview .recruit-interview-others-item {
        width: 400px !important;
        max-width: 400px !important;
        min-width: 400px !important;
        flex-basis: 400px !important;
        flex-grow: 0 !important;
        flex-shrink: 0 !important;
        height: auto !important;
        min-height: 540px !important;
    }
    body.single-interview .recruit-interview-others-item-image {
        width: 100%;
        height: 100%;
        min-height: 540px;
    }
}

/* PC幅が小さい場合は画像とカードを縮小してはみ出し防止（拡大はしない） */
@media (min-width: 1025px) and (max-width: 1350px) {
    body.single-interview .recruit-interview-others .container {
        margin-left: 40px;
        margin-right: 40px;
    }
    body.single-interview .recruit-interview-others-wrapper {
        gap: 24px;
    }
    body.single-interview .recruit-interview-others-image {
        flex: 0 0 26%;
        max-width: 26%;
        height: auto;
    }
    body.single-interview .recruit-interview-others-image img {
        width: 100%;
        height: auto;
        object-fit: contain;
    }
    body.single-interview .recruit-interview-others-grid {
        flex: 1 1 auto;
    }
    body.single-interview .recruit-interview-others-item {
        width: calc((100% - 24px) / 2) !important;
        max-width: calc((100% - 24px) / 2) !important;
        min-width: 0 !important;
        flex-basis: calc((100% - 24px) / 2) !important;
        min-height: auto !important;
        height: auto !important;
    }
    body.single-interview .recruit-interview-others-item-image {
        min-height: 0;
        height: auto;
    }
}

@media (max-width: 1024px) {
    body.single-interview .recruit-interview-others { padding-top: 0 !important; padding-bottom: 20px !important; background: #ccf0f9 !important; width: 100%; max-width: 100%; overflow-x: hidden; box-sizing: border-box; }
    body.single-interview .recruit-interview-others .container { margin-left: 0 !important; margin-right: 0 !important; padding-left: 0 !important; padding-right: 0 !important; max-width: 100% !important; width: 100% !important; box-sizing: border-box; }
    body.single-interview .recruit-interview-others-wrapper { width: 100%; max-width: 100%; padding: 30px 30px 0; box-sizing: border-box; }
    body.single-interview .recruit-interview-others-image {
        display: block;
        width: 100%;
        max-width: 100%;
        margin: 0 0 24px;
    }
    body.single-interview .recruit-interview-others-image img {
        width: 80%;
        max-width: 100%;
        min-width: 80%;
        height: auto;
        display: block;
        margin-left: 0;
        margin-right: 0;
        object-fit: contain;
    }
    body.single-interview .recruit-interview-others-grid {
        width: 100% !important;
        max-width: 100% !important;
        display: flex !important;
        flex-direction: column !important;
        gap: 24px;
    }
    body.single-interview .recruit-interview-others-item { width: 100% !important; max-width: 100% !important; flex-basis: 100% !important; }
}

@media (max-width: 1024px) {
    .recruit-interview-hero-content { flex-direction: column; }
    .recruit-interview-hero-image { max-width: 100%; width: 100%; height: auto; }
    .recruit-interview-hero-image img { height: auto; }
    .recruit-interview-message-content { flex-direction: column; }
    .recruit-interview-message-image { max-width: 100%; }
    .recruit-interview-others-wrapper { flex-direction: column; gap: 40px; }
    .recruit-interview-others-grid { flex-direction: column; gap: 24px; }
    .recruit-interview-others-item { flex-basis: 100%; max-width: 100%; width: 100%; }
}

/* Recruit TOP: SP 幅が広いとき（769〜1024px）は「他のインタビュー」カードを横並びに */
@media (min-width: 769px) and (max-width: 1024px) {
    .recruit-interview-others-grid {
        flex-direction: row;
        gap: 24px;
        justify-content: center;
    }
    .recruit-interview-others-item {
        flex-basis: calc((100% - 24px) / 2) !important;
        width: calc((100% - 24px) / 2) !important;
        max-width: calc((100% - 24px) / 2) !important;
    }
}

/* Recruit TOP: PC ではカードの位置（左からの配置）は維持しつつ、
   画面サイズに応じてカード幅だけを拡大縮小させる */
@media (min-width: 1025px) {
    .recruit-interview-others-grid {
        flex-wrap: nowrap;
    }
    .recruit-interview-others-item {
        flex-basis: clamp(260px, calc((100% - 24px) / 2), 400px) !important;
        width:      clamp(260px, calc((100% - 24px) / 2), 400px) !important;
        max-width:  clamp(260px, calc((100% - 24px) / 2), 400px) !important;
    }
}

/* Recruit Job Page Styles */
.recruit-job-page .recruit-page-hero::before,
.recruit-job-page .recruit-page-content::before { display: none; }
.recruit-job-page .recruit-page-content .container { margin-left: 80px; margin-right: 80px; }
@media (max-width: 1024px) {
    .recruit-job-page .recruit-page-content .container { margin-left: 20px; margin-right: 20px; }
}
.recruit-job-section-nav { display: flex; flex-direction: column; gap: 0; margin-bottom: 40px; }
.recruit-job-section-nav-link { display: flex; align-items: center; gap: 12px; color: #888; font-size: 16px; font-weight: 400; letter-spacing: var(--ls-wide); text-decoration: none; transition: color 0.2s; padding: 8px 0; }
.recruit-job-section-nav-link::before { content: ''; flex-shrink: 0; width: 12px; height: 12px; border-radius: 50%; border: 2px solid #ccc; background: transparent; transition: border-color 0.2s, background 0.2s; }
.recruit-job-section-nav-link:hover { color: #555; }
.recruit-job-section-nav-link:hover::before { border-color: #999; }
.recruit-job-section-nav-link.is-current { color: #1a1a1a; }
.recruit-job-section-nav-link.is-current::before { border-color: #00B4E3; background: #00B4E3; }
@media (min-width: 770px) {
    .recruit-job-section-nav { display: none; }
}
.recruit-job-sections-wrapper { border: 2px solid #e0e8eb; border-radius: 20px; padding: 100px 60px 150px; margin-bottom: 200px; background: #fff; }
.recruit-job-section { display: flex; flex-direction: row; flex-wrap: wrap; gap: 0; align-items: flex-start; margin-bottom: 80px; padding: 0; position: relative; z-index: 1; }
.recruit-job-section:last-child { margin-bottom: 0; }
.recruit-job-section-header { flex-shrink: 0; width: 300px; margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.recruit-job-section-body { flex: 0 0 750px; width: 750px; min-width: 0; margin-left: auto; }
.recruit-job-section-title { font-size: 30px; font-weight: 700; color: #1a1a1a; letter-spacing: var(--ls-wide); margin: 0; display: inline-flex; align-items: center; gap: 14px; line-height: 1.2; }
.recruit-job-section-title-bullet { display: inline-block; width: 10px; height: 10px; border-radius: 50%; background: #00B4E3; flex-shrink: 0; }
/* 縦積みの表形式 */
.recruit-job-details { display: block; }
.recruit-job-details-row { display: flex; flex-direction: row; align-items: stretch; gap: 30px; border-bottom: 1px solid #d5dce2; min-height: 56px; }
.recruit-job-details-label { flex: 0 0 130px; width: 130px; font-size: 16px; font-weight: 700; color: #1a1a1a; letter-spacing: 0.08em; line-height: 1.5; padding: 18px 0; background: none; display: flex; align-items: flex-start; }
.recruit-job-details-value { flex: 1; min-width: 0; font-size: 16px; font-weight: 400; color: #2a2a2a; letter-spacing: var(--ls-tight); line-height: 1.85; padding: 18px 24px 18px 0; background: none; display: flex; align-items: flex-start; }
.recruit-job-details-value > div { margin-bottom: 6px; }
.recruit-job-details-value > div:last-child { margin-bottom: 0; }
.recruit-job-process { display: flex; flex-direction: column; align-items: stretch; gap: 0; }
.recruit-job-process-step { display: grid; grid-template-columns: max-content 1fr; align-items: center; column-gap: 24px; background: #f0f4f6; border: none; border-radius: 50px; padding: 24px 28px; position: relative; }
.recruit-job-process-step-number { grid-column: 1; min-width: 88px; font-size: 20px; font-weight: 700; color: #00B4E3; letter-spacing: 0.12em; margin: 0; white-space: nowrap; }
.recruit-job-process-step-title { grid-column: 2; font-size: 18px; font-weight: 700; color: #1a1a1a; letter-spacing: var(--ls-wide); line-height: 1.5; margin: 0; text-align: center; }
.recruit-job-process-arrow { display: flex; align-items: center; justify-content: center; padding: 15px 0; color: #00b4e3; font-size: 12px; line-height: 1; }
.recruit-job-entry-form { flex: 0 0 100%; width: 100%; display: flex; justify-content: center; margin-top: 150px; padding-top: 0; }
.recruit-job-entry-form-button { display: inline-flex; align-items: center; justify-content: space-between; gap: 16px; width: 450px; height: 100px; box-sizing: border-box; background: #ccf0f9; border-radius: 16px; padding: 0 48px; text-decoration: none; color: #00b4e3; font-weight: 700; font-size: 24px; letter-spacing: var(--ls-wide); transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.5s; position: relative; overflow: hidden; }
.recruit-job-entry-form-button:hover { opacity: 0.6; }
.recruit-job-entry-form-button-icon { width: 24px; height: 24px; border: 2px solid #00b4e3; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; position: relative; flex-shrink: 0; }
.recruit-job-entry-form-button-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 7px solid #00b4e3; border-top: 5px solid transparent; border-bottom: 5px solid transparent; transform: translate(-50%, -50%); }
br.sp { display: none; }

@media (max-width: 1024px) {
  .sp-hide-divider {
    display: none;
  }

  br.sp {
    display: block;
  }

    .recruit-job-details-label { flex: 0 0 80px; width: 80px; padding: 16px 0; }
    .recruit-job-details-value { padding: 16px 0 16px 20px; }
}

@media (max-width: 1024px) {
    .recruit-job-page .recruit-page-content { padding-top: 30px; }
    .recruit-job-section-nav { margin-bottom: 24px; }
    .recruit-job-section-nav-link { font-size: 14px; gap: 10px; padding: 6px 0; }
    .recruit-job-section-nav-link::before { width: 10px; height: 10px; border-width: 1.5px; }
    .recruit-job-sections-wrapper { padding: 40px 24px; border-radius: 16px; margin-bottom: 0; }
    .recruit-job-section { flex-direction: column; margin-bottom: 56px; }
    .recruit-job-section-header { width: auto; margin-bottom: 32px; padding-bottom: 16px; border-bottom: none; }
    .recruit-job-section-body { flex: 1 1 auto; width: auto; max-width: 100%; margin-left: auto; margin-right: auto; }
    .recruit-job-section-title { font-size: 24px; gap: 10px; }
    .recruit-job-section-title-bullet { width: 8px; height: 8px; }
    .recruit-job-details-row { flex-direction: row; gap: 0; min-height: 0; align-items: stretch; }
    .recruit-job-details-label { flex: 0 0 80px; width: 80px; border-bottom: none; padding: 14px 0; font-size: 13px; }
    .recruit-job-details-value { padding: 14px 0 14px 20px; font-size: 15px; }
    .recruit-job-process-step { grid-template-columns: max-content 1fr; column-gap: 16px; padding: 20px 24px; }
    .recruit-job-process-step-number { min-width: 72px; font-size: 18px; }
    .recruit-job-process-step-title { font-size: 17px; }
    .recruit-job-entry-form { margin-top: 80px; }
    .recruit-job-entry-form-button { width: 100%; max-width: 450px; height: 80px; padding: 0 24px; font-size: clamp(18px, 4vw, 24px); gap: 12px; }
    .recruit-job-entry-form-button-icon { width: 20px; height: 20px; border-width: 1.5px; }
    .recruit-job-entry-form-button-icon::after { border-left-width: 5px; border-top-width: 4px; border-bottom-width: 4px; }
}

/* Message Page: PC 幅が小さいときにヘッダー・本文がかぶらないように調整 */
@media (min-width: 1025px) and (max-width: 1400px) {
    .message-page-top {
        gap: 24px;
        align-items: flex-start;
        justify-content: space-between;
    }
    .message-page-header-section {
        flex: 0 1 320px;
        min-width: 280px;
    }
    .message-page-image {
        width: 480px;
        height: auto;
        margin-left: auto;
        flex-shrink: 0;
    }
    .message-page-image img {
        width: 100%;
        height: auto;
        object-fit: cover;
    }
    .message-page-bottom {
        flex-direction: row;
        gap: 24px;
        align-items: flex-start;
        margin: 40px 0 40px;
    }
    .message-page-quote {
        font-size: 38px;
        line-height: 1.3;
        max-width: 460px;
        flex: 0 1 460px;
        text-align: left;
    }
    .message-page-text {
        width: auto;
        max-width: 520px;
        flex: 0 1 520px;
    }
}

/* Outline / Privacy: PC 幅が小さいときにヘッダー・本文のバランスを調整 */
@media (min-width: 1025px) and (max-width: 1400px) {
    /* Outline Page */
    .outline-page-top {
        gap: 24px;
        align-items: flex-start;
        justify-content: space-between;
    }
    .outline-page-header-section {
        flex: 0 1 320px;
        min-width: 280px;
    }
    .outline-page-image {
        width: 480px;
        height: auto;
        margin-left: auto;
        flex-shrink: 0;
    }
    .outline-page-image img {
        width: 100%;
        height: auto;
        object-fit: cover;
    }

    /* Privacy Page */
    body.page-template-page-privacy main > .container,
    body.privacy main > .container {
        margin-left: 40px;
        margin-right: 40px;
    }
    .privacy-page-content {
        width: 100%;
        max-width: 880px;
        margin-left: auto;
        margin-right: auto;
    }

    /* Recruit About (想いを知る) - PC 幅が小さいときにテキストカラムが細くなりすぎないよう調整 */
    .recruit-page-hero .container {
        margin-left: 40px;
        margin-right: 40px;
    }
    .recruit-page-hero-content {
        gap: 32px;
        justify-content: center;
    }
    .recruit-page-hero-top {
        flex: 0 1 480px;
        min-width: 420px;
        max-width: 520px;
    }
    .recruit-page-hero-image {
        width: 440px;
        height: 360px;
    }

    /* recruit-page-content（想いを知る） - 幅が狭いときに section-content が細くなりすぎないよう調整 */
    .recruit-page-content .container {
        margin-left: 40px;
        margin-right: 40px;
    }
    .recruit-page-content-inner {
        gap: 60px;
    }
    .recruit-page-section {
        gap: 48px;
    }
    .recruit-page-section-content {
        flex: 1 1 360px;
        min-width: 320px;
    }
    .recruit-page-section-image {
        width: 340px;
        height: 340px;
        flex: 0 0 340px;
    }
    .recruit-page-section-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* インタビューページ - PC 幅が狭いときに hero-left が細くなりすぎないよう調整 */
    .recruit-interview-hero .container {
        margin-left: 100px;
        margin-right: 100px;
    }
    .recruit-interview-hero-content {
        gap: 32px;
    }
    .recruit-interview-hero-left {
        flex: 1 1 380px;
        min-width: 320px;
    }
    .recruit-interview-hero-image {
        width: 440px;
        height: 330px;
        flex: 0 0 440px;
    }
    .recruit-interview-hero-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    /* インタビューページ - PC 幅が狭いときに questions-content が細くなりすぎないよう調整 */
    .recruit-interview-questions .container {
        margin-left: 40px;
        margin-right: 40px;
    }
    .recruit-interview-questions-wrapper {
        gap: 40px;
    }
    .recruit-interview-questions-wrapper.has-nav-out-of-flow {
        padding-left: 260px;
    }
    .recruit-interview-questions-nav {
        width: 220px;
    }
    .recruit-interview-questions-content {
        flex: 1 1 380px;
        min-width: 320px;
    }
}

/* Company Site Responsive Styles */
@media (max-width: 1024px) {
    /* Company Page */
    .company-page-title { font-size: 40px; }
    .company-philosophy-content { padding: 0; }
    .company-philosophy-block { padding: 0; }
    
    /* Message Page */
    .message-page-top { flex-direction: column; gap: 32px; }
    .message-page-header-section { width: 100%; align-items: flex-start; }
    .message-page-header-content { width: 100%; }
    .message-page-image { width: 100%; }
    .message-page-image img { width: 100%; height: auto; }
    .message-page-bottom { flex-direction: column; gap: 32px; margin: 60px 0 40px; }
    .message-page-quote { font-size: 36px; text-align: left; }
    .message-page-signature { text-align: left; }
    
    /* Vision Page */
    .vision-section-row { flex-direction: column; gap: 32px; }
    .vision-section-row-1 { margin-bottom: 60px; }
    .vision-section-2 { flex-direction: column; gap: 0; }
    .vision-section-quote { font-size: 32px; }
    
    /* Outline Page */
    .outline-page-top { flex-direction: column; gap: 32px; margin-top: 0; margin-bottom: 60px; }
    .outline-page-image { width: 100%; height: auto; }
    .outline-page-history { flex-direction: column; gap: 32px; padding: 32px 24px; }
    .outline-history-header { flex: none; width: 100%; }
    .outline-info-list dt { flex: 0 0 120px; }
}

@media (max-width: 1024px) {
    /* Company Page */
    .company-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
    .company-page-title { font-size: 40px; }
    .company-page-sub { font-size: 16px; }
    .company-slider-block { height: 440px; }
    .company-slider-item { width: 440px; height: 440px; }
    .company-philosophy-block { padding: 0; }
    .company-philosophy-content { padding: 0; }
    .company-philosophy-text p { font-size: 16px; }
    .company-cards { flex-direction: column; gap: 16px; }
    .company-card { max-width: 100%; width: 100%; }
    
    /* Message Page */
    .message-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
    .message-page-title { font-size: 40px; }
    .message-page-sub { font-size: 16px; }
    .message-page-top { margin: 0; gap: 0; }
    .message-page-header-section { margin: 60px 0; align-items: center; }
    .message-page-header-content { align-items: center; text-align: center; }
    .message-page-section-title { font-size: 24px; text-align: center; }
    .message-page-section-sub { font-size: 20px; text-align: center; }
    .message-page-image { width: 100%; padding: 0; box-sizing: border-box; height: auto; }
    .message-page-bottom { margin: 0; gap: 0; align-items: center; }
    .message-page-quote { font-size: 25px; line-height: 1.3; padding: 0 10px; margin: 60px 0; text-align: left; margin-left: auto; margin-right: auto; max-width: 640px; width: 100%; box-sizing: border-box; }
    .message-page-text { font-size: 15px; padding: 0 10px; margin-left: auto; margin-right: auto; max-width: 640px; width: 100%; box-sizing: border-box; }
    .message-page-text p { margin: 0 0 60px; }
    .message-page-signature { padding: 0 10px; text-align: right; }
    .message-page-signature-name { font-size: 24px; }
    .message-cards-section { margin-top: 80px; margin-bottom: 100px; }
    .message-cards-section .container { margin: 0; width: 100%; padding: 0 30px; box-sizing: border-box; }
    .message-cards { flex-direction: column; gap: 16px; width: 100%; box-sizing: border-box; }
    .message-card { flex-direction: column; align-items: center; width: 100%; text-align: center; box-sizing: border-box; border-radius: 20px; }
    .message-card-left { align-items: center; text-align: center; }
    .message-card-title-en,
    .message-card-title-ja,
    .message-card-link { font-weight: 700; }
    .message-card-link { margin-top: 16px; }

    .vision-cards-section { margin-top: 80px; margin-bottom: 100px; }
    .vision-cards-section .container { margin: 0; width: 100%; padding: 0 30px; box-sizing: border-box; }
    .vision-cards { flex-direction: column; gap: 16px; width: 100%; box-sizing: border-box; align-items: stretch; }
    .vision-card { flex-direction: column; align-items: center; width: 100%; text-align: center; box-sizing: border-box; border-radius: 20px; }
    .vision-card-left { display: flex; flex-direction: column; align-items: center; text-align: center; width: 100%; }
    .vision-card-title-en,
    .vision-card-title-ja,
    .vision-card-link { font-weight: 700; text-align: center; width: 100%; }
    .vision-card-link { margin-top: 16px; justify-content: center; }
    
    /* Vision Page */
    .vision-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
    .vision-page-title { font-size: 40px; }
    .vision-page-sub { font-size: 16px; }
    .vision-section { margin: 48px 0; }
    .vision-section-2 { margin-top: 0; margin-bottom: 0; }
    .vision-section:first-of-type { margin-top: 0; }
    .vision-section-1 { margin-top: 0; margin-bottom: 0; }
    .vision-section-header { margin: 60px 0; }
    .vision-section-image { width: 100%; height: auto; margin: 0; }
    .vision-section-image img { width: 100%; height: auto; object-fit: cover; display: block; border-radius: 8px; }
    .vision-section-row { margin-bottom: 0; gap: 0; }
    .vision-section-row-1 { margin-bottom: 0; }
    .vision-section-title { font-size: 24px; text-align: center; }
    .vision-section-sub { font-size: 20px; text-align: center; }
    .vision-section-title-2 { font-size: 18px; margin-bottom: 30px; padding: 0 10px; }
    .vision-section-quote { font-size: 25px; line-height: 1.3; padding: 0 10px; margin: 60px 0; text-align: left; margin-left: auto; margin-right: auto; max-width: 640px; width: 100%; box-sizing: border-box; }
    .vision-section-text { font-size: 15px; padding: 0 10px; margin-left: auto; margin-right: auto; margin-bottom: 40px; max-width: 640px; width: 100%; box-sizing: border-box; }
    .vision-section-text p { margin: 0 0 60px; }
    .vision-section-content-wrapper { margin-top: 40px; }
    .vision-cards { flex-direction: column; gap: 16px; }
    .vision-card { flex-direction: column; align-items: flex-start; width: 100%; }
    .vision-card-link { margin-top: 16px; }
    
    /* Outline Page */
    .outline-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
    .outline-page-title { font-size: 40px; }
    .outline-page-sub { font-size: 16px; }
    .outline-page-top { margin-top: 0; margin-bottom: 60px; gap: 0; }
    .outline-page-header-section { margin: 60px 0; align-items: center; text-align: center; }
    .outline-page-section-title { font-size: 24px; text-align: center; }
    .outline-page-section-sub { font-size: 20px; text-align: center; }
    .outline-page-info { margin: 0 0 32px; width: 100%; padding: 0 10px; box-sizing: border-box; max-width: 100%; }
    .outline-info-list { margin: 0; padding: 0; list-style: none; border-top: 1px solid #ddd; }
    .outline-info-item { display: flex; align-items: flex-start; padding: 20px 0; border-bottom: 1px solid #ddd; height: auto; }
    .outline-info-list dt { flex: 0 0 90px; max-width: 90px; padding: 0; margin: 0; font-size: 15px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
    .outline-info-list dd { flex: 1; padding: 0; margin: 0 0 0 8px; font-size: 15px; line-height: 1.5; color: #222; letter-spacing: var(--ls-tight); word-break: break-word; overflow-wrap: break-word; }
    .outline-map-placeholder { width: calc(100% + 20px); height: 300px; margin: 60px -10px 0; box-sizing: border-box; }
    .outline-page-history { margin: 60px 0 0; padding: 0 30px; gap: 0; }
    .outline-history-header { margin: 60px 0; text-align: center; align-items: center; display: flex; flex-direction: column; }
    .outline-history-title { font-size: 24px; text-align: center; }
    .outline-history-sub { font-size: 20px; text-align: center; }
    .outline-history-item { flex-direction: column; gap: 0px; padding-left: 20px; }
    .outline-history-date { flex: none; width: 100%; }
    .outline-history-event { flex: none; width: 100%; }
    .outline-history-content { margin-bottom: 60px; }
    .outline-cards-section { margin-top: 80px; margin-bottom: 100px; }
    .outline-cards-section .container { margin: 0; width: 100%; padding: 0 30px; box-sizing: border-box; }
    .outline-cards { flex-direction: column; gap: 16px; width: 100%; box-sizing: border-box; align-items: stretch; }
    .outline-card { flex-direction: column; align-items: center; width: 100%; text-align: center; box-sizing: border-box; border-radius: 20px; }
    .outline-card-left { display: flex; flex-direction: column; align-items: center; text-align: center; width: 100%; }
    .outline-card-title-en,
    .outline-card-title-ja,
    .outline-card-link { font-weight: 700; text-align: center; width: 100%; }
    .outline-card-link { margin-top: 16px; justify-content: center; }
    
    /* Recruit Entry Page */
    .recruit-entry-page::before { height: 520px; clip-path: polygon(0 0, 100% 0, 100% 85%, 0 100%); }
    .recruit-entry-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; border-bottom: none; }
    .recruit-entry-page-title { font-size: 36px; }
    .recruit-entry-page-sub { font-size: 16px; }
    .recruit-entry-page-instructions { margin-top: 0px; margin-bottom: 0; padding-left: 10px; padding-right: 10px; font-size: 15px; }
    .recruit-entry-page-instructions .recruit-entry-instruction-text,
    .recruit-entry-page-instructions .recruit-entry-instruction-note { font-size: 15px; }
    .recruit-entry-instruction-text { margin-top: 0; margin-bottom: 0; }
    .recruit-entry-page-content { margin-top: 60px; margin-bottom: 100px; }

    /* Contact Page */
    .contact-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
    .contact-page-title { font-size: 40px; }
    .contact-page-sub { font-size: 16px; }
    .contact-page-instructions { margin-top: 60px; margin-bottom: 0; padding-left: 10px; padding-right: 10px; font-size: 15px; }
    .contact-page-instructions .contact-instruction-text,
    .contact-page-instructions .contact-instruction-note { font-size: 15px; }
    .contact-instruction-text { margin-top: 0; margin-bottom: 0; }
    .contact-page-content { margin-top: 60px; margin-bottom: 100px; }
    .contact-form-wrapper { padding: 0 0px; }
    
    /* Privacy Page */
    .privacy-page-header { margin-bottom: 0; padding-bottom: 0; padding-left: 20px; padding-right: 20px; height: 140px; width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; display: flex; flex-direction: column; align-items: flex-start; justify-content: flex-start; }
    .privacy-page-title { font-size: 40px; }
    .privacy-page-sub { font-size: 16px; }
    .privacy-page-content { width: 100%; max-width: 100%; box-sizing: border-box; margin-top: 60px; margin-bottom: 100px; }
}

/* Desktop: Hide hamburger menu, show normal nav */
@media (min-width: 1025px) {
    .header { padding-top: 50px; margin-top: 0; }
    .header-recruit { padding-top: 0; margin-top: 0; }
    .edge-pad { padding-left: 80px; }
    .news-block .news-item { grid-template-columns: 180px 1fr 24px; }
    h1, h2 { font-family: 'Roboto', sans-serif; }
    .hero { height: 800px; }
    .hero img { height: 800px; width: 100%; object-fit: cover; }
    .hero .hero-title { font-family: 'Roboto', sans-serif; font-weight: 700; font-size: 70px; line-height: 105px; color: #fff; text-shadow: 0 0 5px rgba(0, 0, 0, 0.5); margin: 0 0 8px; }
    .hero .hero-sub { font-family: 'Noto Sans JP', sans-serif; font-weight: 700; font-size: 26px; line-height: 39px; letter-spacing: 1.3px; color: #fff; text-shadow: 0 0 5px rgba(0, 0, 0, 0.5); margin: 16px 0 0; }
    .philosophy-label { font-weight: 700; }
    .philosophy-block .philosophy-text-bold { font-weight: 700; }
    .philosophy-block { margin-top: 100px; }
    .philosophy-content { max-width: 880px; }
    .philosophy-visual { min-height: 310px; }
    .philosophy-label { margin-top: 120px; }
    .philosophy-label,
    .philosophy-title-wrap,
    .philosophy-block .philosophy-text { position: relative; z-index: 1; margin-top: 0; font-weight: 700; }
    .philosophy-bg { overflow: visible; }
    .philosophy-bg-img { width: 848px; height: 310px; max-width: 848px; object-fit: contain; }
    .slider-block { width: 100vw; max-width: 100vw; margin-left: calc(50% - 50vw); box-sizing: border-box; }
    .win-philosophy-visual-block { display: flex !important; padding: 150px 140px !important; }
    .win-philosophy-visual-img-sp { display: none !important; }
    .win-philosophy-visual-img-pc { display: block !important; }
    .madein-block { background: #fff; }
    .madein-container { position: relative; }
    .madein-container .madein-link { position: absolute; right: 24px; bottom: 24px; z-index: 2; }
    .footer { display: flex; flex-direction: column; }
    .footer-inner { display: flex; flex-direction: row; flex-wrap: wrap; align-items: flex-start; padding-top: 200px; width: 100%; }
    .footer-logo { flex: none; margin-left: 100px; margin-right: 48px; padding: 0 0 80px; text-align: left; order: unset; }
    .footer-logo img.footer-logo-img { width: 200px !important; height: 126.6px !important; min-width: 200px !important; max-width: 200px !important; object-fit: contain; }
    .footer-nav { flex: 1; min-width: 0; padding: 0; margin-right: 100px; order: unset; display: flex; justify-content: flex-end; }
    .footer-nav-inner { max-width: none; width: 100%; min-width: 0; }
    .footer-nav-columns { justify-content: flex-end; gap: 40px; flex-wrap: wrap; }
    .footer-nav-col { flex-direction: row; gap: 40px; flex: none; min-width: 0; }
    .footer-copyright { width: 100%; order: unset; padding: 0 24px 40px; text-align: center; }
    body.recruit .recruit-interview { padding-bottom: 0; }
}

/* company-recruit-cards PC: 画面幅に応じて縮小（拡大なし） */
@media (min-width: 1025px) and (max-width: 1200px) {
    .company-recruit-block { height: 360px; }
    .company-recruit-bg { height: 360px; }
    .company-recruit-content { padding: 0 24px; }
    .company-recruit-cards { gap: 24px; }
    .company-recruit-card { width: 460px; height: 160px; flex: none; flex-direction: column; justify-content: center; align-items: center; gap: 12px; padding: 20px; border: none; border-radius: 14px; background: #fff; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15); transition: box-shadow 0.2s; }
    .company-recruit-card:hover { box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15); }
    .company-recruit-card-text { align-items: center; gap: 4px; }
    .company-recruit-card-title { font-size: 38px; font-weight: 700; text-align: center; color: #222; }
    .company-recruit-card-sub { font-size: 18px; font-weight: 700; text-align: center; color: #222; }
    .company-recruit-card-link { font-size: 18px; font-weight: 700; color: #00B4E3; gap: 6px; }
    .company-recruit-icon { width: 20px; height: 20px; }
    .company-recruit-icon::after { border-left-width: 5px; border-top-width: 3px; border-bottom-width: 3px; }
}
@media (min-width: 1201px) and (max-width: 1400px) {
    .company-recruit-block { height: 380px; }
    .company-recruit-bg { height: 380px; }
    .company-recruit-content { padding: 0 28px; }
    .company-recruit-cards { gap: 32px; }
    .company-recruit-card { width: 510px; height: 175px; flex: none; flex-direction: column; justify-content: center; align-items: center; gap: 14px; padding: 22px; border: none; border-radius: 15px; background: #fff; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15); transition: box-shadow 0.2s; }
    .company-recruit-card:hover { box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15); }
    .company-recruit-card-text { align-items: center; gap: 4px; }
    .company-recruit-card-title { font-size: 42px; font-weight: 700; text-align: center; color: #222; }
    .company-recruit-card-sub { font-size: 18px; font-weight: 700; text-align: center; color: #222; }
    .company-recruit-card-link { font-size: 20px; font-weight: 700; color: #00B4E3; gap: 8px; }
    .company-recruit-icon { width: 24px; height: 24px; }
    .company-recruit-icon::after { border-left-width: 5px; border-top-width: 3px; border-bottom-width: 3px; }
}
@media (min-width: 1401px) {
    .company-recruit-block { height: 400px; }
    .company-recruit-bg { height: 400px; }
    .company-recruit-content { padding: 0 30px; }
    .company-recruit-cards { gap: 40px; }
    .company-recruit-card { width: 560px; height: 190px; flex: none; flex-direction: column; justify-content: center; align-items: center; gap: 16px; padding: 24px; border: none; border-radius: 16px; background: #fff; box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15); transition: box-shadow 0.2s; }
    .company-recruit-card:hover { box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15); }
    .company-recruit-card-text { align-items: center; gap: 4px; }
    .company-recruit-card-title { font-size: 46px; font-weight: 700; text-align: center; color: #222; }
    .company-recruit-card-sub { font-size: 18px; font-weight: 700; text-align: center; color: #222; }
    .company-recruit-card-link { font-size: 22px; font-weight: 700; color: #00B4E3; gap: 8px; }
    .company-recruit-icon { width: 22px; height: 22px; }
}

/* フッター: 中幅で余白を詰めて崩れ防止 */
@media (min-width: 1025px) and (max-width: 1200px) {
    .footer-logo { margin-left: 40px; margin-right: 24px; }
    .footer-nav { margin-right: 40px; }
    .footer-nav-columns { gap: 24px; }
    .footer-nav-col { gap: 24px; }
}

/* 1728px以上: フッター中身を1728pxで中央に、100vw要素のはみ出し防止 */
@media (min-width: 1728px) {
    .slider-block {
        width: 100%;
        max-width: 1728px;
        margin-left: auto;
        margin-right: auto;
        box-sizing: border-box;
    }
    .slider-block .slider-block-swiper {
        width: 100%;
        max-width: 1728px;
        margin-left: auto;
        margin-right: auto;
    }
    .footer-inner { max-width: 1728px; margin-left: auto; margin-right: auto; width: 100%; box-sizing: border-box; }
    .footer-copyright { max-width: 1728px; margin-left: auto; margin-right: auto; }
    .footer-nav { justify-content: flex-end; }
    .footer-nav-columns { justify-content: flex-end; }
    .news-archive-wrapper .news-archive-header,
    .brands-page-header, .brand-single-header, .company-page-header,
    .message-page-header, .vision-page-header, .outline-page-header,
    .contact-page-header, .privacy-page-header, .recruit-entry-page-header { max-width: 100%; box-sizing: border-box; }
    .slider-block, .news-block::before, .company-recruit-bg { max-width: 100%; box-sizing: border-box; }
}

@media (min-width: 1025px) {
    .news-archive-wrapper .news-archive-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .news-archive-wrapper .news-archive-title { font-size: 60px; }
    .news-archive-wrapper .news-archive-sub { font-weight: 600; }
    .brands-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .brands-page-title { font-size: 60px; }
    .brands-page-sub { font-weight: 600; }
    .brand-single-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .brand-single-title { font-size: 60px; }
    .brand-single-sub { font-weight: 600; }
    .outline-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .outline-page-title { font-size: 60px; }
    .outline-page-sub { font-weight: 600; }
    .outline-page-header-section { margin-left: 0; }
    .outline-info-item { padding-top: 30px; padding-bottom: 30px; }
    .recruit-entry-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .recruit-entry-page-title { font-size: 60px; }
    .recruit-entry-page-sub { font-weight: 600; }
    .recruit-entry-page-instructions { margin-left: 180px; margin-right: 180px; }
    .contact-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .contact-page-title { font-size: 60px; }
    .contact-page-sub { font-weight: 600; }
    .contact-page-instructions { margin-left: 180px; margin-right: 180px; }
    .privacy-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .privacy-page-title { font-size: 60px; }
    .privacy-page-sub { font-weight: 600; }
    .vision-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .vision-page-title { font-size: 60px; }
    .vision-page-sub { font-weight: 600; }
    .vision-section-header { margin-left: 0; }
    .vision-section-quote { font-weight: 600; }
    .vision-section-1 { margin-bottom: 140px; }
    .vision-section-2 .vision-section-content-wrapper { order: 1; width: 520px;  max-width: 520px; min-width: 0; }
    .vision-section-2 .vision-section-image { order: 2; width: 560px; height: 385px; flex: 0 0 560px; max-width: 560px; margin-left: auto; }
    .message-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .message-page-title { font-size: 60px; }
    .message-page-sub { font-weight: 600; }
    .message-page-text-sp { display: none !important; }
    .message-page-text-pc { display: block !important; }
    .message-page-quote-sp { display: none !important; }
    .message-page-quote-pc { display: block !important; text-align: left; }
    .company-page-header { width: 100vw; margin-left: calc(50% - 50vw); padding-left: 140px; padding-right: 140px; box-sizing: border-box; }
    .company-page-title { font-size: 60px; }
    .company-page-sub { font-weight: 600; }
    .company-philosophy-block { display: none; }
    .company-cards-section { margin-top: 0; margin-bottom: 150px; }
    .company-cards-section .container { margin-left: 140px; margin-right: 140px; }
    .company-card { width: 360px; height: 280px; flex: 0 0 auto; min-width: 360px; max-width: 360px; }
    .company-card-title-en { text-align: center; margin-top: 50px; }
    .company-card-title-ja { text-align: center; }
    .company-card-link { margin-top: 12px; margin-bottom: 10px; }
    .brand-single-main { margin-top: 120px; margin-bottom: 120px; display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 0 60px; height: 430px; }
    .brand-single-main .brand-single-name { grid-column: 1; grid-row: 1; align-self: end; margin-bottom: 70px; }
    .brand-single-main .brand-single-image { grid-column: 2; grid-row: 1 / -1; justify-self: end; width: 640px; height: 425px; margin-bottom: 0; align-self: stretch; }
    .brand-single-main .brand-single-image img { width: 100%; height: 100%; object-fit: cover; }
    .brand-single-main .brand-single-content { grid-column: 1; grid-row: 2; align-self: start; min-height: 0; overflow-y: auto; width: 370px; margin-top: -40px; }
    .brand-stores-region-list { flex-direction: column; justify-content: flex-start; align-items: flex-start; }
    .brand-other-title { font-size: 24px; }
    .brand-other-card { border-radius: 20px; gap: 40px; }
    .brand-other-image img { border-radius: 20px; }
    .brand-other-image { padding: 0; width: 320px; height: 220px; aspect-ratio: unset; }
    .brand-other-desc { margin: 0; display: flex; align-items: center; }
    .brand-other-name { text-align: left; margin-top: 16px; margin-bottom: 0; }
    .brand-other-link { align-self: flex-end; }
    .news-archive-wrapper .news-archive-content { margin-top: 120px; }
    .news-archive-wrapper .news-archive-category-list { grid-template-columns: 1fr; justify-items: start; }
    .news-archive-wrapper .news-archive-sidebar-title { font-size: 28px; }
}

/* パンくず: 画面幅が十分広いときだけ左に寄せる（小さいPCでははみ出さないように） */
@media (min-width: 1401px) {
    .breadcrumb { margin-left: -60px; }
}

/* Company cards: PC 幅が小さいときも 1 行で収まり画面からはみ出さないように調整 */
@media (min-width: 1025px) and (max-width: 1400px) {
    .company-cards-section .container {
        margin-left: 80px;
        margin-right: 80px;
    }
    .company-cards {
        flex-wrap: nowrap;
        justify-content: center;
        gap: 20px;
    }
    .company-card {
        width: 320px;
        min-width: 320px;
        max-width: 320px;
        height: 260px;
    }
}

/* Brand Single: PC 幅が小さいときに画像が画面外に見切れないよう調整 */
@media (min-width: 1025px) and (max-width: 1400px) {
    .brand-single-main {
        margin-top: 100px;
        margin-bottom: 100px;
        grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
        gap: 0 40px;
        height: auto;
    }
    .brand-single-main .brand-single-image {
        width: 100%;
        max-width: 480px;
        height: auto;
        aspect-ratio: 4/3;
        justify-self: end;
        margin-bottom: 0;
    }
    .brand-single-main .brand-single-image img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .brand-single-main .brand-single-content {
        width: auto;
        max-width: 420px;
        margin-top: -20px;
    }
    .brands-intro-text { font-size: 20px; font-weight: 700; }
    .brands-page-wrapper .brands-page-intro-text { font-weight: 700; }
    .brands-page-wrapper .brands-page-intro { margin-bottom: 120px; }
    .brands-page-wrapper .brands-page-card { height: auto; }
    .brands-page-wrapper .brands-page-card-desc { flex: none; }
    .brands-page-wrapper .brands-page-showcase { margin-bottom: 150px; }
    /* 以下の Recruit TOP PC 用スタイルは 1025px 以上全体に適用するため、
       別の @media (min-width: 1025px) ブロックに再定義しています */
    .menu-toggle { display: none !important; }
    .nav { display: flex !important; visibility: visible !important; position: static !important; right: auto !important; width: auto !important; max-width: none !important; height: 50px !important; padding: 0 !important; box-shadow: 0 0 15px -6px #777777; }
    .nav-recruit { display: flex !important; visibility: visible !important; position: static !important; right: auto !important; width: auto !important; max-width: none !important; height: auto !important; padding: 0 !important; }
    .nav .menu > li { opacity: 1 !important; transform: none !important; transition: none !important; }
    .nav-recruit .menu-recruit > li { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* Recruit TOP: PC デザイン（1025px 以上共通） */
@media (min-width: 1025px) {
    .recruit-hero { height: 800px; position: relative; z-index: 20; }
    .recruit-hero-container { position: relative; height: 100%; }
    .recruit-hero-image { position: absolute; top: 0; left: 0; right: 0; bottom: 0; width: 100%; height: 100%; z-index: 0; }
    .recruit-hero-image img { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
    .recruit-hero-text { position: absolute; bottom: 0; left: 0; height: 270px; width: 660px; padding: 0 0 20px; z-index: 30; display: flex; align-items: center; }
    .recruit-hero-text-img { width: 100%; height: 100%; object-fit: contain; display: block; margin-top: 24px; }

    .recruit-about { padding: 150px 0 200px; position: relative; z-index: 0; }
    .recruit-about .container { margin-left: 80px; margin-right: 80px; }

    .recruit-know { padding: 80px 0 150px; }
    .recruit-know-header { margin-bottom: 100px; text-align: center; }
    .recruit-know-title { font-size: 50px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0 0 8px; }
    .recruit-know-sub { font-size: 20px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); }
    .recruit-know-cards { display: flex; gap: 25px; justify-content: center; flex-wrap: nowrap; }
    .recruit-know-card { width: 370px; height: 260px; flex: none; background: #fff; border-radius: 8px; padding: 0; text-decoration: none; color: #222; transition: box-shadow 0.2s, opacity 0.5s; position: relative; overflow: hidden; display: flex; flex-direction: column; justify-content: center; align-items: center; }
    .recruit-know-card-content { display: flex; flex-direction: column; align-items: center; justify-content: center; width: 100%; height: 100%; position: relative; }
    .recruit-know-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background-image: linear-gradient(to right, transparent 10px, rgba(0,180,227,0.3) 11px), linear-gradient(to bottom, transparent 10px, rgba(0,180,227,0.3) 11px); background-size: 11px 11px; pointer-events: none; z-index: 0; }
    .recruit-know-card:hover { box-shadow: 0 8px 24px rgba(0,0,0,.12); opacity: 0.6; }
    .recruit-know-card-label { font-size: 20px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); margin: 0 0 20px 20px; position: absolute; top: 20px; left: 0; z-index: 1; }
    .recruit-know-card-title { font-size: 60px; font-weight: 700; color: #00B4E3; letter-spacing: var(--ls-wide); margin: 0; text-align: center; z-index: 1; line-height: 1.2; }
    .recruit-know-card-subtitle { font-size: 28px; font-weight: 700; color: #222; letter-spacing: var(--ls-wide); margin: 0; text-align: center; z-index: 1; margin-top: 8px; }
    .recruit-know-card-title + .recruit-know-card-subtitle { margin-top: 8px; }
    .recruit-know-card-link { display: inline-flex; align-items: center; gap: 8px; color: #00B4E3; text-decoration: none; font-weight: 700; font-size: 22px; position: absolute; bottom: 20px; left: 50%; transform: translateX(-50%); z-index: 1; justify-content: center; margin: 0; }
    .recruit-know-card-icon { width: 22px; height: 22px; border: 1px solid #00B4E3; border-radius: 50%; background: transparent; display: inline-block; position: relative; flex-shrink: 0; }
    .recruit-know-card-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }
    @media (min-width: 1025px) and (max-width: 1400px) {
        .recruit-know-cards { gap: 20px; width: 100%; }
        .recruit-know-card { width: calc((100% - 40px) / 3); max-width: 370px; min-width: 0; height: auto; aspect-ratio: 370 / 260; }
        .recruit-know-card-label { font-size: clamp(14px, 1.4vw, 20px); margin: 0 0 16px 16px; top: 16px; white-space: nowrap; }
        .recruit-know-card-title { font-size: clamp(40px, 4vw, 60px); white-space: nowrap; }
        .recruit-know-card-subtitle { font-size: clamp(18px, 2vw, 28px); white-space: nowrap; }
        .recruit-know-card-link { font-size: clamp(16px, 1.6vw, 22px); bottom: 16px; white-space: nowrap; }
    }
    @media (min-width: 1025px) and (max-width: 1200px) {
        .recruit-know-cards { gap: 16px; }
        .recruit-know-card { width: calc((100% - 32px) / 3); }
        .recruit-know-card-title { font-size: clamp(34px, 3.6vw, 50px); }
        .recruit-know-card-subtitle { font-size: clamp(16px, 1.7vw, 22px); }
        .recruit-know-card-link { font-size: clamp(14px, 1.4vw, 18px); gap: 6px; }
        .recruit-know-card-icon { width: 18px; height: 18px; }
        .recruit-know-card-icon::after { border-left-width: 5px; border-top-width: 3px; border-bottom-width: 3px; }
    }

    .recruit-interview { padding: 150px 0 150px; position: relative; display: flex; flex-direction: column; align-items: center; }
    .recruit-interview > .container { width: 100%; align-self: stretch; margin: 0; }
    .recruit-interview-header { margin-bottom: 0; text-align: center; padding-left: 140px; padding-right: 80px; }
    .recruit-interview-header-img { display: block; width: 100%; height: auto; max-width: 100%; margin: 0; }
    .recruit-interview-cards-wrapper { position: relative; margin-bottom: 40px; width: 100%; box-sizing: border-box; overflow: visible; display: flex; flex-direction: column; align-items: center; }
    .recruit-interview-cards-wrapper .container { margin-left: 80px; margin-right: 80px; }
    .recruit-interview-cards-wrapper .recruit-interview-cards {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        gap: 24px;
        align-items: stretch;
        justify-content: flex-start;
        overflow-x: visible;
    }
    .recruit-interview-card {
        display: block !important;
        flex: none !important;
        flex-basis: 400px !important;
        flex-grow: 0 !important;
        flex-shrink: 0 !important;
        min-width: 400px !important;
        max-width: 400px !important;
        width: 400px !important;
        min-height: 540px !important;
        height: auto !important;
        float: none !important;
        clear: none !important;
        box-sizing: border-box !important;
        background: transparent;
        border-radius: 12px;
        overflow: visible;
        box-shadow: none;
        transition: transform 0.2s, opacity 0.5s;
        position: relative;
    }
    a.recruit-interview-card { color: inherit; text-decoration: none; }
    .recruit-interview-card:hover { opacity: 0.6; }
    .recruit-interview-card-image { width: 100%; height: auto; overflow: hidden; position: relative; z-index: 1; border-radius: 12px 12px 0 12px; background: transparent; isolation: isolate; display: flex; align-items: center; justify-content: center; }
    .recruit-interview-cards-wrapper .recruit-interview-card-image img { width: auto !important; height: auto !important; max-width: 100% !important; max-height: 100% !important; object-fit: contain !important; display: block; border-radius: 0; border: none; outline: none; margin: 0; vertical-align: bottom; }
    .recruit-interview-card-image img.attachment-card.size-card.wp-post-image { width: auto !important; height: auto !important; max-width: 100% !important; object-fit: contain !important; margin: 0 !important; }
    .recruit-interview-bg-text { position: absolute; right: 0; top: 50%; transform: translateY(-50%); z-index: 0; pointer-events: none; height: auto; max-width: 100%; opacity: 0.3; }

    .recruit-join { padding: 160px 0 200px; }
    .recruit-join-content { display: flex; align-items: center; gap: 40px; }
    .recruit-join-title-wrapper { width: calc((100% - 40px) / 3 * 2); flex: 0 0 calc((100% - 40px) / 3 * 2); position: relative; }
    .recruit-join-title { margin: 0; display: block; height: auto; width: 650px; max-width: 100%; position: relative; z-index: 1; }
    .recruit-join-buttons { display: flex; flex-direction: column; gap: 16px; width: calc((100% - 40px) / 3); flex: 0 0 calc((100% - 40px) / 3); min-width: 0; }
    .recruit-join-button { display: flex; align-items: center; justify-content: space-between; background: #ccf0f9; border-radius: 8px; padding: 20px 24px; text-decoration: none; color: #00b4e3; font-weight: 700; font-size: 24px; letter-spacing: var(--ls-wide); transition: opacity 0.5s; width: 100%; max-width: 100%; min-width: 0; height: 100px; box-sizing: border-box; }
    .recruit-join-button:hover { opacity: 0.6; }
    .recruit-join-button-icon { width: 22px; height: 22px; border: 1px solid #00B4E3; border-radius: 50%; display: inline-block; position: relative; flex-shrink: 0; }
    .recruit-join-button-icon::after { content: ''; position: absolute; top: 50%; left: 50%; width: 0; height: 0; border-left: 6px solid #00B4E3; border-top: 4px solid transparent; border-bottom: 4px solid transparent; transform: translate(-50%, -50%); }
}

/* Recruit TOP: 狭いPC幅でもカード3枚を横1列で画面内に収める調整 */
@media (min-width: 1025px) and (max-width: 1400px) {
    .recruit-interview-cards-wrapper .recruit-interview-cards {
        flex-wrap: nowrap;
        justify-content: center;
    }

    .recruit-interview-cards-wrapper .recruit-interview-cards .recruit-interview-card {
        flex: 0 1 calc((100% - 48px) / 3) !important;
        max-width: calc((100% - 48px) / 3) !important;
        min-width: 0 !important;
        width: auto !important;
        height: auto !important;
        min-height: 0 !important;
    }
}

/* Hamburger Menu Responsive (共通 PC→SP 切替) */
@media (max-width: 1024px) {
    /* 横スクロール禁止：はみ出しをクリップ（clip でスクロール不可を強制） */
    html { overflow-x: hidden; overflow-x: clip; width: 100%; max-width: 100%; }
    body { overflow-x: hidden; overflow-x: clip; max-width: 100%; width: 100%; min-width: 0; }
    main { overflow-x: hidden; overflow-x: clip; max-width: 100%; width: 100%; min-width: 0; }
    main > .container { overflow-x: hidden; max-width: 100%; box-sizing: border-box; }
    /* 共通: スマホヘッダー - 白地、左下・右下のみ角丸、ロゴ左・ハンバーガー右 */
    .header { background: #fff !important; border-radius: 0; border-bottom-left-radius: 16px; border-bottom-right-radius: 16px; box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08); padding-top: 0; height: 60px; }
    .header .container { margin-left: 16px; margin-right: 16px; padding: 0; }
    .header-recruit { border-radius: 0; border-bottom-left-radius: 16px; border-bottom-right-radius: 16px; height: 60px; padding: 0; }
    .header-recruit .container { margin-left: 16px; margin-right: 16px; padding: 0 16px; }
    .header-recruit-logo { margin-left: 0; }
    .logo img { height: 36px !important; }
    .logo-recruit img { height: 28px !important; }
    .menu-toggle { display: flex; }
    .menu-toggle-line { background: #00B4E3 !important; }
    .menu-toggle-recruit .menu-toggle-line { background: #00B4E3 !important; }
    .nav { visibility: hidden; position: fixed; top: 0; right: -100%; width: 72%; max-width: 280px; height: 100vh; background: #fafafa; box-shadow: -4px 0 24px rgba(0,0,0,.12); flex-direction: column; align-items: stretch; padding: 0; transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0.35s; z-index: 1000; overflow-y: auto; overflow-x: hidden; border-left: 4px solid #00B4E3; border-radius: 16px 0 0 16px; }
    .nav.is-open { right: 0; visibility: visible; transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0s; }
    .nav .menu { flex-direction: column; gap: 0; width: 100%; padding: 72px 0 32px; }
    .nav .menu > li { width: 100%; opacity: 0; transform: translateX(20px); transition: opacity 0.3s ease 0.1s, transform 0.3s ease 0.1s; }
    .nav.is-open .menu > li { opacity: 1; transform: translateX(0); }
    .nav.is-open .menu > li:nth-child(1) { transition-delay: 0.12s; }
    .nav.is-open .menu > li:nth-child(2) { transition-delay: 0.16s; }
    .nav.is-open .menu > li:nth-child(3) { transition-delay: 0.2s; }
    .nav.is-open .menu > li:nth-child(4) { transition-delay: 0.24s; }
    .nav.is-open .menu > li:nth-child(5) { transition-delay: 0.28s; }
    .nav.is-open .menu > li:nth-child(6) { transition-delay: 0.32s; }
    .nav.is-open .menu > li:nth-child(7) { transition-delay: 0.36s; }
    .nav.is-open .menu > li:nth-child(8) { transition-delay: 0.4s; }
    .nav a { padding: 18px 24px; margin: 6px 16px 0; border-radius: 8px; text-align: left; font-size: 16px; min-height: 52px; display: flex; align-items: center; border: none; background: transparent; transition: background 0.2s ease, color 0.2s ease; }
    #menu-item-136 > a { padding: 24px 24px !important; }
    .nav a:hover { background: rgba(0, 180, 227, 0.5); }
    .nav a:active { background: rgba(0,180,227,.12); }
    .nav .menu > li:first-child a { margin-top: 0; border-top-right-radius: 0; }
    .nav .menu > li:last-child a { margin-bottom: 0; border-bottom-right-radius: 0; }
    .nav .nav__cta { background: #FCEE21 !important; color: #111 !important; margin: 16px 16px 0; font-weight: 700; box-shadow: 0 2px 8px rgba(252,238,33,.4); }
    .nav .nav__cta:hover { background: #f5e61a !important; }
    .nav .nav__cta:active { transform: scale(0.98); }
    .nav-overlay { visibility: hidden; position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,.45); backdrop-filter: blur(2px); z-index: 999; opacity: 0; transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0.35s; }
    .nav-overlay.is-open { visibility: visible; opacity: 1; transition: opacity 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0s; }
    
    .nav-recruit { visibility: hidden; position: fixed; top: 60px; right: -100%; width: 72%; max-width: 300px; height: calc(100vh - 60px); background: #fff; box-shadow: -8px 0 32px rgba(0,0,0,.12); flex-direction: column; align-items: stretch; justify-content: flex-start; padding: 0; transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0.35s; z-index: 1000; overflow-y: auto; overflow-x: hidden; margin-right: 0; border-left: 4px solid #00B4E3; border-radius: 16px 0 0 0; }
    .nav-recruit.is-open { right: 0; visibility: visible; transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1), visibility 0s 0s; }
    .menu-recruit { flex-direction: column; gap: 0; width: 100%; align-items: stretch; align-self: flex-start; padding: 24px 16px 16px; }
    .menu-recruit > li { width: 100%; opacity: 0; transform: translateX(16px); transition: opacity 0.3s ease 0.1s, transform 0.3s ease 0.1s; }
    .nav-recruit.is-open .menu-recruit > li { opacity: 1; transform: translateX(0); }
    .nav-recruit.is-open .menu-recruit > li:nth-child(1) { transition-delay: 0.08s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(2) { transition-delay: 0.12s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(3) { transition-delay: 0.16s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(4) { transition-delay: 0.2s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(5) { transition-delay: 0.24s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(6) { transition-delay: 0.28s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(7) { transition-delay: 0.32s; }
    .nav-recruit.is-open .menu-recruit > li:nth-child(8) { transition-delay: 0.36s; }
    .menu-recruit a { padding: 16px 20px; margin: 0 0 4px; border-radius: 10px; border: none; background: transparent; min-height: 48px; display: flex; align-items: center; transition: background 0.2s ease, color 0.2s ease; font-size: 16px; font-weight: 700; letter-spacing: var(--ls-wide); color: #222; }
    .menu-recruit a:hover { background: rgba(0, 180, 227, 0.5); }
    .menu-recruit a:active { background: rgba(0,180,227,.15); }
    .menu-recruit > li:first-child a { margin-top: 0; }
    .menu-recruit > li:last-child a { margin-bottom: 0; }
    .header-recruit-entry { position: fixed; top: auto; bottom: 0; right: -100%; width: 72%; max-width: 300px; padding: 20px 20px 24px; padding-bottom: calc(20px + env(safe-area-inset-bottom)); background: #fff; border-top: 1px solid rgba(0,180,227,.2); box-shadow: 0 -4px 20px rgba(0,0,0,.08); transition: right 0.35s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.3s ease; z-index: 1000; opacity: 0; box-sizing: border-box; }
    .nav-recruit.is-open ~ .header-recruit-entry { right: 0; opacity: 1; transition-delay: 0.2s; }
    .header-recruit-entry .recruit-entry-button { width: 100%; max-width: 100%; box-sizing: border-box; justify-content: center; min-height: 56px; height: 56px; border-radius: 12px; font-size: 18px; font-weight: 700; box-shadow: 0 4px 12px rgba(0,180,227,.25); }
    .header-recruit-entry .recruit-entry-button:hover { background: rgba(252, 238, 33, 0.55); color: #222; }
    .header-recruit-entry .recruit-entry-button:active { transform: scale(0.98); }
}

/* TOP Page Responsive Styles */
@media (max-width: 1024px) {
    .hero h1 { font-size: 56px !important; }
    .hero-sub { font-size: 22px !important; }
    .brands-intro { flex-direction: column; align-items: flex-start; gap: 24px; }
    .brands-intro-text { width: 100%; }
    .brand-item { flex-direction: column; }
    .brand-item-content { padding: 0 24px; }
    .brand-item-image { width: 100%; height: auto; }
    .madein-container { flex-direction: column; }
}

@media (max-width: 1024px) {
    /* 横スクロール完全防止：ルートでクリップ（後続の上書きに負けないよう !important） */
    html { overflow-x: clip !important; max-width: 100%; width: 100%; }
    body { overflow-x: clip !important; max-width: 100%; width: 100%; min-width: 0; }
    main { overflow-x: clip !important; max-width: 100%; width: 100%; min-width: 0; }
    main > .container { margin-left: 20px; margin-right: 20px; overflow-x: hidden; max-width: 100%; box-sizing: border-box; }
    .section { max-width: 100%; overflow-x: hidden; box-sizing: border-box; }
    .slider-block { max-width: 100%; width: 100%; overflow: hidden !important; overflow-x: hidden !important; min-width: 0; margin-left: 0; contain: layout style; }
    .slider-block .slider-block-swiper { overflow: hidden !important; overflow-x: hidden !important; width: 100%; min-width: 0; max-width: 100%; contain: layout style; }
    /* TOPページのみ：スライダーによる横スクロールを確実に防ぐ */
    body.home { overflow-x: hidden !important; overflow-x: clip !important; }
    body.home main { overflow-x: hidden !important; overflow-x: clip !important; }
    body.home main > .container { margin-left: 0; margin-right: 0; overflow-x: hidden !important; overflow-x: clip !important; }
    body.home .slider-block { display: grid; grid-template-columns: minmax(0, 1fr); overflow: hidden !important; overflow-x: clip !important; width: 100%; max-width: 100%; min-width: 0; }
    body.home .slider-block .slider-block-swiper { overflow: hidden !important; overflow-x: clip !important; width: 100%; max-width: 100%; min-width: 0; }
    body.home .philosophy-bg { margin-left: 20px; margin-right: 20px; }
    body.home .brands-head { margin-left: 20px; margin-right: 20px; }
    body.home .brands-intro { margin-left: 0; margin-right: 0; padding-left: 20px; padding-right: 20px; box-sizing: border-box; max-width: 100%; overflow: hidden; }
    body.home .brands-list { margin-left: 20px; }
    body.home .madein-container picture { margin-right: 20px; }
    .breadcrumb { margin-top: 70px !important; overflow: hidden; }
    .breadcrumb-list { flex-wrap: nowrap; overflow: hidden; min-width: 0; }
    .breadcrumb-list li { flex-shrink: 0; min-width: 0; }
    .breadcrumb-list li:last-child { flex-shrink: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
    .breadcrumb-list li + li::before { flex-shrink: 0; }
    .breadcrumb-list li a { white-space: nowrap; }
    .breadcrumb-list li:last-child a,
    .breadcrumb-list li:last-child .breadcrumb-text { display: block; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .news-single { padding-top: 60px; }
    .news-single-header { margin-bottom: 60px; }
    .news-single-content { margin-bottom: 0; }
    .news-single-footer { margin-top: 80px; margin-bottom: 100px; }
    .brands-page-wrapper .brands-page-intro { margin: 60px 0; }
    .brands-page-wrapper .brands-page-intro-title { font-size: 25px; margin-bottom: 60px; }
    .brands-page-wrapper .brands-page-intro-text { font-size: 15px; }
    .brands-page-wrapper .brands-page-intro-text br { display: none; }
    .news-archive-wrapper .news-archive-content { display: flex !important; flex-direction: column !important; gap: 80px !important; align-items: stretch !important; margin-top: 60px !important; padding-left: 10px !important; padding-right: 10px !important; width: 100% !important; box-sizing: border-box !important; }
    .news-archive-wrapper .news-archive-sidebar { width: 100% !important; }
    .news-archive-wrapper .news-archive-main { margin-bottom: 100px !important; width: 100% !important; min-width: 0 !important; box-sizing: border-box !important; }
    .news-archive-wrapper .news-archive-list { width: 100% !important; min-width: 0 !important; box-sizing: border-box !important; }
    .news-archive-wrapper .news-archive-pagination { margin-top: 80px !important; }
    body.recruit main > .container .breadcrumb,
    body.page-template-page-recruit main > .container .breadcrumb,
    body.post-type-archive-interview main > .container .breadcrumb { margin-top: 70px !important; }
    /* SPヒーロー: 横幅MAX・横スクロール禁止、縦700px、Swiperフェード */
    .hero { width: 100%; max-width: 100%; height: 700px; min-height: 700px; overflow: hidden; overflow-x: hidden; box-sizing: border-box; position: relative; }
    .hero-overlay { align-items: flex-end; justify-content: flex-start; padding-bottom: 240px; }
    .hero .edge-pad { height: auto; align-items: flex-end; }
    .hero h1 { font-size: 34px !important; line-height: 1.2 !important; }
    .hero-sub { font-size: 20px !important; margin-top: 12px !important; }
    .hero-overlay .edge-pad { padding: 0 16px; }
    .news-block { flex-direction: column; align-items: stretch; padding: 80px 20px !important; margin-left: 0; margin-right: 0; overflow-x: hidden; }
    .news-block::before { left: 0; width: 100%; }
    .news-head { margin-bottom: 40px; }
    .news-block .news-title { font-size: 40px !important; margin: 0; }
    .news-block .news-sub { font-size: 16px; color: #222; margin-top: 4px; }
    .news-content { width: 100%; text-align: left; display: flex; flex-direction: column; }
    .news-list { order: 1; margin: 0; padding: 0; }
    .news-block .news-list .news-item:nth-child(n+2) { display: none; }
    .news-viewall { order: 2; margin: 30px 0 0; margin-left: auto; padding-top: 0; border-top: none; }
    .news-item { display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto; gap: 8px 16px; padding: 20px 0; border-top: 1px solid rgba(0,0,0,.1); align-items: start; }
    .news-item:first-child { border-top: none; padding-top: 0; }
    .news-item-meta { grid-column: 1; grid-row: 1; }
    .news-link { grid-column: 1; grid-row: 2; }
    .news-arrow { grid-column: 2; grid-row: 2; align-self: center; justify-self: end; }
    .philosophy-block { margin-top: 100px; margin-bottom: 100px; }
    .philosophy-content { padding: 0; }
    .philosophy-block .philosophy-label,
    .philosophy-block .philosophy-title,
    .philosophy-block .philosophy-text,
    .philosophy-block .philosophy-cta { font-weight: 600; }
    .philosophy-label { font-size: 16px; margin-bottom: 0; }
    .philosophy-title-wrap { padding: 10px 0; }
    .philosophy-bg-img { max-width: 100%; }
    .philosophy-title { font-size: 36px !important; }
    .philosophy-text { font-size: 16px !important; margin-top: 20px; }
    .philosophy-cta { margin-top: 24px; }
    .slider-block { height: 220px; margin-top: 60px; margin-bottom: 100px; }
    .slider-block .slider-item,
    .slider-block .swiper-slide.slider-item { width: 220px; height: 220px; flex-shrink: 0; }
    .win-philosophy-visual-block { padding: 0 20px; margin: 0; }
    .brands-block { padding-top: 0 !important; padding-bottom: 0 !important; margin-bottom: 100px; }
    .brands-block .brands-head { margin-bottom: 40px; }
    .brands-block .brands-title { font-size: 40px !important; }
    .brands-block .brands-sub { font-size: 14px !important; }
    .brands-block .brands-intro { margin-bottom: 60px; gap: 24px; }
    .brands-block .brands-intro-text { font-size: 20px !important; font-weight: 700 !important; }
    .brands-block .brands-viewall { margin-left: auto; }
    .brands-block .brand-item { flex-direction: column; padding: 20px 40px 20px 20px; margin: 0; margin-right: 0; width: 100%; max-width: 100%; height: auto; border-radius: 16px; border-top-right-radius: 0; border-bottom-right-radius: 0; overflow: hidden; background: #f5f5f5; align-items: stretch; box-sizing: border-box; }
    .brands-block .brand-item::before, .brands-block .brand-item::after { display: none; }
    .brands-block .brand-item-content { order: 2; padding: 0; padding-bottom: 28px; min-height: auto; display: flex; flex-direction: column; box-sizing: border-box; }
    .brands-block .brand-item-image { order: 1; width: 100%; max-width: 100%; height: auto; aspect-ratio: 4/3; margin: 0; box-sizing: border-box; }
    .brands-block .brand-item-image img { border-radius: 16px; }
    .brands-block .brand-item-title { font-size: 24px; margin-bottom: 12px; }
    .brands-block .brand-item-desc { font-size: 14px; line-height: 1.8; margin-bottom: 20px; color: #555; }
    .brands-block .brand-item-link { font-size: 18px; margin-top: 0; margin-left: auto; margin-right: auto; }
    .madein-container { gap: 40px; }
    .madein-hero-img { margin-left: 0; width: 100%; max-width: 100%; }
    /* リクルートTOP SP: madein-block = ヘッダー(asset-9-2x) + 画像2のカード */
    body.recruit .recruit-interview.madein-block { padding-bottom: 0; }
    body.recruit .recruit-interview.madein-block > .container { margin-left: 0; margin-right: 0; padding: 0; padding-left: 30px; max-width: 100%; box-sizing: border-box; }
    body.recruit .recruit-interview.madein-block .madein-block-header { width: 100%; margin: 0; padding: 0; }
    body.recruit .recruit-interview.madein-block .madein-block-header picture { display: block; width: 100%; }
    body.recruit .recruit-interview.madein-block .madein-block-header .recruit-interview-header-img { display: block; width: 100%; height: auto; max-width: 100%; margin: 0; }
    body.recruit .recruit-interview.madein-block .recruit-interview-cards-wrapper { margin-top: 0; padding: 0; margin-left: 0 !important; padding-left: 0 !important; }
    body.recruit .recruit-interview-cards-wrapper .recruit-interview-cards { display: flex; flex-direction: column; gap: 30px; }
    body.recruit .recruit-interview.madein-block .recruit-interview-cards-wrapper .container { margin-left: 0 !important; margin-right: 0 !important; padding-left: 30px !important; padding-right: 30px !important; max-width: 100%; box-sizing: border-box; }
    body.recruit .recruit-interview.madein-block .recruit-interview-cards .recruit-interview-card { width: 100% !important; max-width: 400px !important; min-width: 0 !important; flex-basis: auto !important; min-height: 0 !important; margin-left: 0 !important; margin-right: 0 !important; }
    body.recruit .recruit-interview.madein-block .recruit-interview-card-image img { width: 100% !important; height: auto !important; max-width: 100% !important; object-fit: cover; min-height: 200px; margin-left: 0 !important; }
    .company-recruit-block { height: auto; min-height: 290px; padding-bottom: 100px; }
    .company-recruit-bg { height: 290px; }
    .company-recruit-bg-img { width: 100%; height: 290px; object-fit: cover; }
    .company-recruit-content { position: relative; left: auto; transform: none; bottom: auto; margin-top: 0; padding: 190px 30px 20px; max-width: none; }
    .company-recruit-cards { flex-direction: column; gap: 16px; align-items: stretch; }
    .company-recruit-card { height: 110px; min-height: 110px; flex: none; padding: 16px 20px; }
    .company-recruit-card-title { font-size: 32px; }
    .company-recruit-card-sub { font-size: 14px; }
    .company-recruit-card-link-text { display: none; }
    .company-recruit-icon { width: 30px; height: 30px; }
    /* Brand Single Page */
    .brand-single-main {
        flex-direction: column;
        margin: 60px -20px 80px;
        padding: 0 20px 0;
        width: calc(100% + 40px);
        box-sizing: border-box;
    }
    .brand-single-main .brand-single-name {
        color: #222;
        font-size: 28px;
        margin-bottom: 0;
    }
    .brand-single-main .brand-single-image {
        width: 100%;
        max-width: 100%;
        height: auto;
        aspect-ratio: 4/3;
        margin-bottom: 36px;
    }
    .brand-single-main .brand-single-image img {
        border-radius: 12px;
    }
    .brand-single-main .brand-single-content,
    .brand-single-main .brand-single-content p {
        color: #222;
        font-size: 15px;
        line-height: 1.8;
    }
    .brand-stores-section {
        margin: 0 -20px 80px;
        padding: 0 20px 0;
        width: calc(100% + 40px);
        box-sizing: border-box;
    }
    .brand-stores-content {
        display: grid;
        grid-template-columns: 1fr;
        gap: 60px;
        margin-top: 0;
        width: 100%;
    }
    .brand-stores-sidebar {
        width: 100%;
    }
    .brand-stores-main {
        width: 100%;
    }
    .brand-stores-sidebar-title {
        color: #222;
        font-size: 20px;
        margin-bottom: 20px;
    }
    .brand-stores-region-list {
        display: flex;
        flex-wrap: wrap;
        gap: 32px;
        justify-content: center;
    }
    .brand-stores-region-item {
        margin-bottom: 0;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    .brand-stores-region-item a {
        display: flex;
        align-items: center;
        gap: 8px;
        color: #888;
    }
    .brand-stores-region-item a::before {
        content: '';
        width: 12px;
        height: 12px;
        border: 2px solid #B0B0B0;
        border-radius: 50%;
        display: inline-block;
        flex-shrink: 0;
        box-sizing: border-box;
    }
    .brand-stores-region-item.active a {
        color: #333;
        font-weight: 500;
    }
    .brand-stores-region-item.active a::before {
        background: #00B4E3;
        border-color: #00B4E3;
    }
    .brand-stores-region-item a:hover {
        color: #00B4E3;
    }
    .brand-stores-region-item a:hover::before {
        border-color: #00B4E3;
    }
    .brand-stores-list {
        border-bottom: 1px solid rgba(0,0,0,.1);
        width: 100%;
    }
    .brand-store-item {
        padding: 20px 0;
        border-bottom: 1px solid rgba(0,0,0,.1);
    }
    .brand-store-item:last-child {
        border-bottom: none;
    }
    .brand-store-name {
        color: #222 !important;
        font-size: 15px;
    }
    .brand-store-postal,
    .brand-store-address,
    .brand-store-phone {
        color: #555 !important;
        font-size: 13px;
    }
    .brand-store-link {
        color: inherit;
    }
    .brand-store-link:hover {
        color: #00B4E3;
    }
    .brand-other-section {
        margin: 0 -20px 100px;
        padding: 0 20px 0;
        width: calc(100% + 40px);
        box-sizing: border-box;
    }
    .brand-other-content {
        flex-direction: column;
        gap: 24px;
        margin-top: 0;
    }
    .brand-other-sidebar {
        width: 100%;
    }
    .brand-other-title {
        color: #222;
        font-size: 22px;
        margin-bottom: 0;
    }
    .brand-other-main {
        display: flex;
        flex-direction: column;
        gap: 16px;
        align-items: center;
    }
    .brand-other-card {
        width: 100%;
        max-width: 520px;
        flex-direction: column;
        padding: 0;
        gap: 0;
        background: #efefef;
        box-shadow: 0 2px 8px rgba(0,0,0,.08);
    }
    .brand-other-image {
        width: 100%;
        aspect-ratio: 4/3;
        padding: 20px;
        box-sizing: border-box;
    }
    .brand-other-image img {
        border-radius: 8px 8px 0 0;
    }
    .brand-other-info {
        padding: 0 20px 20px;
        margin: 0;
    }
    .brand-other-name {
        color: #222;
        font-size: 20px;
        margin-bottom: 12px;
        text-align: center;
    }
    .brand-other-desc {
        color: #555;
        font-size: 15px;
        line-height: 1.7;
        margin-bottom: 16px;
    }
    .brand-other-link {
        font-size: 22px;
        align-self: center;
    }
}

@media (min-width: 769px) and (max-width: 1024px) {
    main > .container { margin-left: 80px; margin-right: 80px; }
    .brand-single-header { padding-left: 80px; padding-right: 80px; }
    .company-page-header { padding-left: 80px; padding-right: 80px; }
    .company-cards-section .container { margin-left: 80px; margin-right: 80px; }
    .message-page-header { padding-left: 80px; padding-right: 80px; }
    .message-cards-section .container { padding-left: 80px; padding-right: 80px; }
    .company-recruit-content { padding-left: 80px; padding-right: 80px; }
    .footer-nav { padding-left: 80px; padding-right: 80px; }
    .vision-page-header { padding-left: 80px; padding-right: 80px; }
    .vision-cards-section .container {padding-left: 80px; padding-right: 80px; }
    .vision-section-text {padding-left: 80px; padding-right: 80px; }
    .outline-page-header { padding-left: 80px; padding-right: 80px; }
    .outline-cards-section .container {padding-left: 80px; padding-right: 80px; }
    .contact-page-header { padding-left: 80px; padding-right: 80px; }
    .recruit-entry-page-header { padding-left: 80px; padding-right: 80px; }
    body.recruit .recruit-know .container {padding-left: 80px; padding-right: 80px; }
    body.recruit .recruit-join .container {padding-left: 80px; padding-right: 80px; }
    .recruit-page-hero .container {padding-left: 80px; padding-right: 80px; }
    .recruit-page-content .container {padding-left: 80px; padding-right: 80px; }
    .recruit-page-seeks-inner {margin-left: 80px; margin-right: 80px; }
    .recruit-interview-hero .container {margin-left: 80px; margin-right: 80px; }
    .recruit-interview-questions .container {margin-left: 80px; margin-right: 80px; }
    .recruit-interview-message .container {margin-left: 80px; margin-right: 80px; }
    body.single-interview .recruit-interview-others .container{padding-left: 80px!important; padding-right: 80px !important; padding-top: 60px !important; padding-bottom: 60px !important;}
}

@media (max-width: 768px) {
    .recruit-works-section { margin-top: 60px; }
    .recruit-works-business-grid { row-gap: 30px; }
    .recruit-page-content .container { margin-left: 40px !important; margin-right: 40px !important; }
}


@media (min-width: 1025px) and (max-width: 1360px) {
    .vision-section-row-1,
    .vision-section-row-2 {
        flex-direction: column;
        align-items: stretch;
        gap: 32px;
    }
    .vision-section-row-1 { margin-bottom: 80px; }
    .vision-section-header,
    .vision-section-quote,
    .vision-section-text,
    .vision-section-image {
        width: 100%;
        max-width: 760px;
        margin-left: auto;
        margin-right: auto;
    }
    .vision-section-2 {
        flex-direction: column;
        align-items: stretch;
        gap: 32px;
    }
    .vision-section-2 .vision-section-image {
        order: 1;
        width: 100%;
        max-width: 760px;
        height: auto;
        flex: none;
        margin-left: auto;
        margin-right: auto;
    }
    .vision-section-2 .vision-section-image img {
        width: 100%;
        height: auto;
    }
    .vision-section-2 .vision-section-content-wrapper {
        order: 2;
        width: 100%;
        max-width: 760px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media (min-width: 600px) and (max-width: 1024px) {
    body.recruit .recruit-hero {
        height: 1050px;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .recruit-interview-message .container{margin-left: 180px; margin-right: 180px; }
}

@media (min-width: 600px) and (max-width: 768px) {
  .recruit-interview-message .container{margin-left: 120px; margin-right: 120px; }
  body.single-interview .recruit-interview-others .container{padding-left: 60px!important; padding-right: 60px !important;}
}

@media (max-width: 599px) {
  .recruit-page-content .container { margin-left: 35px !important; margin-right: 35px !important; }
  body.single-interview .recruit-interview-others .container{padding-left: 15px!important; padding-right: 15px !important;}
}