@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC&family=Noto+Serif+TC:wght@200;400;500&display=swap');

/* 增加根變數，方便後續主題維護 */
:root {
  --twnic-orange: #FF6100;
  --twnic-black: #202020;
  --twnic-gray: #E0E0E0;
  --twnic-gray-light: #E0E0E0;
  --twnic-gray-bg: #F9F9F9;
  --twnic-white: #FFFFFF;
  --twnic-blue: #AEDCE7;
  --twnic-green: #BBDAAC;
  --font-en: 'Inter', 'Noto Sans TC', '思源黑體', sans-serif;
}


/* 標題色統一橘色 */
h1, h2, h3, h4, .twnic-title {
  color: var(--twnic-orange);
}
/* 內文黑色 */
p, .news-content, .news-article, td, th {
  color: var(--twnic-black);
}

body {
  /*font-family: 'Inter', 'Noto Sans TC', '思源黑體', sans-serif;*/
  /*background: #fff;*/
  /*color: #202020;*/
  font-family: var(--font-en);  /* 字體全站強制 */
  background: var(--twnic-white);
  color: var(--twnic-black);
  margin: 0;
  padding: 0;
  line-height: 1.8;  /* 新加 */
}


/* Header 與 Logo */
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  /*padding: 32px 48px 24px 48px;*/
  padding: 0px 48px 0px 48px;
  background: var(--twnic-white);
  border-bottom: 1.5px solid var(--twnic-gray);  /* 新加 */
}

.logo {
  height: 60px;
  min-width: 120px;
/*  height: 150px;
  min-width: 267px;*/
/*  height: 150px;
  min-width: 100px;*/
  margin-right: 40px;  /* 安全距離 */
  padding: 0 32px 0 0; /* 安全距離 */
  object-fit: contain;
}

.nav {
  display: flex;
  gap: 32px;
}

.nav-link {
  /*color: #202020;*/
  color: var(--twnic-black);
  text-decoration: none;
  font-weight: 500;
  font-size: 1.1rem;
  padding: 8px 0;
  border-bottom: 2px solid transparent;
  transition: border-color 0.2s, color 0.2s;
}

.nav-link.active,
.nav-link:hover {
  /*color: #FF6100;
  border-bottom: 2px solid #FF6100;*/
  color: var(--twnic-orange);
  border-bottom: 2px solid var(--twnic-orange);
}

/* Hero Section */
.hero {
  text-align: center;
  margin: 48px 0 32px 0;
}

.hero-title {
  font-size: 2.5rem;
  font-weight: 700;
  color: var(--twnic-orange);
  letter-spacing: 1px;
  margin-bottom: 12px;
}

.hero-desc {
  font-size: 1.2rem;
  color: var(--twnic-black);
  margin-bottom: 0;
}

/* 檢測表單 */
.myForm_website-section {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  margin: 24px 0 64px 0;
}

.myForm_website {
  background: var(--twnic-gray-bg);
  border-radius: 16px;
  padding: 32px 40px;
  box-shadow: 0 4px 24px rgba(224,224,224,0.25);
  display: flex;
  flex-direction: column;
  gap: 20px;
  min-width: 450px;
  /* min-width: 340px; */
}

.form-label {
  font-weight: 500;
  color: var(--twnic-black);
  margin-bottom: 4px;
}

.form-input {
  /* width: 400px; */
  padding: 12px 16px;
  border: 1px solid var(--twnic-gray);
  border-radius: 8px;
  font-size: 1rem;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s;
}

.form-input:focus {
  border-color: var(--twnic-orange);
}

.btn-primary {
  background: var(--twnic-orange);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 12px 0;
  font-size: 1.1rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s;
}

.btn-primary:hover {
  background: #F89F68;
}

/* 結果區塊 */
.result {
  margin-top: 24px;
  font-size: 1.1rem;
  color: var(--twnic-black);
  min-height: 40px;
}


/* Footer, 淺灰底 #E0E0E0、中英皆 Inter/思源黑體、置中 */
.footer {
  background: var(--twnic-gray);
  color: var(--twnic-black);
  text-align: center;
  padding: 24px 0;
  font-size: 1rem;
  letter-spacing: 1px;
}


