/* ==========================================================================
   Hoshikawa Laboratory — Shared Stylesheet
   最終更新: 2026-04-21
   ========================================================================== */

:root{
  --ink:#1b1b1b;
  --ink-2:#3a3a3a;
  --ink-3:#606060;
  --ink-4:#8a8a8a;
  --paper:#faf8f3;
  --paper-2:#f2ede1;
  --line:#dcd6c4;
  --line-2:#e8e2d2;
  --accent:#5a4a2e;
  --accent-2:#3a4a5a;

  /* Map marker colors */
  --pin-lab:#d64545;     /* 研究室：赤 */
  --pin-office:#2e6bd6;  /* 教員室：青 */

  --serif-disp:'Cormorant Garamond',serif;
  --serif-ja:'Noto Serif JP',serif;
  --sans:'Inter','Helvetica Neue',sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--serif-ja);
  font-weight:400;
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"palt";
}

/* ========== 上部ライン ========== */
.toprule{
  border-bottom:1px solid var(--line);
  padding:14px 40px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.14em;
  color:var(--ink-3);
  flex-wrap:wrap;
  gap:10px;
}
.toprule .brand-mini{
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-2);
  letter-spacing:.08em;
}

/* ========== メインヘッダ ========== */
.masthead{
  padding:56px 40px 40px;
  border-bottom:2px solid var(--ink);
  background:var(--paper);
}
.masthead-inner{max-width:1300px;margin:0 auto}
.titlecard .over{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-3);
  margin-bottom:18px;
  display:flex;
  align-items:center;
  gap:14px;
}
.titlecard .over::before{content:"";display:block;width:30px;height:1px;background:var(--ink-3)}
.titlecard h1{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:46px;
  line-height:1.3;
  letter-spacing:.04em;
  color:var(--ink);
  margin-bottom:8px;
}
.titlecard .subtitle{
  font-family:var(--serif-ja);
  font-weight:500;
  font-size:18px;
  color:var(--ink-2);
  letter-spacing:.08em;
  margin-top:4px;
  margin-bottom:4px;
}
.titlecard .english{
  font-family:var(--serif-disp);
  font-weight:400;
  font-size:20px;
  color:var(--ink-3);
  letter-spacing:.02em;
  margin-top:2px;
}
.titlecard .page-lede{
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--ink-3);
  margin-top:14px;
  line-height:1.8;
  max-width:700px;
}

/* ========== ナビ ========== */
nav.primary{
  background:var(--paper);
  padding:16px 40px;
  border-bottom:1px solid var(--line);
  position:sticky;top:0;z-index:20;
  backdrop-filter:blur(8px);
}
nav.primary ul{
  list-style:none;
  display:flex;
  gap:40px;
  max-width:1300px;
  margin:0 auto;
  justify-content:center;
  flex-wrap:wrap;
}
nav.primary a{
  color:var(--ink);
  text-decoration:none;
  font-family:var(--serif-ja);
  font-weight:500;
  font-size:15px;
  letter-spacing:.12em;
  transition:.2s;
  position:relative;
  padding:4px 0;
}
nav.primary li.active a{color:var(--accent)}
nav.primary a:hover{color:var(--accent)}
nav.primary a::after{
  content:"";
  position:absolute;bottom:-4px;left:50%;
  width:0;height:1px;background:var(--accent);
  transition:.3s;
}
nav.primary a:hover::after,nav.primary li.active a::after{left:0;width:100%}

/* ========== 共通セクション ========== */
.section{max-width:1300px;margin:70px auto;padding:0 40px}
.sec-head{
  display:flex;
  align-items:baseline;
  gap:20px;
  margin-bottom:36px;
  padding-bottom:12px;
  border-bottom:1px solid var(--ink);
  flex-wrap:wrap;
}
.sec-head h3{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:26px;
  letter-spacing:.08em;
}
.sec-head .english{
  font-family:var(--serif-disp);
  font-weight:400;
  font-size:16px;
  color:var(--ink-3);
  letter-spacing:.02em;
}
.sec-head .see-all{
  margin-left:auto;
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-2);
  text-decoration:none;
  letter-spacing:.1em;
  padding-bottom:2px;
  border-bottom:1px solid var(--line);
  transition:.2s;
}
.sec-head .see-all:hover{color:var(--accent);border-color:var(--accent)}

