/*
Theme Name: DAYS CARGO
Theme URI: https://days-cargo.com/
Author: 株式会社Grow-Days
Description: DAYS CARGO 軽貨物事業専用サイト
Version: 2.1.1
Text Domain: days-cargo
*/

/* ===== BRAND COLORS (ロゴ準拠) ===== */
:root {
  --navy:        #1B2A4A;
  --navy-dark:   #111d33;
  --navy-mid:    #243559;
  --orange:      #E84A1A;
  --orange-light:#F06535;
  --orange-pale: rgba(232,74,26,0.1);
  --white:       #FFFFFF;
  --off-white:   #F5F3EE;
  --gray-light:  #ECEAE4;
  --gray:        #9B9893;
  --text:        #1A1A1A;
  --text-light:  #636060;
  --green:       #2ECC71;
  --red:         #E74C3C;

  --radius:    12px;
  --radius-lg: 22px;
  --shadow:    0 8px 40px rgba(0,0,0,0.10);
  --shadow-hov:0 20px 60px rgba(0,0,0,0.16);
  --trans:     all 0.32s cubic-bezier(0.25,0.46,0.45,0.94);
  --pad:       clamp(60px,8vw,120px);
}

/* ===== RESET ===== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Noto Sans JP','Hiragino Kaku Gothic ProN',sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}

.container{max-width:1200px;margin:0 auto;padding:0 clamp(20px,4vw,60px)}

/* ===== TYPE ===== */
h1,h2,h3,h4,h5{font-family:'Zen Kaku Gothic New','Noto Sans JP',sans-serif;font-weight:700;line-height:1.3}
.sec-label{display:inline-flex;align-items:center;gap:9px;font-size:.7rem;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.sec-label::before{content:'';width:26px;height:2px;background:var(--orange)}
.sec-title{font-size:clamp(1.85rem,3.6vw,2.8rem);color:var(--navy);margin-bottom:18px;line-height:1.3}
.sec-title em{color:var(--orange);font-style:normal}
.sec-desc{color:var(--text-light);line-height:1.95;max-width:560px;font-size:.95rem}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:100px;font-weight:700;font-size:.85rem;letter-spacing:.04em;cursor:pointer;border:2px solid transparent;transition:var(--trans);white-space:nowrap;font-family:inherit}
.btn svg{width:16px;height:16px;transition:transform .25s ease}
.btn:hover svg{transform:translateX(3px)}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:var(--orange-light);transform:translateY(-2px);box-shadow:0 8px 24px rgba(232,74,26,.38)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.55)}
.btn-outline:hover{background:#fff;color:var(--navy);transform:translateY(-2px)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-2px);box-shadow:0 8px 24px rgba(27,42,74,.35)}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--navy)}
.btn-ghost:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}

