/* =========================================
   Apply Guest - tokens
   ========================================= */
   :root {
    /* Layout */
    --page-max: 1440px;
    --page-pad-x: 108px;
    --card-max: 880px;
  
    /* Spacing */
    --space-40: 40px;
    --space-24: 24px;
    --space-16: 16px;
    --space-8: 8px;
  
    /* Radius */
    --radius-card: 16px;
    --radius-12: 12px;
    --radius-4: 4px;
  
    /* Colors (Figma: Typography / Primary / Background) */
    --typo-9: #333333;
    --typo-8: #4D4D4D;
    --typo-7: #666666;
    --typo-6: #7F7F7F;
    --typo-5: #999999;
  
    --primary-05: #FF5500;   /* Primary 01/5 */
    --primary-04: #FF7B39;   /* Primary 01/4 */
    --link-1: #004CC4;
  
    --bg-1: #F2F6F9;
    --white: #FFFFFF;
  
    /* Effects */
    --cta-shadow: 0 1px 16px rgba(233, 85, 19, 0.35);
  }
  
  /* =========================================
     Header 差異の吸収（本番挙動寄せ）
     ========================================= */
  .p-header-wrap .site-header {
    border-bottom: none !important;
  }
  
  .p-header-wrap .header-subtitle {
    display: none !important;
  }
  
  .p-top-nav {
    border-top: none !important;
  }
  
  /* =========================================
     Layout
     ========================================= */
  .apply-guest {
    width: 100%;
    display: block;
  }
  
  .apply-guest__container {
    max-width: var(--page-max);
    margin: 0 auto;
    padding-left: var(--page-pad-x);
    padding-right: var(--page-pad-x);
    padding-bottom: 80px;
    margin-inline: auto;
  }
  
  .apply-guest__card {
    max-width: var(--card-max);
    background: var(--white);
    border-radius: var(--radius-card);
    padding: 0 24px 24px 24px;
    margin-inline: auto;
    display: block;
  }
  
  /* =========================================
     Head + Breadcrumbs
     ========================================= */
  .apply-guest__head {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
    padding-top: var(--space-16);
    padding-bottom: var(--space-16);
    margin-top: 127px
  }
  
  .breadcrumbs {
    display: inline-flex;
    align-items: center;
    gap: var(--space-8);
  }
  
  .breadcrumbs__item {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 12px;
    line-height: 18px;
    color: var(--primary-05);
  }
  
  .breadcrumbs__sep {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 10px;
    line-height: 15px;
    color: var(--typo-8);
  }
  
  .apply-guest__title {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    font-size: 28px;
    line-height: 28px;
    color: var(--typo-9);
  }
  
  .apply-guest__lead {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 21px;
    color: var(--typo-5);
  }

/* ===== recruit/detail と同等トーンのパンくず ===== */
.recruit-breadcrumb {
    width: 100%;
  }
  .recruit-breadcrumb__inner {
    max-width: 1160px;
    margin: 8px auto 0;
    padding: 10px 10px;
  }
  .recruit-breadcrumb__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    margin: 0;
    padding: 0;
    list-style: none;
  }
  .recruit-breadcrumb__item {
    display: flex;
    align-items: center;
    font-size: 12px;
    line-height: 18px;
    color: #4D4D4D;
  }
  
  /* 区切り（本番は画像スプライトだが、矢印で再現） */
  .recruit-breadcrumb__item:not(.is-current)::after {
    content: "";
    display: inline-block;
    width: 5px;
    height: 5px;
    margin: 0 8px;
    border-top: 2px solid #A6A6A6;
    border-right: 2px solid #A6A6A6;
    transform: rotate(45deg);
  }
  
  .recruit-breadcrumb__item a:hover {
    text-decoration: underline;
  }



  /* カラーバリアブル（必要なら） */
