/*
 * style.css — 株式会社イースタイル（e-style.asia）
 * デザイン：ネイビー×レッドのB2B IT企業コーポレート。ロゴの配色（紺＋赤ドット）を基調にする。
 */
:root{
  --navy-900:#141c4d; --navy-800:#1f2d74; --navy-700:#2b3d94; --navy-050:#eef0fa;
  --red:#d01f36; --red-dark:#a5182a;
  --ink-900:#1a1c22; --ink-700:#3a3d47; --ink-600:#5c606c; --ink-400:#8b8f9c;
  --line:#e5e7ee; --paper:#f8f9fc; --paper-2:#eef0f7; --white:#fff;
  --serif:"Noto Serif JP","Yu Mincho",serif;
  --sans:"Noto Sans JP","Hiragino Kaku Gothic ProN","Meiryo",sans-serif;
  --wrap:1160px; --header-h:74px; --radius:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--ink-900);background:var(--paper);line-height:1.85;letter-spacing:.02em;font-size:16px;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:.2s}
ul{list-style:none}
.wrap{width:min(var(--wrap),92%);margin-inline:auto}

.section{padding:clamp(3.25rem,7vw,5.75rem) 0}
.section--tint{background:var(--paper-2)}
.section--ink{background:var(--navy-900);color:#eceef2}
.section-head{margin-bottom:clamp(1.75rem,4vw,3rem);text-align:center}
.section-head .en{display:block;font-size:.72rem;letter-spacing:.3em;color:var(--red);font-weight:700;margin-bottom:.5rem}
.section-head .ja{font-family:var(--serif);font-size:clamp(1.5rem,3.4vw,2.15rem);font-weight:600;color:var(--ink-900);line-height:1.5}
.section-head .lead{margin:1rem auto 0;color:var(--ink-600);max-width:680px}
.section--ink .section-head .ja{color:#fff}

.btn{display:inline-flex;align-items:center;gap:.6rem;font-weight:700;font-size:.94rem;padding:.95rem 2.1rem;border-radius:6px;border:2px solid var(--navy-800);color:var(--navy-800);background:transparent;cursor:pointer;transition:.25s;line-height:1.4}
.btn:hover{background:var(--navy-800);color:#fff}
.btn--fill{background:var(--navy-800);color:#fff;border-color:var(--navy-800)}
.btn--fill:hover{background:var(--navy-900);border-color:var(--navy-900)}
.btn--ghost{border-color:rgba(255,255,255,.7);color:#fff}
.btn--ghost:hover{background:#fff;color:var(--navy-900);border-color:#fff}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(4px)}

/* ヘッダー */
.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);display:flex;align-items:center;background:rgba(255,255,255,.96);box-shadow:0 1px 0 var(--line);backdrop-filter:saturate(1.2) blur(4px)}
.header.solid{position:relative;background:#fff}
.header .wrap{display:flex;align-items:center;justify-content:space-between;width:min(var(--wrap),95%)}
.brand{display:flex;align-items:center}
.brand img{height:30px;width:auto}
.nav{display:flex;align-items:center;gap:1.6rem}
.nav a{color:var(--ink-700);font-size:.9rem;font-weight:500;position:relative;padding:.3rem 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--red);transition:width .25s}
.nav a:hover{color:var(--navy-800)}
.nav a:hover::after{width:100%}
.nav a.active{color:var(--navy-800)}
.nav a.active::after{width:100%}
.nav__cta{background:var(--red);color:#fff!important;padding:.55rem 1.2rem!important;border-radius:6px}
.nav__cta::after{display:none}
.nav__cta:hover{background:var(--red-dark)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;width:32px;height:24px;position:relative}
.nav-toggle span{position:absolute;left:0;width:100%;height:2px;background:var(--ink-900);transition:.3s}
.nav-toggle span:nth-child(1){top:1px}.nav-toggle span:nth-child(2){top:11px}.nav-toggle span:nth-child(3){top:21px}
.nav-toggle.open span:nth-child(1){top:11px;transform:rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){top:11px;transform:rotate(-45deg)}

/* ヒーロー */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:linear-gradient(150deg,#0f1638 0%,var(--navy-800) 55%,var(--navy-700) 120%)}
.hero::before{content:"";position:absolute;inset:0;background:radial-gradient(900px 520px at 84% 10%,rgba(208,31,54,.35),transparent 62%)}
.hero::after{content:"";position:absolute;right:8%;top:24%;width:210px;height:210px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.10),rgba(208,31,54,.32) 60%,transparent 72%)}
.hero__inner{position:relative;z-index:2;padding-top:var(--header-h)}
.hero__eyebrow{font-size:.82rem;letter-spacing:.22em;color:#f3b9c1;margin-bottom:1.3rem;font-weight:700}
.hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(1.9rem,4.8vw,3.3rem);line-height:1.5;margin-bottom:1.5rem;white-space:pre-line}
.hero__lead{max-width:640px;color:#dfe2ee;font-size:clamp(.98rem,1.6vw,1.08rem);margin-bottom:2.4rem}
.hero__actions{display:flex;gap:1rem;flex-wrap:wrap}

/* サービスカード */
.cards{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:2rem 1.7rem;transition:.25s;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .3s}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(20,28,77,.12)}
.card:hover::before{transform:scaleX(1)}
.card__ic{font-size:2rem;margin-bottom:.9rem;line-height:1}
.card h3{font-family:var(--serif);font-size:1.12rem;color:var(--ink-900);margin-bottom:.7rem}
.card p{font-size:.9rem;color:var(--ink-600)}
.card__link{display:inline-flex;align-items:center;gap:.4rem;margin-top:1rem;font-size:.84rem;font-weight:700;color:var(--navy-800)}
.card__link:hover{color:var(--red)}

/* 強み・数値 */
.stbar{display:grid;grid-template-columns:repeat(3,1fr)}
.st{padding:2.4rem 1.3rem;text-align:center;border-left:1px solid rgba(255,255,255,.1)}
.st:first-child{border-left:0}
.st__n{font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,1.9rem);color:#f3b9c1;line-height:1.2;font-weight:600}
.st__l{margin-top:.7rem;font-size:.82rem;color:#c7cad3}

/* CTA帯 */
.cta{background:linear-gradient(120deg,var(--navy-900),var(--red-dark));color:#fff;text-align:center}
.cta h2{font-family:var(--serif);font-size:clamp(1.5rem,3.4vw,2.3rem);margin-bottom:1rem}
.cta p{color:#dfe2ee;margin-bottom:1.5rem;max-width:600px;margin-inline:auto}
.cta__info{display:flex;gap:2rem;justify-content:center;flex-wrap:wrap;margin-bottom:2rem;font-size:.94rem}
.cta__info b{color:#f3b9c1;font-family:var(--serif);margin-right:.5rem}

/* 下層ページヘッダー */
.page-hero{padding:calc(var(--header-h) + 3.5rem) 0 3rem;background:linear-gradient(150deg,#0f1638,var(--navy-700));color:#fff;text-align:center}
.page-hero .en{font-size:.74rem;letter-spacing:.3em;color:#f3b9c1;font-weight:700}
.page-hero h1{font-family:var(--serif);font-size:clamp(1.8rem,4.4vw,2.9rem);font-weight:600;margin-top:.6rem}
.breadcrumb{margin-top:1rem;font-size:.76rem;color:#c9cdE0}
.breadcrumb a:hover{color:#fff}.breadcrumb span{margin:0 .5rem;opacity:.6}

/* 会社概要テーブル */
.tbl{width:100%;border-collapse:collapse;max-width:760px;margin-inline:auto;background:#fff;border:1px solid var(--line)}
.tbl th,.tbl td{text-align:left;padding:1.1rem 1.5rem;border-bottom:1px solid var(--line);font-size:.92rem;vertical-align:top}
.tbl tr:last-child th,.tbl tr:last-child td{border-bottom:0}
.tbl th{width:30%;font-family:var(--serif);color:var(--navy-800);font-weight:600;background:var(--navy-050)}

/* サービス詳細行 */
.feat-rows{display:flex;flex-direction:column;gap:clamp(2rem,5vw,3rem)}
.feat-row{display:grid;grid-template-columns:88px 1fr;gap:clamp(1.2rem,3vw,2rem);align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.5rem,3vw,2.2rem)}
.feat-row__ic{width:64px;height:64px;border-radius:50%;background:var(--navy-050);display:grid;place-items:center;font-size:1.8rem}
.feat-row__body h3{font-family:var(--serif);font-size:clamp(1.15rem,2.4vw,1.4rem);color:var(--ink-900);margin-bottom:.7rem}
.feat-row__body p{color:var(--ink-600)}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s,transform .7s}
.reveal.in{opacity:1;transform:none}

/* フッター */
.footer{background:var(--navy-900);color:#a7abb6;padding:clamp(2.5rem,5vw,3.5rem) 0 2rem;font-size:.88rem}
.footer__top{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding-bottom:2rem;border-bottom:1px solid rgba(255,255,255,.1)}
.footer__brand img{height:26px;filter:brightness(0) invert(1);margin-bottom:.7rem}
.footer__brand p{max-width:320px;color:#8d92a3}
.footer__nav{display:flex;gap:1.6rem;flex-wrap:wrap}
.footer__nav a:hover{color:#fff}
.footer__bottom{padding-top:1.6rem;text-align:center;color:#6f7480;font-size:.8rem}

@media(max-width:900px){
  .stbar{grid-template-columns:1fr 1fr}.st:nth-child(3){border-left:0}
  .feat-row{grid-template-columns:1fr}
}
@media(max-width:760px){
  .nav{position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:#fff;padding:.5rem 6%;transform:translateY(-140%);transition:transform .35s;box-shadow:0 20px 40px rgba(0,0,0,.12)}
  .nav.open{transform:translateY(0)}
  .nav a{width:100%;padding:1rem 0;border-bottom:1px solid var(--line)}
  .nav-toggle{display:block}
  .stbar{grid-template-columns:1fr}.st{border-left:0}
}
