/* ============================================================
   株式会社 和翔 - メインスタイルシート
   全ページ共通CSS + ページ固有CSS
============================================================ */

/* ---- CSS変数 ---- */
:root {
    --color-white: #fff;
    --color-cream: #fbf8f3;
    --color-gold: #c8a85c;
    --color-gold-light: #e6d4a5;
    --color-gold-dark: #a8884a;
    --color-purple: #5d3a7a;
    --color-purple-light: #8a6ba8;
    --color-purple-dark: #3d2752;
    --color-navy: #1a3a5c;
    --color-text: #2a2a2a;
    --color-text-light: #555;
    --color-border: #e8e2d3;
    --font-serif: 'Shippori Mincho','Noto Serif JP','Yu Mincho','游明朝',serif;
    --font-sans: 'Noto Sans JP','Hiragino Sans','Yu Gothic','游ゴシック',sans-serif;
}

/* ---- リセット ---- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font-serif);color:var(--color-text);line-height:1.8;background:var(--color-white);overflow-x:hidden;-webkit-font-smoothing:antialiased;
    /* 日本語改行最適化 */
    word-break:normal;          /* CJK文字を不要な位置で切らない */
    overflow-wrap:break-word;   /* URLなど長い欧文文字列のはみ出しを防止 */
    line-break:strict;          /* 句読点・括弧前後の禁則を厳格に適用 */
}
img{max-width:100%;height:auto;display:block}
a{color:var(--color-purple);text-decoration:none;transition:all .3s ease}
a:hover{color:var(--color-gold)}

/* ---- 日本語テキスト最適化 ---- */
/* 見出し: 均等ぶら下がり防止・文節改行 */
h1,h2,h3,h4,h5,h6{
    text-wrap:balance;          /* 行末に1文字だけ残るウィドウを抑制 */
    word-break:auto-phrase;     /* 文節境界で改行（Chrome119+ / 未対応は通常改行にフォールバック） */
}
/* 段落: 欧文長文の折り返し保証 */
p{overflow-wrap:break-word;word-break:normal}

/* ================================================================
   ヘッダー
================================================================ */
.site-header{position:fixed;top:0;left:0;width:100%;background:rgba(255,255,255,.95);backdrop-filter:blur(10px);z-index:1000;border-bottom:1px solid var(--color-border);transition:all .3s ease}
.header-inner{max-width:1200px;margin:0 auto;padding:16px 32px;display:flex;justify-content:space-between;align-items:center}
.header-logo{display:flex;align-items:center;gap:12px}
.header-logo img{height:64px;width:64px;object-fit:contain}
.header-logo-text{font-family:var(--font-serif);font-weight:600;font-size:18px;color:var(--color-navy);letter-spacing:.1em}
.nav-list{display:flex;list-style:none;gap:36px}
.nav-list a{color:var(--color-text);font-weight:500;font-size:15px;letter-spacing:.1em;position:relative;padding:6px 0}
.nav-list a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:linear-gradient(90deg,var(--color-gold),var(--color-purple));transition:width .3s ease}
.nav-list a:hover::after,.nav-list a.active::after{width:100%}
.nav-cta{background:linear-gradient(135deg,var(--color-purple),var(--color-purple-dark));color:var(--color-white)!important;padding:10px 24px!important;border-radius:4px;border:1px solid var(--color-gold)}
.nav-cta:hover{background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));color:var(--color-white)!important}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{display:block;width:28px;height:2px;background:var(--color-navy);transition:all .3s ease}