/* ========== ヒーロー（トップ用） ========== */
.hero{padding:72px 40px 60px;max-width:1300px;margin:0 auto}
.hero-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:70px;align-items:center}
.hero-figure{position:relative}
.hero-figure img{width:100%;height:auto;display:block}
.hero-figure figcaption{
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-3);
  margin-top:14px;
  padding-left:14px;
  border-left:1px solid var(--line);
  max-width:460px;
  line-height:1.8;
}
.hero-text .hero-eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--ink-3);
  margin-bottom:20px;
}
.hero-text h2{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:26px;
  line-height:1.6;
  letter-spacing:.04em;
  margin-bottom:24px;
  color:var(--ink);
}
.hero-text p{
  font-size:15px;
  color:var(--ink-2);
  line-height:2;
}
.hero-text .sign{
  margin-top:28px;
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--ink-3);
  letter-spacing:.05em;
}
.hero-text .sign b{color:var(--ink);font-weight:500}

/* ========== ニュース（リスト） ========== */
.news-list{list-style:none}
.news-item{
  padding:18px 0;
  border-bottom:1px dashed var(--line);
  display:grid;
  grid-template-columns:110px 1fr;
  gap:20px;
  align-items:baseline;
  transition:.2s;
}
.news-item:hover{background:linear-gradient(90deg,transparent,var(--paper-2),transparent);padding-left:8px;padding-right:8px}
.news-item:last-child{border-bottom:none}
.news-date{
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--accent);
  letter-spacing:.05em;
  font-weight:500;
}
.news-body{font-size:14.5px;line-height:1.9;color:var(--ink-2)}
.news-body a{
  color:var(--ink);
  text-decoration:none;
  border-bottom:1px solid var(--line);
  padding-bottom:1px;
  transition:.2s;
}
.news-body a:hover{border-color:var(--accent);color:var(--accent)}

/* ========== 研究領域（トップ用プレビュー） ========== */
.research-preview{background:var(--paper-2);padding:70px 0;margin-top:70px}
.research-preview .inner{max-width:1300px;margin:0 auto;padding:0 40px}
.research-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:32px}
.research-card{background:var(--paper);padding:28px 26px;border:1px solid var(--line);transition:.3s}
.research-card:hover{transform:translateY(-3px);box-shadow:0 18px 36px -20px rgba(27,27,27,.15)}
.research-card .rnum{
  font-family:var(--serif-disp);
  font-size:16px;
  color:var(--ink-3);
  letter-spacing:.15em;
  margin-bottom:12px;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.research-card h6{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:18px;
  line-height:1.5;
  letter-spacing:.04em;
  margin-bottom:12px;
  color:var(--ink);
}
.research-card p{font-family:var(--serif-ja);font-size:13.5px;color:var(--ink-2);line-height:1.9}
.research-card .more{
  display:inline-block;
  margin-top:18px;
  font-family:var(--serif-ja);
  font-size:12px;
  color:var(--ink-2);
  text-decoration:none;
  letter-spacing:.1em;
  border-bottom:1px solid var(--line);
  padding-bottom:2px;
}
.research-card .more:hover{color:var(--accent);border-color:var(--accent)}

/* ========== 研究ページ：詳細 ========== */
.research-intro{
  max-width:1300px;
  margin:60px auto 40px;
  padding:0 40px;
  font-family:var(--serif-ja);
  font-size:15px;
  color:var(--ink-2);
  line-height:2;
}
.research-intro p{max-width:880px}

.research-domain{
  max-width:1300px;
  margin:60px auto;
  padding:0 40px;
}
.domain-head{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:24px;
  align-items:baseline;
  padding-bottom:16px;
  border-bottom:2px solid var(--ink);
  margin-bottom:32px;
}
.domain-head .dnum{
  font-family:var(--serif-disp);
  font-size:24px;
  color:var(--accent);
  letter-spacing:.1em;
  font-style:italic;
}
.domain-head h3{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:24px;
  letter-spacing:.06em;
  line-height:1.5;
}
.domain-lede{
  font-family:var(--serif-ja);
  font-size:15px;
  color:var(--ink-2);
  line-height:2;
  padding:20px 24px;
  background:var(--paper-2);
  border-left:3px solid var(--accent);
  margin-bottom:40px;
}

.theme-block{
  margin-bottom:50px;
  padding-bottom:50px;
  border-bottom:1px dashed var(--line);
}
.theme-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.theme-block h4{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:17px;
  color:var(--ink);
  letter-spacing:.04em;
  margin-bottom:16px;
  line-height:1.6;
  padding-left:14px;
  border-left:3px solid var(--accent);
}
.theme-block p{
  font-family:var(--serif-ja);
  font-size:14.5px;
  color:var(--ink-2);
  line-height:2;
  margin-bottom:14px;
}
.theme-block p a{
  color:var(--ink);
  border-bottom:1px solid var(--line);
  text-decoration:none;
  padding-bottom:1px;
}
.theme-block p a:hover{border-color:var(--accent);color:var(--accent)}
.theme-figure{margin:24px 0;text-align:center}
.theme-figure img{max-width:100%;height:auto;display:inline-block}
.theme-figure img + img{margin-top:14px}
.theme-figure figcaption{
  font-family:var(--serif-ja);
  font-size:12.5px;
  color:var(--ink-3);
  margin-top:12px;
  line-height:1.7;
}

/* ========== メンバーページ ========== */
.members-section{max-width:1300px;margin:60px auto;padding:0 40px}
.members-section p{
  font-family:var(--serif-ja);
  font-size:14.5px;
  color:var(--ink-2);
  line-height:2;
  margin-bottom:14px;
  max-width:880px;
}
.members-section p a{
  color:var(--ink);
  border-bottom:1px solid var(--line);
  text-decoration:none;
  padding-bottom:1px;
}
.members-section p a:hover{border-color:var(--accent);color:var(--accent)}

.callout{
  background:var(--paper-2);
  border-left:3px solid var(--accent);
  padding:20px 24px;
  margin:24px 0;
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--ink-2);
  line-height:2;
}
.callout b{color:var(--ink)}
.callout h5{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:15px;
  color:var(--ink);
  margin-bottom:10px;
  letter-spacing:.04em;
}

