@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Oswald:wght@400;600;700&display=swap');

:root {
  --navy: #1a2744; --navy-light: #243059; --gold: #E8960A; --gold-light: #F5A623;
  --white: #ffffff; --off-white: #F8F8F6; --gray-light: #f4f4f2; --gray: #888888;
  --text-dark: #222222; --text-body: #444444; --border: #e0e0de;
  --shadow: 0 4px 24px rgba(26,39,68,0.10); --shadow-lg: 0 8px 40px rgba(26,39,68,0.16);
}
* { box-sizing: border-box; }
body { font-family: 'Noto Sans JP', sans-serif !important; color: var(--text-body) !important; background: var(--white) !important; overflow-x: hidden; }

/* ヘッダー */
#pattern2, header { background: var(--navy) !important; box-shadow: 0 2px 16px rgba(26,39,68,0.18) !important; }
#pattern2 * { color: var(--white) !important; }
#pattern2 img { filter: brightness(0) invert(1) !important; }
#pattern2 nav a, #pattern2 .nav a, #pattern2 ul.menu a { color: rgba(255,255,255,0.85) !important; font-size:14px !important; font-weight:500 !important; letter-spacing:0.05em !important; }

/* ヒーロー */
#mv_outer { position: relative !important; }

/* STATSバー */
#uk-stats { background: var(--navy) !important; padding: 0 !important; margin: 0 !important; }
.uk-stats-grid { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 0 !important; }
.uk-stat-item { padding: 40px 20px !important; text-align: center !important; border-right: 1px solid rgba(255,255,255,0.12) !important; transition: background 0.2s !important; }
.uk-stat-item:last-child { border-right: none !important; }
.uk-stat-number { font-family: 'Oswald', sans-serif !important; font-size: 52px !important; font-weight: 700 !important; color: var(--gold) !important; line-height: 1 !important; display: block !important; }
.uk-stat-unit { font-size: 18px !important; color: rgba(255,255,255,0.6) !important; font-weight: 400 !important; }
.uk-stat-label { display: block !important; color: rgba(255,255,255,0.7) !important; font-size: 12px !important; margin-top: 8px !important; letter-spacing: 0.06em !important; font-weight: 500 !important; }

