.recruitPage{
  --recruit-red:#b4432f;
  --recruit-navy:#003f50;
  --recruit-light:#e9e9e9;
  --recruit-yellow:#dfe63a;
  --recruit-text:#111;
  --recruit-white:#fff;
  --privacy-bg:#e9e9e9;
  --privacy-text:#111;
  --privacy-line:#000;
  font-family:"LINE Seed JP","Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  background:#000;
  color:#fff;
}

.recruitPage *,
.recruitPage *::before,
.recruitPage *::after{
  box-sizing:border-box;
}

.recruitPage strong,
.recruitPage b{
  font-family:"LINE Seed JP","Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
}

.recruitWrap{
  width:min(1920px, 100%);
  margin:0 auto;
}

.recruitInner{
  width:min(1760px, calc(100% - 40px));
  margin:0 auto;
}

.recruitWide{
  width:min(1920px, calc(100% - 40px));
  margin:0 auto;
}

.recruitHero{
  position:relative;
  min-height:clamp(420px, 56vw, 700px);
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  background:
    linear-gradient(to top, rgba(10,10,10,.82), rgba(10,10,10,.28)),
    url('https://images.unsplash.com/photo-1514525253161-7a46d19cd819?q=80&w=2000&auto=format&fit=crop') center/cover no-repeat;
}

.recruitHero__inner{
  position:relative;
  z-index:1;
  width:min(1760px, calc(100% - 40px));
  margin:0 auto;
  padding:0 0 26px;
}

.recruitHero__title{
  margin:0;
  padding-left:24px;
  color:#fff;
  font-size:clamp(52px, 5vw, 96px);
  line-height:1;
  letter-spacing:.02em;
  text-shadow:0 8px 24px rgba(0,0,0,.28);
}

.recruitLead{
  background:
    linear-gradient(90deg,
      rgba(170,67,48,.98) 0%,
      rgba(128,72,64,.92) 34%,
      rgba(10,65,80,.96) 66%,
      rgba(8,58,71,.98) 100%);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}

.recruitLead__grid{
  min-height:220px;
  display:grid;
  grid-template-columns:1.08fr 250px 1.18fr;
  gap:28px;
  align-items:center;
  padding:20px 24px;
}

.recruitLead__copy{
  margin:0;
  color:#fff;
  font-size:clamp(34px, 2.5vw, 64px);
  line-height:1.14;
  letter-spacing:.01em;
}

.recruitLead__badge{
  width:200px;
  height:200px;
  margin:0 auto;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--recruit-red);
  color:#fff;
  text-align:center;
  font-size:clamp(24px, 1.8vw, 48px);
  line-height:1;
}

.recruitLead__info{
  color:#fff;
  font-size:clamp(17px, 1vw, 26px);
  line-height:1.6;
}

.recruitLead__info strong{
  display:block;
  margin-bottom:8px;
  font-size:clamp(20px, 1.35vw, 34px);
  line-height:1.4;
}

.recruitLead__list{
  margin:10px 0 0;
  padding:0;
  list-style:none;
}

.recruitLead__list li{
  display:inline-block;
  margin:6px 0;
  padding-bottom:4px;
  border-bottom:4px solid var(--recruit-yellow);
  font-size:clamp(16px, .98vw, 24px);
  line-height:1.4;
}

.recruitJobTop{
  width:min(1920px, calc(100% - 40px));
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
}

.recruitJobTop__card{
  min-height:480px;
  padding:34px 20px 28px;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
}

.recruitJobTop__card--black{
  background:#000;
  color:#fff;
}

.recruitJobTop__card--navy{
  background:var(--recruit-navy);
  color:#fff;
}

.recruitJobTop__card--light{
  background:var(--recruit-light);
  color:var(--recruit-navy);
}

.recruitJobTop__card--red{
  background:var(--recruit-red);
  color:#fff;
}

.recruitJobTop__circle{
  width:min(260px, 72%);
  aspect-ratio:1 / 1;
  border-radius:50%;
  display:grid;
  place-items:center;
  margin:0 auto 24px;
  overflow:hidden;
}

