@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;
}


/* ============================================== */
/* === ブラッシュアップCSS（2026/05 追加） === */
/* ============================================== */

/* --- 1. ヒーロー領域の視認性向上 --- */
.uk-hero, .swiper-slide, .mv, [class*="mainvisual"], .top_mv {
  position: relative;
}
.uk-hero::after, .swiper-slide::after, .mv::after, [class*="mainvisual"]::after, .top_mv::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0.25) 0%, rgba(0,0,0,0.55) 100%);
  pointer-events: none;
  z-index: 1;
}
.uk-hero > *, .swiper-slide > *, .mv > *, [class*="mainvisual"] > *, .top_mv > * {
  position: relative;
  z-index: 2;
}
.swiper-slide h2, .mv h2, [class*="mainvisual"] h2,
.swiper-slide h1, .mv h1, [class*="mainvisual"] h1 {
  text-shadow: 0 2px 12px rgba(0,0,0,0.5);
  font-weight: 700 !important;
  letter-spacing: 0.04em;
}

/* --- 2. CTAボタンの強弱付け --- */
a[href*="contact"], a[href*="form"], .btn-cta, .uk-btn-primary {
  position: relative;
  transition: transform .2s ease, box-shadow .2s ease, filter .2s ease !important;
  box-shadow: 0 6px 18px rgba(176, 121, 56, 0.35);
  font-weight: 700 !important;
}
a[href*="contact"]:hover, a[href*="form"]:hover, .btn-cta:hover, .uk-btn-primary:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 10px 28px rgba(176, 121, 56, 0.5);
  filter: brightness(1.05);
}

/* サブCTA（ご依頼の流れ等）はアウトライン化 */
a[href*="flow"], a[href*="process"], .btn-secondary, .uk-btn-outline {
  background: rgba(255,255,255,0.05) !important;
  border: 2px solid rgba(255,255,255,0.85) !important;
  color: #fff !important;
  transition: all .25s ease !important;
}
a[href*="flow"]:hover, a[href*="process"]:hover, .btn-secondary:hover, .uk-btn-outline:hover {
  background: rgba(255,255,255,1) !important;
  color: #1a2438 !important;
}

/* --- 3. 数字バナー（uk-stats）の視認性強化 --- */
#uk-stats, .uk-stats {
  padding: 60px 20px;
  background: linear-gradient(135deg, #1a2438 0%, #2c3e5d 100%);
}
#uk-stats .uk-stat-number, .uk-stats .uk-stat-number,
#uk-stats [class*="stat-number"], .uk-stats [class*="stat-number"] {
  font-size: clamp(3rem, 6vw, 4.8rem) !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  color: #fff;
  letter-spacing: -0.02em;
  background: linear-gradient(135deg, #fff 0%, #ffd89b 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
#uk-stats .uk-stat-unit, .uk-stats .uk-stat-unit,
#uk-stats [class*="stat-unit"], .uk-stats [class*="stat-unit"] {
  font-size: 0.9rem !important;
  font-weight: 500 !important;
  margin-left: 4px;
  color: rgba(255,255,255,0.85) !important;
}
#uk-stats [class*="stat-label"], .uk-stats [class*="stat-label"] {
  font-size: 0.95rem;
  margin-top: 12px;
  color: rgba(255,255,255,0.75);
  letter-spacing: 0.05em;
}

/* --- 4. PROCESSセクション（01〜04ステップ）の装飾 --- */
[class*="process"] [class*="step"], .uk-process-item, .process-item {
  position: relative;
  padding-top: 28px;
  transition: transform .3s ease;
}
[class*="process"] [class*="step"]:hover, .uk-process-item:hover, .process-item:hover {
  transform: translateY(-4px);
}
[class*="process"] [class*="step"]::before {
  content: "";
  display: block;
  width: 56px;
  height: 4px;
  background: linear-gradient(90deg, #b07938 0%, #ffd89b 100%);
  border-radius: 2px;
  margin: 0 auto 18px;
}

/* --- 5. CLIENT VOICE（お客様の声）の信頼補強 --- */
[class*="voice"] [class*="card"], .uk-voice-card, .voice-item {
  background: #fff;
  border-radius: 12px;
  padding: 28px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.06);
  border-top: 4px solid #b07938;
  transition: transform .3s ease, box-shadow .3s ease;
}
[class*="voice"] [class*="card"]:hover, .uk-voice-card:hover, .voice-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(0,0,0,0.1);
}

