@charset "UTF-8";

/* ==========================================
   品質基本方針ページ専用スタイル（改修版 / FIX）
   - 上部（方針 + KPI）をスマートに（カード化）
   - 下部テーブル（ISOテーブル）は従来の見た目を維持
   ========================================== */

*,
*::before,
*::after {
   box-sizing: border-box;
}

/* レイアウト基本設定 */
.iso-page {
   padding: clamp(48px, 6vw, 80px) 20px;
   color: #1f2937;
   line-height: 1.85;
   font-family: "Noto Sans JP", sans-serif;
}

.iso-page .container {
   max-width: 1000px;
   margin: 0 auto;
   padding: 0;
}

/* タイトル設定 */
.iso-page .page-title {
   text-align: center;
   font-size: clamp(1.75rem, 2.8vw, 2.25rem);
   color: #003366;
   /* トスコのテーマカラー */
   margin: 0 0 clamp(28px, 4vw, 56px);
   font-weight: 800;
   letter-spacing: 0.02em;
   line-height: 1.25;
   position: relative;
}

/*
.iso-page .page-title::after {
   content: "";
   display: block;
   width: 72px;
   height: 3px;
   background: rgba(0, 84, 152, 0.22);
   margin: 16px auto 0;
   border-radius: 999px;
}
*/

/* ==========================================
   上部（方針・品質目標）: スマート化
   ========================================== */

.iso-page .policy-section {
   padding: clamp(20px, 3vw, 36px);
   border: 1px solid #eaf0f6;
   border-radius: 16px;
   background: linear-gradient(180deg, #f7fbff 0%, #ffffff 55%);
}

.iso-page .policy-head {
   text-align: center;
   margin-bottom: clamp(18px, 3vw, 28px);
}

.iso-page .policy-eyebrow {
   display: inline-block;
   font-size: 0.85rem;
   letter-spacing: 0.18em;
   font-weight: 800;
   color: #005498;
   background: rgba(0, 84, 152, 0.08);
   padding: 8px 14px;
   border-radius: 999px;
   margin: 0 0 14px;
}

.iso-page .policy-lead {
   margin: 0;
   font-weight: 900;
   line-height: 1.55;
   font-size: clamp(1.15rem, 2.2vw, 1.65rem);
   color: #0f172a;
}

.iso-page .policy-sub {
   margin: 12px 0 0;
   color: #475569;
   font-size: 0.95rem;
}

/* KPI */
.iso-page .kpi {
   margin-top: clamp(18px, 3vw, 26px);
}

.iso-page .kpi-title {
   margin: 0 0 12px;
   font-size: 1.05rem;
   font-weight: 900;
   color: #0f172a;
   text-align: left;
}

.iso-page .kpi-grid {
   display: grid;
   grid-template-columns: repeat(3, minmax(0, 1fr));
   gap: 14px;
}

.iso-page .kpi-card {
   border: 1px solid #e8eef5;
   border-radius: 14px;
   background: #fff;
   padding: 16px 16px 14px;
   box-shadow: 0 10px 26px rgba(2, 8, 23, 0.05);
}

.iso-page .kpi-card-head {
   display: flex;
   align-items: baseline;
   justify-content: space-between;
   gap: 12px;
   padding-bottom: 10px;
   border-bottom: 1px dashed #e5e7eb;
}

.iso-page .kpi-name {
   margin: 0;
   font-size: 1rem;
   font-weight: 900;
   color: #111827;
   line-height: 1.35;
}

.iso-page .kpi-value {
   margin: 0;
   display: inline-flex;
   align-items: baseline;
   gap: 4px;
   color: #005498;
}

.iso-page .kpi-num {
   font-size: 2rem;
   font-weight: 900;
   line-height: 1;
   letter-spacing: 0.01em;
}

.iso-page .kpi-unit {
   font-size: 1rem;
   font-weight: 900;
}

.iso-page .kpi-desc {
   margin: 10px 0 0;
   font-size: 0.9rem;
   color: #64748b;
   line-height: 1.7;
}

/* 署名部分 */
.iso-page .policy-footer {
   text-align: right;
   margin-top: clamp(18px, 3vw, 26px);
   color: #475569;
}

.iso-page .policy-footer p {
   margin: 0;
}

.iso-page .policy-footer p+p {
   margin-top: 6px;
}

/* 区切り線 */
.iso-page .separator {
   margin: clamp(40px, 6vw, 70px) 0;
   border: 0;
   border-top: 1px solid #eee;
}

/* ==========================================
   ISOテーブル（ここは現状踏襲）
   ========================================== */

.iso-page .iso-table {
   width: 100%;
   border-collapse: collapse;
   margin-top: 20px;
}

.iso-page .iso-table th,
.iso-page .iso-table td {
   border: 1px solid #ddd;
   padding: 15px 20px;
   text-align: left;
}

.iso-page .iso-table th {
   background-color: #f9f9f9;
   width: 30%;
   font-weight: 700;
}

/* ==========================================
   レスポンシブ
   ========================================== */

@media (max-width: 900px) {
   .iso-page .kpi-grid {
      grid-template-columns: 1fr;
   }
}

@media (max-width: 768px) {

   .iso-page .policy-lead,
   .iso-page .policy-sub{
      text-align: left;
   }
   
   .iso-page .iso-table th,
   .iso-page .iso-table td {
      display: block;
      width: 100%;
   }

   .iso-page .iso-table th {
      background-color: #eee;
   }
}