/*
Theme Name:   NANO Child
Theme URI:    https://tcd-theme.com/tcd065
Description:  NANO (tcd065) Child Theme
Author:       TCD
Author URI:   https://tcd-theme.com/
Template:     nano_tcd065
Version:      1.23.0
Text Domain:  tcd-nano-child
*/

/* ==========================================================
   Theme Name: nano_tcd065-child (Extracted Overrides from nano_jcp)
   ========================================================== */

body {
  margin: 0;
}

a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects;
}

b, strong {
  font-weight: inherit;
}

img {
  border-style: none;
}

@font-face {
  font-family: "design_plus"; src: url("../nano_tcd065/assets/fonts/design_plus.eot?v=1.0"); src: url("../nano_tcd065/assets/fonts/design_plus.eot?v=1.0#iefix") format("embedded-opentype"), url("../nano_tcd065/assets/fonts/design_plus.woff?v=1.0") format("woff"), url("../nano_tcd065/assets/fonts/design_plus.ttf?v=1.0") format("truetype"), url("../nano_tcd065/assets/fonts/design_plus.svg?v=1.0#design_plus") format("svg"); font-weight: normal; font-style: normal;
}

@font-face {
  font-family: "update_icon"; src: url("../nano_tcd065/assets/fonts/update_icon.eot?v=1.2"); src: url("../nano_tcd065/assets/fonts/update_icon.eot?v=1.2#iefix") format("embedded-opentype"), url("../nano_tcd065/assets/fonts/update_icon.woff?v=1.2") format("woff"), url("../nano_tcd065/assets/fonts/update_icon.ttf?v=1.2") format("truetype"), url("../nano_tcd065/assets/fonts/update_icon.svg?v=1.2#update_icon") format("svg"); font-weight: normal; font-style: normal;
}

.l-contents--no-border .l-contents__inner {
  margin-top: 00px;
}

.l-header {
  background: #ffffff;
  border-bottom: 1px solid rgba(26, 54, 93, 0.08);
  box-shadow: 0 4px 30px rgba(26, 54, 93, 0.03);
  transition: background 0.3s ease, box-shadow 0.3s ease;
}

.l-header--fixed.is-active {
  -webkit-animation: slideDown 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  animation: slideDown 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  background: rgba(255, 255, 255, 0.98);
  backdrop-filter: blur(8px);
  box-shadow: 0 10px 30px rgba(26, 54, 93, 0.06);
}

.l-header__inner {
  gap: 0;
}

.l-header__logo {
  margin-right: 0;
  padding-right: 32px;
  border-right: 1px solid rgba(26, 54, 93, 0.12);
  transition: transform 0.3s ease, opacity 0.3s ease;
  flex-shrink: 0;
}

.l-header__logo:hover {
  transform: scale(1.02);
  opacity: 0.85;
}

.l-header__desc {
  padding-left: 28px;
  font-size: 13px;
  font-weight: 500;
  color: #4a5568;
  letter-spacing: 0.04em;
  line-height: 1.5;
  position: relative;
}

.l-header__search:hover {
  color: #086823;
}

.l-main {
  overflow: hidden;
}

.c-comment input, .c-comment textarea {
  border-radius: 0;
  box-sizing: border-box;
}

.c-share__btn {
  list-style: none;
}

.p-news-tab-list__panel.p-news-list {
  background: #ffffff !important;
  border-radius: 12px !important;
  border: 1px solid rgba(26, 54, 93, 0.06) !important;
  box-shadow: 0 8px 30px rgba(26, 54, 93, 0.03) !important;
  overflow: hidden !important;
  padding: 0 !important;
  margin-bottom: 30px !important;
}

.p-article04 {
  background: #ffffff !important;
  border: 0 !important;
  border-bottom: 1px solid rgba(26, 54, 93, 0.05) !important;
  position: relative !important;
  overflow: hidden !important;
  transition: background-color 0.3s ease !important;
}

.p-article04:last-child {
  border-bottom: 0 !important;
}

.p-article04::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 4px !important;
  height: 100% !important;
  background-color: #086823 !important;
  transform: scaleY(0) !important;
  transform-origin: center !important;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  z-index: 2 !important;
}

.p-article04:hover::before {
  transform: scaleY(1) !important;
}

.p-article04:hover {
  background-color: rgba(8, 104, 35, 0.01) !important;
}

.p-article04__inner {
  display: flex !important;
  align-items: center !important;
  padding: 0 32px !important;
  height: 64px !important;
  line-height: 64px !important;
}

.p-article04__date {
  font-family: "Outfit", "Inter", sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #1a365d !important;
  margin-right: 28px !important;
  letter-spacing: 0.05em !important;
}

.p-article04__title {
  font-size: 14.5px !important;
  font-weight: 500 !important;
  color: #2d3748 !important;
  flex: 1 !important;
  margin-bottom: 0 !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
}

.p-article04__title a {
  display: block !important;
  height: 100% !important;
  color: inherit !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  white-space: nowrap !important;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s ease !important;
}

.p-article04:hover .p-article04__title a {
  transform: translateX(8px) !important;
  color: #086823 !important;
}

.p-works-list__item.p-article06 {
  background: #ffffff !important;
  border-radius: 12px !important;
  border: 1px solid rgba(26, 54, 93, 0.07) !important;
  box-shadow: 0 6px 20px rgba(26, 54, 93, 0.03) !important;
  padding: 24px !important;
  box-sizing: border-box !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
  transition-property: transform, box-shadow, border-color !important;
  overflow: hidden !important;
}

.p-works-list__item.p-article06:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 22px 40px rgba(8, 104, 35, 0.08) !important;
  border-color: rgba(8, 104, 35, 0.15) !important;
}

.p-article06__img {
  width: 100% !important;
  height: auto !important;
  border-radius: 6px !important;
  overflow: hidden !important;
  margin-bottom: 0 !important;
  border: 1px solid rgba(26, 54, 93, 0.04) !important;
  box-shadow: 0 4px 12px rgba(26, 54, 93, 0.02) !important;
  display: block !important;
  transition: opacity 0.3s ease !important;
}