/* ================================================================
   ヒーロー（トップページ）
   ※ background-image は functions.php の wp_head から inline で注入
================================================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-purple-dark);background-size:cover;background-position:center center;background-repeat:no-repeat;color:var(--color-white);text-align:center;padding:120px 24px 80px;overflow:hidden}
.hero::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 30%,rgba(200,168,92,.2) 0%,transparent 50%),radial-gradient(circle at 80% 70%,rgba(200,168,92,.15) 0%,transparent 50%);pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:900px}
.hero-tagline{font-size:14px;letter-spacing:.4em;color:var(--color-gold-light);margin-bottom:24px;font-weight:300}
.hero-title{font-size:clamp(32px,6vw,60px);font-weight:600;line-height:1.4;margin-bottom:32px;letter-spacing:.05em}
.hero-title .accent{color:var(--color-gold)}
.hero-subtitle{font-size:clamp(15px,2vw,18px);line-height:2.2;margin-bottom:48px;font-weight:300;opacity:.95}
.hero-cta{display:inline-flex;align-items:center;gap:12px;padding:18px 48px;background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));color:var(--color-white);font-size:16px;font-weight:600;letter-spacing:.15em;border-radius:4px;border:1px solid var(--color-gold-light);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.hero-cta:hover{color:var(--color-white);transform:translateY(-2px);box-shadow:0 12px 32px rgba(200,168,92,.4)}
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);color:var(--color-gold-light);font-size:12px;letter-spacing:.3em;z-index:2}
.hero-scroll::after{content:'';display:block;width:1px;height:48px;background:var(--color-gold);margin:12px auto 0;animation:scrollDown 2s infinite}
@keyframes scrollDown{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ================================================================
   ページヒーロー（会社概要・お問い合わせ）
================================================================ */
.page-hero{background:linear-gradient(135deg,rgba(93,58,122,.9),rgba(26,58,92,.85)),var(--color-purple-dark);color:var(--color-white);padding:180px 24px 80px;text-align:center;position:relative}
.page-hero::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:100px;height:1px;background:var(--color-gold)}
.page-hero-en{font-size:13px;letter-spacing:.5em;color:var(--color-gold);margin-bottom:16px;text-transform:uppercase}
.page-hero-title{font-size:clamp(28px,5vw,44px);font-weight:600;letter-spacing:.2em}

/* ================================================================
   セクション共通
================================================================ */
.section{padding:100px 24px}
.section-inner{max-width:1200px;margin:0 auto}
.section-header{text-align:center;margin-bottom:64px}
.section-en{font-size:13px;letter-spacing:.5em;color:var(--color-gold);margin-bottom:16px;font-weight:500;text-transform:uppercase}
.section-title{font-size:clamp(28px,4vw,40px);font-weight:600;color:var(--color-navy);letter-spacing:.1em;position:relative;display:inline-block;padding-bottom:20px}
.section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:2px;background:linear-gradient(90deg,var(--color-gold),var(--color-purple))}
.section-cream{background:var(--color-cream);position:relative}

/* ================================================================
   ミッション
================================================================ */
.mission-text{text-align:center;max-width:800px;margin:0 auto;font-size:17px;line-height:2.4;color:var(--color-text)}
.mission-text p{margin-bottom:24px}
.mission-keywords{display:flex;justify-content:center;gap:32px;margin-top:48px;flex-wrap:wrap}
.mission-keyword{text-align:center;padding:24px 40px;background:var(--color-white);border:1px solid var(--color-gold);border-radius:4px;min-width:180px;position:relative}
.mission-keyword::before,.mission-keyword::after{content:'';position:absolute;width:12px;height:12px;border:1px solid var(--color-gold)}
.mission-keyword::before{top:-1px;left:-1px;border-right:none;border-bottom:none}
.mission-keyword::after{bottom:-1px;right:-1px;border-left:none;border-top:none}
.mission-keyword-en{font-size:11px;letter-spacing:.3em;color:var(--color-gold);margin-bottom:8px}
.mission-keyword-jp{font-size:22px;font-weight:600;color:var(--color-navy);letter-spacing:.15em}

/* ================================================================
   事業内容
================================================================ */
.services-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:24px}
.service-card{grid-column:span 2;background:var(--color-white);padding:40px 20px;text-align:center;border:1px solid var(--color-border);border-radius:4px;transition:all .4s ease;position:relative;overflow:hidden}
.service-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--color-gold),var(--color-purple));transform:scaleX(0);transition:transform .4s ease;transform-origin:left}
.service-card:hover{transform:translateY(-8px);box-shadow:0 16px 40px rgba(93,58,122,.12);border-color:var(--color-gold)}
.service-card:hover::before{transform:scaleX(1)}
.service-card:nth-child(4){grid-column:2/span 2}
.service-card:nth-child(5){grid-column:4/span 2}
.service-icon{width:80px;height:80px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,var(--color-cream),var(--color-white));border:2px solid var(--color-gold);font-size:32px;color:var(--color-purple);font-weight:600;font-family:var(--font-serif)}
.service-title{font-size:22px;font-weight:600;color:var(--color-navy);margin-bottom:16px;letter-spacing:.1em}
.service-desc{font-size:15px;line-height:2;color:var(--color-text-light)}