.twnic-checkbox-group {
  margin: 24px 0;
  font-family: 'Inter', 'Noto Sans TC', '思源黑體', sans-serif;
}

.twnic-checkbox {
  display: flex;
  align-items: center;
  font-size: 1.08rem;
  font-weight: 500;
  color: var(--twnic-black);
  cursor: pointer;
  user-select: none;
  gap: 10px;
}

.twnic-checkbox input[type="checkbox"] {
  display: none;
}

.twnic-custom-checkbox {
  width: 22px;
  height: 22px;
  border: 2px solid var(--twnic-orange);
  border-radius: 6px;
  background: #fff;
  display: inline-block;
  position: relative;
  transition: border-color 0.2s, background 0.2s;
  margin-right: 0px;
  /* margin-right: 8px; */
}

.twnic-checkbox input[type="checkbox"]:checked + .twnic-custom-checkbox {
  background: var(--twnic-orange);
  border-color: var(--twnic-orange);
}

.twnic-custom-checkbox::after {
  content: "";
  display: none;
  position: absolute;
  left: 5px;
  top: 1px;
  width: 7px;
  height: 13px;
  border: solid #fff;
  border-width: 0 3px 3px 0;
  transform: rotate(45deg);
}

.twnic-checkbox input[type="checkbox"]:checked + .twnic-custom-checkbox::after {
  display: block;
}




.page-hero {
  text-align: left;
  margin: 48px 0 32px 0;
  position: relative;
}

.page-title {
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--twnic-orange);
  margin-bottom: 8px;
  letter-spacing: 1px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.brand-dot {
  display: inline-block;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--twnic-orange);
  vertical-align: middle;
  margin-left: 8px;
}


.check-time {
  color: var(--twnic-black);
  font-size: 1.1rem;
  margin-bottom: 12px;
}

.section {
  margin: 0 48px 48px 48px;
}

.card {
  background: var(--twnic-gray-bg);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(224,224,224,0.15);
  padding: 28px 24px;
  margin-bottom: 32px;
}

.card-title {
  color: var(--twnic-orange);
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 8px;
}

.card-desc {
  color: var(--twnic-black);
  font-size: 1.05rem;
  margin-bottom: 12px;
}

.sub-title {
  color: var(--twnic-black);
  font-size: 1.1rem;
  font-weight: 700;
  margin-top: 20px;
  margin-bottom: 8px;
}

.card-subblock {
  margin-bottom: 18px;
}

.subblock-title {
  font-weight: 600;
  color: var(--twnic-orange);
  font-size: 1.05rem;
  margin-bottom: 4px;
}

.subblock-desc {
  color: var(--twnic-black);
  font-size: 1.01rem;
  margin-bottom: 8px;
}



/* 表格標頭：橘底白字、間距對齊 */
table {
  width: 100%;
  border-collapse: collapse;
  margin: 8px 0 12px 0;
  font-size: 1.01rem;
}

table thead tr {
  background: var(--twnic-orange);
  color: #fff;
}

table th, table td {
  padding: 8px 10px;
  border: 1px solid var(--twnic-gray);
  text-align: left;
}

table tbody tr:nth-child(even) {
  background: #FFF6EE;
}




/*
響應式設定:
主要段落和區塊在窄螢幕時由 max-width:90vw、padding 減少。
手機直式自動堆疊。
 */
@media (max-width: 900px) {
  .news-list, .news-article {
    max-width: 98vw;
    margin: 0 6px;
    padding: 18px 2vw 0 2vw;
  }
  .section {
    margin: 0 16px 32px 16px;
  }
  .news-content-wrap {
    flex-direction: column;
    gap: 24px;
    padding: 24px 6vw 8vw 6vw;
    max-width: 100vw;
  }
  .news-article {
    padding: 20px 6vw 30px 6vw;
    margin-bottom: 18px;
  }
  .list {
    max-width: 96vw;
    min-width: 0;
    padding: 18px 4vw;
  }
  .header {
    padding: 20px 12px 15px 12px;
  }
}

@media (max-width: 700px) {
  .header {
    flex-direction: column;
    align-items: flex-start;
    padding: 24px 16px 16px 16px;
  }
  .logo {
    margin: 0 0 12px 0;
    padding: 0;
  }
  .nav {
    gap: 16px;
  }
  .myForm_website {
    min-width: 90vw;
    padding: 24px 8vw;
  }
}