.recruitJobTop__card--black .recruitJobTop__circle{
  background:#003f50;
}

.recruitJobTop__card--navy .recruitJobTop__circle{
  background:#efefef;
}

.recruitJobTop__card--light .recruitJobTop__circle{
  background:var(--recruit-red);
}

.recruitJobTop__card--red .recruitJobTop__circle{
  background:#000;
}

.recruitJobTop__circle img{
  width:72%;
  height:auto;
  display:block;
  object-fit:contain;
}

.recruitJobTop__title{
  margin:0 0 14px;
  font-size:clamp(28px, 2vw, 56px);
  line-height:1.1;
  letter-spacing:.01em;
}

.recruitJobTop__desc{
  margin:0;
  max-width:88%;
  font-size:clamp(15px, .9vw, 21px);
  line-height:1.7;
}

.recruitInfoGrid{
  width:min(1920px, calc(100% - 40px));
  margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:12px;
  padding:16px 0 24px;
  background:#000;
}

.recruitInfoCard{
  background:#ebebeb;
  border-radius:16px;
  padding:20px 22px 24px;
  min-height:440px;
  color:#000;
  position:relative;
}

.recruitInfoCard__pill{
  width:min(270px, 82%);
  margin:0 auto 34px;
  background:var(--recruit-navy);
  color:#fff;
  border-radius:999px;
  padding:15px 20px;
  text-align:center;
  font-size:clamp(16px, .95vw, 22px);
  line-height:1.2;
}

.recruitInfoCard__title{
  margin:0 0 10px;
  font-size:clamp(28px, 1.7vw, 48px);
  line-height:1.18;
  color:#000;
}

.recruitInfoCard__text{
  margin:0;
  font-size:clamp(15px, .92vw, 21px);
  line-height:1.7;
  color:#000;
}

.recruitQualification{
  padding:22px 20px 30px;
  background:#fff;
}

.recruitQualification__frame{
  position:relative;
  border:14px solid var(--recruit-red);
  padding:82px 30px 50px;
  background:#fff;
  text-align:center;
}

.recruitQualification__label{
  position:absolute;
  left:50%;
  top:0;
  transform:translate(-50%, 0%);
  width:min(720px, calc(100% - 70px));
  background:var(--recruit-red);
  color:#fff;
  text-align:center;
  padding:16px 22px;
  font-size:clamp(30px, 2.4vw, 58px);
  line-height:1.1;
  letter-spacing:.02em;
}

.recruitQualification__age{
  margin:0 0 8px;
  color:var(--recruit-red);
  font-size:clamp(50px, 3.4vw, 82px);
  line-height:1.05;
}

.recruitQualification__lead{
  margin:0 0 42px;
  color:var(--recruit-red);
  font-size:clamp(22px, 1.45vw, 34px);
  line-height:1.2;
}

.recruitQualification__body{
  max-width:1240px;
  margin:0 auto;
  color:var(--recruit-red);
  font-size:clamp(18px, 1.2vw, 28px);
  line-height:1.65;
}

.recruitBottom{
  padding:48px 0 0;
  background:#000;
  color:#111;
}

.recruitBottom__inner{
  width:min(980px, calc(100% - 32px));
  margin:0 auto;
  background:#fff;
  padding:30px 24px 34px;
}

.recruitSectionHead{
  margin:0 0 24px;
  text-align:center;
}

.recruitSectionHead__en{
  margin:0 0 8px;
  color:var(--recruit-red);
  font-size:13px;
  letter-spacing:.18em;
}

.recruitSectionHead__ja{
  margin:0;
  color:#111;
  font-size:clamp(26px, 1.8vw, 38px);
  line-height:1.2;
}

.recruitForm{
  display:grid;
  gap:14px;
}

.recruitFormRow{
  display:grid;
  gap:10px;
}

.recruitFormLabel{
  font-size:13px;
  color:#222;
  letter-spacing:.04em;
}

.recruitRequired{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:34px;
  padding:2px 8px;
  margin-left:8px;
  background:var(--recruit-red);
  color:#fff;
  font-size:10px;
  line-height:1.6;
  vertical-align:middle;
}