/* PI card */
.pi-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:32px 36px;
  margin:36px 0;
  display:grid;
  grid-template-columns:1fr auto;
  gap:30px;
  align-items:start;
}
.pi-card .role{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:12px;
}
.pi-card h3{
  font-family:var(--serif-ja);
  font-weight:700;
  font-size:28px;
  letter-spacing:.08em;
  margin-bottom:10px;
}
.pi-card .pi-meta{
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--ink-3);
  line-height:1.9;
  margin-bottom:16px;
}
.pi-card .pi-note{
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--ink-2);
  line-height:1.9;
}
.pi-links{
  text-align:right;
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-3);
  line-height:2;
}
.pi-links a{
  color:var(--ink-2);
  text-decoration:none;
  border-bottom:1px solid var(--line);
  padding-bottom:1px;
}
.pi-links a:hover{border-color:var(--accent);color:var(--accent)}

.member-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:32px;
}
.member-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:28px 28px;
}
.member-card.placeholder{
  background:transparent;
  border:1px dashed var(--line);
  min-height:180px;
}
.member-card .card-role{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:16px;
  padding-bottom:10px;
  border-bottom:1px solid var(--line);
}
.member-block{margin-bottom:22px}
.member-block:last-child{margin-bottom:0}
.member-block .degree{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:13px;
  color:var(--ink);
  letter-spacing:.1em;
  margin-bottom:4px;
}
.member-block .grade{
  font-family:var(--serif-disp);
  font-style:italic;
  font-size:14px;
  color:var(--ink-3);
  letter-spacing:.05em;
  margin-bottom:8px;
}
.member-block ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:6px 18px;
  font-family:var(--serif-ja);
  font-size:14.5px;
  color:var(--ink-2);
}
.member-block ul li{position:relative;padding-left:12px}
.member-block ul li::before{
  content:"・";
  position:absolute;
  left:-2px;
  color:var(--ink-4);
}
.member-block ul li a{color:var(--ink);border-bottom:1px solid var(--line);text-decoration:none;padding-bottom:1px}
.member-block ul li a:hover{border-color:var(--accent);color:var(--accent)}

/* ========== コンタクトページ ========== */
.info-section{max-width:1300px;margin:60px auto;padding:0 40px}