/* ===== HEADER ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:1000;height:70px;display:flex;align-items:center;justify-content:space-between;padding:0 clamp(20px,4vw,56px);background:rgba(17,29,51,.97);backdrop-filter:blur(20px);border-bottom:1px solid rgba(255,255,255,.07);transition:var(--trans)}
.site-header.scrolled{height:62px;box-shadow:0 4px 28px rgba(0,0,0,.4)}
.header-logo img{height:38px;width:auto}
.header-logo{display:flex;align-items:center}
.header-nav{display:flex;gap:26px}
.header-nav a{color:rgba(255,255,255,.75);font-size:.82rem;font-weight:500;letter-spacing:.04em;transition:color .2s;position:relative;padding-bottom:2px}
.header-nav a::after{content:'';position:absolute;bottom:-3px;left:0;right:0;height:2px;background:var(--orange);transform:scaleX(0);transition:transform .3s ease;transform-origin:left}
.header-nav a:hover{color:#fff}
.header-nav a:hover::after{transform:scaleX(1)}
.header-cta{display:flex;align-items:center;gap:12px}
.header-tel{color:var(--orange);font-size:.78rem;font-weight:700;display:flex;align-items:center;gap:5px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.hamburger span{display:block;width:24px;height:2px;background:#fff;transition:var(--trans)}

/* ===== MOBILE MENU ===== */
.mobile-menu{position:fixed;inset:0;background:var(--navy-dark);z-index:999;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;transform:translateX(100%);transition:transform .4s cubic-bezier(.25,.46,.45,.94)}
.mobile-menu.active{transform:translateX(0)}
.mobile-menu a{color:#fff;font-size:1.4rem;font-weight:700;letter-spacing:.04em}

/* ===== HERO ===== */
.hero{min-height:100vh;background:var(--navy-dark);position:relative;overflow:hidden;display:flex;align-items:center;padding-top:70px}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:54px 54px}
.hero-glow{position:absolute;top:10%;right:0;width:700px;height:700px;background:radial-gradient(circle,rgba(232,74,26,.08) 0%,transparent 65%);pointer-events:none}
.hero-glow2{position:absolute;bottom:-20%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(27,42,74,.7) 0%,transparent 70%);pointer-events:none}
.hero-inner{max-width:1200px;margin:0 auto;padding:clamp(70px,10vh,120px) clamp(20px,4vw,60px);display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(232,74,26,.14);border:1px solid rgba(232,74,26,.3);padding:7px 16px;border-radius:100px;font-size:.7rem;font-weight:700;letter-spacing:.2em;color:var(--orange);margin-bottom:24px;animation:fadeUp .7s ease forwards}
.hero h1{font-size:clamp(2.6rem,5.5vw,4.4rem);color:#fff;line-height:1.18;margin-bottom:22px;animation:fadeUp .7s .1s ease both}
.hero h1 em{color:var(--orange);font-style:normal;display:block}
.hero-desc{color:rgba(255,255,255,.65);font-size:1rem;line-height:1.95;margin-bottom:34px;animation:fadeUp .7s .2s ease both}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:46px;animation:fadeUp .7s .3s ease both}
.hero-stats{display:flex;gap:34px;padding-top:34px;border-top:1px solid rgba(255,255,255,.1);animation:fadeUp .7s .4s ease both}
.hstat-num{font-family:'Zen Kaku Gothic New',sans-serif;font-size:2.2rem;font-weight:900;color:var(--orange);line-height:1}
.hstat-num small{font-size:.9rem;color:rgba(255,255,255,.45)}
.hstat-label{font-size:.72rem;color:rgba(255,255,255,.42);margin-top:3px}
.hero-visual{animation:fadeLeft .8s .3s ease both}
.hcard{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);padding:36px;position:relative;overflow:hidden}
.hcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),var(--orange-light))}
.hcard-icon{width:52px;height:52px;background:rgba(232,74,26,.15);border-radius:13px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:1.4rem}
.hcard h3{color:#fff;font-size:1.12rem;margin-bottom:10px}
.hcard p{color:rgba(255,255,255,.55);font-size:.875rem;line-height:1.85}
.hcard-mini{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:18px}
.hmini{background:rgba(255,255,255,.05);border-radius:9px;padding:12px;text-align:center}
.hmini-val{font-family:'Zen Kaku Gothic New',sans-serif;font-size:1.3rem;font-weight:900;color:var(--orange);line-height:1}
.hmini-label{font-size:.68rem;color:rgba(255,255,255,.38);margin-top:3px}
.hfloat{position:absolute;bottom:-18px;right:-16px;background:var(--orange);border-radius:12px;padding:16px 20px;animation:float 4s ease-in-out infinite}
.hfloat-label{font-size:.62rem;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:.1em;text-transform:uppercase}
.hfloat-val{font-size:1.2rem;font-weight:900;color:#fff;line-height:1.2}

/* ===== SECTION BASE ===== */
.section{padding:var(--pad) 0}

/* ===== FEATURES ===== */
.features{background:var(--off-white)}
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:52px}
.feat-card{background:#fff;border-radius:var(--radius-lg);padding:34px 28px;border:1px solid rgba(0,0,0,.05);transition:var(--trans);position:relative;overflow:hidden}
.feat-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--orange),var(--orange-light));transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.feat-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-hov)}
.feat-card:hover::after{transform:scaleX(1)}
.feat-num{font-family:'Zen Kaku Gothic New',sans-serif;font-size:2.6rem;font-weight:900;color:rgba(232,74,26,.12);line-height:1;margin-bottom:12px}
.feat-icon{width:48px;height:48px;background:linear-gradient(135deg,var(--orange),var(--orange-light));border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;font-size:1.3rem}
.feat-card h3{font-size:1.05rem;color:var(--navy);margin-bottom:9px}
.feat-card p{font-size:.855rem;color:var(--text-light);line-height:1.85}

