/* ================================
   Modal base styles + animation
   ================================ */
.modal {
  position: fixed;
  inset: 0;
  display: none;
}
.modal[aria-hidden="false"] { display: block; }

.modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
  backdrop-filter: saturate(120%) blur(2px);
  opacity: 0;
  transition: opacity .25s ease;
}
.modal[aria-hidden="false"] .modal-backdrop { opacity: 1; }

/* ===== パネル（PCは中央寄せ＋ガター、内側余白あり） ===== */
.modal-panel {
  position: relative;
  background: var(--panel, #0f131a);
  color: var(--text, #e8eef6);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 16px;
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  overflow: hidden;
  opacity: 0;
  transition: opacity .25s ease, transform .25s ease;

  /* 中央寄せ（PC時） */
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  /* 画面端の“寄りすぎ”防止ガター（左右 32px / 上下 64px） */
  width: min(960px, calc(100vw - 64px));      /* 左右 32px ずつの余白を確保 */
  max-height: calc(100vh - 128px);            /* 上下 64px ずつの余白を確保 */

  /* パネル内の余白（中身がボーダーにベタ付かない） */
  padding: 16px;
}
.modal[aria-hidden="false"] .modal-panel {
  opacity: 1;
}

.modal-close {
  position: absolute;
  top: 12px; right: 16px;
  z-index: 2;
  width: 36px; height: 36px;
  border: 0; border-radius: 999px;
  background: transparent;
  color: var(--text, #e8eef6);
  font-size: 24px;
  cursor: pointer;
}

/* ===== 本文レイアウト（左 OGP / 右テキスト） ===== */
.modal-body {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 24px;                   /* パネル内のカラム間もゆったり */
}

/* 左 OGP 枠（角丸＋オーバーフロー隠し） */
.modal-ogp {
  background: #0b0f15;
  min-height: 220px;
  aspect-ratio: 1200 / 630;
  border-radius: 12px;
  overflow: hidden;
}
.modal-ogp img {
  display: block;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover;
}

/* 右コンテンツ */
.modal-content { padding: 4px 0; } /* パネルに16pxあるので中は控えめでOK */
.modal-title { margin: 0 0 8px; font-size: 22px; line-height: 1.35; }

.modal-meta {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 6px 14px;
  margin: 10px 0 16px;
}
.modal-meta dt { color: var(--muted, #a6b0bf); }

.modal-actions { display: flex; gap: 10px; }

.btn { display: inline-block; padding: 10px 14px; border-radius: 10px; text-decoration: none; }
.btn-primary { background: var(--brand, #00A6FE); color: #fff; }

/* --- スマホ（全画面＋内側12pxパディング） --- */
@media (max-width: 800px) {
  .modal-panel {
    top: 0; left: 0; transform: none;
    width: 100%;
    max-height: none;
    border-radius: 0;
    padding: 12px;                 /* 画面端から少し内側に余白 */
  }
  .modal-body {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .modal-ogp { max-height: 40vh; }
}

/* --- PC 微調整：フォーカス枠と内部スクロール --- */
@media (min-width: 801px) {
  .modal-body { overflow: auto; }
}
.modal-panel:focus {
  outline: 2px solid rgba(0,166,254,.6);
  outline-offset: 2px;
}

/* ==== 共通：OGP/プレースホルダーの表示ルール ==== */
/* OGPはトリミングせず全体表示（ガタつき防止用） */
#companyModal .modal-ogp img {
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #0b0f15 !important;
  padding: 8px !important;
}

/* プレースホルダー（動的SVG/共通ロゴ）時 */
#companyModal .modal-ogp img[data-placeholder="1"] {
  object-fit: contain !important;
  padding: 8px !important;
  background: #0b0f15 !important;
}

/* ======= company-modal 強制オーバーライド（最優先） ======= */
/* パネルをPCは中央寄せ・ガター確保、SPは全画面に */
#companyModal .modal-panel {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;

  /* 画面端ガター：左右32px・上下64px（幅・高さの上限） */
  width: min(960px, calc(100vw - 64px)) !important;  /* 左右 32px ずつ空ける */
  max-height: calc(100vh - 128px) !important;        /* 上下 64px ずつ空ける */

  background: var(--panel, #0f131a) !important;
  color: var(--text, #e8eef6) !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  border-radius: 16px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.45) !important;
  overflow: hidden !important;

  /* 旧CSSの margin: 5vh auto; を無効化 */
  margin: 0 !important;

  /* 内側余白（中身がベタ付かない） */
  padding: 16px !important;

  opacity: 1 !important;          /* アニメ前提ならここはお好みで */
}

/* パネル内部の2カラムとOGP */
#companyModal .modal-body{
  display: grid !important;
  grid-template-columns: 360px 1fr !important;
  gap: 24px !important;
}
#companyModal .modal-ogp{
  background: #0b0f15 !important;
  aspect-ratio: 1200 / 630 !important;
  border-radius: 12px !important;
  overflow: hidden !important;
}
#companyModal .modal-ogp img{
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 100% !important;
  max-height: 100% !important;
  object-fit: contain !important;
  object-position: center center !important;
  background: #0b0f15 !important;
  padding: 8px !important;
}
#companyModal .modal-ogp img[data-placeholder="1"]{
  object-fit: contain !important;
  padding: 8px !important;
  background: #0b0f15 !important;
}

/* 閉じるボタン位置 */
#companyModal .modal-close{
  position: absolute !important;
  top: 12px !important;
  right: 16px !important;
}

/* スマホは全画面に */
@media (max-width: 800px){
  #companyModal .modal-panel{
    top: 0 !important;
    left: 0 !important;
    transform: none !important;
    width: 100% !important;
    max-height: none !important;
    border-radius: 0 !important;
    padding: 12px !important;
  }
  #companyModal .modal-body{
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  #companyModal .modal-ogp{ max-height: 40vh !important; }
}

/* モーダル内の会社情報（設立・公式サイトなど）を横並びにする */
.modal-meta {
  display: grid;
  grid-template-columns: 7rem 1fr;
  gap: 8px 12px;
  align-items: center;
}

.modal-meta dt {
  color: var(--muted);
  margin: 0;
}

.modal-meta dd {
  margin: 0;
}

/* JSから消したい時に使う非表示クラス */
.is-hidden {
  display: none !important;
}

/* モーダル内の会社情報（設立・公式サイトなど）を横並びにする */
.modal-meta {
  display: grid;
  grid-template-columns: 7rem 1fr;
  gap: 8px 12px;
  align-items: center;
}

.modal-meta dt {
  color: var(--muted);
  margin: 0;
}

.modal-meta dd {
  margin: 0;
}

/* JSから消したい時に使う非表示クラス */
.is-hidden {
  display: none !important;
}
/* ===== モーダル中身は縦フローに固定（グリッド無効化） ===== */
#companyModal .modal-body{
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  padding: 0 !important;
  grid-template-columns: none !important;
}