/* ================================================================
   選ばれる理由
================================================================ */
.strengths-list{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.strength-item{display:flex;flex-direction:column;gap:20px;align-items:center;text-align:center;padding:36px 20px;background:var(--color-white);border:1px solid var(--color-border);border-radius:4px;transition:all .3s ease}
.strength-item:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(93,58,122,.1);border-color:var(--color-gold)}
.strength-number{flex-shrink:0;width:60px;height:60px;background:linear-gradient(135deg,var(--color-purple),var(--color-purple-dark));color:var(--color-gold);display:flex;align-items:center;justify-content:center;border-radius:50%;font-family:'Cinzel',serif;font-size:20px;font-weight:600;border:2px solid var(--color-gold)}
.strength-body h3{font-size:18px;font-weight:600;color:var(--color-navy);margin-bottom:12px;letter-spacing:.05em}
.strength-body p{font-size:14px;line-height:1.9;color:var(--color-text-light)}

/* ================================================================
   採用セクション
================================================================ */
.recruit-section{background:linear-gradient(135deg,var(--color-purple-dark) 0%,var(--color-navy) 100%);color:var(--color-white);padding:120px 24px;position:relative;overflow:hidden}
.recruit-section::before{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background-image:radial-gradient(circle at 10% 20%,rgba(200,168,92,.18) 0%,transparent 45%),radial-gradient(circle at 90% 80%,rgba(200,168,92,.12) 0%,transparent 45%);pointer-events:none}
.recruit-section::after{content:'採用';position:absolute;top:50%;right:-80px;transform:translateY(-50%) rotate(-90deg);font-size:200px;font-weight:700;color:rgba(200,168,92,.05);letter-spacing:.3em;pointer-events:none;font-family:var(--font-serif)}
.recruit-inner{position:relative;z-index:2;max-width:1100px;margin:0 auto}
.recruit-header{text-align:center;margin-bottom:72px}
.recruit-en{font-size:14px;letter-spacing:.5em;color:var(--color-gold);margin-bottom:16px;text-transform:uppercase;font-weight:500}
.recruit-title{font-size:clamp(28px,5vw,44px);font-weight:600;margin-bottom:24px;letter-spacing:.1em;line-height:1.5}
.recruit-title .accent{color:var(--color-gold)}
.recruit-lead{font-size:17px;line-height:2.2;opacity:.95;max-width:780px;margin:0 auto}
.recruit-message{background:rgba(255,255,255,.04);border:1px solid rgba(200,168,92,.3);padding:48px 40px;margin-bottom:64px;text-align:center;position:relative;border-radius:4px}
.recruit-message::before,.recruit-message::after{content:'';position:absolute;width:32px;height:32px;border:2px solid var(--color-gold)}
.recruit-message::before{top:-2px;left:-2px;border-right:none;border-bottom:none}
.recruit-message::after{bottom:-2px;right:-2px;border-left:none;border-top:none}
.recruit-message-quote{font-size:clamp(22px,3.5vw,32px);font-weight:600;color:var(--color-gold);letter-spacing:.1em;margin-bottom:24px;line-height:1.7}
.recruit-message-text{font-size:16px;line-height:2.2;opacity:.95}
.recruit-points{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:64px}
.recruit-point{text-align:center;padding:32px 18px;background:rgba(255,255,255,.05);border:1px solid rgba(200,168,92,.25);border-radius:4px;transition:all .3s ease}
.recruit-point:hover{background:rgba(255,255,255,.08);border-color:var(--color-gold);transform:translateY(-4px)}
.recruit-point-num{display:inline-block;width:48px;height:48px;line-height:44px;border:2px solid var(--color-gold);border-radius:50%;color:var(--color-gold);font-family:'Cinzel',serif;font-size:18px;font-weight:600;margin-bottom:20px}
.recruit-point-title{font-size:20px;font-weight:600;color:var(--color-gold);margin-bottom:12px;letter-spacing:.1em}
.recruit-point-desc{font-size:14px;line-height:2;opacity:.9}
.recruit-table-wrap{background:rgba(255,255,255,.04);border:1px solid rgba(200,168,92,.25);padding:48px;border-radius:4px;margin-bottom:48px}
.recruit-table-title{text-align:center;font-size:22px;font-weight:600;color:var(--color-gold);margin-bottom:32px;letter-spacing:.15em;padding-bottom:20px;border-bottom:1px solid rgba(200,168,92,.3)}
.recruit-table{width:100%;border-collapse:collapse}
.recruit-table th,.recruit-table td{padding:20px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1);font-size:15px;line-height:1.9;vertical-align:top}
.recruit-table th{width:160px;color:var(--color-gold);font-weight:600;letter-spacing:.1em;white-space:nowrap}
.recruit-table td{color:var(--color-white);opacity:.95}
.recruit-table tr:last-child th,.recruit-table tr:last-child td{border-bottom:none}
.recruit-cta-wrap{text-align:center}
.recruit-cta-lead{font-size:16px;margin-bottom:24px;opacity:.95;line-height:2}