/* ===== SERVICES ===== */
.services{background:var(--navy-dark);position:relative;overflow:hidden}
.services::before{content:'SERVICE';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:18vw;font-weight:900;color:rgba(255,255,255,.02);font-family:'Zen Kaku Gothic New',sans-serif;pointer-events:none;white-space:nowrap}
.services .sec-title{color:#fff}
.services .sec-desc{color:rgba(255,255,255,.55)}
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:50px}
.svc-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-lg);padding:34px;transition:var(--trans)}
.svc-card:hover{background:rgba(255,255,255,.07);transform:translateY(-4px);border-color:rgba(232,74,26,.35)}
.svc-tag{display:inline-block;background:rgba(232,74,26,.18);color:var(--orange);font-size:.66rem;font-weight:700;letter-spacing:.14em;padding:4px 11px;border-radius:100px;margin-bottom:13px}
.svc-card h3{color:#fff;font-size:1.12rem;margin-bottom:9px}
.svc-card p{color:rgba(255,255,255,.52);font-size:.855rem;line-height:1.85;margin-bottom:16px}
.svc-feats{display:flex;flex-wrap:wrap;gap:8px}
.svc-feat{font-size:.78rem;color:rgba(255,255,255,.62);display:flex;align-items:center;gap:5px}
.svc-feat::before{content:'✓';color:var(--orange);font-weight:700}

/* ===== NEWS ===== */
.news{background:#fff}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.news-card{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--gray-light);transition:var(--trans);display:flex;flex-direction:column;background:#fff}
.news-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hov);border-color:var(--orange)}
.news-thumb{width:100%;aspect-ratio:16/9;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);display:flex;align-items:center;justify-content:center;font-size:2.5rem;overflow:hidden;position:relative}
.news-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.news-cat{display:inline-block;font-size:.66rem;font-weight:700;letter-spacing:.12em;padding:3px 10px;border-radius:100px;margin-bottom:8px}
.news-cat.info{background:rgba(27,42,74,.1);color:var(--navy)}
.news-cat.recruit{background:rgba(232,74,26,.1);color:var(--orange)}
.news-cat.service{background:rgba(46,204,113,.1);color:#27ae60}
.news-body{padding:22px;flex:1;display:flex;flex-direction:column}
.news-date{font-size:.74rem;color:var(--gray);margin-bottom:6px;display:flex;align-items:center;gap:5px}
.news-card h3{font-size:.95rem;color:var(--navy);line-height:1.55;margin-bottom:10px;flex:1}
.news-card h3 a:hover{color:var(--orange)}
.news-more{font-size:.8rem;color:var(--orange);font-weight:700;display:flex;align-items:center;gap:4px;margin-top:auto}
.news-more::after{content:'→';transition:transform .2s}
.news-card:hover .news-more::after{transform:translateX(4px)}
.news-all{text-align:center;margin-top:40px}

/* archive-post page */
.news-archive{padding:var(--pad) 0;background:var(--off-white)}
.news-archive-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
.post-single{padding:var(--pad) 0;background:var(--off-white)}
.post-content{background:#fff;border-radius:var(--radius-lg);padding:clamp(30px,5vw,60px);max-width:800px;margin:0 auto}
.post-content h1{color:var(--navy);font-size:clamp(1.5rem,3vw,2rem);margin-bottom:16px;line-height:1.4}
.post-meta{display:flex;align-items:center;gap:12px;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid var(--gray-light)}
.post-body{color:var(--text);line-height:1.9;font-size:.95rem}
.post-body h2{font-size:1.3rem;color:var(--navy);margin:32px 0 12px;padding-left:12px;border-left:3px solid var(--orange)}
.post-body p{margin-bottom:16px}
.post-body ul{padding-left:1.5em;margin-bottom:16px;list-style:disc}

/* ===== RECRUIT ===== */
.recruit{background:#fff}
.recruit-hero{background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy-mid) 100%);border-radius:var(--radius-lg);padding:clamp(44px,7vw,88px) clamp(28px,5vw,70px);display:grid;grid-template-columns:1fr 1fr;gap:52px;align-items:center;position:relative;overflow:hidden;margin-bottom:52px}
.recruit-hero::before{content:'';position:absolute;top:-40%;right:-15%;width:520px;height:520px;background:radial-gradient(circle,rgba(232,74,26,.1) 0%,transparent 70%);pointer-events:none}
.recruit-hero h2{color:#fff;font-size:clamp(1.8rem,3.5vw,2.6rem);line-height:1.3}
.recruit-hero h2 em{color:var(--orange);font-style:normal}
.recruit-hero p{color:rgba(255,255,255,.62);margin-top:13px;line-height:1.92;font-size:.95rem}
.rh-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.rbenefits{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.rbenefit{background:rgba(255,255,255,.07);border-radius:11px;padding:17px;display:flex;align-items:flex-start;gap:10px}
.rbenefit-icon{width:32px;height:32px;background:var(--orange);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:.95rem;flex-shrink:0}
.rbenefit strong{display:block;color:#fff;font-size:.84rem;margin-bottom:2px}
.rbenefit span{color:rgba(255,255,255,.42);font-size:.74rem}
.job-list{display:flex;flex-direction:column;gap:20px}
.job-card{border:2px solid var(--gray-light);border-radius:var(--radius-lg);padding:30px 34px;transition:var(--trans);display:grid;grid-template-columns:1fr auto;gap:18px;align-items:start;background:#fff}
.job-card:hover{border-color:var(--orange);box-shadow:0 10px 38px rgba(232,74,26,.13);transform:translateY(-3px)}
.job-type{display:inline-flex;align-items:center;gap:5px;background:rgba(232,74,26,.09);color:var(--orange);border:1px solid rgba(232,74,26,.26);padding:4px 12px;border-radius:100px;font-size:.7rem;font-weight:700;letter-spacing:.08em;margin-bottom:9px}
.job-card h3{font-size:1.15rem;color:var(--navy);margin-bottom:12px}
.job-details{display:flex;flex-wrap:wrap;gap:16px;margin-top:8px}
.jd{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-light)}
.jd-icon{color:var(--orange);font-size:.9rem}
.jd strong{color:var(--text);font-weight:600}
.job-actions{display:flex;flex-direction:column;gap:9px;align-items:flex-end}
.job-badge{display:inline-block;background:var(--green);color:#fff;font-size:.68rem;font-weight:700;padding:4px 10px;border-radius:100px}
.job-badge.urgent{background:var(--red)}

/* ===== FLOW ===== */
.flow{background:var(--off-white)}
.flow-steps{display:grid;grid-template-columns:repeat(4,1fr);margin-top:52px;position:relative}
.flow-steps::before{content:'';position:absolute;top:37px;left:12.5%;right:12.5%;height:2px;background:linear-gradient(90deg,var(--orange),rgba(232,74,26,.2));z-index:0}
.flow-step{text-align:center;padding:0 16px;position:relative;z-index:1}
.step-num{width:74px;height:74px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:'Zen Kaku Gothic New',sans-serif;font-size:1.35rem;font-weight:900;color:#fff;box-shadow:0 8px 22px rgba(232,74,26,.3);position:relative}
.step-num::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(232,74,26,.28)}
.flow-step h4{font-size:.95rem;color:var(--navy);margin-bottom:7px}
.flow-step p{font-size:.82rem;color:var(--text-light);line-height:1.75}

/* ===== VOICE ===== */
.voice{background:#fff}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.voice-card{background:var(--off-white);border-radius:var(--radius-lg);padding:30px;position:relative}
.voice-card::before{content:'"';position:absolute;top:18px;right:22px;font-size:4.5rem;color:rgba(232,74,26,.16);font-family:Georgia,serif;line-height:1}
.voice-avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-light));display:flex;align-items:center;justify-content:center;font-size:1.2rem;margin-bottom:14px}
.voice-card h4{font-size:.93rem;color:var(--navy);margin-bottom:3px}
.voice-meta{font-size:.76rem;color:var(--text-light);margin-bottom:13px}
.voice-card p{font-size:.855rem;color:var(--text-light);line-height:1.85}

/* ===== COMPANY ===== */
.company{background:var(--off-white)}
.co-wrap{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start;margin-top:52px}
.co-table{width:100%;border-collapse:collapse}
.co-table tr{border-bottom:1px solid rgba(0,0,0,.06)}
.co-table td{padding:14px 0;font-size:.88rem}
.co-table td:first-child{color:var(--text-light);font-weight:600;width:34%;letter-spacing:.04em}
.highlights{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}
.hl{background:#fff;border-radius:13px;padding:24px;text-align:center;border:1px solid rgba(0,0,0,.05);transition:var(--trans)}
.hl:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.hl-num{font-family:'Zen Kaku Gothic New',sans-serif;font-size:2.1rem;font-weight:900;color:var(--orange);line-height:1.15}
.hl-unit{font-size:.9rem;color:var(--gray)}
.hl-label{font-size:.74rem;color:var(--text-light);margin-top:3px}
.license-box{background:#fff;border-radius:13px;padding:24px;border:1px solid rgba(0,0,0,.05)}
.license-box h4{color:var(--navy);margin-bottom:11px;font-size:.93rem}
.license-item{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--text-light);padding:7px 0;border-bottom:1px solid var(--gray-light)}
.license-item:last-child{border-bottom:none}
.license-item::before{content:'✓';color:var(--orange);font-weight:700;flex-shrink:0}

/* ===== CONTACT ===== */
.contact{background:var(--navy-dark)}
.contact .sec-title{color:#fff}
.contact .sec-desc{color:rgba(255,255,255,.52)}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;margin-top:50px}
.cf-wrap{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-lg);padding:38px}
.cf-wrap h3{color:#fff;font-size:1.12rem;margin-bottom:6px}
.cf-sub{color:rgba(255,255,255,.42);font-size:.8rem;margin-bottom:24px;display:flex;align-items:center;gap:7px}
.cf-sub span{background:rgba(232,74,26,.18);color:var(--orange);font-size:.66rem;padding:3px 9px;border-radius:100px;font-weight:700}
.ctabs{display:flex;gap:10px;margin-bottom:22px}
.ctab{flex:1;padding:11px;border:1px solid rgba(255,255,255,.17);border-radius:10px;background:transparent;color:rgba(255,255,255,.42);font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--trans);font-family:inherit;text-align:center}
.ctab.active{background:var(--orange);border-color:var(--orange);color:#fff}
.ctab:hover:not(.active){border-color:rgba(255,255,255,.35);color:#fff}
.fg{margin-bottom:16px}
.fg label{display:block;color:rgba(255,255,255,.72);font-size:.8rem;font-weight:600;margin-bottom:6px}
.fg label .req{color:var(--orange);margin-left:3px}
.fg input,.fg select,.fg textarea{width:100%;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:9px;padding:11px 15px;color:#fff;font-size:.875rem;font-family:inherit;outline:none;transition:var(--trans)}
.fg input::placeholder,.fg textarea::placeholder{color:rgba(255,255,255,.26)}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,74,26,.14)}
.fg select option{background:var(--navy-dark);color:#fff}
.fg textarea{height:108px;resize:vertical}
.fg-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.fsub{width:100%;padding:15px;background:var(--orange);color:#fff;border:none;border-radius:100px;font-size:.95rem;font-weight:800;cursor:pointer;transition:var(--trans);font-family:inherit;display:flex;align-items:center;justify-content:center;gap:8px;letter-spacing:.04em}
.fsub:hover{background:var(--orange-light);transform:translateY(-2px);box-shadow:0 10px 26px rgba(232,74,26,.36)}
.form-section{display:none}
.form-section.active{display:block}
.cinfo{display:flex;flex-direction:column;gap:22px}
.ci-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.09);border-radius:var(--radius-lg);padding:28px}
.ci-card h3{color:#fff;font-size:.98rem;margin-bottom:13px;display:flex;align-items:center;gap:7px}
.ci-card h3 .ico{color:var(--orange)}
.ci-tel{font-family:'Zen Kaku Gothic New',sans-serif;font-size:1.8rem;font-weight:900;color:#fff;display:flex;align-items:center;gap:7px;margin-bottom:5px}
.ci-tel .ico{color:var(--orange);font-size:1.3rem}
.ci-hours{font-size:.8rem;color:rgba(255,255,255,.42)}
.ci-addr{font-size:.875rem;color:rgba(255,255,255,.62);line-height:1.85}
.ci-faq{background:rgba(232,74,26,.08);border-color:rgba(232,74,26,.2)}
.ci-faq h3{color:var(--orange)}
.faq-item{margin-bottom:13px}
.faq-item:last-child{margin-bottom:0}
.faq-q{color:#fff;font-size:.86rem;font-weight:700;margin-bottom:3px}
.faq-a{color:rgba(255,255,255,.52);font-size:.82rem}

/* ===== PRIVACY PAGE ===== */
.privacy{padding:var(--pad) 0;background:var(--off-white)}
.privacy-content{background:#fff;border-radius:var(--radius-lg);padding:clamp(32px,5vw,64px);max-width:900px;margin:0 auto}
.privacy-content h1{color:var(--navy);font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:10px}
.privacy-date{color:var(--text-light);font-size:.82rem;margin-bottom:36px;padding-bottom:20px;border-bottom:1px solid var(--gray-light)}
.privacy-content h2{color:var(--navy);font-size:1.1rem;margin:32px 0 12px;padding-left:12px;border-left:3px solid var(--orange);font-family:'Zen Kaku Gothic New',sans-serif}
.privacy-content p{color:var(--text-light);line-height:1.9;font-size:.9rem;margin-bottom:14px}
.privacy-content ul{padding-left:1.4em;margin-bottom:14px}
.privacy-content ul li{color:var(--text-light);font-size:.9rem;line-height:1.85;list-style:disc;margin-bottom:4px}
.privacy-content .company-sign{margin-top:40px;padding-top:24px;border-top:1px solid var(--gray-light)}
.privacy-content .company-sign p{color:var(--navy);font-weight:700;font-size:.9rem}

/* ===== PAGE HERO ===== */
.page-hero{background:var(--navy-dark);padding:clamp(110px,16vw,180px) 0 clamp(55px,7vw,90px);text-align:center;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:48px 48px}
.page-hero h1{color:#fff;font-size:clamp(2rem,4vw,3.2rem);position:relative;z-index:1}
.page-hero p{color:rgba(255,255,255,.55);margin-top:14px;font-size:1rem;position:relative;z-index:1}
.breadcrumb{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;font-size:.78rem;color:rgba(255,255,255,.4);position:relative;z-index:1}
.breadcrumb a{color:rgba(255,255,255,.4);transition:color .2s}
.breadcrumb a:hover{color:var(--orange)}
.breadcrumb span{color:rgba(255,255,255,.25)}

/* ===== FOOTER ===== */
.site-footer{background:#080e18;padding:50px 0 26px;border-top:1px solid rgba(255,255,255,.06)}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;margin-bottom:44px}
.fb-logo{height:36px;width:auto;margin-bottom:14px}
.fb p{font-size:.82rem;color:rgba(255,255,255,.33);line-height:1.85;margin-bottom:14px}
.fb-link{color:var(--orange);font-size:.78rem;display:flex;align-items:center;gap:4px;width:fit-content}
.fc h4{color:#fff;font-size:.8rem;font-weight:700;letter-spacing:.1em;margin-bottom:14px}
.fc ul{display:flex;flex-direction:column;gap:9px}
.fc ul a{color:rgba(255,255,255,.36);font-size:.8rem;transition:color .2s;display:flex;align-items:center;gap:5px}
.fc ul a::before{content:'→';color:var(--orange);font-size:.66rem}
.fc ul a:hover{color:var(--orange)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;border-top:1px solid rgba(255,255,255,.06);gap:14px;flex-wrap:wrap}
.footer-bottom p{font-size:.74rem;color:rgba(255,255,255,.26)}
.footer-links{display:flex;gap:18px}
.footer-links a{font-size:.74rem;color:rgba(255,255,255,.26);transition:color .2s}
.footer-links a:hover{color:var(--orange)}

/* ===== SCROLL TOP ===== */
.scroll-top{position:fixed;bottom:28px;right:28px;width:46px;height:46px;background:var(--orange);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:500;opacity:0;transform:translateY(18px);transition:var(--trans);border:none;color:#fff;font-size:1.1rem;font-weight:900;box-shadow:0 4px 18px rgba(232,74,26,.4)}
.scroll-top.vis{opacity:1;transform:translateY(0)}
.scroll-top:hover{background:var(--orange-light);transform:translateY(-4px)}

/* ===== ANIMATIONS ===== */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeLeft{from{opacity:0;transform:translateX(38px)}to{opacity:1;transform:translateX(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.vis{opacity:1;transform:translateY(0)}
.d1{transition-delay:.1s}.d2{transition-delay:.2s}.d3{transition-delay:.3s}.d4{transition-delay:.4s}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .hero-inner{grid-template-columns:1fr}.hero-visual{display:none}
  .feat-grid{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:1fr}
  .news-grid,.news-archive-grid{grid-template-columns:1fr 1fr}
  .voice-grid{grid-template-columns:1fr 1fr}
  .co-wrap{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  .site-header{padding:0 20px}.header-nav{display:none}.hamburger{display:flex}.header-tel{display:none}
  .hero-inner,.contact-grid{padding:60px 20px;grid-template-columns:1fr}
  .recruit-hero{grid-template-columns:1fr}
  .flow-steps{grid-template-columns:1fr 1fr;gap:32px}.flow-steps::before{display:none}
  .feat-grid,.voice-grid,.news-grid,.news-archive-grid{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr 1fr;gap:32px}
  .container{padding:0 20px}
  .job-card{grid-template-columns:1fr}.job-actions{align-items:flex-start}
  .co-wrap{gap:34px}.fg-row{grid-template-columns:1fr}
  .rbenefits{grid-template-columns:1fr}
  .highlights{grid-template-columns:1fr 1fr}
}
@media(max-width:480px){
  .footer-inner{grid-template-columns:1fr}
  .ctabs{flex-direction:column}
}

/* ── 求人詳細ページ スマホ対応 ── */
@media(max-width:768px){
  /* 給与ハイライトバー */
  .job-detail-hero{
    flex-direction:column;
    align-items:flex-start;
    padding:24px 20px !important;
  }
  .job-detail-hero .apply-btns{
    align-items:stretch !important;
    width:100%;
  }
  .job-detail-hero .apply-btns a{
    text-align:center;
    padding:14px 20px !important;
    font-size:.95rem !important;
  }
  /* 2カラム → 1カラム */
  .job-detail-grid{
    grid-template-columns:1fr !important;
  }
  /* サイドバーのstickyを解除 */
  .job-detail-sidebar{
    position:static !important;
  }
  /* テーブルのラベル列を少し狭く */
  .job-detail-grid table td:first-child{
    width:30% !important;
    font-size:.82rem;
  }
  /* 給与の大きい数字 */
  .salary-display{
    font-size:1.9rem !important;
  }
}
@media(max-width:480px){
  .job-detail-grid table td:first-child{
    width:28% !important;
  }
}

/* ── 求人一覧・カード スマホ追加改善 ── */
@media(max-width:768px){
  .job-card{
    padding:20px 18px !important;
  }
  .job-card h3{
    font-size:1.05rem;
  }
  .job-details{
    gap:10px;
  }
  .job-actions{
    flex-direction:row;
    flex-wrap:wrap;
    gap:8px;
    margin-top:4px;
  }
  .job-actions .btn{
    flex:1;
    text-align:center;
    min-width:120px;
  }
}


/* ================================================
   協力会社募集ページ (page-partner.php) 全面刷新
   ================================================ */

/* ── ヒーロー ── */
.pt-hero { background:var(--navy-dark); position:relative; overflow:hidden; padding-top:70px; }
.pt-hero-bg { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px); background-size:48px 48px; }
.pt-hero-bg::after { content:''; position:absolute; top:-20%; right:-10%; width:600px; height:600px; background:radial-gradient(circle,rgba(232,74,26,.12) 0%,transparent 65%); pointer-events:none; }
.pt-hero-inner { display:grid; grid-template-columns:1fr 320px; gap:60px; align-items:center; padding-top:clamp(60px,8vh,100px); padding-bottom:clamp(60px,8vh,100px); position:relative; z-index:2; }
.pt-eyebrow { display:inline-flex; align-items:center; background:rgba(232,74,26,.14); border:1px solid rgba(232,74,26,.3); padding:6px 16px; border-radius:100px; font-size:.7rem; font-weight:700; letter-spacing:.2em; color:var(--orange); margin-bottom:24px; }
.pt-hero-title { font-size:clamp(2.2rem,4.5vw,3.4rem); color:#fff; line-height:1.2; margin-bottom:22px; }
.pt-hero-title em { color:var(--orange); font-style:normal; display:block; }
.pt-hero-desc { color:rgba(255,255,255,.65); font-size:.95rem; line-height:1.95; margin-bottom:34px; }
.pt-hero-actions { display:flex; gap:14px; flex-wrap:wrap; }
.pt-hero-stats { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-lg); padding:28px 24px; display:flex; flex-direction:column; gap:20px; }
.pt-stat { padding-bottom:18px; border-bottom:1px solid rgba(255,255,255,.08); }
.pt-stat:last-child { padding-bottom:0; border-bottom:none; }
.pt-stat-num { font-family:'Zen Kaku Gothic New',sans-serif; font-size:1.5rem; font-weight:900; color:var(--orange); line-height:1.1; margin-bottom:4px; }
.pt-stat-num span { font-size:.95rem; color:rgba(255,255,255,.7); font-weight:700; }
.pt-stat-label { font-size:.75rem; color:rgba(255,255,255,.4); }

/* ── こんな方へ ── */
.pt-welcome { background:var(--off-white); }
.pt-welcome-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.pt-welcome-card { background:#fff; border-radius:var(--radius-lg); padding:28px 22px; border:1.5px solid var(--gray-light); transition:var(--trans); }
.pt-welcome-card:hover { border-color:var(--orange); box-shadow:0 8px 28px rgba(232,74,26,.12); transform:translateY(-4px); }
.pt-wc-icon { font-size:1.8rem; margin-bottom:12px; }
.pt-welcome-card h3 { font-size:.92rem; color:var(--navy); margin-bottom:8px; font-weight:700; }
.pt-welcome-card p { font-size:.82rem; color:var(--text-light); line-height:1.75; }

/* ── 取引条件テーブル ── */
.pt-conditions { background:var(--off-white); }
.pt-table-wrap { border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 4px 24px rgba(0,0,0,.08); border:1.5px solid var(--gray-light); }
.pt-table { width:100%; border-collapse:collapse; }
.pt-table tr { border-bottom:1px solid var(--gray-light); }
.pt-table tr:last-child { border-bottom:none; }
.pt-table tr:nth-child(even) td { background:#fafafa; }
.pt-table tr:nth-child(even) th { background:rgba(232,74,26,.06); }
.pt-table th { width:30%; padding:18px 22px; background:rgba(232,74,26,.04); color:var(--navy); font-weight:700; font-size:.88rem; border-right:2px solid var(--orange); vertical-align:middle; white-space:nowrap; }
.pt-th-icon { margin-right:8px; }
.pt-table td { padding:18px 24px; color:var(--text); font-size:.9rem; line-height:1.8; }
.pt-table td small { display:block; font-size:.78rem; color:var(--text-light); margin-top:3px; }

/* ── 流れ ── */
.pt-flow { background:#fff; }
.pt-flow-grid { display:flex; align-items:center; gap:0; overflow-x:auto; padding-bottom:8px; }
.pt-flow-step { flex:1; min-width:150px; text-align:center; padding:28px 16px; background:var(--off-white); border-radius:var(--radius-lg); border:1.5px solid var(--gray-light); transition:var(--trans); }
.pt-flow-step:hover { border-color:var(--orange); box-shadow:0 6px 24px rgba(232,74,26,.1); }
.pt-flow-num { font-family:'Zen Kaku Gothic New',sans-serif; font-size:.72rem; font-weight:900; color:var(--orange); letter-spacing:.1em; margin-bottom:8px; }
.pt-flow-icon { font-size:1.8rem; margin-bottom:10px; }
.pt-flow-step h3 { font-size:.88rem; color:var(--navy); margin-bottom:6px; }
.pt-flow-step p { font-size:.76rem; color:var(--text-light); line-height:1.65; }
.pt-flow-arrow { font-size:1.2rem; color:var(--orange); flex-shrink:0; padding:0 8px; opacity:.5; }

/* ── FAQ ── */
.pt-faq-section { background:var(--off-white); }
.pt-faq-list { display:flex; flex-direction:column; gap:12px; }
.pt-faq-item { background:#fff; border-radius:var(--radius); border:1.5px solid var(--gray-light); overflow:hidden; transition:border-color .25s; }
.pt-faq-item.open { border-color:var(--orange); }
.pt-faq-q { display:flex; align-items:center; gap:14px; padding:18px 22px; cursor:pointer; font-weight:700; font-size:.9rem; color:var(--navy); user-select:none; transition:background .2s; }
.pt-faq-q:hover { background:var(--off-white); }
.pt-faq-q span:nth-child(2) { flex:1; }
.pt-faq-toggle { font-size:1.2rem; color:var(--orange); flex-shrink:0; }
.pt-faq-a { display:none; align-items:flex-start; gap:14px; padding:0 22px 18px; font-size:.88rem; color:var(--text-light); line-height:1.85; }
.pt-faq-item.open .pt-faq-a { display:flex; }
.pt-faq-badge { background:var(--orange); color:#fff; font-weight:800; font-size:.72rem; width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.pt-faq-badge-a { background:var(--navy); }

/* ── CTA ── */
.pt-cta-section { position:relative; overflow:hidden; padding:var(--pad) 0; background:var(--navy-dark); }
.pt-cta-bg { position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px); background-size:48px 48px; }
.pt-cta-inner { position:relative; z-index:1; display:grid; grid-template-columns:1fr 300px; gap:60px; align-items:center; }
.pt-cta-actions { display:flex; flex-direction:column; gap:12px; }
.pt-tel-btn { display:flex; align-items:center; justify-content:center; padding:14px 20px; border:2px solid rgba(255,255,255,.3); border-radius:100px; color:#fff; font-weight:700; font-size:.9rem; transition:var(--trans); text-decoration:none; }
.pt-tel-btn:hover { background:rgba(255,255,255,.1); }

/* ── TOPページ 協力会社セクション ── */
.top-partner { background:var(--navy-dark); }
.top-partner .sec-title { color:#fff; }
.top-partner .sec-desc { color:rgba(255,255,255,.52); }
.top-partner-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.top-partner-card { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius-lg); padding:32px 26px; transition:var(--trans); }
.top-partner-card:hover { background:rgba(255,255,255,.07); border-color:rgba(232,74,26,.4); transform:translateY(-4px); }
.tpc-icon { font-size:2rem; margin-bottom:14px; }
.top-partner-card h3 { color:#fff; font-size:1rem; margin-bottom:10px; }
.top-partner-card p { color:rgba(255,255,255,.52); font-size:.84rem; line-height:1.8; }

/* ── レスポンシブ ── */
@media(max-width:1024px) {
  .pt-welcome-grid { grid-template-columns:repeat(2,1fr); }
  .top-partner-grid { grid-template-columns:1fr 1fr; }
}
@media(max-width:768px) {
  .pt-hero-inner { grid-template-columns:1fr; gap:28px; }
  .pt-hero-stats { flex-direction:row; flex-wrap:wrap; padding:18px; }
  .pt-stat { padding-bottom:0; border-bottom:none; flex:1; min-width:100px; }
  .pt-welcome-grid,.top-partner-grid { grid-template-columns:1fr; }
  .pt-table th { width:36%; padding:13px 12px; font-size:.82rem; white-space:normal; }
  .pt-table td { padding:13px 14px; font-size:.84rem; }
  .pt-flow-grid { flex-direction:column; align-items:stretch; }
  .pt-flow-step { min-width:auto; }
  .pt-flow-arrow { transform:rotate(90deg); text-align:center; }
  .pt-cta-inner { grid-template-columns:1fr; gap:32px; }
}
