/* ===================================================================
   ASFARES 2026 — main.css
   紺 #0d1430 / 山吹 #ffe14d / オレンジ #ff5a1f / クリーム #f4f2ec
=================================================================== */
:root{
  /* === アスファレス・ブルー：水色を主役に、安心感のある青で構成 === */
  --navy:#0a2a52;     /* 深い信頼ブルー（背景・見出し） */
  --cream:#eef4fb;    /* 青みのある明るい背景 */
  --yellow:#79d8ff;   /* 明るい水色アクセント（旧yellow役・ハイライト/強調文字） */
  --orange:#1f86cf;   /* メインアクセント青（見出しキッカー・罫線・アイコン） */
  --orange2:#49c4f2;  /* 暗背景上の明るい水色アクセント */
  --grad:linear-gradient(120deg,#2bb6e8,#1f7fd1); /* 水色→青のグラデ（ボタン） */
  --ink:#10243f;      /* 本文の濃紺 */
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  font-family:'Noto Sans JP',sans-serif;
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.7;
}
a{color:inherit;text-decoration:none;-webkit-tap-highlight-color:transparent}
img{max-width:100%;display:block}
.asf-y{color:var(--yellow)}
.asf-en{font-family:'Anton',sans-serif;letter-spacing:.28em}
.asf-jp{font-family:'Zen Kaku Gothic New',sans-serif}
.asf-wrap{max-width:1280px;margin:0 auto}
.asf-mark{background:var(--yellow);padding:.02em .12em;-webkit-box-decoration-break:clone;box-decoration-break:clone}

/* ---- 画像プレースホルダー ---- */
.asf-ph{
  width:100%;height:100%;min-height:inherit;
  background:
    repeating-linear-gradient(45deg,rgba(255,255,255,.025) 0 12px,transparent 12px 24px),
    linear-gradient(135deg,#123a66,#0a2a52);
  display:flex;align-items:center;justify-content:center;
}
.asf-ph span{
  font-size:12px;letter-spacing:.1em;color:rgba(255,255,255,.45);
  font-family:'Zen Kaku Gothic New';font-weight:700;text-align:center;padding:0 12px;
}

/* ---- ボタン ---- */
.asf-btn{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:900;font-size:16px;padding:19px 38px;border-radius:3px;
  font-family:'Zen Kaku Gothic New';
}
.asf-btn-primary{background:var(--grad);color:#fff;box-shadow:0 12px 30px rgba(255,90,31,.35)}
.asf-btn-white{background:#fff;color:var(--navy)}
.asf-btn-arrow{font-family:'Anton'}
.asf-more{color:var(--orange);font-size:14px;font-weight:900;border-bottom:2px solid var(--orange);padding-bottom:5px;font-family:'Zen Kaku Gothic New'}

/* ===================================================================
   HEADER
=================================================================== */
.asf-header{
  position:fixed;top:0;left:0;width:100%;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(20px,5vw,60px);
  transition:background .35s,box-shadow .35s,padding .35s;
}
.asf-header.is-solid{background:rgba(13,20,48,.96);box-shadow:0 6px 24px rgba(0,0,0,.2);padding-top:12px;padding-bottom:12px}
.asf-logo{display:flex;align-items:center;gap:12px}
.asf-logo img{height:34px;width:auto}
.asf-logo .asf-logo-tx{font-family:'Zen Kaku Gothic New';font-weight:900;color:#fff;font-size:20px;letter-spacing:.04em}
.asf-nav-list{list-style:none;display:flex;align-items:center;gap:clamp(14px,2vw,30px)}
.asf-nav-list a{color:#fff;font-weight:700;font-size:14px;font-family:'Zen Kaku Gothic New';position:relative;padding:6px 0}
.asf-nav-list a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--yellow);transition:width .3s}
.asf-nav-list a:hover::after{width:100%}
.asf-nav-cta{background:var(--grad);color:#fff!important;padding:11px 22px;border-radius:3px;box-shadow:0 8px 20px rgba(255,90,31,.3)}
.asf-nav-cta::after{display:none}
.asf-nav-wrap{display:flex;align-items:center;gap:clamp(14px,2vw,30px)}
.asf-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px;z-index:120}
.asf-burger span{width:26px;height:2px;background:#fff;transition:transform .3s,opacity .3s}
.asf-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.asf-burger.is-open span:nth-child(2){opacity:0}
.asf-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ===================================================================
   セクション共通
=================================================================== */
.asf-sec{padding:clamp(70px,9vw,120px) clamp(20px,5vw,80px);position:relative;overflow:hidden}
.asf-sec--navy{background:var(--navy);color:#fff}
.asf-sec--white{background:#fff}
.asf-sec--cream{background:var(--cream)}
.asf-ghost{position:absolute;font-family:'Anton';line-height:.85;color:transparent;white-space:nowrap;pointer-events:none;user-select:none}
.asf-head-c{text-align:center;margin-bottom:56px}
.asf-kicker{font-family:'Anton';letter-spacing:.28em;font-size:13px;color:var(--orange)}
.asf-kicker--lt{color:var(--orange2)}
.asf-h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(30px,4.5vw,54px);margin-top:12px;line-height:1.25;word-break:auto-phrase}
.asf-line{display:flex;align-items:center;gap:12px}
.asf-line span:first-child{width:32px;height:2px;background:var(--orange)}

/* ===================================================================
   HERO
=================================================================== */
.asf-hero{
  position:relative;width:100%;min-height:clamp(620px,90vh,940px);
  display:flex;align-items:center;overflow:hidden;background:var(--navy);
  padding:140px clamp(20px,5vw,80px) 90px;
}
.asf-hero__bg{position:absolute;inset:0;width:100%;height:100%}
.asf-hero__bg img,.asf-hero__bg .asf-ph{width:100%;height:100%;object-fit:cover}
.asf-hero__veil{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(100deg,rgba(13,20,48,.92) 0%,rgba(13,20,48,.62) 40%,rgba(13,20,48,.2) 72%,rgba(13,20,48,0) 100%);}
.asf-hero__kanji{
  position:absolute;right:clamp(8px,3vw,48px);top:50%;transform:translateY(-50%);
  writing-mode:vertical-rl;font-family:'Zen Kaku Gothic New';font-weight:900;
  font-size:clamp(70px,13vw,190px);line-height:.9;color:transparent;
  -webkit-text-stroke:1.5px rgba(255,255,255,.16);letter-spacing:.05em;pointer-events:none;
}
.asf-hero__inner{position:relative;z-index:2;max-width:1280px;margin:0 auto;width:100%}
.asf-hero__eyebrow{color:#fff;font-family:'Anton';letter-spacing:.3em;font-size:14px}
.asf-hero h1{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(46px,8vw,108px);line-height:1.12;color:#fff;margin-top:26px;text-shadow:0 2px 30px rgba(0,0,0,.4);word-break:auto-phrase}
.asf-hero__lead{font-family:'Zen Kaku Gothic New';font-weight:700;color:#fff;font-size:clamp(16px,2vw,24px);margin-top:28px;line-height:1.7;text-shadow:0 1px 14px rgba(0,0,0,.5)}
.asf-hero__sub{color:rgba(255,255,255,.82);font-size:clamp(14px,1.4vw,16px);margin-top:14px;line-height:1.9;max-width:460px;text-shadow:0 1px 10px rgba(0,0,0,.5)}
.asf-hero__btns{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}
.asf-hero__stats{display:flex;align-items:flex-end;gap:clamp(22px,4vw,46px);margin-top:52px;flex-wrap:wrap}
.asf-hero__stats .num{font-family:'Anton';font-size:clamp(36px,4vw,52px);color:#fff;line-height:1}
.asf-hero__stats .num.y{color:var(--yellow)}
.asf-hero__stats .lab{font-size:11px;letter-spacing:.1em;color:rgba(255,255,255,.7);margin-top:5px}
.asf-hero__stats .div{width:1px;height:44px;background:rgba(255,255,255,.25)}
.asf-hero__stats .big{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(26px,2.8vw,38px);color:#fff;line-height:1.1;white-space:nowrap}
.asf-scroll{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px}
.asf-scroll span.t{font-size:9px;letter-spacing:.3em;color:rgba(255,255,255,.55)}
.asf-scroll .bar{width:1px;height:34px;background:rgba(255,255,255,.25);position:relative;overflow:hidden}
.asf-scroll .bar i{position:absolute;top:0;left:0;width:1px;height:14px;background:var(--yellow);animation:asfScroll 1.8s infinite}
@keyframes asfScroll{0%{transform:translateY(0);opacity:0}40%{opacity:1}100%{transform:translateY(14px);opacity:0}}

/* ===================================================================
   PHILOSOPHY
=================================================================== */
.asf-philo .asf-ghost{right:-3%;top:8%;font-size:clamp(90px,16vw,230px);-webkit-text-stroke:1.5px rgba(13,20,48,.07)}
.asf-philo .lead{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(26px,4.4vw,58px);color:var(--navy);margin-top:28px;line-height:1.6;word-break:auto-phrase;line-break:strict}
.asf-philo .body{color:rgba(13,20,48,.6);font-size:clamp(14px,1.4vw,16px);margin-top:34px;line-height:2;max-width:680px}

/* ===================================================================
   DATA / numbers
=================================================================== */
.asf-data .asf-ghost{left:-2%;bottom:-6%;font-size:clamp(120px,22vw,320px);-webkit-text-stroke:1.5px rgba(255,255,255,.05)}
.asf-data__head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:56px}
.asf-data__head h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(30px,4.5vw,54px);color:#fff;margin-top:12px}
.asf-data__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:rgba(255,255,255,.12)}
.asf-data__cell{background:var(--navy);padding:32px 16px}
.asf-data__cell .num{font-family:'Anton';font-size:clamp(32px,3vw,48px);color:#fff;line-height:1}
.asf-data__cell .num.y{color:var(--yellow)}
.asf-data__cell .txt{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(22px,2.2vw,34px);color:var(--yellow);line-height:1.15;white-space:nowrap}
.asf-data__cell .txt .ant{font-family:'Anton',sans-serif;font-weight:400;letter-spacing:.01em}
.asf-data__cell .txt .u{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:.6em;margin-left:.05em}
.asf-data__cell .lab{color:rgba(255,255,255,.62);font-size:13px;margin-top:10px}
.asf-prov{color:var(--orange2)}

/* ===================================================================
   BUSINESS (service cards)
=================================================================== */
.asf-biz{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.asf-card{background:#fff;border:1px solid rgba(13,20,48,.1);border-radius:6px;overflow:hidden;display:block;box-shadow:0 10px 30px rgba(13,20,48,.05);transition:transform .45s cubic-bezier(.4,0,.1,1)}
.asf-card:hover{transform:translateY(-8px)}
.asf-thumb{overflow:hidden}
.asf-thumb .asf-th,.asf-thumb img,.asf-thumb .asf-ph{display:block;width:100%;height:180px;object-fit:cover;transition:transform .6s}
.asf-card:hover .asf-th,.asf-card:hover .asf-thumb img{transform:scale(1.06)}
.asf-card__body{padding:24px 22px 28px}
.asf-card__tag{display:flex;align-items:center;gap:10px}
.asf-card__tag .asf-en{font-size:12px;letter-spacing:.16em;color:var(--orange)}
.asf-card__title{font-family:'Zen Kaku Gothic New';font-size:20px;font-weight:900;color:var(--navy);margin-top:12px}
.asf-card__desc{color:rgba(13,20,48,.55);font-size:13px;line-height:1.8;margin-top:8px}

/* ===================================================================
   CLIENTS banner
=================================================================== */
.asf-clients{position:relative;overflow:hidden;padding:clamp(70px,9vw,110px) clamp(20px,5vw,80px);background:var(--navy);min-height:clamp(600px,76vh,820px);display:flex;align-items:flex-end}
.asf-clients__bg{position:absolute;inset:0;width:100%;height:100%}
.asf-clients__bg img,.asf-clients__bg .asf-ph{width:100%;height:100%;object-fit:cover;object-position:center 16%}
.asf-clients__veil{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(10,42,82,.12) 0%,rgba(10,42,82,.35) 42%,rgba(10,42,82,.82) 82%,rgba(10,42,82,.92) 100%)}
.asf-clients__inner{position:relative;z-index:2;max-width:1100px;margin:0 auto}
.asf-clients h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(30px,5vw,62px);color:#fff;margin-top:16px;line-height:1.3;word-break:auto-phrase}
.asf-clients .mark-navy{background:var(--yellow);color:var(--navy);padding:.02em .12em;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.asf-clients p{color:rgba(255,255,255,.82);font-size:clamp(14px,1.5vw,17px);margin-top:22px;line-height:1.9;max-width:600px}

/* ===================================================================
   MEDIA / 掲載実績
=================================================================== */
.asf-media__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(30px,5vw,64px);align-items:center}
.asf-media__thumb{max-width:380px}
.asf-media__thumb a{display:block;position:relative;border-radius:8px;overflow:hidden;box-shadow:0 22px 50px rgba(10,42,82,.18);transition:transform .4s}
.asf-media__thumb a:hover{transform:translateY(-6px)}
.asf-media__thumb img{width:100%;display:block}
.asf-media__pdf{position:absolute;top:14px;left:14px;background:var(--grad);color:#fff;font-family:'Anton';font-size:13px;letter-spacing:.12em;padding:5px 12px;border-radius:3px}
.asf-media__lead{color:rgba(13,20,48,.72);font-size:15px;line-height:1.95;margin-top:22px;max-width:560px}
.asf-media__lead strong{color:var(--navy);font-weight:700}
.asf-media__btns{display:flex;gap:14px;margin-top:30px;flex-wrap:wrap}
.asf-media__btns .asf-btn-white{border:1px solid rgba(10,42,82,.15)}
.asf-media__list{list-style:none;margin-top:24px;display:flex;flex-direction:column;gap:10px;max-width:600px}
.asf-media__list a{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid rgba(10,42,82,.1);border-radius:6px;padding:14px 18px;transition:transform .25s,box-shadow .25s}
.asf-media__list a:hover{transform:translateX(4px);box-shadow:0 10px 26px rgba(10,42,82,.1)}
.asf-media__list .m-site{font-family:'Zen Kaku Gothic New';font-weight:900;color:var(--navy);font-size:14px;white-space:nowrap}
.asf-media__list .m-ttl{font-size:13px;color:rgba(13,20,48,.62);line-height:1.5;flex:1}
.asf-media__list .m-go{font-family:'Anton';color:var(--orange);font-size:13px;white-space:nowrap}
@media(max-width:560px){.asf-media__list a{flex-wrap:wrap;gap:4px}.asf-media__list .m-ttl{flex-basis:100%;order:3}}
@media(max-width:800px){.asf-media__grid{grid-template-columns:1fr}.asf-media__thumb{max-width:300px;margin:0 auto}}

/* ===================================================================
   WHY
=================================================================== */
.asf-3{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.asf-why__num{font-family:'Anton';font-size:46px;color:rgba(13,20,48,.16)}
.asf-why__t{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:21px;color:var(--navy);margin-top:14px}
.asf-why__d{color:rgba(13,20,48,.55);font-size:14px;line-height:1.9;margin-top:12px}

/* ===================================================================
   MEMBERS
=================================================================== */
.asf-mem-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:46px}
.asf-mem-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.asf-mem{position:relative;border-radius:6px;overflow:hidden;display:block;min-height:380px;background:var(--navy)}
.asf-mem .img-wrap{position:absolute;inset:0;overflow:hidden}
.asf-mem .img-wrap img,.asf-mem .img-wrap .asf-ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}
.asf-mem:hover .img-wrap img{transform:scale(1.05)}
.asf-mem__veil{position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(13,20,48,0) 35%,rgba(13,20,48,.9) 100%)}
.asf-mem__body{position:absolute;left:0;bottom:0;padding:32px;z-index:2}
.asf-mem__q{font-family:'Zen Kaku Gothic New';font-weight:900;color:#fff;font-size:clamp(18px,2vw,24px);line-height:1.5}
.asf-mem__n{margin-top:16px;color:var(--yellow);font-weight:900;font-size:15px}
.asf-mem__r{color:rgba(255,255,255,.65);font-size:12px}

/* ===================================================================
   GALLERY
=================================================================== */
.asf-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.asf-gitem{position:relative;overflow:hidden;border-radius:6px;height:248px;background:#11305c}
.asf-gitem img,.asf-gitem .asf-ph{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.asf-gitem:hover img{transform:scale(1.06)}
@media(max-width:900px){.asf-gallery{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.asf-gallery{grid-template-columns:1fr;gap:10px}}

/* ===================================================================
   BLOG cards
=================================================================== */
.asf-blog3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.asf-bcard{display:block;background:#fff;border-radius:6px;overflow:hidden;border:1px solid rgba(13,20,48,.08);box-shadow:0 10px 30px rgba(13,20,48,.05);transition:transform .45s cubic-bezier(.4,0,.1,1)}
.asf-bcard:hover{transform:translateY(-8px)}
.asf-bcard .asf-thumb img,.asf-bcard .asf-thumb .asf-ph,.asf-bcard .asf-th{height:190px}
.asf-bcard__body{padding:22px}
.asf-bcard__meta{display:flex;gap:10px;align-items:center}
.asf-badge{font-size:10px;font-weight:900;padding:4px 10px;border-radius:2px}
.asf-badge--orange{background:var(--grad);color:#fff}
.asf-badge--navy{background:var(--navy);color:var(--yellow)}
.asf-date{color:rgba(13,20,48,.4);font-size:12px;font-family:'Anton'}
.asf-bcard__title{color:var(--navy);font-family:'Zen Kaku Gothic New';font-weight:700;font-size:16px;line-height:1.6;margin-top:12px}

/* ===================================================================
   下層ページ共通（page header + 本文）
=================================================================== */
.asf-pagehero{position:relative;background:var(--navy);color:#fff;padding:160px clamp(20px,5vw,80px) 80px;overflow:hidden}
.asf-pagehero .asf-ghost{right:-2%;bottom:-20%;font-size:clamp(90px,18vw,260px);-webkit-text-stroke:1.5px rgba(255,255,255,.06)}
.asf-pagehero__inner{position:relative;z-index:2;max-width:1280px;margin:0 auto}
.asf-pagehero h1{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(32px,5vw,64px);margin-top:14px}
.asf-pagehero .en{font-family:'Anton';letter-spacing:.28em;color:var(--orange2);font-size:13px}
.asf-breadcrumb{font-size:12px;color:rgba(13,20,48,.5);padding:18px clamp(20px,5vw,80px);max-width:1280px;margin:0 auto}
.asf-breadcrumb a{color:var(--orange)}
.asf-content{max-width:820px;margin:0 auto;padding:clamp(50px,8vw,90px) clamp(20px,5vw,40px);font-size:16px;line-height:2}
.asf-content h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(24px,3vw,34px);color:var(--navy);margin:48px 0 18px;padding-left:16px;border-left:5px solid var(--orange)}
.asf-content h3{font-family:'Zen Kaku Gothic New';font-weight:700;font-size:20px;color:var(--navy);margin:32px 0 12px}
.asf-content p{margin:0 0 18px;color:rgba(13,20,48,.8)}
.asf-content a{color:var(--orange);text-decoration:underline}
.asf-content img{border-radius:6px;margin:20px 0}
.asf-content ul,.asf-content ol{margin:0 0 18px 1.4em}
.asf-content li{margin-bottom:8px}

/* 会社概要テーブル */
.asf-table{width:100%;border-collapse:collapse;margin:10px 0 30px;background:#fff;border-radius:6px;overflow:hidden;box-shadow:0 10px 30px rgba(13,20,48,.05)}
.asf-table th,.asf-table td{text-align:left;padding:18px 22px;border-bottom:1px solid rgba(13,20,48,.08);font-size:15px;vertical-align:top}
.asf-table th{width:34%;background:var(--navy);color:#fff;font-family:'Zen Kaku Gothic New';font-weight:700}
.asf-table tr:last-child th,.asf-table tr:last-child td{border-bottom:0}

/* ===================================================================
   ブログ一覧 / 記事
=================================================================== */
.asf-archive{max-width:1200px;margin:0 auto;padding:clamp(50px,8vw,90px) clamp(20px,5vw,40px)}
.asf-single{max-width:820px;margin:0 auto;padding:clamp(40px,6vw,70px) clamp(20px,5vw,40px)}
.asf-single__meta{display:flex;gap:12px;align-items:center;margin-bottom:18px;flex-wrap:wrap}
.asf-single h1{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(24px,3.4vw,40px);color:var(--navy);line-height:1.45;margin-bottom:24px}
.asf-single__thumb img{width:100%;border-radius:8px;margin-bottom:30px}
.asf-single__body{font-size:16px;line-height:2;color:rgba(13,20,48,.85)}
.asf-single__body h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:26px;color:var(--navy);margin:40px 0 16px;padding-left:14px;border-left:5px solid var(--orange)}
.asf-single__body h3{font-weight:700;font-size:20px;margin:28px 0 12px;color:var(--navy)}
.asf-single__body p{margin:0 0 18px}
.asf-single__body img{border-radius:6px;margin:20px 0}
.asf-single__body a{color:var(--orange);text-decoration:underline}
.asf-pager{display:flex;justify-content:center;gap:8px;margin-top:50px;flex-wrap:wrap}
.asf-pager a,.asf-pager span{padding:10px 16px;border-radius:3px;font-family:'Anton';font-size:14px;background:#fff;border:1px solid rgba(13,20,48,.12);color:var(--navy)}
.asf-pager .current{background:var(--navy);color:#fff}
.asf-backlink{display:inline-flex;align-items:center;gap:8px;margin-top:40px;font-weight:900;color:var(--orange);font-family:'Zen Kaku Gothic New'}

/* ===================================================================
   下層ページ共通パーツ（サービス/車両/採用）
=================================================================== */
/* 導入リード */
.asf-intro{max-width:860px;margin:0 auto;text-align:center}
.asf-intro p{font-size:clamp(15px,1.7vw,18px);line-height:2.05;color:rgba(13,20,48,.72)}
.asf-intro .big{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(22px,3.4vw,40px);color:var(--navy);line-height:1.5;margin-bottom:22px;word-break:auto-phrase}
.asf-intro .big .asf-mark{padding:.04em .14em}

/* 交互メディア行（サービス詳細・車両） */
.asf-srow{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(30px,5vw,68px);align-items:center;margin-bottom:clamp(40px,6vw,72px)}
.asf-srow:last-child{margin-bottom:0}
.asf-srow--rev .asf-srow__media{order:2}
.asf-srow__media{position:relative;border-radius:8px;overflow:hidden;box-shadow:0 20px 50px rgba(10,42,82,.16);aspect-ratio:4/3}
.asf-srow__media img,.asf-srow__media .asf-ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s}
.asf-srow__media:hover img{transform:scale(1.05)}
.asf-srow__no{font-family:'Anton';font-size:clamp(40px,5vw,64px);color:rgba(31,134,207,.22);line-height:1}
.asf-srow__en{font-family:'Anton';letter-spacing:.22em;color:var(--orange);font-size:12px;margin-left:4px}
.asf-srow__t{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(24px,3vw,34px);color:var(--navy);margin:10px 0 16px}
.asf-srow__d{color:rgba(13,20,48,.66);font-size:15px;line-height:1.95}

/* 特徴リスト（チェック） */
.asf-feat{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:10px}
.asf-feat li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--navy);font-weight:700;font-family:'Zen Kaku Gothic New'}
.asf-feat li::before{content:"";flex:0 0 20px;height:20px;margin-top:1px;border-radius:50%;background:var(--grad);
  -webkit-mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/></svg>") center/13px no-repeat;
  mask:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'><path fill='white' d='M9 16.2l-3.5-3.5L4 14.2l5 5 11-11-1.5-1.5z'/></svg>") center/13px no-repeat}

/* 3カラム情報カード */
.asf-icards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.asf-icard{background:#fff;border:1px solid rgba(13,20,48,.09);border-radius:8px;padding:34px 28px;box-shadow:0 10px 30px rgba(13,20,48,.05);transition:transform .4s}
.asf-icard:hover{transform:translateY(-6px)}
.asf-icard__ic{width:54px;height:54px;border-radius:12px;background:linear-gradient(135deg,rgba(43,182,232,.16),rgba(31,127,209,.16));display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.asf-icard__t{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:19px;color:var(--navy)}
.asf-icard__d{color:rgba(13,20,48,.6);font-size:14px;line-height:1.9;margin-top:10px}

/* 数字ストリップ（車両） */
.asf-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.14);border-radius:8px;overflow:hidden}
.asf-strip__c{background:var(--navy);padding:34px 20px;text-align:center}
.asf-strip__n{font-family:'Anton';font-size:clamp(40px,5vw,64px);color:#fff;line-height:1}
.asf-strip__n.y{color:var(--yellow)}
.asf-strip__l{color:rgba(255,255,255,.66);font-size:13px;margin-top:8px}

/* タイムライン（採用 1日の流れ） */
.asf-timeline{max-width:760px;margin:0 auto;position:relative;padding-left:10px}
.asf-timeline::before{content:"";position:absolute;left:64px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--aqua,#38bdf0),rgba(31,127,209,.2))}
.asf-tl{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:14px 0;position:relative}
.asf-tl__time{font-family:'Anton';font-size:18px;color:var(--orange);text-align:right;padding-top:2px}
.asf-tl__dot{position:absolute;left:58px;top:18px;width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:0 0 0 4px rgba(43,182,232,.18);z-index:2}
.asf-tl__body{padding-left:22px}
.asf-tl__t{font-family:'Zen Kaku Gothic New';font-weight:900;color:var(--navy);font-size:17px}
.asf-tl__d{color:rgba(13,20,48,.6);font-size:14px;line-height:1.85;margin-top:4px}

/* CTAバンド */
.asf-cta{background:linear-gradient(120deg,#0a2a52,#123a6b);text-align:center;border-radius:0}
.asf-cta__in{max-width:760px;margin:0 auto}
.asf-cta h2{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(26px,4vw,46px);color:#fff;line-height:1.4;word-break:auto-phrase}
.asf-cta p{color:rgba(255,255,255,.8);font-size:15px;line-height:1.9;margin-top:18px}
.asf-cta__btns{display:flex;gap:14px;justify-content:center;margin-top:34px;flex-wrap:wrap}
.asf-cta .asf-tel{font-family:'Anton';font-size:clamp(26px,3vw,38px);color:var(--yellow);margin-top:24px;letter-spacing:.02em}

@media(max-width:840px){
  .asf-srow{grid-template-columns:1fr;gap:24px}
  .asf-srow--rev .asf-srow__media{order:0}
  .asf-icards{grid-template-columns:1fr}
  .asf-strip{grid-template-columns:1fr}
}

/* ===================================================================
   会社概要 / お問い合わせ
=================================================================== */
/* 会社概要：表＋地図の2カラム */
.asf-company{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,4vw,52px);align-items:start}
.asf-company .asf-table{margin:0}
.asf-map{position:relative;width:100%;border-radius:8px;overflow:hidden;box-shadow:0 16px 40px rgba(10,42,82,.14);aspect-ratio:4/3;background:#dfe7f1}
.asf-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.1)}
.asf-company__msg{max-width:900px;margin:0 auto clamp(40px,6vw,64px)}
.asf-company__msg .lead{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(20px,2.8vw,30px);color:var(--navy);line-height:1.6;margin-bottom:18px;word-break:auto-phrase}
.asf-company__msg p{color:rgba(13,20,48,.7);font-size:15px;line-height:2}

/* 連絡先メソッド */
.asf-method{background:#fff;border:1px solid rgba(13,20,48,.09);border-radius:8px;padding:30px 26px;text-align:center;box-shadow:0 10px 30px rgba(13,20,48,.05)}
.asf-method__l{font-family:'Anton';letter-spacing:.16em;color:var(--orange);font-size:12px}
.asf-method__v{font-family:'Anton';font-size:clamp(22px,2.4vw,30px);color:var(--navy);margin-top:8px;word-break:break-all}
.asf-method__s{font-size:12px;color:rgba(13,20,48,.5);margin-top:6px}

/* お問い合わせフォーム */
.asf-form{max-width:680px;margin:0 auto;background:#fff;border-radius:10px;padding:clamp(26px,4vw,44px);box-shadow:0 18px 44px rgba(10,42,82,.1);border:1px solid rgba(13,20,48,.07)}
.asf-form .row{margin-bottom:20px}
.asf-form label{display:block;font-family:'Zen Kaku Gothic New';font-weight:700;color:var(--navy);font-size:14px;margin-bottom:8px}
.asf-form label .req{color:#e0483a;font-size:12px;margin-left:6px}
.asf-form input,.asf-form textarea{width:100%;border:1px solid rgba(13,20,48,.18);border-radius:6px;padding:13px 15px;font-size:15px;font-family:inherit;background:#fbfcfe;transition:border-color .2s,box-shadow .2s}
.asf-form input:focus,.asf-form textarea:focus{outline:none;border-color:var(--aqua,#38bdf0);box-shadow:0 0 0 3px rgba(43,182,232,.16)}
.asf-form textarea{min-height:140px;resize:vertical}
.asf-form .submit{text-align:center;margin-top:10px}
.asf-form button{border:0;cursor:pointer;background:var(--grad);color:#fff;font-family:'Zen Kaku Gothic New';font-weight:900;font-size:16px;padding:16px 46px;border-radius:4px;box-shadow:0 12px 30px rgba(43,182,232,.32);transition:transform .2s}
.asf-form button:hover{transform:translateY(-2px)}
.asf-form .note{font-size:12px;color:rgba(13,20,48,.5);text-align:center;margin-top:16px;line-height:1.8}
.asf-form__done{background:#eaf7ef;border:1px solid #b7e2c6;color:#1f7a44;border-radius:8px;padding:18px 22px;text-align:center;font-weight:700;margin-bottom:24px}
.asf-form__err{background:#fdeceb;border:1px solid #f3bdb8;color:#c0392b;border-radius:8px;padding:14px 18px;text-align:center;font-weight:700;margin-bottom:20px}

@media(max-width:840px){
  .asf-company{grid-template-columns:1fr}
}

/* ===================================================================
   荷主向け：ご利用の流れ
=================================================================== */
.asf-flow{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.asf-flow__item{position:relative;background:#fff;border:1px solid rgba(13,20,48,.09);border-radius:8px;padding:30px 22px 26px;box-shadow:0 10px 30px rgba(13,20,48,.05)}
.asf-flow__item::after{content:"→";position:absolute;right:-16px;top:50%;transform:translateY(-50%);font-family:'Anton';color:rgba(31,134,207,.4);font-size:22px;z-index:2}
.asf-flow__item:last-child::after{display:none}
.asf-flow__no{font-family:'Anton';font-size:40px;color:var(--aqua,#38bdf0);line-height:1}
.asf-flow__no small{font-size:11px;letter-spacing:.18em;color:rgba(13,20,48,.4);display:block;font-family:'Anton';margin-bottom:2px}
.asf-flow__t{font-family:'Zen Kaku Gothic New';font-weight:900;color:var(--navy);font-size:18px;margin:12px 0 8px}
.asf-flow__d{color:rgba(13,20,48,.6);font-size:13px;line-height:1.85}
@media(max-width:840px){.asf-flow{grid-template-columns:1fr 1fr}.asf-flow__item::after{display:none}}
@media(max-width:520px){.asf-flow{grid-template-columns:1fr}}

/* ===================================================================
   代表メッセージ
=================================================================== */
.asf-ceo{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(30px,5vw,60px);align-items:center}
.asf-ceo__photo{position:relative;border-radius:10px;overflow:hidden;box-shadow:0 24px 56px rgba(10,42,82,.2);aspect-ratio:4/5}
.asf-ceo__photo img{width:100%;height:100%;object-fit:cover;display:block}
.asf-ceo__role{font-family:'Anton';letter-spacing:.2em;color:var(--orange);font-size:13px}
.asf-ceo__name{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:clamp(30px,4.4vw,52px);color:var(--navy);margin:8px 0 4px;line-height:1.2}
.asf-ceo__name span{font-size:.42em;color:rgba(13,20,48,.45);margin-left:12px;letter-spacing:.08em}
.asf-ceo__sum{color:rgba(13,20,48,.66);font-size:15px;line-height:1.95;margin-top:18px}

.asf-story{max-width:760px;margin:0 auto}
.asf-story p{font-size:clamp(15px,1.7vw,17px);line-height:2.15;color:rgba(13,20,48,.82);margin-bottom:26px}
.asf-story p.strong{font-family:'Zen Kaku Gothic New';font-weight:900;color:var(--navy)}
.asf-quote{margin:clamp(36px,5vw,56px) 0;padding:clamp(24px,4vw,40px) clamp(24px,5vw,48px);background:linear-gradient(120deg,#0a2a52,#123a6b);border-radius:10px;position:relative}
.asf-quote p{font-family:'Zen Kaku Gothic New';font-weight:900;color:#fff;font-size:clamp(20px,2.8vw,30px);line-height:1.6;margin:0;word-break:auto-phrase}
.asf-quote .mk{background:var(--yellow);color:var(--navy);padding:.02em .14em;-webkit-box-decoration-break:clone;box-decoration-break:clone}
.asf-aspire{display:flex;flex-direction:column;gap:10px;margin:28px 0}
.asf-aspire li{list-style:none;display:flex;align-items:center;gap:12px;font-family:'Zen Kaku Gothic New';font-weight:900;color:var(--navy);font-size:clamp(16px,2vw,20px)}
.asf-aspire li::before{content:"";width:10px;height:10px;border-radius:50%;background:var(--grad);flex:0 0 auto}
.asf-sign{text-align:right;margin-top:30px;color:var(--navy)}
.asf-sign .t{font-size:13px;color:rgba(13,20,48,.55)}
.asf-sign .n{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:24px;margin-top:4px}

@media(max-width:840px){
  .asf-ceo{grid-template-columns:1fr;gap:24px}
  .asf-ceo__photo{max-width:340px;margin:0 auto}
}

/* ===================================================================
   FOOTER
=================================================================== */
.asf-footer{background:var(--navy);color:#fff;padding:clamp(60px,8vw,90px) clamp(20px,5vw,80px) 40px}
.asf-footer__top{max-width:1280px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:40px}
.asf-footer__brand{max-width:360px}
.asf-footer__brand .lg{display:flex;align-items:center;gap:12px}
.asf-footer__brand img{height:30px}
.asf-footer__brand .nm{font-family:'Zen Kaku Gothic New';font-weight:900;font-size:20px}
.asf-footer__brand p{color:rgba(255,255,255,.6);font-size:13px;line-height:1.9;margin-top:18px}
.asf-footer__col h4{font-family:'Anton';letter-spacing:.2em;font-size:12px;color:var(--orange2);margin-bottom:16px}
.asf-footer__col ul{list-style:none}
.asf-footer__col li{margin-bottom:10px}
.asf-footer__col a{color:rgba(255,255,255,.78);font-size:14px}
.asf-footer__col a:hover{color:var(--yellow)}
.asf-footer__contact .tel{font-family:'Anton';font-size:28px;color:#fff;margin-top:4px}
.asf-footer__contact .small{font-size:12px;color:rgba(255,255,255,.55)}
.asf-footer__mail{display:inline-block;margin-top:12px;color:rgba(255,255,255,.82);font-size:14px;border-bottom:1px solid rgba(255,255,255,.3);padding-bottom:2px;word-break:break-all}
.asf-footer__mail:hover{color:var(--yellow);border-color:var(--yellow)}
.asf-footer__cta{display:inline-flex;margin-top:16px;background:var(--grad);color:#fff;font-weight:900;padding:14px 28px;border-radius:3px;box-shadow:0 12px 30px rgba(255,90,31,.3)}
.asf-footer__bottom{max-width:1280px;margin:50px auto 0;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:12px;color:rgba(255,255,255,.5)}

/* ===================================================================
   REVEAL アニメ
=================================================================== */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1)}
[data-reveal].is-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){[data-reveal]{opacity:1;transform:none;transition:none}.asf-scroll .bar i{animation:none}}

/* ===================================================================
   レスポンシブ
=================================================================== */
@media(max-width:1000px){
  .asf-data__grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:900px){
  .asf-biz{grid-template-columns:1fr 1fr}
  .asf-3{grid-template-columns:1fr}
  .asf-mem-grid{grid-template-columns:1fr}
  .asf-blog3{grid-template-columns:1fr}
  .asf-burger{display:flex}
  .asf-nav-wrap{
    position:fixed;inset:0;background:rgba(13,20,48,.985);
    flex-direction:column;justify-content:center;gap:8px;
    transform:translateX(100%);transition:transform .4s cubic-bezier(.4,0,.1,1);
  }
  .asf-nav-wrap.is-open{transform:none}
  .asf-nav-list{flex-direction:column;gap:4px}
  .asf-nav-list a{font-size:22px;padding:14px}
  .asf-nav-cta{margin-top:14px;font-size:18px;padding:14px 30px}
  .asf-header{background:rgba(13,20,48,.96)}
  .asf-footer__top{flex-direction:column}
}
@media(max-width:560px){
  .asf-biz{grid-template-columns:1fr}
  .asf-data__grid{grid-template-columns:1fr 1fr}
  .asf-hero{padding-top:120px}
}