/* ================================================================
   会社概要ページ
================================================================ */
.message-box{max-width:800px;margin:0 auto;background:var(--color-white);padding:64px 48px;border:1px solid var(--color-border);position:relative}
.message-box::before,.message-box::after{content:'';position:absolute;width:24px;height:24px;border:2px solid var(--color-gold)}
.message-box::before{top:-2px;left:-2px;border-right:none;border-bottom:none}
.message-box::after{bottom:-2px;right:-2px;border-left:none;border-top:none}
.message-title{font-size:24px;font-weight:600;color:var(--color-navy);margin-bottom:32px;text-align:center;letter-spacing:.15em}
.message-text{font-size:16px;line-height:2.4;color:var(--color-text)}
.message-text p{margin-bottom:20px}
.message-sign{text-align:right;margin-top:32px;color:var(--color-navy)}
.message-sign .role{font-size:14px;letter-spacing:.2em;color:var(--color-text-light)}
.message-sign .name{font-size:22px;font-weight:600;margin-top:4px;letter-spacing:.2em}
.company-table-wrap{max-width:880px;margin:0 auto}
.company-table{width:100%;border-collapse:collapse}
.company-table th,.company-table td{padding:28px 20px;text-align:left;border-bottom:1px solid var(--color-border);font-size:16px;line-height:1.8}
.company-table th{width:200px;color:var(--color-navy);font-weight:600;letter-spacing:.1em;background:var(--color-cream);position:relative;padding-left:32px}
.company-table th::before{content:'';position:absolute;left:16px;top:50%;transform:translateY(-50%);width:4px;height:16px;background:linear-gradient(180deg,var(--color-gold),var(--color-purple))}
.company-table td{color:var(--color-text);padding-left:32px}

