/* ============================================================
   STOCK VISION — Common CSS（ヘッダー・フッター共通）
   パークフィールド株式会社
   用途：WP側（/blog）でも共通ヘッダー・フッターに適用するため、
         style.css からヘッダー・フッター用スタイルのみを切り出したファイル。
         グローバルタグ（body / h1〜h4 / p）には一切触らないため、
         WP側のスタイルとの競合を回避できる。
   ============================================================ */


/* ------------------------------------------------------------
   1. CSS カスタムプロパティ（デザイントークン）
   ヘッダー・フッター内のすべてのセレクタが参照するため必須。
   ------------------------------------------------------------ */

:root {

  /* Brand Orange */
  --color-orange:        #FF5B0A;
  --color-orange-light:  #FF722B;
  --color-orange-tint:   #FFF3E3;

  /* Brand Navy */
  --color-navy:          #104071;
  --color-navy-light:    #1A5A9A;
  --color-navy-tint:     #E8F0F8;

  /* Neutral — テキスト */
  --color-text-primary:    #0A0A0A;
  --color-text-secondary:  #434343;
  --color-text-muted:      #999999;

  /* Neutral — サーフェス */
  --color-white:           #FFFFFF;
  --color-surface-1:       #F3F3F3;
  --color-surface-2:       #EFEFEF;

  /* ボーダー */
  --color-border:          #D9D9D9;

  /* タイポグラフィ */
  --font-base:             'Murecho', sans-serif;
  --font-weight-regular:   400;
  --font-weight-bold:      700;
  --font-weight-black:     900;
  --font-size-xs:          12px;
  --font-size-sm:          14px;
  --font-size-base:        16px;
  --font-size-md:          18px;

}


/* ------------------------------------------------------------
   2. HEADER — 共通ヘッダー
   ------------------------------------------------------------ */

.sv-header {
  position:      sticky;
  top:           0;
  z-index:       100;
  background:    var(--color-white);
  border-bottom: 1px solid var(--color-border);
}

.sv-header-inner {
  max-width:       1200px;
  margin:          0 auto;
  padding:         10px clamp(16px, 4vw, 40px);
  display:         flex;
  align-items:     center;
  justify-content: space-between;
}

.sv-header-logo img {
  height:  36px;
  width:   auto;
  display: block;
}

.sv-header-nav {
  flex:            1;
  display:         flex;
  justify-content: center;
}

.sv-hamburger {
  display:         none;
  flex-direction:  column;
  justify-content: center;
  gap:             5px;
  width:           40px;
  height:          40px;
  background:      none;
  border:          none;
  cursor:          pointer;
  padding:         8px;
}

.sv-hamburger-bar {
  display:       block;
  width:         22px;
  height:        2px;
  background:    var(--color-navy);
  border-radius: 2px;
  transition:    transform 0.25s, opacity 0.25s;
}

.sv-hamburger.is-open .sv-hamburger-bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.sv-hamburger.is-open .sv-hamburger-bar:nth-child(2) {
  opacity: 0;
}
.sv-hamburger.is-open .sv-hamburger-bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}

.sv-nav {
  display:     flex;
  flex-wrap:   wrap;
  align-items: center;
  gap:         clamp(16px, 3vw, 32px);
  list-style:  none;
  margin:      0;
  padding:     0;
}

.sv-nav-link {
  font-size:       var(--font-size-sm);
  font-weight:     var(--font-weight-bold);
  color:           var(--color-text-primary);
  text-decoration: none;
  transition:      color 0.15s;
}

.sv-nav-link:hover {
  color: var(--color-orange);
}

@media (max-width: 900px) {
  .sv-hamburger {
    display: flex;
  }
  .sv-header-nav {
    display:    none;
    position:   absolute;
    top:        100%;
    left:       0;
    right:      0;
    background: var(--color-white);
    border-top: 1px solid var(--color-border);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    padding:    8px 0 16px;
  }
  .sv-header-nav.is-open {
    display: block;
  }
  .sv-header-nav .sv-nav {
    flex-direction: column;
    align-items:    flex-start;
    gap:            0;
    padding:        0 clamp(16px, 4vw, 40px);
  }
  .sv-header-nav .sv-nav li {
    width: 100%;
  }
  .sv-header-nav .sv-nav-link {
    display:       block;
    padding:       12px 0;
    border-bottom: 1px solid var(--color-border);
  }
  .sv-header-nav .sv-nav li:last-child .sv-nav-link {
    border-bottom: none;
  }
}


/* ------------------------------------------------------------
   3. FOOTER — 共通フッター
   ------------------------------------------------------------ */

.sv-footer {
  background:  var(--color-surface-1);
  border-top:  1px solid var(--color-border);
  padding:     clamp(32px, 5vw, 56px) clamp(16px, 4vw, 40px);
}

.sv-footer-inner {
  max-width:       1200px;
  margin:          0 auto;
  display:         flex;
  flex-wrap:       wrap;
  gap:             clamp(24px, 4vw, 48px);
  justify-content: space-between;
  align-items:     flex-start;
}

.sv-footer-brand {
  display:        flex;
  flex-direction: column;
  gap:            12px;
  flex:           1 1 260px;
}

.sv-footer-logo {
  height:  32px;
  width:   auto;
  display: block;
}

.sv-footer-company {
  font-size:   var(--font-size-sm);
  font-style:  normal;
  color:       var(--color-text-secondary);
  line-height: 1.9;
}

.sv-footer-company a {
  color:           var(--color-text-secondary);
  text-decoration: none;
  transition:      color 0.15s;
}

.sv-footer-company a:hover {
  color: var(--color-orange);
}

.sv-footer-links {
  list-style:     none;
  padding:        0;
  margin:         0;
  display:        flex;
  flex-direction: column;
  gap:            8px;
  flex:           0 0 auto;
}

.sv-footer-link {
  font-size:       var(--font-size-sm);
  color:           var(--color-text-secondary);
  text-decoration: none;
  transition:      color 0.15s;
}

.sv-footer-link:hover {
  color: var(--color-orange);
}

.sv-footer-bottom {
  max-width:   1200px;
  margin:      clamp(24px, 3vw, 36px) auto 0;
  padding-top: 20px;
  border-top:  1px solid var(--color-border);
  font-size:   var(--font-size-xs);
  color:       var(--color-text-muted);
  text-align:  center;
}

.sv-footer-bottom a {
  color:           var(--color-text-muted);
  text-decoration: none;
}

.sv-footer-bottom a:hover {
  color:           var(--color-orange);
  text-decoration: underline;
}