.map-wrap{
  margin:32px 0;
  padding:24px;
  background:var(--paper);
  border:1px solid var(--line);
}
.map-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:18px;
  flex-wrap:wrap;
  gap:10px;
}
.map-legend{
  display:flex;
  gap:20px;
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-2);
  align-items:center;
}
.map-legend .dot{
  display:inline-block;
  width:12px;height:12px;
  border-radius:50%;
  margin-right:8px;
  vertical-align:middle;
  border:2px solid #fff;
  box-shadow:0 0 0 1px rgba(0,0,0,.15);
}
.map-legend .dot-office{background:var(--pin-office)}
.map-legend .dot-lab{background:var(--pin-lab)}
.campus-map{
  width:100%;
  height:420px;
  border:1px solid var(--line);
}

.access-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:32px;
}
.access-card{
  background:var(--paper);
  border:1px solid var(--line);
  padding:28px 28px;
}
.access-card .role{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:10px;
}
.access-card h3{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:20px;
  letter-spacing:.06em;
  margin-bottom:14px;
}
.access-card .addr{
  font-family:var(--serif-ja);
  font-size:14px;
  color:var(--ink-2);
  line-height:1.9;
  margin-bottom:16px;
}
.access-card .addr a{color:var(--ink);border-bottom:1px solid var(--line);text-decoration:none;padding-bottom:1px}
.access-card .addr a:hover{border-color:var(--accent);color:var(--accent)}
.access-card .warn{
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-2);
  background:var(--paper-2);
  padding:12px 16px;
  border-left:2px solid var(--accent);
  margin-bottom:16px;
  line-height:1.8;
}
.access-card .btn{
  display:inline-block;
  padding:10px 20px;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--serif-ja);
  font-size:13px;
  text-decoration:none;
  letter-spacing:.1em;
  transition:.2s;
}
.access-card .btn:hover{background:var(--accent)}

.affiliation-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:24px}
.affiliation-card{
  background:var(--paper-2);
  border:1px solid var(--line);
  padding:22px 24px;
}
.affiliation-card .role{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:8px;
}
.affiliation-card p{font-family:var(--serif-ja);font-size:14px;color:var(--ink-2);line-height:1.8}
.affiliation-card p a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:1px;transition:.2s}
.affiliation-card p a:hover{color:var(--accent);border-color:var(--accent)}

.contact-box{
  background:var(--paper-2);
  border-left:3px solid var(--accent);
  padding:24px 28px;
  margin-top:24px;
}
.contact-box .mail{
  font-family:var(--sans);
  font-size:16px;
  color:var(--ink);
  font-weight:500;
  letter-spacing:.02em;
  margin-bottom:10px;
  word-break:break-all;
}
.contact-box .note{
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-3);
  line-height:1.8;
}

/* ========== ノートページ ========== */
.notes-intro{
  max-width:780px;
  margin:48px auto 0;
  padding:0 40px;
  font-family:var(--serif-ja);
  font-size:14.5px;
  color:var(--ink-3);
  line-height:2;
}

.notes-list{
  max-width:880px;
  margin:48px auto 0;
  padding:0 40px;
}
.note-entry{
  display:block;
  padding:28px 0;
  border-bottom:1px dashed var(--line);
  text-decoration:none;
  color:inherit;
  transition:.2s;
}
.note-entry:hover{padding-left:8px;padding-right:8px;background:linear-gradient(90deg,transparent,var(--paper-2),transparent)}
.note-entry:first-child{padding-top:0}
.note-entry:last-child{border-bottom:none}
.note-entry .entry-meta{
  display:flex;
  gap:16px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--ink-4);
  margin-bottom:10px;
}
.note-entry .entry-meta .date{color:var(--ink-3)}
.note-entry .entry-meta .cat{color:var(--accent);font-weight:500}
.note-entry h3{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:22px;
  line-height:1.55;
  letter-spacing:.04em;
  color:var(--ink);
  margin-bottom:10px;
  transition:.2s;
}
.note-entry:hover h3{color:var(--accent)}
.note-entry .excerpt{
  font-family:var(--serif-ja);
  font-size:14.5px;
  color:var(--ink-2);
  line-height:2;
}