@media (max-width: 600px) {
  .header {
    flex-direction: column;
    align-items: flex-start;
    padding: 15px 5vw 9px 5vw;
  }
  .logo {
    margin: 0 0 12px 0;
    padding: 0;
    height: 46px;
    min-width: 82px;
  }
  .news-content-wrap {
    padding: 9vw 2vw 2vw 2vw;
  }
  .news-article {
    padding: 14px 3vw;
  }
  .list {
    padding: 14px 3vw;
  }
}



.collapsible-subblock .collapse-toggle {
  cursor: pointer;
  user-select: none;
  position: relative;
  padding-left: 20px;
  margin-left: 20px;
}

.collapsible-subblock .collapse-toggle::before {
  content: "▶";
  position: absolute;
  left: 0;
  top: 2px;
  font-size: 1em;
  transition: transform 0.2s;
}

.collapsible-subblock.active .collapse-toggle::before {
  content: "▼";
}

.collapsible-subblock.active .subblock-content {
  display: block;
}

@keyframes fadeIn {
  from { opacity: 0;}
  to { opacity: 1;}
}



/* 以下是修改 */
.collapsible-subblock .subblock-content {
  display: none;
  margin-top: 10px;
  margin-left: 45px;
  animation: fadeIn 0.2s;
}


/* 以下是新增加 */
.card-subblock .subblock-title span {
  padding: 5px 5px 5px 30px;
  position: relative;
}

.card-subblock .subblock-title span::before {
  display: inline-block;
  position: absolute;
  top: 5px;
  left: 5px;
  width: 20px;
  height: 20px;
}

.card-subblock .subblock-title span.level-a::before {
  content: url(/img/test-result-icon-level-a.svg);
}

.card-subblock .subblock-title span.level-b::before {
  content: url(/img/test-result-icon-level-b.svg);
}

.card-subblock .subblock-title span.level-c::before {
  content: url(/img/test-result-icon-level-c.svg);
}



.card .card-title span {
  padding: 5px 5px 5px 30px;
  position: relative;
}

.card .card-title span::before {
  display: inline-block;
  position: absolute;
  top: 5px;
  left: 5px;
  width: 20px;
  height: 20px;
}

.card .card-title span.safe::before {
  content: url(/img/test-result-icon-safe.svg);
}

.card .card-title span.attention::before {
  content: url(/img/test-result-icon-attention.svg);
}

/* 這張圖套進去, 位置格式會有問題, 不要用 */
.card .card-title span.error::before {
  content: url(/img/test-result-icon-error.svg);
}



/*
按鈕與重點色: 按鈕主色統一橘色（#FF6100），hover 為 #F89F68。
 */
.btn-primary, .twnic-btn {
  background: var(--twnic-orange);
  color: #fff;
  border-radius: 8px;
  font-weight: 700;
  border: none;
}

.btn-primary:hover, .twnic-btn:hover {
  background: #F89F68;
}



/*
卡片/區塊、內容底色: 依設計稿，重要資訊區塊採淺灰底(如 #F9F9F9)或 #FFF6EE。
 */
.twnic-card, .news-card, .news-box {
  background-color: var(--twnic-gray-bg);
  border-radius: 16px;
  /*box-shadow: 0 4px 24px rgba(224,224,224,0.13);*/
  /*padding: 28px 32px;*/
  padding: 32px 40px;
  box-shadow: 0 4px 24px rgba(224, 224, 224, 0.15);
  color: var(--twnic-black);
  margin-bottom: 32px;
}



/*
列表頁面:
1.標題用 Inter Bold、橘色
2.日期用輔助灰色
3.文章摘要用黑色+標準字體
4.Row 間距 32px
5.每個 article 外框可用 box-shadow
 */
.news-list {
  margin: 0 auto;
  max-width: 900px;
  padding: 32px 0;
}