/* 旧OGPブロックは常に非表示（互換用にDOMだけ残す） */
#companyModal .modal-ogp{ display: none !important; }

/* ヘッダー（ロゴ＋社名） */
#companyModal .company-head{
  display: flex !important;
  align-items: center;
  gap: 12px;
  margin: 0;
}

/* 会社情報カード */
#companyModal .kv-list{
  margin: 0;
  padding: 12px;
  border-radius: 10px;
}

/* ボタン行：パネル内に収める＆左寄せ（好みで右寄せに） */
#companyModal .modal-actions{
  display: flex !important;
  justify-content: flex-start;   /* 右寄せなら flex-end */
  margin: 0;                     /* はみ出し防止 */
}

/* 念のため：どこかのCSSでfloat/positionが当たってても無効化 */
#companyModal .modal-actions,
#companyModal .modal-actions .btn{
  float: none !important;
  position: static !important;
}

/* スマホ時はボタンを幅いっぱいにするなら */
@media (max-width: 768px){
  #companyModal .modal-actions .btn{ width: 100%; text-align: center; }
}

/* モーダル：縦フロー固定（念のため） */
#companyModal .modal-body{ display:flex !important; flex-direction:column !important; gap:12px !important; }

/* ボタンは廃止 */
#companyModal .modal-actions{ display:none !important; }

/* アイコン（小さめ） */
#companyModal .company-logo{
  width: clamp(44px, 9vw, 56px);
  height: clamp(44px, 9vw, 56px);
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  display:grid; place-items:center; overflow:hidden;
}
#companyModal .company-logo img{ width: 70%; height:auto; }

/* 社名の存在感はキープ */
#companyModal .company-title .name{
  margin:0; font-weight:800; font-size: clamp(18px, 4.8vw, 22px); line-height:1.25;
}

/* 情報カード */
#companyModal .kv-list{ margin:0; padding:12px; border:1px solid var(--line); border-radius:10px; }
#companyModal .kv-list .modal-meta{
  display:grid; grid-template-columns: 96px 1fr; row-gap:8px; column-gap:10px; margin:0;
}
#companyModal .kv-list dt{ color:var(--muted); font-size:13px; }
#companyModal .kv-list dd{ margin:0; font-size:14px; }

/* URLを“主役”に（ホバーも分かりやすく） */
#companyModal .url-link{
  text-decoration: underline; text-underline-offset: 3px;
  border-radius:6px; padding:2px 4px;
}
#companyModal .url-link:hover, 
#companyModal .url-link:focus{
  background: rgba(41,170,255,.12);
  outline: none;
}
@media (max-width:380px){
  #companyModal .kv-list .modal-meta{ grid-template-columns: 88px 1fr; }
}


/* ===== 準備中リンク共通スタイル ===== */
.link-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.link-list li {
  margin-bottom: 12px;
}
.link-list a,
.link-list .coming-soon {
  display: inline-block;
  padding: 12px 16px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
}
.link-list a {
  background: var(--panel);
  color: var(--text);
}
.link-list a:hover {
  background: var(--brand);
  color: #fff;
}
.coming-soon {
  background: var(--panel-2);
  color: var(--muted);
  cursor: not-allowed;
  opacity: 0.6;
}

/* お問い合わせボタン（通常時を明るい青に強制） */
.nav .contact-btn > a {
  background: linear-gradient(180deg, #00A6FE, #29AAFF) !important;
  color: #fff !important;
}

/* ホバー時 */
.nav .contact-btn > a:hover,
.nav .contact-btn > a:focus {
  background: linear-gradient(180deg, #00BFFF, #4FC7FF) !important;
}
