@charset "utf-8";

/* =========================
   Company Table (Ultra Stylish + Color)
========================= */
:root{
  --ink:#0f172a;
  --muted:#64748b;
  --line:rgba(15,23,42,.10);

  --card:rgba(255,255,255,.92);
  --glass:rgba(255,255,255,.72);

  --accent1:#2563eb; /* blue */
  --accent2:#06b6d4; /* cyan */

  --radius:22px;
  --radius-in:16px;

  /* 多層シャドウ（“上質”に見える） */
  --shadow1:0 10px 28px rgba(15,23,42,.10);
  --shadow2:0 26px 70px rgba(15,23,42,.14);

  --ease:cubic-bezier(.2,.8,.2,1);
}

.company-box{
  display:flex;
  justify-content:center;
  margin-top: clamp(18px, 3vw, 44px);
  padding: 0 clamp(12px, 3vw, 22px);
  color: var(--ink);
  font-size: 16px;
}

/* カード本体 */
.company-box table{
  width: min(980px, 100%);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--line);
  position: relative;

  /* “光”＋ガラス感＋白 */
  background:
    radial-gradient(1200px 320px at 12% -14%, rgba(37,99,235,.14), transparent 62%),
    radial-gradient(900px 300px at 92% -18%, rgba(6,182,212,.16), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.78), rgba(255,255,255,.92)),
    var(--card);

  box-shadow: var(--shadow1), var(--shadow2);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

/* 上部グラデ帯＋グロー */
.company-box table::before{
  content:"";
  display:block;
  height: 12px;
  background: linear-gradient(90deg, var(--accent1), var(--accent2));
}
.company-box table::after{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height: 16px;
  background: linear-gradient(90deg, rgba(37,99,235,.55), rgba(6,182,212,.55));
  filter: blur(14px);
  opacity: .55;
  pointer-events:none;
}

/* 罫線（薄く） */
.company-box table tr + tr th,
.company-box table tr + tr td{
  border-top: 1px solid rgba(15,23,42,.085);
}

.company-box table th,
.company-box table td{
  padding: 18px 20px;
  vertical-align: top;
}

/* 左：ラベル（th）→ ガラス＋アクセント */
.company-box table th{
  width: 28%;
  text-align:left;
  font-weight: 900;
  letter-spacing: .04em;
  color: var(--ink);
  white-space: nowrap;
  position: relative;

  background:
    linear-gradient(180deg, rgba(37,99,235,.06), rgba(6,182,212,.04)),
    var(--glass);

  /* 右の仕切りを“極細”で上品に */
  border-right: 1px solid rgba(15,23,42,.08);
}

/* th 左端アクセント（細くして高級感） */
.company-box table th::before{
  content:"";
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:3px;
  background: linear-gradient(180deg, var(--accent1), var(--accent2));
  opacity: .95;
}

/* 右：値（td） */
.company-box table td{
  width: 72%;
  text-align:left;
  line-height: 1.75;
  color: var(--ink);
  background: transparent;
}

/* ゼブラ（さらに薄く） */
.company-box table tr:nth-child(even) td{
  background: rgba(15,23,42,.012);
}

/* PCのみ：行ホバーで“UI感” */
@media (hover:hover) and (pointer:fine){
  .company-box table tr{
    transition: background-color .25s var(--ease), transform .25s var(--ease);
  }
  .company-box table tr:hover td{
    background: rgba(37,99,235,.035);
  }
}

/* リンク：フォールバック→color-mix対応で上書き */
.company-box table td a{
  color: var(--accent1);
  text-decoration: none;
  border-bottom: 1px solid rgba(37,99,235,.28);
  padding-bottom: 2px;
  transition: border-color .2s var(--ease), color .2s var(--ease), opacity .2s var(--ease);
}
@supports (color: color-mix(in srgb, #000 50%, #fff)){
  .company-box table td a{
    color: color-mix(in srgb, var(--accent1) 86%, var(--ink));
  }
}
.company-box table td a:hover{
  color: var(--accent2);
  border-bottom-color: rgba(6,182,212,.55);
}

/* 強調（電話など） */
.company-box table td.is-strong{
  font-weight: 900;
  letter-spacing: .01em;
}
.company-box table td.is-strong::before{
  content:"";
  display:inline-block;
  width:10px;
  height:10px;
  border-radius: 999px;
  margin-right: 10px;
  background: linear-gradient(90deg, var(--accent1), var(--accent2));
  vertical-align: middle;
  transform: translateY(-1px);
}

/* ===== SP：縦積み（より見やすく） ===== */
@media (max-width: 720px){
  .company-box table,
  .company-box table tbody,
  .company-box table tr,
  .company-box table th,
  .company-box table td{
    display:block;
    width:100%;
  }

  .company-box table{
    border-radius: 20px;
  }

  .company-box table tr{
    padding: 14px 16px;
  }
  .company-box table tr + tr{
    border-top: 1px solid rgba(15,23,42,.085);
  }

  .company-box table th{
    padding: 0 0 6px 0;
    background: transparent;
    border-right: 0;
    font-size: 12.5px;
    color: rgba(15,23,42,.62);
    white-space: normal;
  }
  .company-box table th::before{
    left: -16px;
    width: 3px;
    opacity: .9;
  }

  .company-box table td{
    padding: 0;
    word-break: break-word;
  }
  .company-box table tr:nth-child(even) td{
    background: transparent;
  }
}

/* map側 */
.company-map{
  text-align:center;
  margin-top: clamp(18px, 3vw, 44px);
  padding: 0 clamp(12px, 3vw, 22px);
}