/* ================================================================
   お問い合わせページ
================================================================ */
.contact-intro{text-align:center;max-width:760px;margin:0 auto 56px;font-size:16px;line-height:2.2;color:var(--color-text-light)}
.contact-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;max-width:900px;margin:0 auto}
.contact-info-card{background:var(--color-white);border:1px solid var(--color-border);padding:36px 24px;text-align:center;border-radius:4px}
.contact-info-label{font-size:12px;letter-spacing:.4em;color:var(--color-gold);margin-bottom:12px;text-transform:uppercase}
.contact-info-value{font-size:18px;color:var(--color-navy);font-weight:600;line-height:1.6}
.contact-info-value.tel{font-size:24px}
.contact-tabs{max-width:880px;margin:0 auto}
.tab-buttons{display:grid;grid-template-columns:1fr 1fr;gap:0;border-radius:4px 4px 0 0;overflow:hidden;box-shadow:0 -4px 16px rgba(0,0,0,.05)}
.tab-button{padding:28px 16px;background:var(--color-white);color:var(--color-text-light);border:1px solid var(--color-border);border-bottom:none;font-family:var(--font-serif);font-size:17px;font-weight:600;letter-spacing:.15em;cursor:pointer;transition:all .3s ease;text-align:center;line-height:1.5;position:relative}
.tab-button .tab-en{display:block;font-size:11px;letter-spacing:.4em;color:var(--color-gold);margin-bottom:6px;font-weight:500}
.tab-button:hover{background:var(--color-cream);color:var(--color-navy)}
.tab-button.active{background:var(--color-white);color:var(--color-navy);border-color:var(--color-gold);border-bottom:1px solid var(--color-white);z-index:2}
.tab-button.active::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--color-gold),var(--color-purple))}
.tab-button:first-child{border-right:none}
.tab-button.active:first-child{border-right:1px solid var(--color-gold)}
.tab-button:last-child{border-left:none}
.tab-button.active:last-child{border-left:1px solid var(--color-gold)}
.contact-form-wrap{background:var(--color-white);padding:56px 48px;border:1px solid var(--color-gold);border-radius:0 0 4px 4px;margin-top:-1px;position:relative;z-index:1}
.form-pane{display:none}
.form-pane.active{display:block;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.form-pane-intro{padding:20px 24px;background:var(--color-cream);border-left:3px solid var(--color-gold);margin-bottom:36px;font-size:14px;line-height:2;color:var(--color-text-light)}
.form-pane-intro strong{color:var(--color-navy);display:block;font-size:16px;margin-bottom:6px;letter-spacing:.05em}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.form-group{margin-bottom:24px}
.form-group.full{grid-column:1/-1}
.form-label{display:block;font-size:14px;font-weight:600;color:var(--color-navy);margin-bottom:8px;letter-spacing:.08em}
.form-label .required{display:inline-block;background:var(--color-purple);color:var(--color-white);font-size:10px;padding:2px 7px;border-radius:2px;margin-left:8px;letter-spacing:.1em;vertical-align:middle}
.form-label .optional{display:inline-block;background:var(--color-border);color:var(--color-text-light);font-size:10px;padding:2px 7px;border-radius:2px;margin-left:8px;letter-spacing:.1em;vertical-align:middle}
.form-input,.form-textarea,.form-select{width:100%;padding:12px 14px;border:1px solid var(--color-border);border-radius:4px;font-family:var(--font-serif);font-size:15px;color:var(--color-text);background:var(--color-cream);transition:all .3s ease}
.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:var(--color-gold);background:var(--color-white);box-shadow:0 0 0 3px rgba(200,168,92,.15)}
.form-textarea{min-height:150px;resize:vertical}
.form-radio-group{display:flex;gap:24px;flex-wrap:wrap;padding:8px 0}
.form-radio-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:15px}
.form-radio-label input{accent-color:var(--color-purple);width:18px;height:18px}
.form-submit{display:block;width:100%;padding:18px;background:linear-gradient(135deg,var(--color-purple),var(--color-purple-dark));color:var(--color-white);border:1px solid var(--color-gold);border-radius:4px;font-family:var(--font-serif);font-size:16px;font-weight:600;letter-spacing:.3em;cursor:pointer;margin-top:16px;transition:all .3s ease}
.form-submit:hover{background:linear-gradient(135deg,var(--color-gold),var(--color-gold-dark));transform:translateY(-2px);box-shadow:0 8px 20px rgba(93,58,122,.3)}
.form-privacy{font-size:13px;color:var(--color-text-light);text-align:center;margin-top:16px;line-height:1.8}
.recruit-cta-banner{max-width:880px;margin:48px auto 0;padding:40px;background:linear-gradient(135deg,var(--color-purple-dark),var(--color-navy));color:var(--color-white);border-radius:4px;display:flex;justify-content:space-between;align-items:center;gap:32px;flex-wrap:wrap;position:relative;overflow:hidden}
.recruit-cta-banner::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(180deg,var(--color-gold),var(--color-gold-dark))}
.recruit-cta-banner-text{flex:1;min-width:240px}
.recruit-cta-banner-en{font-size:11px;letter-spacing:.4em;color:var(--color-gold);margin-bottom:8px;text-transform:uppercase}
.recruit-cta-banner h3{font-size:22px;font-weight:600;margin-bottom:8px;letter-spacing:.1em}
.recruit-cta-banner p{font-size:14px;opacity:.9;line-height:1.8}
.recruit-cta-btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;background:var(--color-gold);color:var(--color-white);font-weight:600;letter-spacing:.15em;border-radius:4px;border:1px solid var(--color-gold-light);font-size:14px;cursor:pointer;font-family:var(--font-serif);white-space:nowrap}
.recruit-cta-btn:hover{background:var(--color-gold-dark);color:var(--color-white);transform:translateY(-2px)}