/* REPRESENTATIVE MESSAGE */
#uk-president { background: var(--off-white) !important; padding: 80px 40px !important; }
.uk-pres-grid { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 60px !important; max-width: 1100px !important; margin: 0 auto !important; align-items: start !important; }
.uk-pres-label { display: inline-block !important; background: var(--navy) !important; color: var(--gold) !important; font-family:'Oswald',sans-serif !important; font-size:11px !important; letter-spacing:0.15em !important; padding: 6px 16px !important; margin-bottom: 24px !important; }
.uk-pres-title { font-size: 28px !important; font-weight: 700 !important; color: var(--navy) !important; line-height: 1.5 !important; margin: 0 0 24px !important; }
.uk-pres-body { font-size: 14px !important; line-height: 1.9 !important; color: var(--text-body) !important; margin: 0 0 20px !important; }
.uk-pres-name { font-size: 13px !important; color: var(--gray) !important; margin: 0 !important; }
.uk-pres-panel { background: var(--navy) !important; padding: 36px !important; border-radius: 4px !important; }
.uk-pres-panel-title { color: var(--gold) !important; font-size: 12px !important; font-family:'Oswald',sans-serif !important; letter-spacing:0.1em !important; margin: 0 0 20px !important; }
.uk-pres-list { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.uk-pres-list li { color: rgba(255,255,255,0.9) !important; font-size: 14px !important; padding: 10px 0 !important; border-bottom: 1px solid rgba(255,255,255,0.1) !important; display: flex !important; align-items: center !important; gap: 10px !important; }
.uk-pres-list li::before { content: '▶' !important; color: var(--gold) !important; font-size: 10px !important; flex-shrink: 0 !important; }
.uk-pres-list li:last-child { border-bottom: none !important; }

/* ABOUT US (法人4つの理由) */
[id^="nbp10613754"] { background: var(--white) !important; }

/* WHAT WE DO (SERVICE AREA) */
[id^="nbp6307596"] { background: var(--off-white) !important; }

/* CONSTRUCTION RECORD */
[id^="nbp10620062"] { background: var(--white) !important; }

/* PROCESS フロー */
#uk-flow { background: #1a2744 !important; padding: 80px 40px !important; margin: 0 !important; }
.uk-flow-grid { display: grid !important; grid-template-columns: repeat(4,1fr) !important; gap: 0 !important; max-width: 1000px !important; margin: 0 auto !important; }
.uk-flow-step { padding: 32px 20px !important; text-align: center !important; position: relative !important; border-right: 1px solid rgba(255,255,255,0.12) !important; }
.uk-flow-step:last-child { border-right: none !important; }
.uk-flow-num { font-family:'Oswald',sans-serif !important; font-size:36px !important; color: var(--gold) !important; font-weight:700 !important; display:block !important; margin-bottom:12px !important; }
.uk-flow-title { color:#fff !important; font-size:15px !important; font-weight:700 !important; margin:0 0 10px !important; }
.uk-flow-desc { color:rgba(255,255,255,0.65) !important; font-size:12px !important; line-height:1.7 !important; margin:0 !important; }
.uk-section-eyebrow { display:inline-block !important; border:1px solid var(--gold) !important; color:var(--gold) !important; font-family:'Oswald',sans-serif !important; font-size:11px !important; letter-spacing:0.2em !important; padding:5px 20px !important; margin-bottom:20px !important; }
.uk-section-title { font-size:32px !important; font-weight:700 !important; color:var(--white) !important; margin:0 0 8px !important; }
.uk-section-sub { color:rgba(255,255,255,0.5) !important; font-size:13px !important; margin:0 0 48px !important; }

/* CLIENT VOICE */
#uk-voice { background: var(--off-white) !important; padding: 80px 40px !important; }
.uk-voice-grid { display: grid !important; grid-template-columns: repeat(3,1fr) !important; gap: 24px !important; max-width: 1100px !important; margin: 0 auto !important; }
.uk-voice-card { background: var(--white) !important; border-radius: 4px !important; padding: 32px !important; box-shadow: var(--shadow) !important; border-top: 3px solid var(--gold) !important; }
.uk-voice-label { font-size:11px !important; color: var(--gold) !important; font-family:'Oswald',sans-serif !important; letter-spacing:0.1em !important; margin-bottom:8px !important; display:block !important; }
.uk-voice-client { font-size:13px !important; color: var(--navy) !important; font-weight:700 !important; margin-bottom:16px !important; display:block !important; }
.uk-voice-text { font-size:13px !important; line-height:1.8 !important; color: var(--text-body) !important; margin:0 !important; }

/* CAPABILITY */
#uk-services { background: var(--white) !important; padding: 80px 40px !important; }
.uk-srv-grid { display: grid !important; grid-template-columns: repeat(3,1fr) !important; gap: 20px !important; max-width: 1100px !important; margin: 0 auto 32px !important; }
.uk-srv-card { border: 1px solid var(--border) !important; border-radius: 4px !important; padding: 28px !important; border-top: 3px solid var(--gold) !important; }
.uk-srv-label { font-size:10px !important; color: var(--gold) !important; font-family:'Oswald',sans-serif !important; letter-spacing:0.1em !important; display:block !important; margin-bottom:6px !important; }
.uk-srv-category { font-size:11px !important; color: var(--gray) !important; margin-bottom:12px !important; display:block !important; }
.uk-srv-title { font-size:18px !important; font-weight:700 !important; color: var(--navy) !important; margin:0 0 12px !important; }
.uk-srv-desc { font-size:13px !important; line-height:1.7 !important; color: var(--text-body) !important; margin:0 !important; }
.uk-srv-note { text-align:center !important; font-size:13px !important; color: var(--gray) !important; }

/* CTA */
#uk-cta { background: var(--navy) !important; padding: 80px 40px !important; text-align: center !important; }
.uk-cta-eyebrow { display:inline-block !important; border:1px solid rgba(232,150,10,0.5) !important; color:var(--gold) !important; font-family:'Oswald',sans-serif !important; font-size:11px !important; letter-spacing:0.2em !important; padding:5px 20px !important; margin-bottom:24px !important; }
.uk-cta-title { font-size:32px !important; font-weight:700 !important; color:var(--white) !important; line-height:1.4 !important; margin:0 0 12px !important; }
.uk-cta-sub { color:rgba(255,255,255,0.6) !important; font-size:14px !important; margin:0 0 40px !important; }
.uk-cta-table { display:grid !important; grid-template-columns:1fr 1fr !important; gap:2px !important; max-width:600px !important; margin:0 auto 40px !important; background:rgba(255,255,255,0.08) !important; border:1px solid rgba(255,255,255,0.1) !important; }
.uk-cta-cell { padding:16px 24px !important; }
.uk-cta-cell:nth-child(odd) { background:rgba(255,255,255,0.05) !important; }
.uk-cta-cell-label { font-size:11px !important; color:rgba(255,255,255,0.5) !important; display:block !important; margin-bottom:4px !important; letter-spacing:0.08em !important; }
.uk-cta-cell-value { font-size:14px !important; color:var(--white) !important; font-weight:500 !important; display:block !important; }
.uk-cta-btns { display:flex !important; gap:16px !important; justify-content:center !important; flex-wrap:wrap !important; }
.uk-cta-btn-primary { background:var(--gold) !important; color:var(--white) !important; padding:18px 40px !important; font-size:16px !important; font-weight:700 !important; border:none !important; cursor:pointer !important; text-decoration:none !important; display:inline-block !important; letter-spacing:0.05em !important; }
.uk-cta-btn-secondary { background:transparent !important; color:var(--white) !important; padding:18px 40px !important; font-size:16px !important; font-weight:500 !important; border:1px solid rgba(255,255,255,0.4) !important; cursor:pointer !important; text-decoration:none !important; display:inline-block !important; }
.uk-cta-hours { color:rgba(255,255,255,0.4) !important; font-size:12px !important; margin-top:16px !important; }

/* フッター */
footer, #footer { background: var(--navy) !important; color: rgba(255,255,255,0.7) !important; }
footer *, #footer * { color: rgba(255,255,255,0.7) !important; }
footer a, #footer a { color: rgba(255,255,255,0.6) !important; }

/* 共通ヘッダースタイル */
.uk-section-eyebrow-dark { display:inline-block !important; background:var(--navy) !important; color:var(--gold) !important; font-family:'Oswald',sans-serif !important; font-size:11px !important; letter-spacing:0.15em !important; padding:5px 20px !important; margin-bottom:20px !important; }
.uk-section-title-dark { font-size:32px !important; font-weight:700 !important; color:var(--navy) !important; margin:0 0 8px !important; }
.uk-section-sub-dark { color:var(--gray) !important; font-size:13px !important; margin:0 0 48px !important; }

/* BtoB追加スタイル */
.uk-stat-label { font-size: 11px !important; letter-spacing: 0.1em !important; }
#mv_outer .btob-badge span {
  background: rgba(26,39,68,0.85) !important;
  border: 1px solid rgba(255,255,255,0.4) !important;
  color: #ffffff !important;
}
#uk-flow {
  background: #1a2744 !important;
  padding: 80px 40px !important;
  margin: 0 !important;
}
.uk-flow-grid {
  display: grid !important;
  grid-template-columns: repeat(4,1fr) !important;
  gap: 0 !important;
  max-width: 1000px !important;
  margin: 0 auto !important;
}
.uk-flow-step {
  padding: 32px 20px !important;
  text-align: center !important;
  position: relative !important;
  border-right: 1px solid rgba(255,255,255,0.12) !important;
}
.uk-flow-step:last-child { border-right: none !important; }



/* === CMS元コンテンツの非表示（BtoB仕様では不要） === */
[id*="nbp10613754"],
[id*="nbp10613787"],
[id*="nbp10620014"],
[id*="nbp6307596"],
[id*="nbp10614555"],
[id*="nbp10614890"],
[id*="nbp10620062"],
[id*="nbp10620405"],
#uraken-stats-banner {
  display: none !important;
}