.recruitForm input,
.recruitForm select,
.recruitForm textarea{
  width:100%;
  appearance:none;
  border:1px solid #d7d0c9;
  background:#fff;
  border-radius:0;
  padding:16px 14px;
  font-family:"LINE Seed JP","Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:15px;
  color:#111;
  outline:none;
}

.recruitForm select{
  background-image:
    linear-gradient(45deg, transparent 50%, #666 50%),
    linear-gradient(135deg, #666 50%, transparent 50%);
  background-position:
    calc(100% - 20px) calc(50% - 3px),
    calc(100% - 14px) calc(50% - 3px);
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
  padding-right:42px;
}

.recruitForm input:focus,
.recruitForm select:focus,
.recruitForm textarea:focus{
  border-color:var(--recruit-red);
}

.recruitForm textarea{
  min-height:180px;
  resize:vertical;
}

.recruitFormNote{
  margin:4px 0 0;
  font-size:12px;
  line-height:1.8;
  color:#666;
}

.recruitForm button{
  width:100%;
  border:none;
  border-radius:0;
  padding:18px 20px;
  background:var(--recruit-red);
  color:#fff;
  font-family:"LINE Seed JP","Noto Sans JP","Hiragino Sans","Yu Gothic",sans-serif;
  font-size:15px;
  letter-spacing:.08em;
  cursor:pointer;
  transition:opacity .2s ease;
  margin-top:6px;
}

.recruitForm button:hover{
  opacity:.88;
}

.recruitPrivacy{
  margin-top:40px;
  background:var(--privacy-bg);
  color:var(--privacy-text);
  padding:44px 0 46px;
}

.recruitPrivacy__inner{
  width:min(1240px, calc(100% - 56px));
  margin:0 auto;
}

.recruitPrivacy__head{
  display:grid;
  grid-template-columns:220px 1fr;
  gap:24px;
  align-items:start;
  margin-bottom:34px;
}

.recruitPrivacy__titleWrap{
  width:100%;
}

.recruitPrivacy__title{
  margin:0 0 10px;
  font-size:clamp(20px, 1.35vw, 30px);
  line-height:1.25;
  letter-spacing:.02em;
  color:#000;
}

.recruitPrivacy__titleLine{
  width:100%;
  height:5px;
  background:var(--privacy-line);
}

.recruitPrivacy__lead{
  margin:0;
  font-size:clamp(13px, .82vw, 16px);
  line-height:1.85;
  color:#000;
}

.recruitPrivacy__grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1fr);
  column-gap:52px;
  row-gap:26px;
  align-items:start;
}

.recruitPrivacy__col{
  display:grid;
  gap:26px;
  align-content:start;
}

.recruitPrivacy__block{
  display:grid;
  gap:8px;
}

.recruitPrivacy__heading{
  margin:0;
  font-size:clamp(14px, .92vw, 18px);
  line-height:1.5;
  color:#000;
}

.recruitPrivacy__text{
  margin:0;
  font-size:clamp(12px, .8vw, 15px);
  line-height:1.9;
  color:#000;
}

.recruitPrivacy__list{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:2px;
}

.recruitPrivacy__list li{
  font-size:clamp(12px, .8vw, 15px);
  line-height:1.9;
  color:#000;
}

@media (max-width:1200px){
  .recruitLead__grid{
    grid-template-columns:1fr;
    text-align:center;
    padding:24px 20px 28px;
  }

  .recruitLead__badge{
    width:172px;
    height:172px;
  }

  .recruitJobTop{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .recruitInfoGrid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }

  .recruitPrivacy__head{
    grid-template-columns:1fr;
    gap:18px;
    margin-bottom:28px;
  }

  .recruitPrivacy__titleWrap{
    max-width:260px;
  }

  .recruitPrivacy__grid{
    column-gap:28px;
  }
}

