
:root{ --blue:#007BCE; --bg:#ffffff; --text:#111; --muted:#f7f7f7; }
html{scroll-behavior:smooth}
body{font-family:"Noto Sans JP", system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial; margin:0; color:var(--text); background:var(--bg); line-height:1.7}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none}
.container{width:min(1140px,92vw);margin:0 auto}

/* Header */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid #eee}
.header .inner{display:flex;align-items:center;justify-content:space-between;gap:18px;height:68px}
.brand{font-weight:800;letter-spacing:.2px}
.nav{margin-left:auto;position:relative}
.nav ul{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  list-style:none;
  margin:0;
  padding:0;
}
.nav a{padding:10px 12px;border-radius:0;color:#111;font-weight:600;border-bottom:2px solid transparent;transition:all .2s}
.nav a:hover{background:#f5f9ff;border-bottom-color:var(--blue)}
.header-cta .btn-primary{background:var(--blue);color:#fff;padding:10px 14px;border-radius:0;font-weight:800;border:2px solid var(--blue)}
.header-cta .btn-primary:hover{filter:brightness(1.05)}
.hamburger{display:none;appearance:none;background:#fff;border:1px solid #e5e7eb;border-radius:0;padding:8px 10px;font-size:18px;line-height:1}
/* ロゴサイズ調整 */
.brand .custom-logo {
  max-height: 48px;   /* ヘッダーの高さ68pxに収まるように */
  width: auto;
  height: auto;
}

/* Hero */
.hero{position:relative;min-height:100vh;color:#fff}
.hero .stage{position:absolute;inset:0;overflow:hidden}
.hero .slide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;
  /* 可変：デフォルト12s、front-pageで --hero-duration を上書き */
  animation:fade var(--hero-duration, 12s) infinite;
}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(0,123,206,.45), rgba(0,0,0,.35));pointer-events:none}
.hero .content{position:relative;z-index:1;min-height:100vh;display:grid;place-items:center;text-align:center;padding:24px}
.hero h1{font-size:clamp(28px,5vw,56px);margin:0 0 10px;font-weight:900;letter-spacing:.02em}
.hero p.sub{font-size:clamp(15px,2.2vw,20px);opacity:.95;margin:0 0 16px}
.cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:0;font-weight:700;border:2px solid #fff;color:#fff}
.btn.fill{background:#fff;color:var(--blue);border-color:#fff}
.scroll-down{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);font-size:14px;opacity:.9;z-index:2}
@keyframes fade{0%,45%{opacity:1} 50%,95%{opacity:0} 100%{opacity:1}}

/* Headline per-char animation */
.headline .char{display:inline-block;opacity:0;transform:translateY(12px);animation:charIn .8s cubic-bezier(.2,.6,.2,1) forwards}
@keyframes charIn{to{opacity:1;transform:none}}
@media (prefers-reduced-motion: reduce){ .headline .char{animation:none;opacity:1;transform:none} }

/* Sections */
.section{padding:72px 0}
.muted{background:var(--muted)}
h2.section-title{font-size:clamp(22px,3.5vw,34px);text-align:center;margin:0 0 28px}
.lead{text-align:center;max-width:820px;margin:0 auto 22px}

/* Services */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.card{background:#fff;border:1px solid #eee;border-radius:0;padding:20px;box-shadow:none}
.card h3{margin:6px 0 8px;font-size:20px}
.card p{margin:0}
.card img{width:100%;height:180px;object-fit:cover;border-radius:0;margin:0 0 10px}

/* Flow */
.flow{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.step{background:#fff;border:1px solid #eee;border-radius:0;padding:18px;text-align:left;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;min-height:160px}
.step .title{font-size:20px;font-weight:800;margin:4px 0 6px}
.step .desc{font-size:14.5px;max-width:40ch;line-height:1.8;opacity:.95}
.no{display:inline-block;background:var(--blue);color:#fff;border-radius:0;padding:6px 12px;font-size:12px;margin-bottom:16px}

/* Company */
.company{display:grid;grid-template-columns:1fr;gap:24px}
.table{width:100%;border-collapse:separate;border-spacing:0 8px}
.table td{background:#fff;border:1px solid #eee;padding:10px 12px;border-radius:0}
.table td:first-child{font-weight:700;width:26%}

/* Recruit button */
#recruit .btn-primary{
  background:var(--blue);
  color:#fff;
  border-color:var(--blue);
}
#recruit .btn-primary:hover{
  filter:brightness(1.05);
}

/* Footer */
 .footer{background:#222;color:#ddd;padding:34px 0;margin-top:48px}
 .footer a{color:#fff}

/* Footer menu */
.footer-links .menu{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.footer-links .menu li{
  display:inline-flex;
  align-items:center;
}
/* スラッシュ区切りが必要なら以下をON */
.footer-links .menu li + li::before{
  content:"／";
  opacity:.8;
  margin:0 4px 0 0;
}

/* Eyebrow under */
.section-head{position:relative;text-align:center;margin-bottom:22px}
.section-head .section-title{position:relative;z-index:2;margin:0}
.eyebrow-under{margin-top:-36px;font-size:clamp(28px,8.5vw,88px);line-height:1;opacity:.07;font-family:"Yu Mincho","Hiragino Mincho ProN","Noto Serif JP",serif}
@media (max-width:580px){ .eyebrow-under{font-size:clamp(24px,12vw,64px);margin-top:-22px} }

/* News list */
#news .news-list{list-style:none;padding:0;margin:0;display:grid;gap:12px}
#news .news-list li{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;border-bottom:1px solid #eee;padding:10px 0}
#news .news-list time{font-feature-settings:"pnum" 1,"lnum" 1;font-size:12px;opacity:.65}
#news .news-list a{display:inline-block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:inherit}
#news .news-list a:hover{text-decoration:underline}

/* Full-bleed visual bands */
.visual-band{min-height:32vh;background-position:center;background-size:cover}
@media (min-width:1024px){ .visual-band{min-height:40vh;background-attachment:fixed} }

/* Responsive */
@media (max-width:980px){
 .grid-3{grid-template-columns:1fr}
 .company{grid-template-columns:1fr}
 .flow{grid-template-columns:1fr 1fr}
 .hamburger{display:inline-flex}
 .nav{
   display:none;
   position:absolute;
   top:68px;left:0;right:0;
   background:#fff;
   padding:12px 16px;
   border-bottom:1px solid #eee;
 }
 .nav.open{display:block;}
 .nav.open ul{
    display:flex;
   flex-direction:column;
   gap:16px;
   align-items:flex-start;
 }
}
@media (max-width:580px){ .flow{grid-template-columns:1fr} }

/* Philosophy typography */
.ph-vision{font-family:"Yu Mincho","Hiragino Mincho ProN","Noto Serif JP",serif;font-size:clamp(22px,4.8vw,40px);color:#444;margin:6px 0 10px}

/* Contact full-bleed styles */
.contact-band{background:var(--blue);color:#fff;padding:34px 0;margin:0}
.footer{margin-top:0}

/* Full width template helpers */
.page-template-template-fullwidth #primary { width: 100%; max-width: none; }

/* ワイド幅は中央に最大幅で */
.page-template-template-fullwidth .entry-content > .alignwide {
  max-width: min(1140px, 92vw);
  margin-left: auto;
  margin-right: auto;
}

/* フル幅ブロックは画面端まで */
.page-template-template-fullwidth .entry-content > .alignfull {
  width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
}

/* カバー等の背景画像もはみ出しなく */
.page-template-template-fullwidth .wp-block-cover.alignfull,
.page-template-template-fullwidth .wp-block-group.alignfull,
.page-template-template-fullwidth .wp-block-image.alignfull {
  width: 100vw;
  margin-left: 50%;
  transform: translateX(-50%);
}