.news-list-item {
  background: var(--twnic-gray-bg);
  border-radius: 12px;
  box-shadow: 0 2px 12px rgba(224,224,224,0.20);
  padding: 24px 28px;
  margin-bottom: 28px;
  transition: box-shadow 0.2s;
}
.news-list-item:hover {
  box-shadow: 0 4px 24px rgba(224,97,0,0.13);
}
.news-title {
  color: var(--twnic-orange);
  font-size: 1.23rem;
  font-weight: 700;
  margin-bottom: 8px;
  font-family: var(--font-en);
}
.news-date {
  color: var(--twnic-green);
  font-size: 0.96rem;
  margin-bottom: 6px;
  display: block;
}
.news-summary {
  color: var(--twnic-black);
  font-size: 1.05rem;
}

.news-list-item .more {
  border: 1px solid #e3e5e8;
  line-height: 24px;
  padding: 0 16px;
  -ms-flex-item-align: end;
  align-self: flex-end;
  color: #9397a0;
  margin-left: auto;
}



/*
內頁文章:
1.主標題：橘色，Inter Bold 2.0rem
2.小標黑色
3.內容 Inter Regular 字級 1.13rem
4.段落距離 1.5em
 */
.news-article {
  max-width: 900px;
  margin: 0 auto 32px auto;
  padding: 32px 0 0 0;
}
.news-article .main-title {
  color: var(--twnic-orange);
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 16px;
}

.news-article h2, .news-article h3 {
  color: var(--twnic-black);
}
.news-article p {
  color: var(--twnic-black);
  line-height: 1.8;
  font-size: 1.13rem;
  margin-bottom: 1.5em;
}

/* 主要 News 內容主體，兩欄式 */
.news-content-wrap {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 48px;
  max-width: 1100px;
  margin: 0 auto;
  padding: 48px 24px 32px 24px;
}

/* 內文卡圖文區 */
/*
.news-article {
  background: var(--twnic-gray-bg);
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(224,224,224,0.10);
  padding: 38px 54px 38px 54px;
  min-width: 0;
  max-width: 900px;
  flex: 1 1 600px;
}
.main-title {
  color: var(--twnic-orange);
  font-size: 2rem;
  font-weight: bold;
  margin-bottom: 8px; margin-top: 0;
  font-family: var(--font-en);
  display: flex; align-items: center; gap: 10px;
}
*/


/* 右側側欄 News list 區 */
.list {
  background: #FFF;
  border-radius: 16px;
  box-shadow: 0 2px 12px rgba(224,224,224,0.16);
  padding: 28px 24px;
  min-width: 210px;
  max-width: 270px;
  flex: 0 0 220px;
  margin-top: 0;
  margin-left: 0;
  display: flex; flex-direction: column; align-items: stretch;
  gap: 12px;
}
.list h3 {
  color: var(--twnic-orange);
  font-size: 1.03rem;
  font-weight: bold;
  letter-spacing: 2px;
  margin: 0 0 10px 0;
  border-bottom: 1.5px solid var(--twnic-orange);
  padding-bottom: 3px;
  font-family: var(--font-en);
}
.list a {
  display: block;
  border-radius: 8px;
  padding: 10px 10px 10px 0;
  margin-bottom: 3px;
  font-size: 1.06rem;
  color: var(--twnic-black);
  text-decoration: none;
  transition: color 0.2s, background 0.2s;
  font-family: var(--font-en);
  position: relative;
  font-weight: 500;
  line-height: 1.5;
}
.list a:hover,
.list a:focus {
  background: #FFF6EE;
  color: var(--twnic-orange);
}



/* 主要 knowledge 列表容器 */
.knowledge-content-wrap {
  max-width: 800px;
  margin: 48px auto 64px auto;
  padding: 0 24px;
}

/* 知識列表樣式 */
.knowledge-list {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.knowledge-list li {
  font-size: 1.1rem;
  margin-bottom: 14px;
  padding-left: 28px;
  position: relative;
  line-height: 1.5;
  cursor: default;
}

/* 列表前小圓點，符合品牌顏色 */
.knowledge-list li::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 9px;
  width: 14px;
  height: 14px;
  background-color: var(--twnic-orange);
  border-radius: 50%;
}

.knowledge-section {
  margin-bottom: 48px;
  border-left: 4px solid var(--twnic-orange);
}




.about-section {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  align-items: flex-start;
}

.about-text {
  flex: 2;
  min-width: 260px;
}

.about-card {
  background: var(--twnic-gray-bg);
  border-radius: 16px;
  padding: 28px 24px;
  min-width: 220px;
  flex: 1;
}