/* ========== ノート記事本文 ========== */
.note-article{
  max-width:760px;
  margin:56px auto 0;
  padding:0 40px;
}
.note-article .back-link{
  display:inline-block;
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-3);
  text-decoration:none;
  letter-spacing:.05em;
  margin-bottom:32px;
}
.note-article .back-link:hover{color:var(--accent)}
.note-article .article-meta{
  display:flex;
  gap:18px;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--ink-4);
  margin-bottom:16px;
  padding-bottom:16px;
  border-bottom:1px solid var(--line);
}
.note-article .article-meta .date{color:var(--ink-3)}
.note-article .article-meta .cat{color:var(--accent);font-weight:500}
.note-article h1.article-title{
  font-family:var(--serif-ja);
  font-weight:700;
  font-size:32px;
  line-height:1.5;
  letter-spacing:.04em;
  color:var(--ink);
  margin-bottom:32px;
}
.note-article .article-body{
  font-family:var(--serif-ja);
  font-size:15.5px;
  color:var(--ink-2);
  line-height:2.1;
}
.note-article .article-body p{margin-bottom:24px}
.note-article .article-body p:last-child{margin-bottom:0}
.note-article .article-body a{
  color:var(--ink);
  border-bottom:1px solid var(--line);
  text-decoration:none;
  padding-bottom:1px;
}
.note-article .article-body a:hover{color:var(--accent);border-color:var(--accent)}
.note-article .article-footer{
  margin-top:56px;
  padding-top:24px;
  border-top:1px solid var(--line);
  font-family:var(--serif-ja);
  font-size:13px;
  color:var(--ink-3);
  line-height:1.9;
}

/* ========== フッタ ========== */
footer{
  border-top:2px solid var(--ink);
  margin-top:80px;
  padding:52px 40px 32px;
  background:var(--paper);
}
footer .inner{
  max-width:1300px;
  margin:0 auto;
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:50px;
}
footer .brand-foot{
  font-family:var(--serif-ja);
  font-weight:600;
  font-size:18px;
  color:var(--ink);
  margin-bottom:6px;
  letter-spacing:.08em;
}
footer .brand-foot-en{
  font-family:var(--serif-disp);
  font-size:15px;
  color:var(--ink-3);
  margin-bottom:14px;
  letter-spacing:.02em;
}
footer .foot-note{
  font-family:var(--serif-ja);
  font-size:12px;
  color:var(--ink-3);
  line-height:1.9;
  max-width:420px;
}
footer .foot-col h6{
  font-family:var(--serif-ja);
  font-size:13px;
  letter-spacing:.1em;
  color:var(--ink);
  margin-bottom:14px;
  font-weight:500;
}
footer .foot-col ul{list-style:none}
footer .foot-col li{margin-bottom:8px}
footer .foot-col a{
  color:var(--ink-3);
  text-decoration:none;
  font-size:13px;
  font-family:var(--serif-ja);
  transition:.2s;
}
footer .foot-col a:hover{color:var(--accent)}
footer .copyline{
  max-width:1300px;
  margin:36px auto 0;
  padding-top:18px;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  font-family:var(--sans);
  font-size:11px;
  color:var(--ink-4);
  letter-spacing:.1em;
  flex-wrap:wrap;
  gap:10px;
}

/* ========== レスポンシブ ========== */
@media(max-width:1000px){
  .hero-grid,.research-grid,.member-grid,.access-grid,.affiliation-grid,footer .inner{
    grid-template-columns:1fr;gap:32px;
  }
  .titlecard h1{font-size:32px}
  .titlecard .subtitle{font-size:16px}
  .titlecard .english{font-size:17px}
  nav.primary ul{gap:20px}
  .pi-card{grid-template-columns:1fr}
  .pi-links{text-align:left}
  .masthead,.section,nav.primary,.toprule,footer{padding-left:24px;padding-right:24px}
  .hero,.research-intro,.research-domain,.members-section,.info-section,.notes-intro,.notes-list,.note-article{padding-left:24px;padding-right:24px}
}
@media(max-width:600px){
  .titlecard h1{font-size:24px}
  .titlecard .subtitle{font-size:14px}
  .titlecard .english{font-size:15px}
  .hero-text h2{font-size:20px}
  .news-item{grid-template-columns:1fr;gap:4px}
  .domain-head{grid-template-columns:1fr;gap:8px}
  .note-article h1.article-title{font-size:24px}
  .note-entry h3{font-size:18px}
}