.p-article06__img img {
  width: 100% !important;
  height: auto !important;
  object-fit: cover !important;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-works-list__item.p-article06:hover .p-article06__img img {
  transform: scale(1.04) !important;
}

.p-article06__content {
  width: 100% !important;
  padding: 20px 0 0 0 !important;
  margin: 0 !important;
  border-left: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
}

.p-article06__title {
  font-size: 17px !important;
  font-weight: 700 !important;
  line-height: 1.6 !important;
  color: #1a365d !important;
  margin: 0 0 12px 0 !important;
  padding-left: 14px !important;
  border-left: 3px solid #086823 !important;
  min-height: auto !important;
  transition: color 0.3s ease !important;
}

.p-article06__title a {
  color: #1a365d !important;
  text-decoration: none !important;
  transition: color 0.3s ease !important;
}

.p-works-list__item.p-article06:hover .p-article06__title a {
  color: #086823 !important;
}

.p-article06__excerpt {
  font-size: 13.5px !important;
  line-height: 1.7 !important;
  color: #4a5568 !important;
  margin: 0 !important;
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important;
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.p-article11 {
  overflow: hidden;
  border-radius: 8px;
}

.p-article11 a {
  display: block;
  position: relative;
  overflow: hidden;
  z-index: 1;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(26, 54, 93, 0.06);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-article11 a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, rgba(26, 54, 93, 0) 0%, rgba(26, 54, 93, 0) 35%, rgba(8, 104, 35, 0.72) 100%);
  z-index: 2;
  transition: background 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-article11 a:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 38px rgba(8, 104, 35, 0.12);
  border-color: rgba(8, 104, 35, 0.15);
}

.p-article11 a:hover::before {
  background: linear-gradient(to right, rgba(26, 54, 93, 0.1) 0%, rgba(26, 54, 93, 0.05) 35%, rgba(8, 104, 35, 0.8) 100%);
}

.p-article11__content {
  z-index: 3;
  box-sizing: border-box;
  pointer-events: none;
}

.p-article11__title {
  font-size: 24px;
  font-weight: 700;
  color: #ffffff !important;
  margin-bottom: 8px;
  transition: padding-left 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.p-article11__sub {
  font-size: 13px;
  color: #4ade80 !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: padding-left 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-article11 a:hover .p-article11__title, .p-article11 a:hover .p-article11__sub {
  padding-left: 10px;
}

.p-article11 img {
  width: 100%;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  display: block;
  position: relative;
  z-index: 1;
}

.p-article11 a:hover img {
  transform: scale(1.06);
}

.p-index-content04__list.p-three-box {
  display: flex !important;
  gap: 28px !important;
  margin-right: 0 !important;
  margin-left: 0 !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
}

.p-three-box__item.p-article12 {
  background: #ffffff !important;
  border-radius: 12px !important;
  border: 1px solid rgba(26, 54, 93, 0.07) !important;
  box-shadow: 0 6px 20px rgba(26, 54, 93, 0.03) !important;
  width: calc(33.333% - 19px) !important;
  margin-right: 0 !important;
  margin-left: 0 !important;
  margin-bottom: 0 !important;
  overflow: hidden !important;
  box-sizing: border-box !important;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s ease, border-color 0.4s ease !important;
}

.p-three-box__item.p-article12:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 22px 42px rgba(8, 104, 35, 0.09) !important;
  border-color: rgba(8, 104, 35, 0.15) !important;
}

.p-article12:first-child .p-article12__img,
.p-article12:last-child .p-article12__img {
  border-left: 0 !important;
  border-right: 0 !important;
}

.p-article12 a {
  display: block !important;
  position: relative !important;
  height: 380px !important;
  overflow: hidden !important;
}

.p-article12__header {
  border: 0 !important;
  background: transparent !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  text-align: center !important;
  width: 100% !important;
  height: 120px !important;
  position: absolute !important;
  top: 0 !important;
  z-index: 2 !important;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-article12__title {
  font-size: 19px !important;
  font-weight: 700 !important;
  color: #1a365d !important;
  margin-bottom: 4px !important;
  transition: color 0.3s ease !important;
}

.p-article12__sub {
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  color: #086823 !important;
  transition: color 0.3s ease !important;
}

.p-article12 a:hover .p-article12__title {
  color: #ffffff !important;
}

.p-article12 a:hover .p-article12__sub {
  color: rgba(255, 255, 255, 0.8) !important;
}

.p-article12__desc {
  color: #ffffff !important;
  font-size: 13.5px !important;
  line-height: 1.8 !important;
  padding: 0 24px !important;
  width: 100% !important;
  box-sizing: border-box !important;
  opacity: 0 !important;
  transition: opacity 0.3s ease, transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 3 !important;
}

.p-article12 a:hover .p-article12__desc {
  opacity: 1 !important;
}

.p-article12__img {
  width: 100% !important;
  height: 100% !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  z-index: 1 !important;
  transform: translateY(120px) !important;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-article12__img::before {
  content: "" !important;
  opacity: 0 !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(135deg, rgba(26, 54, 93, 0.95), rgba(8, 104, 35, 0.95)) !important;
  z-index: 2 !important;
  transition: opacity 0.4s ease !important;
}

.p-article12 a:hover .p-article12__img {
  transform: translateY(0) !important;
}

.p-article12 a:hover .p-article12__img::before {
  opacity: 1 !important;
}

.p-article12__img img {
  object-fit: cover !important;
  width: 100% !important;
  height: 100% !important;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-article12 a:hover .p-article12__img img {
  transform: scale(1.05) !important;
}

.p-banner {
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 28px rgba(26, 54, 93, 0.08);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s ease;
  display: block;
}

.p-banner:hover,
.p-footer-banners__list-item:hover .p-banner {
  transform: translateY(-7px);
  box-shadow: 0 22px 44px rgba(26, 54, 93, 0.15);
}

.p-banner a {
  display: block;
  width: 100%;
  height: 100%;
}

.p-banner img {
  display: block;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  transform-origin: center center;
}

.p-banner:hover img {
  transform: scale(1.04);
}

.p-entry__share {
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  justify-content: center;
}

.p-footer-banners {
  border-bottom: 1px solid rgba(26, 54, 93, 0.07);
  padding: 70px 0;
  background: #f7f9fc;
}

.p-footer-banners__list {
  gap: 28px;
}

.p-footer-banners__list-item {
  margin-right: 0;
}

.p-footer-widget {
  padding: 50px 2.9661% 42px;
}

.p-footer-widget a {
  color: inherit;
}

.p-global-nav {
  line-height: 100px;
  height: 100px;
}

.p-global-nav > li {
  border: 0;
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-global-nav > li > a {
  padding: 0 16px;
  display: flex !important;
  align-items: center;
  justify-content: center;
  color: #334155 !important;
  font-weight: 600;
  font-family: 'Outfit', 'Inter', "Noto Sans JP", sans-serif;
  letter-spacing: 0.06em;
  transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-global-nav > li > a::after {
  content: "";
  position: absolute;
  bottom: 26px;
  left: 50%;
  width: 0;
  height: 2px;
  background: #086823;
  transition: width 0.3s cubic-bezier(0.16, 1, 0.3, 1), left 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-global-nav > li > a:hover {
  color: #086823 !important;
}

.p-global-nav > li > a:hover::after {
  width: 32px;
  left: calc(50% - 16px);
}

.p-global-nav .sub-menu {
  transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease !important;
  background: #ffffff;
  border-radius: 6px;
  box-shadow: 0 10px 40px rgba(26, 54, 93, 0.08);
  border: 1px solid rgba(26, 54, 93, 0.04);
  padding: 8px 0;
}

.p-global-nav .sub-menu a {
  padding: 14px 28px 14px 24px;
  color: #475569 !important;
  font-weight: 500;
  transition: padding-left 0.3s cubic-bezier(0.16, 1, 0.3, 1), color 0.3s cubic-bezier(0.16, 1, 0.3, 1), background-color 0.3s ease !important;
  position: relative;
}

.p-global-nav .sub-menu a::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%) scaleX(0);
  width: 3px;
  height: 14px;
  background: #086823;
  transform-origin: left;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-global-nav .sub-menu a:hover {
  padding-left: 28px;
  color: #086823 !important;
  background-color: rgba(8, 104, 35, 0.03);
}

.p-global-nav .sub-menu a:hover::before {
  transform: translateY(-50%) scaleX(1);
}

.p-index-content05__item {
  display: flex;
  flex-direction: column;
}

.p-index-content05__item-banner {
  position: relative;
  border-radius: 8px;
}

.p-index-content05__item-banner a {
  display: block;
  position: relative;
  width: 100%;
  aspect-ratio: 570 / 150;
  overflow: hidden;
  z-index: 1;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  border: 1px solid rgba(26, 54, 93, 0.06);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  background: #f8f9ff;
}

.p-index-content05__item-banner a:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 38px rgba(8, 104, 35, 0.12);
  border-color: rgba(8, 104, 35, 0.15);
}

.p-index-content05__item-banner img {
  display: none !important;
}

.p-index-content05__item-banner a::before {
  display: none !important;
}

.p-index-content05__item-banner a:hover::before {
  display: none !important;
}

.p-index-content05__item-banner a::after {
  content: "" !important;
  position: absolute;
  top: 0;
  left: 0;
  width: 60px;
  height: 60px;
  background: linear-gradient(135deg, #1a365d 0%, #086823 100%) !important;
  clip-path: polygon(0 0, 100% 0, 0 100%) !important;
  z-index: 4;
  pointer-events: none;
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.p-index-content05__item-banner a:hover::after {
  transform: scale(1.08) !important;
}

.p-article11__svg-container {
  position: absolute;
  right: 48px;
  top: 50%;
  transform: translateY(-50%);
  width: 90px;
  height: 90px;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.p-article11__svg {
  width: 100%;
  height: 100%;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-index-content05__item-banner a:hover .p-article11__svg {
  transform: scale(1.12) rotate(6deg);
}

.p-index-content05__item-banner .p-article11__content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: 32px 160px 32px 48px;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  box-sizing: border-box;
  pointer-events: none;
}

.p-index-content05__item--1 .p-index-content05__item-banner .p-article11__title,
.p-index-content05__item--2 .p-index-content05__item-banner .p-article11__title {
  color: #1a365d !important;
  text-shadow: none !important;
}

.p-index-content05__item--1 .p-index-content05__item-banner .p-article11__sub,
.p-index-content05__item--2 .p-index-content05__item-banner .p-article11__sub {
  color: #086823 !important;
}

.p-index-content05__item-banner .p-article11__title {
  font-size: 24px;
  font-weight: 700;
  color: #1a365d !important;
  margin-bottom: 8px;
  transition: padding-left 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-index-content05__item-banner .p-article11__sub {
  font-size: 13px;
  font-weight: 700;
  color: #086823 !important;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  transition: padding-left 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-index-content05__item-banner a:hover .p-article11__title, .p-index-content05__item-banner a:hover .p-article11__sub {
  padding-left: 10px;
}

.p-index-content05__item--3 .p-index-content05__item-banner a {
  overflow: hidden;
  position: relative;
  border: 1px solid rgba(26, 54, 93, 0.06);
}

.p-index-content05__item--3 .p-index-content05__item-banner img {
  width: calc(100% + 12px) !important;
  height: calc(100% + 12px) !important;
  margin: -6px !important;
  max-width: none !important;
}

.p-index-content05__item--3 .p-index-content05__item-banner a:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 20px 38px rgba(8, 104, 35, 0.12) !important;
  border-color: rgba(8, 104, 35, 0.15) !important;
}

.p-index-content05__item--3 .p-index-content05__item-banner a:hover img {
  transform: scale(1.06) !important;
}

.p-index-content05__item--3 .p-index-content05__item-banner .p-article11__title {
  font-size: 0 !important;
}

.p-index-content05__item--3 .p-index-content05__item-banner .p-article11__title::before {
  content: "展示会出展情報";
  font-size: 24px !important;
  color: #1a365d !important;
  font-weight: 700 !important;
  text-shadow: none !important;
}

.p-index-content05__item--3 .p-index-content05__item-banner .p-article11__sub {
  font-size: 0 !important;
}

.p-index-content05__item--3 .p-index-content05__item-banner .p-article11__sub::before {
  content: "EXHIBITION INFO";
  font-size: 13px !important;
  color: #086823 !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
}

.p-widget {
  line-height: 1.7;
  margin-bottom: 50px;
}

.l-secondary .widget_nav_menu ul li, .widget_meta ul li, .widget_pages ul li, .widget_archive ul li, .widget_categories ul li {
  font-size: 1em;
  margin: 0;
  padding: 0;
  line-height: 1;
}

.p-entry__body .alignright {
  float: right;
}

.p-entry__body .alignleft {
  float: left;
}

.p-entry__body .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 7px;
}

.wp-block-image .aligncenter,.wp-block-image .alignleft,.wp-block-image .alignright,.wp-block-image.aligncenter,.wp-block-image.alignleft,.wp-block-image.alignright {
  display: table;
}

.p-entry__body blockquote.alignleft, .p-entry__body img.alignleft {
  margin: 7px 24px 7px 0;
}

.p-entry__body .wp-caption.alignleft {
  margin: 7px 14px 7px 0;
}

.p-entry__body blockquote.alignright, .p-entry__body img.alignright {
  margin: 7px 0 7px 24px;
}

.p-entry__body .wp-caption.alignright {
  margin: 7px 0 7px 14px;
}

.p-entry__body blockquote.aligncenter, .p-entry__body img.aligncenter, .p-entry__body .wp-caption.aligncenter {
  margin-top: 7px;
  margin-bottom: 7px;
}

.p-entry__body h1, .p-entry__body h2, .p-entry__body h3, .p-entry__body h4, .p-entry__body h5, .p-entry__body h6 {
  clear: both;
  line-height: 1.4;
  margin-bottom: 24.2px;
}

.p-entry__body h1 {
  font-size: 150%;
}

.p-entry__body h2 {
  font-size: 140%;
}

.p-entry__body h3 {
  font-size: 130%;
}

.p-entry__body h4 {
  font-size: 120%;
}

.p-entry__body h5 {
  font-size: 110%;
}

.p-entry__body h6 {
  font-size: 100%;
}

.p-entry__body img[class*="align"], .p-entry__body img[class*="wp-image-"], .p-entry__body img[class*="attachment-"], .p-entry__body .size-full, .p-entry__body .size-large, .p-entry__body .wp-post-image, .p-entry__body img {
  max-width: 100%;
  height: auto;
}

.p-entry__body li, .p-entry__body dt, .p-entry__body dd {
  line-height: 2.2;
}

.p-entry__body ul, .p-entry__body ol, .p-entry__body dl {
  margin-bottom: 24px;
}

.p-entry__body ol {
  list-style: decimal outside none;
  margin-left: 1.5em;
}

.p-entry__body ul {
  list-style: circle outside none;
  margin-left: 1.3em;
}

.p-entry__body li > ul, .p-entry__body li > ol {
  margin-bottom: 0;
}

.p-entry__body dt {
  font-weight: bold;
}

.p-entry__body dd {
  margin-bottom: 1em;
}

.p-entry__body table {
  margin: 0 0 24px 0;
  border-collapse: collapse;
}

.p-entry__body td, .p-entry__body th {
  border: 1px solid #ddd;
  padding: 10px 15px 7px;
  line-height: 2.2;
  font-size: 14px;
}

.p-entry__body th {
  background: #fafafa;
  font-weight: normal;
}

.table_no_border th, .table_no_border td {
  border: none;
  padding-left: 0;
}

.table_border_horizontal th, .table_border_horizontal td {
  border-left: none;
  border-right: none;
  padding-left: 0;
}

.p-entry__body blockquote {
  margin: 0 0 25px 0;
  padding: 27px 30px 0;
  border: 1px solid #ccc;
  box-shadow: 0px 4px 0px 0px #f2f2f2;
  position: relative;
}

.p-entry__body blockquote:before {
  content: '"';
  font-style: italic;
  font-size: 30px;
  font-weight: normal;
  line-height: 40px;
  width: 30px;
  height: 30px;
  position: absolute;
  top: 5px;
  left: 10px;
  color: #5cbcd7;
}

.p-entry__body blockquote:after {
  content: '"';
  font-style: italic;
  font-size: 30px;
  font-weight: normal;
  text-align: left;
  line-height: 60px;
  width: 30px;
  height: 30px;
  position: absolute;
  bottom: 7px;
  right: 0;
  color: #5cbcd7;
}

.p-entry__body blockquote cite {
  border-top: 1px dotted #aaa;
  display: block;
  padding: 20px 0 0 0;
  font-style: italic;
  text-align: right;
  font-size: 90%;
}

.p-entry__body .wp-caption {
  margin-bottom: 24px;
  background: #fff;
  border: 1px solid #ccc;
  padding: 5px;
  max-width: 100%;
  border-radius: 5px;
  box-sizing: border-box;
}

.p-entry__body .wp-caption-text {
  text-align: center;
  font-size: 12px;
  font-style: italic;
  line-height: 1.5;
  margin: 9px auto;
}

.p-entry__body .wp-caption img[class*="wp-image-"] {
  display: block;
  margin: 0 auto;
}

.gallery {
  margin-bottom: 20px;
}

.gallery a img {
  border: 0 !important;
}

.gallery-item {
  float: left;
  margin: 0 4px 4px 0;
  overflow: hidden;
  position: relative;
}

.gallery-columns-1 .gallery-item {
  max-width: 100%;
}

.gallery-columns-2 .gallery-item {
  max-width: calc(50% - 4px);
}

.gallery-columns-3 .gallery-item {
  max-width: calc(33.3% - 4px);
}

.gallery-columns-4 .gallery-item {
  max-width: calc(25% - 4px);
}

.gallery-columns-5 .gallery-item {
  max-width: calc(20% - 4px);
}

.gallery-columns-6 .gallery-item {
  max-width: calc(16.7% - 4px);
}

.gallery-columns-7 .gallery-item {
  max-width: calc(14.28% - 4px);
}

.gallery-columns-8 .gallery-item {
  max-width: calc(12.5% - 4px);
}

.gallery-columns-9 .gallery-item {
  max-width: calc(11.1% - 4px);
}

.gallery-columns-10 .gallery-item {
  max-width: calc(9.4% - 0px);
}

.gallery-columns-1 .gallery-item:nth-of-type(1n), .gallery-columns-2 .gallery-item:nth-of-type(2n), .gallery-columns-3 .gallery-item:nth-of-type(3n), .gallery-columns-4 .gallery-item:nth-of-type(4n), .gallery-columns-5 .gallery-item:nth-of-type(5n), .gallery-columns-6 .gallery-item:nth-of-type(6n), .gallery-columns-7 .gallery-item:nth-of-type(7n), .gallery-columns-8 .gallery-item:nth-of-type(8n), .gallery-columns-9 .gallery-item:nth-of-type(9n), .gallery-columns-10 .gallery-item:nth-of-type(10n) {
  margin-right: 0;
}

.gallery-caption {
  background-color: rgba(0, 0, 0, 0.7);
  box-sizing: border-box;
  color: #fff;
  font-size: 12px;
  line-height: 1.5;
  margin: 0;
  max-height: 50%;
  opacity: 0;
  padding: 6px 8px;
  position: absolute;
  bottom: 0;
  left: 0;
  text-align: left;
  width: 100%;
}

.gallery-caption:before {
  content: "";
  height: 100%;
  min-height: 49px;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.gallery-item:hover .gallery-caption {
  opacity: 1;
}

.gallery-columns-7 .gallery-caption, .gallery-columns-8 .gallery-caption, .gallery-columns-9 .gallery-caption, .gallery-columns-10 .gallery-caption {
  display: none;
}

.p-entry__body .wp-smiley {
  border: 0;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0;
}

.p-entry__body address {
  margin: 0 0 24px 0;
  line-height: 2.2;
}

.p-entry__body pre {
  border-left: 5px solid #7fc120;
  font-size: 12px;
  margin: 0 0 27px 0;
  line-height: 25px;
  padding: 0 17px;
  overflow: auto;
}

.p-entry__body .mejs-container {
  margin: 12px 0 25px;
}

.post_row {
  line-height: 2.4;
  margin-left: -25px;
  margin-right: -25px;
}

.post_row:before, .post_row:after {
  content: " ";
  display: table;
}

.post_row:after {
  clear: both;
}

.post_col, .post_col-2, .post_col-3 {
  float: left;
  margin-bottom: 2em;
  min-height: 1px;
  padding-left: 25px;
  padding-right: 25px;
  position: relative;
  width: 100%;
  box-sizing: border-box;
}

.style2a, .style2b, .style3a, .style3b, .style4a, .style4b, .style5a, .style5b, .style6 {
  line-height: 1.6;
  font-weight: 500;
}

.style2a {
  margin: 65px 0 30px !important;
  padding: 0 0 .9em;
  border-bottom: 3px solid #000;
  font-size: 26px !important;
}

.style2b {
  margin: 65px 0 30px !important;
  padding: .48em 1em .47em;
  font-size: 26px !important;
  color: #fff;
  background: #000;
}

.style3a {
  margin: 65px 0 30px !important;
  padding: 1.2em .15em;
  font-size: 22px !important;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.style3b {
  margin: 65px 0 30px !important;
  padding: 1.1em 1.4em 1.15em;
  font-size: 22px !important;
  background: #fafafa;
  border: 1px solid #ddd;
  border-top: 3px solid #000;
}

.style4a {
  margin: 65px 0 30px !important;
  padding: .4em 0 .4em 1.2em;
  border-left: 3px solid #000;
  font-size: 20px !important;
  font-weight: 500;
}

.style4b {
  position: relative;
  margin: 65px 0 30px !important;
  padding: .8em 1.5em .8em;
  border-left: #000 3px solid;
  font-size: 20px !important;
  box-sizing: border-box;
}

.style4b:after {
  position: absolute;
  top: 0;
  left: 0;
  content: '';
  width: 100%;
  height: calc(100% - 2px);
  border: 1px solid #ddd;
  border-left: none;
}

.style5a {
  margin: 65px 0 30px !important;
  padding: .85em 1.5em .8em;
  font-size: 18px !important;
  background: #fafafa;
  border: 1px solid #ddd;
}

.style5b {
  margin: 65px 0 30px !important;
  padding: .85em 1.5em .8em;
  font-size: 18px !important;
  color: #fff;
  background: #000;
}

.style6 {
  position: relative;
  margin: 65px 0 30px !important;
  padding: 0 .8em 0 1.3em;
  color: #000;
  font-size: 16px !important;
  font-weight: 700;
}

.style6:before {
  background: #000;
  content: "";
  position: absolute;
  top: .35em;
  left: 0;
  width: 12px;
  height: 12px;
}

.news_headline1 {
  border-left: 8px solid #444;
  font-size: 1.2em;
  line-height: 1.2;
  margin: 80px 0 25px 0;
  padding: .5em;
  position: relative;
}

.news_headline1:after {
  border-bottom: 1px dotted #ddd;
  content: "";
  position: absolute;
  bottom: 0px;
  left: 0;
  width: 100%;
  height: 0;
}

.news_headline2 {
  border-left: 6px solid #545454;
  font-size: 1.1em;
  line-height: 26px;
  margin: 40px 0 20px 0;
  padding: 0 .5em;
}

.balloon {
  background: #222;
  border-bottom: 0;
  clear: both;
  color: #fff;
  display: block;
  font-size: 20px;
  font-weight: 400;
  margin: 50px 0 22px;
  min-width: 115px;
  padding: .5em 18px .5em;
  position: relative;
  text-align: left;
  width: auto;
  z-index: 0;
}

.balloon:after {
  border-color: #222 transparent transparent transparent;
  border-style: solid;
  border-width: 10px 10px 0 10px;
  bottom: -10px;
  content: "";
  display: block;
  margin-left: -10px;
  position: absolute;
  left: 30px;
  width: 0px;
  height: 0px;
}

.well {
  margin-bottom: 30px;
  padding: 1.1em 2em;
  background-color: #fafafa;
  border: 1px solid #ddd;
  border-radius: 6px;
  line-height: 1.8;
}

.well2 {
  margin-bottom: 30px;
  padding: 1.1em 2em;
  border: 1px solid #ddd;
  line-height: 1.8;
}

.well3 {
  margin-bottom: 30px;
  padding: 1.1em 2em;
  border: 1px dashed #ddd;
  background: #fafafa;
  line-height: 1.8;
}

.wl_red {
  background-color: #f2dede;
  border-color: #ebccd1;
  color: #a94442;
}

.wl_yellow {
  background-color: #fcf8e3;
  border-color: #faebcc;
  color: #8a6d3b;
}

.wl_blue {
  background-color: #d9edf7;
  border-color: #bce8f1;
  color: #31708f;
}

.wl_green {
  background-color: #dff0d8;
  border-color: #d6e9c6;
  color: #3c763d;
}

.q_button {
  background-color: #535353;
  box-sizing: border-box;
  color: #fff !important;
  display: inline-block;
  font-size: 100%;
  font-weight: 400;
  min-width: 200px;
  margin: 0;
  max-width: 90%;
  padding: .6em 1.3em .5em;
  transition: all 0.3s ease-in-out 0s;
  text-decoration: none;
  text-align: center;
  vertical-align: middle;
}

.q_button:hover, .q_button:focus {
  background-color: #7d7d7d;
  color: #fff;
  text-decoration: none;
}

.q_button_wrap {
  text-align: center;
  margin: 2em auto;
}

.rounded {
  border-radius: 6px;
}

.pill {
  border-radius: 50px;
}

.sz_full {
  display: block;
  font-size: 110%;
  max-width: 100%;
  min-width: 100px;
  padding: 1em 1.5em .9em;
}

.sz_l {
  font-size: 110%;
  max-width: 90%;
  min-width: 350px;
  padding: .8em 1.5em .7em;
}

.sz_s {
  min-width: 100px;
  max-width: 90%;
  font-size: 85%;
  padding: .4em 1em .3em;
}

.bt_red {
  background: #c01f0e;
  color: #fff;
}

.bt_red:hover, .bt_red:focus {
  background-color: #d33929;
  color: #fff;
}

.bt_yellow {
  background: #f1c40f;
  color: #fff;
}

.bt_yellow:hover, .bt_yellow:focus {
  background-color: #f9d441;
  color: #fff;
}

.bt_blue {
  background: #2980b9;
  color: #fff;
}

.bt_blue:hover, .bt_blue:focus {
  background-color: #3a91c9;
  color: #fff;
}

.bt_green {
  background: #27ae60;
  color: #fff;
}

.bt_green:hover, .bt_green:focus {
  background-color: #39c574;
  color: #fff;
}

.ytube {
  position: relative;
  height: 0;
  margin-top: 20px;
  margin-bottom: 20px;
  padding-bottom: 56.25%;
  padding-top: 30px;
  overflow: hidden;
}

.ytube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;
}

.rps_table {
  line-height: 2.0;
}

.cardlink {
  padding: 20px;
  margin: 10px 0;
  border: 1px solid #ddd;
  word-wrap: break-word;
  max-width: 100%;
  background: #fafafa;
}

.cardlink_thumbnail {
  float: left;
  margin-right: 25px;
}

.cardlink_thumbnail img {
  width: 130px;
  height: 130px;
  -o-object-fit: cover;
  object-fit: cover;
}

.cardlink_content {
  line-height: 1.6;
}

.cardlink_timestamp {
  display: inline;
  margin: 0;
  padding: 0;
  vertical-align: top;
  color: #222;
  line-height: 1;
  font-size: 12px;
}

.cardlink_title {
  font-size: 16px;
  margin: -3px 0 5px;
}

.cardlink_title a {
  font-weight: bold;
  color: #000;
  text-decoration: none;
}

.cardlink_title a:hover {
  text-decoration: underline;
}

.cardlink_excerpt {
  color: #000;
  font-size: 14px;
  overflow: hidden;
  line-height: 1.9;
}

.cardlink_footer {
  clear: both;
}

.clear {
  clear: both;
}

.wpcf7 {
  background: #fafafa;
  border: 1px solid #ddd;
  font-size: 14px;
  margin: 0 0 2.5em !important;
  padding: 0;
  width: 100%;
}

.wpcf7 form {
  margin: 1.5em 1.5em 0;
}

.wpcf7 p {
  margin-bottom: 1em;
  font-size: 16px;
}

.wpcf7 input, .wpcf7 textarea {
  border: 1px solid #ccc;
  box-sizing: border-box;
  line-height: 1.2;
  padding: 8px;
  width: 100%;
}

.wpcf7 select, .wpcf7 input[type=checkbox], .wpcf7 input[type=radio] {
  border: 1px solid #ccc;
  max-width: 97%;
  padding: 8px;
  width: auto;
}

.wpcf7 select, .wpcf7 .wpcf7-list-item-label {
  font-size: 14px;
  line-height: 1.2;
}

.wpcf7 .wpcf7-list-item {
  display: block;
}

.wpcf7 textarea {
  height: 300px;
}

.wpcf7 input:focus, .wpcf7 textarea:focus {
  border: 1px solid #bbb;
  outline: none;
}

.wpcf7 .wpcf7-submit, .wpcf7 .wpcf7-previous {
  box-sizing: border-box;
  position: relative;
  display: block;
  width: 225px;
  height: 48px;
  margin: 30px auto 0;
  background-color: #333333;
  cursor: pointer;
  border: none !important;
  color: #fff;
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  line-height: 1.5;
  outline: none;
  transition: all .3s;
}

.wpcf7 .wpcf7-submit:before, .wpcf7 .wpcf7-submit:after {
  box-sizing: border-box;
}

.wpcf7 .wpcf7-submit:hover, .wpcf7 .wpcf7-previous:hover {
  background-color: #666666;
}

.wpcf7 .wpcf7-submit .wpcf7-not-valid {
  background: pink;
}

.wpcf7 .wpcf7-submit .wpcf7-response-output {
  margin: 10px 0 0;
  padding: 8px 35px 8px 14px;
  border-radius: 4px;
}

.wpcf7 .wpcf7-submit .wpcf7-validation-errors {
  color: #B94A48;
  background-color: #F2DEDE;
  border: 1px solid #EED3D7;
}

.wpcf7 .wpcf7-submit .wpcf7-mail-sent-ok {
  color: #3A87AD;
  background-color: #D9EDF7;
  border: 1px solid #BCE8F1;
}

.wpcf7 .wpcf7-previous + br {
  display: none;
}

.wpcf7 form .wpcf7-response-output {
  margin: 2em 0.5em 2em;
  padding: 0;
  border: none;
  text-align: center;
}

.wpcf7 form.invalid .wpcf7-response-output, .wpcf7 form.unaccepted .wpcf7-response-output {
  color: #dc3232;
  font-size: 1em;
}

.text70 {
  font-size: 70%;
}

.text80 {
  font-size: 80%;
}

.text90 {
  font-size: 90%;
}

.text100 {
  font-size: 100%;
}

.text110 {
  font-size: 110%;
}

.text120 {
  font-size: 120%;
}

.text130 {
  font-size: 130%;
}

.text140 {
  font-size: 140%;
}

.text150 {
  font-size: 150%;
}

.text160 {
  font-size: 160%;
}

.text170 {
  font-size: 170%;
}

.text180 {
  font-size: 180%;
}

.text190 {
  font-size: 190%;
}

.text200 {
  font-size: 200%;
}

.text210 {
  font-size: 210%;
}

.text220 {
  font-size: 220%;
}

.b {
  font-weight: 700;
}

.u {
  text-decoration: underline;
}

.del {
  text-decoration: line-through;
}

.red {
  color: red;
}

.blue {
  color: #2ca9e1;
}

.green {
  color: #82ae46;
}

.orange {
  color: #ff7d00;
}

.yellow {
  color: #fff000;
}

.pink {
  color: #ff0084;
}

.gray {
  color: #999999;
}

.bg-blue {
  background-color: #4ab0f5;
  padding: 2px;
}

.bg-red {
  background-color: red;
  padding: 2px;
}

.bg-yellow {
  background-color: #ff0;
  padding: 2px;
}

.align1 {
  text-align: center !important;
}

.align2 {
  text-align: right !important;
}

.align3 {
  text-align: left !important;
}

.r-flo {
  float: right;
  margin: 10px;
}

.l-flo {
  float: left;
  margin: 10px;
}

.f-clear {
  clear: both;
}

a img.fade {
  background: none !important;
  outline: none;
  transition: all .3s;
}

a:hover img.fade {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha( opacity=70 )";
  background: none !important;
}

.att {
  padding-left: 1em;
  text-indent: -1em;
}

.att_box {
  margin: 2em 0 2.5em;
  padding: 1em 1.2em;
  line-height: 2.0;
  border: 1px dotted #cccccc;
  background: #fcfcfc;
}

.m0 {
  margin: 0 !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.ml0 {
  margin-left: 0 !important;
}

.m5 {
  margin: 5px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.ml5 {
  margin-left: 5px !important;
}

.m10 {
  margin: 10px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.m15 {
  margin: 15px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.m20 {
  margin: 20px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.m25 {
  margin: 25px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.m30 {
  margin: 30px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.m35 {
  margin: 35px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mr35 {
  margin-right: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.ml35 {
  margin-left: 35px !important;
}

.m40 {
  margin: 40px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.m45 {
  margin: 45px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mr45 {
  margin-right: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.ml45 {
  margin-left: 45px !important;
}

.m50 {
  margin: 50px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.m55 {
  margin: 55px !important;
}

.mt55 {
  margin-top: 55px !important;
}

.mr55 {
  margin-right: 55px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.ml55 {
  margin-left: 55px !important;
}

.m60 {
  margin: 60px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mr60 {
  margin-right: 60px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.ml60 {
  margin-left: 60px !important;
}

.m65 {
  margin: 65px !important;
}

.mt65 {
  margin-top: 65px !important;
}

.mr65 {
  margin-right: 65px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.ml65 {
  margin-left: 65px !important;
}

.m70 {
  margin: 70px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mr70 {
  margin-right: 70px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.ml70 {
  margin-left: 70px !important;
}

.m75 {
  margin: 75px !important;
}

.mt75 {
  margin-top: 75px !important;
}

.mr75 {
  margin-right: 75px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.ml75 {
  margin-left: 75px !important;
}

.m80 {
  margin: 80px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mr80 {
  margin-right: 80px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.ml80 {
  margin-left: 80px !important;
}

.p0 {
  padding: 0 !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pr0 {
  padding-right: 0 !important;
}

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

.pl0 {
  padding-left: 0 !important;
}

.p5 {
  padding: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pr5 {
  padding-right: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.pl5 {
  padding-left: 5px !important;
}

.p10 {
  padding: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pl10 {
  padding-left: 10px !important;
}

.p15 {
  padding: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pr15 {
  padding-right: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.pl15 {
  padding-left: 15px !important;
}

.p20 {
  padding: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.p25 {
  padding: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pr25 {
  padding-right: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.pl25 {
  padding-left: 25px !important;
}

.p30 {
  padding: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.p35 {
  padding: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pr35 {
  padding-right: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.pl35 {
  padding-left: 35px !important;
}

.p40 {
  padding: 40px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.p45 {
  padding: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pr45 {
  padding-right: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.pl45 {
  padding-left: 45px !important;
}

.p50 {
  padding: 50px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.p55 {
  padding: 55px !important;
}

.pt55 {
  padding-top: 55px !important;
}

.pr55 {
  padding-right: 55px !important;
}

.pb55 {
  padding-bottom: 55px !important;
}

.pl55 {
  padding-left: 55px !important;
}

.p60 {
  padding: 60px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pr60 {
  padding-right: 60px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.pl60 {
  padding-left: 60px !important;
}

.p65 {
  padding: 65px !important;
}

.pt65 {
  padding-top: 65px !important;
}

.pr65 {
  padding-right: 65px !important;
}

.pb65 {
  padding-bottom: 65px !important;
}

.pl65 {
  padding-left: 65px !important;
}

.p70 {
  padding: 70px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pr70 {
  padding-right: 70px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.pl70 {
  padding-left: 70px !important;
}

.p75 {
  padding: 75px !important;
}

.pt75 {
  padding-top: 75px !important;
}

.pr75 {
  padding-right: 75px !important;
}

.pb75 {
  padding-bottom: 75px !important;
}

.pl75 {
  padding-left: 75px !important;
}

.p80 {
  padding: 80px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pr80 {
  padding-right: 80px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.pl80 {
  padding-left: 80px !important;
}

.p-entry__body .a_break {
  display: inline-block;
}

.p-entry__body .e_link {
  display: inline-block;
  position: relative;
  padding-right: 1em;
}

.p-entry__body .e_link:after {
  font-family: 'design_plus';
  content: '\e92a';
  font-size: 100%;
  display: block;
  position: absolute;
  transition: none;
  margin-top: -0.1em;
  right: 0;
  top: 50%;
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.p-entry__body img.frame {
  border: 1px solid #d2d2d2;
  -webkit-box-shadow: 0 6px 6px -6px #cccccc;
  -moz-box-shadow: 0 6px 6px -6px #cccccc;
  box-shadow: 0 6px 6px -6px #cccccc;
}

li#menu-item-3023, 
li#menu-item-3299 {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 0 16px !important;
}

li#menu-item-3023 > a,
li#menu-item-3299 > a {
  display: flex !important;
  align-items: center;
  justify-content: center;
  height: 42px !important;
  line-height: 42px !important;
  padding: 0 26px !important;
  background: linear-gradient(135deg, #1a365d 0%, #086823 100%) !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  font-family: 'Outfit', 'Inter', "Noto Sans JP", sans-serif;
  border-radius: 4px !important;
  box-shadow: 0 4px 15px rgba(8, 104, 35, 0.15) !important;
  border: 0 !important;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease !important;
}

li#menu-item-3023 > a::after,
li#menu-item-3299 > a::after {
  display: none !important;
}

li#menu-item-3023 > a:hover,
li#menu-item-3299 > a:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 24px rgba(8, 104, 35, 0.28) !important;
  opacity: 0.95 !important;
  color: #ffffff !important;
}

.l-header {
  background: #ffffff !important;
}

.l-header__nav {
  background: #ffffff !important;
}

.p-global-nav {
  background: #ffffff !important;
  display: flex !important;
  align-items: center !important;
}

.p-global-nav > li,
.p-global-nav > li.current-menu-item,
.p-global-nav > li.current_page_item,
.p-global-nav > li.current-menu-ancestor {
  background: transparent !important;
  border: 0 !important;
}

.p-global-nav > li > a,
.p-global-nav > li.current-menu-item > a,
.p-global-nav > li.current_page_item > a,
.p-global-nav > li.current-menu-ancestor > a {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

.p-global-nav > li.current-menu-item > a,
.p-global-nav > li.current_page_item > a,
.p-global-nav > li.current-menu-ancestor > a {
  color: #086823 !important;
}

.p-global-nav > li > a {
  white-space: nowrap !important;
  padding: 0 14px !important;
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  color: #334155 !important;
}

.p-global-nav > li > a::after {
  bottom: 26px !important;
}

.p-index-content05__item--1 .p-article11__title {
  font-size: 0 !important;
}

.p-index-content05__item--1 .p-article11__title::before {
  content: "導入事例を確認する";
  font-size: 24px;
  font-weight: 700;
  color: #1a365d !important;
  display: block;
  margin-bottom: 2px;
  text-shadow: none !important;
}

.p-index-content05__item--1 .p-article11__sub {
  font-size: 0 !important;
}

.p-index-content05__item--1 .p-article11__sub::before {
  content: "CASE STUDY";
  font-size: 13px;
  font-weight: 700;
  color: #086823 !important;
  letter-spacing: 0.18em;
  display: block;
  text-shadow: none !important;
}

.p-index-content05__item--2 .p-article11__title {
  font-size: 0 !important;
}

.p-index-content05__item--2 .p-article11__title::before {
  content: "お問い合わせはこちら";
  font-size: 24px;
  font-weight: 700;
  color: #1a365d !important;
  display: block;
  margin-bottom: 2px;
  text-shadow: none !important;
}

.p-index-content05__item--2 .p-article11__sub {
  font-size: 0 !important;
}

.p-index-content05__item--2 .p-article11__sub::before {
  content: "CONTACT US";
  font-size: 13px;
  font-weight: 700;
  color: #086823 !important;
  letter-spacing: 0.18em;
  display: block;
  text-shadow: none !important;
}

.p-global-nav .sub-menu {
  background: #ffffff !important;
  background-color: #ffffff !important;
  border-radius: 6px !important;
  box-shadow: 0 10px 40px rgba(26, 54, 93, 0.12) !important;
  border: 1px solid rgba(26, 54, 93, 0.06) !important;
  padding: 8px 0 !important;
}

.p-global-nav .sub-menu li {
  background: transparent !important;
  background-color: transparent !important;
  border: 0 !important;
}

.p-global-nav .sub-menu a {
  color: #334155 !important;
  background: transparent !important;
  background-color: transparent !important;
  font-weight: 500 !important;
  display: block !important;
  width: 240px !important;
}

.p-global-nav .sub-menu a:hover {
  color: #086823 !important;
  background-color: rgba(8, 104, 35, 0.04) !important;
}

.p-global-nav .sub-menu li.current-menu-item > a,
.p-global-nav .sub-menu li.current_page_item > a {
  color: #086823 !important;
  font-weight: 700 !important;
}

.p-btn a {
  background-color: #086823;
  color: #fff !important;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(8, 104, 35, 0.2);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  border: none;
}

.p-btn a:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(8, 104, 35, 0.3);
  background-color: #06541c;
  color: #fff !important;
}

.p-article09 {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  margin-bottom: 40px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.p-article09:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
  border-left: 4px solid #086823;
}

.p-article09__content {
  border: none !important;
}

.p-article09--rev .p-article09__content,
.p-article05--rev .p-article05__content {
  border: none !important;
}

.p-article05 {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  margin-bottom: 40px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.05);
}

.p-article05:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
  border-left: 4px solid #086823;
}

.p-article05__content {
  border: none !important;
}

.p-breadcrumb-wrapper {
  border-bottom: 1px solid rgba(0,0,0,0.05);
  background-color: #fafbfc;
}

.p-breadcrumb {
  border-bottom: none;
  background-color: transparent;
}

.p-breadcrumb__item a {
  color: #555;
  transition: color 0.2s ease;
}

.p-breadcrumb__item a:hover {
  color: #086823;
}

.p-global-nav > li:has(a[href*="inquiry"]) {
  display: flex !important;
  align-items: center !important;
  margin-left: 10px !important;
}

.p-global-nav a[href*="inquiry"] {
  background-color: #086823 !important;
  color: #fff !important;
  border-radius: 8px !important;
  border: none !important;
  font-weight: bold;
  padding: 12px 24px !important;
  box-shadow: 0 4px 12px rgba(8, 104, 35, 0.2);
  display: flex !important;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease;
}

.p-global-nav a[href*="inquiry"]::before {
  content: "\f0e0";
  font-family: "design_plus", sans-serif;
  margin-right: 8px;
}

.p-global-nav a[href*="inquiry"]:hover {
  background-color: #06541c !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(8, 104, 35, 0.3);
}

.p-accordion-nav > li:has(a[href*="inquiry"]) {
  width: 100% !important;
  flex: 0 0 100% !important;
  margin-top: 10px !important;
  border: none !important;
}

.p-accordion-nav a[href*="inquiry"] {
  background-color: #086823 !important;
  color: #fff !important;
  border-radius: 8px !important;
  border: none !important;
  text-align: center !important;
  font-weight: bold;
  margin: 10px auto;
  width: 90%;
  padding: 14px 20px !important;
  box-shadow: 0 4px 12px rgba(8, 104, 35, 0.3);
  display: flex !important;
  justify-content: center;
  align-items: center;
}

.p-accordion-nav a[href*="inquiry"]::before {
  content: "\f0e0";
  font-family: "design_plus", sans-serif;
  margin-right: 8px;
}

.p-accordion-nav a[href*="inquiry"]:hover {
  background-color: #06541c !important;
}

.p-works-entry table,
.p-entry__body table {
  width: 100%;
  border-collapse: separate !important;
  border-spacing: 0;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
  margin-bottom: 2em;
}

.p-works-entry table th,
.p-works-entry table td,
.p-entry__body table th,
.p-entry__body table td {
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
  padding: 16px 20px !important;
  vertical-align: middle;
}

.p-works-entry table th,
.p-entry__body table th {
  background-color: #f7f9fc !important;
  font-weight: 700;
  color: #333;
  width: 30%;
}

.p-works-entry table tr:hover td,
.p-entry__body table tr:hover td {
  background-color: rgba(8, 104, 35, 0.02);
}

.p-entry__title, 
h2.p-entry__title,
.p-entry__body h2 {
  position: relative;
  padding-left: 20px;
  border-left: 4px solid #086823;
  background: transparent;
  padding-bottom: 10px;
  border-bottom: 1px solid #eaeaea;
}

.p-entry__title::before,
h2.p-entry__title::before,
.p-entry__body h2::before {
  content: none;
}

.p-archive-header {
  box-shadow: none !important;
  border-bottom: 1px solid #eaeaea;
}

.p-archive-header::before, 
.p-archive-header::after {
  display: none !important;
}

.p-index-content01__bg-text,
.p-index-content02__bg-text,
.p-index-content03__bg-text,
.p-index-content04__bg-text,
.p-index-content05__bg-text {
  display: none !important;
}

.p-footer-banners__list-item.p-banner {
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  height: auto !important;
}

.p-footer-banners__list-item.p-banner img,
.p-footer-banners__list-item.p-banner .p-banner__content {
  display: none !important;
}

.p-footer-banners__list-item.p-banner a {
  display: flex !important;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  min-height: 100px;
  border-radius: 8px;
  text-decoration: none;
  box-shadow: 0 4px 16px rgba(0,0,0,0.05);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
  overflow: hidden;
  padding: 0 20px;
}

.p-footer-banners__list-item.p-banner a::before {
  font-family: "design_plus", sans-serif;
  font-size: 22px;
  margin-right: 12px;
  transition: all 0.3s ease;
}

.p-footer-banners__list-item.p-banner a::after {
  font-size: 18px;
  font-weight: 700;
  transition: color 0.3s ease;
  z-index: 2;
  position: relative;
}

.p-footer-banners__list-item.p-banner a[href*="inquiry"] {
  background-color: #086823;
  border: 1px solid #086823;
}

.p-footer-banners__list-item.p-banner a[href*="inquiry"]::before {
  content: "\f0e0";
  color: #fff;
}

.p-footer-banners__list-item.p-banner a[href*="inquiry"]::after {
  content: "お問い合わせ";
  color: #fff;
}

.p-footer-banners__list-item.p-banner:hover a[href*="inquiry"] {
  background-color: #06541c;
  border-color: #06541c;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(8, 104, 35, 0.25);
}

.p-footer-banners__list-item.p-banner a[href*="downloiad"] {
  background-color: #fff;
  border: 2px solid #086823;
}

.p-footer-banners__list-item.p-banner a[href*="downloiad"]::before {
  content: "\f15c";
  color: #086823;
}

.p-footer-banners__list-item.p-banner a[href*="downloiad"]::after {
  content: "資料ダウンロード";
  color: #086823;
}

.p-footer-banners__list-item.p-banner:hover a[href*="downloiad"] {
  background-color: #086823;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(8, 104, 35, 0.2);
}

.p-footer-banners__list-item.p-banner:hover a[href*="downloiad"]::before,
.p-footer-banners__list-item.p-banner:hover a[href*="downloiad"]::after {
  color: #fff;
}

.p-footer-banners__list-item.p-banner a[href*="company"] {
  background-color: #2c3e50;
  border: 1px solid #2c3e50;
}

.p-footer-banners__list-item.p-banner a[href*="company"]::before {
  content: "\e93b";
  color: #fff;
}

.p-footer-banners__list-item.p-banner a[href*="company"]::after {
  content: "アクセス・会社概要";
  color: #fff;
}

.p-footer-banners__list-item.p-banner:hover a[href*="company"] {
  background-color: #1a252f;
  border-color: #1a252f;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(44, 62, 80, 0.3);
}

.p-footer-banners__list-item.p-banner:hover,
.p-footer-banners__list-item:hover .p-banner {
  transform: none !important;
  box-shadow: none !important;
}

@media only screen and (max-width: 1199px) {
  .l-header {
    box-shadow: none;
  }

  .l-header__nav {
    background: #ffffff;
    border-top: 1px solid #eee;
    box-shadow: 0 10px 30px rgba(0,0,0,0.1);
  }

  .p-global-nav {
    line-height: normal;
  }

  .p-global-nav > li {
    display: block;
  }

  .p-global-nav > li > a {
    display: flex !important;
    align-items: center;
    line-height: 1.3 !important;
    min-height: 50px;
    text-align: left;
    white-space: normal !important;
  }

  .p-global-nav > li > a::after {
    display: none;
  }

  li#menu-item-3023, 
  li#menu-item-3299 {
    display: block !important;
    padding: 0 !important;
    width: calc((50% - 6px)) !important;
    margin: 0 0 12px 0 !important;
  }

  li#menu-item-3023 > a,
  li#menu-item-3299 > a {
    display: block !important;
    height: 50px !important;
    line-height: 50px !important;
    padding: 0 5.55556% !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #086823 !important;
    font-weight: 600 !important;
    text-align: left !important;
    transition: none !important;
  }

  li#menu-item-3023 > a:hover,
  li#menu-item-3299 > a:hover {
    transform: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
  }

}

@media screen and (max-width: 767px) {
  .p-news-tab-list {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .p-news-tab-list__panel.p-news-list {
    margin-bottom: 20px !important;
  }

  .p-article04__inner {
    padding: 16px 20px !important;
    height: auto !important;
    line-height: 1.6 !important;
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  .p-article04__date {
    margin-right: 0 !important;
    margin-bottom: 6px !important;
    font-size: 13px !important;
  }

  .p-article04__title {
    font-size: 13.5px !important;
    width: 100% !important;
    white-space: normal !important;
  }

  .p-article04__title a {
    white-space: normal !important;
  }

  .p-article04:hover .p-article04__title a {
    transform: translateX(4px) !important;
  }

  .p-works-list__item.p-article06 {
    padding: 16px !important;
    margin-bottom: 20px !important;
  }

  .p-article06__content {
    padding-top: 14px !important;
  }

  .p-article06__title {
    font-size: 15px !important;
    margin-bottom: 8px !important;
  }

  .p-article06__excerpt {
    font-size: 12.5px !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  .p-article11 a:hover {
    transform: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  }

  .p-article11__title {
    font-size: 20px;
    margin-bottom: 4px;
  }

  .p-article11__sub {
    font-size: 11px;
    letter-spacing: 0.12em;
  }

  .p-index-content04__list.p-three-box {
    gap: 16px !important;
  }

  .p-three-box__item.p-article12 {
    width: 100% !important;
    margin-bottom: 16px !important;
  }

  .p-article12 a {
    height: 280px !important;
  }

  .p-cover {
    margin-top: 50px;
  }

  .p-footer-banners {
    padding: 48px 0;
  }

  .p-index-content05 {
    margin-top: 30px;
  }

  .p-index-content05__item:nth-child(n+3) {
    margin-top: 0;
  }

  .p-index-content05__item-banner:hover {
    transform: none;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04);
  }

  .p-index-content05__item-banner img {
    display: none !important;
  }

  .p-article11__svg-container {
    right: 20px;
    width: 60px;
    height: 60px;
  }

  .p-index-content05__item-banner .p-article11__content {
    padding: 16px 95px 16px 24px;
  }

  .p-index-content05__item--1 .p-index-content05__item-banner .p-article11__title::before,
  .p-index-content05__item--2 .p-index-content05__item-banner .p-article11__title::before,
  .p-index-content05__item--3 .p-index-content05__item-banner .p-article11__title::before {
    font-size: 20px !important;
  }

  .p-index-content05__item--1 .p-index-content05__item-banner .p-article11__sub::before,
  .p-index-content05__item--2 .p-index-content05__item-banner .p-article11__sub::before,
  .p-index-content05__item--3 .p-index-content05__item-banner .p-article11__sub::before {
    font-size: 11px !important;
  }

  .p-index-content05__item-banner .p-article11__title {
    font-size: 20px;
    margin-bottom: 4px;
  }

  .p-index-content05__item-banner .p-article11__sub {
    font-size: 11px;
    letter-spacing: 0.12em;
  }

  .style2a {
    margin: 30px 0 20px !important;
    padding: 0 0 .6em;
    font-size: 20px !important;
  }

  .style2b {
    margin: 30px 0 20px !important;
    padding: .42em .7em .41em;
    font-size: 20px !important;
    color: #fff;
    background: #000;
  }

  .style3a {
    margin: 30px 0 20px !important;
    padding: .6em .15em;
    font-size: 18px !important;
  }

  .style3b {
    margin: 30px 0 20px !important;
    padding: .5em .5em .45em .6em;
    font-size: 18px !important;
  }

  .style4a {
    margin: 30px 0 20px !important;
    padding: .4em 0 .4em .8em;
    border-left: 2px solid #000;
    font-size: 16px !important;
  }

  .style4b {
    margin: 30px 0 20px !important;
    padding: .8em 1em .75em;
    border-left: #000 2px solid;
    font-size: 16px !important;
  }

  .style5a {
    margin: 30px 0 20px !important;
    padding: .8em 1em .75em;
    font-size: 15px !important;
  }

  .style5b {
    margin: 30px 0 20px !important;
    padding: .8em 1em .75em;
    font-size: 15px !important;
  }

  .well, .well2, .well3 {
    padding: .9em .8em .9em 1em;
  }

  .sz_l {
    box-sizing: border-box;
    max-width: 100%;
    min-width: 0;
    width: 100%;
  }

  .cardlink_timestamp {
    display: none;
  }

}

@media screen and (max-width: 991px) {
  .p-index-content04__list.p-three-box {
    gap: 20px !important;
  }

  .p-three-box__item.p-article12 {
    width: calc(50% - 10px) !important;
  }

  .p-article12 a {
    height: 320px !important;
  }

  .p-footer-banners__list {
    gap: 20px;
  }

  .p-footer-banners__list-item {
    width: 60%;
  }

}

@media screen and (max-width: 600px) {
  .p-footer-banners__list {
    gap: 14px;
  }

}

@media screen and (max-width:1199px) {
  #header_lang_button:before {
    font-family: 'design_plus';
    display: block;
    position: absolute;
    top: 22px;
    left: 0;
    right: 0;
    margin: auto;
    font-size: 18px;
    width: 18px;
    height: 18px;
    line-height: 18px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

}

@media screen and (min-width: 768px) {
  .post_col-2 {
    width: 50%;
  }

  .post_col-3 {
    width: 33.33333%;
  }

}

@media screen and (min-width: 1024px) {
  .post_col-2 {
    width: 50%;
  }

  .post_col-3 {
    width: 33.33333%;
  }

}

@media only screen and (max-width: 567px) {
  .rps_table tr {
    display: block;
    margin-bottom: 1.5em;
  }

  .rps_table th, .rps_table td {
    display: list-item;
    list-style-type: none;
  }

  .rps_table td {
    border-top: none;
  }

}

@media screen and (-ms-high-contrast: active), screen and (-ms-high-contrast: none) {
  .cardlink_thumbnail img {
    height: auto;
  }

}

@media screen and (max-width: 567px) {
  .cardlink {
    padding: 15px 11px 12px 13px;
  }

  .cardlink_thumbnail {
    float: left;
    margin-bottom: 10px;
    margin-right: 12px;
  }

  .cardlink_thumbnail img {
    width: 100px;
    height: 100px;
  }

  .cardlink_title {
    font-size: 14px;
    margin-top: -5px;
  }

  .cardlink_excerpt {
    clear: both;
  }

}

@media (max-width: 767px) {
  .p-entry__body .is-pc {
    display: none!important;
  }

  .p-entry__body .s_table {
    overflow: auto;
    white-space: nowrap;
    margin-bottom: 2em;
  }

  .p-entry__body .s_table table {
    margin-bottom: 0;
  }

}

@media not all and (max-width: 767px) {
  .p-entry__body .is-sp {
    display: none!important;
  }

}



/* ==========================================================
   グローバルナビゲーション「お問い合わせ」の極上プレミアムCTAボタン化
   ========================================================== */
li#menu-item-3023, 
li#menu-item-3299 {
  display: flex !important;
  align-items: center;
  justify-content: center;
  padding: 0 16px !important;
}

li#menu-item-3023 > a,
li#menu-item-3299 > a {
    display: flex !important;
    align-items: center;
    justify-content: center;
    height: 42px !important;
    line-height: 42px !important;
    padding: 0 26px !important;
    background: linear-gradient(135deg, #1a365d 0%, #086823 100%) !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    font-family: 'Outfit', 'Inter', "Noto Sans JP", sans-serif;
    border-radius: 4px !important;
    box-shadow: 0 4px 15px rgba(8, 104, 35, 0.15) !important;
    border: 0 !important;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease !important;
}

li#menu-item-3023 > a::after,
li#menu-item-3299 > a::after {
    display: none !important; /* 通常のホバーラインを非表示にする */
}

li#menu-item-3023 > a:hover,
li#menu-item-3299 > a:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 24px rgba(8, 104, 35, 0.28) !important;
    opacity: 0.95 !important;
    color: #ffffff !important;
}

@media only screen and (max-width: 1199px) { 
  li#menu-item-3023, 
  li#menu-item-3299 {
    display: block !important;
    padding: 0 !important;
    width: calc((50% - 6px)) !important;
    margin: 0 0 12px 0 !important;
  }
  li#menu-item-3023 > a,
  li#menu-item-3299 > a {
    display: block !important;
    height: 50px !important;
    line-height: 50px !important;
    padding: 0 5.55556% !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #086823 !important; /* スマホ折りたたみ時はソリッドなForest Green */
    font-weight: 600 !important;
    text-align: left !important;
    transition: none !important;
  }
  li#menu-item-3023 > a:hover,
  li#menu-item-3299 > a:hover {
    transform: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
  }
}

/* ==========================================================
   グローバルナビゲーションのプレミアムバグ修正と極上化
   ========================================================== */
.l-header {
  background: #ffffff !important;
}

.l-header__nav {
  background: #ffffff !important;
}

.p-global-nav {
  background: #ffffff !important;
  display: flex !important;
  align-items: center !important;
}

/* TCDやWordPressの強制黄緑背景を100%確実に消去 */
.p-global-nav > li,
.p-global-nav > li.current-menu-item,
.p-global-nav > li.current_page_item,
.p-global-nav > li.current-menu-ancestor {
  background: transparent !important;
  border: 0 !important;
}

.p-global-nav > li > a,
.p-global-nav > li.current-menu-item > a,
.p-global-nav > li.current_page_item > a,
.p-global-nav > li.current-menu-ancestor > a {
  background: transparent !important;
  background-color: transparent !important;
  box-shadow: none !important;
  border: 0 !important;
}

/* アクティブ項目時のテキストカラー */
.p-global-nav > li.current-menu-item > a,
.p-global-nav > li.current_page_item > a,
.p-global-nav > li.current-menu-ancestor > a {
  color: #086823 !important; /* Stitch Forest Green */
}

/* 「選ばれる5つの理由」等の改行を防止し、1行で完璧に整列させる */
.p-global-nav > li > a {
  white-space: nowrap !important;
  padding: 0 14px !important; /* 左右余白を最適化 */
  height: 100% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  color: #334155 !important;
  line-height: 1.3 !important;
}

/* ホバーラインの調整 */
.p-global-nav > li > a::after {
  bottom: 26px !important;
}

/* ==========================================================
   全3バナー：デジタルテキスト上書き統一（焼き込み文字の完全刷新）
   元の画像に焼き込まれている解像度の低い古い文字を白マスクで覆い隠し、
   モダンで美しい統一されたデジタルフォントで上書き描写します。
   ========================================================== */

/* 1枚目バナー（導入事例を確認する） */
.p-index-content05__item--1 .p-article11__title { font-size: 0 !important; }
.p-index-content05__item--1 .p-article11__title::before { 
  content: "導入事例を確認する"; 
  font-size: 24px; 
  font-weight: 700; 
  color: #1a365d !important; /* Stitch Deep Navy */
  display: block; 
  margin-bottom: 2px;
  text-shadow: none !important;
}
.p-index-content05__item--1 .p-article11__sub { font-size: 0 !important; }
.p-index-content05__item--1 .p-article11__sub::before { 
  content: "CASE STUDY"; 
  font-size: 13px; 
  font-weight: 700; 
  color: #086823 !important; /* Stitch Forest Green */
  letter-spacing: 0.18em; 
  display: block; 
  text-shadow: none !important;
}

/* 2枚目バナー（お問い合わせはこちら） */
.p-index-content05__item--2 .p-article11__title { font-size: 0 !important; }
.p-index-content05__item--2 .p-article11__title::before { 
  content: "お問い合わせはこちら"; 
  font-size: 24px; 
  font-weight: 700; 
  color: #1a365d !important; /* Stitch Deep Navy */
  display: block; 
  margin-bottom: 2px;
  text-shadow: none !important;
}
.p-index-content05__item--2 .p-article11__sub { font-size: 0 !important; }
.p-index-content05__item--2 .p-article11__sub::before { 
  content: "CONTACT US"; 
  font-size: 13px; 
  font-weight: 700; 
  color: #086823 !important; /* Stitch Forest Green */
  letter-spacing: 0.18em; 
  display: block; 
  text-shadow: none !important;
}

/* ==========================================================
   子メニュー（sub-menu）のプレミアム配色バグ修正
   TCDのいかなる強制上書きも防ぎ、上品な白背景＆グレー文字を保証します
   ========================================================== */
.p-global-nav .sub-menu {
  background: #ffffff !important;
  background-color: #ffffff !important;
  border-radius: 6px !important;
  box-shadow: 0 10px 40px rgba(26, 54, 93, 0.12) !important;
  border: 1px solid rgba(26, 54, 93, 0.06) !important;
  padding: 8px 0 !important;
}

.p-global-nav .sub-menu li {
  background: transparent !important;
  background-color: transparent !important;
  border: 0 !important;
}

.p-global-nav .sub-menu a {
  color: #334155 !important; /* 上品な濃いグレー（Stitch仕様） */
  background: transparent !important;
  background-color: transparent !important;
  font-weight: 500 !important;
  display: block !important;
  width: 240px !important;
}

.p-global-nav .sub-menu a:hover {
  color: #086823 !important; /* Stitch Forest Green */
  background-color: rgba(8, 104, 35, 0.04) !important; /* 非常に薄い緑背景 */
}

/* 子メニューの中のアクティブ項目も考慮 */
.p-global-nav .sub-menu li.current-menu-item > a,
.p-global-nav .sub-menu li.current_page_item > a {
  color: #086823 !important;
  font-weight: 700 !important;
}
/* ==========================================================
   Stitch Premium Design v2: Components & Mobile Nav
   ========================================================== */

/* 1. トップページ等：標準ボタン (.p-btn a) */
.p-btn a {
  background-color: #086823;
  color: #fff !important;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(8, 104, 35, 0.2);
  transition: all 0.3s ease;
  position: relative;
  overflow: hidden;
  border: none;
}
.p-btn a:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(8, 104, 35, 0.3);
  background-color: #06541c;
  color: #fff !important;
}

/* 2. 製品一覧の交互レイアウト (.p-article09) */
.p-article09 {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  margin-bottom: 40px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.05);
}
.p-article09:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
  border-left: 4px solid #086823;
}
.p-article09__content {
  border: none !important;
}
.p-article09--rev .p-article09__content,
.p-article05--rev .p-article05__content {
  border: none !important;
}

/* 2.5. 会社概要などの交互レイアウト (.p-article05) */
.p-article05 {
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  margin-bottom: 40px;
  background: #fff;
  border: 1px solid rgba(0, 0, 0, 0.05);
}
.p-article05:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.08);
  border-left: 4px solid #086823;
}
.p-article05__content {
  border: none !important;
}

.p-breadcrumb-wrapper {
  border-bottom: 1px solid rgba(0,0,0,0.05);
  background-color: #fafbfc;
}
.p-breadcrumb {
  border-bottom: none;
  background-color: transparent;
}
.p-breadcrumb__item a {
  color: #555;
  transition: color 0.2s ease;
}
.p-breadcrumb__item a:hover {
  color: #086823;
}

/* 4.1. PC用グローバルメニュー内の「お問い合わせ」ボタン */
.p-global-nav > li:has(a[href*="inquiry"]) {
  display: flex !important;
  align-items: center !important;
  margin-left: 10px !important;
}
.p-global-nav a[href*="inquiry"] {
  background-color: #086823 !important;
  color: #fff !important;
  border-radius: 8px !important;
  border: none !important;
  font-weight: bold;
  padding: 12px 24px !important;
  box-shadow: 0 4px 12px rgba(8, 104, 35, 0.2);
  display: flex !important;
  justify-content: center;
  align-items: center;
  transition: all 0.3s ease;
}
.p-global-nav a[href*="inquiry"]::before {
  content: "\f0e0";
  font-family: "design_plus", sans-serif;
  margin-right: 8px;
}
.p-global-nav a[href*="inquiry"]:hover {
  background-color: #06541c !important;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(8, 104, 35, 0.3);
}

/* 4.2. モバイル用メニュー内の「お問い合わせ」ボタン */
.p-accordion-nav > li:has(a[href*="inquiry"]) {
  width: 100% !important;
  flex: 0 0 100% !important;
  margin-top: 10px !important;
  border: none !important;
}
.p-accordion-nav a[href*="inquiry"] {
  background-color: #086823 !important;
  color: #fff !important;
  border-radius: 8px !important;
  border: none !important;
  text-align: center !important;
  font-weight: bold;
  margin: 10px auto;
  width: 90%;
  padding: 14px 20px !important;
  box-shadow: 0 4px 12px rgba(8, 104, 35, 0.3);
  display: flex !important;
  justify-content: center;
  align-items: center;
}
.p-accordion-nav a[href*="inquiry"]::before {
  content: "\f0e0";
  font-family: "design_plus", sans-serif;
  margin-right: 8px;
}
.p-accordion-nav a[href*="inquiry"]:hover {
  background-color: #06541c !important;
}

/* 5. 記事内のテーブル共通装飾 (会社概要・導入事例・設備表など) */
.p-works-entry table,
.p-entry__body table {
  width: 100%;
  border-collapse: separate !important;
  border-spacing: 0;
  border: 1px solid rgba(0, 0, 0, 0.08) !important;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.02);
  margin-bottom: 2em;
}
.p-works-entry table th,
.p-works-entry table td,
.p-entry__body table th,
.p-entry__body table td {
  border: 1px solid rgba(0, 0, 0, 0.05) !important;
  padding: 16px 20px !important;
  vertical-align: middle;
}
.p-works-entry table th,
.p-entry__body table th {
  background-color: #f7f9fc !important;
  font-weight: 700;
  color: #333;
  width: 30%;
}
.p-works-entry table tr:hover td,
.p-entry__body table tr:hover td {
  background-color: rgba(8, 104, 35, 0.02);
}

/* 6. 見出しの装飾（三角のアクセント） */
.p-entry__title, 
h2.p-entry__title,
.p-entry__body h2 {
  position: relative;
  padding-left: 20px;
  border-left: 4px solid #086823;
  background: transparent;
  padding-bottom: 10px;
  border-bottom: 1px solid #eaeaea;
}
.p-entry__title::before,
h2.p-entry__title::before,
.p-entry__body h2::before {
  content: none;
}

/* 7. サイドバー上部 (.p-archive-header) の不要なグラデーションとシャドウ削除 */
.p-archive-header {
  box-shadow: none !important;
  border-bottom: 1px solid #eaeaea;
}
.p-archive-header::before, 
.p-archive-header::after {
  display: none !important;
}

/* 8. 薄い不要な文字（background text）の削除 */
.p-index-content01__bg-text,
.p-index-content02__bg-text,
.p-index-content03__bg-text,
.p-index-content04__bg-text,
.p-index-content05__bg-text {
  display: none !important;
}


/* 9. フッターCTA画像のCSSボタン化 (.p-footer-banners) */
.p-footer-banners__list-item.p-banner {
  background: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  height: auto !important;
}
.p-footer-banners__list-item.p-banner img,
.p-footer-banners__list-item.p-banner .p-banner__content {
  display: none !important; /* 画像と空のコンテンツを隠す */
}
.p-footer-banners__list-item.p-banner a {
  display: flex !important;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  min-height: 100px;
  border-radius: 8px;
  text-decoration: none;
  box-shadow: 0 4px 16px rgba(0,0,0,0.05);
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
  overflow: hidden;
  padding: 0 20px;
}
.p-footer-banners__list-item.p-banner a::before {
  font-family: "design_plus", sans-serif;
  font-size: 22px;
  margin-right: 12px;
  transition: all 0.3s ease;
}
.p-footer-banners__list-item.p-banner a::after {
  font-size: 18px;
  font-weight: 700;
  transition: color 0.3s ease;
  z-index: 2;
  position: relative;
}

/* 1. お問い合わせ (Primary CTA - 深緑ベタ塗り) */
.p-footer-banners__list-item.p-banner a[href*="inquiry"] {
  background-color: #086823;
  border: 1px solid #086823;
}
.p-footer-banners__list-item.p-banner a[href*="inquiry"]::before {
  content: "\f0e0";
  color: #fff;
}
.p-footer-banners__list-item.p-banner a[href*="inquiry"]::after {
  content: "お問い合わせ";
  color: #fff;
}
.p-footer-banners__list-item.p-banner:hover a[href*="inquiry"] {
  background-color: #06541c;
  border-color: #06541c;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(8, 104, 35, 0.25);
}

/* 2. 資料ダウンロード (Secondary CTA - 白背景に緑枠線) */
.p-footer-banners__list-item.p-banner a[href*="downloiad"] {
  background-color: #fff;
  border: 2px solid #086823;
}
.p-footer-banners__list-item.p-banner a[href*="downloiad"]::before {
  content: "\f15c";
  color: #086823;
}
.p-footer-banners__list-item.p-banner a[href*="downloiad"]::after {
  content: "資料ダウンロード";
  color: #086823;
}
.p-footer-banners__list-item.p-banner:hover a[href*="downloiad"] {
  background-color: #086823;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(8, 104, 35, 0.2);
}
.p-footer-banners__list-item.p-banner:hover a[href*="downloiad"]::before,
.p-footer-banners__list-item.p-banner:hover a[href*="downloiad"]::after {
  color: #fff;
}

/* 3. アクセス・会社概要 (Tertiary CTA - ネイビーベタ塗り) */
.p-footer-banners__list-item.p-banner a[href*="company"] {
  background-color: #2c3e50;
  border: 1px solid #2c3e50;
}
.p-footer-banners__list-item.p-banner a[href*="company"]::before {
  content: "\e93b";
  color: #fff;
}
.p-footer-banners__list-item.p-banner a[href*="company"]::after {
  content: "アクセス・会社概要";
  color: #fff;
}
.p-footer-banners__list-item.p-banner:hover a[href*="company"] {
  background-color: #1a252f;
  border-color: #1a252f;
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(44, 62, 80, 0.3);
}

/* Base hover state reset */
.p-footer-banners__list-item.p-banner:hover,
.p-footer-banners__list-item:hover .p-banner {
  transform: none !important;
  box-shadow: none !important;
}

/* ==========================================================
   ヘッダー縦幅の縮小 (2/3化: 約132px) および関連位置の調整 (PC用)
   ========================================================== */
@media only screen and (min-width: 1200px) {
  /* ヘッダー上部エリアの高さを 100px -> 66px に縮小 */
  .l-header__inner {
    height: 66px !important;
  }

  /* ロゴ画像の最大高さを縮小に合わせて調整 */
  .l-header__logo img {
    max-height: 46px !important;
    width: auto !important;
  }

  /* グローバルナビゲーションの高さを 100px -> 66px に縮小 */
  .p-global-nav {
    line-height: 66px !important;
    height: 66px !important;
    align-items: stretch !important;
  }

  /* メニューホバー時の下線位置を調整 (文字に被らないよう bottom を 12px に) */
  .p-global-nav > li > a::after {
    bottom: 12px !important;
  }

  /* 固定ヘッダー有効時のメインコンテンツのパディングトップを全体の高さに合わせて上書き */
  .l-header--fixed.is-active + .l-main {
    padding-top: 132px !important;
  }

  /* ページ内スクロール位置の調整 */
  html:has(.l-header--fixed) {
    scroll-padding-top: 132px !important;
  }

  /* 言語切り替えボタンおよびメニューの高さ・位置調整 */
  #header_lang.type1 li a {
    height: 66px !important;
    line-height: 66px !important;
  }
  #header_lang.type1 img {
    top: 23px !important;
  }
  #header_lang.type2 > ul > li > a {
    height: 66px !important;
    line-height: 66px !important;
  }
  #header_lang_button {
    height: 66px !important;
    line-height: 66px !important;
  }
  #header_lang ul,
  #header_lang.type2 ul ul {
    top: 66px !important;
  }

  /* メガメニューの表示位置を 160px -> 132px に調整 (管理バー表示時は 164px) */
  .p-megamenu01,
  .p-megamenu02 {
    top: 132px !important;
  }
  .admin-bar .p-megamenu01,
  .admin-bar .p-megamenu02 {
    top: 164px !important;
  }
}

/* ==========================================================
   資料ダウンロードページ (/downloiad/): 画像リンクの角丸・ホバー効果
   ========================================================== */
/* 対象ページID: 2064 (downloiad) */
.page-id-2064 .so-widget-sow-image img,
.page-id-2064 .sow-image-container img {
  border-radius: 12px !important;
  border: 6px solid #ffffff !important;
  box-sizing: border-box !important;
  transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  box-shadow: 0 4px 15px rgba(26, 54, 93, 0.06) !important;
  display: block;
}

/* リンク付き画像のホバー時に浮き上がりと影の広がりを適用 */
.page-id-2064 .so-widget-sow-image a:hover img,
.page-id-2064 .sow-image-container a:hover img {
  transform: translateY(-6px) !important;
  box-shadow: 0 16px 32px rgba(8, 104, 35, 0.15) !important;
}

/* ==========================================================
   お問い合わせフォーム (.inquiry): 必須・任意ラベルの装飾
   ========================================================== */
.inquiry .haveto,
.inquiry .any {
  display: inline-block !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  padding: 3px 8px !important;
  border-radius: 4px !important;
  color: #ffffff !important;
  text-align: center !important;
  margin-right: 8px !important;
  vertical-align: middle !important;
  line-height: 1.2 !important;
}

.inquiry .haveto {
  background-color: #dd2c00 !important; /* 必須：ビビッドな朱赤 */
}

.inquiry .any {
  background-color: #78909c !important; /* 任意：落ち着いたブルーグレー */
}

/* ==========================================================
   導入事例一覧 (works): 仕切り線と事例カード群との間に余白を追加
   ========================================================== */
.p-works-list {
  margin-top: 50px !important;
}

@media only screen and (max-width: 767px) {
  .p-works-list {
    margin-top: 30px !important;
  }
}