.recruit-breadcrumb {
    --primary-05: #FF5500;
  }
  
  /* 最後以外＝リンクはすべてオレンジ */
  .recruit-breadcrumb__item a,
  .recruit-breadcrumb__item a:visited,
  .recruit-breadcrumb__item a:active,
  .recruit-breadcrumb__item a:focus {
    color: var(--primary-05);
  }
  
  /* （もし途中にリンクなしの span を使うケースがあれば） */
  .recruit-breadcrumb__item:not(.is-current) > span {
    color: var(--primary-05);
  }
  
  /* 現在地（最後の要素）は従来通り濃いグレー／黒 */
  .recruit-breadcrumb__item.is-current > span {
    color: var(--typo-8);
  }
  
  /* =========================================
     Login shortcut
     ========================================= */
  .login-shortcut {
    margin-top: var(--space-24);
    background: var(--bg-1);
    border-radius: 8px;
    padding: var(--space-16);
  }
  
  .login-shortcut__title {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 24px;
    color: var(--link-1);
  }
  
  .login-shortcut__desc {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 21px;
    color: var(--typo-5);
  }
  
  /* =========================================
     Form
     ========================================= */
     .form{
        margin-top:var(--space-24);
        display:flex;
        flex-direction:column;
        gap:var(--space-24);
      }
      
      /* 行 */
      .form-row{
        display:flex;
        align-items:center;
        gap:var(--space-16);
      }
      
      /* ラベル */
      .form-row__label{
        width:196px;
        min-height:40px;
        display:flex;
        flex-direction:column;
        justify-content:center;
        gap:2px;
        font-family:"Noto Sans JP",sans-serif;
        font-weight:700;
        font-size:16px;
        line-height:24px;
        color:var(--typo-8);
      }
      
      /* ラベル内注記 */
      .form-row__label .note{
        font-family:"Noto Sans JP",sans-serif;
        font-weight:400;
        font-size:12px;
        line-height:1.2;
        color:var(--typo-7);
        margin-top:2px;
      }
      
      /* コントロールの横並び */
      .form-row__controls{
        display:flex;
        align-items:center;
        gap:var(--space-8);
        flex:1 1 auto;
      }
      
      /* ========== input / select ========== */
      .input,
      .select{
        height:40px;
        display:flex;
        align-items:center;
        background:var(--white);
        border-radius:4px;
        outline:1px solid var(--typo-5);
        outline-offset:-1px;
        padding:0 12px 0 16px;
      }
      
      /* テキスト入力 */
      .input{ flex:1 1 auto; }
      .input input{
        width:100%;
        height:100%;
        border:0;
        background:transparent;
        font-family:"Noto Sans JP",sans-serif;
        font-size:16px;
        color:var(--typo-8);
        outline:none;
      }
      
      /* セレクト */
      .select{
        position:relative;
        min-width:160px;
        width: 0 !important;
      }
      .select--wide{ min-width:240px; }
      .select select{
        appearance:none;
        -webkit-appearance:none;
        -moz-appearance:none;
        border:0;
        background:transparent;
        width:100%;
        height:100%;
        font-family:"Noto Sans JP",sans-serif;
        font-size:16px;
        color:var(--typo-9);
        outline:none;
        padding:0;
        cursor:pointer;
      }
      /* ▼（HTMLには caret の要素を置かない） */
      .select::after{
        content:"";
        position:absolute;
        right:12px;
        top:50%;
        width:0;height:0;
        border-left:6px solid transparent;
        border-right:6px solid transparent;
        border-top:6px solid var(--typo-7);
        transform:translateY(-50%);
        pointer-events:none;
      }
      
      /* 単位などの後置文字 */
      .suffix{
        font-family:"Noto Sans JP",sans-serif;
        font-weight:500;
        font-size:16px;
        line-height:1;
        color:var(--typo-9);
      }
      
      /* ========== chips（checkbox / radio の見た目） ========== */
      .chips{
        display:flex;
        flex-wrap:wrap;
        gap:12px;
      }
      .chips--inline{ flex-wrap:nowrap; gap:var(--space-16); }
      
      .chip{
        position:relative;
        display:inline-flex;
        align-items:center;
        min-height:40px;
      }
      /* アクセシブル非表示 */
      .chip > input{
        position:absolute;
        inset:0;
        opacity:0;
        cursor:pointer;
      }
      /* 見た目は隣の span */
      .chip > span{
        display:inline-flex;
        align-items:center;
        justify-content:center;
        padding:8px 24px;
        min-width:160px;
        border-radius:4px;
        background:var(--white);
        color:var(--typo-8);
        outline:1px solid var(--typo-5);
        outline-offset:-1px;
        font-family:"Noto Sans JP",sans-serif;
        font-size:16px;
        line-height:24px;
        transition:background .15s ease,color .15s ease,outline-color .15s ease;
        cursor:pointer;
      }
      /* hover */
      .chip > input:hover + span{
        outline-color:#B3B3B3;
      }
      /* 選択状態 */
      .chip > input:checked + span{
        background:rgba(255,236,227,.5);
        color:var(--primary-05);
        font-weight:700;
        outline-color:var(--primary-05);
      }

      /* 保有資格を3列×2段のグリッドに */
        .chips--grid3 {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            column-gap: 12px;
            row-gap: 12px;
        }
        
        /* 既存の min-width を打ち消して均等幅に */
        .chips--grid3 .chip {
            width: 100%;
            min-width: 0;
        }
        
        .chips--grid3 .chip > span {
            width: 100%;
            justify-content: center;
        }
  
  /* =========================================
     CTA
     ========================================= */
  .cta {
    margin-top: 40px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-16);
  }
  
  .cta__button {
    max-width: 480px;
    padding-top: 16px;
    padding-bottom: 16px;
    padding-left: 40px;
    padding-right: 40px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    color: var(--white);
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    background: linear-gradient(90deg, #FF611B 0%, #FFB300 100%), linear-gradient(90deg, #F29600 0%, #E95513 100%);
    box-shadow: var(--cta-shadow);
  }
  
  .cta__note {
    text-align: center;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 14px;
    line-height: 21px;
    color: var(--typo-6);
    max-width: 370px;
  }
  
  /* =========================================
     FAQ
     ========================================= */
  .faq {
    margin-top: var(--space-40);
    display: flex;
    flex-direction: column;
    gap: var(--space-16);
  }
  
  .faq__head {
    display: flex;
    align-items: center;
    gap: var(--space-8);
  }
  
  .faq__title {
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    font-size: 24px;
    line-height: 24px;
    color: var(--primary-04);
    position: relative;           
    display: flex;         
    line-height: 1.2;
    gap: 8px;              
  }

  .faq_title { display:inline-flex; align-items:center; gap:8px; }
  .faq_icon  { width:30px; height:30px; display:block; }
  
  .faq__divider {
    flex: 1;
    height: 0;
    border: none;
    outline: 1px solid var(--primary-04);
    outline-offset: -0.5px;
  }
  
  .faq__item {
    display: flex;
    flex-direction: column;
    gap: var(--space-8);
  }
  
  .faq__q {
    display: inline-flex;
    align-items: baseline;
    gap: var(--space-8);
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 700;
    font-size: 20px;
    line-height: 30px;
    color: var(--typo-9);
  }
  
  .faq__qmark {
    font-family: "DIN 2014", sans-serif;
    font-weight: 700;
    font-size: 20px;
    line-height: 20px;
    color: var(--primary-04);
  }
  
  .faq__a {
    padding-left: 24px;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 16px;
    line-height: 24px;
    color: var(--typo-8);
    max-width: 784px;
  }
  
  /* =========================================
     Responsive
     ========================================= */
  @media (max-width: 768px) {
    .apply-guest__container {
      padding-left: 16px;
      padding-right: 16px;
      padding-bottom: 0;
      width: 100%;
    }
  
    .apply-guest__card {
      border-radius: var(--radius-12);
      padding: 0;
    }
  }
  
  @media (max-width: 768px) {
    .form-row {
      align-items: flex-start;
      flex-direction: column;
      gap: 4px;
    }
  
    .form-row__label {
      width: 140px;
    }
  
    .select--wide {
      width: 100%;
    }
  
    .input {
      width: 100%;
    }
  }

    /* ページ横幅が狭い時の折返し最適化 */
    @media (max-width: 768px) {
        .recruit-breadcrumb__inner {
          padding: 8px 0;
        }
    
        .apply-guest__head {
            margin-top: 50px;
            padding-bottom: 8px;
        }
    
        .recruit-breadcrumb__list {
          gap: 4px;
          display: flex;
          padding: 4px;
          align-items: center;
          gap: 8px;
          align-self: stretch;
        }
    }

    /* === SP styles === */
    @media (max-width: 768px) {
        /* 名前空間（ルート） */
        .apply-guest{
        width:100%;
        height:100%;
        padding:24px 16px 80px;
        background:#fff;
        display:flex;
        flex-direction:column;
        align-items:center;
        gap:24px;
        font-family: "Noto Sans JP", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
        }
    
        /* 見出し */
        .apply-guest__head{
            align-self:stretch;
            display:flex;
            flex-direction:column;
            gap:0px;
        }
        .apply-guest__title{
        color:var(--Typography-9,#333333);
        font-size:24px;
        font-weight:700;
        line-height:31.2px;
        margin-top: 24px;
        margin-bottom: 4px;
        }
        .apply-guest__lead{
        color:var(--Typography-5,#999999);
        font-size:13px;font-weight:500;line-height:19.5px;
        }

        .login-shortcut {
            padding: 8px;
        }
    
        /* ログイン案内ボックス */
        .apply-guest__login{
        width:100%;
        max-width:880px;
        padding:8px;
        background:var(--Background-1,#F2F6F9);
        border-radius:4px;
        display:flex;flex-direction:column;gap:4px;
        }
        .apply-guest__login-title{
        color:var(--Link-1,#004CC4);
        font-size:14px;font-weight:500;line-height:21px;
        }
        .apply-guest__login-desc{
        color:var(--Typography-5,#999999);
        font-size:13px;font-weight:500;line-height:19.5px;
        }
    
        /* フォーム全体 */
        .apply-guest__form{align-self:stretch;display:flex;flex-direction:column;gap:24px;}
        .form-block{display:flex;flex-direction:column;gap:4px;}
        .form-label-sm{
        color:var(--Typography-9,#333333);
        font-size:14px;font-weight:700;line-height:21px;
        }
        .form-label-lg{
        color:var(--Typography-9,#333333);
        font-size:16px;font-weight:700;line-height:24px;
        }
        .form-hint{
        color:var(--Typography-7,#666666);
        font-size:14px;font-weight:400;
        }
    
        /* 入力系 */
        .input, .select, .textarea{
        width:100%;
        height:40px;
        padding:0 12px 0 16px;
        background:#fff;
        border-radius:4px;
        outline:1px var(--Typography-4,#B2B2B2) solid;
        outline-offset:-1px;
        display:flex;align-items:center;justify-content:flex-start;
        }
        .input--thin{ outline:0.5px var(--Typography-5,#999999) solid; outline-offset:-0.5px; }
        .input__text{
        color:var(--Typography-8,#4D4D4D);
        font-size:16px;font-weight:500;
        }
    

    
        /* 氏名 */
        .name-row{display:flex;align-items:center;gap:8px;}
        .name-row .input{flex:1;}
    
        /* 生まれ年（年 + “年生まれ”） */
        .birth-row{display:flex;align-items:baseline;gap:4px;}
        .birth-select{width:160px;}
        .birth-suffix{
        width:64px;
        color:var(--Typography-9,#333333);
        font-size:16px;font-weight:500;
        }
    
        /* 電話・メール共通 */
        .input-40{height:40px;}
        .input-40 .input__text{font-size:16px;font-weight:500;color:var(--Typography-8,#4D4D4D);}
        /* ラベル行を横方向に */
        .form-row--tel .form-row__label{
            display:flex;
            flex-direction:row;      /* 縦積みをやめる */
            align-items:baseline;    /* 文字のベースラインを揃える */
            gap:4px;                 /* 「電話番号」と「ハイフンなし」の間隔 */
            width:auto;
            min-width:unset;
            white-space:nowrap;      /* 折り返し防止（必要なら外してOK） */
            margin:0;
            min-height: 32px;
        }

        /* 補足テキストの見た目（ハイフンなし） */
        .form-row--tel .form-row__label .note{
            color:var(--Typography-7,#666);
            font-size:14px;
            font-weight:400;
        }
        
        /* 保有資格のグリッド本体 */
        .apply-guest .chips,
        .apply-guest .chips--grid3 {              /* 既存クラス名をそのまま上書き */
        display: grid !important;               /* 既存の display:flex を打ち消す */
        grid-template-columns: repeat(2, minmax(0, 1fr)); /* 2列固定 */
        gap: 12px;
        align-items: stretch;
        }





        
    
        /* 現在の職業状況（在職中/離職中） */
        .choice-row{display:flex;gap:16px;height:40px;}
        .choice{width:160px;height:40px;padding:8px 24px;background:#fff;border-radius:4px;outline:1px var(--Typography-5,#999) solid;display:flex;align-items:center;justify-content:center;}
        .choice__text{color:var(--Typography-8,#4D4D4D);font-size:14px;font-weight:500;}
        .choice--active{background:rgba(255,236,227,.5);outline-color:var(--Primary-01-5,#FF5500);}
        .choice--active .choice__text{color:var(--Primary-01-5,#FF5500);font-weight:700;}
    
        /* 転職希望エリア/業界経験年数 */
        .select-40{height:40px;}
        .select-40 .input__text{font-size:16px;font-weight:500;color:var(--Typography-8,#4D4D4D);}
    
        /* CTA + 注意文 */
        .cta {
            margin-top: 24px;
            gap: 8px;
        }
        .cta__button {
        height:40px;padding:12px 40px;border-radius:4px;
        display:inline-flex;align-items:center;justify-content:center;gap:24px;
        background:linear-gradient(90deg,#FF611B 0%,#FFB300 100%), linear-gradient(90deg,#F29600 0%, #E95513 100%);
        box-shadow:0 1px 16px rgba(233,85,19,.35);
        color:#fff;font-size:14px;font-weight:700;text-align:center;
        }
        .cta__note{
        align-self:stretch;text-align:center;
        color:var(--Typography-5,#999999);
        font-size:13px;
        font-weight:500;
        line-height:19.5px;
        padding: 0 40px;
        }
    
        /* FAQ */
        .faq {
            align-self:stretch;
            display:flex;
            flex-direction:column;
            gap:16px;
            margin-top: 24px;
        }
        .faq__head{display:flex;align-items:center;gap:8px;}
        .faq__title{
        color:var(--Primary-01-4,#FF7B39);
        font-size:16px;font-weight:700;line-height:24px;
        }
        .faq__divider{flex:1;height:0;border-top:1px solid var(--Primary-01-4,#FF7B39);}
        .faq__item{display:flex;flex-direction:column;gap:8px;}
        .faq__qline{display:flex;align-items:baseline;gap:8px;}
        .faq__q {
            font-size:16px;
            font-weight:700;
            line-height:24px;
        }
        .faq__qtext{
        flex:1;color:var(--Typography-9,#333333);
        font-size:16px;font-weight:700;line-height:24px;
        }
        .faq__a{
        padding-left:24px;
        color:var(--Typography-8,#4D4D4D);
        font-size:15px;font-weight:500;line-height:23px;
        }
    }


@media (max-width: 768px){
    .apply-guest { 
        padding-left: 0; 
        padding-right: 0; 
        padding-top: 0
    }
    .apply-guest__container{ padding-left:16px; padding-right:16px; } 
  }
  
  @media (max-width: 768px){
    .apply-guest .chips,
    .apply-guest .chips--grid3{
      display: grid !important;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;                   
      align-items: stretch;
    }
  
    .apply-guest .chips > *{
      width: 100% !important;
      min-width: 0 !important;
      box-sizing: border-box;
    }
  
    .apply-guest .chip > span{
      border: 1px solid var(--typo-5);
      outline: none;                          
      padding: 8px 24px;
      display: inline-flex;
      justify-content: center;
      align-items: center;
      height: 40px;
      width: 100%;
    }
    .apply-guest .chip > input:hover + span{ border-color: #B3B3B3; }
    .apply-guest .chip > input:checked + span{
      background: rgba(255,236,227,.5);
      color: var(--primary-05);
      font-weight: 700;
      border-color: var(--primary-05);
    }
  }
  
  
  