/* --- 6. セクション見出しのリズム強化 --- */
section h2, .uk-section h2 {
  position: relative;
  letter-spacing: 0.06em;
}
section h2 + p, section h2 + .uk-h2-sub {
  letter-spacing: 0.03em;
}

/* --- 7. 追従CTAバー（PC/SP共通） --- */
.uk-floating-cta {
  position: fixed;
  bottom: 16px;
  right: 16px;
  z-index: 999;
  display: none;
  flex-direction: column;
  gap: 8px;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .4s ease, transform .4s ease;
  pointer-events: none;
}
.uk-floating-cta.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.uk-floating-cta a {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none;
  box-shadow: 0 6px 20px rgba(0,0,0,0.18);
  transition: transform .2s ease, box-shadow .2s ease;
  white-space: nowrap;
}
.uk-floating-cta a:hover {
  transform: translateY(-2px);
  box-shadow: 0 10px 28px rgba(0,0,0,0.25);
}
.uk-floating-cta .uk-fcta-tel {
  background: #1a2438;
  color: #fff;
}
.uk-floating-cta .uk-fcta-form {
  background: linear-gradient(135deg, #b07938 0%, #d4924d 100%);
  color: #fff;
}
@media (min-width: 769px) {
  .uk-floating-cta { display: flex; }
}
@media (max-width: 768px) {
  .uk-floating-cta {
    display: flex;
    bottom: 0;
    right: 0;
    left: 0;
    flex-direction: row;
    gap: 0;
  }
  .uk-floating-cta a {
    flex: 1;
    border-radius: 0;
    padding: 14px 8px;
    font-size: 0.85rem;
    box-shadow: 0 -4px 14px rgba(0,0,0,0.12);
  }
  body { padding-bottom: 56px; }
}

/* --- 8. 全体のフォント可読性 --- */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
p, li {
  line-height: 1.85;
}

/* --- 9. リンクのフォーカス可視化（アクセシビリティ） --- */
a:focus-visible, button:focus-visible {
  outline: 3px solid #b07938;
  outline-offset: 2px;
  border-radius: 4px;
}

/* --- 10. 画像のホバー演出 --- */
.uk-card img, [class*="service"] img, [class*="achievement"] img {
  transition: transform .5s ease;
}
.uk-card:hover img, [class*="service"] a:hover img, [class*="achievement"] a:hover img {
  transform: scale(1.04);
}
.uk-card, [class*="service"] a, [class*="achievement"] a {
  overflow: hidden;
}
/* === ブラッシュアップCSS END === */


/* Hero overlay lighten - applied 2026-05-02 */
.mv-overlay { background: rgba(15,22,45,0.15) !important; }
.slide10::after, .mv_img li::after, .mv_img li::before { background: transparent !important; }
.mv_text, .mv-text, .mv_text * { text-shadow: 0 2px 8px rgba(0,0,0,0.55), 0 1px 2px rgba(0,0,0,0.45); }


/* Hero overlay - mv::after lighten (added 2026-05-02 v2) */
body #mv::after, html body #mv::after, #mv::after, #mv.slide10::after { background: rgba(77, 65, 57, 0.10) !important; }
body .mv-overlay, html body .mv-overlay { background: rgba(15,22,45,0.18) !important; }


/* Hero buttons clickable fix (added 2026-05-02) */
#mv .mv_text a, #mv .mv_text button, #mv .hero-btns, #mv .hero-btns *, #mv .mv_text .hero-btns a { pointer-events: auto !important; cursor: pointer !important; }


/* Hero height fix - remove empty space below hero (added 2026-05-02) */
#mv_outer { height: auto !important; min-height: 0 !important; }
#mv { height: 600px !important; min-height: 0 !important; }
@media (max-width: 768px) {
  #mv { height: 70vw !important; min-height: 320px !important; }
}
