.elementor-1721 .elementor-element.elementor-element-18075d1{--display:flex;--min-height:100vh;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-e78c9d1{width:100%;max-width:100%;}.elementor-1721 .elementor-element.elementor-element-5926b5c{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:center;--gap:60px 60px;--row-gap:60px;--column-gap:60px;--padding-top:100px;--padding-bottom:100px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-31261a5{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-widget-heading .elementor-heading-title{font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-weight:var( --e-global-typography-primary-font-weight );color:var( --e-global-color-primary );}.elementor-1721 .elementor-element.elementor-element-723c66c .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:30px;font-weight:600;color:#015EEA;}.elementor-1721 .elementor-element.elementor-element-2627b92 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:20px;font-weight:500;}.elementor-1721 .elementor-element.elementor-element-94544d4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--gap:40px 40px;--row-gap:40px;--column-gap:40px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-dd51ec1.elementor-element{--align-self:flex-end;}.elementor-1721 .elementor-element.elementor-element-70923ea{--display:flex;--gap:60px 60px;--row-gap:60px;--column-gap:60px;--padding-top:0px;--padding-bottom:100px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-70923ea:not(.elementor-motion-effects-element-type-background), .elementor-1721 .elementor-element.elementor-element-70923ea > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#F0F0F0;}.elementor-1721 .elementor-element.elementor-element-79f4781{--display:flex;--margin-top:-32px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-658ba56 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:70px;font-weight:600;text-transform:uppercase;line-height:60px;color:#015EEA;}.elementor-1721 .elementor-element.elementor-element-50f62ea .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:20px;font-weight:500;}.elementor-widget-image .widget-image-caption{color:var( --e-global-color-text );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );}.elementor-1721 .elementor-element.elementor-element-c2053a9{width:var( --container-widget-width, 240px );max-width:240px;margin:-170px 160px calc(var(--kit-widget-spacing, 0px) + -100px) 0px;padding:0px 0px 0px 0px;--container-widget-width:240px;--container-widget-flex-grow:0;}.elementor-1721 .elementor-element.elementor-element-c2053a9.elementor-element{--align-self:flex-end;}.elementor-1721 .elementor-element.elementor-element-11f427d{z-index:2;}.elementor-1721 .elementor-element.elementor-element-ae97841.elementor-element{--align-self:center;}.elementor-1721 .elementor-element.elementor-element-e879316{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:60px 60px;--row-gap:60px;--column-gap:60px;--overlay-opacity:0.2;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-e879316:not(.elementor-motion-effects-element-type-background), .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#015EEA;}.elementor-1721 .elementor-element.elementor-element-e879316::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-background-video-container::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .e-con-inner > .elementor-background-video-container::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-background-slideshow::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .e-con-inner > .elementor-background-slideshow::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-image:url("https://sweet-johnson.163-43-30-20.plesk.page/wp-content/uploads/2026/04/recruit8.svg");--background-overlay:'';background-position:22% 20%;background-repeat:no-repeat;background-size:14% auto;}.elementor-1721 .elementor-element.elementor-element-fa5cf01{padding:30px 40px 0px 0px;}.elementor-1721 .elementor-element.elementor-element-54572e7{--display:flex;--justify-content:center;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-e6dbd3e{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-b9f87d9 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:60px;font-weight:600;color:#FFFFFF;}.elementor-1721 .elementor-element.elementor-element-b3ba2a0 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:20px;font-weight:500;color:#FFFFFF;}.elementor-widget-text-editor{font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-weight:var( --e-global-typography-text-font-weight );color:var( --e-global-color-text );}.elementor-widget-text-editor.elementor-drop-cap-view-stacked .elementor-drop-cap{background-color:var( --e-global-color-primary );}.elementor-widget-text-editor.elementor-drop-cap-view-framed .elementor-drop-cap, .elementor-widget-text-editor.elementor-drop-cap-view-default .elementor-drop-cap{color:var( --e-global-color-primary );border-color:var( --e-global-color-primary );}.elementor-1721 .elementor-element.elementor-element-ef78570{width:initial;max-width:initial;text-align:justify;font-family:"Noto Sans JP", Sans-serif;font-size:16px;font-weight:400;line-height:30px;color:#FFFFFF;}.elementor-1721 .elementor-element.elementor-element-6664d02{--display:flex;--flex-direction:column;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--justify-content:center;--align-items:center;--gap:60px 60px;--row-gap:60px;--column-gap:60px;--padding-top:100px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-6664d02:not(.elementor-motion-effects-element-type-background), .elementor-1721 .elementor-element.elementor-element-6664d02 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#FFFAE1;}.elementor-1721 .elementor-element.elementor-element-18842cc{--display:flex;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--gap:40px 40px;--row-gap:40px;--column-gap:40px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-18842cc.e-con{--align-self:center;}.elementor-1721 .elementor-element.elementor-element-971bf11 .elementor-heading-title{font-family:"Noto Sans JP", Sans-serif;font-size:70px;font-weight:600;text-transform:uppercase;line-height:60px;color:#015EEA;}.elementor-1721 .elementor-element.elementor-element-411a449{width:var( --container-widget-width, 450px );max-width:450px;--container-widget-width:450px;--container-widget-flex-grow:0;text-align:center;font-family:"Noto Sans JP", Sans-serif;font-weight:400;letter-spacing:2px;}.elementor-1721 .elementor-element.elementor-element-ece98a9{width:var( --container-widget-width, 160px );max-width:160px;--container-widget-width:160px;--container-widget-flex-grow:0;top:30px;z-index:2;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-ece98a9{left:0px;}body.rtl .elementor-1721 .elementor-element.elementor-element-ece98a9{right:0px;}.elementor-1721 .elementor-element.elementor-element-5782daa{width:var( --container-widget-width, 184px );max-width:184px;--container-widget-width:184px;--container-widget-flex-grow:0;top:56px;z-index:2;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-5782daa{right:0px;}body.rtl .elementor-1721 .elementor-element.elementor-element-5782daa{left:0px;}.elementor-1721 .elementor-element.elementor-element-081c068{width:var( --container-widget-width, 80px );max-width:80px;--container-widget-width:80px;--container-widget-flex-grow:0;top:-28px;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-081c068{left:166px;}body.rtl .elementor-1721 .elementor-element.elementor-element-081c068{right:166px;}.elementor-1721 .elementor-element.elementor-element-bc6c925{width:var( --container-widget-width, 68px );max-width:68px;--container-widget-width:68px;--container-widget-flex-grow:0;top:80px;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-bc6c925{right:212px;}body.rtl .elementor-1721 .elementor-element.elementor-element-bc6c925{left:212px;}.elementor-1721 .elementor-element.elementor-element-3ee7a67{width:var( --container-widget-width, 57px );max-width:57px;--container-widget-width:57px;--container-widget-flex-grow:0;top:-28px;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-3ee7a67{right:142px;}body.rtl .elementor-1721 .elementor-element.elementor-element-3ee7a67{left:142px;}.elementor-1721 .elementor-element.elementor-element-99e0a37{width:var( --container-widget-width, 110px );max-width:110px;--container-widget-width:110px;--container-widget-flex-grow:0;top:38px;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-99e0a37{right:20px;}body.rtl .elementor-1721 .elementor-element.elementor-element-99e0a37{left:20px;}.elementor-1721 .elementor-element.elementor-element-d14fb7d{width:var( --container-widget-width, 54px );max-width:54px;--container-widget-width:54px;--container-widget-flex-grow:0;top:8px;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-d14fb7d{left:70px;}body.rtl .elementor-1721 .elementor-element.elementor-element-d14fb7d{right:70px;}.elementor-1721 .elementor-element.elementor-element-388bd95{width:var( --container-widget-width, 108px );max-width:108px;--container-widget-width:108px;--container-widget-flex-grow:0;top:79px;}body:not(.rtl) .elementor-1721 .elementor-element.elementor-element-388bd95{left:200px;}body.rtl .elementor-1721 .elementor-element.elementor-element-388bd95{right:200px;}.elementor-1721 .elementor-element.elementor-element-6f9f52b{width:var( --container-widget-width, 800px );max-width:800px;--container-widget-width:800px;--container-widget-flex-grow:0;}.elementor-1721 .elementor-element.elementor-element-6f9f52b .elementor-wrapper{--video-aspect-ratio:1.77777;}.elementor-1721 .elementor-element.elementor-element-1a6d9ff{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:space-between;--margin-top:-200px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-00eaa41{width:var( --container-widget-width, 170px );max-width:170px;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 80px;--container-widget-width:170px;--container-widget-flex-grow:0;}.elementor-1721 .elementor-element.elementor-element-81e02eb{width:var( --container-widget-width, 167px );max-width:167px;margin:0px 80px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;--container-widget-width:167px;--container-widget-flex-grow:0;}.elementor-1721 .elementor-element.elementor-element-78391e2{--display:flex;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-474dc1d{margin:-40px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-1721 .elementor-element.elementor-element-f92e429{--display:flex;--margin-top:80px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:100px;--padding-bottom:100px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-738f6e0{--display:flex;--flex-direction:row;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--justify-content:space-between;--align-items:center;--gap:60px 60px;--row-gap:60px;--column-gap:60px;--margin-top:-30px;--margin-bottom:14px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-1721 .elementor-element.elementor-element-2e4237b{margin:-117px 0px calc(var(--kit-widget-spacing, 0px) + -34px) 0px;}.elementor-1721 .elementor-element.elementor-element-b793beb{--display:flex;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}@media(min-width:768px){.elementor-1721 .elementor-element.elementor-element-31261a5{--width:100px;}.elementor-1721 .elementor-element.elementor-element-94544d4{--width:600px;}.elementor-1721 .elementor-element.elementor-element-54572e7{--width:400px;}.elementor-1721 .elementor-element.elementor-element-738f6e0{--content-width:1000px;}}@media(max-width:1024px){.elementor-1721 .elementor-element.elementor-element-e879316::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-background-video-container::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .e-con-inner > .elementor-background-video-container::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-background-slideshow::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .e-con-inner > .elementor-background-slideshow::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-position:0% 0%;}}@media(max-width:767px){.elementor-1721 .elementor-element.elementor-element-e879316::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-background-video-container::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .e-con-inner > .elementor-background-video-container::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-background-slideshow::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .e-con-inner > .elementor-background-slideshow::before, .elementor-1721 .elementor-element.elementor-element-e879316 > .elementor-motion-effects-container > .elementor-motion-effects-layer::before{background-position:0% 0%;}}/* Start custom CSS for html, class: .elementor-element-e78c9d1 *//* ==========================================================================
   RECRUIT HERO SECTION
   ========================================================================== */

/* --- 1. セクション全体（背景・配置） --- */
.recruit-wavy-hero {
    position: relative;
    width: 100%;
    min-height: clamp(700px, 80vw, 1200px);
    display: flex;
    align-items: flex-start; /* タイトルを上合わせにする */
    justify-content: center;
    background-color: #015eea;
    
    /* 背景画像の設定 */
    background-image: url('/wp-content/uploads/2026/04/recruit1.png');
    background-repeat: no-repeat;
    background-size: 85%;      /* 画像がデカすぎないよう調整 */
    background-position: center 64%; /* 画像を中央より少し上に配置 */
    
    overflow: hidden;
    padding: 140px 20px 100px; /* 上部パディングを広げてヘッダーとの被りを防止 */
    
}

/* 背景画像に薄い青のフィルターを重ねて文字を読みやすくする */
.recruit-wavy-hero::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(1, 94, 234, 0.3); /* 青いオーバーレイ 30% */
    z-index: 0;
}

/* --- 2. コンテンツ（テキスト・タイトル） --- */
.recruit-hero-content { 
    text-align: center; 
    z-index: 2; /* 背景やアイコンより手前に表示 */
    margin-top: 40px; 
}

.hero-sub-text {
    color: #ffffff;
    font-size: 1.1rem;
    font-weight: 700;
    margin-bottom: 10px;
    letter-spacing: 0.2em;
    text-shadow: 0 2px 4px rgba(0,0,0,0.3);
}

.hero-title {
    color: #ffffff;
    font-size: clamp(24px, 4vw, 60px);
    font-weight: 900;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-shadow: 0 4px 12px rgba(0,0,0,0.5);
    margin-top: 0;
}

/* 情熱SVG */
.passion-svg-container {
    display: inline-block;
    vertical-align: middle;
    width: 2.4em;
    height: auto;
    margin: 0 0.1em;
}

.passion-svg-container svg {
    width: 100%;
    height: auto;
    display: block;
    transform: translateY(-5%);
}

/* ★ここが修正ポイント */
.passion-svg-container svg path {
    fill: none;              /* ← 塗りを消す */
    stroke: #ffffff;         /* 線だけ表示 */
    stroke-width: 20px;       /* ← 8pxは太すぎ。3〜4がベスト */
    stroke-linecap: round;
    stroke-linejoin: round;
}

/* --- 3. 装飾アイコン（浮遊・固定） --- */
.hero-icon, .float-icon {
    position: absolute;
    height: auto;
    z-index: 1;
    pointer-events: none;
}

/* 固定アイコン */
.hero-icon { max-width: 300px; opacity: 0.8; }
.icon-top-left { top: -50px; left: -80px; }
.icon-bottom-right { bottom: -30px; right: -60px; }

/* ふわふわ動くアイコン */
.float-icon { opacity: 0.5; animation: floating-sway infinite ease-in-out; }

.f-icon-1 { width: 80px; top: 15%; left: 10%; animation-duration: 6s; }
.f-icon-2 { width: 120px; top: 60%; left: 5%; animation-duration: 8s; animation-delay: -1s; }
.f-icon-3 { width: 70px; top: 10%; right: 15%; animation-duration: 7s; }
.f-icon-4 { width: 140px; top: 70%; right: 12%; animation-duration: 10s; animation-delay: -2s; }
.f-icon-5 { width: 90px; top: 40%; left: 45%; animation-duration: 9s; }
.f-icon-6 { width: 110px; bottom: 20%; left: 30%; animation-duration: 11s; }

@keyframes floating-sway {
    0% { transform: translate(0, 0) rotate(0deg); }
    33% { transform: translate(15px, -20px) rotate(5deg); }
    66% { transform: translate(-10px, 10px) rotate(-5deg); }
    100% { transform: translate(0, 0) rotate(0deg); }
}

/* --- 4. レスポンシブ調整（スマホ） --- */
@media (max-width: 767px) {
    .recruit-wavy-hero { 
        padding-top: 100px;
        min-height: 500px;
        background-size: 160%;    /* スマホでは画像を相対的に大きく */
        background-position: center 50%;
    }
    .hero-sub-text {
        font-size: 0.9rem;
        margin-bottom: 10px;
    }
    .passion-svg-container {
        width: 2.0em;
    }
    .hero-icon { max-width: 150px; }
    .f-icon-1, .f-icon-3, .f-icon-5 { display: none; } /* スマホでは数を減らす */
    .float-icon { width: 60px !important; opacity: 0.3; }
}
/* =========================================
   1. 人物写真の基本設定と出現アニメーション
========================================= */

/* ボールのように弾むアニメーション定義 */
@keyframes bounceIn {
    0% {
        opacity: 0;
        transform: translate(0, 100px) scale(0.3); /* 下から小さく登場 */
    }
    30% {
        opacity: 1;
        transform: translate(0, -20px) scale(1.1); /* 少し上に行き過ぎる */
    }
    50% {
        transform: translate(0, 5px) scale(0.9);   /* 少し沈む */
    }
    100% {
        opacity: 1;
        transform: translate(0, 0) scale(1);       /* 定位置 */
    }
}

.hero-photo {
    position: absolute;
    z-index: 5;
    opacity: 0; /* 最初は隠す */
    /* 4.5秒後から着火、1.2秒かけて弾む */
    animation: bounceIn 1.2s cubic-bezier(0.34, 1.56, 0.64, 1) forwards;
}

.hero-photo img {
    width: 100%;
    height: auto;
    display: block;
    transition: transform 0.3s ease, filter 0.3s ease;
    /* 影の大きさもvwで維持 */
    filter: drop-shadow(0.8vw 0.8vw 1.2vw rgba(0, 0, 0, 0.4));
}

/* 足元の影（photo-1以外に適用） */
.hero-photo::after {
    content: "";
    position: absolute;
    z-index: -1;
    width: 100%;
    height: 16px;
    bottom: 2px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    filter: blur(10px);
    pointer-events: none;
}

/* =========================================
   2. 各写真の個別配置とタイミング（4.5s〜）
========================================= */

.photo-1 {
    width: 20vw; top: 42vw; left: 38vw;
    animation-delay: 4.5s; /* 1番目 */
    z-index: 10;
}
.photo-1 img { transform: rotate(-5deg); }
.photo-1.hero-photo::after { display: none !important; } /* 吹き出しがあるため足元影を消す */

.photo-2 {
    width: 18vw; top: 33vw; left: 18vw;
    animation-delay: 4.7s; /* 2番目 */
}
.photo-2 img { transform: rotate(3deg); }

.photo-3 {
    width: 12vw; top: 33vw; right: 29vw;
    animation-delay: 4.9s; /* 3番目 */
}
.photo-3 img { transform: rotate(4deg); }

.photo-4 {
    width: 13vw; top: 37vw; right: 16vw;
    animation-delay: 5.1s; /* 4番目 */
}
.photo-4 img { transform: rotate(-3deg); }

/* =========================================
   3. 吹き出し（ENOMOTO VISION）のアニメーション
========================================= */

.photo-1 .photo-deco-link {
    position: absolute;
    z-index: 10;
    width: 80%;
    top: -86px; 
    left: 4%;
    opacity: 0;
    /* 人物が出た直後（5.5s後）にふわっと出す */
    animation: fadeInUpSubtle 0.8s ease forwards;
    animation-delay: 5.5s;
    transform: translateY(-40%) rotate(-10deg);
}

@keyframes fadeInUpSubtle {
    from { opacity: 0; transform: translateY(-20%) rotate(-10deg); }
    to { opacity: 1; transform: translateY(-40%) rotate(-10deg); }
}

/* 吹き出しホバー設定 */
.photo-1 .photo-deco-link:hover {
    transform: translateY(-50%) rotate(0deg) scale(1.1) !important;
    filter: drop-shadow(0 0 10px rgba(255, 255, 255, 0.5));
}

.photo-1 .photo-deco-svg {
    width: 100%;
    filter: none !important;
}

/* =========================================
   4. スマホ調整
========================================= */
@media (max-width: 767px) {
    .hero-photo {
        width: 120px !important;
        animation-duration: 0.8s; /* スマホでは少し速く */
    }
    .photo-1 { top: 70%; left: 5%; animation-delay: 2.5s; } /* スマホは早めに出す調整 */
    .photo-3 { top: 70%; right: 5%; animation-delay: 2.7s; }
    .photo-2, .photo-4 { display: none; }
}

/* --- 基本スタイル --- */
.passion-svg-container path {
    fill: none;
    stroke: #ffffff;
    stroke-width: 2px;
    stroke-linecap: round;
    stroke-linejoin: round;

    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;

    /* ★ここがポイント */
    animation: drawLine 1.2s ease forwards;
    animation-delay: calc(var(--i) * 0.08s);
}

/* アニメーション */
@keyframes drawLine {
    to {
        stroke-dashoffset: 0;
    }
}

/* ===== SVG 手書きアニメーション ===== */
.passion-svg-container svg path {
    fill: none;
    stroke: #ffffff;
    stroke-width: 20px;
    stroke-linecap: round;
    stroke-linejoin: round;

    /* 描画アニメーションの初期状態 */
    stroke-dasharray: 1000;
    stroke-dashoffset: 1000;

    /* アニメーション設定 */
    animation: draw-line 0.6s ease forwards;
    
    /* 共通設定：開始まで非表示にする（任意） */
    opacity: 0; 
}

/* アニメーション本体 */
@keyframes draw-line {
    from { opacity: 1; }
    to {
        opacity: 1;
        stroke-dashoffset: 0;
    }
}

/* ===== アニメーション着火タイミングの計算 =====
   ベースの 3.5s + 各パーツのステップ（0.12s刻み）
*/

/* 左側（16〜26）：3.50s から順次スタート */
.passion-svg-container svg path:nth-of-type(16) { animation-delay: 3.50s; }
.passion-svg-container svg path:nth-of-type(17) { animation-delay: 3.62s; }
.passion-svg-container svg path:nth-of-type(18) { animation-delay: 3.74s; }
.passion-svg-container svg path:nth-of-type(19) { animation-delay: 3.86s; }
.passion-svg-container svg path:nth-of-type(20) { animation-delay: 3.98s; }
.passion-svg-container svg path:nth-of-type(21) { animation-delay: 4.10s; }
.passion-svg-container svg path:nth-of-type(22) { animation-delay: 4.22s; }
.passion-svg-container svg path:nth-of-type(23) { animation-delay: 4.34s; }
.passion-svg-container svg path:nth-of-type(24) { animation-delay: 4.46s; }
.passion-svg-container svg path:nth-of-type(25) { animation-delay: 4.58s; }
.passion-svg-container svg path:nth-of-type(26) { animation-delay: 4.70s; }

/* 右側（1〜15）：左側が終わった後の 4.90s から順次スタート */
.passion-svg-container svg path:nth-of-type(1) { animation-delay: 4.90s; }
.passion-svg-container svg path:nth-of-type(2) { animation-delay: 5.02s; }
.passion-svg-container svg path:nth-of-type(3) { animation-delay: 5.14s; }
.passion-svg-container svg path:nth-of-type(4) { animation-delay: 5.26s; }
.passion-svg-container svg path:nth-of-type(5) { animation-delay: 5.38s; }
.passion-svg-container svg path:nth-of-type(6) { animation-delay: 5.50s; }
.passion-svg-container svg path:nth-of-type(7) { animation-delay: 5.62s; }
.passion-svg-container svg path:nth-of-type(8) { animation-delay: 5.74s; }
.passion-svg-container svg path:nth-of-type(9) { animation-delay: 5.86s; }
.passion-svg-container svg path:nth-of-type(10) { animation-delay: 5.98s; }
.passion-svg-container svg path:nth-of-type(11) { animation-delay: 6.10s; }
.passion-svg-container svg path:nth-of-type(12) { animation-delay: 6.22s; }
.passion-svg-container svg path:nth-of-type(13) { animation-delay: 6.34s; }
.passion-svg-container svg path:nth-of-type(14) { animation-delay: 6.46s; }
.passion-svg-container svg path:nth-of-type(15) { animation-delay: 6.58s; }

/* コンテナ自体の文字崩れ防止 */
.passion-svg-container {
    overflow: visible !important;
}
/* 共通のアニメーション定義（2.5s後に発火） */
@keyframes fadeInUpSubtle {
    0% {
        opacity: 0;
        transform: translateY(20px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}

/* サブテキスト（ENOMOTO RECRUITING） */
.hero-sub-text {
    opacity: 0;
    animation: fadeInUpSubtle 1s ease forwards;
    animation-delay: 2.5s; /* 2.5秒後に着火 */
}

/* タイトル全体（SVG以外の文字部分） */
.hero-title {
    opacity: 0;
    animation: fadeInUpSubtle 1s ease forwards;
    animation-delay: 2.5s; /* 2.5秒後に着火 */
    overflow: visible !important;
}/* End custom CSS */
/* Start custom CSS for shortcode, class: .elementor-element-65fb54e *//* リスト全体のコンテナ */
.custom-news-list {
    display: flex;
    flex-direction: column;
    gap: 15px; /* アイテム間の隙間 */
}

/* 各アイテム（リンク） */
.news-item {
    display: flex;
    align-items: center;
    background-color: #f2f2f2; /* 背景の薄いグレー */
    padding: 15px 30px;
    border-radius: 50px; /* カプセル型の丸み */
    text-decoration: none;
    color: #333;
    transition: background-color 0.3s ease;
}

.news-item:hover {
    background-color: #e6e6e6; /* ホバー時の色 */
}

/* 日付部分 */
.news-date {
    font-family: sans-serif;
    color: #888;
    margin-right: 40px; /* 日付とタイトルの間隔 */
    font-size: 0.95rem;
    white-space: nowrap;
}

/* タイトル部分 */
.news-title {
    font-weight: bold;
    font-size: 1rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* スマホ対応（幅が狭い場合） */
@media (max-width: 767px) {
    .news-item {
        padding: 12px 20px;
        flex-direction: column;
        align-items: flex-start;
        border-radius: 20px; /* スマホでは丸みを少し抑えるときれいです */
    }
    .news-date {
        margin-right: 0;
        margin-bottom: 5px;
    }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-dd51ec1 *//* ボタン全体のスタイル */
.more-button {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    gap: 15px; /* テキストと矢印の間隔 */
    cursor: pointer;
}

/* "MORE" テキスト */
.more-text {
    color: #0066ff; /* 青色（画像に合わせて調整してください） */
    font-size: 18px;
    font-weight: 900;
    letter-spacing: 0.05em;
}

/* 矢印を包む丸背景 */
.more-arrow {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    background-color: #0066ff; /* 背景の青 */
    color: #fff; /* 矢印の白 */
    border-radius: 50%;
    transition: transform 0.3s ease; /* 動きを滑らかに */
}

/* 矢印アイコン（SVG）のサイズ */
.more-arrow svg {
    width: 20px;
    height: 20px;
    transition: transform 0.3s ease;
}

/* ホバー時の動き（重要！） */
.more-button:hover .more-arrow {
    background-color: #0055dd; /* ホバー時に少し濃く（お好みで） */
}

.more-button:hover .more-arrow svg {
    /* 矢印だけを右に 5px 動かす */
    transform: translateX(5px);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-ae97841 *//* ボタン全体のスタイル */
.more-button {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    gap: 15px; /* テキストと矢印の間隔 */
    cursor: pointer;
}

/* "MORE" テキスト */
.more-text {
    color: #0066ff; /* 青色（画像に合わせて調整してください） */
    font-size: 18px;
    font-weight: 900;
    letter-spacing: 0.05em;
}

/* 矢印を包む丸背景 */
.more-arrow {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 40px;
    height: 40px;
    background-color: #0066ff; /* 背景の青 */
    color: #fff; /* 矢印の白 */
    border-radius: 50%;
    transition: transform 0.3s ease; /* 動きを滑らかに */
}

/* 矢印アイコン（SVG）のサイズ */
.more-arrow svg {
    width: 20px;
    height: 20px;
    transition: transform 0.3s ease;
}

/* ホバー時の動き（重要！） */
.more-button:hover .more-arrow {
    background-color: #0055dd; /* ホバー時に少し濃く（お好みで） */
}

.more-button:hover .more-arrow svg {
    /* 矢印だけを右に 5px 動かす */
    transform: translateX(5px);
}/* End custom CSS */
/* Start custom CSS for image, class: .elementor-element-fa5cf01 *//* 親要素（枠）の設定：はみ出しをカットする */
.img-person-shadow {
    overflow: hidden !important;
    display: block;
}

/* 人物のシルエットに影をつける */
.img-person-shadow img {
    /* 垂直方向の影を少し小さく(5px)して、下へのはみ出しを抑える */
    filter: drop-shadow(10px 5px 15px rgba(0, 0, 0, 0.3)) !important;
    transition: filter 0.3s ease, transform 0.3s ease !important;
    /* 下端に少し余白を作ることでカットされすぎるのを防ぐ場合は padding-bottom を入れる */
    padding-bottom: 2px; 
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-33b2ca4 *//* 独自のクラス名で干渉を防ぐ */
.recruit-more-button {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    background: transparent; /* 背景なし */
    cursor: pointer;
    transition: opacity 0.3s ease;
}

/* テキスト：常に白 */
.recruit-more-text {
    color: #ffffff;
    font-size: 18px;
    font-weight: 800;
    letter-spacing: 0.05em;
    line-height: 1;
}

/* 矢印の土台（白い円） */
.recruit-more-circle {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 36px;
    height: 36px;
    background-color: #ffffff; /* 円は白 */
    border-radius: 50%;
    color: #0066ff; /* 矢印の色（青） */
    transition: transform 0.3s ease;
}

/* 矢印アイコン（SVG）本体 */
.recruit-more-circle svg {
    width: 18px;
    height: 18px;
    transition: transform 0.3s ease; /* 動きを滑らかに */
}

/* --- ホバー時の動き --- */

/* 全体の透明度を少し変える演出（必要なければ削除してください） */
.recruit-more-button:hover {
    opacity: 0.9;
}

/* ホバーしても文字は白のまま（色指定を維持） */
.recruit-more-button:hover .recruit-more-text {
    color: #ffffff;
}

/* ホバー時に矢印アイコンだけが右に動く */
.recruit-more-button:hover .recruit-more-circle svg {
    transform: translateX(4px);
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-474dc1d *//* =========================================
   【超重要】人物ごとの個別調整エリア
========================================= */

/* --- 1人目 (福利厚生) --- */
.person-1 .person-img img { height: 250px; } /* 大きさ */
.person-1 .person-img { bottom: 86%; }       /* 上下の位置 */

/* --- 2人目 (数字：全身) --- */
.person-2 .person-img img { height: 250px; } /* 大きさ */
.person-2 .person-img { bottom: 86%; }       /* 上下の位置 */

/* --- 2人目 (数字：手だけ) --- */
.person-2 .person-hand img { height: 250px; } /* 手の大きさ */
.person-2 .person-hand { bottom: 86%; }       /* 手の位置 */

/* --- 3人目 (ビジョン) --- */
.person-3 .person-img img { height: 250px; } /* 大きさ */
.person-3 .person-img { bottom: 88%; }       /* 上下の位置 */

/* ========================================= */

/* 共通スタイル */
.recruit-feature-container {
    display: flex;
    justify-content: center;
    gap: 20px;
    padding-top: 140px; 
    flex-wrap: wrap;
}

.feature-card-wrapper {
    position: relative;
    width: 320px;
    margin-bottom: 30px;
}

.person-img, .person-hand {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    pointer-events: none;
    display: flex;
    justify-content: center;
}

.person-img { z-index: 1; }  /* カードの後ろ */
.person-hand { z-index: 10; } /* カードの前 */

.feature-card {
    display: block;
    position: relative;
    z-index: 5;
    background: #fff;
    border: 3px solid #ccc;
    border-radius: 20px;
    padding: 30px 20px 25px;
    text-align: center;
    text-decoration: none;
    transition: all 0.3s ease;
    height: 100%;
    box-sizing: border-box;
}

/* カラー設定 */
.color-orange { border-color: #f69c65; color: #f69c65 !important; }
.color-green  { border-color: #83bc41; color: #83bc41 !important; }
.color-blue   { border-color: #6bc8cc; color: #6bc8cc !important; }

/* アイコン二重円 */
.card-icon-area { display: flex; justify-content: center; margin-bottom: 20px; }
.icon-outer-circle {
    position: relative; width: 80px; height: 80px; border-radius: 50%;
    background-color: currentColor; display: flex; justify-content: center; align-items: center;
}
.main-icon { width: 40px; height: 40px; z-index: 3; filter: brightness(0) invert(1); }
.icon-inner-circle {
    position: absolute; width: 90%; height: 90%; border-radius: 50%;
     opacity: 0.3; top: 50%; left: 50%;
    transform: translate(-40%, -40%); z-index: 1;
}

/* テキスト・矢印 */
.card-headline, .card-desc, .card-arrow { color: currentColor; }
.card-headline { font-size: 24px; font-weight: bold; margin-bottom: 10px; }
.card-desc { font-size: 14px; line-height: 1.6; margin-bottom: 20px; }
.card-arrow { display: block; text-align: right; font-size: 20px; transition: 0.3s; }

/* ホバー設定 */
.feature-card:hover { transform: translateY(-5px); box-shadow: 0 10px 25px rgba(0,0,0,0.1); }
.feature-card:hover .card-arrow { transform: translateX(5px); }

@media (max-width: 768px) {
    .recruit-feature-container { padding-top: 120px; gap: 80px; }
    .feature-card-wrapper { width: 90%; }
}
/* 1. 初期状態：透明にして少し下げておく */
.person-img, .person-hand {
    opacity: 0;
    transform: translate(-50%, 30px) scale(0.9);
    transition: opacity 1.2s ease-out, transform 1.2s cubic-bezier(0.22, 1, 0.36, 1);
    will-change: opacity, transform;
}

/* 2. 着火用クラス：画面に入ったらこれが付与される */
.feature-card-wrapper.is-visible .person-img,
.feature-card-wrapper.is-visible .person-hand {
    opacity: 1;
    transform: translate(-50%, 0) scale(1);
}

/* 3. 個別遅延（順番に出す設定） */
.person-1.is-visible .person-img { transition-delay: 0.1s; }
.person-2.is-visible .person-img { transition-delay: 0.4s; }
.person-2.is-visible .person-hand { transition-delay: 0.5s; } /* 手を少し遅らせる */
.person-3.is-visible .person-img { transition-delay: 0.7s; }

/* 既存の個別調整（高さ・位置）はそのまま維持 */
.person-1 .person-img { bottom: 86%; }
.person-2 .person-img { bottom: 86%; }
.person-2 .person-hand { bottom: 86%; }
.person-3 .person-img { bottom: 88%; }/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-67d1a76 */@import url('https://fonts.googleapis.com/css2?family=Inter:wght@700&display=swap');

.tk-join-btn {
  display: inline-flex;
  align-items: center;
  text-decoration: none !important;
  color: #ffffff !important; /* 白を維持 */
  background: transparent;
  gap: 20px;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

/* 英語：JOIN US */
.tk-eng {
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif;
  font-size: 68px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
}

/* 日本語：エントリーする */
.tk-jpn {
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
}

/* 矢印のアニメーション設定 */
.tk-arrow {
  display: inline-block;
  margin-left: 8px;
  transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1); /* 滑らかな動き */
}

/* ホバー時の動き */
.tk-join-btn:hover {
  opacity: 1; /* 色は薄くせずそのまま */
}

.tk-join-btn:hover .tk-arrow {
  transform: translateX(8px); /* 矢印を右に8px動かす */
}

/* スマホ対応 */
@media (max-width: 600px) {
  .tk-eng { font-size: 28px; }
  .tk-jpn { font-size: 14px; }
}
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@700&display=swap');

.tk-join-btn {
  display: inline-flex;
  align-items: center;
  text-decoration: none !important;
  color: #ffffff !important;
  background: transparent;
  gap: 20px;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

/* 英語：JOIN US */
.tk-eng {
  font-family: 'Inter', 'Helvetica Neue', Arial, sans-serif;
  font-size: 68px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
}

/* 日本語：エントリーする */
.tk-jpn {
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
}

/* 矢印の設定 */
.tk-arrow {
  display: inline-block;
  margin-left: 8px;
  color: #ffffff !important; /* 矢印を白に指定 */
  transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}

/* ホバー時の動き */
.tk-join-btn:hover {
  opacity: 1;
}

.tk-join-btn:hover .tk-arrow {
  transform: translateX(8px);
  color: #ffffff !important; /* ホバー時も白を維持 */
}

/* スマホ対応 */
@media (max-width: 600px) {
  .tk-eng { font-size: 28px; }
  .tk-jpn { font-size: 14px; }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-754ecec *//* --- コンテナ設定 --- */
.tk-banner-container {
  display: flex;
  gap: 20px;
  max-width: 1100px;
  margin: 0 auto;
}

/* --- カード共通スタイル --- */
.tk-banner-card {
  flex: 1;
  background-color: #333333;
  padding: 40px 30px;
  text-decoration: none !important;
  color: #ffffff !important;
  position: relative;
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: background-color 0.3s ease;
  border-radius: 4px;
  box-sizing: border-box;
}

.tk-banner-card:not(.is-mynavi):hover {
  background-color: #3d3d3d;
}

/* --- 英語・日本語タイトル --- */
.tk-banner-eng {
  font-family: 'Trebuchet MS', sans-serif;
  font-size: 28px;
  font-weight: bold;
  letter-spacing: 0.05em;
  line-height: 1.2;
}

.tk-banner-jpn {
  font-size: 14px;
  margin-top: 5px;
  opacity: 0.9;
}

/* --- ★マイナビ専用（白背景＆センターロゴ修正版） --- */
.tk-banner-card.is-mynavi {
  background-color: #ffffff;
  color: #333333 !important;
  display: flex;
  flex-direction: column;
  justify-content: flex-end; /* VIEW MOREを下に配置 */
}

.tk-banner-card.is-mynavi:hover {
  background-color: #ffff;
}

.tk-mynavi-logo-center {
  position: absolute;
  top: 40%; /* ロゴの中央位置（VIEW MOREとの被りを微調整） */
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  pointer-events: none; /* リンクのクリックを邪魔しない */
}

.tk-mynavi-logo-center img {
  max-width: 200px;
  height: auto;
}

/* --- VIEW MOREエリア共通 --- */
.tk-view-more-wrap {
  align-self: flex-end; /* 右下へ */
  display: flex;
  align-items: center;
  position: relative;
  z-index: 2; /* ロゴより手前に */
}

.tk-view-more-text {
  font-family: 'Trebuchet MS', sans-serif;
  font-size: 13px;
  font-weight: bold;
  letter-spacing: 0.1em;
}

/* 青いカプセル矢印 */
.tk-arrow-capsule {
  background: linear-gradient(to right, #00c6ff, #0072ff);
  color: #ffffff !important;
  width: 38px;
  height: 18px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 10px;
  font-size: 13px;
  padding-bottom: 2px;
  transition: transform 0.3s cubic-bezier(0.25, 1, 0.5, 1);
}

.tk-banner-card:hover .tk-arrow-capsule {
  transform: translateX(6px);
}

/* --- スマホ対応 --- */
@media (max-width: 768px) {
  .tk-banner-container {
    flex-direction: column;
  }
  .tk-banner-card {
    min-height: 150px;
    padding: 30px 20px;
  }
  .tk-mynavi-logo-center img {
    max-width: 160px;
  }
}/* End custom CSS */
/* Start custom CSS for container, class: .elementor-element-f92e429 *//* グラデーションのうねりアニメ */
@keyframes gWaveGradient {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
/* 1. フォントの読み込み（丸ゴシック ＋ 明朝体） */
@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&family=Noto+Serif+JP:wght@400;700&display=swap');

body {
  font-kerning: none;
  font-feature-settings: "palt" 1;
  letter-spacing: 0.5px;
}/* End custom CSS */