.blue-text {color: #00a0e9 !important;}
.marker-yellow {background-color: #e5df1b; font-weight: bold;}
.purple-text {color: #b84ebe !important;}
.max-full_width {margin: 5% 0;}
.bullet-heart {color: #af62a3;}
.special-note {border: 3px dotted #bb6ebff2; border-radius: 15px; padding: 3% 0; margin: 2%; }
.special-note p{font-size: 1.3rem; }
.special-bullet {color: #af62a3; margin: 0 1% 0 0;}
.center-img {margin: 5% 20% !important; padding: 0%; text-align: center;}
.align-right {float: right;}
.purple-bg {background-color: #2196f352 !important;}
.highlighted-bg {background-color: #c9c9c94a; width:fit-content; padding: 2px;}
.back-to { border: 1px solid #00a0e9; background-color: #009fe91a; width:fit-content; padding: 1%; font-size: 12px; font-weight: 500; margin: 2% 0; letter-spacing: -1px;}
    .back-to:hover {text-decoration: none !important; background-color: #009fe935 !important;}
/*色*/
/*背景画像*/
/*メディアクエリ*/
/*width*/


/*------------------------------------------------------*/
.special-placeholder {margin: 10px 40px 15px; display: flex; flex-direction: row; padding: 3%; 
 border-radius: 15px; background-color:#f1d9e99e;}

.special-placeholder .left-side {width: 22%; margin: auto; background-image: radial-gradient(circle, #f9f1ee, #f9f1ee, #f0e4f0, #d4bfd5, #d4bfd500, #f0e4f0, #f0e4f0);  border-radius: 50%; padding: 2%;}
    .special-placeholder .left-side p {font-size: 2rem; text-align: center; text-shadow: 2px 2px  white; font-weight: 600; margin: 5%;}
    .special-placeholder .left-side p span {color: purple; text-shadow: 2px 2px  white; font-size: 2.2rem; letter-spacing: 1px;}

.special-placeholder .right-side {width: 73%; line-height: 2.5rem;}    
/*------------------------------------------------------*/
.special-placeholder-full {margin: 10px 40px 15px; padding: 1%; border-radius: 15px; background-color: #f1d9e947;}
.special-placeholder-full h3 {color: purple; font-weight: 600; margin: 1rem 30px 1.5rem; 
    font-size: 2rem; width:max-content; border-radius: 15px; padding: 1%;}
/*------------------------------------------------------*/
.gallery-4-img {padding: 3% 1%; display: flex; flex-direction: row; width: 90%; margin: 2% auto; background-color: #7f7c7c52;}
.gallery-4-img-col {width: 25%; margin: auto 0.5%;}
.gallery-4-img-col img {width: 100%;}
.gallery-4-img-col h3 {font-weight: 600; color: #000; padding: 2%; font-size: 1.8rem; text-align: center; margin: 5% auto;}
.gallery-4-img-col h3 span {font-size: 1.3rem;}
.gallery-4-img-col h4 {font-weight: 500;
    padding: 2%;
    background-color: #b84ec9;
    color: #ffffff;
    font-size: 1.3rem;
    text-align: center;
    width: 65%;
    margin: auto; border-radius: 15px;}
.instructions p {font-size: 1.5rem; text-align: right; font-weight: 500;}
/*------------------------------------------------------*/

/*------------------------------------------------------*/
.section-cont {
    display: block;
    border-width: 20px;
    border-style: solid;
    border-image-source: url(../img/tokushu48-background.jpg);
    border-image-slice: 30; /* Ajusta este número según el grosor */
    border-image-repeat: round; /* Puede ser 'stretch', 'repeat', o 'round' */
}

/*.section-cont {display: block; border-width: 20px;
    border-style: solid;
    border-image: linear-gradient(to bottom, #0084ff33, #124869) 1;}*/

.top-icon-tokushu{
display: flex;
margin-bottom: 0;
}

.mof-era-page {
  --mof-side-margin: 16px;
  --mof-side-stripe: 16px;
  position: relative;
  z-index: 0;
  overflow: visible;
  margin: 18px 16px 14px;
  padding: 0 14px;
}

.mof-era-page::before,
.mof-era-page::after {
  content: "";
  position: absolute;
  top: 0;
  width: var(--mof-side-stripe);
  height: 100%;
  pointer-events: none;
  z-index: -1;
  background: repeating-linear-gradient(
    180deg,
    #d3edfb 0,
    #d3edfb 3px,
    #ffffff 3px,
    #ffffff 6px
  );
}

.mof-era-page::before {
  left: calc(-1 * var(--mof-side-margin));
}

.mof-era-page::after {
  right: calc(-1 * var(--mof-side-margin));
}

.mof-era-page > section,
.mof-era-page > p {
  position: relative;
  z-index: 1;
}

.mof-era-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 14px;
  align-items: end;
}

.mof-era-main-title {
  color: #001f6f;
  font-size: 5rem;
  font-weight: 800;
  line-height: 1.28;
  margin-left: 10px !important;
}

.mof-era-main-lead {
  margin: 0 10px 0 !important;
  color: #001f6f;
  border: 1px solid #d8deef;
  border-left: 4px solid #217fc4;
  background: linear-gradient(180deg, #fcfdff 0%, #f7f9ff 100%);
  padding: 1.15em 1.15em;
  border-radius: 4px;
  box-shadow: 0 2px 6px rgba(174, 193, 241, 0.06);
  line-height: 2.1;
}

.mof-era-hero-copy {
  align-self: end;
}

.mof-era-guide-box {
  display: grid;
  grid-template-columns: 1fr 148px;
  grid-template-rows: auto auto;
  gap: 6px 0px;
  padding: 10px 10px 8px;
  text-align: left;
  margin: 0 !important;
}

.mof-era-guide-box p {
  margin: 0 !important;
}

.mof-era-guide-box p.mof-era-guide-kicker {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 78px;
  height: 78px;
  margin: 0 !important;
  padding: 2px;
  color: #8b640f;
  font-size: 1rem;
  font-weight: 550;
  line-height: 1.1;
  letter-spacing: 0.01em;
  text-align: center;
  background: #f5f1e4;
  border: 2px dotted #be8f2f;
  border-radius: 50%;
  box-shadow: none;
  white-space: normal;
}

.mof-era-guide-photo {
  grid-column: 2;
  grid-row: 1 / 3;
  margin: 0;
  align-self: end;
  text-align: right;
  transform: translateX(-24px);
  margin-bottom: 14px;
}

.mof-era-guide-photo img {
  width: 100%;
  max-width: 148px;
  height: auto;
  display: block;
}

.mof-era-guide-box .tokushu-subpage-profile {
  grid-column: 1;
  grid-row: 2;
  margin: 0;
  color: #000000;
  font-size: 1.05rem;
  font-weight: 700;
  line-height: 1.3;
}

.mof-era-guide-box .tokushu-subpage-profile .mof-era-guide-name {
  font-size: 1.25em;
  line-height: 1.1;
}

.mof-era-intro {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  grid-template-rows: min-content 1fr;
  gap: 0 16px;
  align-items: start;
  margin-top: 16px;
}

.mof-era-intro-title {
  grid-column: 2;
  grid-row: 1;
  margin: 30px 10px 2px !important;
  color: #001f6f;
  font-size: 2rem !important;
  line-height: 1.3;
  font-weight: 700;
}

.mof-era-intro-image {
  grid-column: 1;
  grid-row: 1 / span 2;
  align-self: center;
  margin: 0;
  padding-left: 20px;
}

.mof-era-intro-image img {
  width: 100%;
}

.mof-era-intro-text {
  grid-column: 2;
  grid-row: 2;
  margin-right: 10px !important;
  margin-left: 10px !important;
}

.mof-era-functions > h2 {
  margin: 10px 0 8px !important;
  color: #001f6f;
  font-size: 2rem;
  line-height: 1.3;
  font-weight: 700;
}

.mof-era-amazing > h2 {
  margin: 0 0 8px;
  color: #001f6f;
  font-size: 3.4rem;
  line-height: 1.3;
  font-weight: 700;
}

.contents .mof-era-amazing > h2 {
  position: relative;
  display: inline-block;
  margin: 0 0 12px 15px !important;
  padding: 0 0.8em; /* スラッシュ分の余白 */
  color: #217fc4 !important;
  font-size: 3.5rem !important;
  font-weight: 900 !important;
  letter-spacing: -0.08em;
  line-height: 1; /* ← ここ重要 */
}

/* 共通 */
.contents .mof-era-amazing > h2::before,
.contents .mof-era-amazing > h2::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto 0;     /* ← 縦中央を安定させる */
  width: 5px;
  height: 120%;        /* 高さは％の方が安定 */
  background: #217fc4;
}

/* 左 */
.contents .mof-era-amazing > h2::before {
  left: 0;
  transform: rotate(-22deg);
}

/* 右 */
.contents .mof-era-amazing > h2::after {
  right: 0;
  transform: rotate(22deg);
}

.mof-era-intro-text p {
  margin: 0;
  color: #000000;
  font-weight: 600;
  line-height: 1.9;
}

.mof-era-functions {
  margin-top: 18px;
}

.mof-era-function-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.mof-era-function-card {
  background: #ffffff;
  border-top: 7px solid #d3edfb;
  padding: 8px;
}

.mof-era-function-card h3 {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  align-self: flex-start;
  margin-left: 0;
  left: 0;
  text-align: left;
  width: fit-content;
  gap: 8px;
  margin: 0 0 8px;
  padding: 4px 12px 4px 8px;
  background: #eef6ff;
  border: 1px solid #a9cdee;
  border-left: 4px solid #217fc4;
  border-radius: 999px;
  color: #001f6f;
  font-size: 2.2rem;
  font-weight: 700;
}

.contents .mof-era-function-card h3 {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  align-self: flex-start !important;
  margin-left: 0 !important;
  left: 0 !important;
  text-align: left !important;
  width: fit-content !important;
  gap: 8px !important;
  margin: 0 0 8px !important;
  padding: 4px 12px 4px 8px !important;
  background: #eef6ff !important;
  border: 1px solid #a9cdee !important;
  border-left: 4px solid #217fc4 !important;
  border-radius: 999px !important;
  color: #001f6f !important;
  font-size: 2.2rem !important;
  font-weight: 700 !important;
}

.mof-era-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 27px;
  height: 27px;
  border-radius: 50%;
  background: #217fc4;
  color: #ffffff;
  font-size: 1.5rem;
}

.mof-era-function-card p {
  margin: 0 2px 10px !important;
  color: #000;
  line-height: 1.75;
}

.mof-era-function-card img {
  width: 100%;
}

.mof-era-amazing {
  margin-top: 0px;
}

.mof-era-amazing-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.mof-era-amazing-card,
.mof-era-design-card {
  border: 1px solid #217fc4;
  background: #ffffff;
  padding: 10px;
}

.mof-era-amazing-card p,
.mof-era-design-card p {
  margin: 0 0 8px;
  color: #000000;
  line-height: 1.8;
}

.contents .mof-era-amazing-card h2,
.contents .mof-era-design-card h2 {
  margin-top: 0.8rem !important;
  margin-left: 0rem !important;
}

.mof-era-amazing-card img,
.mof-era-design-card img {
  width: 100%;
}

.mof-era-design-card img {
  width: 72%;
  max-width: 420px;
  margin: 0 auto 8px;
  display: block;
}

.mof-era-design-card {
  margin-top: 12px;
}

.mof-era-design-note {
  margin-bottom: 0 !important;
  font-size: 1.3rem;
}

.mof-era-gas-alchemy,
.mof-era-mentor {
  margin-top: 0px;
}

.mof-era-gas-title {
  margin: 10px 0 8px !important;
  color: #001f6f;
  font-size: 2rem !important;
  font-weight: 700;
  line-height: 1.3;
}

.contents .mof-era-mentor .mof-era-mentor-title {
  position: relative;
  margin: 0 0 14px;
  padding: 0.56em 1.2em 0.62em;
  color: #7d5a11;
  font-size: 2rem;
  font-weight: 800;
  line-height: 1.5;
  letter-spacing: 0.01em;
  text-align: center;
  background: linear-gradient(180deg, #f8f4ea 0%, #f2ecdf 100%);
}
.contents .mof-era-mentor .mof-era-mentor-title .sp-br {
  display: none;
}

.contents .mof-era-mentor .mof-era-mentor-title::before,
.contents .mof-era-mentor .mof-era-mentor-title::after {
  content: "";
  position: absolute;
  top: 6px;
  bottom: 6px;
  width: 12px;
}

.contents .mof-era-mentor .mof-era-mentor-title::before {
  left: 6px;
  border-top: 2px solid #b78b2f;
  border-bottom: 2px solid #b78b2f;
  border-left: 2px solid #b78b2f;
}

.contents .mof-era-mentor .mof-era-mentor-title::after {
  right: 6px;
  border-top: 2px solid #b78b2f;
  border-bottom: 2px solid #b78b2f;
  border-right: 2px solid #b78b2f;
}

.mof-era-gas-alchemy > p {
  margin: 0 0px 12px !important;
  color: #000000;
  line-height: 1.9;
  font-weight: 600;
}

.mof-era-gas-main-image {
  margin: 0 0 10px;
  background: linear-gradient(180deg, #ffffff 0%, #d3edfb 100%);
  padding: 5px;
}

.mof-era-gas-main-image img {
  width: 100%;
  display: block;
}

.mof-era-gas-case-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.mof-era-gas-case {
  margin: 0;
  padding: 6px 8px;
  background: #ffffff;
}

.mof-era-gas-case figure {
  margin: 0 auto 4px;
  width: 190px;
  height: 190px;
  max-width: 100%;
  border-radius: 50%;
  background: #d3edfb;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mof-era-gas-case img {
  width: 84%;
  height: 84%;
  display: block;
  object-fit: contain;
}

.mof-era-gas-case p {
  margin-top: 10px !important;
  color: #000000;
  font-size: 1.45rem;
  line-height: 1.65;
  font-weight: 500;
}

.mof-era-mentor {
  padding: 12px;
}

.mof-era-mentor-intro {
  width: 185px;
  float: left;
  margin: 0 14px 2px 0;
}

.mof-era-mentor-portrait {
  margin: 0;
}

.mof-era-mentor-portrait img {
  width: 100%;
  display: block;
}

.mof-era-mentor-profile {
  margin: 8px 0 2px !important;
  color: #001f6f;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1;
  text-align: left;
}

.mof-era-mentor-profile .mof-era-mentor-name {
  display: inline-block;
  font-size: 1.2em;
  font-weight: 700;
  margin-bottom: 5px;
}

.mof-era-mentor-body p {
  margin: 0 0px 10px!important;
  color: #000000;
  line-height: 1.9;
  font-weight: 500;
}

.mof-era-mentor-body p:last-child {
  margin-bottom: 0;
}

.mof-era-mentor-body::after {
  content: "";
  display: table;
  clear: both;
}

.mof-era-mentor-photo {
  float: right;
  width: 42%;
  max-width: 280px;
  margin: 0 0 8px 14px;
}

.mof-era-mentor-photo img {
  width: 100%;
  display: inline-block;
  vertical-align: text-bottom;
}

.sp-only-caption { display: none; }
.pc-only-caption { display: inline; }

@media screen and (max-width: 900px) {
  .mof-era-page {
    --mof-side-margin: 10px;
    --mof-side-stripe: 16px;
    margin: 14px 10px 12px;
    padding: 0 10px;
  }

  .mof-era-hero-grid {
    grid-template-columns: minmax(0, 1fr) 220px;
    gap: 12px;
    align-items: end;
  }

  .mof-era-intro {
    grid-template-columns: 180px minmax(0, 1fr);
    gap: 10px;
  }

  .mof-era-function-grid,
  .mof-era-amazing-grid {
    grid-template-columns: 1fr;
  }

  .mof-era-intro-title {
    font-size: 2rem !important;
  }

  .mof-era-functions > h2 {
    font-size: 2rem;
    padding-left: 10px;
    padding-right: 10px;
  }

  .mof-era-gas-alchemy > p {
    padding-left: 10px;
    padding-right: 10px;
  }

  .mof-era-amazing > h2 {
    font-size: 2.7rem;
  }

  .contents .mof-era-amazing > h2 {
    padding: 0 0.8em;
    margin-left: 40px !important;
    font-size: 2.5rem !important;
  }

  .mof-era-main-title {
    font-size: 4.1rem;
    line-height: 1.32;
    margin: 0;
  }

  .mof-era-main-lead {
    margin: 0;
    font-size: 1.45rem;
    line-height: 1.8;
    padding: 0.9em 1.1em;
  }

  .mof-era-guide-box {
    grid-template-columns: 78px minmax(0, 1fr);
    gap: 6px 8px;
    padding: 8px 0 6px;
  }

  .mof-era-guide-photo {
    grid-column: 2;
    grid-row: 1 / 3;
    transform: none;
    margin-bottom: 0;
    align-self: end;
  }

  .mof-era-guide-photo img {
    max-width: 132px;
  }

  .mof-era-guide-box p.mof-era-guide-kicker {
    width: 70px;
    height: 70px;
    font-size: 0.95rem;
  }

  .mof-era-guide-box .tokushu-subpage-profile {
    font-size: 0.95rem;
  }

  .mof-era-intro-image {
    max-width: 230px;
    margin: 0 auto;
    padding-left: 0;
  }

  .contents .mof-era-mentor .mof-era-mentor-title {
    font-size: 1.8rem;
    line-height: 1.55;
    padding: 0.58em 0.9em 0.62em;
  }
  .contents .mof-era-mentor .mof-era-mentor-title .sp-br {
    display: inline;
  }

  .mof-era-gas-case-grid {
    grid-template-columns: 1fr;
  }

  .mof-era-mentor-intro {
    float: none;
    width: 100%;
    max-width: 200px;
    margin: 0 auto 10px;
  }

  .mof-era-gas-case {
    padding: 6px;
  }

  .mof-era-gas-case figure {
    width: 150px;
    height: 150px;
  }

  .mof-era-mentor-portrait {
    max-width: 200px;
  }

  .mof-era-mentor-photo {
    float: none;
    width: 100%;
    max-width: none;
    margin: 12px 0 0;
    order: 10;
  }

  .mof-era-mentor-body {
    display: flex;
    flex-direction: column;
  }

  .mof-era-mentor-body p {
    order: 0;
  }

  .sp-only-caption { display: block; margin-top: 5px; }
  .pc-only-caption { display: none; }

}

@media screen and (max-width: 560px) {
  .mof-era-page {
    margin: 8px 6px 6px;
    padding: 0 6px;
  }

  .mof-era-hero-grid {
    grid-template-columns: 1fr;
    gap: 10px;
    align-items: start;
  }

  .mof-era-hero-copy {
    width: 100%;
    text-align: left;
  }

  .mof-era-main-title {
    font-size: 3.8rem;
    line-height: 1.25;
  }

  .mof-era-main-lead {
    font-size: 1.3rem;
    line-height: 1.75;
    padding: 0.8em 1em;
    margin: 0;
  }

  .mof-era-intro {
    grid-template-columns: 1fr;
  }

  .mof-era-function-card img {
    width: 80%;
    display: block;
    margin: 0 auto;
  }

  .mof-era-gas-title {
    margin: 15px 10px 8px !important;
  }

  .mof-era-intro-title {
    grid-column: auto;
    grid-row: auto;
    margin: 10px 10px 8px !important;
    font-size: 2rem !important;
  }

  .mof-era-intro-image {
    grid-column: auto;
    grid-row: auto;
    max-width: 180px;
    margin: 0 auto;
    padding-left: 0;
  }

  .mof-era-intro-text {
    grid-column: auto;
    grid-row: auto;
  }

  .mof-era-guide-box {
    grid-template-columns: 70px minmax(0, 1fr);
    max-width: 360px;
    margin: 0 auto !important;
    justify-content: center;
    gap: 4px 8px;
    padding: 4px 0 0;
  }

  .mof-era-guide-box p.mof-era-guide-kicker {
    width: 62px;
    height: 62px;
    font-size: 0.9rem;
  }

  .mof-era-guide-photo {
    text-align: left;
  }

  .mof-era-guide-photo img {
    width: 108px;
    max-width: 100%;
  }

  .mof-era-guide-box .tokushu-subpage-profile {
    font-size: 0.9rem;
    line-height: 1.25;
  }
}

@media screen and (max-width: 400px) {
  .mof-era-main-title {
    font-size: 3.2rem;
    line-height: 1.2;
  }

  .mof-era-main-lead {
    font-size: 1.1rem;
    padding: 0.7em 0.8em;
  }

  .mof-era-guide-box {
    max-width: 95%;
  }

  .mof-era-guide-box p {
    margin: 0 !important;
  }

  .mof-era-guide-box p.mof-era-guide-kicker {
    width: 54px;
    height: 54px;
    font-size: 0.9rem;
  }

  .mof-era-guide-photo img {
    width: 92px;
  }
}

.nobel-week-stage-intro {
  margin: 16px 0 10px;
  padding: 10px 12px 0;
  background: #ffffff;
}
.nobel-week-stage-inner {
  display: grid;
  grid-template-columns: 58% 1fr;
  gap: 10px;
  align-items: center;
}
.nobel-week-stage-left {
  position: relative;
  padding: 10px 5px 12px;
  border-bottom: 0;
  border-radius: 180px 180px 0 0;
  background: #ffffff;
  text-align: center;
}
.nobel-week-stage-left::before {
  content: "✈";
  position: absolute;
  top: 2px;
  right: 18px;
  color: #a31647;
  font-size: 2.4rem;
  line-height: 1;
  transform: rotate(18deg);
}
.nobel-week-stage-lead {
  margin: 0 0 6px !important;
  color: #001f6f;
  font-size: 2rem !important;
  font-weight: 700;
  line-height: 1.35;
}
.nobel-week-stage-left h2 {
  margin: 0 !important;
  color: #001f6f;
  font-size: 5rem !important;
  font-weight: 800;
  line-height: 1.22;
  letter-spacing: 0.02em;
}
.nobel-week-stage-stamp {
  position: absolute;
  right: -14px;
  bottom: -10px;
  margin: 0 !important;
  width: 74px;
  height: 74px;
  border-radius: 50%;
  border: 2px solid #cdbf93;
  background: #f6efd9;
  color: #000000;
  font-size: 1.2rem !important;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.nobel-week-stage-right {
  padding: 0 8px 6px 8px;
}
.nobel-week-stage-right p {
  margin: 0 0 6px !important;
  color: #000000;
  font-size: 2.2rem !important;
  line-height: 1.85;
  font-weight: 700;
}
.nobel-week-stage-right p:last-child {
  margin-bottom: 0 !important;
}

.top-icon-tokushu img{
     width:30%;
  object-fit: cover; 
  margin-left:0;  
}

.section-cont h3 {font-size: 1.5rem; color: #206DB0;}

@media screen and (max-width: 700px) {
  .nobel-week-stage-intro {
    padding: 8px 6px 0;
  }
  .nobel-week-stage-inner {
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .nobel-week-stage-left {
    padding: 14px 14px 12px;
    border-radius: 160px 160px 0 0;
  }
  .nobel-week-stage-left::before {
    right: 10px;
    font-size: 1.9rem;
  }
  .nobel-week-stage-lead {
    font-size: 1.5rem !important;
  }
  .nobel-week-stage-left h2 {
    font-size: 3.1rem !important;
  }
  .nobel-week-stage-stamp {
    right: 4px;
    bottom: -8px;
    width: 62px;
    height: 62px;
    font-size: 1.1rem !important;
  }
  .nobel-week-stage-right {
    padding: 4px 6px 6px;
  }
  .nobel-week-stage-right p {
    font-size: 1.7rem !important;
    line-height: 1.7;
  }
}

.section-cont .icon-title {width: 90%; display: flex; flex-direction: row; margin: 2% 5%;}

    .section-cont .icon-title .main-icon {width: 15%; margin: auto;}
    .section-cont .icon-title .main-icon img {margin: auto;}
    .section-cont .icon-title .main-icon .tag-name {font-weight: 600;
                padding: 2% 0%;
                color: #ffffff; background-color: #00a0e9;
                font-size: 1.3rem;
                text-align: center;
                width: 100%;
                margin: auto; border-radius: 15px;}
        .main-icon-title{
             display: flex; /* 讓ｪ荳ｦ縺ｳ縺ｫ縺吶ｋ */
          align-items: center; /* 邵ｦ縺ｮ荳ｭ螟ｮ謠�∴ */
        }

        .section-cont .icon-title .main-icon-title {width: 100%;}
        .section-cont .icon-title .main-icon-title p {font-size: 24px; font-weight: bold; color:#206DB0; margin-left:5%;
        text-align:right;}

        .section-cont .content-box {width: 96%; margin: 2%;}

        .section-cont .content-box .sensei-img {width: 96%; padding: 2%;}
        .section-cont .content-box .sensei-img img {width: 70%; margin:0 15%;margin-top:1em;}
        .section-cont .content-box .sensei-img .k-word {background-color: #bb6ebf; padding: 0.5% 1%; margin: 0.5% 1%; color: #ffffff; border-radius: 15px;}

    /* HTML: <div class="ribbon">Your text content</div> */
    .section-cont .content-box .content-box-top .ribbon {
    font-size: 28px;
    font-weight: bold;
    color: #df1414;
  }
 /* HTML: <div class="ribbon">Your text content</div> */
/* HTML: <div class="ribbon">Your text content</div> */
/* HTML: <div class="ribbon">Your text content</div> */
.section-cont .content-box .content-box-top  .ribbon {
    font-size: 1rem;
    font-weight: bold;
    color: #ffffff;
  }
  .section-cont .content-box .content-box-top  .ribbon {
    --r: .8em;
    border-inline: .5em solid #0000;
    padding: .5em .2em calc(var(--r) + .5em);
    clip-path: polygon(0 0, 100% 0, 100% 100%, calc(100% - .5em) 100%, 50% calc(100% - var(--r)), .5em 100%, 0 100%);
    background: radial-gradient(50% .2em at top, #000a, #0000) border-box, #b84ec9 padding-box; right: 35%;
    width: 8%;
    position: absolute;
  }
  .section-cont .content-box .content-box-top  .ribbon p {margin: 2%; font-size: 1rem; text-align: center;}
  .section-cont .content-box .content-box-top  .ribbon .p-bg {background-color: white; border-radius: 15px; color: #000; padding: 1%;}
  .section-cont .content-box .content-box-top  .ribbon .p-bg a {color: #000 !important;}
  .section-cont .content-box .content-box-top  .ribbon .p-bg a:hover {color: #22ba29 !important; text-decoration: underline;}

    .content-box .sensei-img h3 {Font-size: 2rem; text-align: center; font-weight: 600; color: #000; letter-spacing: 0; margin: 10px 30px 0.5rem; }
    .content-box .sensei-img h3 span {font-size: 1.3rem;}
    .content-box .sensei-img p {font-size: 1.2rem; font-weight: 600; text-align: center;}
/*------------------------------------------------------*/

@media screen and (max-width: 600px) {
    .special-note img {margin: 0 1px 1.5rem;}
    .special-placeholder-full {margin: 10px 20px 15px;}
    .special-placeholder {flex-direction: column; margin: 10px 20px 15px;}
    .special-placeholder .left-side  {width: 50%;}
    .special-placeholder .right-side {width: 100%;}

    .gallery-4-img {flex-direction: column;}
    .gallery-4-img-col {width:fit-content; margin: 3% auto ;}
    .gallery-4-img-col h3 {margin: 1% auto;; padding: 1% 0;}
    .gallery-4-img-col h4 {margin: auto; padding: 1% 0; width: 35%;}
    .instructions p {font-size: 1.35rem;}

    .section-cont {border-width: 8px;}
    .section-cont .icon-title  {flex-direction: column; width: 96%; margin: 2%;}
    .section-cont .icon-title .main-icon {width: 35%;}
    .section-cont .icon-title .main-icon-title {width: 100%; border-radius: 0;}
   
    .content-box .sensei-img p {font-size: 1.2rem; font-weight: 500;}
    .section-cont .content-box .sensei-img img {width: 100%; margin: 0;}
    .section-cont .icon-title .main-icon-title p{font-size: 1.5rem; font-weight:bold;}
    .content-box .sensei-img h3 span {font-size: 1.1rem;}

    .section-cont .content-box .content-box-top .ribbon {width: 18%; right: 2%;}
    .section-cont .content-box .content-box-top .ribbon .p-bg {margin: 2% 0;}

}
@media only screen and (min-width: 768px ) and (max-device-width: 1023px) {
    .special-note img {margin: 0 30px 1.5rem;}
    .special-placeholder {flex-direction: column; margin: 10px 40px 15px;}
    .special-placeholder .left-side  {width: 30%;}
    .special-placeholder .right-side {width: 100%;}

    .gallery-4-img-col h3 {font-size: 1.6rem;}

    .section-cont .icon-title .main-icon {width: 20%;}
    .section-cont .icon-title .main-icon-title {width: 80%;}
    .section-cont .icon-title .main-icon-title p {font-size: 1.75rem;}

    .section-cont .content-box .content-box-top  .ribbon {width: 10%;}
}

.wrapperprof-fondo-tokushu{
  margin: 1em;
  padding: 1em;
  color: #003355;
  padding: 6px 10px;
  border-radius: 5px;
  font-weight: bold;
  background: linear-gradient(135deg, #d9f1ff, #b2d8ff);
  border-radius: 8px;
}

.texto-container {
    box-sizing: border-box !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px; 
    background: linear-gradient(120deg, #83a4c5 10%, #0061b0 100%);
}

.sp-title {
    width: 85%;
    text-align: left;
    color: #fff;
    margin: auto;
    margin-bottom: 1.5em;
    margin-top:1.5em;
}


.top-bg{
        width:100%;
            background-image: url('../img/tokushu48-background.jpg');
            background-repeat: repeat; 
            background-size: cover;  
}

.icon-container {
            display: flex;
            align-items: center;
            gap: 10px;
        }
        .icon-container img {
            width:20%;
            border-radius: 50%;
            margin-bottom:-1.5em;
        }

.asean-highlight-box {
    background: rgb(247, 226, 214);
    padding: 1em;
    position: relative;
    z-index: 3;  
    text-align: center;  
}

.asean-icon-circle {
    position: absolute;
    bottom: 80%; 
    left: -3%;  
    z-index: 2;   
}

.asean-icon-circle img {
    width: 45%;
    border-radius: 50%;
}

table {
    z-index: 1;  /* 最背面 */
}

.cp_timeline01{
  margin-bottom: 11rem!important;
}

table span[style*="font-weight: 600"] {
    font-size: 13px; 
    font-weight: bold !important;
}
/*contenido columnas circunferencias*/
/* Contenedor general */
.cont-xy7 {
    max-width: 900px; /* Ajusta según tu gusto */
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 30px; /* Espacio entre filas */
    padding: 10px;
}

/* Título dentro de txtbox */
.txtbox-xy7 h2 {
    font-size: 2.2rem !important; /* Reducir tamaño del título */
    color: #000000; /* Color del título */
    font-weight: bold !important;
    margin-bottom: 10px;
}

/* Fila con los elementos */
.fila-xy7 {
    display: flex;
    align-items: center;
    justify-content: center; /* Centra horizontalmente las columnas */
    gap: 70px; /* Reducir espacio entre columna izquierda y derecha */
}

/* Circunferencia con imagen de fondo (más pequeño) */
.circ-xy7 {
    width: 250px;  /* Reducir tamaño */
    height: 250px; /* Reducir tamaño */
    border-radius: 50%; /* Asegura que sea redonda */
    overflow: hidden; /* Recorta cualquier parte de la imagen que sobresalga */
    flex-shrink: 0;
    background-size: cover;  /* Asegura que la imagen cubra toda la circunferencia */
    background-position: center; /* Centra la imagen */
    border: 12px solid white;  /* Borde blanco de 12px */
}

/* Circunferencia con imágenes específicas */
.fila-xy7 .circ-xy7:nth-child(1) {
    background-image: url('img/tokushu48-photo10.png'); /* Foto 1 */
}

.fila-xy7 .circ-xy7:nth-child(2) {
    background-image: url('img/tokushu48-photo9.jpg'); /* Foto 2 */
}

.fila-xy7 .circ-xy7:nth-child(3) {
    background-image: url('img/tokushu48-photo4.JPG'); /* Foto 3 */
}

/* Imagen dentro de la circunferencia */
.circ-xy7 img {
    width: 100%;
    height: 100%;
    object-fit: cover;  /* Asegura que la imagen se recorte y cubra bien el círculo */
    border-radius: 50%; /* Hace que la imagen dentro del contenedor también sea redonda */
}

/* Texto con fondo para mejorar la legibilidad */
.txtbox-xy7 {
    width: 350px; /* Reducir tamaño */
    color: #000000;
    font-size: 15px !important; /* Reducir tamaño del texto */
    text-align: justify;
    margin-right: -5%;
    background-color: #c0e1ffd6; /* Fondo oscuro semi-transparente */
    padding: 15px; /* Reducir padding */
    border-radius: 10px; /* Bordes redondeados */
}

/* Cuadro de diálogo */
.dlgbox-xy7 {
    width: 300px; /* Igual que la circunferencia */
    color: #ffffff;
    font-size: 16px;
}

/* Cuadro gris */
.cuad-xy7 {
    width: 180px;
    height: 180px;
    background-color: #a94461;
    flex-shrink: 0;
}

/* Nueva fila con 3 columnas separadas */
.fila-xy7-final {
    display: flex;
    justify-content: center;
    gap: 40px; /* Espacio entre columnas */
}

/* Responsive */
@media (max-width: 768px) {
    .fila-xy7 {
        flex-direction: column;
        gap: 20px;
    }
    .txtbox-xy7 h2 {
        font-size: 1.3em;
    }

    /* Fila separada con 3 columnas */
    .fila-xy7-final {
        flex-direction: column;
        gap: 20px;
    }
}



/* Contenedor general */
.cont-xy8 {
    max-width: 900px; /* Ajusta según tu gusto */
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 30px; /* Espacio entre filas */
    padding: 10px;
}

/* Título dentro de txtbox */
.txtbox-xy8 h2 {
    font-size: 1.5em;
    color: #000000; /* Color del título en negro */
    font-weight: bold;
    margin-bottom: 10px;
}

/* Fila con los elementos */
.fila-xy8 {
    display: flex;
    align-items: center;
    justify-content: center; /* Centra horizontalmente las columnas */
    gap: 40px; /* Espacio entre columna izquierda y derecha */
}

/* Circunferencia */
.circ-xy8 {
    width: 180px;
    height: 180px;
    border-radius: 50%;
    background-color: #a94461;
    color: white;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 10px;
    flex-shrink: 0;
}

.circ-xy8 {
    width: 300px;
    height: 300px;
    border-radius: 50%;
    background-color: #4493a9;
    color: white;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    padding: 10px;
    flex-shrink: 0;
}

/* Texto */
.txtbox-xy8 {
    width: 300px; /* Igual que la circunferencia para que se alineen */
    color: #000000; /* Cambiar color del texto a negro */
    font-size: 16px;
    text-align: justify;
    background-color: #c0e1ffd6; /* Fondo azul claro */
    padding: 30px;
    border-radius: 10px; /* Bordes redondeados */
}

/* Cuadro de diálogo */
.dlgbox-xy8 {
    width: 300px; /* Igual que la circunferencia */
    color: #ffffff;
    font-size: 16px;
}

/* Cuadro gris */
.cuad-xy8 {
    width: 180px;
    height: 180px;
    background-color: #a94461;
    flex-shrink: 0;
}

/* Nueva fila con 3 columnas separadas */
.fila-xy8-final {
    display: flex;
    justify-content: center;
    gap: 40px; /* Espacio entre columnas */
}

/* Responsive */
@media (max-width: 768px) {
    .fila-xy8 {
        flex-direction: column;
        gap: 20px;
    }
    .txtbox-xy8 h2 {
        font-size: 1.3em;
    }

    /* Fila separada con 3 columnas */
    .fila-xy8-final {
        flex-direction: column;
        gap: 20px;
    }
}




/* parte incial texto principal*/

/* Banner con bordes redondeados desiguales y sombra */
.contenedor-banner-nuevo {
  background: linear-gradient(135deg, #d9f1ff, #b2d8ff); /* Azul suave */
  color: #003355;
  padding: 30px;
  border-radius: 40px 20px 40px 20px; /* Bordes desiguales: superior izquierdo y derecho inferior más redondeados */
  box-shadow: 0 8px 12px rgba(0, 0, 0, 0.1); /* Sombra sutil */
  text-align: left; /* Centrado de los textos */
  width: 85%; /* Aseguramos que no ocupe todo el ancho */
  margin: 0 auto; /* Centrado horizontal */
  max-width: 800px; /* Limitar el tamaño máximo */
  margin-bottom: 5%;
}

/* Título principal */
.contenedor-banner-nuevo .titulo-banner-nuevo {
  font-size: 2.5rem;
  margin-bottom: 5px; /* Reduzco el margen inferior */
  margin-left: 0;
  font-weight: bold;
}

/* Subtítulo con un toque más sutil */
.contenedor-banner-nuevo .subtitulo-banner-nuevo {
  font-size: 1.8rem;
  font-weight: 400;
  display: inline-block;
  position: relative;
  background: linear-gradient(to top, rgba(255, 255, 150, 0.7) 50%, transparent 50%);
  margin-top: 0;
  margin-left: 0;
}

/* Párrafo descriptivo */
.contenedor-banner-nuevo .texto-banner-nuevo {
  font-size: 1.5rem;
  line-height: 1.6;
  max-width: 650px;
  margin: 0 auto;
  margin-left: 0;
  color: #003355; /* Gris claro para el texto */
  margin-top: 0; /* Aseguro que no haya margen superior innecesario */
}

/* ==================== */
/* Adaptación a móviles */
/* ==================== */
@media screen and (max-width: 600px) {
  .contenedor-banner-nuevo {
    padding: 20px;
    width: 80%; /* Aseguramos que ocupe un poco más de espacio en pantallas pequeñas */
  }

  .contenedor-banner-nuevo .titulo-banner-nuevo {
    font-size: 2rem;
    margin-bottom: 3px; /* Ajusto el margen inferior */
  }

  .contenedor-banner-nuevo .subtitulo-banner-nuevo {
    font-size: 1.4rem;
    margin-bottom: 8px; /* Ajusto el margen inferior */
    display: inline-block;
    position: relative;
    background: linear-gradient(to top, rgba(255, 255, 150, 0.7) 50%, transparent 50%);
  }

  .contenedor-banner-nuevo .texto-banner-nuevo {
    font-size: 1rem;
    margin-top: 0; /* Aseguro que no haya margen superior innecesario */
  }
}

/* Flex container para texto + imagen */
.contenido-banner-flex {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

/* Contenedor de texto */
.texto-banner {
  flex: 1;
}

/* Imagen a la derecha del segundo banner */
.contenido-banner-flex img.imagen-banner {
  max-width: 30% !important; /* Reducido para que no quede tan grande */
  height: auto;
  border-radius: 10px;
}

/* Contenedor imágenes múltiples (tercer banner) */
.imagenes-multiples {
  display: flex;
  flex-direction: column;
  gap: 25px; /* Más espacio entre imágenes */
  max-width: 45%; /* Más ancho para imágenes más grandes */
  align-items: center;
}

/* Cada imagen dentro del contenedor múltiple */
.imagenes-multiples .imagen-banner-multi {
  width: 70%;
  height: auto;
  border-radius: 10px;
}

/* Responsive: en móviles la imagen pasa abajo */
@media screen and (max-width: 600px) {
  .contenido-banner-flex {
    flex-direction: column;
    align-items: center;
  }

  /* Imagen del segundo banner en móvil */
  .contenido-banner-flex img.imagen-banner {
    max-width: 50% !important;
    margin-top: 15px;
  }

  .texto-banner {
    width: 100%;
  }

  /* Contenedor imágenes múltiples en móvil */
  .imagenes-multiples {
    max-width: 100%;
    flex-direction: row;
    gap: 15px; /* Un poco más de espacio entre imágenes en móvil */
    margin-top: 15px;
  }

  .imagenes-multiples .imagen-banner-multi {
    width: 48%; /* Dos imágenes lado a lado en móvil */
  }
}

/* Contenedor de columnas */
.contenido-banner-flex-nuevo {
  display: flex;
  flex-direction: row;
  gap: 40px;
  align-items: flex-start;
}

/* Cada bloque */
.bloque-q {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.subtitulo-banner-nuevo {
    font-size: 1.4rem;
    margin-bottom: 8px; /* Ajusto el margen inferior */
    display: inline-block;
    position: relative;
    background: linear-gradient(to top, rgba(255, 255, 150, 0.7) 50%, transparent 50%);
  }
/* Sección de texto */
.texto-q {
  flex-direction: column;
  justify-content: flex-start;
}

/* Párrafo */
.parrafo-q {
  font-size: 15px!important;
  line-height: 1.6;
  margin: 0 !important;
}

/* Imagen: contenedor */
.imagen-q-wrap {
  display: flex;
  justify-content: center;
}

/* Imagen: tamaño */
.imagen-q {
  width: 70%;
  height: auto;
  border-radius: 10px;
  max-width: 100%;
}

/* Responsive: móviles */
@media screen and (max-width: 600px) {
  .contenido-banner-flex-nuevo {
    flex-direction: column;
  }

  .bloque-q {
    width: 100%;
  }

  .imagen-q-wrap {
    justify-content: center;
  }

  .imagen-q {
    width: 70%;
    max-width: 320px;
  }
}
.div_banner_postit_unico874 {
  background-color: #1f2d39;
  padding: 25px 30px;
  border: 5px solid #d5e5ed;
  border-radius: 8px;
  box-shadow: 6px 6px 12px rgba(0, 0, 0, 0.15);
  width: 85%;
  max-width: 800px;
  margin: 40px auto;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  position: relative;
}

/* Título */
.div_banner_postit_unico874 .titulo-postit {
  font-size: 25px;
  margin: 0 0 10px;
  color: #ffffff;
  font-weight: bold;
}

/* Subtítulo */
.div_banner_postit_unico874 .subtitulo-postit {
  font-size: 18px;
  margin: 0 0 15px;
  color: #ffffff;
  font-weight: 500;
}

/* Párrafo */
.div_banner_postit_unico874 .texto-postit {
  font-size: 15px;
  line-height: 1.6;
  color: #ffffff;
  margin: 0 0 15px;
}

/* Responsive */
@media screen and (max-width: 600px) {
  .div_banner_postit_unico874 {
    padding: 20px;
  }

  .div_banner_postit_unico874 .titulo-postit {
    font-size: 1.6rem;
  }

  .div_banner_postit_unico874 .subtitulo-postit {
    font-size: 1.2rem;
  }

  .div_banner_postit_unico874 .texto-postit {
    font-size: 1rem;
  }
}


/* Banner base: forma de bocadillo */
.bocadilloSuperX298 {
  background-color: #e0f4ff;
  border-radius: 20px;
  padding: 30px;
  width: 80%;
  max-width: 700px;
  margin: 60px auto 80px;
  position: relative;
  box-shadow: 4px 6px 12px rgba(0, 0, 0, 0.15);

}

/* Título dentro del bocadillo */
.bocadilloTituloZeta {
  font-size: 25px !important;
  color: #003b5c;
  font-weight: bold;
  margin-bottom: 10px;
  text-align: center;
}

/* Texto del bocadillo */
.bocadilloTextoZeta {
  font-size: 15px !important;
  line-height: 1.6;
  color: #004d6e;
}

/* Punta estilo triángulo — izquierda */
.puntaBocadilloIzqLuna {
  position: absolute;
  bottom: -20px;
  left: 30px;
  width: 0;
  height: 0;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent;
  border-top: 20px solid #e0f4ff;
}

/* Punta estilo triángulo — derecha */
.puntaBocadilloDerSol {
  position: absolute;
  bottom: -20px;
  right: 30px;
  width: 0;
  height: 0;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent;
  border-top: 20px solid #e0f4ff;
}

/* Opcional: animación de entrada 
.bocadilloSuperX298 {
  animation: suaveAparicionZeta 0.8s ease-out;
}

@keyframes suaveAparicionZeta {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}*/

/* Responsive */
@media screen and (max-width: 600px) {
  .bocadilloSuperX298 {
    padding: 20px;
  }

  .bocadilloTituloZeta {
    font-size: 2.5rem !important;
  }

  .bocadilloTextoZeta {
    font-size: 1.3rem !important;
  }

  .puntaBocadilloIzqLuna,
  .puntaBocadilloDerSol {
    bottom: -18px;
  }
}



/* Contenedor de las imágenes circulares */
.contenedorOrbito999 {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 30px;
  margin: 60px auto;
  max-width: 1000px;
  padding: 10px;
}

/* Estilo para las imágenes redondas */
.circuloZafiro47 {
  width: 200px;
  height: 200px;
  border-radius: 50%;
  object-fit: cover;
  box-shadow: 0 8px 20px rgb(255 255 255);
  transition: transform 0.3s ease;
}

/* Efecto al pasar el mouse */
.circuloZafiro47:hover {
  transform: scale(1.05);
}

/* Responsive para móviles */
@media screen and (max-width: 600px) {
  .contenedorOrbito999 {
    flex-direction: column;
    gap: 20px;
  }

  .circuloZafiro47 {
    width: 150px;
    height: 150px;
  }
}




/* Contenedor principal forzado a flex horizontal */
.envoltorioCuantico42 {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding-top: 20px;
  margin: 0 auto !important;
  max-width: 1000px;
  flex-wrap: nowrap !important;
  gap: 100px; /* espacio entre ícono y texto */
}

/* Imagen más grande, alineada */
.contenedorIconoIzquierda88 {
  flex: 0 0 auto;
  text-align: center;
}

.iconoEsferaAtomica88 {
  width: 250px !important;
  height: auto;
  display: block;
}

/* Texto a la derecha */
.contenedorTextoDerecho99 {
  flex: 1;
  padding: 0 !important;
  text-align: center !important;
  display: flex;
  align-items: center;
}

/* Título con márgenes anulados */
.tituloCuanticoBrillante22 {
  color: #ffffff !important;
  font-size: 40px !important;
  margin: 0 !important;
  padding: 0 !important;
  line-height: 1.4;
}

/* Responsive */
@media screen and (max-width: 600px) {
  .envoltorioCuantico42 {
    flex-direction: column !important;
    gap: 10px;
    text-align: center !important;
  }

  .iconoEsferaAtomica88 {
    width: 180px !important;
  }

  .tituloCuanticoBrillante22 {
    font-size: 28px !important;
    text-align: center !important;
  }

  .contenedorTextoDerecho99 {
    justify-content: center;
  }
}

/* Contenedor principal */
.glxq-wrapper {
  max-width: 1200px;
  margin: 0 auto;
  font-family: 'Segoe UI', sans-serif;
  padding: 20px;
}

/* Título con fondo azul */
.glxq-titulo {
  background: linear-gradient(135deg, #d9f1ff, #b2d8ff);
  color: white !important;
  padding: 16px;
  text-align: center;
  border-radius: 8px 8px 0 0;
  margin-bottom: 20px;
}

.glxq-titulo h2 {
  font-size: 1.8em !important;
  margin: 0 !important;
  font-weight: 600 !important;
  letter-spacing: 1px;
}

/* Contenedor de columnas */
.glxq-tabla {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
}

/* Cada columna */
.glxq-columna {
  flex: 1 1 calc(25% - 20px);
  background-color: #f9f9f9;
  border-radius: 8px;
  padding: 16px;
  box-shadow: 0 0 10px rgba(0,0,0,0.05);
  min-width: 250px;
  transition: transform 0.3s ease;
}

.glxq-columna:hover {
  transform: translateY(-5px);
}

/* Estilo para h3 dentro de columnas */
.glxq-columna h3 {
  font-size: 1.2em !important;
  margin: 4px 0 !important;
  color: #1f1f1f !important;
  font-weight: 600;
  border-left: 4px solid #1f5fbf;
  padding-left: 8px;
}

/* Estilo para párrafos */
.glxq-columna p {
  font-size: 0.95em !important;
  color: #444;
  line-height: 1.6;
  margin: 0 !important;
}

/* Responsive para móviles */
@media (max-width: 768px) {
  .glxq-columna {
    flex: 1 1 100%;
  }

  .glxq-titulo h2 {
    font-size: 1.5em !important;
  }
}




/* Usa tu estilo existente para el contenedor y el icono */
.top-icon-tokushu {
  display: flex;
  align-items: center;
  margin-bottom: 0;
}

.top-icon-tokushu img {
  width: 30%;
  object-fit: cover;
  margin-left: 0;
}

/* Nuevo contenedor del texto */
.glow-wrap-texto {
  width: 70%;
  padding-left: 20px;
}

.glow-titulo-texto p {
  font-size: 23px !important;
  font-weight: 600;
  color: #206DB0;
  margin-left: 15px !important;
  line-height: 1.6;
  text-align: right;
}

/* Responsive: en móvil, icono arriba y texto abajo */
@media (max-width: 768px) {
  .top-icon-tokushu {
    flex-direction: column;
    align-items: flex-start;
  }

  .glow-wrap-texto {
    width: 100%;
    padding-left: 0;
    margin-top: 15px;
  }

  .glow-titulo-texto p {
    font-size: 17px !important;
    text-align: right;
  }
}

/* Estilos base del banner QR */
.banner-qr {
  background-color: #f5f5f5;
  border: 2px solid #ccc;
  padding: 20px;
  text-align: center;
  width: 70%;
  max-width: 600px;
  margin: 40px auto;
  margin-top: 5px;
  font-family: Arial, sans-serif;
  border-radius: 8px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}

/* Fila superior con título y texto */
.qr-fila-superior {
  margin-bottom: 15px;
}

.qr-titulo {
  font-size: 24px;
  margin: 0 0 10px 0;
  color: #333;
}

.qr-texto {
  font-size: 16px;
  color: #666;
}

/* Fila inferior con enlace */
.qr-fila-inferior {
  text-align: center;
}

.qr-enlace {
  color: #62aeff;
  text-decoration: none;
  font-weight: bold;
}

.qr-enlace:hover {
  text-decoration: underline;
}

/* 🎯 Estilos responsive para pantallas pequeñas */
@media (max-width: 480px) {
  .banner-qr {
    padding: 15px;
  }

  .qr-titulo {
    font-size: 20px;
    text-align: center;
  }

  .qr-texto {
    font-size: 14px;
    text-align: center;
  }

  .qr-fila-inferior {
    text-align: center;
    margin-top: 10px;
  }
}




/* Contenedor del banner pie de página */
.banner-piedepagina {
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 12px 16px;
  background: transparent;
}

.banner-inner {
  width: 100%;
  max-width: 980px;
  background: transparent;
}

.caption {
  font-size: 16px;
  line-height: 1.6;
  color: #111;
  text-align: left;
  word-break: break-word;
  letter-spacing: 0.02em;
}

@media (max-width: 520px) {
  .caption { font-size: 14px; line-height: 1.5; }
  .banner-piedepagina { padding: 10px; }
  .banner-inner { padding: 8px; }
}

/* Dummy image support (top & banners) */
.contents > img,
.imagen-banner,
.imagen-q,
.circuloZafiro47 {
  object-fit: cover;
}

.imagen-banner,
.imagen-q {
  width: 100%;
  min-height: 220px;
  max-height: 420px;
}

@media screen and (max-width: 768px) {
  .imagen-banner,
  .imagen-q {
    min-height: 180px;
    max-height: 280px;
  }
}

/* ==========================================================
   2026 Spring Premium Design (Below main title)
   Colors: #002b68 / #000c2f / #b38123
   ========================================================== */

.wrapperprof-fondo-tokushu {
  margin: 1.2em 0.8em 1.6em;
  padding: 1.1em 1.3em;
  background: linear-gradient(135deg, rgba(255,255,255,0.96) 0%, rgba(245,239,226,0.95) 100%);
  border: 1px solid rgba(179, 129, 35, 0.55);
  border-left: 5px solid #b38123;
  color: #000c2f;
  border-radius: 10px;
  line-height: 1.9;
  box-shadow: 0 10px 24px rgba(0, 12, 47, 0.12);
}

.texto-container {
  position: relative;
  gap: 18px;
  padding: 24px 18px 30px;
  background: linear-gradient(145deg, #000c2f 0%, #002b68 68%, #1b4c93 100%);
  border-radius: 14px;
  border: 1px solid rgba(179, 129, 35, 0.45);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.05), 0 14px 34px rgba(0, 12, 47, 0.32);
}

.texto-container::before {
  content: "";
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(179, 129, 35, 0.32);
  border-radius: 10px;
  pointer-events: none;
}

.div_banner_postit_unico874,
.contenedor-banner-nuevo,
.bocadilloSuperX298,
.glxq-wrapper {
  width: min(96%, 1080px);
  margin: 0 auto;
  background: linear-gradient(180deg, #ffffff 0%, #f7f3ea 100%);
  border: 1px solid rgba(179, 129, 35, 0.5);
  border-radius: 12px;
  box-shadow: 0 12px 26px rgba(0, 12, 47, 0.18);
}

.div_banner_postit_unico874 {
  padding: 22px 24px;
}

.div_banner_postit_unico874 .titulo-postit,
.contenedor-banner-nuevo .titulo-banner-nuevo,
.bocadilloTituloZeta,
.glxq-titulo h2 {
  color: #002b68 !important;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  letter-spacing: 0.03em;
}

.div_banner_postit_unico874 .titulo-postit,
.contenedor-banner-nuevo .titulo-banner-nuevo,
.bocadilloTituloZeta {
  margin-bottom: 10px;
  padding-bottom: 8px;
  border-bottom: 1px solid rgba(179, 129, 35, 0.45);
}

.div_banner_postit_unico874 .subtitulo-postit,
.contenedor-banner-nuevo .subtitulo-banner-nuevo {
  color: #b38123 !important;
  font-weight: 700;
}

.div_banner_postit_unico874 .texto-postit,
.contenedor-banner-nuevo .texto-banner-nuevo,
.parrafo-q,
.bocadilloTextoZeta,
.glxq-columna p,
.content-box p {
  color: #10254a;
  line-height: 1.92;
}

.contenedor-banner-nuevo {
  padding: 20px 22px;
}

.contenido-banner-flex,
.contenido-banner-flex-nuevo {
  align-items: stretch;
  gap: 20px;
}

.bloque-q {
  background: linear-gradient(180deg, rgba(0,43,104,0.03) 0%, rgba(179,129,35,0.06) 100%);
  border: 1px solid rgba(179, 129, 35, 0.42);
  border-radius: 10px;
  padding: 14px;
}

.imagen-banner,
.imagen-q,
.circuloZafiro47,
.gallery-4-img-col img,
.sensei-img img,
.columns02 img,
.migi.caption img,
.hidari.caption img {
  border-radius: 10px;
  border: 1px solid rgba(179, 129, 35, 0.55);
  box-shadow: 0 10px 20px rgba(0, 12, 47, 0.22);
}

.top-bg {
  padding: 26px 14px;
  border-radius: 14px;
  background: linear-gradient(170deg, rgba(0, 12, 47, 0.95) 0%, rgba(0, 43, 104, 0.95) 75%);
  border: 1px solid rgba(179, 129, 35, 0.5);
}

.bocadilloSuperX298 {
  padding: 18px 20px;
  background: linear-gradient(180deg, #fff 0%, #f6f0e4 100%);
}

.bocadilloSuperX298.bocadilloInvertidoOmega {
  background: linear-gradient(180deg, #f9fbff 0%, #ecf3ff 100%);
}

.bocadilloTextoZeta span,
.bocadilloTextoZeta strong {
  color: #000c2f;
}

.glxq-wrapper {
  margin-top: 22px;
  padding: 18px 20px;
}

.glxq-titulo {
  margin-bottom: 12px;
  padding: 8px 12px;
  background: linear-gradient(90deg, #000c2f 0%, #002b68 100%);
  border-left: 5px solid #b38123;
  border-radius: 8px;
}

.glxq-titulo h2 {
  color: #ffffff !important;
  margin: 0;
}

.glxq-tabla {
  gap: 12px;
}

.glxq-columna {
  background: #fff;
  border: 1px solid rgba(179, 129, 35, 0.48);
  border-radius: 8px;
  padding: 12px 14px;
}

.glxq-columna h3 {
  color: #002b68;
  margin-bottom: 6px;
}

.instructions p {
  color: #b38123;
  font-weight: 600;
}

.gallery-4-img {
  width: min(100%, 1120px);
  gap: 12px;
  padding: 18px 14px;
  background: linear-gradient(180deg, rgba(0, 12, 47, 0.92) 0%, rgba(0, 43, 104, 0.92) 100%);
  border: 1px solid rgba(179, 129, 35, 0.55);
  border-radius: 12px;
}

.gallery-4-img-col {
  background: linear-gradient(180deg, #ffffff 0%, #f4ecdb 100%);
  border: 1px solid rgba(179, 129, 35, 0.55);
  border-radius: 10px;
  padding: 10px;
}

.gallery-4-img-col h3 {
  color: #002b68;
}

.section-cont {
  margin-top: 18px;
  border-width: 8px;
  border-style: solid;
  border-image: linear-gradient(165deg, #b38123 0%, #f1ddae 25%, #002b68 55%, #000c2f 100%) 1;
  background: linear-gradient(180deg, #ffffff 0%, #f7f2e8 100%);
  box-shadow: 0 10px 24px rgba(0, 12, 47, 0.16);
}

.top-icon-tokushu {
  align-items: center;
  padding: 10px;
  background: linear-gradient(90deg, rgba(0,12,47,0.98) 0%, rgba(0,43,104,0.95) 100%);
}

.top-icon-tokushu img {
  border: 1px solid rgba(179, 129, 35, 0.6);
  border-radius: 10px;
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.24);
}

.glow-wrap-texto {
  width: 100%;
  margin-left: 12px;
  padding: 12px 16px;
  background: transparent;
  border-left: 5px solid #b38123;
}

.glow-titulo-texto p {
  color: #ffffff;
  font-size: 2.1rem;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  line-height: 1.6;
}

.content-box .sensei-img h3,
.section-cont h3 {
  color: #002b68;
}

.purple-bg {
  background: linear-gradient(135deg, rgba(0,43,104,0.1) 0%, rgba(179,129,35,0.11) 100%) !important;
  border: 1px solid rgba(179, 129, 35, 0.5);
}

.back-to {
  border: 1px solid #b38123;
  background: rgba(179, 129, 35, 0.1);
  color: #002b68 !important;
}

.back-to:hover {
  background: rgba(179, 129, 35, 0.2) !important;
}

@media screen and (max-width: 1024px) {
  .texto-container { padding: 18px 12px 22px; }
  .div_banner_postit_unico874,
  .contenedor-banner-nuevo,
  .bocadilloSuperX298,
  .glxq-wrapper { width: 100%; }
  .glow-titulo-texto p { font-size: 1.8rem; }
}

@media screen and (max-width: 768px) {
  .texto-container { gap: 12px; }
  .div_banner_postit_unico874,
  .contenedor-banner-nuevo,
  .bocadilloSuperX298,
  .glxq-wrapper { padding: 14px; border-radius: 10px; }
  .top-bg { padding: 14px 8px; }
  .gallery-4-img { padding: 12px 8px; }
  .top-icon-tokushu { flex-direction: column; align-items: stretch; }
  .glow-wrap-texto { margin-left: 0; margin-top: 10px; }
  .glow-titulo-texto p { font-size: 1.55rem; }
}

@media screen and (max-width: 520px) {
  .wrapperprof-fondo-tokushu { margin: 0.8em 0 1.2em; padding: 0.95em; }
  .div_banner_postit_unico874 .titulo-postit,
  .contenedor-banner-nuevo .titulo-banner-nuevo,
  .bocadilloTituloZeta { font-size: 1.9rem !important; }
  .div_banner_postit_unico874 .subtitulo-postit,
  .contenedor-banner-nuevo .subtitulo-banner-nuevo { font-size: 1.45rem !important; }
}

.tokushu-main-title {
  margin: 8px 0 14px;
  text-align: left;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1.35;
  color: #000c2f;
}

.tokushu-main-title-accent {
  color: #000c2f;
  font-weight: 700;
}

@media screen and (max-width: 900px) {
  .tokushu-main-title {
    font-size: 3.4rem;
    line-height: 1.4;
  }
}

@media screen and (max-width: 560px) {
  .tokushu-main-title {
    font-size: 2.8rem;
    line-height: 1.45;
  }
}

/* 2026 Spring New Board */
.nobel-board-2026 {
  --nobel-side-width: 68px;
  --nobel-side-gap: 0px;
  position: relative;
  margin: 28px 0 0;
  padding: 18px 14px 10px calc(var(--nobel-side-width) + var(--nobel-side-gap));
  background: #000c2f url("../img/the-backgrund.png") left top / cover no-repeat;
  border: none;
  box-shadow: none;
}

.nobel-board-2026::before {
  content: "KYOTO UNIVERSITY";
  position: absolute;
  top: 5px;
  bottom: 0;
  left: 0;
  width: var(--nobel-side-width);
  writing-mode: vertical-rl;
  color: #b38123;
  font-family: "Times New Roman", serif;
  font-size: calc(var(--nobel-side-width) + 10px);
  letter-spacing: 0.15em;
  opacity: 0.95;
  line-height: 1;
  white-space: nowrap;
  word-break: keep-all;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  pointer-events: none;
}

.nobel-board-title {
  display: block;
  width: calc(100% - 308px);
  margin: 8px auto 18px;
}

.nobel-board-title h2 {
  position: relative;
  display: block;
  margin: 0;
  width: 100%;
  box-sizing: border-box;
  min-width: 0;
  padding: 14px 30px 14px 34px;
  text-align: center;
  font-size: 4.2rem;
  color: #000c2f;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  letter-spacing: 0.06em;
  line-height: 1.35;
  border: 1px solid #ececec;
  background: #ffffff;
  box-shadow: 0 6px 14px rgba(0, 0, 0, 0.18);
}

.nobel-board-title h2::before {
  content: "";
  position: absolute;
  left: -1px;
  top: -1px;
  right: -1px;
  bottom: -1px;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(179, 129, 35, 0.95) 0%, rgba(179, 129, 35, 0) 72%) left top / 100% 4px no-repeat,
    linear-gradient(180deg, rgba(179, 129, 35, 0.95) 0%, rgba(179, 129, 35, 0) 72%) left top / 4px 100% no-repeat;
}

.contents .nobel-board-2026 .nobel-board-title h2 {
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  box-sizing: border-box;
  text-align: center !important;
  font-size: 2.2rem !important;
}

.nobel-board-main {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 8px;
  align-items: stretch;
}

.nobel-board-side {
  display: none;
}

.nobel-board-list {
  background: transparent;
  border: none;
  padding: 4px 4px;
}

.nobel-row {
  display: grid;
  grid-template-columns: 11.2em 1fr 1.1em;
  align-items: center;
  gap: 0;
  padding: 4px 0;
  border-bottom: 1px solid rgba(179, 129, 35, 0.95);
}

.nobel-row:last-child { border-bottom: 1px solid rgba(179, 129, 35, 0.95); }

.nobel-row .name {
  margin: 0;
  font-weight: 700;
  font-size: 1.8rem;
  color: #000;
  letter-spacing: 0.03em;
  text-shadow: none;
}

.nobel-row .year {
  margin: 0;
  font-size: 1.5rem;
  color: #000;
  font-weight: 700;
  text-shadow: none;
}

.nobel-row .no {
  width: 15px;
  min-width: 15px;
  height: 15px;
  line-height: 15px;
  align-self: center;
  text-align: center;
  font-size: 0.95rem;
  color: #fff;
  background: #b38123;
  border-radius: 0;
}

.nobel-board-photos {
  position: relative;
  min-height: 820px;
}

.nobel-board-photos .photo {
  position: absolute;
  margin: 0;
  overflow: hidden;
  display: block;
  background: #fff;
  border: 1px solid rgba(179, 129, 35, 0.5);
  box-shadow: 0 6px 14px rgba(0, 12, 47, 0.18);
}

.nobel-board-photos .photo img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: #fff;
  border: 0;
}

.nobel-board-photos .photo figcaption {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: 0;
  padding: 4px 24px 4px 6px;
  font-size: 0.82rem;
  line-height: 1.28;
  text-align: left;
  color: #111;
  background: rgba(255, 255, 255, 0.92);
  border: 0;
  z-index: 1;
}

.nobel-board-photos .photo::after {
  content: attr(data-no);
  position: absolute;
  right: 6px;
  bottom: 30px;
  width: 16px;
  height: 16px;
  line-height: 16px;
  text-align: center;
  font-size: 1rem;
  color: #fff;
  background: #b38123;
  z-index: 2;
}

.nobel-board-photos .p1,
.nobel-board-photos .p2,
.nobel-board-photos .p3,
.nobel-board-photos .p4,
.nobel-board-photos .p5,
.nobel-board-photos .p6 {
  top: auto;
  right: auto;
  left: auto;
  display: block;
}

.nobel-board-photos .p1 { top: 0; right: 0; width: 228px; height: 322px; }
.nobel-board-photos .p2 { top: 330px; right: 0; left: auto; width: 280px; height: 150px; }
.nobel-board-photos .p3 { top: 500px; right: 0; width: 150px; height: 230px; }
.nobel-board-photos .p4 { top: 500px; left: -15px; width: 150px; height: 230px; }
.nobel-board-photos .p5 { top: 500px; left: -200px; width: 170px; height: 230px; }
.nobel-board-photos .p6 { display: none; }

.nobel-board-photos .p1 figcaption,
.nobel-board-photos .p3 figcaption,
.nobel-board-photos .p4 figcaption {
  top: auto;
  right: 0;
  writing-mode: horizontal-tb;
  text-orientation: initial;
  font-size: 0.82rem;
}

.nobel-board-photos .p2 figcaption,
.nobel-board-photos .p5 figcaption {
  left: 0;
  right: 0;
  bottom: 0;
}

.nobel-board-photos .p6 figcaption {
  display: none;
}

@media screen and (max-width: 1120px) {
  .nobel-board-title { width: calc(100% - 268px); }
  .nobel-board-main { grid-template-columns: 1fr 260px; }
  .nobel-board-side { width: 70px; }
  .nobel-row .name { font-size: 1.75rem; }
  .nobel-row .year { font-size: 1.45rem; }
  .nobel-board-photos { min-height: 760px; }
}

@media screen and (max-width: 900px) {
  .nobel-board-2026::before { display: none; }
  .nobel-board-2026 { padding-left: 14px; }
  .nobel-board-title { width: 100%; }
  .nobel-board-main {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .nobel-board-side {
    display: block;
    position: static;
    width: auto;
    writing-mode: horizontal-tb;
    transform: none;
    font-size: 3.2rem;
    letter-spacing: 0.12em;
    margin: 0;
    text-align: left;
  }

  .nobel-board-title h2 {
    width: 100%;
    min-width: auto;
    font-size: 3.7rem;
  }

  .nobel-board-photos {
    min-height: auto;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }

  .nobel-board-photos .photo {
    position: relative;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    width: auto !important;
    height: auto !important;
    overflow: hidden;
  }

  .nobel-board-photos .photo img {
    width: 100%;
    height: auto;
    object-fit: unset;
    object-position: unset;
  }

  .nobel-board-photos .photo figcaption {
    position: static;
    padding: 6px 0 0;
    writing-mode: horizontal-tb;
    font-size: 0.9rem;
    background: transparent;
  }

  .nobel-board-photos .p1,
  .nobel-board-photos .p2,
  .nobel-board-photos .p3,
  .nobel-board-photos .p4,
  .nobel-board-photos .p5,
  .nobel-board-photos .p6 {
    top: auto;
    right: auto;
    left: auto;
    width: auto;
    height: auto;
  }

  .nobel-board-photos .p6 { display: none; }

  .nobel-board-photos .p3,
  .nobel-board-photos .p4 {
    overflow: visible;
  }

  .nobel-board-photos .p3 img,
  .nobel-board-photos .p4 img {
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    object-position: top;
  }
}

@media screen and (max-width: 560px) {
  .contents { border: none !important; }
  .nobel-board-side { display: none; }
  .nobel-board-2026,
  .contents .nobel-board-2026 { padding: 10px 8px 14px; border: none !important; }
  .nobel-board-title h2 { font-size: 3.1rem; padding: 10px 12px; }
  .nobel-row {
    grid-template-columns: 11.2em 1fr 1.1em;
    gap: 0;
    padding: 4px 0;
  }
  .nobel-row .name { font-size: 1.25rem; }
  .nobel-row .year { font-size: 1.1rem; }
  .nobel-row .no {
    justify-self: center;
    margin-top: 0;
    align-self: center;
  }
  .nobel-board-photos {
    grid-template-columns: repeat(2, 1fr);
  }
  .nobel-board-photos .photo {
    height: auto !important;
  }
}

.sakaguchi-page {
  margin: 18px 16px 14px;
  padding: 14px 12px 10px;
  background: #ffffff;
}

.sakaguchi-hero {
  margin-bottom: 16px;
  padding-bottom: 12px;
}

.contents .sakaguchi-hero-banner-copy .sakaguchi-hero-name {
  margin: 0 !important;
  color: #ffffff;
  font-size: 3.9rem !important;
  font-weight: 700 !important;
  line-height: 1.16;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "YuMincho", "Noto Serif JP", serif;
  letter-spacing: 0.01em;
  text-shadow: 0 2px 10px rgba(0, 31, 111, 0.5);
}

.contents .sakaguchi-hero-banner-copy .sakaguchi-hero-name small {
  font-size: 0.56em !important;
  font-weight: 500 !important;
  margin-left: 0.2em;
}

.contents .sakaguchi-hero-banner-copy .sakaguchi-hero-award {
  margin: 6px 0 0 !important;
  color: #ffffff;
  font-size: 3.9rem !important;
  font-weight: 700 !important;
  line-height: 1.14;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "YuMincho", "Noto Serif JP", serif;
  letter-spacing: 0.01em;
  text-shadow: 0 2px 12px rgba(0, 31, 111, 0.55);
}

.sakaguchi-hero-banner {
  position: relative;
  margin: 0 0 12px;
  overflow: hidden;
}

.sakaguchi-hero-banner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(
    100deg,
    rgba(0, 31, 111, 0.9) 0%,
    rgba(0, 31, 111, 0.82) 28%,
    rgba(0, 31, 111, 0.62) 52%,
    rgba(0, 31, 111, 0.5) 80%,
    rgba(0, 31, 111, 0.42) 90%,
    rgba(0, 31, 111, 0.35) 100%
  );
  z-index: 1;
}

.sakaguchi-hero-banner img {
  width: 100%;
  display: block;
}

.sakaguchi-hero-banner-copy {
  position: absolute;
  inset: 0;
  margin: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  padding: 2.2rem 2.6rem;
}

.contents .sakaguchi-hero h1 {
  margin: 0 !important;
  color: #947318;
  font-size: 3rem !important;
  line-height: 1.22;
  font-weight: 700;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", "Hiragino Mincho Pro", "YuMincho", "Noto Serif JP", serif;
  letter-spacing: 0.01em;
  background: linear-gradient(180deg, #f3de88 0%, #d0a437 42%, #947318 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  text-shadow: 0 1px 3px rgba(148, 115, 24, 0.2);
}

.sakaguchi-message {
  display: block;
}

.sakaguchi-message::after {
  content: "";
  display: block;
  clear: both;
}

.sakaguchi-profile {
  float: left;
  width: 180px;
  margin: 0 14px 10px 0;
  padding: 8px;
  background: #ffffff;
}

.sakaguchi-profile-photo {
  margin: 0 0 8px;
}

.sakaguchi-profile-photo img {
  width: 100%;
  display: block;
}

.contents .sakaguchi-profile .sakaguchi-profile-name {
  margin: 0 0 4px !important;
  color: #000000;
  font-size: 2.5rem !important;
  line-height: 1.1;
  font-weight: 650;
  text-align: left;
}

.contents .sakaguchi-profile .sakaguchi-profile-role {
  margin: 0 !important;
  color: #000000;
  font-size: 1.5rem !important;
  line-height: 1.5;
  font-weight: 500;
  text-align: left;
}

.sakaguchi-message-body {
  column-count: 1;
}

.sakaguchi-message-body p,
.sakaguchi-message-body h2 {
  break-inside: avoid;
}

.contents .sakaguchi-message-body p {
  margin: 0 0 1em !important;
  color: #000000;
  font-size: 1.5rem !important;
  line-height: 1.95;
  font-weight: 500;
  text-align: justify;
}

.contents .sakaguchi-message-body h2 {
  margin: 0.2em 0 0.55em !important;
  color: #947318;
  font-size: 1.8rem !important;
  font-weight: 700;
  line-height: 1.35;
  padding-left: 0.35em;
}

.contents .sakaguchi-page .nobel-week-back-wrap {
  margin: 20px 0 8px !important;
  text-align: center;
}

.contents .sakaguchi-page .nobel-week-back-wrap .back-to {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 18px;
  border-radius: 999px;
  background: #ffffff;
  color: #001f6f;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  box-shadow: 0 2px 6px rgba(0, 31, 111, 0.18);
}

.contents .sakaguchi-page .nobel-week-back-wrap .back-to:hover {
  background-color: #001f6f !important;
  color: #ffffff !important;
}

@media screen and (min-width: 901px) and (max-width: 1200px) {
  .contents .sakaguchi-hero h1 {
    font-size: clamp(2.2rem, 2.6vw, 3rem) !important;
    line-height: 1.28;
  }

  .contents .sakaguchi-hero-banner-copy .sakaguchi-hero-name {
    font-size: clamp(2.2rem, 3vw, 3.9rem) !important;
  }

  .contents .sakaguchi-hero-banner-copy .sakaguchi-hero-award {
    font-size: clamp(2.2rem, 3vw, 3.9rem) !important;
  }

  .sakaguchi-hero-banner-copy {
    padding: 1.4rem 1.6rem;
  }
}

@media screen and (max-width: 900px) {
  .sakaguchi-page {
    margin: 14px 10px 12px;
  }

  .contents .sakaguchi-hero h1 {
    font-size: clamp(2.7rem, 3.9vw, 3.5rem) !important;
    line-height: 1.28;
  }

  .contents .sakaguchi-hero-banner-copy .sakaguchi-hero-award {
    font-size: clamp(2.8rem, 4.3vw, 3.9rem) !important;
  }

  .contents .sakaguchi-hero-banner-copy .sakaguchi-hero-name {
    font-size: clamp(2.3rem, 3.3vw, 3rem) !important;
  }

  .sakaguchi-hero-banner-copy {
    padding: clamp(1.1rem, 1.8vw, 1.6rem) clamp(1.2rem, 2vw, 1.8rem);
  }

  .sakaguchi-profile {
    float: none;
    width: 100%;
    max-width: 230px;
    margin: 0 auto 10px;
  }

  .sakaguchi-profile-photo img {
    width: 70%;
    margin: 0 auto;
  }

  .contents .sakaguchi-profile .sakaguchi-profile-name,
  .contents .sakaguchi-profile .sakaguchi-profile-role {
    text-align: center;
  }

  .sakaguchi-message-body {
    column-count: 1;
    column-rule: none;
  }
}

@media screen and (max-width: 560px) {
  /* ページ全体のマージン・パディングを縮小 */
  .sakaguchi-page {
    margin: 8px 4px 10px;
    padding: 10px 8px 8px;
  }

  .sakaguchi-hero {
    margin-bottom: 10px;
    padding-bottom: 8px;
  }

  .contents .sakaguchi-hero h1 {
    font-size: clamp(2rem, 6.2vw, 2.4rem) !important;
  }

  .contents .sakaguchi-hero-banner-copy .sakaguchi-hero-name {
    font-size: clamp(0.9rem, 3.5vw, 1.4rem) !important;
  }

  .contents .sakaguchi-hero-banner-copy .sakaguchi-hero-award {
    margin: 2px 0 0 !important;
    font-size: clamp(2rem, 5.5vw, 1.2rem) !important;
  }

  .sakaguchi-hero-banner-copy {
    padding: 1rem 1.1rem !important;
  }

  .contents .sakaguchi-profile .sakaguchi-profile-name {
    font-size: 2.2rem !important;
  }

  .contents .sakaguchi-profile .sakaguchi-profile-role,
  .contents .sakaguchi-message-body p {
    font-size: 1.7rem !important;
  }

  .contents .sakaguchi-message-body h2 {
    font-size: 2.2rem !important;
  }
}

/* ===== sakaguchi-treg: timeline section ===== */
.sakaguchi-treg {
  margin: 16px 0 12px;
  padding: 12px;
  border-top: 3px solid #947318;
}

/* --- Header --- */
.sakaguchi-treg-head {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 2px solid rgba(148, 115, 24, 0.3);
  flex-wrap: wrap;
}

.sakaguchi-treg-guide-box {
  display: grid;
  grid-template-columns: 86px 155px;
  grid-template-rows: auto auto;
  gap: 8px 10px;
  flex-shrink: 0;
}

.sakaguchi-treg-guide-box .sakaguchi-treg-guide-kicker {
  grid-column: 1;
  grid-row: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 76px;
  height: 76px;
  margin: 0 !important;
  padding: 6px;
  color: #947318;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.3;
  text-align: center;
  background: #f9f5eb;
  border: 2px dotted #947318;
  border-radius: 50%;
}

.sakaguchi-treg-guide-photo {
  grid-column: 2;
  grid-row: 1 / 3;
  margin: 0 0 0 12px;
  align-self: end;
}

.sakaguchi-treg-guide-photo img {
  width: 100%;
  max-width: 180px;
  height: auto;
  display: block;
}

.sakaguchi-treg-guide-box .sakaguchi-treg-guide-profile {
  grid-column: 1 / 3;
  grid-row: 2;
  margin: 0 !important;
  color: #000;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
  white-space: nowrap;
}

.sakaguchi-treg-guide-name {
  font-size: 1.2em;
  line-height: 1.1;
  display: inline-block;
}

.sakaguchi-treg-title-block {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 4px;
  min-width: 0;
  padding: 4px 0 4px 14px;
  border-left: 1px solid rgba(148, 115, 24, 0.5);
}

.sakaguchi-treg-profiling-badge {
  display: inline-block;
  padding: 2px 9px;
  font-size: 1.15rem;
  font-weight: 600;
  color: #6e5714;
  letter-spacing: 0.06em;
  border: 1px solid rgba(148, 115, 24, 0.45);
  border-radius: 999px;
  background: rgba(249, 245, 235, 0.7);
  white-space: nowrap;
}

.contents .sakaguchi-page .sakaguchi-treg-title {
  margin: 0 !important;
  color: #111;
  font-size: 3rem !important;
  font-weight: 800;
  line-height: 1.25!important;
  background: none;
}

/* --- Body --- */
.sakaguchi-treg-body {
  position: relative;
}

/* --- Timeline (central spine) --- */
.sakaguchi-treg-timeline {
  position: relative;
  padding: 20px 0 30px;
}

.sakaguchi-treg-timeline::before {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: 0;
  bottom: 0;
  width: 2px;
  background: linear-gradient(
    to bottom,
    transparent 0%,
    rgba(26, 50, 85, 0.28) 5%,
    rgba(26, 50, 85, 0.28) 95%,
    transparent 100%
  );
  z-index: 0;
}

.sakaguchi-treg-item {
  position: relative;
  width: 80%;
  margin-bottom: 32px;
  z-index: 1;
}

.sakaguchi-treg-item:last-child {
  margin-bottom: 0;
}

.sakaguchi-treg-item::before {
  content: none;
  display: none;
}

.sakaguchi-treg-item-left {
  margin-right: auto;
}

.sakaguchi-treg-item-right {
  margin-left: auto;
}

.sakaguchi-treg-year-label {
  position: absolute;
  top: 0;
  width: 68px;
  text-align: center;
  background: #8a6814;
  color: #fff;
  padding: 6px 4px 7px;
  display: flex;
  flex-direction: column;
  align-items: center;
  z-index: 3;
  box-shadow: 0 2px 10px rgba(138, 104, 20, 0.32);
}

.sakaguchi-treg-item-left .sakaguchi-treg-year-label {
  right: 0;
  border-radius: 0 6px 0 6px;
}

.sakaguchi-treg-item-right .sakaguchi-treg-year-label {
  left: 0;
  border-radius: 6px 0 6px 0;
}

.sakaguchi-treg-year-num {
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1.1;
  display: block;
  letter-spacing: -0.02em;
}

.sakaguchi-treg-year-suffix {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
  display: block;
}

.sakaguchi-treg-item-body {
  position: relative;
  background: #faf7f2;
  border: 1px solid rgba(138, 104, 20, 0.28);
  border-top: 3px solid #8a6814;
  border-radius: 6px;
  padding: 14px 16px;
  box-shadow: 0 2px 10px rgba(138, 104, 20, 0.08);
}

.sakaguchi-treg-item-right .sakaguchi-treg-item-body {
  transform: none;
}

/* 年ラベル（高さ約66px）の下からテキストを開始 */
.sakaguchi-treg-item .sakaguchi-treg-item-body {
  padding-top: 56px;
}

.contents .sakaguchi-page .sakaguchi-treg-item-body > p {
  margin: 0 0 8px !important;
  font-size: 1.5rem !important;
  line-height: 1.7;
  color: #2d2d2d;
}

/* Photo comment cards */
.sakaguchi-treg-bubble {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin: 10px 0 12px !important;
  background: #fff;
  border: 1px solid rgba(138, 104, 20, 0.2);
  border-radius: 20px;
  padding: 5px 12px;
}

.sakaguchi-treg-bubble-icon {
  margin: 0;
  width: 56px;
  flex-shrink: 0;
}

.sakaguchi-treg-bubble-icon img {
  width: 100%;
  display: block;
  border-radius: 50%;
  border: none;
  box-shadow: none;
}

.sakaguchi-treg-bubble-icon figcaption {
  font-size: 1.1rem;
  text-align: center;
  color: #947318;
  font-weight: 600;
  margin-top: 3px;
  line-height: 1;
}

.contents .sakaguchi-page .sakaguchi-treg-bubble-text {
  margin: 0 !important;
  font-size: 1.5rem !important;
  line-height: 1.6;
  color: #1a3255;
  font-weight: 600;
  align-self: center;
}

/* Discovery highlight (1995) */
.sakaguchi-treg-discovery {
  background: #ffff99;
  border: 1px solid rgba(138, 104, 20, 0.35);
  border-radius: 6px;
  padding: 12px 14px;
  margin-top: 10px;
  text-align: center;
}

.contents .sakaguchi-page .sakaguchi-treg-discovery p {
  margin: 0 0 4px !important;
  font-size: 1.5rem !important;
  font-weight: bold;
  color: #000;
  line-height: 1.5;
}

.contents .sakaguchi-page .sakaguchi-treg-discovery p.sakaguchi-treg-discovery-name {
  font-size: 2.5rem !important;
  font-weight: 800;
  color: #000 !important;
  margin: 0 !important;
  letter-spacing: 0.03em;
}

.sakaguchi-treg-item-climax {
  margin-bottom: 32px;
}

.sakaguchi-treg-item-milestone {
  margin-bottom: 32px;
}

.sakaguchi-treg-item-climax .sakaguchi-treg-item-body {
  overflow: visible;
}

.sakaguchi-treg-proof-comment {
  position: static;
  transform: none;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  width: fit-content;
  margin-top: 12px;
  padding: 8px 12px;
  background: #f9f5eb;
  border: 2px dotted #947318;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(138, 104, 20, 0.12);
  z-index: 2;
}

.sakaguchi-treg-proof-comment-icon {
  margin: 0;
  width: 48px;
  flex-shrink: 0;
}

.sakaguchi-treg-proof-comment-icon img {
  width: 100%;
  display: block;
  border-radius: 50%;
}

.contents .sakaguchi-page .sakaguchi-treg-proof-comment-text {
  margin: 0 !important;
  font-size: 1.5rem !important;
  line-height: 1.5;
  font-weight: 700;
  color: #947318;
}

.sakaguchi-treg-proof-comment-2003 {
  width: auto;
  max-width: 400px;
}

/* --- Foxp3 box --- */
.sakaguchi-treg-foxp3-box {
  background: #ffff99;
  border: 1px solid rgba(138, 104, 20, 0.35);
  border-radius: 6px;
  padding: 12px 14px;
  margin-top: -10px;
  text-align: center;
}

.contents .sakaguchi-page .sakaguchi-treg-foxp3-label {
  margin: 0 0 4px !important;
  font-size: 1.5rem !important;
  font-weight: bold;
  color: #333;
  line-height: 1.5;
}

.contents .sakaguchi-page .sakaguchi-treg-foxp3-name {
  font-size: 2.5rem !important;
  font-weight: 800;
  color: #000 !important;
  margin: 0 !important;
  letter-spacing: 0.03em;
}

/* --- Nobel box --- */
.sakaguchi-treg-nobel-box {
  background: #fff;
  border: 1px solid rgba(138, 104, 20, 0.22);
  border-radius: 6px;
  box-shadow: 0 2px 10px rgba(26, 50, 85, 0.07);
}

.contents .sakaguchi-page .sakaguchi-treg-nobel-title {
  margin: 0 !important;
  background: none !important;
  color: #8a6814 !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  padding: 0.56em 1.2em 0.62em !important;
  line-height: 1.5 !important;
  text-align: center !important;
  position: relative !important;
}

.contents .sakaguchi-page .sakaguchi-treg-nobel-title::before,
.contents .sakaguchi-page .sakaguchi-treg-nobel-title::after {
  content: "" !important;
  position: absolute !important;
  top: 6px !important;
  bottom: 6px !important;
  width: 12px !important;
}

.contents .sakaguchi-page .sakaguchi-treg-nobel-title::before {
  left: 6px !important;
  border-top: 2px solid #8a6814 !important;
  border-bottom: 2px solid #8a6814 !important;
  border-left: 2px solid #8a6814 !important;
}

.contents .sakaguchi-page .sakaguchi-treg-nobel-title::after {
  right: 6px !important;
  border-top: 2px solid #8a6814 !important;
  border-bottom: 2px solid #8a6814 !important;
  border-right: 2px solid #8a6814 !important;
}



.contents .sakaguchi-page .sakaguchi-treg-nobel-box > p {
  margin: 0 !important;
  font-size: 1.5rem !important;
  line-height: 1.75;
  color: #2d2d2d;
  padding: 12px 14px;
}

.sakaguchi-treg-achievement {
  display: flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(135deg, #f0f4f9 0%, #e8eef6 100%);
  border: 1px solid rgba(26, 50, 85, 0.16);
  border-radius: 6px;
  padding: 14px 16px;
}

.sakaguchi-treg-achievement-portrait {
  margin: 0;
  width: 60px;
  flex-shrink: 0;
}

.sakaguchi-treg-achievement-portrait img {
  width: 100%;
  display: block;
  border-radius: 50%;
  border: 2px solid rgba(26, 50, 85, 0.2);
}

.contents .sakaguchi-page .sakaguchi-treg-achievement-text {
  margin: 0 !important;
  font-size: 1.5rem !important;
  font-weight: 700;
  color: #1a3255;
  line-height: 1.6;
}

@media screen and (max-width: 900px) {
  .sakaguchi-treg-timeline::before {
    left: 12px;
    transform: none;
  }

  .sakaguchi-treg-item,
  .sakaguchi-treg-item-left,
  .sakaguchi-treg-item-right {
    width: auto;
    margin: 0 0 16px;
    padding: 0 0 0 26px;
  }

  .sakaguchi-treg-year-label,
  .sakaguchi-treg-item-left .sakaguchi-treg-year-label,
  .sakaguchi-treg-item-right .sakaguchi-treg-year-label {
    position: static;
    margin: 0 0 8px;
    display: inline-flex;
    flex-direction: row;
    align-items: baseline;
    gap: 2px;
    padding: 3px 10px 4px;
    border-radius: 20px;
    width: auto;
    box-shadow: 0 1px 4px rgba(26, 50, 85, 0.2);
  }

  .sakaguchi-treg-year-label::after {
    display: none;
  }

  /* モバイルでは年ラベルが通常フローなのでpaddingをリセット */
  .sakaguchi-treg-item .sakaguchi-treg-item-body {
    padding-top: 14px;
  }

  .sakaguchi-treg-item-right .sakaguchi-treg-item-body {
    transform: none;
  }

  .sakaguchi-treg-item-climax {
    margin-bottom: 16px;
  }

  .sakaguchi-treg-item-milestone {
    margin-bottom: 16px;
  }

  .sakaguchi-treg-proof-comment {
    position: static;
    transform: none;
    width: fit-content;
    max-width: 360px;
    margin: 12px 0 0;
    border-radius: 20px;
  }

  .contents .sakaguchi-page .sakaguchi-treg-title {
    font-size: 2.05rem !important;
  }

  .contents .sakaguchi-page .sakaguchi-treg-item-body > p {
    font-size: 1.4rem !important;
  }
}

@media screen and (min-width: 901px) and (max-width: 1200px) {
  .sakaguchi-treg-proof-comment {
    position: static;
    transform: none;
    width: fit-content;
    max-width: 360px;
    margin: 12px 0 0;
    border-radius: 20px;
  }
}

@media screen and (max-width: 560px) {
  /* タイムラインセクション */
  .sakaguchi-treg {
    padding: 8px 6px;
    margin: 10px 0 8px;
  }

  .sakaguchi-treg-guide-box .sakaguchi-treg-guide-profile,
  .sakaguchi-treg-profiling-badge {
    white-space: normal;
  }

  .sakaguchi-treg-head {
    gap: 10px;
    margin-bottom: 10px;
    flex-direction: column;
    align-items: center;
  }

  .sakaguchi-treg-title-block {
    order: 1;
    border-left: none;
    border-top: 1px solid rgba(148, 115, 24, 0.5);
    padding: 10px 0 4px;
    width: 100%;
    align-items: center;
  }

  .sakaguchi-treg-guide-box {
    order: 0;
  }

  .contents .sakaguchi-page .sakaguchi-treg-title {
    font-size: clamp(1.8rem, 5.2vw, 2rem) !important;
  }

  .sakaguchi-treg-proof-comment {
    gap: 8px;
    padding: 8px 10px;
  }

  .sakaguchi-treg-proof-comment-icon {
    width: 42px;
  }

  .contents .sakaguchi-page .sakaguchi-treg-proof-comment-text {
    font-size: 1.35rem !important;
    line-height: 1.45;
  }

  .contents .sakaguchi-page .sakaguchi-treg-item-body > p {
    font-size: clamp(1.2rem, 3.5vw, 1.35rem) !important;
  }

  .contents .sakaguchi-page .sakaguchi-treg-discovery p {
    font-size: clamp(1.2rem, 3.5vw, 1.4rem) !important;
  }

  .contents .sakaguchi-page .sakaguchi-treg-discovery p.sakaguchi-treg-discovery-name {
    font-size: 1.9rem !important;
  }

  .contents .sakaguchi-page .sakaguchi-treg-foxp3-name {
    font-size: 1.9rem !important;
  }

  .sakaguchi-2025-award-highlight {
    font-size: clamp(1.6rem, 4.8vw, 1.9rem);
    line-height: 1.5;
  }

  .sakaguchi-key-highlight {
    font-size: clamp(1.55rem, 4.6vw, 1.85rem);
    line-height: 1.4;
    padding-bottom: 0.1em;
  }

  .contents .sakaguchi-page .sakaguchi-2025-key-block p {
    line-height: 1.5 !important;
  }

  /* メンターセクション */
  .mof-era-mentor {
    padding: 8px 6px;
  }

  .contents .mof-era-mentor .mof-era-mentor-title {
    font-size: clamp(1.3rem, 3.8vw, 1.45rem) !important;
    padding: 0.5em 0.8em 0.55em;
  }

  /* 散歩写真キャプション */
  .sakaguchi-mentor-walk figcaption {
    font-size: 1.3rem;
  }

  .sakaguchi-treg-item-full .sakaguchi-treg-item-body::after {
    width: 52px;
    height: 52px;
    top: -8px;
    right: -2px;
  }
}

/* --- 2025年（フル幅） --- */
.sakaguchi-treg-item-full {
  width: 100%;
}

.sakaguchi-treg-item-full .sakaguchi-treg-item-body {
  background: #fff url(../img/the-backgrund.png) center / cover;
  border-radius: 6px;
  padding: 55px 16px 16px;
}

.sakaguchi-treg-item-full .sakaguchi-treg-item-body::after {
  content: "";
  position: absolute;
  top: -20px;
  right: -6px;
  width: 110px;
  height: 110px;
  background: url(../img/the-t.png) center / contain no-repeat transparent;
  pointer-events: none;
}

.sakaguchi-treg-item-full .sakaguchi-treg-year-label {
  left: 50%;
  transform: translateX(-50%);
  border-radius: 6px 6px 0 0;
}

.contents .sakaguchi-page .sakaguchi-2025-award {
  font-size: 1.8rem !important;
  font-weight: 700;
  color: #8a6814;
  margin: 0 0 12px !important;
}

.sakaguchi-2025-award-highlight {
  font-size: 2.8rem;
  background: linear-gradient(transparent 60%, #e5df1b 60%) center / 92% no-repeat;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

.sakaguchi-2025-two-col {
  display: flex;
  gap: 20px;
  align-items: stretch;
  margin: 16px 0;
}

.sakaguchi-2025-side-by-side {
  width: 35%;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin: 0;
}

.sakaguchi-2025-side-by-side > * {
  margin: 0 !important;
}

.sakaguchi-2025-right-col {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.sakaguchi-2025-key-block {
  background: #fffbf0;
  border: 2px solid #c9a84c;
  border-radius: 6px;
  padding: 20px 15px;
  text-align: center;
  margin: 16px 0;
}

.contents .sakaguchi-page .sakaguchi-2025-key-block p {
  margin: 0 !important;
  font-size: 1.5rem !important;
  text-align: left;
  font-weight: 700;
  color: #000;
  line-height: 1.8;
}

.sakaguchi-key-highlight {
  font-size: 2rem;
  background: linear-gradient(transparent 60%, #e5df1b 60%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  line-height: 0;
}

.sakaguchi-2025-tolerance {
  display: flex;
  flex-direction: column;
  margin: 0;
}

.sakaguchi-2025-tolerance-text {
  border-left: 4px solid #8a6814;
  padding: 8px 12px;
  margin-bottom: 8px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
  border-radius: 0 4px 4px 0;
}

.contents .sakaguchi-page .sakaguchi-2025-tolerance-text p,
.contents .sakaguchi-page p.sakaguchi-2025-tolerance-text {
  margin: 0 0 2px !important;
  font-size: 1.5rem !important;
  font-weight: 600;
  color: #000;
}

.contents .sakaguchi-page .sakaguchi-2025-tolerance-name {
  font-size: 1.8rem !important;
  font-weight: 700;
  color: #000;
}

.sakaguchi-2025-tolerance-img {
  margin: 0;
  width: 100%;
}

.sakaguchi-2025-tolerance-img img {
  width: 100%;
  display: block;
}

.sakaguchi-2025-immune-img {
  margin: 16px 0 0;
  position: relative;
}

.sakaguchi-2025-immune-img img {
  width: 100%;
  display: block;
}

.sakaguchi-2025-immune-credit {
  position: absolute;
  bottom: 6px;
  right: 8px;
  font-size: 1.1rem;
  color: #555;
  line-height: 1;
}

/* --- Tレグが拓く医療の未来 --- */
.contents .sakaguchi-page .sakaguchi-treg-future {
  margin-top: 24px;
  text-align: left !important;
}

.contents .sakaguchi-page .sakaguchi-treg-future-title {
  display: inline-block;
  background: #8b1f30;
  color: #fff !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  padding: 6px 20px !important;
  border-radius: 999px;
  margin: 0 0 16px !important;
}

.contents .sakaguchi-page .sakaguchi-treg-future-cols {
  display: flex !important;
  gap: 16px;
  text-align: left !important;
}

.contents .sakaguchi-page .sakaguchi-treg-future-col {
  flex: 1;
  background: #fff;
  border: 1px solid rgba(139, 31, 48, 0.2);
  border-radius: 6px;
  padding: 16px !important;
  text-align: left !important;
}

.contents .sakaguchi-page .sakaguchi-treg-future-col-title {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: #000 !important;
  margin: 0 0 10px !important;
  padding-left: 22px !important;
  padding-top: 0 !important;
  padding-right: 0 !important;
  padding-bottom: 0 !important;
  position: relative;
  text-align: left !important;
}

.contents .sakaguchi-page .sakaguchi-treg-future-col-title::before {
  content: "";
  display: inline-block;
  width: 13px;
  height: 13px;
  background: #8b1f30;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 4px;
}

.contents .sakaguchi-page .sakaguchi-treg-future-col ul {
  margin: 0 !important;
  padding: 0 0 0 22px !important;
  text-align: left !important;
  list-style: none !important;
}

.contents .sakaguchi-page .sakaguchi-treg-future-col li {
  font-size: 1.4rem !important;
  margin: 0 0 4px !important;
  color: #333 !important;
  text-align: left !important;
  list-style: none !important;
}

@media screen and (max-width: 900px) {
  .sakaguchi-treg-item-full {
    width: auto;
    padding: 0 0 0 26px;
  }

  .sakaguchi-treg-item-full .sakaguchi-treg-year-label {
    position: static;
    left: auto;
    transform: none;
    border-radius: 20px;
    margin: 0 0 8px;
    display: inline-flex;
    flex-direction: row;
    align-items: baseline;
    gap: 2px;
    padding: 3px 10px 4px;
    width: auto;
    box-shadow: 0 1px 4px rgba(26, 50, 85, 0.2);
  }

  .sakaguchi-treg-item-full .sakaguchi-treg-item-body::after {
    width: 70px;
    height: 70px;
    top: -12px;
    right: -4px;
  }

  .sakaguchi-2025-two-col {
    flex-direction: column;
  }

  .sakaguchi-2025-side-by-side {
    width: 100%;
  }

  .sakaguchi-2025-award-highlight {
    font-size: clamp(2rem, 4.2vw, 2.4rem);
    line-height: 1.45;
  }

  .sakaguchi-key-highlight {
    font-size: clamp(1.8rem, 3.8vw, 2.1rem);
    line-height: 1.6;
  }

  .sakaguchi-2025-tolerance-img {
    max-width: 100%;
    width: 100%;
  }

  .sakaguchi-treg-future-cols {
    flex-direction: column;
  }
}


.kitagawa-feature {
  margin: 0 0 10px;
  display: block;
  padding: 0 0 16px;
  background-image: url(../img/the-backgrund.png);
  background-repeat: repeat;
  background-size: auto;
  background-position: left top;
  background-origin: border-box;
  background-clip: border-box;
  border-width: 20px;
  border-style: solid;
  border-color: transparent;
  border-image-source: url(../img/the-backgrund.png);
  border-image-slice: 30;
  border-image-repeat: round;
}

.kitagawa-feature-inner {
  position: relative;
  margin: 0 24px;
  padding: 26px 0 24px;
  background: #fff;
  border: 1px solid rgba(179, 129, 35, 0.45);
  box-shadow: 0 8px 16px rgba(0, 12, 47, 0.12);
}

.kitagawa-feature-head {
  display: grid;
  grid-template-columns: 258px 1fr;
  gap: 0;
  padding: 10px;
  align-items: end;
}

.kitagawa-feature-photo {
  position: relative;
  margin: 0;
  padding-left: 22px;
}

.kitagawa-feature-photo img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
  border-radius: 0;
  border: 1px solid rgba(179, 129, 35, 0.45);
  box-shadow: none;
}

.kitagawa-feature-photo figcaption {
  position: absolute;
  top: 0;
  left: 2px;
  writing-mode: vertical-rl;
  font-size: 1.15rem;
  color: #10254a;
  line-height: 1.4;
}

.kitagawa-feature-meta {
  margin-left: -10px;
}

.kitagawa-feature-meta h2 {
  margin: 0;
  color: #b38123;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 4.5rem;
  line-height: 1.14;
  letter-spacing: 0.04em;
}

.contents .kitagawa-feature .kitagawa-feature-meta h2 {
  font-size: 4.5rem !important;
  line-height: 1.1 !important;
}

@media screen and (max-width: 1280px) {
  .kitagawa-feature-meta h2 { font-size: 4.4rem; }
  .contents .kitagawa-feature .kitagawa-feature-meta h2 { font-size: 4.4rem !important; }
}

.contents .kitagawa-feature .kitagawa-feature-sub {
  margin-top: -10px !important;
  color: #000c2f;
  font-size: 2.6rem;
  line-height: 1.35;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
}

.contents .kitagawa-feature .kitagawa-feature-name {
  margin-top: 6px !important;
  margin-bottom: -1px !important;
  color: #000c2f;
  font-size: 1.8rem !important;
  font-weight: 800 !important;
  line-height: 1.2;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
}

.contents .kitagawa-feature .kitagawa-feature-role {
  margin-top: 0 !important;
  margin-bottom: 4px !important;
  padding-bottom: 7px;
  border-bottom: 1px solid rgba(179, 129, 35, 0.7);
  color: #000c2f;
  font-size: 1.5rem !important;
  font-weight: 500 !important;
}

.contents .kitagawa-feature .kitagawa-feature-yomi {
  margin-top: 12px !important;
  margin-bottom: 2px !important;
  color: #b38123;
  font-size: 1.8rem;
  font-weight: 700;
}

.contents .kitagawa-feature .kitagawa-feature-bio {
  margin-top: -2px !important;
  margin-bottom: 0 !important;
  color: #b38123;
  font-size: 1.4rem !important;
  line-height: 1.65;
  font-weight: 580;
}

.kitagawa-feature-body {
  margin-top: 18px;
  padding: 0;
  column-count: 2;
  column-gap: 0px;
}

.contents .kitagawa-feature .kitagawa-feature-body {
  column-count: 2 !important;
  column-gap: 36px !important;
  column-rule: 0 none !important;
  padding-left: 15px !important;
  padding-right: 15px !important;
  box-sizing: border-box;
}

.kitagawa-feature-body p {
  margin: 0 0 1em;
  break-inside: avoid;
  color: #000c2f;
  font-size: 3rem;
  font-family: "Hiragino Maru Gothic W4 JIS2004", 游ゴシック, YuGothic, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, "Helvetica Neue", Helvetica, Arial, sans-serif;
  line-height: 1.95;
  text-align: justify;
  letter-spacing: -0.03em;
}

.contents .kitagawa-feature .kitagawa-feature-body p {
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
  width: auto !important;
  max-width: none !important;
}

.kitagawa-feature-body ruby rt {
  font-size: 0.5em;
}

.kitagawa-message {
  display: grid;
  grid-template-columns: 58fr 42fr;
  gap: 16px;
  align-items: start;
  margin: 18px 24px 0;
  padding-top: 8px;
  box-sizing: border-box;
}

.kitagawa-message-text {
  display: block;
}

.kitagawa-message-text::after {
  content: "";
  display: block;
  clear: both;
}

.contents .kitagawa-feature .kitagawa-message-label {
  margin: 0 !important;
  width: 120px;
  aspect-ratio: 1 / 1;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  float: left;
  margin-right: 12px !important;
  margin-bottom: 6px !important;
  background: #002b68;
  color: #fff;
  border: 2px solid #003c8a;
  font-size: 2.0rem !important;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.02em;
  text-align: center;
}

.contents .kitagawa-feature .kitagawa-message-label::before,
.contents .kitagawa-feature .kitagawa-message-label::after {
  content: "";
  position: absolute;
  width: 14px;
  height: 14px;
  background: #c79b1c;
}

.contents .kitagawa-feature .kitagawa-message-label::before {
  top: -2px;
  left: -2px;
}

.contents .kitagawa-feature .kitagawa-message-label::after {
  right: -2px;
  bottom: -2px;
}

.contents .kitagawa-feature .kitagawa-message-quote {
  margin: 0 !important;
  color: #1a1a1a;
  font-size: 14px !important;
  line-height: 1.8;
  font-weight: 600;
}

.kitagawa-message-photo {
  margin: 0;
}

.contents .kitagawa-feature .kitagawa-message-photo {
  margin-right: 0 !important;
  margin-top: 0 !important;
  align-self: start;
}

.kitagawa-message-photo img {
  display: block;
  width: 100%;
  height: auto;
  box-sizing: border-box;
  border: 1px solid rgba(179, 129, 35, 0.45);
}

.contents .kitagawa-feature .kitagawa-message-photo figcaption {
  margin: 6px 0 0 !important;
  color: #000;
  font-size: 1.2rem !important;
  text-align: center;
}

@media screen and (max-width: 1024px) {
  .kitagawa-feature-head {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .kitagawa-feature-photo {
    width: min(320px, 100%);
    margin: 0 auto;
    height: auto;
  }

  .kitagawa-feature-photo img {
    height: auto;
  }

  .kitagawa-feature-body {
    column-count: 1;
    column-gap: 0;
  }

  .contents .kitagawa-feature .kitagawa-feature-body {
    column-count: 1 !important;
    column-gap: 0 !important;
  }

  .kitagawa-feature-meta h2 { font-size: 3.8rem; }
  .contents .kitagawa-feature .kitagawa-feature-meta h2 { font-size: 3.8rem !important; }
  .contents .kitagawa-feature .kitagawa-feature-sub { font-size: 1.8rem; }
  .contents .kitagawa-feature .kitagawa-feature-name { font-size: 1.5rem !important; }
  .contents .kitagawa-feature .kitagawa-feature-role { font-size: 1.5rem !important; }
  .kitagawa-feature-body p { font-size: 2.4rem; }

  .kitagawa-message {
    grid-template-columns: 1fr;
    margin: 10px 24px 0;
  }

  .kitagawa-message-text {
    display: block;
  }

  .contents .kitagawa-feature .kitagawa-message-label {
    width: fit-content;
    padding: 8px 12px;
    font-size: 1.6rem !important;
    text-align: left;
  }

  .contents .kitagawa-feature .kitagawa-message-quote {
    font-size: 15px !important;
    line-height: 1.65;
  }
}

@media screen and (max-width: 700px) {
  .kitagawa-feature-inner {
    margin: 0px;
    padding: 16px 0 14px;
  }

  .kitagawa-feature-head {
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 0;
  }

  .kitagawa-feature-photo {
    width: min(280px, 100%);
    margin: 0 auto;
  }

  .kitagawa-feature-meta {
    text-align: center;
  }

  .kitagawa-feature-meta h2 {
    font-size: 3rem;
    line-height: 1.16;
    text-align: center;
  }

  .contents .kitagawa-feature .kitagawa-feature-meta h2 {
    font-size: 3rem !important;
    text-align: center !important;
  }

  .contents .kitagawa-feature .kitagawa-feature-sub {
    margin-top: -6px;
    text-align: center;
  }

  .kitagawa-message {
    margin: 10px 12px 0;
  }

  .kitagawa-feature-body {
    margin-top: 14px;
    padding: 0;
    column-count: 1;
  }

  .contents .kitagawa-feature .kitagawa-feature-name {
    margin-top: 0px !important;
    text-align: center;
  }

  .contents .kitagawa-feature .kitagawa-feature-role {
    text-align: center;
  }

  .contents .kitagawa-feature .kitagawa-feature-yomi,
  .contents .kitagawa-feature .kitagawa-feature-bio {
    text-align: left !important;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

.tokushu-next-links {
  margin: 30px 24px 10px;
  padding: 0;
  border: none;
  background: transparent;
  box-shadow: none;
}

.tokushu-next-links h2 {
  display: block;
  margin: 0 0 24px;
  padding: 0;
  color: #000c2f;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 2.15rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  border: none;
  background: transparent;
  text-align: left;
}

.tokushu-next-links-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.tokushu-next-link {
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 170px;
  padding: 16px 16px 14px 42px;
  border: 1px solid rgba(179, 129, 35, 0.42);
  background: linear-gradient(180deg, #ffffff 0%, #fbf7ee 100%);
  text-decoration: none;
  box-shadow: 0 4px 10px rgba(0, 12, 47, 0.1);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  text-align: left;
}

.tokushu-next-links-grid .tokushu-next-link:nth-child(1) {
  background: linear-gradient(180deg, #ffffff 0%, #f9f4e8 100%);
}

.tokushu-next-links-grid .tokushu-next-link:nth-child(2) {
  background: linear-gradient(180deg, #ffffff 0%, #f5f8fc 100%);
}

.tokushu-next-links-grid .tokushu-next-link:nth-child(3) {
  background: linear-gradient(180deg, #ffffff 0%, #f8f3fb 100%);
}

.tokushu-next-link::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, #b38123 0%, #f1ddae 45%, #b38123 100%);
}

.tokushu-next-link::after {
  position: absolute;
  left: 2px;
  top: -10px;
  width: 24px;
  height: 24px;
  transform: translateX(-50%);
  border: 1px solid rgba(179, 129, 35, 0.68);
  border-radius: 50%;
  background: linear-gradient(180deg, #fffdf8 0%, #f4e7c7 100%);
  color: #7a5a1c;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 24px;
  text-align: center;
  box-shadow: 0 2px 6px rgba(0, 12, 47, 0.16);
}

.tokushu-next-link-kicker,
.tokushu-next-link-title,
.tokushu-next-link-arrow {
  position: relative;
  z-index: 1;
}

.tokushu-next-link-kicker {
  display: none;
}

.tokushu-next-link-title {
  margin-top: 2px;
  color: #000c2f;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 1.74rem;
  line-height: 1.56;
  font-weight: 700;
  flex: 1;
  text-align: left;
}

.tokushu-person-prefix {
  font-size: 0.82em;
  color: #624b1f;
  font-weight: 600;
  line-height: 1.32;
}

.tokushu-next-links-grid .tokushu-next-link:nth-child(1)::after { content: "✧"; }
.tokushu-next-links-grid .tokushu-next-link:nth-child(2)::after { content: "◎"; }
.tokushu-next-links-grid .tokushu-next-link:nth-child(3)::after { content: "❖"; }

.tokushu-next-link-title small {
  display: block;
  margin-top: 6px;
  color: #624b1f;
  font-size: 0.82em;
  font-weight: 600;
  line-height: 1.5;
}

.tokushu-next-link-arrow {
  margin-top: 12px;
  color: #0d2f6e;
  font-size: 1.2rem;
  font-weight: 700;
  text-align: left;
  letter-spacing: 0.02em;
}

.tokushu-next-link:hover,
.tokushu-next-link:focus {
  border-color: transparent;
  box-shadow: 0 12px 24px rgba(0, 12, 47, 0.2);
  background: linear-gradient(180deg, #ffffff 0%, #f9f2e2 100%);
  transform: translateY(-2px);
  text-decoration: none !important;
}

.tokushu-next-link:hover *,
.tokushu-next-link:focus * {
  text-decoration: none !important;
}

@media screen and (max-width: 1024px) {
  .tokushu-next-links-grid {
    grid-template-columns: 1fr;
  }

  .tokushu-next-link {
    min-height: auto;
  }
}

@media screen and (max-width: 700px) {
  .tokushu-next-links {
    margin: 12px;
    padding: 6px 0 8px;
  }

  .tokushu-next-links h2 {
    font-size: 1.7rem;
  }

  .tokushu-next-link-title {
    font-size: 1.42rem;
  }

  .tokushu-person-prefix {
    font-size: 0.84em;
    line-height: 1.3;
  }

  .tokushu-next-link-title small {
    font-size: 0.84em;
  }
}

.contents .tokushu-next-links {
  margin: 20px 15px 10px !important;
}

.contents .tokushu-next-links h2 {
  margin: 0 0 24px !important;
  padding: 0 !important;
  text-align: left !important;
  position: relative;
  display: inline-block;
  padding-bottom: 6px !important;
}

.contents .tokushu-next-links h2::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 72px;
  height: 2px;
  background: linear-gradient(90deg, #b38123 0%, #f1ddae 100%);
}

.contents .tokushu-next-links .tokushu-person-prefix {
  display: block !important;
  font-size: 0.82em !important;
  color: #3f2f12 !important;
  font-weight: 700 !important;
  line-height: 1.34 !important;
  margin-top: 8px !important;
}

@media screen and (max-width: 700px) {
  .contents .tokushu-next-links {
    margin: 12px 15px 8px !important;
  }

  .contents .tokushu-next-links h2 {
    margin: 0 0 20px !important;
  }

  .contents .tokushu-next-links .tokushu-person-prefix {
    font-size: 0.84em !important;
    line-height: 1.32 !important;
  }
}

.tokushu-subpage {
  margin: 18px 0 14px;
  padding: 18px 16px;
  border: 1px solid rgba(179, 129, 35, 0.55);
  background: linear-gradient(180deg, #ffffff 0%, #f7f2e8 100%);
  box-shadow: 0 8px 18px rgba(0, 12, 47, 0.14);
}

.tokushu-subpage h1 {
  margin: 0 0 12px;
  color: #002b68;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 3.2rem;
  line-height: 1.45;
  letter-spacing: 0.03em;
}

.tokushu-subpage-lead {
  margin: 0 0 10px;
  color: #000c2f;
  font-size: 1.55rem;
  line-height: 1.85;
  font-weight: 600;
}

.tokushu-subpage-profile {
  margin: 0 0 10px;
  color: #b38123;
  font-size: 1.35rem;
  font-weight: 700;
}

.tokushu-subpage p {
  color: #10254a;
  line-height: 1.9;
}

@media screen and (max-width: 700px) {
  .tokushu-subpage {
    padding: 12px 10px;
  }

  .tokushu-subpage h1 {
    font-size: 2.2rem;
  }

  .tokushu-subpage-lead {
    font-size: 1.35rem;
  }
}

html,
body {
  margin-bottom: 0 !important;
  padding-bottom: 0 !important;
}

.contents {
  padding-bottom: 0 !important;
}

.contents > :last-child {
  margin-bottom: 0 !important;
}

.contents.nobel-week-page {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

.nobel-week-behind {
  position: relative;
  margin: 0 0 14px;
  padding: 60px 30px 10px 14px;
  border: none;
  background-color: #f6f0df;
  background-image: url('../img/the-backgrund.png');
  background-repeat: repeat;
  background-position: left top;
}

.nobel-week-behind::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 120px;
  height: 120px;
  background: #001f6f;
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-sizing: border-box;
  z-index: 0;
}

.nobel-week-meta-band {
  position: absolute;
  left: 3px;
  top: 5px;
  z-index: 2;
  display: inline-block;
  margin: 0;
  padding: 7px 14px 8px;
  background: #001f6f;
}

.contents.nobel-week-page .nobel-week-meta-band .date,
.contents.nobel-week-page .nobel-week-meta-band .category {
  margin: 0;
  color: #ffffff;
  font-size: 1.2rem;
  line-height: 1.45;
  letter-spacing: 0.03em;
}

.contents.nobel-week-page .nobel-week-meta-band .category {
  margin-top: 2px;
  padding-top: 2px;
  border-top: 1px solid rgba(255, 255, 255, 0.45);
  font-weight: 700;
}

.nobel-week-behind-head {
  position: relative;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-bottom: 14px;
}

.nobel-week-page .nobel-week-behind-head h1 {
  flex: 1;
  margin: 20px 0 0;
  padding: 14px 12px;
  border: 2px dashed #2f5d93;
  background: #ffffff;
  position: relative;
  z-index: 2;
  color: #002b68;
  font-family: "Yu Mincho", "Hiragino Mincho ProN", serif;
  font-size: 2.5rem;
  font-weight: 550;
  line-height: 1.4;
  letter-spacing: 0.02em;
  text-align: center;
  box-shadow: 8px 8px 0 rgba(14, 57, 110, 0.36);
}

.nobel-week-page .nobel-week-behind-head h1 .nobel-week-title-lg {
  font-size: 1.18em;
  font-weight: 900;
}

.nobel-week-page .nobel-week-behind-head h1 strong {
  font-weight: 900;
}

.nobel-week-behind-title-photo {
  width: 40%;
  min-width: 210px;
  margin: 0;
  position: relative;
  padding: 6px;
}

.nobel-week-behind-title-photo img {
  width: 100%;
  display: block;
}

.nobel-week-item {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 10px 18px;
  padding: 24px 0;
  border-top: 1px solid #001f6f;
}

.nobel-week-item:first-of-type {
  border-top: none;
}

.nobel-week-early-block {
  display: grid;
  grid-template-columns: 1fr 30%;
  gap: 12px;
  align-items: start;
}

.nobel-week-late-block {
  display: grid;
  grid-template-columns: 1fr 30%;
  gap: 12px;
  align-items: start;
}

.nobel-week-content-layout {
  display: grid;
  grid-template-columns: 1fr 28%;
  gap: 10px;
  align-items: start;
  margin-left: -15px;
}

.nobel-week-text-flow {
  text-align: left;
}

.nobel-week-side-photos {
  align-self: start;
}

.nobel-week-early-text,
.nobel-week-late-text {
  text-align: left;
}

.nobel-week-early-text .nobel-week-item:first-child {
  border-top: none;
}

.nobel-week-late-text .nobel-week-item:first-child {
  border-top: 1px solid #001f6f;
}

.nobel-week-early-photos {
  margin-top: 12px;
}

.nobel-week-early-text .nobel-week-item {
  gap: 8px 12px;
}

.nobel-week-late-text .nobel-week-item {
  gap: 8px 12px;
}

.nobel-week-early-text .nobel-week-text {
  border-left: 2px solid #001f6f;
  padding-left: 14px;
  padding-right: 14px;
}

.nobel-week-late-text .nobel-week-text {
  border-left: 2px solid #001f6f;
  padding-left: 14px;
  padding-right: 8px;
}

.nobel-week-early-text .nobel-week-text p {
  margin: 0 0 4px;
  padding: 0;
  background: none;
  border-left: none;
  color: #000000;
  font-size: 1.35rem;
  line-height: 1.55;
  font-weight: 500;
}

.nobel-week-early-text .nobel-week-text p:first-child {
  font-weight: 500;
}

.nobel-week-late-text .nobel-week-text p {
  margin: 0 0 4px;
  padding: 0;
  background: none;
  border-left: none;
  color: #000000;
  font-size: 1.35rem;
  line-height: 1.55;
  font-weight: 500;
}

.nobel-week-late-text .nobel-week-text p:first-child {
  font-weight: 500;
}

.nobel-week-text .nobel-week-link-highlight {
  color: #001f6f;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.nobel-week-text .nobel-week-link-highlight:hover {
  color: #00a0e9;
}

.nobel-week-support-text .nobel-week-link-highlight {
  color: #001f6f;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.nobel-week-support-text .nobel-week-link-highlight:hover {
  color: #00a0e9;
}

.nobel-week-top-text {
  color: #001f6f;
  font-weight: 700;
}

.nobel-week-date {
  margin: 0;
  width: 70px;
  height: 70px;
  border-radius: 50%;
  border: 2px solid #cfd4dc;
  background: radial-gradient(circle at 35% 30%, #ffffff 0%, #f7fbff 62%, #edf3fb 100%);
  color: #001f6f;
  font-weight: 700;
  font-family: "Times New Roman", "Yu Mincho", "Hiragino Mincho ProN", serif;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  line-height: 1;
  font-size: 3.8rem !important;
  letter-spacing: -0.02em;
  box-shadow: inset 0 0 0 2px #ffffff, 0 1px 0 rgba(0, 31, 111, 0.12);
  justify-self: end;
  transform: translateX(28px);
  align-self: start;
}

.nobel-week-date span {
  display: inline-block;
  font-size: 2.5rem !important;
  line-height: 1 !important;
  font-weight: 700;
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.65);
}

.nobel-week-text p {
  margin: 0 0 8px;
  padding: 4px 8px;
  color: #001c45;
  line-height: 1.75;
  font-size: 1.45rem;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.62);
  border-left: 3px solid #001f6f;
}

.nobel-week-text p:last-child {
  margin-bottom: 0;
}

.nobel-week-item-photo-right {
  grid-template-columns: 92px 1fr 30%;
}

.nobel-week-photos {
  display: grid;
  gap: 8px;
  justify-self: end;
  width: 100%;
}

.nobel-week-photo-with-source {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin: 0;
  padding: 0;
}

.nobel-week-photo-with-source figure {
  margin: 0;
}

.nobel-week-photos figure {
  margin: 0;
  position: relative;
  border: none;
}

.nobel-week-photos img {
  display: block;
  width: 100%;
  border: none;
}

.nobel-week-photos.two-photos {
  grid-template-columns: 1fr;
}

.nobel-week-item-photo-bottom {
  grid-template-columns: 92px 1fr;
}

.nobel-week-item-photo-bottom .nobel-week-photos.horizontal {
  grid-column: 2;
  grid-template-columns: 1fr 1fr;
  margin-top: 8px;
}

.photo-no {
  position: absolute;
  right: 4px;
  bottom: 4px;
  width: 16px;
  height: 16px;
  padding: 0;
  margin: 0;
  border: 1px solid #ffffff;
  background: #001f6f;
  color: #ffffff;
  font-size: 1.1rem;
  font-weight: 700;
  text-align: center;
  line-height: 16px;
}

.nobel-week-photo-with-source .photo-source {
  display: block;
  margin: 0 !important;
  padding: 0 !important;
  font-size: 1rem;
  line-height: 1.35;
  color: #333333;
  text-align: center;
  white-space: normal;
  overflow-wrap: anywhere;
}

.photo-source a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.nobel-week-ref-no {
  display: inline-block;
  width: 16px;
  height: 16px;
  margin: 0 1px;
  border: 1px solid #ffffff;
  background: #001f6f;
  color: #ffffff;
  font-size: 1.1rem;
  font-weight: 700;
  text-align: center;
  line-height: 16px;
  vertical-align: baseline;
}

.nobel-week-support-banner {
  margin: 12px 0 12px;
  padding: 30px;
  background-image: none !important;
}

.nobel-week-support-banner,
.nobel-week-support-banner * {
  background-image: none !important;
}

.nobel-week-support-banner::before,
.nobel-week-support-banner::after,
.nobel-week-support-card::before,
.nobel-week-support-card::after {
  background-image: none !important;
}

.nobel-week-support-card {
  border: 10px solid #c7d2e3;
  background: #ffffff !important;
  background-image: none !important;
  padding: 0 20px 10px 20px;
}

.nobel-week-support-title {
  position: relative;
  display: block;
  margin: -22px auto 4px;
  width: fit-content;
  max-width: calc(100% - 24px);
  box-sizing: border-box;
  padding: 8px 28px;
  background: #001f6f;
  color: #ffffff;
  font-size: 2rem;
  line-height: 1.3;
  font-weight: 700;
  text-align: center;
  clip-path: polygon(14px 0, calc(100% - 14px) 0, 100% 50%, calc(100% - 14px) 100%, 14px 100%, 0 50%);
}

.contents.nobel-week-page .nobel-week-support-banner .nobel-week-support-title {
  margin: -10px auto 4px !important;
  padding: 8px 28px !important;
  width: fit-content !important;
  max-width: calc(100% - 24px) !important;
  font-size: 2rem !important;
  line-height: 1.3 !important;
  text-align: center !important;
}

.nobel-week-support-title::before,
.nobel-week-support-title::after {
  content: none;
}

.nobel-week-support-body {
  display: grid;
  grid-template-columns: 1fr 68px;
  gap: 10px;
  align-items: end;
}

.nobel-week-support-text p {
  margin: 0 0 4px;
  color: #000000;
  font-size: 1.38rem;
  line-height: 1.6;
  font-weight: 700;
}

.contents.nobel-week-page .nobel-week-support-banner .nobel-week-support-text p {
  margin: 10px 0 4px !important;
  font-size: 1.38rem !important;
  line-height: 1.6 !important;
}

.nobel-week-support-text p:last-child {
  margin-bottom: 0;
}

.nobel-week-support-qr {
  margin: 0;
}

.nobel-week-support-qr img {
  display: block;
  width: 62px;
  height: 62px;
}

.nobel-week-stage-intro {
  margin: 12px 0 0px;
  padding: 8px 30px 0;
  background-image: url('../img/s_paper11.jpg');
  background-repeat: repeat;
  background-position: left top;
}

.nobel-week-stage-inner {
  display: grid;
  grid-template-columns: 56% 1fr;
  gap: 14px;
  align-items: stretch;
}

.nobel-week-stage-left {
  position: relative;
  margin: 0px 10px 0px 0px;
  min-height: 160px;
  padding: 34px 24px 0px 24px;
  background: linear-gradient(150deg, #eef1fc 0%, #f5f2ea 55%, #ffffff 100%);
  border-radius: 999px 999px 0 0;
  overflow: visible;
  box-shadow: 0 8px 32px rgba(0, 31, 111, 0.1), 0 2px 8px rgba(205, 191, 147, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.8);
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}

.nobel-week-stage-left::before {
  content: "✈";
  position: absolute;
  right: 14px;
  top: -26px;
  color: #b70f4f;
  font-size: 5.4rem;
  line-height: 1;
  transform: rotate(-45deg);
  filter: drop-shadow(0 2px 4px rgba(183, 15, 79, 0.25));
}

.contents.nobel-week-page .nobel-week-stage-lead {
  margin: 0 0 0px !important;
  color: #001f6f;
  font-size: 1.7rem !important;
  line-height: 1.15;
  font-weight: 700;
  transform: translate(0, 25px);
}


.contents.nobel-week-page .nobel-week-stage-left h2 {
  margin: 0 auto !important;
  color: #001f6f;
  font-size: 3.2rem !important;
  line-height: 1.2;
  font-weight: 800;
  letter-spacing: 0.01em;
  white-space: nowrap;
  transform: translate(0, 25px);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.9);
}


.contents.nobel-week-page .nobel-week-stage-stamp {
  position: absolute;
  left: 50%;
  right: auto;
  top: 3px;
  transform: translateX(-50%);
  margin: 0 !important;
  width: 100px;
  height: 116px;
  padding: 0;
  border: none;
  background: transparent;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  gap: 4px;
  text-align: center;
  line-height: 1;
  z-index: 2;
}

.contents.nobel-week-page .nobel-week-stage-stamp span {
  position: static;
  transform: none;
  color: #000000;
  font-size: 1.05rem !important;
  font-weight: 700;
  letter-spacing: 0.01em;
  white-space: nowrap;
  line-height: 1.2;
  margin-top: -2px !important;
}

.contents.nobel-week-page .nobel-week-stage-stamp::before {
  content: "";
  position: static;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 1px solid #cdbf93;
  background: #f6efd9 url('../img/icon-b.png') center / 84% no-repeat;
}

.contents.nobel-week-page .nobel-week-stage-stamp::after {
  display: none;
}

.nobel-week-stage-right {
  padding: 8px 6px 6px 12px;
  align-self: center;
}

.contents.nobel-week-page .nobel-week-stage-right p {
  margin: 0 0 6px !important;
  color: #000000;
  font-size: 1.5rem !important;
  line-height: 1.8;
  font-weight: 600;
}

.contents.nobel-week-page .nobel-week-stage-right p:last-child {
  margin-bottom: 0 !important;
}

br.sp-br { display: none; }
@media screen and (max-width: 700px) {
  br.sp-br { display: inline; }
  .nobel-week-behind {
    padding: 50px 14px 10px 14px !important;
  }

  .nobel-week-behind::before {
    width: 124px;
    height: 124px;
  }

  .nobel-week-meta-band {
    left: 10px;
    top: 8px;
    padding: 5px 10px 6px;
  }

  .contents.nobel-week-page .nobel-week-meta-band .date,
  .contents.nobel-week-page .nobel-week-meta-band .category {
    font-size: 1.15rem;
  }

  .nobel-week-behind-head {
    flex-direction: column;
  }

  .nobel-week-page .nobel-week-behind-head h1 {
    margin-top: 17px;
    margin-left: 5px;
    font-size: 2rem;
    text-align: left;
  }

  .nobel-week-behind-title-photo {
    width: 100%;
    min-width: 0;
  }

  .nobel-week-item,
  .nobel-week-item-photo-right,
  .nobel-week-item-photo-bottom {
    grid-template-columns: 66px 1fr;
  }

  .nobel-week-early-text .nobel-week-text {
    padding-left: 10px;
  }

  .nobel-week-late-text .nobel-week-text {
    padding-left: 10px;
  }

  .nobel-week-early-block {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .nobel-week-late-block {
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .nobel-week-content-layout {
    grid-template-columns: 1fr;
    gap: 6px;
    margin-left: 0;
  }

  .nobel-week-early-photos,
  .nobel-week-late-photos,
  .nobel-week-side-photos {
    justify-self: stretch;
  }

  .nobel-week-early-photos {
    margin-top: 4px;
  }

  .nobel-week-late-photos {
    margin-top: 4px;
  }

  .nobel-week-date {
    width: 54px;
    height: 54px;
    font-size: 2.8rem !important;
    transform: translateX(18px);
  }

  .nobel-week-date span {
    font-size: 2rem !important;
  }

  .nobel-week-item-photo-right .nobel-week-photos {
    grid-column: 2;
    margin-top: 8px;
  }

  .nobel-week-item-photo-bottom .nobel-week-photos.horizontal {
    grid-template-columns: 1fr;
  }

  .nobel-week-support-card {
    border-width: 8px;
    padding: 0 6px 4px;
  }

  .nobel-week-support-title {
    margin-top: -18px;
    margin-bottom: 4px;
    max-width: calc(100% - 8px);
    padding: 7px 14px;
    font-size: 1.5rem;
    clip-path: polygon(10px 0, calc(100% - 10px) 0, 100% 50%, calc(100% - 10px) 100%, 10px 100%, 0 50%);
  }

  .contents.nobel-week-page .nobel-week-support-banner .nobel-week-support-title {
    margin-top: -18px !important;
    margin-bottom: 4px !important;
    max-width: calc(100% - 8px) !important;
    padding: 7px 14px !important;
    font-size: 1.5rem !important;
    clip-path: polygon(10px 0, calc(100% - 10px) 0, 100% 50%, calc(100% - 10px) 100%, 10px 100%, 0 50%) !important;
  }

  .nobel-week-support-body {
    grid-template-columns: 1fr 52px;
    gap: 6px;
  }

  .nobel-week-support-text p {
    font-size: 1.26rem;
    line-height: 1.55;
  }

  .nobel-week-support-qr img {
    width: 48px;
    height: 48px;
  }

  .nobel-week-stage-intro {
    margin: 12px 0 12px;
    padding: 6px 30px 0;
  }

  .nobel-week-stage-inner {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .nobel-week-stage-left {
    min-height: auto;
    padding: 96px 18px 12px 18px;
    border-radius: 999px 999px 0 0;
    display: block;
  }

  .nobel-week-stage-left::before {
    right: 8px;
    top: 4px;
    font-size: 3.8rem;
  }

  .contents.nobel-week-page .nobel-week-stage-lead {
    font-size: 1.45rem !important;
  }

  .contents.nobel-week-page .nobel-week-stage-left h2 {
    font-size: 2.7rem !important;
    white-space: normal;
    transform: translate(0, 0);
  }

  .contents.nobel-week-page .nobel-week-stage-lead {
    transform: translate(0, 0);
  }

  .contents.nobel-week-page .nobel-week-stage-stamp {
    left: 50%;
    right: auto;
    top: 3px;
    bottom: auto;
    transform: translateX(-50%);
    width: 72px;
    height: 86px;
    padding: 0;
    gap: 3px;
  }

  .contents.nobel-week-page .nobel-week-stage-stamp span {
    font-size: 0.9rem !important;
  }

  .contents.nobel-week-page .nobel-week-stage-stamp::before {
    width: 52px;
    height: 52px;
    background-size: 84%;
  }

  .contents.nobel-week-page .nobel-week-stage-right p {
    font-size: 1.35rem !important;
    line-height: 1.72;
  }
}


.contents.nobel-week-page .nobel-week-back-wrap,
.contents .nobel-week-back-wrap {
  margin: 22px 0 14px !important;
  text-align: center;
}

.contents.nobel-week-page .nobel-week-back-wrap .back-to,
.contents .nobel-week-back-wrap .back-to {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 18px;
  border: 1px solid #001f6f;
  border-radius: 999px;
  background: #ffffff;
  color: #001f6f;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-decoration: none !important;
  box-shadow: 0 2px 6px rgba(0, 31, 111, 0.18);
  transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.contents.nobel-week-page .nobel-week-back-wrap .back-to:hover,
.contents .nobel-week-back-wrap .back-to:hover {
  background-color: #001f6f !important;
  color: #ffffff !important;
  box-shadow: 0 3px 8px rgba(0, 31, 111, 0.24);
}

.nobel-week-micyaku {
  margin:0;
  padding: 18px 20px 10px;
  background: #ffffff;
  border: 1px solid #d8deea;
}

.nobel-week-micyaku-item {
  display: grid;
  grid-template-columns: 104px 1fr 35%;
  gap: 10px 16px;
  align-items: start;
  padding: 14px 0;
  border-top: 1px solid #001f6f;
}

.nobel-week-micyaku-item:first-child {
  border-top: none;
  padding-top: 4px;
}

.nobel-week-micyaku-date p {
  margin: 0 !important;
  color: #ffffff;
  text-align: center;
  line-height: 1.2;
  font-weight: 700;
}

.nobel-week-micyaku-date {
  position: relative;
  width: 92px;
  margin-top: 2px;
  padding: 9px 7px 10px;
  border-radius: 18px;
  border: 2px solid #cdbf93;
  background: linear-gradient(180deg, #13407f 0%, #001f6f 100%);
  box-shadow: inset 0 0 0 1px #ffffff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
}

.nobel-week-micyaku-date::before {
  content: "";
  position: absolute;
  left: 10px;
  right: 10px;
  top: 7px;
  height: 8px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.22);
}

.nobel-week-micyaku-year {
  font-size: 1.15rem !important;
  letter-spacing: 0.02em;
}

.nobel-week-micyaku-day {
  margin-top: 1px !important;
  font-size: 3rem !important;
  line-height: 1.05 !important;
  font-family: "Times New Roman", "Yu Mincho", "Hiragino Mincho ProN", serif;
}

.nobel-week-micyaku-day .nobel-week-micyaku-num {
  font-size: 1em;
}

.nobel-week-micyaku-day .nobel-week-micyaku-unit {
  font-size: 0.58em;
  vertical-align: 0.08em;
  margin: 0 0.03em;
}

.nobel-week-micyaku-week {
  margin-top: 1px !important;
  font-size: 1.6rem !important;
  letter-spacing: 0.06em;
}

.nobel-week-micyaku-body h3 {
  margin: 0 0 8px !important;
  color: #001f6f;
  font-size: 2rem !important;
  line-height: 1.4;
  font-weight: 700;
}

.nobel-week-micyaku-subline {
  font-size: 0.78em;
}

.contents.nobel-week-page .nobel-week-micyaku-body h3.nobel-week-micyaku-heading-gap {
  margin-top: 34px !important;
}

.nobel-week-micyaku-body p {
  margin: 0 0 6px !important;
  color: #000000;
  font-size: 1.4rem !important;
  line-height: 1.85;
  font-weight: 500;
}

.nobel-week-micyaku-body p:last-child {
  margin-bottom: 0 !important;
}

.nobel-week-micyaku-comment {
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: #ece7d2;
}

.nobel-week-micyaku-comment::after {
  content: "";
  display: block;
  clear: both;
}

.nobel-week-micyaku-comment-icon {
  display: block;
  float: left;
  width: 38px;
  height: 38px;
  margin: 0 10px 4px 0;
  border-radius: 50%;
  border: none !important;
  box-shadow: none !important;
  background-color: transparent !important;
  background-image: url('../img/icon-b.png');
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}

.nobel-week-micyaku-comment p {
  margin: 0 !important;
  font-size: 1.28rem !important;
  line-height: 1.65;
  font-weight: 600;
}

.nobel-week-micyaku-comment + h3 {
  margin-top: 22px !important;
}

.nobel-week-micyaku .nobel-week-mini-ref {
  display: inline-flex;
  width: 18px;
  height: 18px;
  padding: 0;
  margin-left: 2px;
  border: 1px solid #ffffff;
  background: #b70f2f;
  color: #ffffff;
  font-size: 1.1rem;
  font-weight: 700;
  line-height: 1;
  align-items: center;
  justify-content: center;
  text-align: center;
  vertical-align: 0.16em;
  flex-shrink: 0;
}

.nobel-week-micyaku .photo-no {
  right: 4px;
  bottom: 4px;
  width: 18px;
  height: 18px;
  padding: 0;
  border: 1px solid #ffffff;
  background: #b70f2f;
  color: #ffffff;
  font-size: 1.1rem;
  font-weight: 700;
  text-align: center;
  line-height: 18px;
}

.nobel-week-micyaku-photo,
.nobel-week-micyaku-photo-single {
  margin: 0;
  position: relative;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.32);
}

.nobel-week-micyaku-photo img {
  display: block;
  width: 100%;
}

.nobel-week-micyaku-photo-circle img {
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 50%;
}

.nobel-week-micyaku-photo-circle {
  border-radius: 50%;
  width: 80%;
  justify-self: center;
}

.nobel-week-micyaku-photo-5 {
  width: 74%;
}

.nobel-week-micyaku-photo-circle .photo-no {
  z-index: 3;
}

.nobel-week-micyaku-photo-rect,
.nobel-week-micyaku-photo-rect img {
  border-radius: 0;
  aspect-ratio: auto;
}

.nobel-week-micyaku-item-no-photo {
  grid-template-columns: 104px 1fr;
}

.nobel-week-micyaku-photo-grid {
  display: grid;
  gap: 8px;
}


@media screen and (max-width: 700px) {
  .contents.nobel-week-page .nobel-week-support-banner,
  .contents.nobel-week-page .nobel-week-stage-intro {
    margin: 12px 0 !important;
  }

  .contents.nobel-week-page .nobel-week-back-wrap,
  .contents .nobel-week-back-wrap {
    margin: 18px 0 12px !important;
    text-align: center;
  }

  .contents.nobel-week-page .nobel-week-back-wrap .back-to,
  .contents .nobel-week-back-wrap .back-to {
    min-height: 36px;
    padding: 0 14px;
    font-size: 1.15rem;
  }

  .nobel-week-micyaku {
    padding: 12px 10px 6px;
  }

  .nobel-week-micyaku-item {
    grid-template-columns: 1fr;
    gap: 8px;
    padding: 10px 0;
  }

  .nobel-week-micyaku-date {
    width: 84px;
    padding: 8px 6px 9px;
  }

  .nobel-week-micyaku-year {
    font-size: 1rem !important;
  }

  .nobel-week-micyaku-day {
    margin-top: 1px !important;
    font-size: 2.5rem !important;
  }

  .nobel-week-micyaku-week {
    margin-top: 0 !important;
    font-size: 1.3rem !important;
  }

  .nobel-week-micyaku-body h3 {
    font-size: 1.7rem !important;
  }

  .nobel-week-micyaku-body p {
    font-size: 1.3rem !important;
    line-height: 1.75;
  }

  .nobel-week-micyaku-comment {
    margin-top: 8px;
    padding: 8px 10px;
  }

  .nobel-week-micyaku-comment-icon {
    width: 33px;
    height: 33px;
    margin-right: 8px;
  }

  .nobel-week-micyaku-comment p {
    font-size: 1.2rem !important;
    line-height: 1.6;
  }

  .nobel-week-micyaku-photo-grid {
    grid-template-columns: 1fr;
  }

}

/* ===== sakaguchi-mentor-walk: 散歩写真 ===== */
.sakaguchi-mentor-walk {
  clear: both;
  margin: 14px 0 0;
}

.sakaguchi-mentor-walk img {
  width: 100%;
  display: block;
}

.sakaguchi-mentor-walk figcaption {
  margin: 6px 0 0;
  color: #444;
  font-size: 1.4rem;
  line-height: 1.7;
}

.sakaguchi-bio-box {
  background: #faf7f2;
  border: 1px solid rgba(138, 104, 20, 0.28);
  border-left: 4px solid #8a6814;
  border-radius: 0 6px 6px 0;
  padding: 14px 0px;
  margin: 20px 0 0;
}

.sakaguchi-bio-label {
  display: inline-block;
  background: #8a6814;
  color: #fff;
  font-size: 1.1rem;
  font-weight: 700;
  padding: 2px 10px;
  border-radius: 3px;
  margin-bottom: 8px;
  letter-spacing: 0.05em;
}

.sakaguchi-bio-name {
  font-size: 1.5rem;
  font-weight: 700;
  color: #8a6814;
  margin: 0 0 6px;
}

.sakaguchi-bio-text {
  font-size: 1.5rem;
  line-height: 1.75;
  color: #333;
  margin: 0;
}

@media screen and (max-width: 700px) {
  .sakaguchi-bio-box {
    margin-top: 0;
  }
}