/* ================================================================
   フッター
================================================================ */
.site-footer{background:var(--color-navy);color:var(--color-white);padding:64px 24px 24px;position:relative}
.site-footer::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:linear-gradient(90deg,var(--color-gold),var(--color-purple),var(--color-gold))}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-brand{display:flex;flex-direction:column;gap:20px}
.footer-logo{display:flex;align-items:center;gap:16px}
.footer-logo img{height:96px;width:96px;object-fit:contain;background:#fff;padding:6px;border-radius:8px}
.footer-brand-name{font-size:20px;font-weight:600;letter-spacing:.15em}
.footer-address{font-size:14px;line-height:2;opacity:.8}
.footer-nav{display:flex;flex-direction:column;gap:16px;text-align:right}
.footer-nav a{color:var(--color-white);font-size:14px;opacity:.8;letter-spacing:.1em}
.footer-nav a:hover{color:var(--color-gold);opacity:1}
.footer-copy{text-align:center;padding-top:24px;font-size:12px;opacity:.6;letter-spacing:.2em}

/* ================================================================
   アニメーション
================================================================ */
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* ================================================================
   表示制御（PC/スマホ切り替え）
================================================================ */
.sp-only{display:none}
.pc-only{display:inline}

/* ================================================================
   レスポンシブ
================================================================ */
@media (max-width:1100px){
    .strengths-list,.recruit-points{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:900px){
    .hamburger{display:flex}
    .nav-list{position:fixed;top:0;right:-100%;width:80%;max-width:320px;height:100vh;background:var(--color-white);flex-direction:column;justify-content:center;align-items:center;gap:32px;transition:right .4s ease;box-shadow:-8px 0 24px rgba(0,0,0,.1)}
    .nav-list.open{right:0}
    .nav-list a{font-size:18px}
    .header-inner{padding:12px 20px}
    .header-logo img{height:48px;width:48px}
    .header-logo-text{font-size:15px}
    .page-hero{padding:130px 16px 48px}
    .section{padding:64px 20px}
    .footer-inner{grid-template-columns:1fr;gap:32px;text-align:center}
    .footer-nav{text-align:center;align-items:center}
    .footer-logo{justify-content:center}
    .mission-keywords{gap:16px}
    .mission-keyword{min-width:140px;padding:20px 24px}
    .recruit-section{padding:80px 16px}
    .recruit-table-wrap{padding:32px 20px}
    .recruit-table th{width:120px;font-size:13px;padding:16px 8px;letter-spacing:.05em;white-space:normal}
    .recruit-table td{font-size:14px;padding:16px 8px}
    .company-table th{width:130px;font-size:14px;padding-left:24px}
    .company-table td{font-size:14px;padding-left:20px}
    .company-table th::before{left:12px}
    .message-box{padding:40px 24px}
    .contact-form-wrap{padding:36px 20px}
    .tab-button{padding:20px 8px;font-size:14px;letter-spacing:.08em}
    .tab-button .tab-en{font-size:10px;letter-spacing:.3em}
    .form-grid{grid-template-columns:1fr}
    .recruit-cta-banner{padding:28px;flex-direction:column;text-align:center}
    .recruit-cta-banner-text{text-align:center}
    .services-grid{grid-template-columns:repeat(4,1fr)}
    .service-card:nth-child(4),.service-card:nth-child(5){grid-column:span 2}
}
@media (max-width:600px){
    .sp-only{display:inline}
    .pc-only{display:none}
    .services-grid,.strengths-list,.recruit-points{grid-template-columns:1fr;gap:16px}
    .service-card{grid-column:span 1}
    .service-card:nth-child(4),.service-card:nth-child(5){grid-column:span 1}
    .section{padding:48px 16px}
    .recruit-table-wrap{padding:24px 16px}
    .recruit-table tr{display:block;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.12)}
    .recruit-table tr:last-child{border-bottom:none}
    .recruit-table th,.recruit-table td{display:block;width:auto;padding:6px 0;border:none;white-space:normal;line-height:1.9}
    .recruit-table th{font-size:13px;letter-spacing:.2em;color:var(--color-gold);margin-bottom:4px}
    .recruit-table td{font-size:14px;color:var(--color-white);opacity:.95}
    .recruit-message{padding:32px 20px}
    .recruit-message-quote{font-size:20px;letter-spacing:.05em}
    .recruit-section::after{font-size:120px;right:-40px}
    .hero-title br,.hero-subtitle br,.mission-text br,.service-desc br,.recruit-title br,.recruit-lead br,.recruit-message-text br,.recruit-cta-lead br{display:none}
    .hero-tagline{letter-spacing:.2em;font-size:12px}
    .mission-keyword{min-width:120px;padding:16px 20px}
    .company-table th,.company-table td{display:block;width:100%;border-bottom:none}
    .company-table th{font-size:13px;padding:16px 16px 4px 28px;letter-spacing:.15em;background:var(--color-cream)}
    .company-table th::before{top:18px;transform:none;left:12px}
    .company-table td{font-size:14px;padding:4px 16px 16px 28px;border-bottom:1px solid var(--color-border)}
    .company-table tr:last-child td{border-bottom:none}
    .message-box{padding:32px 20px}
}
@media (max-width:480px){
    .hero{padding:100px 20px 60px}
    .hero-cta{padding:16px 32px;font-size:14px}
}