@media (max-width:768px){
  .recruitInner,
  .recruitWide{
    width:min(100%, calc(100% - 24px));
  }

  .recruitHero{
    min-height:56svh;
  }

  .recruitHero__inner{
    width:min(100%, calc(100% - 24px));
  }

  .recruitHero__title{
    padding-left:8px;
    font-size:52px;
  }

  .recruitLead__grid{
    gap:18px;
    padding:18px 14px 22px;
  }

  .recruitLead__copy{
    font-size:28px;
    text-align:left;
  }

  .recruitLead__badge{
    width:132px;
    height:132px;
    font-size:18px;
  }

  .recruitLead__info{
    font-size:14px;
    text-align:left;
  }

  .recruitLead__info strong{
    font-size:18px;
  }

  .recruitLead__list li{
    font-size:14px;
    border-bottom-width:3px;
  }

  .recruitJobTop{
    width:min(100%, calc(100% - 24px));
    grid-template-columns:1fr;
  }

  .recruitJobTop__card{
    min-height:auto;
    padding:28px 18px 26px;
  }

  .recruitJobTop__circle{
    width:180px;
    margin-bottom:22px;
  }

  .recruitJobTop__title{
    font-size:28px;
  }

  .recruitJobTop__desc{
    max-width:100%;
    font-size:14px;
  }

  .recruitInfoGrid{
    width:min(100%, calc(100% - 24px));
    grid-template-columns:1fr;
    gap:12px;
    padding:12px 0 24px;
  }

  .recruitInfoCard{
    min-height:auto;
    padding:18px 16px 22px;
    border-radius:14px;
  }

  .recruitInfoCard__pill{
    margin-bottom:22px;
    padding:12px 16px;
    font-size:14px;
  }

  .recruitInfoCard__title{
    font-size:26px;
  }

  .recruitInfoCard__text{
    font-size:14px;
  }

  .recruitQualification{
    padding:0 12px 38px;
  }

  .recruitQualification__frame{
    border-width:8px;
    padding:58px 16px 28px;
  }

  .recruitQualification__label{
    width:calc(100% - 28px);
    padding:10px 12px;
    font-size:26px;
  }

  .recruitQualification__age{
    font-size:42px;
  }

  .recruitQualification__lead{
    margin-bottom:24px;
    font-size:20px;
  }

  .recruitQualification__body{
    font-size:15px;
    line-height:1.7;
  }

  .recruitBottom{
    padding:34px 0 0;
  }

  .recruitBottom__inner{
    padding:22px 16px 24px;
  }

  .recruitPrivacy{
    margin-top:28px;
    padding:28px 0 30px;
  }

  .recruitPrivacy__inner{
    width:min(100%, calc(100% - 24px));
  }

  .recruitPrivacy__head{
    gap:14px;
    margin-bottom:24px;
  }

  .recruitPrivacy__titleWrap{
    max-width:220px;
  }

  .recruitPrivacy__title{
    margin-bottom:8px;
    font-size:22px;
  }

  .recruitPrivacy__titleLine{
    height:4px;
  }

  .recruitPrivacy__lead{
    font-size:13px;
    line-height:1.85;
  }

  .recruitPrivacy__grid{
    grid-template-columns:1fr;
    row-gap:20px;
  }

  .recruitPrivacy__col{
    gap:20px;
  }

  .recruitPrivacy__block{
    gap:6px;
  }

  .recruitPrivacy__heading{
    font-size:15px;
    line-height:1.55;
  }

  .recruitPrivacy__text,
  .recruitPrivacy__list li{
    font-size:13px;
    line-height:1.9;
  }
}

.recruitFormStatus{
  margin:0 0 18px;
  padding:14px 16px;
  border:1px solid #d7d0c9;
  font-size:14px;
  line-height:1.8;
}

.recruitFormStatus--success{
  background:#f4f8f2;
  color:#234b1f;
  border-color:#b9d3b0;
}

.recruitFormStatus--error{
  background:#fff5f5;
  color:#8c1d1d;
  border-color:#e3b4b4;
}

.recruitFormError{
  margin:6px 0 0;
  color:#b4432f;
  font-size:12px;
  line-height:1.7;
}

.recruitThanksAction{
  margin-top:24px;
  text-align:center;
}

.recruitThanksButton{
  display:inline-block;
  padding:16px 28px;
  background:#b4432f;
  color:#fff;
  text-decoration:none;
}